Drupal 8: Добавление пункта меню в Toolbar

Узнайте, как добавить свой собственный пункт в административный тулбар Drupal 8.

20.03.2017
1 комментарий
3 мин.

В продолжении темы про создание собственного раздела на странице конфигурации я решил дополнить её статьей о том, как добавить свой собстенный пункт в административный тулбар.

Добавление раздела на страницу конфигурации это хорошо, но что если необходимо сделать пункт в тулбаре? На самом деле, подход абсолютно идентичен тому как это делается для страницы конфигурации, с мелкими отличиями из-за особенности тулбара, но суть и подход в целом тот же самый. При этом они оба отлично уживаются вместе и можно добавлять как на страницу конфигурации, так и в тулбар одновременно.

За основу этой статьи я беру модуль из предыдущей статьи.

В данном модуле у нас имеется файл helloworld.routing.yml в котором объявлена страница ("блок") для пунктов на странице конфигурации, и путь для формы с настройками модуля. Мы задействуем оба роута. Первый /admin/config/hello-world станет основным пунктом в тулбаре, а второй /admin/config/hello-world/phone-settings будет в виде вкладки.

Если вы читали предыдущую статью и пользуетесь Administrative Toolbar, вы заметили что наведя на "Конфигурация", там появляся наш пункт Hello World и все его ссылки были также вложены в данное выпадающее меню. В текущем варианте это не прокатит, вложенные пункты придется обьявлять нам самостоятельно.

Так как роутинги у нас уже готовы и с ними полный порядок, нам остается сделать совсем ничего.

Добавляем основной пункт меню в тулбар

Первым делом мы добавим пункт Hello World в тулбар. Для этого, нам необходимо в helloworld.links.menu.yml добавить ссылку на нашу страницу указав в качестве родителя роутинг для тулбара.

helloworld.links.menu.yml
hello_world.admin_toolbar_hello_world:
  title: 'Hello World'
  parent: system.admin
  route_name: hello_world.admin_config_hello_world
  weight: 0

Опять же, если вы читали предыдущую статью, то можете обратить внимание, что отличие от hello_world.admin_config_hello_world — который добавляет раздел на странице конфигурации лишь в parent. Для страницы кофнигурации это system.admin_config , а для тулбара system.admin . Вот и вся разница между статьями.

Если сбросить кэш, вы увидите пункт в тулбаре.

Добавляем вложенную ссылку

Вложенные ссылки опять же, делаются абсолютно также. Нам лишь нужно указать в качестве родителя только что созданную ссылку (выше).

helloworld.links.menu.yml
hello_world.admin_toolbar_collect_phone_settings:
  title: 'Collect Phone settings'
  description: 'In this settings you can set default phone number for collect phone form.'
  parent: hello_world.admin_toolbar_hello_world
  route_name: hello_world.collect_phone_admin_settings
  weight: 1

Опять же, сбрасываем кэш и смотрим что получилось.

Вы глядит как-то инородно, верно? А всё потому что не хватает иконки!

Добавление иконки

В идеале, как и другие пункты меню, иконка должна иметь размер 16x16 px, иметь цвет #787878 и быть в формате svg.

Всё это, конечно, на ваше усмотрение. Я лишь сделал иконку соответствующую данным параметрам из иконки FontAwesome. Назвал её globe.svg и положил в папку /img (которая наоходится в корне модуля).

Иконки подключаются в тулбаре при помощи CSS. У каждого пункта меню, есть собственный класс, который генерируется автоматически. Если вы копировали код из статьи, то класс у ссылки Hello World будет toolbar-icon-hello-world-admin-toolbar-hello-world .

Данному классу, на элемент :before мы должены добавить данную иконку в качестве background-image .

Для этого, создаем папку css в корне модуля, в нём создаем файл * helloworld.toolbar.css* и добавляем нашу иконку.

css/helloworld.toolbar.css
.toolbar-icon-hello-world-admin-toolbar-hello-world:before {
  background-image: url('../img/globe.svg');
}

Далее нам необходимо обьявить этот файл в виде библиотеки, и подключить данную библиотеку к тулбару.

Первым делом, вспоминая Libraries API, нам необходимо объявить наш css файл в качестве библиотеки. Для этого создаем файл helloworld.libraries.yml и добавляем наш файл стилей.

helloworld.libraries.yml
helloworld.toolbar:
  version: VERSION
  css:
    theme:
      css/helloworld.toolbar.css: { }

Библиотеку обьявили, теперь надо её подключить к тулбару. Лучше всего, как по мне, использовать хук hook_preprocess_HOOK и повесить подключение данной библиотеки (стиля) непосредственно к тулбару. Если модуль тулбар по каким-то причинам отключат, то и библиотека перестанет подключаться. Соответственно, гостям эта библиотека также не будет грузится.

helloworld.module
/**
 * Implements hook_preprocess_HOOK().
 */
function helloworld_preprocess_toolbar(&$variables) {
  $variables['#attached']['library'][] = 'helloworld/helloworld.toolbar';
}

Сбрасываем кэш, перезагружаем страницу и смотрим на результат.

Готовый модуль, как обычно, во вложениях.

Ссылки

Drupal
Drupal 8

Комментарии

Андрей Ковтун   вс, 28/05/2017 - 10:33

Или, как вариант, подключение библиотеки, используя hook_toolbar_alter(). Сделал у себя именно так.

/**

  • Implements hook_toolbar_alter(). */ function helloworld_toolbar_alter(&$items) { $items['administration']['#attached']['library'][] = 'helloworld/helloworld.toolbar'; }