homefront/src/app/battery/battery.service.ts
2018-12-25 21:20:32 -05:00

66 lines
2.0 KiB
TypeScript

import {Injectable} from '@angular/core';
import {firebaseApp} from '../app.module';
@Injectable({
providedIn: 'root'
})
export class BatteryService {
readonly firestore;
batteries = [];
last: Date;
total: number = 0;
get icon() {
if (!this.batteries.length) return 'battery_alert';
if (!this.last) return 'battery_warn';
return 'battery_full';
let temp = 'battery';
// if (this.batteries.length) temp += '_charging';
/*if (this.average <= 20) {
temp += '_20';
} else if (this.average <= 30) {
temp += '_30';
} else if (this.average <= 50) {
temp += '_50';
} else if (this.average <= 60) {
temp += '_60';
} else if (this.average <= 80) {
temp += '_80';
} else if (this.average <= 90) {
temp += '_90';
} else if (this.average > 90) {
temp += 'full'
}*/
return temp;
}
constructor() {
this.firestore = firebaseApp.firestore();
this.firestore.settings({timestampsInSnapshots: true});
this.firestore.collection('Battery').doc('170724D').onSnapshot(snap => {
this.last = new Date();
let data = snap.data();
this.batteries = Object.keys(data.modules).map(key => ({
charge: data.modules[key][0].charge,
chargeHistory: data.modules[key].map((val, i) => ({name: i, value: val.charge})),
charging: data.modules[key][0] > data.modules[key][1],
name: key,
temp: data.modules[key][0].temp,
tempHistory: data.modules[key].map((val, i) => ({name: i, value: val.temp}))
}));
this.total = this.batteries.reduce((acc, battery) => acc + battery.charge, 0) / 2;
console.log(this.batteries)
});
}
setRelayMode(mode?:boolean) {
this.firestore.collection('Battery').doc('170724D').update({config: {relayMode: mode}});
}
}