Cleanup: Updated copyright comments
[Packages/TYPO3.CMS.git] / typo3 / sysext / rtehtmlarea / extensions / DefaultInline / class.tx_rtehtmlarea_defaultinline.php
1 <?php
2 /***************************************************************
3 * Copyright notice
4 *
5 * (c) 2007-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 * DefaultInline plugin for htmlArea RTE
26 *
27 * @author Stanislas Rolland <typo3(arobas)sjbr.ca>
28 *
29 * TYPO3 SVN ID: $Id$
30 *
31 */
32 class tx_rtehtmlarea_defaultinline extends tx_rtehtmlarea_api {
33
34 protected $extensionKey = 'rtehtmlarea'; // The key of the extension that is extending htmlArea RTE
35 protected $pluginName = 'DefaultInline'; // The name of the plugin registered by the extension
36 protected $relativePathToLocallangFile = 'extensions/DefaultInline/locallang.xml'; // Path to this main locallang file of the extension relative to the extension dir.
37 protected $relativePathToSkin = 'extensions/DefaultInline/skin/htmlarea.css'; // Path to the skin (css) file relative to the extension dir.
38 protected $htmlAreaRTE; // Reference to the invoking object
39 protected $thisConfig; // Reference to RTE PageTSConfig
40 protected $toolbar; // Reference to RTE toolbar array
41 protected $LOCAL_LANG; // Frontend language array
42
43 protected $pluginButtons = 'bold,italic,strikethrough,subscript,superscript,underline';
44 protected $convertToolbarForHtmlAreaArray = array (
45 'bold' => 'Bold',
46 'italic' => 'Italic',
47 'underline' => 'Underline',
48 'strikethrough' => 'StrikeThrough',
49 'superscript' => 'Superscript',
50 'subscript' => 'Subscript',
51 );
52
53 /**
54 * Return JS configuration of the htmlArea plugins registered by the extension
55 *
56 * @param integer Relative id of the RTE editing area in the form
57 *
58 * @return string JS configuration for registered plugins
59 *
60 * The returned string will be a set of JS instructions defining the configuration that will be provided to the plugin(s)
61 * Each of the instructions should be of the form:
62 * RTEarea['.$RTEcounter.']["buttons"]["button-id"]["property"] = "value";
63 */
64 public function buildJavascriptConfiguration($RTEcounter) {
65 global $TSFE, $LANG;
66
67 $registerRTEinJavascriptString = '';
68 return $registerRTEinJavascriptString;
69 }
70
71 /**
72 * Return tranformed content
73 *
74 * @param string $content: The content that is about to be sent to the RTE
75 *
76 * @return string the transformed content
77 */
78 public function transformContent($content) {
79
80 // Change the strong and em tags for gecko browsers
81 if ($this->htmlAreaRTE->client['browser'] == 'gecko') {
82 // change <strong> to <b>
83 $content = preg_replace('/<(\/?)strong/i', "<$1b", $content);
84 // change <em> to <i>
85 $content = preg_replace('/<(\/?)em([^b>]*>)/i', "<$1i$2", $content);
86 }
87
88 return $content;
89 }
90
91 } // end of class
92
93 if (defined('TYPO3_MODE') && isset($GLOBALS['TYPO3_CONF_VARS'][TYPO3_MODE]['XCLASS']['ext/rtehtmlarea/extensions/DefaultInline/class.tx_rtehtmlarea_defaultinline.php'])) {
94 include_once($GLOBALS['TYPO3_CONF_VARS'][TYPO3_MODE]['XCLASS']['ext/rtehtmlarea/extensions/DefaultInline/class.tx_rtehtmlarea_defaultinline.php']);
95 }
96
97 ?>