2016-08-17 06:01:20 +08:00
|
|
|
import ko from 'ko';
|
2022-11-22 17:01:56 +08:00
|
|
|
import { $htmlCL, elementById, leftPanelDisabled, Settings, SettingsGet } from 'Common/Globals';
|
2022-11-08 17:53:14 +08:00
|
|
|
import { isArray, arrayLength } from 'Common/Utils';
|
2023-01-19 23:46:39 +08:00
|
|
|
import { cssLink, serverRequestRaw } from 'Common/Links';
|
2022-11-08 17:53:14 +08:00
|
|
|
import { SaveSettingStatus } from 'Common/Enums';
|
2015-01-27 05:06:00 +08:00
|
|
|
|
2022-11-08 17:53:14 +08:00
|
|
|
let __themeTimer = 0;
|
|
|
|
|
|
|
|
export const
|
2022-11-22 17:01:56 +08:00
|
|
|
appEl = () => elementById('rl-app'),
|
|
|
|
|
2022-11-08 17:53:14 +08:00
|
|
|
ThemeStore = {
|
|
|
|
theme: ko.observable(''),
|
|
|
|
themes: ko.observableArray(),
|
|
|
|
userBackgroundName: ko.observable(''),
|
|
|
|
userBackgroundHash: ko.observable(''),
|
|
|
|
fontSansSerif: ko.observable(''),
|
|
|
|
fontSerif: ko.observable(''),
|
|
|
|
fontMono: ko.observable(''),
|
|
|
|
isMobile: ko.observable($htmlCL.contains('rl-mobile')),
|
|
|
|
|
|
|
|
populate: () => {
|
|
|
|
const themes = Settings.app('themes');
|
|
|
|
|
|
|
|
ThemeStore.themes(isArray(themes) ? themes : []);
|
|
|
|
ThemeStore.theme(SettingsGet('Theme'));
|
|
|
|
if (!ThemeStore.isMobile()) {
|
|
|
|
ThemeStore.userBackgroundName(SettingsGet('UserBackgroundName'));
|
|
|
|
ThemeStore.userBackgroundHash(SettingsGet('UserBackgroundHash'));
|
|
|
|
}
|
|
|
|
ThemeStore.fontSansSerif(SettingsGet('fontSansSerif'));
|
|
|
|
ThemeStore.fontSerif(SettingsGet('fontSerif'));
|
|
|
|
ThemeStore.fontMono(SettingsGet('fontMono'));
|
|
|
|
|
|
|
|
leftPanelDisabled(ThemeStore.isMobile());
|
2021-02-15 22:20:22 +08:00
|
|
|
}
|
2022-11-08 17:53:14 +08:00
|
|
|
},
|
|
|
|
|
|
|
|
changeTheme = (value, themeTrigger = ()=>0) => {
|
|
|
|
const themeStyle = elementById('app-theme-style'),
|
|
|
|
clearTimer = () => {
|
|
|
|
__themeTimer = setTimeout(() => themeTrigger(SaveSettingStatus.Idle), 1000);
|
|
|
|
},
|
2023-01-19 23:46:39 +08:00
|
|
|
url = cssLink(value);
|
2022-11-08 17:53:14 +08:00
|
|
|
|
|
|
|
clearTimeout(__themeTimer);
|
|
|
|
|
|
|
|
themeTrigger(SaveSettingStatus.Saving);
|
|
|
|
|
|
|
|
rl.app.Remote.abort('theme').get('theme', url)
|
|
|
|
.then(data => {
|
|
|
|
if (2 === arrayLength(data)) {
|
|
|
|
themeStyle.textContent = data[1];
|
|
|
|
themeTrigger(SaveSettingStatus.Success);
|
|
|
|
}
|
|
|
|
clearTimer();
|
|
|
|
}, clearTimer);
|
|
|
|
},
|
2021-03-05 23:46:40 +08:00
|
|
|
|
2022-11-08 17:53:14 +08:00
|
|
|
convertThemeName = theme => theme
|
|
|
|
.replace(/@custom$/, '')
|
|
|
|
.replace(/([A-Z])/g, ' $1')
|
|
|
|
.replace(/[^a-zA-Z0-9]+/g, ' ')
|
|
|
|
.trim();
|
2015-01-27 05:06:00 +08:00
|
|
|
|
2021-02-17 03:12:23 +08:00
|
|
|
ThemeStore.isMobile.subscribe(value => $htmlCL.toggle('rl-mobile', value));
|
2021-07-20 22:49:03 +08:00
|
|
|
|
2022-10-20 15:33:44 +08:00
|
|
|
ThemeStore.fontSansSerif.subscribe(value => {
|
|
|
|
if (null != value) {
|
2022-11-22 17:01:56 +08:00
|
|
|
let cl = appEl().classList;
|
2022-10-20 15:33:44 +08:00
|
|
|
cl.forEach(name => {
|
2022-10-26 22:38:39 +08:00
|
|
|
if (name.startsWith('font') && !/font(Serif|Mono)/.test(name)) {
|
2022-10-20 15:33:44 +08:00
|
|
|
cl.remove(name);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
value && cl.add('font'+value);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
ThemeStore.fontSerif.subscribe(value => {
|
|
|
|
if (null != value) {
|
2022-11-22 17:01:56 +08:00
|
|
|
let cl = appEl().classList;
|
2022-10-26 22:38:39 +08:00
|
|
|
cl.forEach(name => name.startsWith('fontSerif') && cl.remove(name));
|
2022-10-20 15:33:44 +08:00
|
|
|
value && cl.add('fontSerif'+value);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
ThemeStore.fontMono.subscribe(value => {
|
|
|
|
if (null != value) {
|
2022-11-22 17:01:56 +08:00
|
|
|
let cl = appEl().classList;
|
2022-10-26 22:38:39 +08:00
|
|
|
cl.forEach(name => name.startsWith('fontMono') && cl.remove(name));
|
2022-10-20 15:33:44 +08:00
|
|
|
value && cl.add('fontMono'+value);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-07-20 22:49:03 +08:00
|
|
|
ThemeStore.userBackgroundHash.subscribe(value => {
|
2022-11-22 17:01:56 +08:00
|
|
|
appEl().classList.toggle('UserBackground', !!value);
|
|
|
|
appEl().style.backgroundImage = value ? "url("+serverRequestRaw('UserBackground', value)+")" : null;
|
2021-07-20 22:49:03 +08:00
|
|
|
});
|