snappymail/dev/bootstrap.js

120 lines
3.1 KiB
JavaScript
Raw Normal View History

2021-09-23 21:30:08 +08:00
import { dropdownVisibility, Settings } from 'Common/Globals';
2019-07-05 03:19:24 +08:00
import { i18n } from 'Common/Translator';
2016-06-07 05:57:52 +08:00
import { root } from 'Common/Links';
export default App => {
2015-11-19 01:32:29 +08:00
addEventListener('click', ()=>rl.Dropdowns.detectVisibility());
2015-11-19 01:32:29 +08:00
rl.app = App;
2021-03-24 21:14:21 +08:00
rl.logoutReload = App.logoutReload;
2015-11-19 01:32:29 +08:00
2016-06-17 07:23:49 +08:00
rl.i18n = i18n;
2015-11-19 01:32:29 +08:00
rl.Enums = {
StorageResultType: {
Success: 0,
Error: 1,
Abort: 2
}
};
2015-11-19 01:32:29 +08:00
2020-08-24 17:14:35 +08:00
rl.Dropdowns = [];
rl.Dropdowns.register = function(element) { this.push(element); };
2020-08-24 17:14:35 +08:00
rl.Dropdowns.detectVisibility = (() =>
dropdownVisibility(!!rl.Dropdowns.find(item => item.classList.contains('show')))
2020-08-24 17:14:35 +08:00
).debounce(50);
rl.route = {
root: () => {
rl.route.setHash(root(), true);
rl.route.off();
},
reload: () => {
2020-09-17 05:28:29 +08:00
rl.route.root();
2021-03-10 18:44:48 +08:00
setTimeout(() => (Settings.app('inIframe') ? parent : window).location.reload(), 100);
},
2021-08-13 16:01:01 +08:00
off: () => hasher.active = false,
on: () => hasher.active = true,
/**
* @param {string} sHash
* @param {boolean=} silence = false
* @param {boolean=} replace = false
* @returns {void}
*/
setHash: (hash, silence = false, replace = false) => {
hash = hash.replace(/^[#/]+/, '');
2021-08-20 21:40:07 +08:00
hasher.active = !silence;
hasher[replace ? 'replaceHash' : 'setHash'](hash);
if (silence) {
2021-08-13 16:01:01 +08:00
hasher.active = true;
} else {
hasher.setHash(hash);
}
}
};
rl.fetch = (resource, init, postData) => {
init = Object.assign({
mode: 'same-origin',
cache: 'no-cache',
redirect: 'error',
referrerPolicy: 'no-referrer',
credentials: 'same-origin',
headers: {}
}, init);
if (postData) {
init.method = 'POST';
init.headers['Content-Type'] = 'application/x-www-form-urlencoded; charset=UTF-8';
const buildFormData = (formData, data, parentKey) => {
if (data && typeof data === 'object' && !(data instanceof Date || data instanceof File)) {
Object.keys(data).forEach(key =>
buildFormData(formData, data[key], parentKey ? `${parentKey}[${key}]` : key)
);
} else {
formData.set(parentKey, data == null ? '' : data);
}
return formData;
};
postData = (postData instanceof FormData)
? postData
: buildFormData(new FormData(), postData);
postData.set('XToken', Settings.app('token'));
// init.body = JSON.stringify(Object.fromEntries(postData));
init.body = new URLSearchParams(postData);
}
return fetch(resource, init);
};
rl.fetchJSON = (resource, init, postData) => {
init = Object.assign({ headers: {} }, init);
init.headers.Accept = 'application/json';
return rl.fetch(resource, init, postData).then(response => {
if (!response.ok) {
2021-02-25 17:12:48 +08:00
return Promise.reject('Network response error: ' + response.status);
}
/* TODO: use this for non-developers?
response.clone()
let data = response.text();
try {
return JSON.parse(data);
} catch (e) {
console.error(e);
// console.log(data);
return Promise.reject(Notification.JsonParse);
return {
Result: false,
ErrorCode: 952, // Notification.JsonParse
ErrorMessage: e.message,
ErrorMessageAdditional: data
}
}
*/
return response.json();
});
};
2016-04-21 01:12:51 +08:00
};