[BUGFIX] Respect absRefPrefix in admin panel
[Packages/TYPO3.CMS.git] / typo3 / sysext / frontend / Classes / View / AdminPanelView.php
old mode 100644 (file)
new mode 100755 (executable)
index 908840b..511b2ab
@@ -1,67 +1,58 @@
 <?php
 namespace TYPO3\CMS\Frontend\View;
 
-/***************************************************************
- *  Copyright notice
+/*
+ * This file is part of the TYPO3 CMS project.
  *
- *  (c) 2008-2011 Jeff Segars <jeff@webempoweredchurch.org>
- *  (c) 2008-2011 David Slayback <dave@webempoweredchurch.org>
- *  All rights reserved
+ * It is free software; you can redistribute it and/or modify it under
+ * the terms of the GNU General Public License, either version 2
+ * of the License, or any later version.
  *
- *  This script is part of the TYPO3 project. The TYPO3 project is
- *  free software; you can redistribute it and/or modify
- *  it under the terms of the GNU General Public License as published by
- *  the Free Software Foundation; either version 2 of the License, or
- *  (at your option) any later version.
+ * For the full copyright and license information, please read the
+ * LICENSE.txt file that was distributed with this source code.
  *
- *  The GNU General Public License can be found at
- *  http://www.gnu.org/copyleft/gpl.html.
- *  A copy is found in the textfile GPL.txt and important notices to the license
- *  from the author is found in LICENSE.txt distributed with these scripts.
- *
- *
- *  This script is distributed in the hope that it will be useful,
- *  but WITHOUT ANY WARRANTY; without even the implied warranty of
- *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- *  GNU General Public License for more details.
- *
- *  This copyright notice MUST APPEAR in all copies of the scri.pt!
- ***************************************************************/
+ * The TYPO3 project - inspiring people to share!
+ */
+
+use TYPO3\CMS\Backend\Utility\BackendUtility;
+use TYPO3\CMS\Backend\Utility\IconUtility;
+use TYPO3\CMS\Core\Imaging\Icon;
+use TYPO3\CMS\Core\Imaging\IconFactory;
+use TYPO3\CMS\Core\Type\Bitmask\Permission;
+use TYPO3\CMS\Core\Utility\ExtensionManagementUtility;
+use TYPO3\CMS\Core\Utility\GeneralUtility;
+
 /**
  * View class for the admin panel in frontend editing.
- *
- * @author Jeff Segars <jeff@webempoweredchurch.org>
- * @author David Slayback <dave@webempoweredchurch.org>
- * @author Dmitry Dulepov <dmitry@typo3.org>
  */
 class AdminPanelView {
 
        /**
         * Determines whether the update button should be shown.
         *
-        * @var         boolean
+        * @var bool
         */
        protected $extNeedUpdate = FALSE;
 
        /**
-        * Force preview?
+        * Force preview
         *
-        * @var boolean
+        * @var bool
         */
        protected $ext_forcePreview = FALSE;
 
        /**
+        * @var string
+        */
+       protected $extJSCODE = '';
+
+       /**
         * Constructor
         */
        public function __construct() {
                $this->initialize();
        }
 
-       /*****************************************************
-        *
-        * Admin Panel Configuration/Initialization
-        *
-        ****************************************************/
        /**
         * Initializes settings for the admin panel.
         *
@@ -69,66 +60,68 @@ class AdminPanelView {
         */
        public function initialize() {
                $this->saveConfigOptions();
+               $typoScriptFrontend = $this->getTypoScriptFrontendController();
                // Setting some values based on the admin panel
-               $GLOBALS['TSFE']->forceTemplateParsing = $this->extGetFeAdminValue('tsdebug', 'forceTemplateParsing');
-               $GLOBALS['TSFE']->displayEditIcons = $this->extGetFeAdminValue('edit', 'displayIcons');
-               $GLOBALS['TSFE']->displayFieldEditIcons = $this->extGetFeAdminValue('edit', 'displayFieldIcons');
+               $typoScriptFrontend->forceTemplateParsing = $this->extGetFeAdminValue('tsdebug', 'forceTemplateParsing');
+               $typoScriptFrontend->displayEditIcons = $this->extGetFeAdminValue('edit', 'displayIcons');
+               $typoScriptFrontend->displayFieldEditIcons = $this->extGetFeAdminValue('edit', 'displayFieldIcons');
                if ($this->extGetFeAdminValue('tsdebug', 'displayQueries')) {
-                       // do not override if the value is already set in t3lib_db
-                       if ($GLOBALS['TYPO3_DB']->explainOutput == 0) {
+                       // Do not override if the value is already set in \TYPO3\CMS\Core\Database\DatabaseConnection
+                       if ($this->getDatabaseConnection()->explainOutput == 0) {
                                // Enable execution of EXPLAIN SELECT queries
-                               $GLOBALS['TYPO3_DB']->explainOutput = 3;
+                               $this->getDatabaseConnection()->explainOutput = 3;
                        }
                }
-               if (\TYPO3\CMS\Core\Utility\GeneralUtility::_GP('ADMCMD_editIcons')) {
-                       $GLOBALS['TSFE']->displayFieldEditIcons = 1;
-                       $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['edit_editNoPopup'] = 1;
+               if (GeneralUtility::_GP('ADMCMD_editIcons')) {
+                       $typoScriptFrontend->displayFieldEditIcons = 1;
                }
-               if (\TYPO3\CMS\Core\Utility\GeneralUtility::_GP('ADMCMD_simUser')) {
-                       $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['preview_simulateUserGroup'] = intval(\TYPO3\CMS\Core\Utility\GeneralUtility::_GP('ADMCMD_simUser'));
+               if (GeneralUtility::_GP('ADMCMD_simUser')) {
+                       $this->getBackendUser()->uc['TSFE_adminConfig']['preview_simulateUserGroup'] = (int)GeneralUtility::_GP('ADMCMD_simUser');
                        $this->ext_forcePreview = TRUE;
                }
-               if (\TYPO3\CMS\Core\Utility\GeneralUtility::_GP('ADMCMD_simTime')) {
-                       $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['preview_simulateDate'] = intval(\TYPO3\CMS\Core\Utility\GeneralUtility::_GP('ADMCMD_simTime'));
+               if (GeneralUtility::_GP('ADMCMD_simTime')) {
+                       $this->getBackendUser()->uc['TSFE_adminConfig']['preview_simulateDate'] = (int)GeneralUtility::_GP('ADMCMD_simTime');
                        $this->ext_forcePreview = TRUE;
                }
-               if ($GLOBALS['TSFE']->forceTemplateParsing || $GLOBALS['TSFE']->displayEditIcons || $GLOBALS['TSFE']->displayFieldEditIcons) {
-                       $GLOBALS['TSFE']->set_no_cache();
+               if ($typoScriptFrontend->forceTemplateParsing) {
+                       $typoScriptFrontend->set_no_cache('Admin Panel: Force template parsing', TRUE);
+               } elseif ($typoScriptFrontend->displayEditIcons) {
+                       $typoScriptFrontend->set_no_cache('Admin Panel: Display edit icons', TRUE);
+               } elseif ($typoScriptFrontend->displayFieldEditIcons) {
+                       $typoScriptFrontend->set_no_cache('Admin Panel: Display field edit icons', TRUE);
+               } elseif (GeneralUtility::_GP('ADMCMD_view')) {
+                       $typoScriptFrontend->set_no_cache('Admin Panel: Display preview', TRUE);
                }
        }
 
        /**
-        * Obtains header data for the admin panel.
+        * Add an additional stylesheet
         *
         * @return string
         */
        public function getAdminPanelHeaderData() {
                $result = '';
-               // Include BE styles
-               $GLOBALS['TSFE']->includeTCA();
                if (!empty($GLOBALS['TBE_STYLES']['stylesheets']['admPanel'])) {
-                       $result = '<link rel="stylesheet" type="text/css" href="' . htmlspecialchars(\TYPO3\CMS\Core\Utility\GeneralUtility::locationHeaderUrl($GLOBALS['TBE_STYLES']['stylesheets']['admPanel'])) . '" />';
+                       $stylesheet = GeneralUtility::locationHeaderUrl($GLOBALS['TBE_STYLES']['stylesheets']['admPanel']);
+                       $result = '<link rel="stylesheet" type="text/css" href="' . htmlspecialchars($stylesheet) . '" />';
                }
                return $result;
        }
 
        /**
-        * Checks if a Admin Panel section ("module") is available for the user. If so, TRUE is returned.
+        * Checks if an Admin Panel section ("module") is available for the user. If so, TRUE is returned.
         *
         * @param string $key The module key, eg. "edit", "preview", "info" etc.
-        * @return boolean
+        * @return bool
         */
        public function isAdminModuleEnabled($key) {
                $result = FALSE;
                // Returns TRUE if the module checked is "preview" and the forcePreview flag is set.
-               if ($key == 'preview' && $this->ext_forcePreview) {
+               if ($key === 'preview' && $this->ext_forcePreview) {
                        $result = TRUE;
-               }
-               // If key is not set, only "all" is checked
-               if ($GLOBALS['BE_USER']->extAdminConfig['enable.']['all']) {
+               } elseif (!empty($this->getBackendUser()->extAdminConfig['enable.']['all'])) {
                        $result = TRUE;
-               }
-               if ($GLOBALS['BE_USER']->extAdminConfig['enable.'][$key]) {
+               } elseif (!empty($this->getBackendUser()->extAdminConfig['enable.'][$key])) {
                        $result = TRUE;
                }
                return $result;
@@ -141,62 +134,69 @@ class AdminPanelView {
         * @return void
         */
        public function saveConfigOptions() {
-               $input = \TYPO3\CMS\Core\Utility\GeneralUtility::_GP('TSFE_ADMIN_PANEL');
+               $input = GeneralUtility::_GP('TSFE_ADMIN_PANEL');
+               $beUser = $this->getBackendUser();
                if (is_array($input)) {
                        // Setting
-                       $GLOBALS['BE_USER']->uc['TSFE_adminConfig'] = array_merge(!is_array($GLOBALS['BE_USER']->uc['TSFE_adminConfig']) ? array() : $GLOBALS['BE_USER']->uc['TSFE_adminConfig'], $input);
-                       // Candidate for t3lib_div::array_merge() if integer-keys will some day make trouble...
-                       unset($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['action']);
+                       $beUser->uc['TSFE_adminConfig'] = array_merge(!is_array($beUser->uc['TSFE_adminConfig']) ? array() : $beUser->uc['TSFE_adminConfig'], $input);
+                       unset($beUser->uc['TSFE_adminConfig']['action']);
                        // Actions:
                        if ($input['action']['clearCache'] && $this->isAdminModuleEnabled('cache')) {
-                               $GLOBALS['BE_USER']->extPageInTreeInfo = array();
-                               $theStartId = intval($input['cache_clearCacheId']);
-                               $GLOBALS['TSFE']->clearPageCacheContent_pidList($GLOBALS['BE_USER']->extGetTreeList($theStartId, $this->extGetFeAdminValue('cache', 'clearCacheLevels'), 0, $GLOBALS['BE_USER']->getPagePermsClause(1)) . $theStartId);
+                               $beUser->extPageInTreeInfo = array();
+                               $theStartId = (int)$input['cache_clearCacheId'];
+                               $this->getTypoScriptFrontendController()->clearPageCacheContent_pidList($beUser->extGetTreeList($theStartId, $this->extGetFeAdminValue('cache', 'clearCacheLevels'), 0, $beUser->getPagePermsClause(1)) . $theStartId);
                        }
                        // Saving
-                       $GLOBALS['BE_USER']->writeUC();
+                       $beUser->writeUC();
                }
-               $GLOBALS['TT']->LR = $this->extGetFeAdminValue('tsdebug', 'LR');
+               $this->getTimeTracker()->LR = $this->extGetFeAdminValue('tsdebug', 'LR');
                if ($this->extGetFeAdminValue('cache', 'noCache')) {
-                       $GLOBALS['TSFE']->set_no_cache();
+                       $this->getTypoScriptFrontendController()->set_no_cache('Admin Panel: No Caching', TRUE);
                }
        }
 
        /**
-        * Returns the value for a Admin Panel setting. You must specify both the module-key and the internal setting key.
+        * Returns the value for an Admin Panel setting.
         *
         * @param string $sectionName Module key
         * @param string $val Setting key
-        * @return string The setting value
+        * @return mixed The setting value
         */
        public function extGetFeAdminValue($sectionName, $val = '') {
-               // Check if module is enabled.
-               if ($this->isAdminModuleEnabled($sectionName)) {
-                       // Exceptions where the values can be overridden from backend:
-                       // deprecated
-                       if ($sectionName . '_' . $val == 'edit_displayIcons' && $GLOBALS['BE_USER']->extAdminConfig['module.']['edit.']['forceDisplayIcons']) {
-                               return TRUE;
-                       }
-                       if ($sectionName . '_' . $val == 'edit_displayFieldIcons' && $GLOBALS['BE_USER']->extAdminConfig['module.']['edit.']['forceDisplayFieldIcons']) {
-                               return TRUE;
-                       }
-                       // Override all settings with user TSconfig
-                       if ($val && $GLOBALS['BE_USER']->extAdminConfig['override.'][$sectionName . '.'][$val]) {
-                               return $GLOBALS['BE_USER']->extAdminConfig['override.'][$sectionName . '.'][$val];
-                       }
-                       if ($GLOBALS['BE_USER']->extAdminConfig['override.'][$sectionName]) {
-                               return $GLOBALS['BE_USER']->extAdminConfig['override.'][$sectionName];
-                       }
-                       $retVal = $val ? $GLOBALS['BE_USER']->uc['TSFE_adminConfig'][$sectionName . '_' . $val] : 1;
-                       if ($sectionName == 'preview' && $this->ext_forcePreview) {
-                               return !$val ? TRUE : $retVal;
-                       }
-                       // Regular check:
-                       // See if the menu is expanded!
-                       if ($this->isAdminModuleOpen($sectionName)) {
-                               return $retVal;
-                       }
+               if (!$this->isAdminModuleEnabled($sectionName)) {
+                       return NULL;
+               }
+
+               $beUser = $this->getBackendUser();
+               // Exceptions where the values can be overridden (forced) from backend:
+               // deprecated
+               if (
+                       $sectionName === 'edit' && (
+                               $val === 'displayIcons' && $beUser->extAdminConfig['module.']['edit.']['forceDisplayIcons'] ||
+                               $val === 'displayFieldIcons' && $beUser->extAdminConfig['module.']['edit.']['forceDisplayFieldIcons'] ||
+                               $val === 'editNoPopup' && $beUser->extAdminConfig['module.']['edit.']['forceNoPopup']
+                       )
+               ) {
+                       return TRUE;
+               }
+
+               // Override all settings with user TSconfig
+               if ($val && isset($beUser->extAdminConfig['override.'][$sectionName . '.'][$val])) {
+                       return $beUser->extAdminConfig['override.'][$sectionName . '.'][$val];
                }
+               if (isset($beUser->extAdminConfig['override.'][$sectionName])) {
+                       return $beUser->extAdminConfig['override.'][$sectionName];
+               }
+
+               $returnValue = $val ? $beUser->uc['TSFE_adminConfig'][$sectionName . '_' . $val] : 1;
+
+               // Exception for preview
+               if ($sectionName === 'preview' && $this->ext_forcePreview) {
+                       return !$val ? TRUE : $returnValue;
+               }
+
+               // See if the menu is expanded!
+               return $this->isAdminModuleOpen($sectionName) ? $returnValue : NULL;
        }
 
        /**
@@ -211,27 +211,24 @@ class AdminPanelView {
        /**
         * Returns TRUE if admin panel module is open
         *
-        * @param string $pre Module key
-        * @return boolean TRUE, if the admin panel is open for the specified admin panel module key.
+        * @param string $key Module key
+        * @return bool TRUE, if the admin panel is open for the specified admin panel module key.
         */
-       public function isAdminModuleOpen($pre) {
-               return $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_top'] && $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_' . $pre];
+       public function isAdminModuleOpen($key) {
+               return $this->getBackendUser()->uc['TSFE_adminConfig']['display_top'] && $this->getBackendUser()->uc['TSFE_adminConfig']['display_' . $key];
        }
 
-       /*****************************************************
-        *
-        * Admin Panel Rendering
-        *
-        ****************************************************/
        /**
         * Creates and returns the HTML code for the Admin Panel in the TSFE frontend.
         *
+        * @throws \UnexpectedValueException
         * @return string HTML for the Admin Panel
         */
        public function display() {
-               $GLOBALS['LANG']->includeLLFile('EXT:lang/locallang_tsfe.php');
-               $moduleContent = '';
-               if ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_top']) {
+               $this->getLanguageService()->includeLLFile('EXT:lang/locallang_tsfe.xlf');
+               $moduleContent = $footer = '';
+
+               if ($this->getBackendUser()->uc['TSFE_adminConfig']['display_top']) {
                        if ($this->isAdminModuleEnabled('preview')) {
                                $moduleContent .= $this->getPreviewModule();
                        }
@@ -250,27 +247,28 @@ class AdminPanelView {
                }
                if (is_array($GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['tslib/class.tslib_adminpanel.php']['extendAdminPanel'])) {
                        foreach ($GLOBALS['TYPO3_CONF_VARS']['SC_OPTIONS']['tslib/class.tslib_adminpanel.php']['extendAdminPanel'] as $classRef) {
-                               $hookObject = \TYPO3\CMS\Core\Utility\GeneralUtility::getUserObj($classRef);
-                               if (!$hookObject instanceof \TYPO3\CMS\Frontend\View\AdminPanelViewHookInterface) {
+                               $hookObject = GeneralUtility::getUserObj($classRef);
+                               if (!$hookObject instanceof AdminPanelViewHookInterface) {
                                        throw new \UnexpectedValueException('$hookObject must implement interface TYPO3\\CMS\\Frontend\\View\\AdminPanelViewHookInterface', 1311942539);
                                }
                                $moduleContent .= $hookObject->extendAdminPanel($moduleContent, $this);
                        }
                }
-               $row = $this->extGetLL('adminPanelTitle') . ': <span class="typo3-adminPanel-beuser">' . htmlspecialchars($GLOBALS['BE_USER']->user['username']) . '</span>';
-               $isVisible = $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_top'];
+               $row = $this->extGetLL('adminPanelTitle') . ': <span class="typo3-adminPanel-beuser">' . htmlspecialchars($this->getBackendUser()->user['username']) . '</span>';
+               $isVisible = $this->getBackendUser()->uc['TSFE_adminConfig']['display_top'];
                $cssClassName = 'typo3-adminPanel-panel-' . ($isVisible ? 'open' : 'closed');
-               $header = '<tr class="typo3-adminPanel-hRow">' . '<td colspan="2" id="typo3-adminPanel-header" class="' . $cssClassName . '">' . '<span class="typo3-adminPanel-header-title">' . $row . '</span>' . $this->linkSectionHeader('top', '<span class="typo3-adminPanel-header-button"></span>', 'typo3-adminPanel-header-buttonWrapper') . '<input type="hidden" name="TSFE_ADMIN_PANEL[display_top]" value="' . $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_top'] . '" /></td>' . '</tr>';
-               if ($moduleContent) {
-                       $footer = '<tr class="typo3-adminPanel-fRow">' . '<td colspan="2" id="typo3-adminPanel-footer">' . ($this->extNeedUpdate ? ' <input class="typo3-adminPanel-update" type="submit" value="' . $this->extGetLL('update') . '" />' : '') . '</td>' . '</tr>';
-               } else {
-                       $footer = '';
+               $header = '<div class="typo3-adminPanel-header">' . '<div id="typo3-adminPanel-header" class="' . $cssClassName . '">' . '<span class="typo3-adminPanel-header-title">' . $row . '</span>' . $this->linkSectionHeader('top', '<span class="typo3-adminPanel-header-button fa"></span>', 'typo3-adminPanel-header-buttonWrapper') . '<input type="hidden" name="TSFE_ADMIN_PANEL[display_top]" value="' . $this->getBackendUser()->uc['TSFE_adminConfig']['display_top'] . '" /></div>' . '</div>';
+               if ($moduleContent && $this->extNeedUpdate) {
+                       $footer = '<div id="typo3-adminPanel-footer">
+                                                       <input class="typo3-adminPanel-update btn btn-default" type="submit" value="' . $this->extGetLL('update') . '" />
+                                       </div>';
                }
-               $query = !\TYPO3\CMS\Core\Utility\GeneralUtility::_GET('id') ? '<input type="hidden" name="id" value="' . $GLOBALS['TSFE']->id . '" />' : '';
+               $query = !GeneralUtility::_GET('id') ? '<input type="hidden" name="id" value="' . $this->getTypoScriptFrontendController()->id . '" />' : '';
+
                // The dummy field is needed for Firefox: to force a page reload on submit
-               // with must change the form value with JavaScript (see "onsubmit" attribute of the "form" element")
+               // which must change the form value with JavaScript (see "onsubmit" attribute of the "form" element")
                $query .= '<input type="hidden" name="TSFE_ADMIN_PANEL[DUMMY]" value="" />';
-               foreach (\TYPO3\CMS\Core\Utility\GeneralUtility::_GET() as $key => $value) {
+               foreach (GeneralUtility::_GET() as $key => $value) {
                        if ($key != 'TSFE_ADMIN_PANEL') {
                                if (is_array($value)) {
                                        $query .= $this->getHiddenFields($key, $value);
@@ -281,13 +279,13 @@ class AdminPanelView {
                }
                $out = '
 <!--
-       TYPO3 admin panel start
+       TYPO3 Admin panel start
 -->
-<a id="TSFE_ADMIN"></a>
-<form id="TSFE_ADMIN_PANEL_FORM" name="TSFE_ADMIN_PANEL_FORM" action="' . htmlspecialchars(\TYPO3\CMS\Core\Utility\GeneralUtility::getIndpEnv('TYPO3_REQUEST_SCRIPT')) . '#TSFE_ADMIN" method="get" onsubmit="document.forms.TSFE_ADMIN_PANEL_FORM[\'TSFE_ADMIN_PANEL[DUMMY]\'].value=Math.random().toString().substring(2,8)">' . $query . '<table class="typo3-adminPanel">' . $header . $moduleContent . $footer . '</table></form>';
-               if ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_top']) {
-                       $out .= '<script type="text/javascript" src="t3lib/jsfunc.evalfield.js"></script>';
-                       $out .= '<script type="text/javascript">/*<![CDATA[*/' . \TYPO3\CMS\Core\Utility\GeneralUtility::minifyJavaScript('
+<a id="TSFE_ADMIN_PANEL"></a>
+<form id="TSFE_ADMIN_PANEL_FORM" name="TSFE_ADMIN_PANEL_FORM" action="' . htmlspecialchars(GeneralUtility::getIndpEnv('TYPO3_REQUEST_SCRIPT')) . '#TSFE_ADMIN_PANEL" method="get" onsubmit="document.forms.TSFE_ADMIN_PANEL_FORM[\'TSFE_ADMIN_PANEL[DUMMY]\'].value=Math.random().toString().substring(2,8)">' . $query . '<div class="typo3-adminPanel">' . $header . $moduleContent . $footer . '</div></form>';
+               if ($this->getBackendUser()->uc['TSFE_adminConfig']['display_top']) {
+                       $out .= '<script type="text/javascript" src="' . htmlspecialchars($this->getTypoScriptFrontendController()->absRefPrefix) . 'typo3/sysext/backend/Resources/Public/JavaScript/jsfunc.evalfield.js"></script>';
+                       $out .= '<script type="text/javascript">/*<![CDATA[*/' . GeneralUtility::minifyJavaScript('
                                var evalFunc = new evalFunc();
                                        // TSFEtypo3FormFieldSet()
                                function TSFEtypo3FormFieldSet(theField, evallist, is_in, checkbox, checkboxValue) {    //
@@ -315,7 +313,7 @@ class AdminPanelView {
                                        TSFEtypo3FormFieldSet(theField, evallist, is_in, checkbox, checkboxValue);
                                }') . '/*]]>*/</script><script language="javascript" type="text/javascript">' . $this->extJSCODE . '</script>';
                }
-               $out .= '<script src="' . \TYPO3\CMS\Core\Utility\GeneralUtility::locationHeaderUrl('t3lib/js/adminpanel.js') . '" type="text/javascript"></script><script type="text/javascript">/*<![CDATA[*/' . 'typo3AdminPanel = new TYPO3AdminPanel();typo3AdminPanel.init("typo3-adminPanel-header", "TSFE_ADMIN_PANEL_FORM");' . '/*]]>*/</script>
+               $out .= '<script src="' . GeneralUtility::locationHeaderUrl('typo3/sysext/frontend/Resources/Public/JavaScript/AdminPanel.js') . '" type="text/javascript"></script><script type="text/javascript">/*<![CDATA[*/' . 'typo3AdminPanel = new TYPO3AdminPanel();typo3AdminPanel.init("typo3-adminPanel-header", "TSFE_ADMIN_PANEL_FORM");' . '/*]]>*/</script>
 <!--
        TYPO3 admin panel end
 -->
@@ -345,9 +343,7 @@ class AdminPanelView {
        }
 
        /*****************************************************
-        *
         * Creating sections of the Admin Panel
-        *
         ****************************************************/
        /**
         * Creates the content for the "preview" section ("module") of the Admin Panel
@@ -357,20 +353,32 @@ class AdminPanelView {
         */
        protected function getPreviewModule() {
                $out = $this->extGetHead('preview');
-               if ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_preview']) {
+               if ($this->getBackendUser()->uc['TSFE_adminConfig']['display_preview']) {
                        $this->extNeedUpdate = TRUE;
-                       $out .= $this->extGetItem('preview_showHiddenPages', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[preview_showHiddenPages]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[preview_showHiddenPages]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['preview_showHiddenPages'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('preview_showHiddenRecords', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[preview_showHiddenRecords]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[preview_showHiddenRecords]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['preview_showHiddenRecords'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('preview_showHiddenPages', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[preview_showHiddenPages]" value="0" /><input type="checkbox" id="preview_showHiddenPages" name="TSFE_ADMIN_PANEL[preview_showHiddenPages]" value="1"' . ($this->getBackendUser()->uc['TSFE_adminConfig']['preview_showHiddenPages'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('preview_showHiddenRecords', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[preview_showHiddenRecords]" value="0" /><input type="checkbox" id="preview_showHiddenRecords" name="TSFE_ADMIN_PANEL[preview_showHiddenRecords]" value="1"' . ($this->getBackendUser()->uc['TSFE_adminConfig']['preview_showHiddenRecords'] ? ' checked="checked"' : '') . ' />');
                        // Simulate date
-                       $out .= $this->extGetItem('preview_simulateDate', '<input type="text" name="TSFE_ADMIN_PANEL[preview_simulateDate]_hr" onchange="TSFEtypo3FormFieldGet(\'TSFE_ADMIN_PANEL[preview_simulateDate]\', \'datetime\', \'\', 1,0);" /><input type="hidden" name="TSFE_ADMIN_PANEL[preview_simulateDate]" value="' . $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['preview_simulateDate'] . '" />');
+                       $out .= $this->extGetItem('preview_simulateDate', '<input type="text" id="preview_simulateDate" name="TSFE_ADMIN_PANEL[preview_simulateDate]_hr" onchange="TSFEtypo3FormFieldGet(\'TSFE_ADMIN_PANEL[preview_simulateDate]\', \'datetime\', \'\', 1,0);" /><input type="hidden" name="TSFE_ADMIN_PANEL[preview_simulateDate]" value="' . $this->getBackendUser()->uc['TSFE_adminConfig']['preview_simulateDate'] . '" />');
                        $this->extJSCODE .= 'TSFEtypo3FormFieldSet("TSFE_ADMIN_PANEL[preview_simulateDate]", "datetime", "", 0, 0);';
                        // Simulate fe_user:
-                       $options = '<option value="0">&nbsp;</option>';
-                       $res = $GLOBALS['TYPO3_DB']->exec_SELECTquery('fe_groups.uid, fe_groups.title', 'fe_groups,pages', 'pages.uid=fe_groups.pid AND pages.deleted=0 ' . \TYPO3\CMS\Backend\Utility\BackendUtility::deleteClause('fe_groups') . ' AND ' . $GLOBALS['BE_USER']->getPagePermsClause(1));
-                       while ($row = $GLOBALS['TYPO3_DB']->sql_fetch_assoc($res)) {
-                               $options .= '<option value="' . $row['uid'] . '"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['preview_simulateUserGroup'] == $row['uid'] ? ' selected="selected"' : '') . '>' . htmlspecialchars(('[' . $row['uid'] . '] ' . $row['title'])) . '</option>';
+
+                       $options = '';
+
+                       $res = $this->getDatabaseConnection()->exec_SELECTquery(
+                               'fe_groups.uid, fe_groups.title',
+                               'fe_groups,pages',
+                               'pages.uid=fe_groups.pid AND pages.deleted=0 ' . BackendUtility::deleteClause('fe_groups') . ' AND ' . $this->getBackendUser()->getPagePermsClause(1),
+                               '',
+                               'fe_groups.title ASC'
+                       );
+                       while ($row = $this->getDatabaseConnection()->sql_fetch_assoc($res)) {
+                               $options .= '<option value="' . $row['uid'] . '"' . ($this->getBackendUser()->uc['TSFE_adminConfig']['preview_simulateUserGroup'] == $row['uid'] ? ' selected="selected"' : '') . '>' . htmlspecialchars(($row['title'] . ' [' . $row['uid'] . ']')) . '</option>';
+                       }
+                       $this->getDatabaseConnection()->sql_free_result($res);
+                       if ($options) {
+                               $options = '<option value="0">&nbsp;</option>' . $options;
+                               $out .= $this->extGetItem('preview_simulateUserGroup', '<select id="preview_simulateUserGroup" name="TSFE_ADMIN_PANEL[preview_simulateUserGroup]">' . $options . '</select>');
                        }
-                       $out .= $this->extGetItem('preview_simulateUserGroup', '<select name="TSFE_ADMIN_PANEL[preview_simulateUserGroup]">' . $options . '</select>');
                }
                return $out;
        }
@@ -383,27 +391,32 @@ class AdminPanelView {
         */
        protected function getCacheModule() {
                $out = $this->extGetHead('cache');
-               if ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_cache']) {
+               $beUser = $this->getBackendUser();
+               if ($beUser->uc['TSFE_adminConfig']['display_cache']) {
                        $this->extNeedUpdate = TRUE;
-                       $out .= $this->extGetItem('cache_noCache', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[cache_noCache]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[cache_noCache]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['cache_noCache'] ? ' checked="checked"' : '') . ' />');
-                       $levels = $GLOBALS['BE_USER']->uc['TSFE_adminConfig']['cache_clearCacheLevels'];
+                       $out .= $this->extGetItem('cache_noCache', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[cache_noCache]" value="0" /><input id="cache_noCache" type="checkbox" name="TSFE_ADMIN_PANEL[cache_noCache]" value="1"' . ($beUser->uc['TSFE_adminConfig']['cache_noCache'] ? ' checked="checked"' : '') . ' />');
+                       $levels = $beUser->uc['TSFE_adminConfig']['cache_clearCacheLevels'];
                        $options = '';
                        $options .= '<option value="0"' . ($levels == 0 ? ' selected="selected"' : '') . '>' . $this->extGetLL('div_Levels_0') . '</option>';
                        $options .= '<option value="1"' . ($levels == 1 ? ' selected="selected"' : '') . '>' . $this->extGetLL('div_Levels_1') . '</option>';
                        $options .= '<option value="2"' . ($levels == 2 ? ' selected="selected"' : '') . '>' . $this->extGetLL('div_Levels_2') . '</option>';
-                       $out .= $this->extGetItem('cache_clearLevels', '<select name="TSFE_ADMIN_PANEL[cache_clearCacheLevels]">' . $options . '</select>' . '<input type="hidden" name="TSFE_ADMIN_PANEL[cache_clearCacheId]" value="' . $GLOBALS['TSFE']->id . '" /> <input type="submit" value="' . $this->extGetLL('update') . '" />');
+                       $out .= $this->extGetItem('cache_clearLevels', '<select id="cache_clearLevels" name="TSFE_ADMIN_PANEL[cache_clearCacheLevels]">' . $options . '</select>' . '<input type="hidden" name="TSFE_ADMIN_PANEL[cache_clearCacheId]" value="' . $GLOBALS['TSFE']->id . '" /> <input class="btn btn-default" type="submit" value="' . $this->extGetLL('update') . '" />');
                        // Generating tree:
-                       $depth = $this->extGetFeAdminValue('cache', 'clearCacheLevels');
+                       $depth = (int)$this->extGetFeAdminValue('cache', 'clearCacheLevels');
                        $outTable = '';
-                       $GLOBALS['BE_USER']->extPageInTreeInfo = array();
-                       $GLOBALS['BE_USER']->extPageInTreeInfo[] = array($GLOBALS['TSFE']->page['uid'], htmlspecialchars($GLOBALS['TSFE']->page['title']), $depth + 1);
-                       $GLOBALS['BE_USER']->extGetTreeList($GLOBALS['TSFE']->id, $depth, 0, $GLOBALS['BE_USER']->getPagePermsClause(1));
-                       foreach ($GLOBALS['BE_USER']->extPageInTreeInfo as $row) {
-                               $outTable .= '<tr>' . '<td><img src="typo3/gfx/clear.gif" width="' . ($depth + 1 - $row[2]) * 18 . '" height="1" alt="" /><img ' . \TYPO3\CMS\Backend\Utility\IconUtility::skinImg(TYPO3_mainDir, 'gfx/i/pages.gif', 'width="18" height="16"') . ' align="top" alt="" /> ' . htmlspecialchars($row[1]) . '</td><td>' . $GLOBALS['BE_USER']->extGetNumberOfCachedPages($row[0]) . '</td></tr>';
+                       $tsfe = $this->getTypoScriptFrontendController();
+                       $beUser->extPageInTreeInfo = array();
+                       $beUser->extPageInTreeInfo[] = array($tsfe->page['uid'], htmlspecialchars($tsfe->page['title']), $depth + 1);
+                       $beUser->extGetTreeList($tsfe->id, $depth, 0, $beUser->getPagePermsClause(1));
+                       /** @var IconFactory $iconFactory */
+                       $iconFactory = GeneralUtility::makeInstance(IconFactory::class);
+                       foreach ($beUser->extPageInTreeInfo as $key => $row) {
+                               $outTable .= '<tr class="typo3-adminPanel-itemRow ' . ($key % 2 == 0 ? 'line-even' : 'line-odd') . '">' . '<td><span style="width: ' . ($depth + 1 - $row[2]) * 18 . 'px; height: 1px; display: inline-block;"></span>' . $iconFactory->getIcon('apps-pagetree-page-default', Icon::SIZE_SMALL) . htmlspecialchars($row[1]) . '</td><td>' . $beUser->extGetNumberOfCachedPages($row[0]) . '</td></tr>';
                        }
-                       $outTable = '<br /><table>' . $outTable . '</table>';
-                       $outTable .= '<input type="submit" name="TSFE_ADMIN_PANEL[action][clearCache]" value="' . $this->extGetLL('cache_doit') . '" />';
-                       $out .= $this->extGetItem('cache_cacheEntries', $outTable);
+                       $outTable = '<table class="typo3-adminPanel-table"><thead><tr><th colspan="2">' . $this->extGetLL('cache_cacheEntries') . '</th></tr></thead>' . $outTable . '</table>';
+                       $outTable .= '<span class="fa fa-bolt clear-cache-icon"><!-- --></span><input class="btn btn-default clear-cache" type="submit" name="TSFE_ADMIN_PANEL[action][clearCache]" value="' . $this->extGetLL('cache_doit') . '" />';
+
+                       $out .= $this->extGetItem('', $outTable, '', 'typo3-adminPanel-tableRow', 'typo3-adminPanel-table-wrapper');
                }
                return $out;
        }
@@ -416,27 +429,25 @@ class AdminPanelView {
         */
        protected function getEditModule() {
                $out = $this->extGetHead('edit');
-               if ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_edit']) {
+               if ($this->getBackendUser()->uc['TSFE_adminConfig']['display_edit']) {
                        // If another page module was specified, replace the default Page module with the new one
-                       $newPageModule = trim($GLOBALS['BE_USER']->getTSConfigVal('options.overridePageModule'));
-                       $pageModule = \TYPO3\CMS\Backend\Utility\BackendUtility::isModuleSetInTBE_MODULES($newPageModule) ? $newPageModule : 'web_layout';
+                       $newPageModule = trim($this->getBackendUser()->getTSConfigVal('options.overridePageModule'));
+                       $pageModule = BackendUtility::isModuleSetInTBE_MODULES($newPageModule) ? $newPageModule : 'web_layout';
                        $this->extNeedUpdate = TRUE;
-                       $out .= $this->extGetItem('edit_displayFieldIcons', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[edit_displayFieldIcons]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[edit_displayFieldIcons]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['edit_displayFieldIcons'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('edit_displayIcons', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[edit_displayIcons]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[edit_displayIcons]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['edit_displayIcons'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('edit_editFormsOnPage', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[edit_editFormsOnPage]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[edit_editFormsOnPage]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['edit_editFormsOnPage'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('edit_editNoPopup', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[edit_editNoPopup]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[edit_editNoPopup]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['edit_editNoPopup'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('edit_displayFieldIcons', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[edit_displayFieldIcons]" value="0" /><input type="checkbox" id="edit_displayFieldIcons" name="TSFE_ADMIN_PANEL[edit_displayFieldIcons]" value="1"' . ($this->getBackendUser()->uc['TSFE_adminConfig']['edit_displayFieldIcons'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('edit_displayIcons', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[edit_displayIcons]" value="0" /><input type="checkbox" id="edit_displayIcons" name="TSFE_ADMIN_PANEL[edit_displayIcons]" value="1"' . ($this->getBackendUser()->uc['TSFE_adminConfig']['edit_displayIcons'] ? ' checked="checked"' : '') . ' />');
                        $out .= $this->extGetItem('', $this->ext_makeToolBar());
-                       if (!\TYPO3\CMS\Core\Utility\GeneralUtility::_GP('ADMCMD_view')) {
-                               $out .= $this->extGetItem('', '<a href="#" onclick="' . htmlspecialchars(('
+                       if (!GeneralUtility::_GP('ADMCMD_view')) {
+                               $out .= $this->extGetItem('', '<a class="btn btn-default" href="#" onclick="' . htmlspecialchars(('
                                                if (parent.opener && parent.opener.top && parent.opener.top.TS) {
-                                                       parent.opener.top.fsMod.recentIds["web"]=' . intval($GLOBALS['TSFE']->page['uid']) . ';
+                                                       parent.opener.top.fsMod.recentIds["web"]=' . (int)$this->getTypoScriptFrontendController()->page['uid'] . ';
                                                        if (parent.opener.top.content && parent.opener.top.content.nav_frame && parent.opener.top.content.nav_frame.refresh_nav) {
                                                                parent.opener.top.content.nav_frame.refresh_nav();
                                                        }
                                                        parent.opener.top.goToModule("' . $pageModule . '");
                                                        parent.opener.top.focus();
                                                } else {
-                                                       vHWin=window.open(\'' . TYPO3_mainDir . \TYPO3\CMS\Backend\Utility\BackendUtility::getBackendScript() . '\',\'' . md5(('Typo3Backend-' . $GLOBALS['TYPO3_CONF_VARS']['SYS']['sitename'])) . '\',\'status=1,menubar=1,scrollbars=1,resizable=1\');
+                                                       vHWin=window.open(' . GeneralUtility::quoteJSvalue(TYPO3_mainDir . BackendUtility::getBackendScript()) . ',\'' . md5('Typo3Backend-' . $GLOBALS['TYPO3_CONF_VARS']['SYS']['sitename']) . '\',\'status=1,menubar=1,scrollbars=1,resizable=1\');
                                                        vHWin.focus();
                                                }
                                                return false;
@@ -454,21 +465,23 @@ class AdminPanelView {
         */
        protected function getTSDebugModule() {
                $out = $this->extGetHead('tsdebug');
-               if ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_tsdebug']) {
+               $beuser = $this->getBackendUser();
+               if ($beuser->uc['TSFE_adminConfig']['display_tsdebug']) {
                        $this->extNeedUpdate = TRUE;
-                       $out .= $this->extGetItem('tsdebug_tree', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_tree]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[tsdebug_tree]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['tsdebug_tree'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('tsdebug_displayTimes', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_displayTimes]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[tsdebug_displayTimes]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['tsdebug_displayTimes'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('tsdebug_displayMessages', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_displayMessages]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[tsdebug_displayMessages]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['tsdebug_displayMessages'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('tsdebug_LR', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_LR]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[tsdebug_LR]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['tsdebug_LR'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('tsdebug_displayContent', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_displayContent]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[tsdebug_displayContent]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['tsdebug_displayContent'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('tsdebug_displayQueries', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_displayQueries]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[tsdebug_displayQueries]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['tsdebug_displayQueries'] ? ' checked="checked"' : '') . ' />');
-                       $out .= $this->extGetItem('tsdebug_forceTemplateParsing', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_forceTemplateParsing]" value="0" /><input type="checkbox" name="TSFE_ADMIN_PANEL[tsdebug_forceTemplateParsing]" value="1"' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['tsdebug_forceTemplateParsing'] ? ' checked="checked"' : '') . ' />');
-                       $GLOBALS['TT']->printConf['flag_tree'] = $this->extGetFeAdminValue('tsdebug', 'tree');
-                       $GLOBALS['TT']->printConf['allTime'] = $this->extGetFeAdminValue('tsdebug', 'displayTimes');
-                       $GLOBALS['TT']->printConf['flag_messages'] = $this->extGetFeAdminValue('tsdebug', 'displayMessages');
-                       $GLOBALS['TT']->printConf['flag_content'] = $this->extGetFeAdminValue('tsdebug', 'displayContent');
-                       $GLOBALS['TT']->printConf['flag_queries'] = $this->extGetFeAdminValue('tsdebug', 'displayQueries');
-                       $out .= '<tr><td colspan="2">' . $GLOBALS['TT']->printTSlog() . '</td></tr>';
+                       $out .= $this->extGetItem('tsdebug_tree', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_tree]" value="0" /><input type="checkbox" id="tsdebug_tree" name="TSFE_ADMIN_PANEL[tsdebug_tree]" value="1"' . ($beuser->uc['TSFE_adminConfig']['tsdebug_tree'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('tsdebug_displayTimes', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_displayTimes]" value="0" /><input id="tsdebug_displayTimes" type="checkbox" name="TSFE_ADMIN_PANEL[tsdebug_displayTimes]" value="1"' . ($beuser->uc['TSFE_adminConfig']['tsdebug_displayTimes'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('tsdebug_displayMessages', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_displayMessages]" value="0" /><input type="checkbox" id="tsdebug_displayMessages" name="TSFE_ADMIN_PANEL[tsdebug_displayMessages]" value="1"' . ($beuser->uc['TSFE_adminConfig']['tsdebug_displayMessages'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('tsdebug_LR', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_LR]" value="0" /><input type="checkbox" id="tsdebug_LR" name="TSFE_ADMIN_PANEL[tsdebug_LR]" value="1"' . ($beuser->uc['TSFE_adminConfig']['tsdebug_LR'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('tsdebug_displayContent', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_displayContent]" value="0" /><input type="checkbox" id="tsdebug_displayContent" name="TSFE_ADMIN_PANEL[tsdebug_displayContent]" value="1"' . ($beuser->uc['TSFE_adminConfig']['tsdebug_displayContent'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('tsdebug_displayQueries', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_displayQueries]" value="0" /><input type="checkbox" id="tsdebug_displayQueries" name="TSFE_ADMIN_PANEL[tsdebug_displayQueries]" value="1"' . ($beuser->uc['TSFE_adminConfig']['tsdebug_displayQueries'] ? ' checked="checked"' : '') . ' />');
+                       $out .= $this->extGetItem('tsdebug_forceTemplateParsing', '', '<input type="hidden" name="TSFE_ADMIN_PANEL[tsdebug_forceTemplateParsing]" value="0" /><input type="checkbox" id="tsdebug_forceTemplateParsing" name="TSFE_ADMIN_PANEL[tsdebug_forceTemplateParsing]" value="1"' . ($beuser->uc['TSFE_adminConfig']['tsdebug_forceTemplateParsing'] ? ' checked="checked"' : '') . ' />');
+                       $timeTracker = $this->getTimeTracker();
+                       $timeTracker->printConf['flag_tree'] = $this->extGetFeAdminValue('tsdebug', 'tree');
+                       $timeTracker->printConf['allTime'] = $this->extGetFeAdminValue('tsdebug', 'displayTimes');
+                       $timeTracker->printConf['flag_messages'] = $this->extGetFeAdminValue('tsdebug', 'displayMessages');
+                       $timeTracker->printConf['flag_content'] = $this->extGetFeAdminValue('tsdebug', 'displayContent');
+                       $timeTracker->printConf['flag_queries'] = $this->extGetFeAdminValue('tsdebug', 'displayQueries');
+                       $out .= $this->extGetItem('', $timeTracker->printTSlog(), '', 'typo3-adminPanel-tableRow', 'typo3-adminPanel-table-wrapper scroll-table');
                }
                return $out;
        }
@@ -480,62 +493,60 @@ class AdminPanelView {
         * @see display()
         */
        protected function getInfoModule() {
-               $out = $this->extGetHead('info');
-               if ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_info']) {
+               $head = $this->extGetHead('info');
+               $out = '';
+               $tsfe = $this->getTypoScriptFrontendController();
+               if ($this->getBackendUser()->uc['TSFE_adminConfig']['display_info']) {
                        $tableArr = array();
                        if ($this->extGetFeAdminValue('cache', 'noCache')) {
                                $theBytes = 0;
                                $count = 0;
-                               if (count($GLOBALS['TSFE']->imagesOnPage)) {
-                                       $tableArr[] = array('*Images on this page:*', '');
+                               if (!empty($tsfe->imagesOnPage)) {
+                                       $tableArr[] = array($this->extGetLL('info_imagesOnPage'), count($tsfe->imagesOnPage), TRUE);
                                        foreach ($GLOBALS['TSFE']->imagesOnPage as $file) {
                                                $fs = @filesize($file);
-                                               $tableArr[] = array('&ndash; ' . $file, \TYPO3\CMS\Core\Utility\GeneralUtility::formatSize($fs));
+                                               $tableArr[] = array(TAB . $file, GeneralUtility::formatSize($fs));
                                                $theBytes += $fs;
                                                $count++;
                                        }
                                }
                                // Add an empty line
-                               $tableArr[] = array('', '');
-                               $tableArr[] = array('*Total number of images:*', $count);
-                               $tableArr[] = array('*Total image file sizes:*', \TYPO3\CMS\Core\Utility\GeneralUtility::formatSize($theBytes));
-                               $tableArr[] = array('*Document size:*', \TYPO3\CMS\Core\Utility\GeneralUtility::formatSize(strlen($GLOBALS['TSFE']->content)));
-                               $tableArr[] = array('*Total page load:*', \TYPO3\CMS\Core\Utility\GeneralUtility::formatSize(strlen($GLOBALS['TSFE']->content) + $theBytes));
+                               $tableArr[] = array($this->extGetLL('info_imagesSize'), GeneralUtility::formatSize($theBytes), TRUE);
+                               $tableArr[] = array($this->extGetLL('info_DocumentSize'), GeneralUtility::formatSize(strlen($tsfe->content)), TRUE);
                                $tableArr[] = array('', '');
                        }
-                       $tableArr[] = array('id:', $GLOBALS['TSFE']->id);
-                       $tableArr[] = array('type:', $GLOBALS['TSFE']->type);
-                       $tableArr[] = array('gr_list:', $GLOBALS['TSFE']->gr_list);
-                       $tableArr[] = array('no_cache:', $GLOBALS['TSFE']->no_cache ? 1 : 0);
-                       $tableArr[] = array('USER_INT objects:', count($GLOBALS['TSFE']->config['INTincScript']));
-                       $tableArr[] = array('fe_user, name:', $GLOBALS['TSFE']->fe_user->user['username']);
-                       $tableArr[] = array('fe_user, uid:', $GLOBALS['TSFE']->fe_user->user['uid']);
-                       // Add an empty line
-                       $tableArr[] = array('', '');
-                       // Parsetime:
-                       $tableArr[] = array('*Total parsetime:*', $GLOBALS['TSFE']->scriptParseTime . ' ms');
+                       $tableArr[] = array($this->extGetLL('info_id'), $tsfe->id);
+                       $tableArr[] = array($this->extGetLL('info_type'), $tsfe->type);
+                       $tableArr[] = array($this->extGetLL('info_groupList'), $tsfe->gr_list);
+                       $tableArr[] = array($this->extGetLL('info_noCache'), $this->extGetLL('info_noCache_' . ($tsfe->no_cache ? 'no' : 'yes')));
+                       $tableArr[] = array($this->extGetLL('info_countUserInt'), count($tsfe->config['INTincScript']));
+
+                       if (!empty($tsfe->fe_user->user['uid'])) {
+                               $tableArr[] = array($this->extGetLL('info_feuserName'), htmlspecialchars($tsfe->fe_user->user['username']));
+                               $tableArr[] = array($this->extGetLL('info_feuserId'), htmlspecialchars($tsfe->fe_user->user['uid']));
+                       }
+                       $tableArr[] = array($this->extGetLL('info_totalParsetime'), $tsfe->scriptParseTime . ' ms', TRUE);
                        $table = '';
-                       foreach ($tableArr as $arr) {
-                               // Put text wrapped by "*" between <strong> tags
-                               if (strlen($arr[0])) {
-                                       $value1 = preg_replace('/^\\*(.*)\\*$/', '$1', $arr[0], -1, $count);
-                                       $value1 = ($count ? '<strong>' : '') . $value1 . ($count ? '</strong>' : '');
-                               } else {
-                                       $value1 = '&nbsp;';
-                               }
-                               $value2 = strlen($arr[1]) ? $arr[1] : '&nbsp;';
-                               $value2 = $value2;
-                               $table .= '<tr class="typo3-adminPanel-itemRow">' . '<td class="typo3-adminPanel-section-content-title">' . $value1 . '</td>' . '<td class="typo3-adminPanel-section-content">' . $value2 . '</td>' . '</tr>';
+                       foreach ($tableArr as $key => $arr) {
+                               $label = (isset($arr[2]) ? '<strong>' . $arr[0] . '</strong>' : $arr[0]);
+                               $value = (string)$arr[1] !== '' ? $arr[1] : '';
+                               $table .=
+                                       '<tr class="typo3-adminPanel-itemRow ' . ($key % 2 == 0 ? 'line-even' : 'line-odd') . '">
+                                                       <td>' . $label . '</td>
+                                                       <td>' . htmlspecialchars($value) . '</td>
+                                               </tr>';
                        }
                        $out .= $table;
+                       $out = '<table class="typo3-adminPanel-table">' . $out . '</table>';
+                       $out = $this->extGetItem('', $out, '', 'typo3-adminPanel-tableRow', 'typo3-adminPanel-table-wrapper');
                }
+
+               $out = $head . $out;
                return $out;
        }
 
        /*****************************************************
-        *
         * Admin Panel Layout Helper functions
-        *
         ****************************************************/
        /**
         * Returns a row (with colspan=4) which is a header for a section in the Admin Panel.
@@ -548,22 +559,28 @@ class AdminPanelView {
         */
        public function extGetHead($sectionSuffix) {
                $settingName = 'display_' . $sectionSuffix;
-               $isVisible = $GLOBALS['BE_USER']->uc['TSFE_adminConfig'][$settingName];
+               $isVisible = $this->getBackendUser()->uc['TSFE_adminConfig'][$settingName];
                $cssClassName = 'typo3-adminPanel-section-' . ($isVisible ? 'open' : 'closed');
-               return '<tr class="typo3-adminPanel-section-title"><td colspan="2">' . $this->linkSectionHeader($sectionSuffix, $this->extGetLL($sectionSuffix), $cssClassName) . '<input type="hidden" name="TSFE_ADMIN_PANEL[' . $settingName . ']" value="' . $isVisible . '" /></td></tr>';
+               return '<div class="typo3-adminPanel-section-title"><div class="wrapper">' . $this->linkSectionHeader($sectionSuffix, $this->extGetLL($sectionSuffix), $cssClassName) . '<input type="hidden" name="TSFE_ADMIN_PANEL[' . $settingName . ']" value="' . $isVisible . '" /></div></div>';
        }
 
        /**
         * Wraps a string in a link which will open/close a certain part of the Admin Panel
         *
         * @param string $sectionSuffix The code for the display_ label/key
-        * @param string $sectionTitle Input string
+        * @param string $sectionTitle Title (in HTML-format)
         * @param string $className The classname for the <a> tag
         * @return string $className Linked input string
         * @see extGetHead()
         */
        public function linkSectionHeader($sectionSuffix, $sectionTitle, $className = '') {
-               return '<div class="typo3-adminPanel-label"><a href="javascript:void(0)" onclick="' . htmlspecialchars(('document.TSFE_ADMIN_PANEL_FORM[\'TSFE_ADMIN_PANEL[display_' . $sectionSuffix . ']\'].value=' . ($GLOBALS['BE_USER']->uc['TSFE_adminConfig']['display_' . $sectionSuffix] ? '0' : '1') . ';document.TSFE_ADMIN_PANEL_FORM.submit();return false;')) . '"' . ($className ? ' class="' . $className . '"' : '') . '>' . $sectionTitle . '</a></div>';
+               $onclick = 'document.TSFE_ADMIN_PANEL_FORM[' . GeneralUtility::quoteJSvalue('TSFE_ADMIN_PANEL[display_' . $sectionSuffix . ']') . '].value=' . ($this->getBackendUser()->uc['TSFE_adminConfig']['display_' . $sectionSuffix] ? '0' : '1') . ';document.TSFE_ADMIN_PANEL_FORM.submit();return false;';
+               $content = '<div class="typo3-adminPanel-label">
+                                               <a href="javascript:void(0)" onclick="' . htmlspecialchars($onclick) . '"' . ($className ? ' class="fa ' . htmlspecialchars($className) . '"' : '') . '>'
+                       . $sectionTitle .
+                       '</a>
+               </div>';
+               return $content;
        }
 
        /**
@@ -572,12 +589,18 @@ class AdminPanelView {
         *
         * @param string $title Key to label
         * @param string $content The HTML content for the forth table cell.
-        * @param string $checkboxContent The HTML for a checkbox or hidden fields
+        * @param string $checkbox The HTML for a checkbox or hidden fields.
+        * @param string  $innerDivClass The Class attribute for the td element.
+        * @param string  $outerDivClass The Class attribute for the tr element.
         * @return string HTML table row.
         * @see extGetHead()
         */
-       public function extGetItem($title, $content = '', $checkboxContent = '') {
-               $out = '<tr class="typo3-adminPanel-itemRow">' . '<td class="typo3-adminPanel-section-content">' . $checkboxContent . ($title ? $this->extGetLL($title) : '&nbsp;') . $content . '</td></tr>';
+       public function extGetItem($title, $content = '', $checkbox = '', $outerDivClass = NULL, $innerDivClass = NULL) {
+               $title = $title ? '<label for="' . htmlspecialchars($title) . '">' . $this->extGetLL($title) . '</label>' : '';
+               $outerDivClass === NULL ? $out = '<div class="typo3-adminPanel-itemRow">' : $out = '<div class="' . $outerDivClass . '">';
+               $innerDivClass === NULL ? $out .= '<div class="typo3-adminPanel-section-content">' : $out .= '<div class="' . $innerDivClass . '">';
+               $out .= $checkbox . $title . $content . '</div>
+                               </div>';
                return $out;
        }
 
@@ -587,66 +610,137 @@ class AdminPanelView {
         * @return string A string containing images wrapped in <a>-tags linking them to proper functions.
         */
        public function ext_makeToolBar() {
+               /** @var IconFactory $iconFactory */
+               $iconFactory = GeneralUtility::makeInstance(IconFactory::class);
+
+               $tsfe = $this->getTypoScriptFrontendController();
                //  If mod.web_list.newContentWiz.overrideWithExtension is set, use that extension's create new content wizard instead:
-               $tsConfig = \TYPO3\CMS\Backend\Utility\BackendUtility::getModTSconfig($this->pageinfo['uid'], 'mod.web_list');
+               $tsConfig = BackendUtility::getModTSconfig($tsfe->page['uid'], 'mod.web_list');
                $tsConfig = $tsConfig['properties']['newContentWiz.']['overrideWithExtension'];
-               $newContentWizScriptPath = \TYPO3\CMS\Core\Utility\ExtensionManagementUtility::isLoaded($tsConfig) ? \TYPO3\CMS\Core\Utility\ExtensionManagementUtility::extRelPath($tsConfig) . 'mod1/db_new_content_el.php' : TYPO3_mainDir . 'sysext/cms/layout/db_new_content_el.php';
-               $perms = $GLOBALS['BE_USER']->calcPerms($GLOBALS['TSFE']->page);
-               $langAllowed = $GLOBALS['BE_USER']->checkLanguageAccess($GLOBALS['TSFE']->sys_language_uid);
-               $id = $GLOBALS['TSFE']->id;
-               $toolBar = '<a href="' . htmlspecialchars((TYPO3_mainDir . 'show_rechis.php?element=' . rawurlencode(('pages:' . $id)) . '&returnUrl=' . rawurlencode(\TYPO3\CMS\Core\Utility\GeneralUtility::getIndpEnv('REQUEST_URI')))) . '#latest">' . '<img ' . \TYPO3\CMS\Backend\Utility\IconUtility::skinImg(TYPO3_mainDir, 'gfx/history2.gif', 'width="13" height="12"') . ' hspace="2" border="0" align="top" title="' . $this->extGetLL('edit_recordHistory') . '" alt="" /></a>';
-               if ($perms & 16 && $langAllowed) {
+               $newContentWizScriptPath = ExtensionManagementUtility::isLoaded($tsConfig) ? ExtensionManagementUtility::extRelPath($tsConfig) . 'mod1/db_new_content_el.php?' : BackendUtility::getModuleUrl('new_content_element') . '&';
+               $perms = $this->getBackendUser()->calcPerms($tsfe->page);
+               $langAllowed = $this->getBackendUser()->checkLanguageAccess($tsfe->sys_language_uid);
+               $id = $tsfe->id;
+               $returnUrl = GeneralUtility::getIndpEnv('REQUEST_URI');
+
+               $icon = $iconFactory->getIcon('actions-document-history-open', Icon::SIZE_SMALL);
+               $link = BackendUtility::getModuleUrl('record_history', array('element' => 'pages:' . $id, 'returnUrl' => $returnUrl));
+               $toolBar = '<a class="t3-icon btn btn-default" href="' . htmlspecialchars($link) . '#latest" title="' . $this->extGetLL('edit_recordHistory') . '">' . $icon . '</a>';
+               if ($perms & Permission::CONTENT_EDIT && $langAllowed) {
                        $params = '';
-                       if ($GLOBALS['TSFE']->sys_language_uid) {
-                               $params = '&sys_language_uid=' . $GLOBALS['TSFE']->sys_language_uid;
+                       if ($tsfe->sys_language_uid) {
+                               $params = '&sys_language_uid=' . $tsfe->sys_language_uid;
                        }
-                       $toolBar .= '<a href="' . htmlspecialchars(($newContentWizScriptPath . '?id=' . $id . $params . '&returnUrl=' . rawurlencode(\TYPO3\CMS\Core\Utility\GeneralUtility::getIndpEnv('REQUEST_URI')))) . '">' . '<img ' . \TYPO3\CMS\Backend\Utility\IconUtility::skinImg(TYPO3_mainDir, 'gfx/new_record.gif', 'width="16" height="12"') . ' hspace="1" border="0" align="top" title="' . $this->extGetLL('edit_newContentElement') . '" alt="" /></a>';
+                       $icon = $iconFactory->getIcon('actions-document-new', Icon::SIZE_SMALL);
+                       $link = $newContentWizScriptPath . 'id=' . $id . $params . '&returnUrl=' . rawurlencode($returnUrl);
+                       $toolBar .= '<a class="t3-icon btn btn-default" href="' . htmlspecialchars($link) . '" title="' . $this->extGetLL('edit_newContentElement') .  '"">' . $icon . '</a>';
                }
-               if ($perms & 2) {
-                       $toolBar .= '<a href="' . htmlspecialchars((TYPO3_mainDir . 'move_el.php?table=pages&uid=' . $id . '&returnUrl=' . rawurlencode(\TYPO3\CMS\Core\Utility\GeneralUtility::getIndpEnv('REQUEST_URI')))) . '">' . '<img ' . \TYPO3\CMS\Backend\Utility\IconUtility::skinImg(TYPO3_mainDir, 'gfx/move_page.gif', 'width="11" height="12') . ' hspace="2" border="0" align="top" title="' . $this->extGetLL('edit_move_page') . '" alt="" /></a>';
+               if ($perms & Permission::PAGE_EDIT) {
+                       $icon = $iconFactory->getIcon('actions-document-move', Icon::SIZE_SMALL);
+                       $link = BackendUtility::getModuleUrl('move_element', ['table' => 'pages', 'uid' => $id, 'returnUrl' => $returnUrl]);
+                       $toolBar .= '<a class="t3-icon btn btn-default" href="' . htmlspecialchars($link) . '" title="' . $this->extGetLL('edit_move_page') . '">' . $icon . '</a>';
                }
-               if ($perms & 8) {
-                       $toolBar .= '<a href="' . htmlspecialchars((TYPO3_mainDir . 'db_new.php?id=' . $id . '&pagesOnly=1&returnUrl=' . rawurlencode(\TYPO3\CMS\Core\Utility\GeneralUtility::getIndpEnv('REQUEST_URI')))) . '">' . '<img ' . \TYPO3\CMS\Backend\Utility\IconUtility::skinImg(TYPO3_mainDir, 'gfx/new_page.gif', 'width="13" height="12"') . ' hspace="0" border="0" align="top" title="' . $this->extGetLL('edit_newPage') . '" alt="" /></a>';
+               if ($perms & Permission::PAGE_NEW) {
+                       $toolBar .= '<a class="t3-icon btn btn-default" href="' . htmlspecialchars(BackendUtility::getModuleUrl('db_new', ['id' => $id, 'pagesOnly' => 1, 'returnUrl' => $returnUrl])) . '" title="' . $this->extGetLL('edit_newPage') . '">'
+                               . $iconFactory->getIcon('actions-page-new', Icon::SIZE_SMALL)
+                               . '</a>';
                }
-               if ($perms & 2) {
-                       $params = '&edit[pages][' . $id . ']=edit';
-                       $toolBar .= '<a href="' . htmlspecialchars((TYPO3_mainDir . 'alt_doc.php?' . $params . '&noView=1&returnUrl=' . rawurlencode(\TYPO3\CMS\Core\Utility\GeneralUtility::getIndpEnv('REQUEST_URI')))) . '">' . '<img ' . \TYPO3\CMS\Backend\Utility\IconUtility::skinImg(TYPO3_mainDir, 'gfx/edit2.gif', 'width="11" height="12"') . 'hspace="2" border="0" align="top" title="' . $this->extGetLL('edit_editPageProperties') . '" alt="" /></a>';
-                       if ($GLOBALS['TSFE']->sys_language_uid && $langAllowed) {
-                               $res = $GLOBALS['TYPO3_DB']->exec_SELECTquery('uid,pid,t3ver_state', 'sys_language_overlay', 'pid=' . intval($id) . ' AND sys_language_uid=' . $GLOBALS['TSFE']->sys_language_uid . $GLOBALS['TSFE']->sys_page->enableFields('sys_language_overlay'), '', '', '1');
-                               $row = $GLOBALS['TYPO3_DB']->sql_fetch_assoc($res);
-                               $GLOBALS['TSFE']->sys_page->versionOL('sys_language_overlay', $row);
+               if ($perms & Permission::PAGE_EDIT) {
+                       $icon = $iconFactory->getIcon('actions-document-open', Icon::SIZE_SMALL);
+                       $url = BackendUtility::getModuleUrl('record_edit', array(
+                               'edit[pages][' . $id . ']' => 'edit',
+                               'noView' => 1,
+                               'returnUrl' => $returnUrl
+                       ));
+                       $toolBar .= '<a class="t3-icon btn btn-default" href="' . htmlspecialchars($url) . '">' . $icon . '</a>';
+                       if ($tsfe->sys_language_uid && $langAllowed) {
+                               $row = $this->getDatabaseConnection()->exec_SELECTgetSingleRow(
+                                       'uid,pid,t3ver_state',
+                                       'pages_language_overlay',
+                                       'pid=' . (int)$id .
+                                       ' AND sys_language_uid=' . $tsfe->sys_language_uid .
+                                       $tsfe->sys_page->enableFields('pages_language_overlay')
+                               );
+                               $tsfe->sys_page->versionOL('pages_language_overlay', $row);
                                if (is_array($row)) {
-                                       $params = '&edit[sys_language_overlay][' . $row['uid'] . ']=edit';
-                                       $toolBar .= '<a href="' . htmlspecialchars((TYPO3_mainDir . 'alt_doc.php?' . $params . '&noView=1&returnUrl=' . rawurlencode(\TYPO3\CMS\Core\Utility\GeneralUtility::getIndpEnv('REQUEST_URI')))) . '">' . '<img ' . \TYPO3\CMS\Backend\Utility\IconUtility::skinImg(TYPO3_mainDir, 'gfx/edit3.gif', 'width="11" height="12"') . ' hspace="2" border="0" align="top" title="' . $this->extGetLL('edit_editPageOverlay') . '" alt="" /></a>';
+                                       $icon = '<span title="' . $this->extGetLL('edit_editPageOverlay', TRUE) . '">'
+                                               . $iconFactory->getIcon('mimetypes-x-content-page-language-overlay', Icon::SIZE_SMALL) . '</span>';
+                                       $url = BackendUtility::getModuleUrl('record_edit', array(
+                                               'edit[pages_language_overlay][' . $row['uid'] . ']' => 'edit',
+                                               'noView' => 1,
+                                               'returnUrl' => $returnUrl
+                                       ));
+                                       $toolBar .= '<a href="' . htmlspecialchars($url) . '">' . $icon . '</a>';
                                }
                        }
                }
-               if ($GLOBALS['BE_USER']->check('modules', 'web_list')) {
-                       $urlParams = array();
-                       $urlParams['id'] = $id;
-                       $urlParams['returnUrl'] = \TYPO3\CMS\Core\Utility\GeneralUtility::getIndpEnv('REQUEST_URI');
-                       $toolBar .= '<a href="' . htmlspecialchars((TYPO3_mainDir . \TYPO3\CMS\Backend\Utility\BackendUtility::getModuleUrl('web_list', $urlParams))) . '">' . '<img ' . \TYPO3\CMS\Backend\Utility\IconUtility::skinImg(TYPO3_mainDir, 'gfx/list.gif', 'width="11" height="11"') . ' hspace="2" border="0" align="top" title="' . $this->extGetLL('edit_db_list') . '" alt="" /></a>';
+               if ($this->getBackendUser()->check('modules', 'web_list')) {
+                       $urlParams = array(
+                               'id' => $id,
+                               'returnUrl' => GeneralUtility::getIndpEnv('REQUEST_URI')
+                       );
+                       $icon = '<span title="' . $this->extGetLL('edit_db_list', FALSE) . '">' . $iconFactory->getIcon('actions-system-list-open', Icon::SIZE_SMALL)->render() . '</span>';
+                       $toolBar .= '<a class="t3-icon btn btn-default" href="' . htmlspecialchars(BackendUtility::getModuleUrl('web_list', $urlParams)) . '">' . $icon . '</a>';
                }
+
+               $toolBar = '<div class="toolbar btn-group" role="group">' . $toolBar . '</div>';
                return $toolBar;
        }
 
        /**
-        * Returns the label for key, $key. If a translation for the language set in $GLOBALS['BE_USER']->uc['lang'] is found that is returned, otherwise the default value.
-        * IF the global variable $LOCAL_LANG is NOT an array (yet) then this function loads the global $LOCAL_LANG array with the content of "sysext/lang/locallang_tsfe.php" so that the values therein can be used for labels in the Admin Panel
+        * Translate given key
         *
-        * FIXME The function should convert to $TSFE->renderCharset, not to UTF8!
-        *
-        * @param string $key Key for a label in the $LOCAL_LANG array of "sysext/lang/locallang_tsfe.php
+        * @param string $key Key for a label in the $LOCAL_LANG array of "sysext/lang/locallang_tsfe.xlf
+        * @param bool $convertWithHtmlspecialchars If TRUE the language-label will be sent through htmlspecialchars
         * @return string The value for the $key
         */
-       public function extGetLL($key) {
-               // Label string in the default backend output charset.
-               $labelStr = htmlspecialchars($GLOBALS['LANG']->getLL($key));
-               $labelStr = $GLOBALS['LANG']->csConvObj->utf8_to_entities($labelStr);
+       protected function extGetLL($key, $convertWithHtmlspecialchars = TRUE) {
+               $labelStr = $this->getLanguageService()->getLL($key);
+               if ($convertWithHtmlspecialchars) {
+                       $labelStr = htmlspecialchars($labelStr);
+               }
                return $labelStr;
        }
 
-}
+       /**
+        * Returns LanguageService
+        *
+        * @return \TYPO3\CMS\Lang\LanguageService
+        */
+       protected function getLanguageService() {
+               return $GLOBALS['LANG'];
+       }
+
+       /**
+        * Returns the current BE user.
+        *
+        * @return \TYPO3\CMS\Backend\FrontendBackendUserAuthentication
+        */
+       protected function getBackendUser() {
+               return $GLOBALS['BE_USER'];
+       }
+
+       /**
+        * Returns the database connection
+        *
+        * @return \TYPO3\CMS\Core\Database\DatabaseConnection
+        */
+       protected function getDatabaseConnection() {
+               return $GLOBALS['TYPO3_DB'];
+       }
+
+       /**
+        * @return \TYPO3\CMS\Frontend\Controller\TypoScriptFrontendController
+        */
+       protected function getTypoScriptFrontendController() {
+               return $GLOBALS['TSFE'];
+       }
 
+       /**
+        * @return \TYPO3\CMS\Core\TimeTracker\TimeTracker
+        */
+       protected function getTimeTracker() {
+               return $GLOBALS['TT'];
+       }
 
-?>
\ No newline at end of file
+}