diff --git a/apps/common/main/lib/util/htmlutils.js b/apps/common/main/lib/util/htmlutils.js
index 77392abde..d75a54d0a 100644
--- a/apps/common/main/lib/util/htmlutils.js
+++ b/apps/common/main/lib/util/htmlutils.js
@@ -88,9 +88,11 @@ if ( !!params.uitheme && checkLocalStorage && !localStorage.getItem("ui-theme-id
}
var ui_theme_name = checkLocalStorage && localStorage.getItem("ui-theme-id") ? localStorage.getItem("ui-theme-id") : params.uitheme;
+var ui_theme_type;
if ( !ui_theme_name ) {
if ( window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches ) {
ui_theme_name = 'theme-dark';
+ ui_theme_type = 'dark';
checkLocalStorage && localStorage.removeItem("ui-theme");
}
}
@@ -100,7 +102,7 @@ if ( !!ui_theme_name ) {
if ( checkLocalStorage ) {
let current_theme = localStorage.getItem("ui-theme");
- if ( !!current_theme && /type":\s*"dark/.test(current_theme) ) {
+ if ( !!current_theme && /type":\s*"dark/.test(current_theme) || ui_theme_type == 'dark' ) {
document.body.classList.add("theme-type-dark");
let content_theme = localStorage.getItem("content-theme");
diff --git a/apps/common/mobile/lib/controller/Themes.js b/apps/common/mobile/lib/controller/Themes.js
index 768fdf9bf..2c076a15f 100644
--- a/apps/common/mobile/lib/controller/Themes.js
+++ b/apps/common/mobile/lib/controller/Themes.js
@@ -12,6 +12,51 @@ class ThemesController {
id: 'theme-light',
type: 'light'
}};
+
+ this.name_colors = [
+ "canvas-background",
+ "canvas-content-background",
+ "canvas-page-border",
+
+ "canvas-ruler-background",
+ "canvas-ruler-border",
+ "canvas-ruler-margins-background",
+ "canvas-ruler-mark",
+ "canvas-ruler-handle-border",
+ "canvas-ruler-handle-border-disabled",
+
+ "canvas-high-contrast",
+ "canvas-high-contrast-disabled",
+
+ "canvas-cell-border",
+ "canvas-cell-title-border",
+ "canvas-cell-title-border-hover",
+ "canvas-cell-title-border-selected",
+ "canvas-cell-title-hover",
+ "canvas-cell-title-selected",
+
+ "canvas-dark-cell-title",
+ "canvas-dark-cell-title-hover",
+ "canvas-dark-cell-title-selected",
+ "canvas-dark-cell-title-border",
+ "canvas-dark-cell-title-border-hover",
+ "canvas-dark-cell-title-border-selected",
+ "canvas-dark-content-background",
+ "canvas-dark-page-border",
+
+ "canvas-scroll-thumb",
+ "canvas-scroll-thumb-hover",
+ "canvas-scroll-thumb-pressed",
+ "canvas-scroll-thumb-border",
+ "canvas-scroll-thumb-border-hover",
+ "canvas-scroll-thumb-border-pressed",
+ "canvas-scroll-arrow",
+ "canvas-scroll-arrow-hover",
+ "canvas-scroll-arrow-pressed",
+ "canvas-scroll-thumb-target",
+ "canvas-scroll-thumb-target-hover",
+ "canvas-scroll-thumb-target-pressed",
+ ];
}
init() {
@@ -41,6 +86,16 @@ class ThemesController {
return !!obj ? JSON.parse(obj).type === 'dark' : false;
}
+ get_current_theme_colors(colors) {
+ let out_object = {};
+ const style = getComputedStyle(document.body);
+ colors.forEach((item, index) => {
+ out_object[item] = style.getPropertyValue('--' + item).trim()
+ })
+
+ return out_object;
+ }
+
switchDarkTheme(dark) {
const theme = typeof dark == 'object' ? dark : this.themes_map[dark ? 'dark' : 'light'];
const refresh_only = !!arguments[1];
@@ -53,7 +108,11 @@ class ThemesController {
$body.addClass(`theme-type-${theme.type}`);
const on_engine_created = api => {
- api.asc_setSkin(theme.id);
+ let obj = this.get_current_theme_colors(this.name_colors);
+ obj.type = theme.type;
+ obj.name = theme.id;
+
+ api.asc_setSkin(obj);
};
const api = Common.EditorApi ? Common.EditorApi.get() : undefined;
diff --git a/apps/common/mobile/resources/less/colors-table-dark.less b/apps/common/mobile/resources/less/colors-table-dark.less
index e97d2d9a0..972f85d49 100644
--- a/apps/common/mobile/resources/less/colors-table-dark.less
+++ b/apps/common/mobile/resources/less/colors-table-dark.less
@@ -33,12 +33,53 @@
--image-border-types-filter: invert(100%) brightness(4);
- --canvas-content-background: #fff;
-
--active-opacity-word: fade(#446995, 20%);
--active-opacity-slide: fade(#AA5252, 20%);
--active-opacity-cell: fade(#40865C, 20%);
--image-border-types-filter: invert(100%) brightness(4);
+
+ // Canvas
+
+ --canvas-background: #555;
+ --canvas-content-background: #fff;
+ --canvas-page-border: #555;
+
+ --canvas-ruler-background: #555;
+ --canvas-ruler-border: #2A2A2A;
+ --canvas-ruler-margins-background: #444;
+ --canvas-ruler-mark: #b6b6b6;
+ --canvas-ruler-handle-border: #b6b6b6;
+ --canvas-ruler-handle-border-disabled: #808080;
+
+ --canvas-high-contrast: #fff;
+ --canvas-high-contrast-disabled: #ccc;
+
+ --canvas-cell-border: fade(#000, 10%);
+ --canvas-cell-title-border: #757575;
+ --canvas-cell-title-border-hover: #858585;
+ --canvas-cell-title-border-selected: #9e9e9e;
+ --canvas-cell-title-hover: #787878;
+ --canvas-cell-title-selected: #939393;
+
+ --canvas-dark-cell-title: #111;
+ --canvas-dark-cell-title-hover: #000;
+ --canvas-dark-cell-title-selected: #333;
+ --canvas-dark-cell-title-border: #282828;
+ --canvas-dark-cell-title-border-hover: #191919;
+ --canvas-dark-cell-title-border-selected: #474747;
+
+ --canvas-scroll-thumb: #404040;
+ --canvas-scroll-thumb-hover: #999;
+ --canvas-scroll-thumb-pressed: #adadad;
+ --canvas-scroll-thumb-border: #2a2a2a;
+ --canvas-scroll-thumb-border-hover: #999;
+ --canvas-scroll-thumb-border-pressed: #adadad;
+ --canvas-scroll-arrow: #999;
+ --canvas-scroll-arrow-hover: #404040;
+ --canvas-scroll-arrow-pressed: #404040;
+ --canvas-scroll-thumb-target: #999;
+ --canvas-scroll-thumb-target-hover: #404040;
+ --canvas-scroll-thumb-target-pressed: #404040;
}
}
\ No newline at end of file
diff --git a/apps/common/mobile/resources/less/colors-table.less b/apps/common/mobile/resources/less/colors-table.less
index 0ce2667ca..331ca6779 100644
--- a/apps/common/mobile/resources/less/colors-table.less
+++ b/apps/common/mobile/resources/less/colors-table.less
@@ -29,13 +29,56 @@
--component-disabled-opacity: .4;
- --canvas-content-background: #fff;
-
--active-opacity-word: fade(#446995, 30%);
--active-opacity-slide: fade(#AA5252, 30%);
--active-opacity-cell: fade(#40865C, 30%);
--image-border-types-filter: none;
+
+ // Canvas
+
+ --canvas-background: #eee;
+ --canvas-content-background: #fff;
+ --canvas-page-border: #ccc;
+
+ --canvas-ruler-background: #fff;
+ --canvas-ruler-border: #cbcbcb;
+ --canvas-ruler-margins-background: #d9d9d9;
+ --canvas-ruler-mark: #555;
+ --canvas-ruler-handle-border: #555;
+ --canvas-ruler-handle-border-disabled: #aaa;
+
+ --canvas-high-contrast: #000;
+ --canvas-high-contrast-disabled: #666;
+
+ --canvas-cell-border: fade(#000, 10%);
+ --canvas-cell-title-hover: #dfdfdf;
+ --canvas-cell-title-selected: #cfcfcf;
+ --canvas-cell-title-border: #d8d8d8;
+ --canvas-cell-title-border-hover: #c9c9c9;
+ --canvas-cell-title-border-selected: #bbb;
+
+ --canvas-dark-cell-title: #444;
+ --canvas-dark-cell-title-hover: #666 ;
+ --canvas-dark-cell-title-selected: #111;
+ --canvas-dark-cell-title-border: #3d3d3d;
+ --canvas-dark-cell-title-border-hover: #5c5c5c;
+ --canvas-dark-cell-title-border-selected: #0f0f0f;
+ --canvas-dark-content-background: #3a3a3a;
+ --canvas-dark-page-border: #2a2a2a;
+
+ --canvas-scroll-thumb: #f7f7f7;
+ --canvas-scroll-thumb-hover: #c0c0c0;
+ --canvas-scroll-thumb-pressed: #adadad;
+ --canvas-scroll-thumb-border: #cbcbcb;
+ --canvas-scroll-thumb-border-hover: #cbcbcb;
+ --canvas-scroll-thumb-border-pressed: #adadad;
+ --canvas-scroll-arrow: #adadad;
+ --canvas-scroll-arrow-hover: #f7f7f7;
+ --canvas-scroll-arrow-pressed: #f7f7f7;
+ --canvas-scroll-thumb-target: #c0c0c0;
+ --canvas-scroll-thumb-target-hover: #f7f7f7;
+ --canvas-scroll-thumb-target-pressed: #f7f7f7;
}
@brand-word: var(--brand-word);
diff --git a/apps/documenteditor/forms/app/controller/SearchBar.js b/apps/documenteditor/forms/app/controller/SearchBar.js
index 53ce27e4f..2465a8466 100644
--- a/apps/documenteditor/forms/app/controller/SearchBar.js
+++ b/apps/documenteditor/forms/app/controller/SearchBar.js
@@ -127,7 +127,7 @@ define([
onInputSearchChange: function (text) {
var text = text[0];
- if (this._state.searchText !== text) {
+ if ((text && this._state.searchText !== text) || (!text && this._state.newSearchText)) {
this._state.newSearchText = text;
this._lastInputChange = (new Date());
if (this._searchTimer === undefined) {
@@ -136,7 +136,11 @@ define([
if ((new Date()) - me._lastInputChange < 400) return;
me._state.searchText = me._state.newSearchText;
- (me._state.newSearchText !== '') && me.onQuerySearch();
+ if (me._state.newSearchText !== '') {
+ me.onQuerySearch();
+ } else {
+ me.api.asc_endFindText();
+ }
clearInterval(me._searchTimer);
me._searchTimer = undefined;
}, 10);
diff --git a/apps/documenteditor/main/app/controller/LeftMenu.js b/apps/documenteditor/main/app/controller/LeftMenu.js
index 1a9e70001..956af1bed 100644
--- a/apps/documenteditor/main/app/controller/LeftMenu.js
+++ b/apps/documenteditor/main/app/controller/LeftMenu.js
@@ -293,6 +293,9 @@ define([
}
})).show();
break;
+ case 'help':
+ close_menu = !!isopts;
+ break;
default: close_menu = false;
}
diff --git a/apps/documenteditor/main/app/view/FileMenu.js b/apps/documenteditor/main/app/view/FileMenu.js
index 0b23ce8e1..8d1f840f5 100644
--- a/apps/documenteditor/main/app/view/FileMenu.js
+++ b/apps/documenteditor/main/app/view/FileMenu.js
@@ -66,6 +66,14 @@ define([
var item = _.findWhere(this.items, {el: event.currentTarget});
if (item) {
var panel = this.panels[item.options.action];
+ if (item.options.action === 'help') {
+ if ( panel.usedHelpCenter === true && navigator.onLine ) {
+ this.fireEvent('item:click', [this, item.options.action, true]);
+ window.open(panel.urlHelpCenter, '_blank');
+ return;
+ }
+ }
+
this.fireEvent('item:click', [this, item.options.action, !!panel]);
if (panel) {
diff --git a/apps/documenteditor/main/app/view/FileMenuPanels.js b/apps/documenteditor/main/app/view/FileMenuPanels.js
index d2e258a5a..eba89f8cf 100644
--- a/apps/documenteditor/main/app/view/FileMenuPanels.js
+++ b/apps/documenteditor/main/app/view/FileMenuPanels.js
@@ -1990,6 +1990,7 @@ define([
this.menu = options.menu;
this.urlPref = 'resources/help/{{DEFAULT_LANG}}/';
this.openUrl = null;
+ this.urlHelpCenter = '{{HELP_CENTER_WEB_EDITORS}}';
this.en_data = [
{"src": "ProgramInterface/ProgramInterface.htm", "name": "Introducing Document Editor user interface", "headername": "Program Interface"},
@@ -2112,9 +2113,10 @@ define([
store.fetch(config);
} else {
if ( Common.Controllers.Desktop.isActive() ) {
- if ( store.contentLang === '{{DEFAULT_LANG}}' || !Common.Controllers.Desktop.helpUrl() )
+ if ( store.contentLang === '{{DEFAULT_LANG}}' || !Common.Controllers.Desktop.helpUrl() ) {
+ me.usedHelpCenter = true;
me.iFrame.src = '../../common/main/resources/help/download.html';
- else {
+ } else {
store.contentLang = store.contentLang === lang ? '{{DEFAULT_LANG}}' : lang;
me.urlPref = Common.Controllers.Desktop.helpUrl() + '/' + store.contentLang + '/';
store.url = me.urlPref + 'Contents.json';
diff --git a/apps/documenteditor/main/locale/en.json b/apps/documenteditor/main/locale/en.json
index 14ad46a37..2e0bb72c9 100644
--- a/apps/documenteditor/main/locale/en.json
+++ b/apps/documenteditor/main/locale/en.json
@@ -2104,6 +2104,7 @@
"DE.Views.LeftMenu.tipSearch": "Search",
"DE.Views.LeftMenu.tipSupport": "Feedback & Support",
"DE.Views.LeftMenu.tipTitles": "Titles",
+ "DE.Views.LeftMenu.tipPageThumbnails": "Page Thumbnails",
"DE.Views.LeftMenu.txtDeveloper": "DEVELOPER MODE",
"DE.Views.LeftMenu.txtEditor": "Document Editor",
"DE.Views.LeftMenu.txtLimit": "Limit Access",
diff --git a/build/Gruntfile.js b/build/Gruntfile.js
index f0ed31065..c4f166801 100644
--- a/build/Gruntfile.js
+++ b/build/Gruntfile.js
@@ -67,6 +67,9 @@ module.exports = function(grunt) {
}, {
from: /\{\{HELP_URL\}\}/g,
to: _encode(process.env.HELP_URL) || 'https://helpcenter.onlyoffice.com'
+ }, {
+ from: /\{\{HELP_CENTER_WEB_EDITORS\}\}/g,
+ to: _encode(process.env.HELP_CENTER_WEB_EDITORS) || 'https://helpcenter.onlyoffice.com/userguides/docs-index.aspx'
}, {
from: /\{\{DEFAULT_LANG\}\}/g,
to: _encode(process.env.DEFAULT_LANG) || 'en'