mirror of
https://github.com/the-djmaze/snappymail.git
synced 2025-01-07 15:27:43 +08:00
189 lines
4.7 KiB
JavaScript
189 lines
4.7 KiB
JavaScript
|
|
(win => {
|
|
|
|
const
|
|
doc = document,
|
|
eId = id => doc.getElementById(id),
|
|
htmlCL = doc.documentElement.classList,
|
|
app = eId('rl-app'),
|
|
options = app && app.dataset.boot && JSON.parse(app.dataset.boot) || {},
|
|
|
|
Storage = type => {
|
|
let name = type+'Storage';
|
|
try {
|
|
win[name].setItem(name, '');
|
|
win[name].getItem(name);
|
|
win[name].removeItem(name);
|
|
} catch (e) {
|
|
console.error(e);
|
|
const cookieName = encodeURIComponent(name+('session' === type ? win.name || (win.name = Date.now()) : ''));
|
|
|
|
// initialise if there's already data
|
|
let data = doc.cookie.match('(^|;) ?'+cookieName+'=([^;]*)(;|$)');
|
|
data = data ? decodeURIComponent(data[2]) : null;
|
|
data = data ? JSON.parse(data) : {};
|
|
|
|
win[name] = {
|
|
getItem: key => data[key] === undefined ? null : data[key],
|
|
setItem: function (key, value) {
|
|
data[key] = ''+value; // forces the value to a string
|
|
doc.cookie = cookieName+'='+encodeURIComponent(JSON.stringify(data))
|
|
+"; expires="+('local' === type ? (new Date(Date.now()+(365*24*60*60*1000))).toGMTString() : '')
|
|
+"; path=/; samesite=strict";
|
|
}
|
|
};
|
|
}
|
|
},
|
|
STORAGE_KEY = '__rlA',
|
|
TIME_KEY = '__rlT',
|
|
AUTH_KEY = 'AuthAccountHash',
|
|
storage = () => window.sessionStorage,
|
|
timestamp = () => Math.round(Date.now() / 1000),
|
|
setTimestamp = () => storage().setItem(TIME_KEY, timestamp()),
|
|
|
|
showError = () => {
|
|
eId('rl-loading').hidden = true;
|
|
eId('rl-loading-error').hidden = false;
|
|
p.end();
|
|
},
|
|
|
|
loadScript = src => {
|
|
if (!src) {
|
|
throw new Error('src should not be empty.');
|
|
}
|
|
return new Promise((resolve, reject) => {
|
|
const script = doc.createElement('script');
|
|
script.onload = () => {
|
|
p.set(pStep += step);
|
|
resolve();
|
|
};
|
|
script.onerror = () => reject(new Error(src));
|
|
script.src = src;
|
|
// script.async = true;
|
|
doc.head.append(script);
|
|
});
|
|
},
|
|
|
|
step = 100 / 7,
|
|
p = win.progressJs = {
|
|
set: percent => progress.style.width = Math.min(percent, 100) + '%',
|
|
end: () => {
|
|
if (container) {
|
|
p.set(100);
|
|
setTimeout(() => {
|
|
container.remove();
|
|
container = progress = null;
|
|
}, 600);
|
|
}
|
|
}
|
|
};
|
|
|
|
if (!navigator || !navigator.cookieEnabled) {
|
|
doc.location.href = './?/NoCookie';
|
|
}
|
|
|
|
let pStep = 0,
|
|
container = doc.querySelector('.progressjs'),
|
|
progress = doc.querySelector('.progressjs-inner'),
|
|
|
|
RL_APP_DATA = {};
|
|
|
|
win.rl = {
|
|
hash: {
|
|
// getHash
|
|
get: () => storage().getItem(STORAGE_KEY) || null,
|
|
// setHash
|
|
set: () => {
|
|
storage().setItem(STORAGE_KEY, RL_APP_DATA && RL_APP_DATA[AUTH_KEY]
|
|
? RL_APP_DATA[AUTH_KEY] : '');
|
|
setTimestamp();
|
|
},
|
|
// clearHash
|
|
clear: () => {
|
|
storage().setItem(STORAGE_KEY, '');
|
|
setTimestamp();
|
|
},
|
|
// checkTimestamp
|
|
check: () => {
|
|
if (timestamp() > (parseInt(storage().getItem(TIME_KEY) || 0, 10) || 0) + 3600000) {
|
|
// 60m
|
|
rl.hash.clear();
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
},
|
|
data: () => RL_APP_DATA,
|
|
adminArea: () => options.admin,
|
|
settings: {
|
|
get: name => null == RL_APP_DATA[name] ? null : RL_APP_DATA[name],
|
|
set: (name, value) => RL_APP_DATA[name] = value,
|
|
app: name => {
|
|
const APP_SETTINGS = RL_APP_DATA.System || {};
|
|
return null == APP_SETTINGS[name] ? null : APP_SETTINGS[name];
|
|
},
|
|
capa: name => null != name && Array.isArray(RL_APP_DATA.Capa) && RL_APP_DATA.Capa.includes(name)
|
|
},
|
|
setWindowTitle: title => {
|
|
title = null == title ? '' : '' + title;
|
|
if (RL_APP_DATA.Title) {
|
|
title += (title ? ' - ' : '') + RL_APP_DATA.Title;
|
|
}
|
|
doc.title = null == title ? '' : '' + title;
|
|
},
|
|
|
|
initData: appData => {
|
|
RL_APP_DATA = appData;
|
|
|
|
rl.hash.set();
|
|
|
|
if (appData) {
|
|
if (appData.NewThemeLink) {
|
|
eId('app-theme-link').href = appData.NewThemeLink;
|
|
}
|
|
|
|
loadScript(appData.StaticLibJsLink)
|
|
.then(() => Promise.all([loadScript(appData.TemplatesLink), loadScript(appData.LangLink)]))
|
|
.then(() => loadScript(appData.StaticAppJsLink))
|
|
.then(() => appData.PluginsLink ? loadScript(appData.PluginsLink) : Promise.resolve())
|
|
.then(() =>
|
|
// Enable the old CKEditor?
|
|
(appData.Auth && appData.StaticEditorJsLink)
|
|
? loadScript(appData.StaticEditorJsLink)
|
|
: Promise.resolve()
|
|
)
|
|
.then(() => win.__APP_BOOT ? win.__APP_BOOT(showError) : showError())
|
|
.catch(e => {
|
|
showError();
|
|
throw e;
|
|
});
|
|
} else {
|
|
showError();
|
|
}
|
|
}
|
|
};
|
|
|
|
p.set(1);
|
|
|
|
Storage('local');
|
|
Storage('session');
|
|
|
|
// init section
|
|
setInterval(setTimestamp, 60000); // 1m
|
|
|
|
htmlCL.add(options.mobileDevice ? 'mobile' : 'no-mobile');
|
|
|
|
[eId('app-css'),eId('app-theme-link')].forEach(css => css.href = css.dataset.href);
|
|
|
|
loadScript('./?/'
|
|
+ (options.admin ? 'Admin' : '')
|
|
+ 'AppData@'
|
|
+ (options.mobile ? 'mobile' : 'no-mobile')
|
|
+ (options.mobileDevice ? '-1' : '-0')
|
|
+ '/'
|
|
+ (rl.hash.get() || '0')
|
|
+ '/'
|
|
+ Math.random().toString().substr(2)
|
|
+ '/').then(() => {});
|
|
|
|
})(this);
|