From a807650a664a434c3b23155cf3ed335c8f57c006 Mon Sep 17 00:00:00 2001 From: Michal Kleiner Date: Fri, 20 May 2016 18:33:23 +1200 Subject: [PATCH] Add config option to use absolute links inside the widget --- README.md | 12 ++++++++++++ code/BetterNavigator.php | 30 +++++++++++++++++++++++------- templates/BetterNavigator.ss | 6 ++++-- 3 files changed, 39 insertions(+), 9 deletions(-) diff --git a/README.md b/README.md index 736d8b9..1a9eeb2 100644 --- a/README.md +++ b/README.md @@ -32,6 +32,7 @@ Download, place the folder in your project root, rename it to 'betternavigator' Just place **$BetterNavigator** somewhere in your template(s). If your website uses caching, make sure BetterNavigator's output is excluded. **Access developer tools on a live website** + You can mark certain CMS users as developers in your site's config, so they can access developer tools when logged in. Example YAML: ``` @@ -41,6 +42,17 @@ You can mark certain CMS users as developers in your site's config, so they can - 'otherdev@yoursite.com' ``` +**Use absolute links** + +Some sites may opt to not use base tag in the page head (e.g. it could be problematic with hash links within a page). +In that case you can use this YAML settings to force output of absolute links always starting with a slash. + +``` + BetterNavigator: + developers: + useAbsoluteLinks: true +``` + ##Customisation BetterNavigator's output is controlled by templates so it can be [easily overridden](http://doc.silverstripe.org/framework/en/topics/theme-development#overriding). diff --git a/code/BetterNavigator.php b/code/BetterNavigator.php index 1d38c88..d537421 100755 --- a/code/BetterNavigator.php +++ b/code/BetterNavigator.php @@ -16,6 +16,18 @@ class BetterNavigator extends DataExtension { */ private static $developers; + /** + * Force use of absolute links starting with a slash for sites not using base tag + * Example YAML: + * + * BetterNavigator: + * useAbsoluteLinks: true + * + * @config + * @var boolean + */ + private static $useAbsoluteLinks = false; + /** * Provides a front-end utility menu with administrative functions and developer tools * Relies on SilverStripeNavigator @@ -30,6 +42,10 @@ class BetterNavigator extends DataExtension { $isDev = Director::isDev(); $canViewDraft = (Permission::check('VIEW_DRAFT_CONTENT') || Permission::check('CMS_ACCESS_CMSMain')); if($isDev || $canViewDraft) { + // use absolute links + $useAbsLinks = Config::inst()->get('BetterNavigator', 'useAbsoluteLinks'); + $linkPrefix = ($useAbsLinks ? '/' : ''); + // Get SilverStripeNavigator links & stage info (CMS/Stage/Live/Archive) $nav = array(); $viewing = ''; @@ -39,8 +55,8 @@ class BetterNavigator extends DataExtension { $name = $item->getName(); $active = $item->isActive(); $nav[$name] = array( - 'Link' => $item->getLink(), - 'Active' => $active + 'Link' => (($name == 'CMSLink') ? $linkPrefix : '') . $item->getLink(), + 'Active' => $active, ); if ($active) { if ($name == 'LiveLink') $viewing = 'Live'; @@ -54,8 +70,7 @@ class BetterNavigator extends DataExtension { // Is the logged in member nominated as a developer? $member = Member::currentUser(); $devs = Config::inst()->get('BetterNavigator', 'developers'); - $identifierField = Member::config()->unique_identifier_field; - $isDeveloper = $member && is_array($devs) ? in_array($member->{$identifierField}, $devs) : false; + $isDeveloper = $member && is_array($devs) ? in_array($member->Email, $devs) : false; // Add other data for template $backURL = '?BackURL=' . urlencode($this->owner->Link()); @@ -63,11 +78,12 @@ class BetterNavigator extends DataExtension { '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, + 'LoginLink' => $linkPrefix . Config::inst()->get('Security', 'login_url') . $backURL, + 'LogoutLink' => $linkPrefix . 'Security/logout' . $backURL, 'EditLink' => $editLink, 'Mode' => Director::get_environment_type(), - 'IsDeveloper' => $isDeveloper + 'IsDeveloper' => $isDeveloper, + 'LinkPrefix' => $linkPrefix, )); // Merge with page data, send to template and render diff --git a/templates/BetterNavigator.ss b/templates/BetterNavigator.ss index 72dc2a0..9700f87 100644 --- a/templates/BetterNavigator.ss +++ b/templates/BetterNavigator.ss @@ -60,8 +60,10 @@ <% end_if %> Flush caches - Build database - Dev menu + <% with $BetterNavigator %> + Build database + Dev menu + <% end_with %>