2011-02-07 19:48:44 +13:00
|
|
|
# LeftAndMain
|
|
|
|
|
|
|
|
## Introduction
|
|
|
|
|
|
|
|
LeftAndMain is the base class of all the admin area controllers.
|
|
|
|
|
|
|
|
## Best Practices
|
|
|
|
|
|
|
|
### Custom Access Checking
|
|
|
|
|
|
|
|
You can customize access control in `[api:LeftAndMain]`.
|
|
|
|
|
|
|
|
:::php
|
|
|
|
// mysite/_config.php
|
|
|
|
LeftAndMain::add_extension('MyLeftAndMain');
|
|
|
|
|
|
|
|
// MyLeftAndMain.php
|
|
|
|
class MyLeftAndMain extends Extension {
|
|
|
|
function augumentInit() {
|
|
|
|
// add custom requirements etc.
|
|
|
|
}
|
|
|
|
function alternateAccessCheck() {
|
|
|
|
// custom permission checks, e.g. to check for an SSL-connection, or an LDAP-group-membership
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
## Subclassing
|
|
|
|
|
|
|
|
There are a few steps in creating a subclass of LeftAndMain.
|
|
|
|
|
|
|
|
### MyAdmin.php
|
|
|
|
|
|
|
|
The PHP file defining your new subclass is the first step in the process. This provides a good starting point:
|
|
|
|
|
|
|
|
:::php
|
|
|
|
class MyAdmin extends LeftAndMain {
|
|
|
|
|
|
|
|
static $url_segment = 'myadmin';
|
|
|
|
static $url_rule = '$Action/$ID';
|
|
|
|
static $menu_title = 'My Admin';
|
|
|
|
static $menu_priority = 60;
|
|
|
|
|
|
|
|
public function init() {
|
2011-04-22 18:11:14 +12:00
|
|
|
Requirements::javascript('cms/javascript/MyAdmin.js');
|
2011-02-07 19:48:44 +13:00
|
|
|
parent::init();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2011-04-22 18:11:14 +12:00
|
|
|
* Form which will be shown when we open one of the items
|
2011-02-07 19:48:44 +13:00
|
|
|
*/
|
|
|
|
public function getEditForm($id = null) {
|
|
|
|
return new Form($this, "EditForm",
|
2011-10-28 14:37:27 +13:00
|
|
|
new FieldList(
|
2011-02-07 19:48:44 +13:00
|
|
|
new ReadonlyField('id #',$id)
|
|
|
|
),
|
2011-10-28 14:37:27 +13:00
|
|
|
new FieldList(
|
2011-02-07 19:48:44 +13:00
|
|
|
new FormAction('go')
|
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
### Templates
|
|
|
|
|
|
|
|
Next, create templates, (classname)_left.ss and (classname)_right.ss. Again, here are a couple of starting points:
|
|
|
|
|
|
|
|
* On the left, we're using the tree as a way of providing navigation. The left and side could be replaced with
|
|
|
|
anything but LeftAndMain has built-in support for trees.
|
|
|
|
* On the right, we have the skeleton that the form will be loaded into.
|
|
|
|
|
|
|
|
MyAdmin_left.ss
|
|
|
|
|
|
|
|
:::ss
|
|
|
|
<div class="title"><div>Functions</div></div>
|
|
|
|
|
|
|
|
<div id="treepanes">
|
|
|
|
<div id="sitetree_holder" style="overflow:auto">
|
|
|
|
<% if Items %>
|
|
|
|
<ul id="sitetree" class="tree unformatted">
|
|
|
|
<li id="$ID" class="root Root"><a>Items</a>
|
|
|
|
<ul>
|
|
|
|
<% control Items %>
|
|
|
|
<li id="record-$class">
|
|
|
|
<a href="admin/my/show/$ID">$Title</a>
|
|
|
|
</li>
|
|
|
|
<% end_control %>
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
</ul>
|
|
|
|
<% end_if %>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
MyAdmin_right.ss
|
|
|
|
|
|
|
|
:::ss
|
|
|
|
<div class="title"><div>My admin</div></div>
|
|
|
|
|
|
|
|
<% if EditForm %>
|
|
|
|
$EditForm
|
|
|
|
<% else %>
|
|
|
|
<form id="Form_EditForm" action="admin/my?executeForm=EditForm" method="post" enctype="multipart/form-data">
|
|
|
|
<p>Welcome to my $ApplicationName admin section. Please choose something from the left.</p>
|
|
|
|
</form>
|
|
|
|
<% end_if %>
|
|
|
|
|
|
|
|
<p id="statusMessage" style="visibility:hidden"></p>
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### Customising the main menu
|
|
|
|
|
|
|
|
*Minimum Requirement: Silverstripe 2.3*
|
|
|
|
|
|
|
|
The static variable $url_segment determines the sub url of the controller.
|
|
|
|
The static variable $url_rule has the url format for the actions performed by the class.
|
|
|
|
The static variable $menu_title is the title of the administration panel in the menu.
|
|
|
|
The static variable $menu_priority tells the CMS where to put the menu item relative to other panels.
|
|
|
|
|
|
|
|
For example:
|
|
|
|
|
|
|
|
:::php
|
|
|
|
static $url_segment = 'myadmin';
|
|
|
|
static $url_rule = '$Action/$ID';
|
|
|
|
static $menu_title = 'My Admin';
|
|
|
|
static $menu_priority = 60;
|
|
|
|
|
|
|
|
|
|
|
|
See also `[api:CMSMenu]`
|
|
|
|
|
|
|
|
### Translatable Menu Titles
|
|
|
|
|
|
|
|
Override the function getMenuTitle() to create a translated menu title name. Eg:
|
|
|
|
|
|
|
|
:::php
|
|
|
|
public function getMenuTitle() {
|
|
|
|
return _t('LeftAndMain.MYADMIN', 'My Admin', PR_HIGH, 'Menu title');
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
## 'onload' javascript in the CMS {#onload-javascript}
|
|
|
|
|
|
|
|
|
|
|
|
You can have custom scripting called when a Page is loaded by clicking on the Site Content Tree.
|
|
|
|
This can be used to set up event handlers, or populate dropdowns, etc.
|
|
|
|
You could insert this code using Requirements from a custom page class.
|
|
|
|
|
|
|
|
:::js
|
|
|
|
Behaviour.register({
|
|
|
|
'#Form_EditForm' : {
|
|
|
|
initialize : function() {
|
|
|
|
this.observeMethod('PageLoaded', this.adminPageHandler);
|
|
|
|
this.adminPageHandler();
|
|
|
|
},
|
|
|
|
adminPageHandler : function() {
|
|
|
|
// Place your custom code here.
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
See [Javascript in the CMS](/topics/javascript#javascript-cms)
|
|
|
|
|
|
|
|
## Related
|
|
|
|
|
|
|
|
* `[api:CMSMain]`
|
|
|
|
* `[api:AssetAdmin]`
|
|
|
|
* `[api:SecurityAdmin]`
|
|
|
|
* `[api:ModelAdmin]`
|
|
|
|
|
|
|
|
## TODO
|
|
|
|
|
|
|
|
* Explain how to build the javascript file
|
|
|
|
* Explain how the ajax button handlers work
|
|
|
|
* Explain how to create little pop-up dialogs
|