silverstripe-framework/docs/en/02_Developer_Guides/15_Customising_the_Admin_Interface/How_Tos/Customise_CMS_Menu.md

151 lines
4.3 KiB
Markdown
Raw Normal View History

# How to customise the CMS Menu
2015-07-15 16:36:33 +02:00
## Adding an administration panel
Every time you add a new extension of the [LeftAndMain](api:SilverStripe\Admin\LeftAndMain) class to the CMS,
SilverStripe will automatically create a new [CMSMenuItem](api:SilverStripe\Admin\CMSMenuItem) for it
The most popular extension of LeftAndMain is a [ModelAdmin](api:SilverStripe\Admin\ModelAdmin) class, so
for a more detailed introduction to creating new `ModelAdmin` interfaces, read
the [ModelAdmin reference](../modeladmin).
2014-11-07 20:43:57 +01:00
In this document we'll take the `ProductAdmin` class used in the
[ModelAdmin reference](../modeladmin#setup) and so how we can change
2014-11-07 20:43:57 +01:00
the menu behaviour by using the `$menu_title` and `$menu_icon` statics to
provide a custom title and icon.
### Defining a Custom Icon
2014-11-07 20:43:57 +01:00
First we'll need a custom icon. For this purpose SilverStripe uses 16x16
black-and-transparent PNG graphics. In this case we'll place the icon in
`app/images`, but you are free to use any location.
```php
use SilverStripe\Admin\ModelAdmin;
2017-08-05 00:45:24 +02:00
class ProductAdmin extends ModelAdmin
{
// ...
private static $menu_icon = 'app/images/product-icon.png';
}
```
### Defining a Custom Title
The title of menu entries is configured through the `$menu_title` static.
2014-11-07 20:43:57 +01:00
If its not defined, the CMS falls back to using the class name of the
controller, removing the "Admin" bit at the end.
```php
use SilverStripe\Admin\ModelAdmin;
2017-08-05 00:45:24 +02:00
class ProductAdmin extends ModelAdmin
{
// ...
private static $menu_title = 'My Custom Admin';
}
```
2014-11-07 20:43:57 +01:00
In order to localize the menu title in different languages, use the
`<classname>.MENUTITLE` entity name, which is automatically created when running
the i18n text collection.
2014-11-07 20:43:57 +01:00
For more information on language and translations, please refer to the
2016-01-14 11:59:53 +01:00
[i18n](/developer_guides/i18n) docs.
## Adding an external link to the menu
2014-11-07 20:43:57 +01:00
On top of your administration windows, the menu can also have external links
(e.g. to external reference). In this example, we're going to add a link to
Google to the menu.
First, we need to define a [LeftAndMainExtension](api:SilverStripe\Admin\LeftAndMainExtension) which will contain our
button configuration.
```php
use SilverStripe\Admin\CMSMenu;
use SilverStripe\Admin\LeftAndMainExtension;
2017-08-05 00:45:24 +02:00
class CustomLeftAndMain extends LeftAndMainExtension
{
public function init()
{
// unique identifier for this item. Will have an ID of Menu-$ID
$id = 'LinkToGoogle';
// your 'nice' title
$title = 'Google';
// the link you want to item to go to
$link = 'http://google.com';
// priority controls the ordering of the link in the stack. The
// lower the number, the lower in the list
$priority = -2;
// Add your own attributes onto the link. In our case, we want to
// open the link in a new window (not the original)
$attributes = [
'target' => '_blank'
];
CMSMenu::add_link($id, $title, $link, $priority, $attributes);
2017-08-07 05:11:17 +02:00
}
}
```
2014-11-07 20:43:57 +01:00
To have the link appear, make sure you add the extension to the `LeftAndMain`
class. For more information about configuring extensions see the
2016-01-14 11:59:53 +01:00
[extensions reference](/developer_guides/extending/extensions).
```php
LeftAndMain::add_extension('CustomLeftAndMain')
```
2014-11-07 20:43:57 +01:00
## Customising the CMS help menu
The CMS help menu links in the south toolbar are configurable via your [configuration file](../../configuration).
You can edit, add or remove existing links as shown in the examples below:
```yml
# app/_config/config.yml
SilverStripe\Admin\LeftAndMain:
help_links:
# Edit an existing link
'CMS User help': 'https://example.com'
# Add a new link
'Additional link': 'https://example.org'
# Remove an existing link
'Feedback': ''
```
## Customising the CMS form actions
The `Previous`, `Next` and `Add` actions on the edit form are visible by default but can be hidden globally by adding the following `.yml` config:
```yml
SilverStripe\Forms\GridField\GridFieldDetailForm_ItemRequest:
formActions:
showPagination: false
showAdd: false
```
You can also override this for a specific `GridField` instance when using the `GridFieldConfig_RecordEditor` constructor:
```php
$grid = new GridField(
"pages",
"All Pages",
SiteTree::get(),
GridFieldConfig_RecordEditor::create(null, false, false));
```
## Related
* [How to extend the CMS interface](extend_cms_interface)