diff options
author | Christoph Wurst <christoph@winzerhof-wurst.at> | 2017-04-11 09:09:45 +0200 |
---|---|---|
committer | Christoph Wurst <christoph@winzerhof-wurst.at> | 2017-04-25 20:47:17 +0200 |
commit | 2c2e1f7988df795d8f85a3003f84fa646c701380 (patch) | |
tree | 79c6ccf13e2efd5228f5d1971f171c9de42ef23d | |
parent | b8c2a8ae36235780675103286a04f8b6af50b4aa (diff) | |
download | nextcloud-server-2c2e1f7988df795d8f85a3003f84fa646c701380.tar.gz nextcloud-server-2c2e1f7988df795d8f85a3003f84fa646c701380.zip |
Use absolute URI for action icons
Signed-off-by: Christoph Wurst <christoph@winzerhof-wurst.at>
-rw-r--r-- | core/js/contactsmenu.js | 6 | ||||
-rw-r--r-- | lib/private/Contacts/ContactsMenu/Providers/EMailProvider.php | 12 | ||||
-rw-r--r-- | tests/lib/Contacts/ContactsMenu/Providers/EMailproviderTest.php | 19 |
3 files changed, 29 insertions, 8 deletions
diff --git a/core/js/contactsmenu.js b/core/js/contactsmenu.js index bf469b8a321..2e33b5e7c64 100644 --- a/core/js/contactsmenu.js +++ b/core/js/contactsmenu.js @@ -58,7 +58,9 @@ + ' <div class="last-message">{{contact.lastMessage}}</div>' + '</div>' + '{{#if contact.topAction}}' - + '<a class="top-action {{contact.topAction.icon}}" href="{{contact.topAction.hyperlink}}" title="{{contact.topAction.title}}"></a>' + + '<a class="top-action" href="{{contact.topAction.hyperlink}}" title="{{contact.topAction.title}}">' + + ' <img src="{{contact.topAction.icon}}">' + + '</a>' + '{{/if}}' + '{{#if contact.hasManyActions}}' + ' <span class="other-actions icon-more"></span>' @@ -67,7 +69,7 @@ + ' {{#each contact.actions}}' + ' <li>' + ' <a href="{{hyperlink}}">' - + ' <span class="{{icon}}"></span>' + + ' <img src="{{icon}}">' + ' <span>{{title}}</span>' + ' </a>' + ' </li>' diff --git a/lib/private/Contacts/ContactsMenu/Providers/EMailProvider.php b/lib/private/Contacts/ContactsMenu/Providers/EMailProvider.php index 18e7ad8cddb..d5630e6420d 100644 --- a/lib/private/Contacts/ContactsMenu/Providers/EMailProvider.php +++ b/lib/private/Contacts/ContactsMenu/Providers/EMailProvider.php @@ -27,26 +27,32 @@ namespace OC\Contacts\ContactsMenu\Providers; use OCP\Contacts\ContactsMenu\IActionFactory; use OCP\Contacts\ContactsMenu\IEntry; use OCP\Contacts\ContactsMenu\IProvider; +use OCP\IURLGenerator; class EMailProvider implements IProvider { /** @var IActionFactory */ private $actionFactory; + /** @var IURLGenerator */ + private $urlGenerator; + /** * @param IActionFactory $actionFactory + * @param IURLGenerator $urlGenerator */ - public function __construct(IActionFactory $actionFactory) { + public function __construct(IActionFactory $actionFactory, IURLGenerator $urlGenerator) { $this->actionFactory = $actionFactory; + $this->urlGenerator = $urlGenerator; } /** * @param IEntry $entry */ public function process(IEntry $entry) { + $iconUrl = $this->urlGenerator->getAbsoluteURL($this->urlGenerator->imagePath('core', 'actions/mail.svg')); foreach ($entry->getEMailAddresses() as $address) { - // TODO: absolute path - $action = $this->actionFactory->newEMailAction('icon-mail', $address, $address); + $action = $this->actionFactory->newEMailAction($iconUrl, $address, $address); $entry->addAction($action); } } diff --git a/tests/lib/Contacts/ContactsMenu/Providers/EMailproviderTest.php b/tests/lib/Contacts/ContactsMenu/Providers/EMailproviderTest.php index af7b21a6485..2d82fa5d68e 100644 --- a/tests/lib/Contacts/ContactsMenu/Providers/EMailproviderTest.php +++ b/tests/lib/Contacts/ContactsMenu/Providers/EMailproviderTest.php @@ -28,6 +28,7 @@ use OC\Contacts\ContactsMenu\Providers\EMailProvider; use OCP\Contacts\ContactsMenu\IActionFactory; use OCP\Contacts\ContactsMenu\IEntry; use OCP\Contacts\ContactsMenu\ILinkAction; +use OCP\IURLGenerator; use PHPUnit_Framework_MockObject_MockObject; use Test\TestCase; @@ -36,6 +37,9 @@ class EMailproviderTest extends TestCase { /** @var IActionFactory|PHPUnit_Framework_MockObject_MockObject */ private $actionFactory; + /** @var IURLGenerator|PHPUnit_Framework_MockObject_MockObject */ + private $urlGenerator; + /** @var EMailProvider */ private $provider; @@ -43,13 +47,22 @@ class EMailproviderTest extends TestCase { parent::setUp(); $this->actionFactory = $this->createMock(IActionFactory::class); - $this->provider = new EMailProvider($this->actionFactory); + $this->urlGenerator = $this->createMock(IURLGenerator::class); + + $this->provider = new EMailProvider($this->actionFactory, $this->urlGenerator); } public function testProcess() { $entry = $this->createMock(IEntry::class); $action = $this->createMock(ILinkAction::class); - + $iconUrl = 'https://example.com/img/actions/icon.svg'; + $this->urlGenerator->expects($this->once()) + ->method('imagePath') + ->willReturn('img/actions/icon.svg'); + $this->urlGenerator->expects($this->once()) + ->method('getAbsoluteURL') + ->with('img/actions/icon.svg') + ->willReturn($iconUrl); $entry->expects($this->once()) ->method('getEMailAddresses') ->willReturn([ @@ -57,7 +70,7 @@ class EMailproviderTest extends TestCase { ]); $this->actionFactory->expects($this->once()) ->method('newEMailAction') - ->with($this->equalTo('icon-mail'), $this->equalTo('Mail'), $this->equalTo('user@example.com')) + ->with($this->equalTo($iconUrl), $this->equalTo('user@example.com'), $this->equalTo('user@example.com')) ->willReturn($action); $entry->expects($this->once()) ->method('addAction') |