@go-avro/avro-js 0.0.9-beta.2 → 0.0.10-beta.0

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.
@@ -34,9 +34,6 @@ AvroQueryClient.prototype.useGetJobs = function (params) {
34
34
  job.last_completed_event = job.tasks.reduce((latest, task) => {
35
35
  return task.last_completed_event && (!latest || task.last_completed_event.time_started > latest.time_started) ? task.last_completed_event : latest;
36
36
  }, job.last_completed_event);
37
- job.overdue_time = job.tasks.reduce((maxOverdue, task) => {
38
- return task.overdue_time && task.overdue_time > maxOverdue ? task.overdue_time : maxOverdue;
39
- }, 0);
40
37
  queryClient.setQueryData(['job', job.id], job);
41
38
  });
42
39
  return jobs;
@@ -66,9 +63,6 @@ AvroQueryClient.prototype.useGetInfiniteJobs = function (body, onProgress) {
66
63
  if (result.data) {
67
64
  result.data.pages.forEach((data_page) => {
68
65
  data_page.forEach((job) => {
69
- job.overdue_time = (job.tasks || []).reduce((maxOverdue, task) => {
70
- return (task.overdue_time && task.overdue_time > maxOverdue) ? task.overdue_time : maxOverdue;
71
- }, 0);
72
66
  queryClient.setQueryData(['job', job.id], job);
73
67
  });
74
68
  });
@@ -8,29 +8,29 @@ declare module '../../types/api/Job' {
8
8
  company: string;
9
9
  description: string;
10
10
  id: string;
11
- is_one_time: boolean;
12
11
  autostart_radius: number;
13
12
  latitude: number;
14
13
  longitude: number;
15
14
  name: string;
16
15
  internal_notes: string;
17
16
  external_notes: string;
18
- priority: number;
17
+ serviced_by: number;
18
+ time_windows: unknown[];
19
19
  tasks: Partial<Task>[];
20
20
  time_created: number;
21
21
  time_updated: number | null;
22
22
  routes: RouteJob[];
23
23
  subscribers: Subscription[];
24
24
  manual_emails: string[][];
25
- overdue_time: number;
26
25
  last_completed_event: _Event | null;
27
26
  current_event: _Event | null;
28
27
  labels: string[];
29
- owner: string;
28
+ owner: string | null;
30
29
  }
31
30
  }
32
31
  export declare class Job {
33
32
  constructor(init?: Partial<Job>);
33
+ getOverdueLabel: () => string;
34
34
  getStatus(): "PENDING_CUSTOMER" | "PENDING_COMPANY" | "ACTIVE" | "ARCHIVED" | "DRAFT" | "PENDING_PAYMENT" | "PENDING_ACTIVATION";
35
35
  getStatusLabel(): "Active" | "Draft" | "Archived" | "Pending Activation" | "Customer Approval" | "Company Approval" | "Awaiting Payment";
36
36
  portionDone: (fallback?: Date | null, routeJob?: RouteJob) => number;
@@ -2,6 +2,26 @@ import { Task, TaskStatus } from "../../types/api/Task";
2
2
  import { RouteJob } from "../../types/api/RouteJob";
3
3
  export class Job {
4
4
  constructor(init) {
5
+ this.getOverdueLabel = () => {
6
+ const activeTasks = this.tasks.filter(t => t.status === TaskStatus.ACTIVE
7
+ && t.overdueness !== null
8
+ && t.overdueness !== undefined
9
+ && t.overdue_time !== undefined);
10
+ if (activeTasks.length === 0) {
11
+ return "N/A";
12
+ }
13
+ const maxOverdueness = Math.max(...activeTasks.map(t => t.overdueness ?? 0));
14
+ const minOverdueTime = Math.min(...activeTasks.map(t => t.overdue_time ?? 0));
15
+ if (maxOverdueness <= 0) {
16
+ return `In ${Math.abs(Math.round(minOverdueTime / 86400))}d`;
17
+ }
18
+ else if (maxOverdueness < 86400) {
19
+ return "< 1d overdue";
20
+ }
21
+ else {
22
+ return `${Math.floor(maxOverdueness / 86400)}d overdue`;
23
+ }
24
+ };
5
25
  this.portionDone = (fallback, routeJob) => {
6
26
  if (!this.tasks || this.tasks.length === 0) {
7
27
  return 0;
@@ -52,6 +52,7 @@ declare module '../../types/api/Task' {
52
52
  export declare class Task {
53
53
  constructor(init?: Partial<Task>);
54
54
  getStatusLabel: () => "Active" | "Draft" | "Archived" | "Pending Customer Approval" | "Pending Company Approval" | "Pending Payment" | "Pending Activation";
55
+ getOverdueLabel: () => string;
55
56
  getNextDue: () => number | null;
56
57
  computeNextTaskState: (isCustomer: boolean, action: "accept" | "modify" | "reject") => TaskStatus;
57
58
  getPrepaidEventsRemaining: () => number;
@@ -30,9 +30,23 @@ export class Task {
30
30
  return this.status;
31
31
  }
32
32
  };
33
+ this.getOverdueLabel = () => {
34
+ if (this.overdueness === null || this.status !== TaskStatus.ACTIVE) {
35
+ return "N/A";
36
+ }
37
+ else if (this.overdueness <= 0) {
38
+ return `In ${Math.abs(Math.round(this.overdue_time / 86400))}d`;
39
+ }
40
+ else if (this.overdue_time < 86400) {
41
+ return "< 1d overdue";
42
+ }
43
+ else {
44
+ return `${Math.floor(this.overdueness / 86400)}d overdue`;
45
+ }
46
+ };
33
47
  this.getNextDue = () => {
34
- if (this.frequency > 0) {
35
- const lastEventTime = this.last_completed_event?.time_ended ?? this.time_created;
48
+ if (this.frequency > 0 && (this.status === TaskStatus.ACTIVE)) {
49
+ const lastEventTime = this.last_completed_event?.time_ended ?? this.activate_on ?? this.time_created;
36
50
  return lastEventTime + this.delay + this.frequency;
37
51
  }
38
52
  return null;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@go-avro/avro-js",
3
- "version": "0.0.9-beta.2",
3
+ "version": "0.0.10-beta.0",
4
4
  "description": "JS client for Avro backend integration.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",