Files
Picsur/frontend/src/app/routes/settings/settings-syspref/settings-syspref.component.ts

56 lines
1.5 KiB
TypeScript
Raw Normal View History

2022-03-20 22:11:17 +01:00
import { Component, OnInit } from '@angular/core';
2022-03-19 19:30:47 +01:00
import { AutoUnsubscribe } from 'ngx-auto-unsubscribe-decorator';
import { SysPreferenceResponse } from 'picsur-shared/dist/dto/api/pref.dto';
import { SysprefService as SysPrefService } from 'src/app/services/api/syspref.service';
2022-03-18 20:45:30 +01:00
@Component({
templateUrl: './settings-syspref.component.html',
})
2022-03-20 22:11:17 +01:00
export class SettingsSysprefComponent implements OnInit {
2022-03-19 19:30:47 +01:00
render = true;
preferences: SysPreferenceResponse[] = [];
2022-03-18 20:45:30 +01:00
2022-03-19 19:30:47 +01:00
constructor(private sysprefService: SysPrefService) {}
async ngOnInit() {
this.subscribePreferences();
await this.sysprefService.getPreferences();
}
@AutoUnsubscribe()
private subscribePreferences() {
return this.sysprefService.live.subscribe((preferences) => {
// If the preferences are the same, something probably went wrong, so reset
if (this.compareFlatObjectArray(this.preferences, preferences)) {
this.render = false;
setTimeout(() => {
this.render = true;
});
}
this.preferences = preferences;
});
}
private compareFlatObjectArray(a: any[], b: any[]): boolean {
if (a.length !== b.length) {
return false;
}
for (let i = 0; i < a.length; i++) {
if (!this.compareFlatObject(a[i], b[i])) {
return false;
}
}
return true;
}
private compareFlatObject(a: any, b: any): boolean {
for (const key in a) {
if (a.hasOwnProperty(key) && a[key] !== b[key]) {
return false;
}
}
return true;
}
2022-03-18 20:45:30 +01:00
}