import autobind from 'autobind-decorator'; import Chart, { Obj, DeepPartial } from '../../core'; import { SchemaType } from '../../../../misc/schema'; import { name, schema } from '../schemas/test-grouped'; type TestGroupedLog = SchemaType; export default class TestGroupedChart extends Chart { private total = {} as Record; constructor() { super(name, schema, true); } @autobind protected genNewLog(latest: TestGroupedLog): DeepPartial { return { foo: { total: latest.foo.total, }, }; } @autobind protected aggregate(logs: TestGroupedLog[]): TestGroupedLog { return { foo: { total: logs[0].foo.total, inc: logs.reduce((a, b) => a + b.foo.inc, 0), dec: logs.reduce((a, b) => a + b.foo.dec, 0), }, }; } @autobind protected async fetchActual(group: string): Promise> { return { foo: { total: this.total[group], }, }; } @autobind public async increment(group: string) { if (this.total[group] == null) this.total[group] = 0; const update: Obj = {}; update.total = 1; update.inc = 1; this.total[group]++; await this.inc({ foo: update }, group); } }