2020-10-15 01:16:37 +08:00
|
|
|
import { SaveSettingsStep } from 'Common/Enums';
|
2022-03-02 17:24:24 +08:00
|
|
|
import { elementById } from 'Common/Globals';
|
2016-06-07 05:57:52 +08:00
|
|
|
|
2021-08-20 21:40:07 +08:00
|
|
|
let __themeTimer = 0,
|
|
|
|
__themeJson = null;
|
|
|
|
|
2021-01-27 07:26:31 +08:00
|
|
|
export const
|
|
|
|
isArray = Array.isArray,
|
2021-07-22 03:34:17 +08:00
|
|
|
arrayLength = array => isArray(array) && array.length,
|
2021-08-20 21:40:07 +08:00
|
|
|
isFunction = v => typeof v === 'function',
|
|
|
|
pString = value => null != value ? '' + value : '',
|
|
|
|
|
2021-11-01 18:24:11 +08:00
|
|
|
forEachObjectValue = (obj, fn) => Object.values(obj).forEach(fn),
|
|
|
|
|
2021-12-01 20:54:35 +08:00
|
|
|
forEachObjectEntry = (obj, fn) => Object.entries(obj).forEach(([key, value]) => fn(key, value)),
|
|
|
|
|
2021-08-20 21:40:07 +08:00
|
|
|
pInt = (value, defaultValue = 0) => {
|
|
|
|
value = parseInt(value, 10);
|
|
|
|
return isNaN(value) || !isFinite(value) ? defaultValue : value;
|
|
|
|
},
|
|
|
|
|
|
|
|
convertThemeName = theme => theme
|
|
|
|
.replace(/@custom$/, '')
|
2020-09-03 18:51:15 +08:00
|
|
|
.replace(/([A-Z])/g, ' $1')
|
2020-10-15 01:16:37 +08:00
|
|
|
.replace(/[^a-zA-Z0-9]+/g, ' ')
|
2021-08-20 21:40:07 +08:00
|
|
|
.trim(),
|
2016-06-07 05:57:52 +08:00
|
|
|
|
2021-08-20 21:40:07 +08:00
|
|
|
defaultOptionsAfterRender = (domItem, item) =>
|
2022-09-02 17:52:07 +08:00
|
|
|
item && undefined !== item.disabled && domItem?.classList.toggle('disabled', domItem.disabled = item.disabled),
|
2016-06-07 05:57:52 +08:00
|
|
|
|
2021-12-07 19:40:55 +08:00
|
|
|
// unescape(encodeURIComponent()) makes the UTF-16 DOMString to an UTF-8 string
|
|
|
|
b64EncodeJSON = data => btoa(unescape(encodeURIComponent(JSON.stringify(data)))),
|
|
|
|
/* // Without deprecated 'unescape':
|
|
|
|
b64EncodeJSON = data => btoa(encodeURIComponent(JSON.stringify(data)).replace(
|
|
|
|
/%([0-9A-F]{2})/g, (match, p1) => String.fromCharCode('0x' + p1)
|
2022-02-24 19:43:44 +08:00
|
|
|
)),
|
2021-12-07 19:40:55 +08:00
|
|
|
*/
|
|
|
|
b64EncodeJSONSafe = data => b64EncodeJSON(data).replace(/\+/g, '-').replace(/\//g, '_').replace(/=+$/, ''),
|
|
|
|
|
2021-08-20 21:40:07 +08:00
|
|
|
changeTheme = (value, themeTrigger = ()=>0) => {
|
|
|
|
const themeStyle = elementById('app-theme-style'),
|
|
|
|
clearTimer = () => {
|
|
|
|
__themeTimer = setTimeout(() => themeTrigger(SaveSettingsStep.Idle), 1000);
|
|
|
|
__themeJson = null;
|
2022-03-08 17:52:40 +08:00
|
|
|
},
|
|
|
|
url = themeStyle.dataset.href.replace(/(Admin|User)\/-\/[^/]+\//, '$1/-/' + value + '/') + 'Json/';
|
2021-08-20 21:40:07 +08:00
|
|
|
|
2022-03-01 22:49:35 +08:00
|
|
|
clearTimeout(__themeTimer);
|
2021-08-20 21:40:07 +08:00
|
|
|
|
2022-03-01 22:49:35 +08:00
|
|
|
themeTrigger(SaveSettingsStep.Animate);
|
2021-08-20 21:40:07 +08:00
|
|
|
|
2022-03-01 22:49:35 +08:00
|
|
|
if (__themeJson) {
|
|
|
|
__themeJson.abort();
|
|
|
|
}
|
|
|
|
let init = {};
|
|
|
|
if (window.AbortController) {
|
|
|
|
__themeJson = new AbortController();
|
|
|
|
init.signal = __themeJson.signal;
|
2020-07-24 02:35:37 +08:00
|
|
|
}
|
2022-03-01 22:49:35 +08:00
|
|
|
rl.fetchJSON(url, init)
|
|
|
|
.then(data => {
|
|
|
|
if (2 === arrayLength(data)) {
|
|
|
|
themeStyle.textContent = data[1];
|
|
|
|
themeTrigger(SaveSettingsStep.TrueResult);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(clearTimer, clearTimer);
|
2021-10-21 23:15:00 +08:00
|
|
|
},
|
|
|
|
|
|
|
|
getKeyByValue = (o, v) => Object.keys(o).find(key => o[key] === v);
|