2022-07-12 07:40:49 +00:00
|
|
|
import { get, writable } from 'svelte/store';
|
2022-07-12 08:30:37 +00:00
|
|
|
import { quintOut } from 'svelte/easing';
|
|
|
|
import { crossfade } from 'svelte/transition';
|
2022-07-12 07:40:49 +00:00
|
|
|
|
2023-02-23 09:08:41 +00:00
|
|
|
export const settings = (() => {
|
2022-07-13 09:21:59 +00:00
|
|
|
const defaults = {
|
2022-07-12 10:28:53 +00:00
|
|
|
theme: 'dark',
|
|
|
|
cols: 4,
|
|
|
|
rows: 3,
|
2022-07-18 09:40:44 +00:00
|
|
|
fontSize: 1,
|
2022-10-28 13:16:04 +00:00
|
|
|
animate: true,
|
2022-07-13 09:21:59 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const s = writable(defaults);
|
2022-07-12 07:40:49 +00:00
|
|
|
|
|
|
|
function updateStorage(val) {
|
2023-02-23 09:08:41 +00:00
|
|
|
window.localStorage.setItem('statusdash', JSON.stringify({ ...defaults, ...val }));
|
2022-07-12 07:40:49 +00:00
|
|
|
s.set(val);
|
|
|
|
}
|
|
|
|
|
2022-07-13 10:10:20 +00:00
|
|
|
const localStorageString = window.localStorage.getItem('statusdash');
|
|
|
|
let localStorage = {};
|
|
|
|
|
|
|
|
try {
|
2023-02-23 09:08:41 +00:00
|
|
|
localStorage = JSON.parse(localStorageString || '{}');
|
2022-07-13 10:10:20 +00:00
|
|
|
}
|
|
|
|
catch {
|
|
|
|
localStorage = {};
|
|
|
|
}
|
|
|
|
|
|
|
|
updateStorage(localStorage);
|
2022-07-12 10:28:53 +00:00
|
|
|
|
2022-07-12 07:40:49 +00:00
|
|
|
return {
|
|
|
|
subscribe: s.subscribe,
|
2023-02-23 09:08:41 +00:00
|
|
|
set: val => updateStorage(val || {}),
|
2022-07-12 11:32:19 +00:00
|
|
|
update: val => updateStorage({ ...get(s), ...val }),
|
2022-07-12 07:40:49 +00:00
|
|
|
};
|
2023-02-23 09:08:41 +00:00
|
|
|
})();
|
2022-07-12 07:40:49 +00:00
|
|
|
|
|
|
|
export const shuffle = crossfade({
|
|
|
|
fallback(node) {
|
|
|
|
const style = getComputedStyle(node);
|
|
|
|
const transform = style.transform === 'none' ? '' : style.transform;
|
|
|
|
|
|
|
|
return {
|
2022-10-28 13:16:04 +00:00
|
|
|
duration: get(settings).animate ? 300 : 0,
|
2022-07-12 07:40:49 +00:00
|
|
|
easing: quintOut,
|
|
|
|
css: t => `
|
|
|
|
transform: ${transform} scale(${t});
|
|
|
|
opacity: ${t}
|
|
|
|
`,
|
|
|
|
};
|
|
|
|
},
|
|
|
|
});
|
2022-07-12 09:08:27 +00:00
|
|
|
|
|
|
|
export function ringBell() {
|
2022-07-13 09:19:48 +00:00
|
|
|
const bell = new Audio(window.location.href + '/sound');
|
2022-07-13 11:42:37 +00:00
|
|
|
bell.loop = true;
|
2022-07-12 09:08:27 +00:00
|
|
|
bell.addEventListener('canplaythrough', () => bell.play());
|
2022-07-13 11:42:37 +00:00
|
|
|
window.addEventListener('keydown', () => bell.pause());
|
2022-07-12 09:08:27 +00:00
|
|
|
}
|
2022-07-12 10:06:26 +00:00
|
|
|
|
|
|
|
export function formatDuration(ms) {
|
|
|
|
// modified from https://www.30secondsofcode.org/js/s/format-duration
|
|
|
|
|
|
|
|
if (ms < 0) {
|
|
|
|
ms = -ms;
|
|
|
|
}
|
|
|
|
const time = {
|
|
|
|
d: Math.floor(ms / 86400000),
|
|
|
|
h: Math.floor(ms / 3600000) % 24,
|
|
|
|
m: Math.floor(ms / 60000) % 60,
|
|
|
|
s: Math.floor(ms / 1000) % 60,
|
|
|
|
};
|
|
|
|
return Object.entries(time)
|
|
|
|
.filter(val => val[1] !== 0)
|
|
|
|
.map(([ key, val ]) => `${val} ${key}`)
|
|
|
|
.join(' ');
|
|
|
|
}
|