2014-08-13 10:11:18 +09:30
|
|
|
<?php
|
|
|
|
|
2016-07-23 07:33:28 +10:00
|
|
|
class BetterNavigatorExtension extends DataExtension {
|
2014-08-13 10:11:18 +09:30
|
|
|
|
2015-12-17 15:58:50 -08:00
|
|
|
/**
|
|
|
|
* Provides a front-end utility menu with administrative functions and developer tools
|
|
|
|
* Relies on SilverStripeNavigator
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function BetterNavigator() {
|
2015-12-17 19:34:13 -08:00
|
|
|
// Make sure this is a page
|
|
|
|
if (!($this->owner && $this->owner->dataRecord && $this->owner->dataRecord instanceof SiteTree && $this->owner->dataRecord->ID > 0)) return false;
|
2014-08-13 10:11:18 +09:30
|
|
|
|
2015-12-17 19:34:13 -08:00
|
|
|
// Only show navigator to appropriate users
|
|
|
|
$isDev = Director::isDev();
|
|
|
|
$canViewDraft = (Permission::check('VIEW_DRAFT_CONTENT') || Permission::check('CMS_ACCESS_CMSMain'));
|
|
|
|
if($isDev || $canViewDraft) {
|
|
|
|
// Get SilverStripeNavigator links & stage info (CMS/Stage/Live/Archive)
|
|
|
|
$nav = array();
|
|
|
|
$viewing = '';
|
|
|
|
$navigator = new SilverStripeNavigator($this->owner->dataRecord);
|
|
|
|
$items = $navigator->getItems();
|
|
|
|
foreach($items as $item) {
|
|
|
|
$name = $item->getName();
|
|
|
|
$active = $item->isActive();
|
|
|
|
$nav[$name] = array(
|
|
|
|
'Link' => $item->getLink(),
|
|
|
|
'Active' => $active
|
|
|
|
);
|
|
|
|
if ($active) {
|
|
|
|
if ($name == 'LiveLink') $viewing = 'Live';
|
|
|
|
if ($name == 'StageLink') $viewing = 'Draft';
|
|
|
|
if ($name == 'ArchiveLink') $viewing = 'Archived';
|
2015-12-17 15:58:50 -08:00
|
|
|
}
|
2015-12-17 19:34:13 -08:00
|
|
|
}
|
|
|
|
// Only show edit link if user has permission to edit this page
|
|
|
|
$editLink = (($this->owner->dataRecord->canEdit() && Permission::check('CMS_ACCESS_CMSMain')) || $isDev) ? $nav['CMSLink']['Link'] : false;
|
2015-12-17 15:58:50 -08:00
|
|
|
|
2015-12-17 19:34:13 -08:00
|
|
|
// Is the logged in member nominated as a developer?
|
|
|
|
$member = Member::currentUser();
|
|
|
|
$devs = Config::inst()->get('BetterNavigator', 'developers');
|
2016-02-10 00:04:12 +01:00
|
|
|
$identifierField = Member::config()->unique_identifier_field;
|
|
|
|
$isDeveloper = $member && is_array($devs) ? in_array($member->{$identifierField}, $devs) : false;
|
2015-12-17 15:58:50 -08:00
|
|
|
|
2015-12-17 19:34:13 -08:00
|
|
|
// Add other data for template
|
|
|
|
$backURL = '?BackURL=' . urlencode($this->owner->Link());
|
|
|
|
$bNData = array_merge($nav, array(
|
|
|
|
'Member' => $member,
|
|
|
|
'Stage' => Versioned::current_stage(),
|
|
|
|
'Viewing' => $viewing, // What we're viewing doesn't necessarily align with the active Stage
|
|
|
|
'LoginLink' => Config::inst()->get('Security', 'login_url') . $backURL,
|
|
|
|
'LogoutLink' => 'Security/logout' . $backURL,
|
|
|
|
'EditLink' => $editLink,
|
|
|
|
'Mode' => Director::get_environment_type(),
|
|
|
|
'IsDeveloper' => $isDeveloper
|
|
|
|
));
|
2015-12-17 15:58:50 -08:00
|
|
|
|
2015-12-17 19:34:13 -08:00
|
|
|
// Merge with page data, send to template and render
|
|
|
|
$bNData = new ArrayData($bNData);
|
|
|
|
$page = $this->owner->customise(array('BetterNavigator' => $bNData));
|
|
|
|
return $page->renderWith('BetterNavigator');
|
2015-12-17 15:58:50 -08:00
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
2014-10-06 15:19:56 +13:00
|
|
|
}
|