@os1-platform/dispatch-mobile 2.1.12 → 2.1.14

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.
Files changed (58) hide show
  1. package/lib/commonjs/components/executiontasks/imageCapture/ImageCapture.js +3 -0
  2. package/lib/commonjs/components/executiontasks/imageCapture/ImageCapture.js.map +1 -1
  3. package/lib/commonjs/components/executiontasks/scan/ScanET.js +9 -6
  4. package/lib/commonjs/components/executiontasks/scan/ScanET.js.map +1 -1
  5. package/lib/commonjs/components/executiontasks/scan/interfaces.js.map +1 -1
  6. package/lib/commonjs/components/executiontasks/scan/sub_components/SummaryPage.js +66 -27
  7. package/lib/commonjs/components/executiontasks/scan/sub_components/SummaryPage.js.map +1 -1
  8. package/lib/commonjs/components/executiontasks/scan/utils.js +4 -2
  9. package/lib/commonjs/components/executiontasks/scan/utils.js.map +1 -1
  10. package/lib/commonjs/manager/syncmanager/document/DocumentSyncManager.js +0 -13
  11. package/lib/commonjs/manager/syncmanager/document/DocumentSyncManager.js.map +1 -1
  12. package/lib/commonjs/ui/screens/DeliverScreen.js +9 -1
  13. package/lib/commonjs/ui/screens/DeliverScreen.js.map +1 -1
  14. package/lib/commonjs/ui/screens/FormsScreen.js +9 -1
  15. package/lib/commonjs/ui/screens/FormsScreen.js.map +1 -1
  16. package/lib/commonjs/ui/screens/ImageCaptureScreen.js.map +1 -1
  17. package/lib/commonjs/utils/Constants.js +9 -0
  18. package/lib/commonjs/utils/Constants.js.map +1 -0
  19. package/lib/commonjs/utils/Enums.js +12 -0
  20. package/lib/commonjs/utils/Enums.js.map +1 -0
  21. package/lib/commonjs/utils/storage.js.map +1 -1
  22. package/lib/module/components/executiontasks/imageCapture/ImageCapture.js +3 -0
  23. package/lib/module/components/executiontasks/imageCapture/ImageCapture.js.map +1 -1
  24. package/lib/module/components/executiontasks/scan/ScanET.js +9 -6
  25. package/lib/module/components/executiontasks/scan/ScanET.js.map +1 -1
  26. package/lib/module/components/executiontasks/scan/interfaces.js.map +1 -1
  27. package/lib/module/components/executiontasks/scan/sub_components/SummaryPage.js +67 -28
  28. package/lib/module/components/executiontasks/scan/sub_components/SummaryPage.js.map +1 -1
  29. package/lib/module/components/executiontasks/scan/utils.js +4 -2
  30. package/lib/module/components/executiontasks/scan/utils.js.map +1 -1
  31. package/lib/module/manager/syncmanager/document/DocumentSyncManager.js +0 -13
  32. package/lib/module/manager/syncmanager/document/DocumentSyncManager.js.map +1 -1
  33. package/lib/module/ui/screens/DeliverScreen.js +9 -1
  34. package/lib/module/ui/screens/DeliverScreen.js.map +1 -1
  35. package/lib/module/ui/screens/FormsScreen.js +9 -1
  36. package/lib/module/ui/screens/FormsScreen.js.map +1 -1
  37. package/lib/module/ui/screens/ImageCaptureScreen.js.map +1 -1
  38. package/lib/module/utils/Constants.js +3 -0
  39. package/lib/module/utils/Constants.js.map +1 -0
  40. package/lib/module/utils/Enums.js +6 -0
  41. package/lib/module/utils/Enums.js.map +1 -0
  42. package/lib/module/utils/storage.js.map +1 -1
  43. package/lib/typescript/components/executiontasks/scan/interfaces.d.ts +2 -0
  44. package/lib/typescript/utils/Constants.d.ts +1 -0
  45. package/lib/typescript/utils/Enums.d.ts +4 -0
  46. package/package.json +2 -2
  47. package/src/components/executiontasks/imageCapture/ImageCapture.tsx +36 -31
  48. package/src/components/executiontasks/scan/ScanET.tsx +23 -23
  49. package/src/components/executiontasks/scan/interfaces.ts +2 -0
  50. package/src/components/executiontasks/scan/sub_components/SummaryPage.tsx +107 -80
  51. package/src/components/executiontasks/scan/utils.ts +4 -1
  52. package/src/manager/syncmanager/document/DocumentSyncManager.ts +45 -62
  53. package/src/ui/screens/DeliverScreen.tsx +9 -7
  54. package/src/ui/screens/FormsScreen.tsx +14 -7
  55. package/src/ui/screens/ImageCaptureScreen.tsx +1 -1
  56. package/src/utils/Constants.ts +2 -0
  57. package/src/utils/Enums.ts +4 -0
  58. package/src/utils/storage.ts +9 -9
@@ -1 +1 @@
1
- {"version":3,"names":["ExpoBarcodeTypes","exports","SCAN_STATUS","PROCEED_STATUS","SummaryPageTabs"],"sources":["interfaces.ts"],"sourcesContent":["import { SnackBarType } from 'src/components/widgets/SnackBarCustom';\nimport { ScannerOutput } from './ScanSchema';\nimport { IDispatchExecutor } from '@os1-platform/platform-coreos-execution-engine-sdk';\n\nexport enum ExpoBarcodeTypes {\n QRCODE = 'QRCODE',\n aztec = 'aztec',\n codabar = 'codabar',\n code39 = 'code39',\n code93 = 'code93',\n code128 = 'code128',\n datamatrix = 'datamatrix',\n ean13 = 'ean13',\n ean8 = 'ean8',\n itf14 = 'itf14',\n pdf417 = 'pdf417',\n upc_e = 'upc_e',\n}\n\nexport enum SCAN_STATUS {\n SCANNED,\n FAILED,\n}\n\nexport interface ScannedItemData {\n value: string; // Value of scanned item\n validated?: boolean; // Boolean to denote if scan was validate successfully\n timestamp?: number; // Epoch timestamp for the scan\n reasonCode?: string;\n reasonText?: string;\n success?: boolean;\n scanStatus: SCAN_STATUS;\n}\n\nexport interface MergedScan {\n value: string;\n mergedObjectiveId?: string;\n validated?: boolean;\n timestamp?: number;\n scanStatus?: SCAN_STATUS;\n eventCode?: string;\n reasonCode?: string;\n success?: boolean;\n}\n\nexport interface BlindScan {\n maxCount: number;\n scannedCount: number;\n}\n\nexport enum PROCEED_STATUS {\n DELIVER_NOW = 'DELIVER_NOW',\n DELIVER_LATER = 'DELIVER_LATER',\n}\n\nexport enum SummaryPageTabs {\n ALL = 'All',\n PENDING = 'Pending',\n DELIVERED = 'Delivered',\n UNDELIVERED = 'Undelivered',\n}\n\nexport interface DisplaySummary {\n scanId: string;\n eventCode: string;\n reasonCode: string;\n clientName?: string;\n orderId?: string;\n prefixedMergedObjectiveId: string;\n lastStatus: IDispatchExecutor.ExecutionStatus;\n}\n\nexport type ListItem = DisplaySummary & {\n index: number;\n};\n\nexport interface SummaryDisplayData {\n data: DisplaySummary[];\n totalCount: number;\n}\n\nexport interface ADD_SCAN {\n status: boolean;\n message: string;\n type: SnackBarType;\n exit?: boolean;\n data?: any;\n}\n\nexport interface SCAN_MERGED_OBJ_ID_INTEFACE {\n [prefixedMergedObjectiveId: string]: SCANNED_RECORD;\n}\n\nexport interface SCANNED_RECORD {\n success: string[]; // Array merged objective ids which are of success type\n failure: string[]; // Array merged objective ids which are of failure type\n pending: string[]; // Array merged objective ids which are of pending type\n}\n\nexport interface SHARED_PREF_SCAN_OUTPUT_INTERFACE {\n [prefixedMergedObjectiveId: string]: ScannerOutput;\n}\n\nexport interface TabRecord {\n [SummaryPageTabs.ALL]: number;\n [SummaryPageTabs.PENDING]: number;\n [SummaryPageTabs.DELIVERED]: number;\n [SummaryPageTabs.UNDELIVERED]: number;\n}\n"],"mappings":";;;;;;IAIYA,gBAAgB,GAAAC,OAAA,CAAAD,gBAAA,0BAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAA,OAAhBA,gBAAgB;AAAA;AAAA,IAehBE,WAAW,GAAAD,OAAA,CAAAC,WAAA,0BAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAA,OAAXA,WAAW;AAAA;AAAA,IA+BXC,cAAc,GAAAF,OAAA,CAAAE,cAAA,0BAAdA,cAAc;EAAdA,cAAc;EAAdA,cAAc;EAAA,OAAdA,cAAc;AAAA;AAAA,IAKdC,eAAe,GAAAH,OAAA,CAAAG,eAAA,0BAAfA,eAAe;EAAfA,eAAe;EAAfA,eAAe;EAAfA,eAAe;EAAfA,eAAe;EAAA,OAAfA,eAAe;AAAA"}
1
+ {"version":3,"names":["ExpoBarcodeTypes","exports","SCAN_STATUS","PROCEED_STATUS","SummaryPageTabs"],"sources":["interfaces.ts"],"sourcesContent":["import { SnackBarType } from 'src/components/widgets/SnackBarCustom';\nimport { ScannerOutput } from './ScanSchema';\nimport { IDispatchExecutor } from '@os1-platform/platform-coreos-execution-engine-sdk';\n\nexport enum ExpoBarcodeTypes {\n QRCODE = 'QRCODE',\n aztec = 'aztec',\n codabar = 'codabar',\n code39 = 'code39',\n code93 = 'code93',\n code128 = 'code128',\n datamatrix = 'datamatrix',\n ean13 = 'ean13',\n ean8 = 'ean8',\n itf14 = 'itf14',\n pdf417 = 'pdf417',\n upc_e = 'upc_e',\n}\n\nexport enum SCAN_STATUS {\n SCANNED,\n FAILED,\n}\n\nexport interface ScannedItemData {\n value: string; // Value of scanned item\n validated?: boolean; // Boolean to denote if scan was validate successfully\n timestamp?: number; // Epoch timestamp for the scan\n reasonCode?: string;\n reasonText?: string;\n success?: boolean;\n scanStatus: SCAN_STATUS;\n}\n\nexport interface MergedScan {\n value: string;\n mergedObjectiveId?: string;\n validated?: boolean;\n timestamp?: number;\n scanStatus?: SCAN_STATUS;\n eventCode?: string;\n reasonCode?: string;\n success?: boolean;\n}\n\nexport interface BlindScan {\n maxCount: number;\n scannedCount: number;\n}\n\nexport enum PROCEED_STATUS {\n DELIVER_NOW = 'DELIVER_NOW',\n DELIVER_LATER = 'DELIVER_LATER',\n}\n\nexport enum SummaryPageTabs {\n ALL = 'All',\n PENDING = 'Pending',\n DELIVERED = 'Delivered',\n UNDELIVERED = 'Undelivered',\n}\n\nexport interface DisplaySummary {\n scanId: string;\n eventCode: string;\n reasonCode: string;\n clientName?: string;\n orderId?: string;\n prefixedMergedObjectiveId: string;\n lastStatus: IDispatchExecutor.ExecutionStatus;\n eCode?: string;\n rCode?: string;\n}\n\nexport type ListItem = DisplaySummary & {\n index: number;\n};\n\nexport interface SummaryDisplayData {\n data: DisplaySummary[];\n totalCount: number;\n}\n\nexport interface ADD_SCAN {\n status: boolean;\n message: string;\n type: SnackBarType;\n exit?: boolean;\n data?: any;\n}\n\nexport interface SCAN_MERGED_OBJ_ID_INTEFACE {\n [prefixedMergedObjectiveId: string]: SCANNED_RECORD;\n}\n\nexport interface SCANNED_RECORD {\n success: string[]; // Array merged objective ids which are of success type\n failure: string[]; // Array merged objective ids which are of failure type\n pending: string[]; // Array merged objective ids which are of pending type\n}\n\nexport interface SHARED_PREF_SCAN_OUTPUT_INTERFACE {\n [prefixedMergedObjectiveId: string]: ScannerOutput;\n}\n\nexport interface TabRecord {\n [SummaryPageTabs.ALL]: number;\n [SummaryPageTabs.PENDING]: number;\n [SummaryPageTabs.DELIVERED]: number;\n [SummaryPageTabs.UNDELIVERED]: number;\n}\n"],"mappings":";;;;;;IAIYA,gBAAgB,GAAAC,OAAA,CAAAD,gBAAA,0BAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAhBA,gBAAgB;EAAA,OAAhBA,gBAAgB;AAAA;AAAA,IAehBE,WAAW,GAAAD,OAAA,CAAAC,WAAA,0BAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAXA,WAAW,CAAXA,WAAW;EAAA,OAAXA,WAAW;AAAA;AAAA,IA+BXC,cAAc,GAAAF,OAAA,CAAAE,cAAA,0BAAdA,cAAc;EAAdA,cAAc;EAAdA,cAAc;EAAA,OAAdA,cAAc;AAAA;AAAA,IAKdC,eAAe,GAAAH,OAAA,CAAAG,eAAA,0BAAfA,eAAe;EAAfA,eAAe;EAAfA,eAAe;EAAfA,eAAe;EAAfA,eAAe;EAAA,OAAfA,eAAe;AAAA"}
@@ -61,22 +61,34 @@ const SummaryPage = props => {
61
61
  // START: Modal Handling for Summary Page
62
62
 
63
63
  const [showUnscannedShipmentModal, setShowUnscannedShipmentModal] = (0, _react.useState)(false);
64
- const [showERCModal, setShowERCModal] = (0, _react.useState)(false);
65
64
  const [showRemoveShipmentModal, setShowRemoveShipmentModal] = (0, _react.useState)(false);
65
+
66
+ //states for ERC Selectors
67
+ const [showEditModal, setShowEditModal] = (0, _react.useState)(false);
68
+ const [showERCModal, setShowERCModal] = (0, _react.useState)(false);
66
69
  const [selectedEventCode, setSelectedEventCode] = (0, _react.useState)();
67
70
  const [selectedReason, setSelectedReason] = (0, _react.useState)(); // reason code from ercSelector
68
71
  const [reasonItems, setReasonItems] = (0, _react.useState)(); // list of reason codes
72
+ const [editedEventItems, setEditedEventItems] = (0, _react.useState)(); // list of reason codes
69
73
  const [editedReasonItems, setEditedReasonItems] = (0, _react.useState)(); // list of reason codes
74
+ const [editedEventCode, setEditedEventCode] = (0, _react.useState)();
75
+ const [editedReason, setEditedReason] = (0, _react.useState)(); // reason code from ercSelector
76
+
70
77
  let {
71
78
  scannedCount,
72
79
  totalCount
73
80
  } = props.shipmentCount;
81
+
82
+ // effect for even code selector
74
83
  (0, _react.useEffect)(() => {
75
84
  props.ercSelector && (async () => {
76
85
  setSelectedEventCode(props.eventCodeItems[0]);
77
86
  setEditedEventCode(props.eventCodeItems[0]);
87
+ setEditedEventItems(props.eventCodeItems);
78
88
  })();
79
89
  }, [props.eventCodeItems]);
90
+
91
+ //effect for reason code selector
80
92
  (0, _react.useEffect)(() => {
81
93
  (selectedEventCode === null || selectedEventCode === void 0 ? void 0 : selectedEventCode.code) && (async () => {
82
94
  let response = await (0, _DropDownUtils.getErcDropDownItems)('REASON', props.ercSelector || [], selectedEventCode === null || selectedEventCode === void 0 ? void 0 : selectedEventCode.code);
@@ -89,6 +101,22 @@ const SummaryPage = props => {
89
101
  }
90
102
  })();
91
103
  }, [selectedEventCode === null || selectedEventCode === void 0 ? void 0 : selectedEventCode.code]);
104
+ (0, _react.useEffect)(() => {
105
+ (editedEventCode === null || editedEventCode === void 0 ? void 0 : editedEventCode.code) && (async () => {
106
+ let response = await (0, _DropDownUtils.getErcDropDownItems)('REASON', props.ercSelector || [], editedEventCode === null || editedEventCode === void 0 ? void 0 : editedEventCode.code);
107
+ if (response.length) {
108
+ // setReasonItems(response);
109
+ setEditedReasonItems(response);
110
+ setEditedReason(response[0]);
111
+ } else {
112
+ // setReasonItems([]);
113
+ setEditedReasonItems([]);
114
+ setEditedReason(undefined);
115
+ }
116
+ })();
117
+ }, [editedEventCode === null || editedEventCode === void 0 ? void 0 : editedEventCode.code]);
118
+
119
+ //Proceed button for ET next flow
92
120
  const renderActionButtons = () => {
93
121
  return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
94
122
  style: {
@@ -130,10 +158,7 @@ const SummaryPage = props => {
130
158
  const [scanList, setScanList] = (0, _react.useState)([]);
131
159
  const [isLoading, setIsLoading] = (0, _react.useState)(false);
132
160
  const [isLoadingMore, setIsLoadingMore] = (0, _react.useState)(false);
133
- const [showEditModal, setShowEditModal] = (0, _react.useState)(false);
134
161
  const [selectedEditItem, setSelectedEditItem] = (0, _react.useState)();
135
- const [editedEventCode, setEditedEventCode] = (0, _react.useState)();
136
- const [editedReason, setEditedReason] = (0, _react.useState)(); // reason code from ercSelector
137
162
  const [selectedItems, setSelectedItems] = (0, _react.useState)({});
138
163
  const [searchText, setSearchText] = (0, _react.useState)('');
139
164
  const [searchQuery, setSearchQuery] = _react.default.useState('');
@@ -192,6 +217,8 @@ const SummaryPage = props => {
192
217
  props.scanProps.showProgress(false);
193
218
  }
194
219
  };
220
+
221
+ //effect for all the tabs and their counts
195
222
  (0, _react.useEffect)(() => {
196
223
  (async () => {
197
224
  const count = await (0, _utils.getTabCount)(props.scanProps);
@@ -220,20 +247,6 @@ const SummaryPage = props => {
220
247
  if (isRemoved) setIsRemoved(false);
221
248
  })();
222
249
  }, [isRemoved, activeTab, searchQuery]);
223
- (0, _react.useEffect)(() => {
224
- (editedEventCode === null || editedEventCode === void 0 ? void 0 : editedEventCode.code) && (async () => {
225
- let response = await (0, _DropDownUtils.getErcDropDownItems)('REASON', props.ercSelector || [], editedEventCode === null || editedEventCode === void 0 ? void 0 : editedEventCode.code);
226
- if (response.length) {
227
- // setReasonItems(response);
228
- setEditedReasonItems(response);
229
- setEditedReason(response[0]);
230
- } else {
231
- // setReasonItems([]);
232
- setEditedReasonItems([]);
233
- setEditedReason(undefined);
234
- }
235
- })();
236
- }, [editedEventCode === null || editedEventCode === void 0 ? void 0 : editedEventCode.code]);
237
250
 
238
251
  // Triggered when the user reaches the end of the list
239
252
  const onEndReached = async () => {
@@ -262,12 +275,14 @@ const SummaryPage = props => {
262
275
  }
263
276
  }, /*#__PURE__*/_react.default.createElement(_reactNative.View, {
264
277
  style: {
265
- marginBottom: 16
278
+ marginBottom: 16,
279
+ zIndex: 10000
266
280
  }
267
281
  }, /*#__PURE__*/_react.default.createElement(_ERDropDown.default, {
268
282
  title: 'Event',
269
283
  style: {
270
- height: 50
284
+ height: 50,
285
+ zIndex: 10000
271
286
  },
272
287
  selectedReason: editedEventCode,
273
288
  items: props.eventCodeItems,
@@ -276,12 +291,14 @@ const SummaryPage = props => {
276
291
  }
277
292
  })), /*#__PURE__*/_react.default.createElement(_reactNative.View, {
278
293
  style: {
279
- marginVertical: 20
294
+ marginVertical: 20,
295
+ zIndex: -1
280
296
  }
281
297
  }, /*#__PURE__*/_react.default.createElement(_ERDropDown.default, {
282
298
  title: 'Reason',
283
299
  style: {
284
- height: 50
300
+ height: 50,
301
+ zIndex: -1
285
302
  },
286
303
  selectedReason: editedReason,
287
304
  disabled: !editedReasonItems || !(editedReasonItems !== null && editedReasonItems !== void 0 && editedReasonItems.length) ? true : false,
@@ -340,7 +357,9 @@ const SummaryPage = props => {
340
357
  eventCode: editedEventCode.text,
341
358
  reasonCode: (editedReason === null || editedReason === void 0 ? void 0 : editedReason.text) || '--',
342
359
  prefixedMergedObjectiveId: scan.prefixedMergedObjectiveId,
343
- lastStatus: scan.lastStatus
360
+ lastStatus: scan.lastStatus,
361
+ eCode: editedEventCode.code,
362
+ rCode: (editedReason === null || editedReason === void 0 ? void 0 : editedReason.code) || '--'
344
363
  };
345
364
  setDataProvider(dataProvider => {
346
365
  if (dataProvider) return dataProvider.cloneWithRows(updatedScanList);else return dataProvider;
@@ -556,12 +575,14 @@ const SummaryPage = props => {
556
575
  }
557
576
  }, /*#__PURE__*/_react.default.createElement(_reactNative.View, {
558
577
  style: {
559
- marginBottom: 16
578
+ marginBottom: 16,
579
+ zIndex: 10000
560
580
  }
561
581
  }, /*#__PURE__*/_react.default.createElement(_ERDropDown.default, {
562
582
  title: 'Event',
563
583
  style: {
564
- height: 50
584
+ height: 50,
585
+ zIndex: 10000
565
586
  },
566
587
  selectedReason: selectedEventCode,
567
588
  items: (0, _utils.filterERCItems)(props.eventCodeItems, 'FAILURE'),
@@ -570,12 +591,14 @@ const SummaryPage = props => {
570
591
  }
571
592
  })), /*#__PURE__*/_react.default.createElement(_reactNative.View, {
572
593
  style: {
573
- marginVertical: 20
594
+ marginVertical: 20,
595
+ zIndex: -1
574
596
  }
575
597
  }, /*#__PURE__*/_react.default.createElement(_ERDropDown.default, {
576
598
  title: 'Reason',
577
599
  style: {
578
- height: 50
600
+ height: 50,
601
+ zIndex: -1
579
602
  },
580
603
  selectedReason: selectedReason,
581
604
  disabled: !reasonItems || !(reasonItems !== null && reasonItems !== void 0 && reasonItems.length) ? true : false,
@@ -779,6 +802,22 @@ const SummaryPage = props => {
779
802
  });
780
803
  } else {
781
804
  setSelectedItems({});
805
+ if (editedEventItems && scan.eCode && scan.eventCode) {
806
+ let eventErc = {
807
+ code: scan.eCode,
808
+ text: scan.eventCode,
809
+ success: (0, _utils.getEventType)(editedEventItems, scan.eCode)
810
+ };
811
+ setEditedEventCode(eventErc);
812
+ if (editedReasonItems && scan.rCode && scan.reasonCode) {
813
+ let resonErc = {
814
+ code: scan.rCode,
815
+ text: scan.reasonCode,
816
+ success: (0, _utils.getEventType)(editedReasonItems, scan.rCode)
817
+ };
818
+ setEditedReason(resonErc);
819
+ }
820
+ }
782
821
  setShowEditModal(true);
783
822
  setSelectedEditItem({
784
823
  ...props,