forked from XimeX/usrspace-browser-addon
faster data fetching, badge improvements
This commit is contained in:
parent
489d675ba8
commit
c3cf1e9b96
|
@ -48,5 +48,14 @@
|
|||
},
|
||||
"closed": {
|
||||
"message": "geschlossen"
|
||||
},
|
||||
"badgeOpen": {
|
||||
"message": "open"
|
||||
},
|
||||
"badgeClosed": {
|
||||
"message": " "
|
||||
},
|
||||
"badgeEvent": {
|
||||
"message": " "
|
||||
}
|
||||
}
|
||||
|
|
|
@ -48,5 +48,14 @@
|
|||
},
|
||||
"closed": {
|
||||
"message": "closed"
|
||||
},
|
||||
"badgeOpen": {
|
||||
"message": "open"
|
||||
},
|
||||
"badgeClosed": {
|
||||
"message": " "
|
||||
},
|
||||
"badgeEvent": {
|
||||
"message": " "
|
||||
}
|
||||
}
|
||||
|
|
|
@ -30,28 +30,33 @@ function fetchSpaceApi() {
|
|||
|
||||
async function fetchNewData() {
|
||||
try {
|
||||
const calendarJson = await fetchCalendar();
|
||||
window.calendar = calendarJson;
|
||||
} catch (error) {
|
||||
console.error(error);
|
||||
}
|
||||
const result = await Promise.allSettled([fetchCalendar(), fetchSpaceApi()]);
|
||||
const calendarJson = result[0].value;
|
||||
const spaceApiJson = result[1].value;
|
||||
|
||||
try {
|
||||
const spaceApiJson = await fetchSpaceApi();
|
||||
if (spaceApiJson) {
|
||||
const now = new Date();
|
||||
const eventActive = calendarJson?.some((event) => (
|
||||
new Date(event.begin) <= now && now <= new Date(event.end)
|
||||
)) ?? false;
|
||||
|
||||
await browser.browserAction.setBadgeBackgroundColor({color: Config.openColor});
|
||||
await browser.browserAction.setBadgeText({text: spaceApiJson.state.open ? 'open' : ''});
|
||||
const badgeText = browser.i18n.getMessage(spaceApiJson.state.open ? 'badgeOpen' : eventActive ? 'badgeEvent' : 'badgeClosed');
|
||||
const badgeBgColor = spaceApiJson.state.open ? Config.openColor : eventActive ? Config.eventColor : Config.closedColor;
|
||||
await browser.browserAction.setBadgeText({text: badgeText});
|
||||
await browser.browserAction.setBadgeBackgroundColor({color: badgeBgColor});
|
||||
|
||||
if (window.spaceApi && window.spaceApi.state.open !== spaceApiJson.state.open) {
|
||||
const state = browser.i18n.getMessage(spaceApiJson.state.open ? 'open' : 'closed');
|
||||
await browser.notifications.create('status-change', {
|
||||
type: 'basic',
|
||||
title: browser.i18n.getMessage('stateNotificationTitle'),
|
||||
message: browser.i18n.getMessage('stateNotificationMessage', state),
|
||||
iconUrl: browser.runtime.getURL('src/icons/favicon.svg')
|
||||
});
|
||||
if (window.spaceApi && window.spaceApi.state.open !== spaceApiJson.state.open) {
|
||||
const state = browser.i18n.getMessage(spaceApiJson.state.open ? 'open' : 'closed');
|
||||
await browser.notifications.create('status-change', {
|
||||
type: 'basic',
|
||||
title: browser.i18n.getMessage('stateNotificationTitle'),
|
||||
message: browser.i18n.getMessage('stateNotificationMessage', state),
|
||||
iconUrl: browser.runtime.getURL('src/icons/favicon.svg')
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
window.calendar = calendarJson;
|
||||
window.spaceApi = spaceApiJson;
|
||||
} catch (error) {
|
||||
console.error(error);
|
||||
|
|
|
@ -3,6 +3,8 @@ export default {
|
|||
spaceApiUrl: 'https://www.usrspace.at/spaceapi.json',
|
||||
calenderUrl: 'https://www.usrspace.at/calendar.php',
|
||||
openColor: '#33cc33',
|
||||
closedColor: '#cc3333',
|
||||
eventColor: '#9933cc',
|
||||
quickLinks: [
|
||||
{
|
||||
url: 'https://www.usrspace.at/',
|
||||
|
|
Loading…
Reference in a new issue