Files
DocumentServer-v-9.2.0/web-apps/apps/common/main/lib/util/themeinit.js
Yajbir Singh f1b860b25c
Some checks failed
check / markdownlint (push) Has been cancelled
check / spellchecker (push) Has been cancelled
updated
2025-12-11 19:03:17 +05:30

185 lines
8.0 KiB
JavaScript

/*
* (c) Copyright Ascensio System SIA 2010-2024
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish
* street, Riga, Latvia, EU, LV-1050.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
+function init_themes() {
let localstorage;
const local_storage_available = +function () {
try {
return !!(localstorage = window.localStorage);
} catch (e) {
console.warn('localStorage is unavailable');
localstorage = {
getItem: function (key) {return null;},
};
return false;
}
}();
!window.uitheme && (window.uitheme = {});
window.uitheme.DEFAULT_LIGHT_THEME_ID = !window.isIEBrowser ? 'theme-white' : 'theme-classic-light';
window.uitheme.DEFAULT_DARK_THEME_ID = !window.isIEBrowser ? 'theme-night' : 'theme-dark';
window.uitheme.set_id = function (id) {
if ( id == 'theme-system' )
this.adapt_to_system_theme();
else this.id = id;
}
window.uitheme.is_theme_system = function () {
return this.id == 'theme-system';
}
window.uitheme.adapt_to_system_theme = function () {
this.id = 'theme-system';
this.type = this.is_system_theme_dark() ? 'dark' : 'light';
}
window.uitheme.relevant_theme_id = function () {
if ( this.is_theme_system() )
return this.is_system_theme_dark() ? window.uitheme.DEFAULT_DARK_THEME_ID : window.uitheme.DEFAULT_LIGHT_THEME_ID;
return this.id;
}
if ( !window.uitheme.is_system_theme_dark )
window.uitheme.is_system_theme_dark = function () {
return window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches;
}
// localstorage.setItem('ui-theme-id', 'theme-white');
!window.uitheme.id && window.uitheme.set_id(localstorage.getItem("ui-theme-id"));
window.uitheme.iscontentdark = localstorage.getItem("content-theme") == 'dark';
function inject_style_tag(content, id) {
if ( id && !!document.getElementById(id) )
return;
const style = document.createElement('style');
style.type = 'text/css';
style.innerHTML = content;
if (id) style.id = id;
document.getElementsByTagName('head')[0].appendChild(style);
}
window.uitheme.apply_icons_from_url = function (themeid, url) {
if ( !url ) return;
let base_url = !url.endsWith('/') ? url + '/' : url;
const sp_names = ['small', 'big', 'huge'];
const sp_scale = {'100':'', '125':'@1.25x','150':'@1.5x','175':'@1.75x','200':'@2x'};
let icons = [];
sp_names.forEach(function (n) {
for (let key in sp_scale) {
const value = sp_scale[key];
icons.push('--sprite-button-'+n+'-'+key+':url('+ base_url +'icons' + n + value + '.png)');
}
});
inject_style_tag('.' + themeid + '{' + icons.join(';') + ';}', themeid);
// workaroud for svg sptites relative path that different from png sprites
if ( base_url.lastIndexOf('../img/', 0) === 0 )
base_url = base_url.replace('..','./resources');
if ( window.Common && window.Common.Utils )
window.Common.Utils.injectSvgIcons([base_url + 'iconssmall@2.5x.svg', base_url + 'iconsbig@2.5x.svg', base_url + 'iconshuge@2.5x.svg', '../../common/main/resources/img/doc-formats/formats@2.5x.svg'], true);
else {
window.uitheme.svg_icons = [base_url + 'iconssmall@2.5x.svg', base_url + 'iconsbig@2.5x.svg', base_url + 'iconshuge@2.5x.svg'];
}
}
inject_style_tag(':root .theme-dark {' +
'--toolbar-header-document: #2a2a2a; --toolbar-header-spreadsheet: #2a2a2a;' +
'--toolbar-header-presentation: #2a2a2a; --toolbar-header-pdf: #2a2a2a; --toolbar-header-visio: #2a2a2a;}' +
':root .theme-contrast-dark {' +
'--toolbar-header-document: #1e1e1e; --toolbar-header-spreadsheet: #1e1e1e;' +
'--toolbar-header-presentation: #1e1e1e; --toolbar-header-pdf: #1e1e1e; --toolbar-header-visio: #1e1e1e;}');
let objtheme = window.uitheme.colors ? window.uitheme : localstorage.getItem("ui-theme");
const header_tokens = ['toolbar-header-document', 'toolbar-header-spreadsheet', 'toolbar-header-presentation', 'toolbar-header-pdf', 'toolbar-header-visio'];
if ( !!objtheme ) {
if ( typeof(objtheme) == 'string' && objtheme.lastIndexOf("{", 0) === 0 &&
objtheme.indexOf("}", objtheme.length - 1) !== -1 )
{
objtheme = JSON.parse(objtheme);
}
if ( objtheme ) {
if ( window.uitheme.id && window.uitheme.id != objtheme.id ) {
local_storage_available && localstorage.removeItem("ui-theme");
!window.uitheme.type && /-dark/.test(window.uitheme.id) && (window.uitheme.type = 'dark');
} else {
window.uitheme.cache = objtheme;
if ( !window.uitheme.type && objtheme.type ) {
window.uitheme.type = objtheme.type;
}
if ( objtheme.colors ) {
header_tokens.forEach(function (i) {
!!objtheme.colors[i] && document.documentElement.style.setProperty('--' + i, objtheme.colors[i]);
});
let colors = [];
for (let c in objtheme.colors) {
colors.push('--' + c + ':' + objtheme.colors[c]);
}
inject_style_tag('.' + objtheme.id + '{' + colors.join(';') + ';}');
}
if ( objtheme.icons && !(window.uitheme.embedicons === true) ) {
window.uitheme.apply_icons_from_url(objtheme.id, objtheme.icons.basepath);
}
if ( objtheme.skeleton ) {
if ( objtheme.skeleton.css )
inject_style_tag(objtheme.skeleton.css);
if ( objtheme.skeleton.html ) {
window.skhtml = objtheme.skeleton.html;
}
}
}
}
} else {
if ( window.uitheme.id && window.uitheme.id.lastIndexOf("theme-gray", 0) === 0 ) {
header_tokens.forEach(function (i) {
!!document.documentElement.style.setProperty('--' + i, "#f7f7f7");
});
} else if ( window.uitheme.id && window.uitheme.id.lastIndexOf("theme-white", 0) === 0 ) {
header_tokens.forEach(function (i) {
!!document.documentElement.style.setProperty('--' + i, "#ffffff");
});
}
}
}();