2015-08-27 02:05:59 -03:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class pluginsimpleMDE extends Plugin {
|
|
|
|
|
|
|
|
private $loadWhenController = array(
|
|
|
|
'new-post',
|
|
|
|
'new-page',
|
|
|
|
'edit-post',
|
|
|
|
'edit-page'
|
|
|
|
);
|
|
|
|
|
2015-09-03 21:46:17 -03:00
|
|
|
public function init()
|
|
|
|
{
|
|
|
|
$this->dbFields = array(
|
|
|
|
'tabSize'=>'2',
|
2016-01-30 20:01:04 -03:00
|
|
|
'toolbar'=>'"bold", "italic", "heading", "|", "quote", "unordered-list", "|", "link", "image", "code", "horizontal-rule", "|", "preview", "side-by-side", "fullscreen", "guide"',
|
|
|
|
'autosave'=>false
|
2015-09-03 21:46:17 -03:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function form()
|
2015-08-27 02:05:59 -03:00
|
|
|
{
|
|
|
|
global $Language;
|
2015-09-03 21:46:17 -03:00
|
|
|
|
|
|
|
$html = '<div>';
|
|
|
|
$html .= '<label>'.$Language->get('Toolbar').'</label>';
|
|
|
|
$html .= '<input name="toolbar" id="jstoolbar" type="text" value="'.$this->getDbField('toolbar').'">';
|
|
|
|
$html .= '</div>';
|
|
|
|
|
|
|
|
$html .= '<div>';
|
|
|
|
$html .= '<label>'.$Language->get('Tab size').'</label>';
|
|
|
|
$html .= '<input name="tabSize" id="jstabSize" type="text" value="'.$this->getDbField('tabSize').'">';
|
|
|
|
$html .= '</div>';
|
|
|
|
|
2016-01-30 20:01:04 -03:00
|
|
|
$html .= '<div>';
|
|
|
|
$html .= '<input name="autosave" id="jsautosave" type="checkbox" value="true" '.($this->getDbField('autosave')?'checked':'').'>';
|
|
|
|
$html .= '<label class="forCheckbox" for="jsautosave">'.$Language->get('Autosave').'</label>';
|
|
|
|
$html .= '</div>';
|
|
|
|
|
2015-09-03 21:46:17 -03:00
|
|
|
return $html;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function adminHead()
|
|
|
|
{
|
2015-08-27 02:05:59 -03:00
|
|
|
global $layout;
|
|
|
|
|
|
|
|
$html = '';
|
|
|
|
|
|
|
|
// Load CSS and JS only on Controllers in array.
|
|
|
|
if(in_array($layout['controller'], $this->loadWhenController))
|
|
|
|
{
|
2015-09-03 21:46:17 -03:00
|
|
|
// Path plugin.
|
2015-08-27 02:05:59 -03:00
|
|
|
$pluginPath = $this->htmlPath();
|
|
|
|
|
2015-11-03 21:28:11 -03:00
|
|
|
// SimpleMDE css
|
2015-08-29 02:02:09 -03:00
|
|
|
$html .= '<link rel="stylesheet" href="'.$pluginPath.'css/simplemde.min.css">';
|
|
|
|
|
2015-11-03 21:28:11 -03:00
|
|
|
// Font-awesome is a dependency of SimpleMDE
|
2016-01-16 21:45:16 -03:00
|
|
|
$html .= '<link rel="stylesheet" href="'.HTML_PATH_ADMIN_THEME_CSS.'font-awesome.min.css">';
|
2015-11-03 21:28:11 -03:00
|
|
|
|
|
|
|
// SimpleMDE js
|
2015-09-03 21:46:17 -03:00
|
|
|
$html .= '<script src="'.$pluginPath.'js/simplemde.min.js"></script>';
|
2015-08-29 02:02:09 -03:00
|
|
|
|
2015-09-03 21:46:17 -03:00
|
|
|
// Hack for Bludit
|
|
|
|
$html .= '<style>
|
2015-10-18 19:45:58 -03:00
|
|
|
.editor-toolbar { background: #f1f1f1; }
|
2015-09-03 21:46:17 -03:00
|
|
|
.editor-toolbar::before { margin-bottom: 2px !important }
|
|
|
|
.editor-toolbar::after { margin-top: 2px !important }
|
2015-10-18 19:45:58 -03:00
|
|
|
.CodeMirror, .CodeMirror-scroll { min-height: 400px !important; }
|
2015-09-03 21:46:17 -03:00
|
|
|
</style>';
|
2015-08-27 02:05:59 -03:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return $html;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function adminBodyEnd()
|
|
|
|
{
|
|
|
|
global $layout;
|
|
|
|
|
|
|
|
$html = '';
|
|
|
|
|
|
|
|
// Load CSS and JS only on Controllers in array.
|
|
|
|
if(in_array($layout['controller'], $this->loadWhenController))
|
|
|
|
{
|
2016-01-30 20:01:04 -03:00
|
|
|
// Autosave
|
|
|
|
global $_Page, $_Post;
|
|
|
|
$autosaveID = $layout['controller'];
|
|
|
|
$autosaveEnable = $this->getDbField('autosave')?'true':'false';
|
|
|
|
if(isset($_Page)) {
|
|
|
|
$autosaveID = $_Page->key();
|
|
|
|
}
|
|
|
|
if(isset($_Post)) {
|
|
|
|
$autosaveID = $_Post->key();
|
|
|
|
}
|
|
|
|
|
2015-08-27 02:05:59 -03:00
|
|
|
$pluginPath = $this->htmlPath();
|
|
|
|
|
2015-10-18 19:45:58 -03:00
|
|
|
$html = '<script>'.PHP_EOL;
|
2015-12-28 19:28:42 -03:00
|
|
|
|
|
|
|
$html .= 'var simplemde = null;'.PHP_EOL;
|
|
|
|
|
|
|
|
$html .= 'function addContentSimpleMDE(content) {
|
|
|
|
var text = simplemde.value();
|
|
|
|
simplemde.value(text + content + "\n");
|
|
|
|
}'.PHP_EOL;
|
|
|
|
|
2015-10-18 19:45:58 -03:00
|
|
|
$html .= '$(document).ready(function() { '.PHP_EOL;
|
2015-12-28 19:28:42 -03:00
|
|
|
$html .= 'simplemde = new SimpleMDE({
|
2015-08-27 02:05:59 -03:00
|
|
|
element: document.getElementById("jscontent"),
|
2015-08-29 02:02:09 -03:00
|
|
|
status: false,
|
2015-08-27 02:05:59 -03:00
|
|
|
toolbarTips: true,
|
|
|
|
toolbarGuideIcon: true,
|
2015-08-29 15:07:47 -03:00
|
|
|
autofocus: false,
|
2015-09-07 21:51:48 -03:00
|
|
|
lineWrapping: true,
|
2015-11-03 21:28:11 -03:00
|
|
|
autoDownloadFontAwesome: false,
|
2015-08-27 02:05:59 -03:00
|
|
|
indentWithTabs: true,
|
2015-09-03 21:46:17 -03:00
|
|
|
tabSize: '.$this->getDbField('tabSize').',
|
|
|
|
spellChecker: false,
|
2016-01-30 20:01:04 -03:00
|
|
|
autosave: {
|
|
|
|
enabled: '.$autosaveEnable.',
|
|
|
|
uniqueId: "'.$autosaveID.'",
|
|
|
|
delay: 1000,
|
|
|
|
},
|
2015-09-03 21:46:17 -03:00
|
|
|
toolbar: ['.Sanitize::htmlDecode($this->getDbField('toolbar')).']
|
2015-11-04 23:54:22 -03:00
|
|
|
});';
|
2015-11-03 21:28:11 -03:00
|
|
|
|
2015-12-28 19:28:42 -03:00
|
|
|
// This is the event for Bludit images
|
|
|
|
$html .= '$("body").on("dblclick", "img.bludit-thumbnail", function() {
|
|
|
|
var filename = $(this).data("filename");
|
|
|
|
addContentSimpleMDE("![alt text]("+filename+")");
|
2015-11-04 23:54:22 -03:00
|
|
|
});';
|
2015-11-03 21:28:11 -03:00
|
|
|
|
2015-08-27 02:05:59 -03:00
|
|
|
$html .= '}); </script>';
|
|
|
|
}
|
|
|
|
|
|
|
|
return $html;
|
|
|
|
}
|
2016-01-18 23:34:33 -03:00
|
|
|
}
|