Move hashId to stationInfo
[e-mobility-charging-stations-simulator.git] / src / types / ChargingStationWorker.ts
index fe09514f26fbe71b40d90c0762b12b45e7606efe..8a8fd381d3080f16a6cb1e434a0d5413eb57586e 100644 (file)
@@ -1,7 +1,10 @@
+import type ChargingStationInfo from './ChargingStationInfo';
+import type { ConnectorStatus } from './ConnectorStatus';
+import type { JsonObject } from './JsonType';
+import type { BootNotificationResponse } from './ocpp/Responses';
+import type Statistics from './Statistics';
 import { WorkerData, WorkerMessage, WorkerMessageEvents } from './Worker';
 
-import { JsonObject } from './JsonType';
-
 export interface ChargingStationWorkerOptions extends JsonObject {
   elementStartDelay?: number;
 }
@@ -12,22 +15,30 @@ export interface ChargingStationWorkerData extends WorkerData {
   chargingStationWorkerOptions?: ChargingStationWorkerOptions;
 }
 
-enum InternalChargingStationWorkerMessageEvents {
+export interface ChargingStationData extends WorkerData {
+  stationInfo: ChargingStationInfo;
+  stopped: boolean;
+  bootNotificationResponse: BootNotificationResponse;
+  connectors: ConnectorStatus[];
+}
+
+enum ChargingStationMessageEvents {
   STARTED = 'started',
   STOPPED = 'stopped',
+  UPDATED = 'updated',
   PERFORMANCE_STATISTICS = 'performanceStatistics',
 }
 
-export type ChargingStationWorkerMessageEvents =
-  | WorkerMessageEvents
-  | InternalChargingStationWorkerMessageEvents;
+export type ChargingStationWorkerMessageEvents = WorkerMessageEvents | ChargingStationMessageEvents;
 
 export const ChargingStationWorkerMessageEvents = {
   ...WorkerMessageEvents,
-  ...InternalChargingStationWorkerMessageEvents,
+  ...ChargingStationMessageEvents,
 };
 
-export interface ChargingStationWorkerMessage
-  extends Omit<WorkerMessage<ChargingStationWorkerData>, 'id'> {
+export type ChargingStationWorkerMessageData = ChargingStationData | Statistics;
+
+export interface ChargingStationWorkerMessage<T extends WorkerData>
+  extends Omit<WorkerMessage<T>, 'id'> {
   id: ChargingStationWorkerMessageEvents;
 }