[TASK] Move ViewHelper arguments to initializeArguments() in ext:install
[Packages/TYPO3.CMS.git] / typo3 / sysext / install / Classes / ViewHelpers / Be / ContainerViewHelper.php
index 0584423..3925b62 100644 (file)
@@ -30,7 +30,7 @@ namespace TYPO3\CMS\Install\ViewHelpers\Be;
  * </output>
  *
  * <code title="All options">
- * <f:be.container pageTitle="foo" enableClickMenu="false" loadPrototype="false" loadScriptaculous="false" scriptaculousModule="someModule,someOtherModule" loadExtJs="true" loadExtJsTheme="false" extJsAdapter="jQuery" enableExtJsDebug="true">your module content</f:be.container>
+ * <f:be.container pageTitle="foo">your module content</f:be.container>
  * </code>
  * <output>
  * "your module content" wrapped with proper head & body tags.
@@ -39,68 +39,58 @@ namespace TYPO3\CMS\Install\ViewHelpers\Be;
  *
  * @internal
  */
-class ContainerViewHelper extends \TYPO3\CMS\Fluid\ViewHelpers\Be\AbstractBackendViewHelper {
+class ContainerViewHelper extends \TYPO3\CMS\Fluid\ViewHelpers\Be\AbstractBackendViewHelper
+{
+    /**
+     * @var bool
+     */
+    protected $escapeOutput = false;
 
-       /**
-        * Render start page with \TYPO3\CMS\Backend\Template\DocumentTemplate and pageTitle
-        *
-        * @param string $pageTitle title tag of the module. Not required by default, as BE modules are shown in a frame
-        * @param bool $enableClickMenu If TRUE, loads clickmenu.js required by BE context menus. Defaults to TRUE
-        * @param bool $loadPrototype specifies whether to load prototype library. Defaults to TRUE
-        * @param bool $loadScriptaculous specifies whether to load scriptaculous libraries. Defaults to FALSE
-        * @param string $scriptaculousModule additionales modules for scriptaculous
-        * @param bool $loadExtJs specifies whether to load ExtJS library. Defaults to FALSE
-        * @param bool $loadExtJsTheme whether to load ExtJS "grey" theme. Defaults to FALSE
-        * @param string $extJsAdapter load alternative adapter (ext-base is default adapter)
-        * @param bool $enableExtJsDebug if TRUE, debug version of ExtJS is loaded. Use this for development only
-        * @param array $addCssFiles Custom CSS files to be loaded
-        * @param array $addJsFiles Custom JavaScript files to be loaded
-        * @param array $triggers Defined triggers to be forwarded to client (e.g. refreshing backend widgets)
-        *
-        * @return string
-        * @see \TYPO3\CMS\Backend\Template\DocumentTemplate
-        * @see \TYPO3\CMS\Core\Page\PageRenderer
-        */
-       public function render($pageTitle = '', $enableClickMenu = TRUE, $loadPrototype = TRUE, $loadScriptaculous = FALSE, $scriptaculousModule = '', $loadExtJs = FALSE, $loadExtJsTheme = TRUE, $extJsAdapter = '', $enableExtJsDebug = FALSE, $addCssFiles = array(), $addJsFiles = array(), $triggers = array()) {
-               $doc = $this->getDocInstance();
-               $pageRenderer = $doc->getPageRenderer();
+    /**
+     * @var bool
+     */
+    protected $escapeChildren = false;
 
-               $doc->JScode .= $doc->wrapScriptTags($doc->redirectUrls());
-               if ($enableClickMenu) {
-                       $doc->loadJavascriptLib('sysext/backend/Resources/Public/JavaScript/clickmenu.js');
-               }
-               if ($loadPrototype) {
-                       $pageRenderer->loadPrototype();
-               }
-               if ($loadScriptaculous) {
-                       $pageRenderer->loadScriptaculous($scriptaculousModule);
-               }
-               if ($loadExtJs) {
-                       $pageRenderer->loadExtJS(TRUE, $loadExtJsTheme, $extJsAdapter);
-                       if ($enableExtJsDebug) {
-                               $pageRenderer->enableExtJsDebug();
-                       }
-               }
-               if (is_array($addCssFiles) && count($addCssFiles) > 0) {
-                       foreach ($addCssFiles as $addCssFile) {
-                               $pageRenderer->addCssFile($addCssFile);
-                       }
-               }
-               if (is_array($addJsFiles) && count($addJsFiles) > 0) {
-                       foreach ($addJsFiles as $addJsFile) {
-                               $pageRenderer->addJsFile($addJsFile);
-                       }
-               }
-               // Handle triggers
-               if (!empty($triggers[\TYPO3\CMS\Extensionmanager\Controller\AbstractController::TRIGGER_RefreshModuleMenu])) {
-                       $pageRenderer->addJsInlineCode(
-                               \TYPO3\CMS\Extensionmanager\Controller\AbstractController::TRIGGER_RefreshModuleMenu,
-                               'if (top.TYPO3ModuleMenu.refreshMenu) { top.TYPO3ModuleMenu.refreshMenu(); }'
-                       );
-               }
-               $output = $this->renderChildren();
-               $output = $doc->startPage($pageTitle) . $output;
-               $output .= $doc->endPage();
-               return $output;
-       }
+    /**
+     * Initialize arguments
+     */
+    public function initializeArguments()
+    {
+        parent::initializeArguments();
+        $this->registerArgument('pageTitle', 'string', 'title tag of the module. Not required by default, as BE modules are shown in a frame', false, '');
+        $this->registerArgument('addCssFiles', 'array', 'Custom CSS files to be loaded', false, []);
+        $this->registerArgument('addJsFiles', 'array', 'Custom JavaScript files to be loaded', false, []);
+    }
+
+    /**
+     * Render start page with \TYPO3\CMS\Backend\Template\DocumentTemplate and pageTitle
+     *
+     * @return string
+     * @see \TYPO3\CMS\Backend\Template\DocumentTemplate
+     * @see \TYPO3\CMS\Core\Page\PageRenderer
+     */
+    public function render()
+    {
+        $pageTitle = $this->arguments['pageTitle'];
+        $addCssFiles = $this->arguments['addCssFiles'];
+        $addJsFiles = $this->arguments['addJsFiles'];
+
+        $doc = $this->getDocInstance();
+        $pageRenderer = $this->getPageRenderer();
+
+        if (is_array($addCssFiles) && !empty($addCssFiles)) {
+            foreach ($addCssFiles as $addCssFile) {
+                $pageRenderer->addCssFile($addCssFile);
+            }
+        }
+        if (is_array($addJsFiles) && !empty($addJsFiles)) {
+            foreach ($addJsFiles as $addJsFile) {
+                $pageRenderer->addJsFile($addJsFile);
+            }
+        }
+        $output = $this->renderChildren();
+        $output = $doc->startPage($pageTitle) . $output;
+        $output .= $doc->endPage();
+        return $output;
+    }
 }