@go-avro/avro-js 0.0.4-beta.21 → 0.0.4-beta.23

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -31,5 +31,6 @@ declare module '../../types/api/Job' {
31
31
  }
32
32
  export declare class Job {
33
33
  constructor(init?: Partial<Job>);
34
- portionDone: () => number;
34
+ portionDone: (fallback: Date) => number;
35
+ isDone: (fallback: Date) => boolean;
35
36
  }
@@ -2,11 +2,14 @@ import { Task } from "../../types/api/Task";
2
2
  import { RouteJob } from "../../types/api/RouteJob";
3
3
  export class Job {
4
4
  constructor(init) {
5
- this.portionDone = () => {
5
+ this.portionDone = (fallback) => {
6
6
  if (!this.tasks || this.tasks.length === 0) {
7
7
  return 0;
8
8
  }
9
- return this.tasks.filter(t => t.isDone?.()).length / this.tasks.length;
9
+ return this.tasks.filter(t => t.isDone?.(fallback)).length / this.tasks.length;
10
+ };
11
+ this.isDone = (fallback) => {
12
+ return this.portionDone(fallback) === 1;
10
13
  };
11
14
  Object.assign(this, init);
12
15
  if (init?.tasks) {
@@ -1,5 +1,6 @@
1
1
  import { RouteJob } from "../../types/api/RouteJob";
2
2
  export declare const FrequencyType: {
3
+ readonly ONCE: "ONCE";
3
4
  readonly DAILY: "DAILY";
4
5
  readonly WEEKLY: "WEEKLY";
5
6
  readonly BIWEEKLY: "BIWEEKLY";
@@ -30,5 +31,7 @@ declare module '../../types/api/Route' {
30
31
  }
31
32
  export declare class Route {
32
33
  constructor(init?: Partial<Route>);
33
- getNextOccurrences: (count?: number) => number[];
34
+ getNextOccurrences: (count?: number) => (Date | null)[];
35
+ getNextOccurrence: (after?: Date) => Date | null;
36
+ getPreviousOccurrence: (before?: Date) => Date | null;
34
37
  }
@@ -1,5 +1,6 @@
1
1
  import { RouteJob } from "../../types/api/RouteJob";
2
2
  export const FrequencyType = {
3
+ ONCE: "ONCE",
3
4
  DAILY: "DAILY",
4
5
  WEEKLY: "WEEKLY",
5
6
  BIWEEKLY: "BIWEEKLY",
@@ -9,37 +10,59 @@ export const FrequencyType = {
9
10
  export class Route {
10
11
  constructor(init) {
11
12
  this.getNextOccurrences = (count = 1) => {
12
- if (!this.frequency) {
13
- return [];
13
+ let next_occurrences = [];
14
+ for (let i = 0; i < count; i++) {
15
+ next_occurrences.push(this.getNextOccurrence(next_occurrences.length > 0 ? next_occurrences[next_occurrences.length - 1] ?? new Date() : new Date()));
14
16
  }
15
- const occurrences = [];
16
- let nextOccurrence = this.start_time;
17
- const now = Date.now();
18
- while (occurrences.length < count) {
19
- if (nextOccurrence > now) {
20
- occurrences.push(nextOccurrence);
21
- }
17
+ return next_occurrences;
18
+ };
19
+ this.getNextOccurrence = (after = new Date()) => {
20
+ let next_occurrence = new Date(this.start_time * 1000);
21
+ while (next_occurrence <= after) {
22
22
  switch (this.frequency) {
23
+ case FrequencyType.ONCE:
24
+ return null;
23
25
  case FrequencyType.DAILY:
24
- nextOccurrence += 24 * 60 * 60 * 1000;
26
+ next_occurrence.setDate(next_occurrence.getDate() + 1);
25
27
  break;
26
28
  case FrequencyType.WEEKLY:
27
- nextOccurrence += 7 * 24 * 60 * 60 * 1000;
29
+ next_occurrence.setDate(next_occurrence.getDate() + 7);
28
30
  break;
29
31
  case FrequencyType.BIWEEKLY:
30
- nextOccurrence += 14 * 24 * 60 * 60 * 1000;
32
+ next_occurrence.setDate(next_occurrence.getDate() + 14);
31
33
  break;
32
34
  case FrequencyType.MONTHLY:
33
- nextOccurrence += 30 * 24 * 60 * 60 * 1000;
35
+ next_occurrence.setMonth(next_occurrence.getMonth() + 1);
34
36
  break;
35
37
  case FrequencyType.YEARLY:
36
- nextOccurrence += 365 * 24 * 60 * 60 * 1000;
38
+ next_occurrence.setFullYear(next_occurrence.getFullYear() + 1);
37
39
  break;
38
- default:
39
- throw new Error("Invalid frequency");
40
40
  }
41
41
  }
42
- return occurrences;
42
+ return next_occurrence;
43
+ };
44
+ this.getPreviousOccurrence = (before = new Date()) => {
45
+ let previous_occurrence = new Date(this.start_time * 1000);
46
+ switch (this.frequency) {
47
+ case FrequencyType.ONCE:
48
+ return null;
49
+ case FrequencyType.DAILY:
50
+ previous_occurrence.setDate(previous_occurrence.getDate() - 1);
51
+ break;
52
+ case FrequencyType.WEEKLY:
53
+ previous_occurrence.setDate(previous_occurrence.getDate() - 7);
54
+ break;
55
+ case FrequencyType.BIWEEKLY:
56
+ previous_occurrence.setDate(previous_occurrence.getDate() - 14);
57
+ break;
58
+ case FrequencyType.MONTHLY:
59
+ previous_occurrence.setMonth(previous_occurrence.getMonth() - 1);
60
+ break;
61
+ case FrequencyType.YEARLY:
62
+ previous_occurrence.setFullYear(previous_occurrence.getFullYear() - 1);
63
+ break;
64
+ }
65
+ return previous_occurrence <= before ? previous_occurrence : null;
43
66
  };
44
67
  Object.assign(this, init);
45
68
  if (init?.jobs) {
@@ -53,5 +53,5 @@ export declare class Task {
53
53
  computeNextTaskState: (isCustomer: boolean, action: "accept" | "modify" | "reject") => TaskStatus;
54
54
  getPrepaidEventsRemaining: () => number;
55
55
  getPrepaidMonthsRemaining: () => number;
56
- isDone: (fallback?: number) => number | boolean;
56
+ isDone: (fallback: Date) => boolean | 1;
57
57
  }
@@ -51,7 +51,7 @@ export class Task {
51
51
  return acc;
52
52
  }, 0);
53
53
  };
54
- this.isDone = (fallback = 0) => {
54
+ this.isDone = (fallback) => {
55
55
  if (!this.status || this.status !== TaskStatus.ACTIVE) {
56
56
  return 1;
57
57
  }
@@ -59,8 +59,8 @@ export class Task {
59
59
  return this.overdue_time <= 0;
60
60
  }
61
61
  else {
62
- // If frequency is 0, task falls back to company.indicator_lifetime
63
- return this.last_completed_event?.time_ended ?? 0 > (new Date().getTime() / 1000 - fallback);
62
+ // If frequency is 0, use fallback
63
+ return new Date(this.last_completed_event?.time_ended ?? 0 * 1000) > fallback;
64
64
  }
65
65
  };
66
66
  Object.assign(this, init);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@go-avro/avro-js",
3
- "version": "0.0.4-beta.21",
3
+ "version": "0.0.4-beta.23",
4
4
  "description": "JS client for Avro backend integration.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",