TYPO3 API  SVNRelease
class.tx_rtehtmlarea_definitionlist.php
Go to the documentation of this file.
00001 <?php
00002 /***************************************************************
00003 *  Copyright notice
00004 *
00005 *  (c) 2008-2011 Stanislas Rolland <typo3(arobas)sjbr.ca>
00006 *  All rights reserved
00007 *
00008 *  This script is part of the Typo3 project. The Typo3 project is
00009 *  free software; you can redistribute it and/or modify
00010 *  it under the terms of the GNU General Public License as published by
00011 *  the Free Software Foundation; either version 2 of the License, or
00012 *  (at your option) any later version.
00013 *
00014 *  The GNU General Public License can be found at
00015 *  http://www.gnu.org/copyleft/gpl.html.
00016 *
00017 *  This script is distributed in the hope that it will be useful,
00018 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00019 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00020 *  GNU General Public License for more details.
00021 *
00022 *  This copyright notice MUST APPEAR in all copies of the script!
00023 ***************************************************************/
00024 /**
00025  * Definition List plugin for htmlArea RTE
00026  *
00027  * @author Stanislas Rolland <typo3(arobas)sjbr.ca>
00028  *
00029  * TYPO3 SVN ID: $Id: class.tx_rtehtmlarea_definitionlist.php 10120 2011-01-18 20:03:36Z ohader $
00030  *
00031  */
00032 class tx_rtehtmlarea_definitionlist extends tx_rtehtmlarea_api {
00033 
00034     protected $extensionKey = 'rtehtmlarea';        // The key of the extension that is extending htmlArea RTE
00035     protected $pluginName = 'DefinitionList';           // The name of the plugin registered by the extension
00036     protected $relativePathToLocallangFile = '';            // Path to this main locallang file of the extension relative to the extension dir.
00037     protected $relativePathToSkin = 'extensions/DefinitionList/skin/htmlarea.css';      // Path to the skin (css) file relative to the extension dir.
00038     protected $htmlAreaRTE;                     // Reference to the invoking object
00039     protected $thisConfig;                      // Reference to RTE PageTSConfig
00040     protected $toolbar;                     // Reference to RTE toolbar array
00041     protected $LOCAL_LANG;                      // Frontend language array
00042 
00043     protected $pluginButtons = 'definitionlist, definitionitem';
00044 
00045     protected $convertToolbarForHtmlAreaArray = array (
00046         'definitionlist'    => 'DefinitionList',
00047         'definitionitem'    => 'DefinitionItem',
00048         );
00049         // The comma-separated list of names of prerequisite plugins
00050     protected $requiredPlugins = 'BlockElements';
00051 
00052     public function main($parentObject) {
00053         $enabled = parent::main($parentObject) && $this->htmlAreaRTE->isPluginEnabled('BlockElements');
00054         if ($enabled && is_object($this->htmlAreaRTE->registeredPlugins['BlockElements'])) {
00055             $this->htmlAreaRTE->registeredPlugins['BlockElements']->setSynchronousLoad();
00056         }
00057         return $enabled;
00058     }
00059 
00060     /**
00061      * Return JS configuration of the htmlArea plugins registered by the extension
00062      *
00063      * @param   integer     Relative id of the RTE editing area in the form
00064      *
00065      * @return string       JS configuration for registered plugins
00066      *
00067      * The returned string will be a set of JS instructions defining the configuration that will be provided to the plugin(s)
00068      * Each of the instructions should be of the form:
00069      *  RTEarea['.$RTEcounter.'].buttons.button-id.property = "value";
00070      */
00071     public function buildJavascriptConfiguration($RTEcounter) {
00072         global $TSFE, $LANG;
00073 
00074         $registerRTEinJavascriptString = '';
00075         return $registerRTEinJavascriptString;
00076     }
00077 
00078     /**
00079      * Return an updated array of toolbar enabled buttons
00080      *
00081      * @param   array       $show: array of toolbar elements that will be enabled, unless modified here
00082      *
00083      * @return  array       toolbar button array, possibly updated
00084      */
00085     public function applyToolbarConstraints($show) {
00086         $blockElementsButtons = 'formatblock, indent, outdent, blockquote, insertparagraphbefore, insertparagraphafter, left, center, right, justifyfull, orderedlist, unorderedlist';
00087         $notRemoved = array_intersect(t3lib_div::trimExplode(',', $blockElementsButtons, 1), $show);
00088             // DefinitionList plugin requires BlockElements plugin
00089             // We will not allow any definition lists operations if all block elements buttons were disabled
00090         if (empty($notRemoved)) {
00091             return array_diff($show, t3lib_div::trimExplode(',', $this->pluginButtons));
00092         } else {
00093             return $show;
00094         }
00095     }
00096 
00097 } // end of class
00098 
00099 if (defined('TYPO3_MODE') && isset($GLOBALS['TYPO3_CONF_VARS'][TYPO3_MODE]['XCLASS']['ext/rtehtmlarea/extensions/DefinitionList/class.tx_rtehtmlarea_definitionlist.php'])) {
00100     include_once($GLOBALS['TYPO3_CONF_VARS'][TYPO3_MODE]['XCLASS']['ext/rtehtmlarea/extensions/DefinitionList/class.tx_rtehtmlarea_definitionlist.php']);
00101 }
00102 
00103 ?>