Możesz dodać elementy do paska narzędzi administratora na dwa sposoby:
Jako treść:
W interfejsie użytkownika /admin/structure/menu/manage/admin
lub w kodzie:
$item = \Drupal\menu_link_content\Entity\MenuLinkContent::create([
'link' => ['uri' => 'internal:/<front>'],
'title' => 'Front Page',
'menu_name' => 'admin',
]);
$item->save();
Lub w statycznych plikach konfiguracyjnych:
system.admin:
title: Administration
route_name: system.admin
weight: 9
menu_name: admin
system.admin_content:
title: Content
description: 'Find and manage content.'
route_name: system.admin_content
parent: system.admin
weight: -10
system.admin_structure:
route_name: system.admin_structure
parent: system.admin
description: 'Administer blocks, content types, menus, etc.'
title: Structure
weight: -8
system.themes_page:
route_name: system.themes_page
title: Appearance
description: 'Select and configure themes.'
parent: system.admin
weight: -6
Jest to początek pliku system.links.menu.yml , który definiuje menu administratora, jakie znamy z D8. Możesz dodawać własne wpisy w mymodule.links.menu.yml .
Edytować:
Aby dodać element do górnego rzędu, użyj haka mymodule_toolbar()
. Oto przykład z modułu wycieczki:
/**
* Implements hook_toolbar().
*/
function tour_toolbar() {
$items = [];
$items['tour'] = [
'#cache' => [
'contexts' => [
'user.permissions',
],
],
];
if (!\Drupal::currentUser()->hasPermission('access tour')) {
return $items;
}
$items['tour'] += array(
'#type' => 'toolbar_item',
'tab' => array(
'#type' => 'html_tag',
'#tag' => 'button',
'#value' => t('Tour'),
'#attributes' => array(
'class' => array('toolbar-icon', 'toolbar-icon-help'),
'aria-pressed' => 'false',
),
),
'#wrapper_attributes' => array(
'class' => array('tour-toolbar-tab', 'hidden'),
'id' => 'toolbar-tab-tour',
),
'#attached' => array(
'library' => array(
'tour/tour',
),
),
);
return $items;
}
hook_toolbar
orazToolbarHandler
.Dla wszystkich, którzy zastanawiają się, gdzie mogą umieścić kod z poprzedniej odpowiedzi - możesz go użyć na przykład w MYMODULE.install
źródło