From 236006b79517ce11ae4aee0daccb2ebed136b5e1 Mon Sep 17 00:00:00 2001 From: Hadi Nategh Date: Mon, 22 Oct 2018 12:37:45 +0200 Subject: [PATCH] W.I.P. implementing TinyMCE editor and deprecating CKEditor: - Keep editor toolbar in one line at least for mail compose - Add a preference to enable/disable menubar at the top of editor - Respects mode preference --- api/js/etemplate/et2_widget_htmlarea.js | 17 +++++++++++++---- api/templates/default/etemplate2.css | 1 + mail/templates/default/compose.xet | 2 +- .../inc/class.preferences_hooks.inc.php | 19 ++++++++++--------- 4 files changed, 25 insertions(+), 14 deletions(-) diff --git a/api/js/etemplate/et2_widget_htmlarea.js b/api/js/etemplate/et2_widget_htmlarea.js index 5db88dcfa5..f54907e911 100644 --- a/api/js/etemplate/et2_widget_htmlarea.js +++ b/api/js/etemplate/et2_widget_htmlarea.js @@ -29,7 +29,7 @@ var et2_htmlarea = (function(){ "use strict"; return et2_inputWidget.extend([et2 'mode': { 'name': 'Mode', 'description': 'One of {ascii|simple|extended|advanced}', - 'default': 'simple', + 'default': '', 'type': 'string' }, 'height': { @@ -65,6 +65,12 @@ var et2_htmlarea = (function(){ "use strict"; return et2_inputWidget.extend([et2 description: "Callback function for handling image upload", type: 'js', default: et2_no_init + }, + menubar: { + name: "Menubar", + description: "Display menubar at the top of the editor", + type: "boolean", + default: true } }, @@ -106,6 +112,7 @@ var et2_htmlarea = (function(){ "use strict"; return et2_inputWidget.extend([et2 language: egw.preference('lang', 'common'), paste_data_images: true, browser_spellcheck: true, + contextmenu: false, images_upload_url: this.options.imageUpload, file_picker_callback: jQuery.proxy(this._file_picker_callback, this), images_upload_handler: jQuery.proxy(this._images_upload_handler, this), @@ -181,20 +188,22 @@ var et2_htmlarea = (function(){ "use strict"; return et2_inputWidget.extend([et2 */ _extendedSettings: function () { + var rte_menubar = egw.preference('rte_menubar', 'common'); var settings = { fontsize_formats: this.font_size_formats[egw.preference('rte_font_unit', 'common')], + menubar: parseInt(rte_menubar) && this.menubar ? true : typeof rte_menubar != 'undefined' ? false : this.menubar }; var mode = this.mode || egw.preference('rte_features', 'common'); switch (mode) { case 'simple': - settings.toolbar = "formatselect | fontselect fontsizeselect | bold italic strikethrough forecolor backcolor | "+ + settings.toolbar = "fontselect fontsizeselect | bold italic forecolor backcolor | "+ "alignleft aligncenter alignright alignjustify | numlist "+ - "bullist outdent indent" + "bullist outdent indent | link image" break; case 'extended': - settings.toolbar = "formatselect | fontselect fontsizeselect | bold italic strikethrough forecolor backcolor | "+ + settings.toolbar = "fontselect fontsizeselect | bold italic strikethrough forecolor backcolor | "+ "link | alignleft aligncenter alignright alignjustify | numlist "+ "bullist outdent indent | removeformat | image" break; diff --git a/api/templates/default/etemplate2.css b/api/templates/default/etemplate2.css index 97c83810e7..3a31892c68 100644 --- a/api/templates/default/etemplate2.css +++ b/api/templates/default/etemplate2.css @@ -2892,6 +2892,7 @@ a.chzn-single.et2_country-select span.img { } .tox-tinymce {display: flex !important;} +.tox-tbtn.tox-tbtn--select.tox-tbtn--bespoke:nth-child(2) {width: 60px;} div.eml { position:absolute; height: 100%; diff --git a/mail/templates/default/compose.xet b/mail/templates/default/compose.xet index 8613e74fd4..15f0c3f8c7 100644 --- a/mail/templates/default/compose.xet +++ b/mail/templates/default/compose.xet @@ -87,7 +87,7 @@ - + diff --git a/preferences/inc/class.preferences_hooks.inc.php b/preferences/inc/class.preferences_hooks.inc.php index 42f8126009..846171ade6 100644 --- a/preferences/inc/class.preferences_hooks.inc.php +++ b/preferences/inc/class.preferences_hooks.inc.php @@ -71,8 +71,6 @@ class preferences_hooks 'br' => lang('br') ); - $rich_text_editor_skins = Api\Html\CkEditorConfig::getAvailableCKEditorSkins(); - $account_sels = array( 'selectbox' => lang('Selectbox'), 'primary_group' => lang('Selectbox with primary group and search'), @@ -388,15 +386,18 @@ class preferences_hooks 'admin' => False, 'forced' => 'br', ), - 'rte_skin' => array( + 'rte_menubar' => array( 'type' => 'select', - 'label' => 'Rich text editor theme', - 'name' => 'rte_skin', - 'values' => $rich_text_editor_skins, - 'help' => 'Select the theme (visualization) of the rich text editor.', + 'label' => 'Enable menubar', + 'name' => 'rte_menubar', + 'values' => array( + '1' => lang('Yes'), + '0' => lang('No'), + ), + 'help' => 'Enable/Disable menubar from top of the editor.', 'xmlrpc' => True, - 'admin' => False, - 'forced' => 'moono', + 'admin' => '1', + 'default' => '1', ), 'rte_features' => array( 'type' => 'select',