@iotize/ionic
Version:
Iotize specific building blocks on top of @ionic/angular.
108 lines • 12.8 kB
JavaScript
import { Injectable } from '@angular/core';
import { createMonitoringTicker, MonitorEngine, MonitoringController, } from '@iotize/tap/data';
import { Subject } from 'rxjs';
import { filter, map, share, switchMap } from 'rxjs/operators';
import { CurrentDeviceService } from '../../current-device.service';
import * as i0 from "@angular/core";
import * as i1 from "../../current-device.service";
/**
* Experimental data logger class
*
* @experimental
*/
export class IonicDataLogger {
service;
controller;
/**
* Packet per packet stream
*/
stream;
/**
* Whole data stream
*/
_data = [];
_data$ = new Subject();
get data() {
return this._data$.asObservable();
}
_packetPerBundles = {};
options = {
period: 1000,
};
constructor(service) {
this.service = service;
this.controller = new MonitoringController({
state: MonitorEngine.State.PAUSE,
dueTime: 0,
period: this.options.period,
refresh: false,
});
this.stream = createMonitoringTicker(this.controller)
.pipe(switchMap(async (_) => {
try {
return await this.service.tap.dataLog.dequeue();
}
catch (err) {
console.warn('Failed to read packet', err);
return undefined;
}
}), filter((value) => {
console.log('pass filter', value);
return value !== undefined;
}), map((entry) => {
// Fix as variables is not populated by default
// if (Object.keys(entry.data).length === 0) {
// entry.packet.variables = entry.packet.rawVariables;
// }
const output = entry;
output.decodedData = entry.data;
this.storePacket(output);
return output;
}))
.pipe(share());
}
getCacheForBundle(bundleId) {
return this._packetPerBundles[bundleId];
}
set period(v) {
// console.info(`Update period to ${v} ms`);
this.controller.setPeriod(v);
}
get events() {
return this.stream;
}
get running() {
return this.controller.state === MonitorEngine.State.START;
}
storePacket(packet) {
if (!(packet.meta.bundleId in this._packetPerBundles)) {
this._packetPerBundles[packet.meta.bundleId] = {
name: packet.meta.bundleName || `Bundle ${packet.meta.bundleId}`,
id: packet.meta.bundleId,
packets: [],
};
}
this._packetPerBundles[packet.meta.bundleId].packets.push(packet);
this._data.push(packet);
this._data$.next(this._data);
}
pause() {
this.controller.pause();
}
stop() {
this.controller.stop();
}
start() {
this.controller.start();
return this.events;
}
/** @nocollapse */ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: IonicDataLogger, deps: [{ token: i1.CurrentDeviceService }], target: i0.ɵɵFactoryTarget.Injectable });
/** @nocollapse */ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: IonicDataLogger, providedIn: 'root' });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: IonicDataLogger, decorators: [{
type: Injectable,
args: [{
providedIn: 'root',
}]
}], ctorParameters: () => [{ type: i1.CurrentDeviceService }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-logger.js","sourceRoot":"","sources":["../../../../../../../projects/iotize-ionic/src/lib/extensions/datalogger/data-logger.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport {\n  createMonitoringTicker,\n  MonitorEngine,\n  MonitoringController,\n} from '@iotize/tap/data';\nimport { DataLogger } from '@iotize/tap/data-log';\nimport { Observable, Subject } from 'rxjs';\nimport { filter, map, share, switchMap } from 'rxjs/operators';\nimport { CurrentDeviceService } from '../../current-device.service';\n\nexport namespace IonicDataLogger {\n  export interface PacketInfo<DataType = any> extends DataLogger.RawPacket {\n    meta: DataLogger.RawPacket.Meta & { bundleName?: string };\n    decodedData: DataType;\n  }\n\n  export interface CachePacketType {\n    id: number;\n    name: string;\n    packets: IonicDataLogger.PacketInfo<any>[];\n  }\n  export interface InstanceOptions {\n    period: number;\n  }\n}\n\n/**\n * Experimental data logger class\n *\n * @experimental\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class IonicDataLogger {\n  controller: MonitoringController;\n\n  /**\n   * Packet per packet stream\n   */\n  stream: Observable<IonicDataLogger.PacketInfo>;\n  /**\n   * Whole data stream\n   */\n  private _data: IonicDataLogger.PacketInfo[] = [];\n  private _data$: Subject<IonicDataLogger.PacketInfo[]> = new Subject();\n  public get data(): Observable<IonicDataLogger.PacketInfo[]> {\n    return this._data$.asObservable();\n  }\n\n  _packetPerBundles: Record<number, IonicDataLogger.CachePacketType> = {};\n\n  public options: IonicDataLogger.InstanceOptions = {\n    period: 1000,\n  };\n\n  constructor(private service: CurrentDeviceService) {\n    this.controller = new MonitoringController({\n      state: MonitorEngine.State.PAUSE,\n      dueTime: 0,\n      period: this.options.period,\n      refresh: false,\n    });\n\n    this.stream = createMonitoringTicker(this.controller)\n      .pipe(\n        switchMap(async (_) => {\n          try {\n            return await this.service.tap.dataLog.dequeue();\n          } catch (err) {\n            console.warn('Failed to read packet', err);\n            return undefined;\n          }\n        }),\n        filter<DataLogger.RawPacket | undefined, DataLogger.RawPacket>(\n          (value): value is DataLogger.RawPacket => {\n            console.log('pass filter', value);\n            return value !== undefined;\n          }\n        ),\n        map<DataLogger.RawPacket, IonicDataLogger.PacketInfo>((entry) => {\n          // Fix as variables is not populated by default\n          //   if (Object.keys(entry.data).length === 0) {\n          //       entry.packet.variables = entry.packet.rawVariables;\n          //   }\n          const output = entry as IonicDataLogger.PacketInfo;\n          output.decodedData = entry.data;\n          this.storePacket(output);\n          return output;\n        })\n      )\n      .pipe(share());\n  }\n\n  getCacheForBundle(bundleId: number): IonicDataLogger.CachePacketType {\n    return this._packetPerBundles[bundleId];\n  }\n\n  set period(v: number) {\n    // console.info(`Update period to ${v} ms`);\n    this.controller.setPeriod(v);\n  }\n\n  get events() {\n    return this.stream;\n  }\n\n  get running(): boolean {\n    return this.controller.state === MonitorEngine.State.START;\n  }\n\n  storePacket(packet: IonicDataLogger.PacketInfo<Record<string, any>>) {\n    if (!(packet.meta.bundleId in this._packetPerBundles)) {\n      this._packetPerBundles[packet.meta.bundleId] = {\n        name: packet.meta.bundleName || `Bundle ${packet.meta.bundleId}`,\n        id: packet.meta.bundleId,\n        packets: [],\n      };\n    }\n    this._packetPerBundles[packet.meta.bundleId].packets.push(packet);\n\n    this._data.push(packet);\n    this._data$.next(this._data);\n  }\n\n  pause() {\n    this.controller.pause();\n  }\n\n  stop() {\n    this.controller.stop();\n  }\n\n  start() {\n    this.controller.start();\n    return this.events;\n  }\n}\n"]}