2021-01-18 16:24:57 +01:00
|
|
|
import { Injectable } from '@angular/core';
|
2021-10-26 15:27:25 +01:00
|
|
|
import { ThemeService } from 'src/app/services/theme.service';
|
2021-11-23 13:55:43 +01:00
|
|
|
import { StorageService} from 'src/app/services/storage.service';
|
2021-01-18 16:24:57 +01:00
|
|
|
|
|
|
|
|
@Injectable({
|
|
|
|
|
providedIn: 'root'
|
|
|
|
|
})
|
2021-08-27 15:30:02 +01:00
|
|
|
export class BackgroundService {
|
2021-01-18 16:24:57 +01:00
|
|
|
|
2021-10-18 17:42:25 +01:00
|
|
|
callBacks: {
|
2021-10-19 09:41:06 +01:00
|
|
|
type: 'Offline' | 'Online' | 'Notification',
|
2021-10-18 17:42:25 +01:00
|
|
|
object?: string
|
|
|
|
|
funx: Function
|
|
|
|
|
}[] = []
|
|
|
|
|
|
2021-10-26 15:27:25 +01:00
|
|
|
constructor(
|
2021-11-23 13:55:43 +01:00
|
|
|
private themeservice: ThemeService,
|
|
|
|
|
private storageservice: StorageService
|
2021-10-26 15:27:25 +01:00
|
|
|
) { }
|
2021-08-27 15:35:29 +01:00
|
|
|
|
|
|
|
|
online() {
|
2022-10-11 17:07:51 +01:00
|
|
|
|
|
|
|
|
this.paint()
|
|
|
|
|
|
|
|
|
|
this.callBacks.forEach((e) => {
|
|
|
|
|
if (e.type == 'Online') {
|
|
|
|
|
e.funx()
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
2021-10-26 15:27:25 +01:00
|
|
|
|
2022-10-11 17:07:51 +01:00
|
|
|
paint() {
|
|
|
|
|
if (this.themeservice.currentTheme == 'gov') {
|
2021-10-26 15:27:25 +01:00
|
|
|
document.body.style.setProperty(`--color`, "#d9d9d9");
|
|
|
|
|
document.body.style.setProperty(`--color2`, "#f0f0f0");
|
|
|
|
|
document.body.style.setProperty(`--color3`, "#d9d9d9");
|
|
|
|
|
document.body.style.setProperty(`--color4`, "#d9d9d9ee");
|
|
|
|
|
document.body.style.setProperty(`--color5`, "#ececec");
|
2021-11-23 13:55:43 +01:00
|
|
|
this.storageservice.store('networkCheckStore','online');
|
2021-10-26 15:27:25 +01:00
|
|
|
|
2022-10-20 15:45:10 +01:00
|
|
|
} else if (this.themeservice.currentTheme == 'default') {
|
2021-10-26 15:27:25 +01:00
|
|
|
document.body.style.setProperty(`--color`, "#0782C9");
|
|
|
|
|
document.body.style.setProperty(`--color2`, "#45BAFF");
|
|
|
|
|
document.body.style.setProperty(`--color3`, "#0782C9");
|
|
|
|
|
document.body.style.setProperty(`--color4`, "#0782c9f0");
|
|
|
|
|
document.body.style.setProperty(`--color5`, "#45BAFF");
|
2021-11-23 13:55:43 +01:00
|
|
|
this.storageservice.store('networkCheckStore','online');
|
2022-10-20 15:45:10 +01:00
|
|
|
} else if (this.themeservice.currentTheme == 'doneIt') {
|
|
|
|
|
document.body.style.setProperty(`--color`, "#69B3E7");
|
|
|
|
|
document.body.style.setProperty(`--color2`, "#A5D1F1");
|
|
|
|
|
document.body.style.setProperty(`--color3`, "#69B3E7");
|
|
|
|
|
document.body.style.setProperty(`--color4`, "#69B3E7");
|
|
|
|
|
document.body.style.setProperty(`--color5`, "#A5D1F1");
|
2021-10-26 15:27:25 +01:00
|
|
|
}
|
2021-08-27 15:35:29 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
offline() {
|
|
|
|
|
document.body.style.setProperty(`--color`, "#ffb703");
|
|
|
|
|
document.body.style.setProperty(`--color2`, "#ffb703");
|
|
|
|
|
document.body.style.setProperty(`--color3`, "#ffb703");
|
|
|
|
|
document.body.style.setProperty(`--color4`, "#ffb703");
|
|
|
|
|
document.body.style.setProperty(`--color5`, "#ffb703");
|
2021-11-23 13:55:43 +01:00
|
|
|
this.storageservice.store('networkCheckStore','offline');
|
2021-10-18 17:42:25 +01:00
|
|
|
this.callBacks.forEach((e) => {
|
|
|
|
|
if (e.type == 'Offline') {
|
|
|
|
|
e.funx()
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
|
2021-10-19 09:41:06 +01:00
|
|
|
registerBackService(type: 'Offline' | 'Online' | 'Notification', funx: Function, object = '') {
|
2021-10-18 17:42:25 +01:00
|
|
|
this.callBacks.push({
|
|
|
|
|
type,
|
|
|
|
|
funx,
|
|
|
|
|
object
|
|
|
|
|
})
|
2021-08-27 15:35:29 +01:00
|
|
|
}
|
2021-10-20 17:46:03 +01:00
|
|
|
|
|
|
|
|
|
2021-01-18 16:24:57 +01:00
|
|
|
}
|