status/gui/dashboard/lib.js

80 lines
1.8 KiB
JavaScript
Raw Normal View History

import { get, writable } from 'svelte/store';
import { quintOut } from 'svelte/easing';
import { crossfade } from 'svelte/transition';
2023-02-23 09:08:41 +00:00
export const settings = (() => {
2022-07-13 09:21:59 +00:00
const defaults = {
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);
function updateStorage(val) {
2023-02-23 09:08:41 +00:00
window.localStorage.setItem('statusdash', JSON.stringify({ ...defaults, ...val }));
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);
return {
subscribe: s.subscribe,
2023-02-23 09:08:41 +00:00
set: val => updateStorage(val || {}),
update: val => updateStorage({ ...get(s), ...val }),
};
2023-02-23 09:08:41 +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,
easing: quintOut,
css: t => `
transform: ${transform} scale(${t});
opacity: ${t}
`,
};
},
});
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;
bell.addEventListener('canplaythrough', () => bell.play());
2022-07-13 11:42:37 +00:00
window.addEventListener('keydown', () => bell.pause());
}
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(' ');
}