forked from pkp/tinymce
-
Notifications
You must be signed in to change notification settings - Fork 0
/
TinyMCEPlugin.inc.php
121 lines (103 loc) · 3.08 KB
/
TinyMCEPlugin.inc.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
<?php
/**
* @file plugins/generic/tinymce/TinyMCEPlugin.inc.php
*
* Copyright (c) 2014-2018 Simon Fraser University
* Copyright (c) 2003-2018 John Willinsky
* Distributed under the GNU GPL v2. For full terms see the file docs/COPYING.
*
* @class TinyMCEPlugin
* @ingroup plugins_generic_tinymce
*
* @brief TinyMCE WYSIWYG plugin for textareas - to allow cross-browser HTML editing
*/
import('lib.pkp.classes.plugins.GenericPlugin');
class TinyMCEPlugin extends GenericPlugin {
/**
* @copydoc Plugin::register()
*/
function register($category, $path, $mainContextId = null) {
if (parent::register($category, $path, $mainContextId)) {
if ($this->getEnabled($mainContextId)) {
HookRegistry::register('TemplateManager::display',array(&$this, 'registerJS'));
HookRegistry::register('TemplateManager::registerJSLibraryData',array(&$this, 'registerJSData'));
}
return true;
}
return false;
}
/**
* @copydoc Plugin::getContextSpecificPluginSettingsFile()
*/
function getContextSpecificPluginSettingsFile() {
return $this->getPluginPath() . '/settings.xml';
}
/**
* @copydoc Plugin::getInstallSitePluginSettingsFile()
*/
function getInstallSitePluginSettingsFile() {
return $this->getPluginPath() . '/settings.xml';
}
/**
* @copydoc PKPPlugin::getTemplatePath()
*/
function getTemplatePath($inCore = false) {
return parent::getTemplatePath($inCore) . 'templates/';
}
/**
* Register the TinyMCE JavaScript file
*
* Hooked to the the `display` callback in TemplateManager
* @param $hookName string
* @param $args array
* @return boolean
*/
function registerJS($hookName, $args) {
$request =& Registry::get('request');
$templateManager =& $args[0];
// Load the TinyMCE JavaScript file
$min = Config::getVar('general', 'enable_minified') ? '.min' : '';
$templateManager->addJavaScript(
'tinymce',
$request->getBaseUrl() . '/lib/pkp/lib/vendor/tinymce/tinymce/tinymce' . $min . '.js',
array(
'contexts' => 'backend',
)
);
return false;
}
/**
* Register script data required by the JS library
*
* Hooked to the the `registerJSLibraryData` callback in TemplateManager.
* This data is used to initialize the TinyMCE component.
* @param $hookName string
* @param $args array $args[0] is an array of plugin data.
* @return boolean
*/
function registerJSData($hookName, $args) {
$request =& Registry::get('request');
$tinymceParams = array();
$localeKey = substr(AppLocale::getLocale(), 0, 2);
$localePath = $request->getBaseUrl() . '/plugins/generic/tinymce/langs/' . $localeKey . '.js';
if (file_exists($localePath)) {
$tinymceParams['language'] = $localeKey;
$tinymceParams['language_url'] = $localePath;
}
$args[0][$this->getJavascriptNameSpace()] = array( 'tinymceParams' => json_encode($tinymceParams) . ';');
return false;
}
/**
* @copydoc Plugin::getDisplayName()
*/
function getDisplayName() {
return __('plugins.generic.tinymce.name');
}
/**
* @copydoc Plugin::getDescription()
*/
function getDescription() {
return __('plugins.generic.tinymce.description');
}
}
?>