[TASK] RTE: Remove PageTSConfig properties deprecated since TYPO3 4.6
[Packages/TYPO3.CMS.git] / typo3 / sysext / rtehtmlarea / extensions / TYPO3Image / class.tx_rtehtmlarea_typo3image.php
1 <?php
2 /***************************************************************
3 * Copyright notice
4 *
5 * (c) 2008-2011 Stanislas Rolland <typo3(arobas)sjbr.ca>
6 * All rights reserved
7 *
8 * This script is part of the Typo3 project. The Typo3 project is
9 * free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * The GNU General Public License can be found at
15 * http://www.gnu.org/copyleft/gpl.html.
16 *
17 * This script is distributed in the hope that it will be useful,
18 * but WITHOUT ANY WARRANTY; without even the implied warranty of
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 * GNU General Public License for more details.
21 *
22 * This copyright notice MUST APPEAR in all copies of the script!
23 ***************************************************************/
24 /**
25 * TYPO3 Image plugin for htmlArea RTE
26 *
27 * @author Stanislas Rolland <typo3(arobas)sjbr.ca>
28 *
29 */
30 class tx_rtehtmlarea_typo3image extends tx_rtehtmlarea_api {
31
32 protected $extensionKey = 'rtehtmlarea'; // The key of the extension that is extending htmlArea RTE
33 protected $pluginName = 'TYPO3Image'; // The name of the plugin registered by the extension
34 protected $relativePathToLocallangFile = ''; // Path to this main locallang file of the extension relative to the extension dir.
35 protected $relativePathToSkin = 'extensions/TYPO3Image/skin/htmlarea.css'; // Path to the skin (css) file relative to the extension dir.
36 protected $htmlAreaRTE; // Reference to the invoking object
37 protected $thisConfig; // Reference to RTE PageTSConfig
38 protected $toolbar; // Reference to RTE toolbar array
39 protected $LOCAL_LANG; // Frontend language array
40
41 protected $pluginButtons = 'image';
42 protected $convertToolbarForHtmlAreaArray = array (
43 'image' => 'InsertImage',
44 );
45
46 public function main($parentObject) {
47 $enabled = parent::main($parentObject);
48 // Check if this should be enabled based on extension configuration and Page TSConfig
49 // The 'Minimal' and 'Typical' default configurations include Page TSConfig that removes images on the way to the database
50 $enabled = $enabled && !($this->thisConfig['proc.']['entryHTMLparser_db.']['tags.']['img.']['allowedAttribs'] == '0' && $this->thisConfig['proc.']['entryHTMLparser_db.']['tags.']['img.']['rmTagIfNoAttrib'] == '1')
51 && !$this->thisConfig['buttons.']['image.']['TYPO3Browser.']['disabled'];
52 return $enabled;
53 }
54
55 /**
56 * Return JS configuration of the htmlArea plugins registered by the extension
57 *
58 * @param integer Relative id of the RTE editing area in the form
59 *
60 * @return string JS configuration for registered plugins, in this case, JS configuration of block elements
61 *
62 * The returned string will be a set of JS instructions defining the configuration that will be provided to the plugin(s)
63 * Each of the instructions should be of the form:
64 * RTEarea['.$RTEcounter.']["buttons"]["button-id"]["property"] = "value";
65 */
66 public function buildJavascriptConfiguration($RTEcounter) {
67
68 $registerRTEinJavascriptString = '';
69 $button = 'image';
70 if (in_array($button, $this->toolbar)) {
71 if (!is_array( $this->thisConfig['buttons.']) || !is_array( $this->thisConfig['buttons.'][$button.'.'])) {
72 $registerRTEinJavascriptString .= '
73 RTEarea['.$RTEcounter.']["buttons"]["'. $button .'"] = new Object();';
74 }
75 $registerRTEinJavascriptString .= '
76 RTEarea['.$RTEcounter.'].buttons.'. $button .'.pathImageModule = "' . $this->htmlAreaRTE->extHttpPath . 'mod4/select_image.php";';
77 }
78 return $registerRTEinJavascriptString;
79 }
80 }
81 ?>