-
Notifications
You must be signed in to change notification settings - Fork 57
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
EZP-28127: Create extendable left sidebar
- Loading branch information
Showing
6 changed files
with
136 additions
and
54 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
41 changes: 41 additions & 0 deletions
41
src/bundle/Resources/views/parts/menu/sidebar_left.html.twig
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
{% extends '@KnpMenu/menu.html.twig' %} | ||
|
||
{% block root %} | ||
{% for item in item.children %} | ||
{{ block('item') }} | ||
{% endfor %} | ||
{% endblock %} | ||
|
||
{% block item -%} | ||
{%- if item.displayed -%} | ||
{%- set attributes = item.attributes|merge({'class': (item.attributes.class|default('') ~ ' btn btn-dark btn-block')|trim}) -%} | ||
{%- set attributes = attributes|merge({'id': item.name ~ '-tab'}) -%} | ||
|
||
{%- if item.uri is not empty %} | ||
{% set attributes = attributes|merge({'href': item.uri}) %} | ||
{% set element = 'a' %} | ||
{{ block('element') }} | ||
{%- else %} | ||
{% set element = 'button' %} | ||
{{ block('element') }} | ||
{%- endif %} | ||
{%- endif -%} | ||
{%- endblock %} | ||
|
||
{% block element %} | ||
{% import 'knp_menu.html.twig' as macros %} | ||
{% set element = element|default('a') %} | ||
<{{ element }}{{ macros.attributes(attributes) }}> | ||
{{ block('label') }} | ||
</{{ element }}> | ||
{% endblock %} | ||
|
||
{% block label %} | ||
{% if item.extras.icon is defined and item.extras.icon != '' %} | ||
<svg class="ez-icon ez-icon-{{ item.extras.icon }}"> | ||
<use xmlns:xlink="http://www.w3.org/1999/xlink" | ||
xlink:href="{{ asset('bundles/ezplatformadminui/img/ez-icons.svg') }}#{{ item.extras.icon }}"></use> | ||
</svg> | ||
{% endif %} | ||
{{ parent() }} | ||
{% endblock %} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
<?php | ||
|
||
/** | ||
* @copyright Copyright (C) eZ Systems AS. All rights reserved. | ||
* @license For full copyright and license information view LICENSE file distributed with this source code. | ||
*/ | ||
namespace EzSystems\EzPlatformAdminUi\Menu; | ||
|
||
use EzSystems\EzPlatformAdminUi\Menu\Event\ConfigureMenuEvent; | ||
use InvalidArgumentException; | ||
use JMS\TranslationBundle\Model\Message; | ||
use JMS\TranslationBundle\Translation\TranslationContainerInterface; | ||
use Knp\Menu\ItemInterface; | ||
|
||
/** | ||
* KnpMenuBundle Menu Builder service implementation for AdminUI left sidebar menu. | ||
* | ||
* @see https://symfony.com/doc/current/bundles/KnpMenuBundle/menu_builder_service.html | ||
*/ | ||
class LeftSidebarBuilder extends AbstractBuilder implements TranslationContainerInterface | ||
{ | ||
/* Menu items */ | ||
const ITEM__SEARCH = 'sidebar_left__search'; | ||
const ITEM__BROWSE = 'sidebar_left__browse'; | ||
const ITEM__TRASH = 'sidebar_left__trash'; | ||
|
||
/** | ||
* @return string | ||
*/ | ||
protected function getConfigureEventName(): string | ||
{ | ||
return ConfigureMenuEvent::CONTENT_SIDEBAR_LEFT; | ||
} | ||
|
||
/** | ||
* @param array $options | ||
* | ||
* @return ItemInterface | ||
* | ||
* @throws InvalidArgumentException | ||
*/ | ||
public function createStructure(array $options): ItemInterface | ||
{ | ||
$menu = $this->factory->createItem('root'); | ||
|
||
$menu->setChildren([ | ||
self::ITEM__SEARCH => $this->createMenuItem( | ||
self::ITEM__SEARCH, | ||
[ | ||
'extras' => ['icon' => 'search'], | ||
'attributes' => ['disabled' => 'disabled'], | ||
] | ||
), | ||
self::ITEM__BROWSE => $this->createMenuItem( | ||
self::ITEM__BROWSE, | ||
[ | ||
'extras' => ['icon' => 'browse'], | ||
'attributes' => [ | ||
'class' => 'btn--udw-browse', | ||
'data-starting-location-id' => 1, | ||
], | ||
] | ||
), | ||
self::ITEM__TRASH => $this->createMenuItem( | ||
self::ITEM__TRASH, | ||
[ | ||
'route' => 'ezplatform.trash.list', | ||
'extras' => ['icon' => 'trash'], | ||
] | ||
), | ||
]); | ||
|
||
return $menu; | ||
} | ||
|
||
/** | ||
* @return Message[] | ||
*/ | ||
public static function getTranslationMessages(): array | ||
{ | ||
return [ | ||
(new Message(self::ITEM__SEARCH, 'menu'))->setDesc('Search'), | ||
(new Message(self::ITEM__BROWSE, 'menu'))->setDesc('Browse'), | ||
(new Message(self::ITEM__TRASH, 'menu'))->setDesc('Trash'), | ||
]; | ||
} | ||
} |