@os1-platform/dispatch-mobile 2.1.8 → 2.1.10
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.
- package/lib/commonjs/analytics/sentry/SentryAnalyticsSingleton.js +0 -2
- package/lib/commonjs/analytics/sentry/SentryAnalyticsSingleton.js.map +1 -1
- package/lib/commonjs/analytics/sentry/SentryAnalyticsUtils.js +0 -6
- package/lib/commonjs/analytics/sentry/SentryAnalyticsUtils.js.map +1 -1
- package/lib/commonjs/analytics/sentry/SentrySdkConstants.js +2 -0
- package/lib/commonjs/analytics/sentry/SentrySdkConstants.js.map +1 -1
- package/lib/commonjs/components/executiontasks/imageCapture/ImageCapture.js +1 -1
- package/lib/commonjs/components/executiontasks/imageCapture/ImageCapture.js.map +1 -1
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/manager/sdk/DispatchSDKManager.js +5 -4
- package/lib/commonjs/manager/sdk/DispatchSDKManager.js.map +1 -1
- package/lib/commonjs/manager/sdk/callbacksHandler.js +28 -1
- package/lib/commonjs/manager/sdk/callbacksHandler.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/AppSyncManager.js +7 -5
- package/lib/commonjs/manager/syncmanager/AppSyncManager.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/DBConfig.js +3 -1
- package/lib/commonjs/manager/syncmanager/DBConfig.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/constants.js +4 -1
- package/lib/commonjs/manager/syncmanager/constants.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/document/DocumentHttpClient.js +37 -20
- package/lib/commonjs/manager/syncmanager/document/DocumentHttpClient.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/document/DocumentManager.js +26 -4
- package/lib/commonjs/manager/syncmanager/document/DocumentManager.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/document/DocumentSyncManager.js +276 -20
- package/lib/commonjs/manager/syncmanager/document/DocumentSyncManager.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/events/ETEventsManager.js +41 -13
- package/lib/commonjs/manager/syncmanager/events/ETEventsManager.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/events/EventsSyncManager.js +116 -59
- package/lib/commonjs/manager/syncmanager/events/EventsSyncManager.js.map +1 -1
- package/lib/commonjs/manager/syncmanager/events/SyncHttpClient.js +17 -0
- package/lib/commonjs/manager/syncmanager/events/SyncHttpClient.js.map +1 -1
- package/lib/commonjs/models/auth.js.map +1 -1
- package/lib/commonjs/models/sdk.js.map +1 -1
- package/lib/commonjs/network/NetworkClient.js +12 -2
- package/lib/commonjs/network/NetworkClient.js.map +1 -1
- package/lib/commonjs/network/NetworkUtils.js +14 -7
- package/lib/commonjs/network/NetworkUtils.js.map +1 -1
- package/lib/commonjs/network/client.js +1 -1
- package/lib/commonjs/network/client.js.map +1 -1
- package/lib/commonjs/ui/screens/DeliverScreen.js.map +1 -1
- package/lib/commonjs/ui/screens/FormsScreen.js.map +1 -1
- package/lib/commonjs/utils/SyncManagerUtils.js +29 -2
- package/lib/commonjs/utils/SyncManagerUtils.js.map +1 -1
- package/lib/commonjs/utils/storage.js +21 -5
- package/lib/commonjs/utils/storage.js.map +1 -1
- package/lib/commonjs/utils/utils.js +0 -9
- package/lib/commonjs/utils/utils.js.map +1 -1
- package/lib/module/analytics/sentry/SentryAnalyticsSingleton.js +0 -2
- package/lib/module/analytics/sentry/SentryAnalyticsSingleton.js.map +1 -1
- package/lib/module/analytics/sentry/SentryAnalyticsUtils.js +0 -6
- package/lib/module/analytics/sentry/SentryAnalyticsUtils.js.map +1 -1
- package/lib/module/analytics/sentry/SentrySdkConstants.js +2 -0
- package/lib/module/analytics/sentry/SentrySdkConstants.js.map +1 -1
- package/lib/module/components/executiontasks/imageCapture/ImageCapture.js +1 -1
- package/lib/module/components/executiontasks/imageCapture/ImageCapture.js.map +1 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/manager/sdk/DispatchSDKManager.js +5 -4
- package/lib/module/manager/sdk/DispatchSDKManager.js.map +1 -1
- package/lib/module/manager/sdk/callbacksHandler.js +27 -1
- package/lib/module/manager/sdk/callbacksHandler.js.map +1 -1
- package/lib/module/manager/syncmanager/AppSyncManager.js +7 -5
- package/lib/module/manager/syncmanager/AppSyncManager.js.map +1 -1
- package/lib/module/manager/syncmanager/DBConfig.js +3 -1
- package/lib/module/manager/syncmanager/DBConfig.js.map +1 -1
- package/lib/module/manager/syncmanager/constants.js +3 -0
- package/lib/module/manager/syncmanager/constants.js.map +1 -1
- package/lib/module/manager/syncmanager/document/DocumentHttpClient.js +38 -21
- package/lib/module/manager/syncmanager/document/DocumentHttpClient.js.map +1 -1
- package/lib/module/manager/syncmanager/document/DocumentManager.js +26 -4
- package/lib/module/manager/syncmanager/document/DocumentManager.js.map +1 -1
- package/lib/module/manager/syncmanager/document/DocumentSyncManager.js +276 -20
- package/lib/module/manager/syncmanager/document/DocumentSyncManager.js.map +1 -1
- package/lib/module/manager/syncmanager/events/ETEventsManager.js +42 -14
- package/lib/module/manager/syncmanager/events/ETEventsManager.js.map +1 -1
- package/lib/module/manager/syncmanager/events/EventsSyncManager.js +119 -61
- package/lib/module/manager/syncmanager/events/EventsSyncManager.js.map +1 -1
- package/lib/module/manager/syncmanager/events/SyncHttpClient.js +15 -0
- package/lib/module/manager/syncmanager/events/SyncHttpClient.js.map +1 -1
- package/lib/module/models/auth.js.map +1 -1
- package/lib/module/models/sdk.js.map +1 -1
- package/lib/module/network/NetworkClient.js +12 -2
- package/lib/module/network/NetworkClient.js.map +1 -1
- package/lib/module/network/NetworkUtils.js +14 -7
- package/lib/module/network/NetworkUtils.js.map +1 -1
- package/lib/module/network/client.js +1 -1
- package/lib/module/network/client.js.map +1 -1
- package/lib/module/ui/screens/DeliverScreen.js.map +1 -1
- package/lib/module/ui/screens/FormsScreen.js.map +1 -1
- package/lib/module/utils/SyncManagerUtils.js +30 -3
- package/lib/module/utils/SyncManagerUtils.js.map +1 -1
- package/lib/module/utils/storage.js +21 -5
- package/lib/module/utils/storage.js.map +1 -1
- package/lib/module/utils/utils.js +0 -9
- package/lib/module/utils/utils.js.map +1 -1
- package/lib/typescript/analytics/sentry/SentrySdkConstants.d.ts +2 -0
- package/lib/typescript/manager/sdk/callbacksHandler.d.ts +3 -1
- package/lib/typescript/manager/syncmanager/DBConfig.d.ts +4 -0
- package/lib/typescript/manager/syncmanager/constants.d.ts +3 -0
- package/lib/typescript/manager/syncmanager/document/DocumentManager.d.ts +2 -0
- package/lib/typescript/manager/syncmanager/document/DocumentSyncManager.d.ts +2 -1
- package/lib/typescript/manager/syncmanager/events/ETEventsManager.d.ts +2 -0
- package/lib/typescript/manager/syncmanager/events/EventsSyncManager.d.ts +1 -1
- package/lib/typescript/models/sdk.d.ts +1 -0
- package/lib/typescript/utils/storage.d.ts +3 -3
- package/package.json +5 -5
- package/src/analytics/sentry/SentryAnalyticsSingleton.ts +7 -9
- package/src/analytics/sentry/SentryAnalyticsUtils.ts +24 -36
- package/src/analytics/sentry/SentrySdkConstants.ts +2 -0
- package/src/components/executiontasks/imageCapture/ImageCapture.tsx +1 -3
- package/src/index.tsx +1 -1
- package/src/manager/sdk/DispatchSDKManager.ts +8 -3
- package/src/manager/sdk/callbacksHandler.ts +39 -2
- package/src/manager/syncmanager/AppSyncManager.ts +15 -13
- package/src/manager/syncmanager/DBConfig.ts +4 -0
- package/src/manager/syncmanager/constants.ts +3 -0
- package/src/manager/syncmanager/document/DocumentHttpClient.ts +54 -24
- package/src/manager/syncmanager/document/DocumentManager.ts +48 -7
- package/src/manager/syncmanager/document/DocumentSyncManager.ts +351 -30
- package/src/manager/syncmanager/events/ETEventsManager.ts +50 -16
- package/src/manager/syncmanager/events/EventsSyncManager.ts +157 -74
- package/src/manager/syncmanager/events/SyncHttpClient.ts +30 -1
- package/src/models/auth.ts +1 -0
- package/src/models/sdk.ts +1 -0
- package/src/network/NetworkClient.ts +18 -2
- package/src/network/NetworkUtils.ts +9 -1
- package/src/network/client.ts +1 -1
- package/src/ui/screens/DeliverScreen.tsx +6 -5
- package/src/ui/screens/FormsScreen.tsx +8 -6
- package/src/utils/SyncManagerUtils.ts +41 -6
- package/src/utils/storage.ts +21 -8
- package/src/utils/utils.ts +0 -8
|
@@ -9,8 +9,12 @@ import { BaseError } from '../../../errors/BaseError';
|
|
|
9
9
|
import BaseErrorCodes, { InvalidArgumentsError, InvalidBaseURL, SyncManagerNotInitialized } from '../../../errors/ErrorCodes';
|
|
10
10
|
import Logger, { LOG_TYPE } from '../../../utils/Logger';
|
|
11
11
|
import NetworkUtil from '../../../utils/NetworkUtil';
|
|
12
|
+
import ETEventsManager from '../events/ETEventsManager';
|
|
13
|
+
import { LAST_SYNCED_EVENT_ID, MAX_RETRY_COUNT, POD_DOC } from '../../syncmanager/constants';
|
|
14
|
+
import EventsSyncManager from '../events/EventsSyncManager';
|
|
12
15
|
import Marker, { Position, TextBackgroundType, ImageFormat } from 'react-native-image-marker';
|
|
13
16
|
import RNFS from 'react-native-fs';
|
|
17
|
+
import Storage from '../../../utils/storage';
|
|
14
18
|
import { Platform } from 'react-native';
|
|
15
19
|
import { SentryEventNameSdkConstants, SeverityLevelValue } from '../../../analytics/sentry/SentrySdkConstants';
|
|
16
20
|
import { fireEventWithScreenName } from '../../../analytics/sentry/SentryAnalyticsUtils';
|
|
@@ -26,7 +30,7 @@ export default class DocumentSyncManager {
|
|
|
26
30
|
_defineProperty(this, "documentHttpClient", void 0);
|
|
27
31
|
_defineProperty(this, "inProgress", false);
|
|
28
32
|
_defineProperty(this, "docManager", void 0);
|
|
29
|
-
_defineProperty(this, "maxRetryCount",
|
|
33
|
+
_defineProperty(this, "maxRetryCount", MAX_RETRY_COUNT);
|
|
30
34
|
_defineProperty(this, "_retries", 0);
|
|
31
35
|
}
|
|
32
36
|
init(baseURL, retryCount) {
|
|
@@ -54,19 +58,78 @@ export default class DocumentSyncManager {
|
|
|
54
58
|
if ((documentRows === null || documentRows === void 0 ? void 0 : documentRows.length) > 0) {
|
|
55
59
|
await this.uploadDocToServer(documentRows[0]);
|
|
56
60
|
} else {
|
|
57
|
-
|
|
61
|
+
let cta = 'startDocumentSync-NoData';
|
|
62
|
+
fireEventWithScreenName({
|
|
63
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
64
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
65
|
+
screenName: cta,
|
|
66
|
+
cta: cta,
|
|
67
|
+
extraParams: {
|
|
68
|
+
msg: 'No data to sync'
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
Logger.getInstance().logEvent(cta, 'No data to sync', LOG_TYPE.SDK_ERROR);
|
|
58
72
|
}
|
|
59
73
|
} else {
|
|
60
|
-
|
|
74
|
+
let cta = 'startDocumentSync-NoNetwork';
|
|
75
|
+
fireEventWithScreenName({
|
|
76
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
77
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
78
|
+
screenName: cta,
|
|
79
|
+
cta: cta,
|
|
80
|
+
extraParams: {
|
|
81
|
+
msg: 'No Network'
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
Logger.getInstance().logEvent(cta, 'No Network', LOG_TYPE.SDK_ERROR);
|
|
61
85
|
}
|
|
62
|
-
} catch (error) {
|
|
86
|
+
} catch (error) {
|
|
87
|
+
let cta = 'startDocumentSync-error';
|
|
88
|
+
fireEventWithScreenName({
|
|
89
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
90
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
91
|
+
screenName: cta,
|
|
92
|
+
cta: cta,
|
|
93
|
+
extraParams: {
|
|
94
|
+
msg: flattenObject(error)
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
Logger.getInstance().logEvent(cta, flattenObject(error), LOG_TYPE.SDK_ERROR);
|
|
98
|
+
} finally {
|
|
63
99
|
this.inProgress = false;
|
|
64
|
-
|
|
100
|
+
let syncPending = await this.isSyncPending();
|
|
101
|
+
if (syncPending && hasNetwork) {
|
|
65
102
|
await this.startDocumentSync();
|
|
103
|
+
} else {
|
|
104
|
+
let cta = 'startDocumentSync-error';
|
|
105
|
+
let extraParameters = {
|
|
106
|
+
hasNetwork: hasNetwork,
|
|
107
|
+
pending: syncPending
|
|
108
|
+
};
|
|
109
|
+
fireEventWithScreenName({
|
|
110
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
111
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
112
|
+
screenName: cta,
|
|
113
|
+
cta: cta,
|
|
114
|
+
extraParams: {
|
|
115
|
+
msg: flattenObject(extraParameters)
|
|
116
|
+
}
|
|
117
|
+
});
|
|
118
|
+
Logger.getInstance().logEvent(cta, flattenObject(extraParameters), LOG_TYPE.SDK_ERROR);
|
|
66
119
|
}
|
|
67
120
|
}
|
|
68
121
|
} else {
|
|
69
|
-
|
|
122
|
+
let cta = 'startDocumentSync';
|
|
123
|
+
fireEventWithScreenName({
|
|
124
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
125
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
126
|
+
screenName: cta,
|
|
127
|
+
cta: cta,
|
|
128
|
+
extraParams: {
|
|
129
|
+
msg: 'sync already in progress or max count reached'
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
Logger.getInstance().logEvent(cta, 'sync already in progress or max count reached', LOG_TYPE.SDK_ERROR);
|
|
70
133
|
}
|
|
71
134
|
}
|
|
72
135
|
async isSyncPending() {
|
|
@@ -85,7 +148,17 @@ export default class DocumentSyncManager {
|
|
|
85
148
|
isEmptyOrBlank(fileType) || isEmptyOrBlank(fileName) || base64 && isEmptyOrBlank(data) || !base64 && isEmptyOrBlank(filePath)) throw new BaseError(BaseErrorCodes.InvalidArgumentError, InvalidArgumentsError);else {
|
|
86
149
|
var _this$docManager;
|
|
87
150
|
if (!this.docManager) {
|
|
88
|
-
|
|
151
|
+
let cta = 'insertDocument';
|
|
152
|
+
fireEventWithScreenName({
|
|
153
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
154
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
155
|
+
screenName: cta,
|
|
156
|
+
cta: cta,
|
|
157
|
+
extraParams: {
|
|
158
|
+
msg: 'INIT DOC SYNC AGAIN'
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
Logger.getInstance().logEvent(cta, 'INIT DOC SYNC AGAIN', LOG_TYPE.SDK_ERROR);
|
|
89
162
|
this.docManager = await DocumentManager.getInstance();
|
|
90
163
|
}
|
|
91
164
|
console.log('insertDocument1:', fmsFolderID);
|
|
@@ -101,12 +174,56 @@ export default class DocumentSyncManager {
|
|
|
101
174
|
this._retries = 0;
|
|
102
175
|
await this.startDocumentSync();
|
|
103
176
|
}
|
|
104
|
-
|
|
177
|
+
|
|
178
|
+
// private async updateDocument(documentRow: DocumentRow, fmsID: string) {
|
|
179
|
+
// if (!this.docManager) this.docManager = await DocumentManager.getInstance();
|
|
180
|
+
// try {
|
|
181
|
+
// await this.docManager.markDocumentSynced(documentRow.id, fmsID);
|
|
182
|
+
// let eventsManager = await ETEventsManager.getInstance();
|
|
183
|
+
// let podId = POD_DOC + '_' + documentRow.id;
|
|
184
|
+
// await eventsManager.markPODDocEventSynced(1, 1, podId);
|
|
185
|
+
// EventsSyncManager.getInstance().startSync();
|
|
186
|
+
// } catch (err: any) {
|
|
187
|
+
// Logger.getInstance().logEvent(
|
|
188
|
+
// 'updateDocument',
|
|
189
|
+
// err.message,
|
|
190
|
+
// LOG_TYPE.SDK_WARNING
|
|
191
|
+
// );
|
|
192
|
+
// }
|
|
193
|
+
// }
|
|
194
|
+
|
|
195
|
+
// This function will update document row with attempt count and sync status
|
|
196
|
+
async updateDocumentWithAttempt(documentRow, fmsID, attempt, sync) {
|
|
105
197
|
if (!this.docManager) this.docManager = await DocumentManager.getInstance();
|
|
106
198
|
try {
|
|
107
|
-
|
|
199
|
+
// Calling document row update method for attempt count and sync.
|
|
200
|
+
await this.docManager.markDocumentSyncedWithAttempt(documentRow.id, fmsID, attempt, sync);
|
|
201
|
+
let eventsManager = await ETEventsManager.getInstance();
|
|
202
|
+
let podId = POD_DOC + '_' + documentRow.id;
|
|
203
|
+
let extraParameters = {
|
|
204
|
+
podId: podId
|
|
205
|
+
};
|
|
206
|
+
Logger.getInstance().logEvent('updateDocumentWithAttempt-success', flattenObject(extraParameters), LOG_TYPE.SDK_ERROR);
|
|
207
|
+
// Calling update method for attempt count and sync to update event row of type POD_DOC
|
|
208
|
+
await eventsManager.markPODDocEventSynced(sync, attempt, podId);
|
|
209
|
+
if (sync == 1) {
|
|
210
|
+
const lastSyncedEventId = await Storage.getInstance().getSharedItem(LAST_SYNCED_EVENT_ID);
|
|
211
|
+
const syncEventId = parseInt(lastSyncedEventId) + 1;
|
|
212
|
+
await Storage.getInstance().setSharedItem(LAST_SYNCED_EVENT_ID, `${syncEventId}`);
|
|
213
|
+
}
|
|
214
|
+
EventsSyncManager.getInstance().startSync();
|
|
108
215
|
} catch (err) {
|
|
109
|
-
|
|
216
|
+
let cta = 'updateDocumentWithAttempt';
|
|
217
|
+
fireEventWithScreenName({
|
|
218
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
219
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
220
|
+
screenName: cta,
|
|
221
|
+
cta: cta,
|
|
222
|
+
extraParams: {
|
|
223
|
+
msg: flattenObject(err)
|
|
224
|
+
}
|
|
225
|
+
});
|
|
226
|
+
Logger.getInstance().logEvent(cta, flattenObject(err), LOG_TYPE.SDK_WARNING);
|
|
110
227
|
}
|
|
111
228
|
}
|
|
112
229
|
|
|
@@ -116,7 +233,17 @@ export default class DocumentSyncManager {
|
|
|
116
233
|
try {
|
|
117
234
|
await this.docManager.updateProcesedFilePath(documentRow.id, origialFilePath, processedPath);
|
|
118
235
|
} catch (err) {
|
|
119
|
-
|
|
236
|
+
let cta = 'updateDocument-updateDocumentProcessedPath';
|
|
237
|
+
fireEventWithScreenName({
|
|
238
|
+
severityLevel: SeverityLevelValue.ERROR,
|
|
239
|
+
eventName: SentryEventNameSdkConstants.APP_ERROR,
|
|
240
|
+
screenName: cta,
|
|
241
|
+
cta: cta,
|
|
242
|
+
extraParams: {
|
|
243
|
+
msg: flattenObject(err)
|
|
244
|
+
}
|
|
245
|
+
});
|
|
246
|
+
Logger.getInstance().logEvent(cta, flattenObject(err), LOG_TYPE.SDK_WARNING);
|
|
120
247
|
}
|
|
121
248
|
}
|
|
122
249
|
async updateDocError(documentRow, uploadError) {
|
|
@@ -124,7 +251,17 @@ export default class DocumentSyncManager {
|
|
|
124
251
|
try {
|
|
125
252
|
await this.docManager.updateDocSyncError(documentRow.id, uploadError);
|
|
126
253
|
} catch (err) {
|
|
127
|
-
|
|
254
|
+
let cta = 'updateDocError';
|
|
255
|
+
fireEventWithScreenName({
|
|
256
|
+
severityLevel: SeverityLevelValue.ERROR,
|
|
257
|
+
eventName: SentryEventNameSdkConstants.APP_ERROR,
|
|
258
|
+
screenName: cta,
|
|
259
|
+
cta: cta,
|
|
260
|
+
extraParams: {
|
|
261
|
+
msg: flattenObject(err)
|
|
262
|
+
}
|
|
263
|
+
});
|
|
264
|
+
Logger.getInstance().logEvent(cta, flattenObject(err), LOG_TYPE.SDK_WARNING);
|
|
128
265
|
}
|
|
129
266
|
}
|
|
130
267
|
checkForInitialization() {
|
|
@@ -137,6 +274,21 @@ export default class DocumentSyncManager {
|
|
|
137
274
|
async processImageData(documentRow) {
|
|
138
275
|
// If processed_file_path of overlayed image already existing then do not generate it again.
|
|
139
276
|
if (documentRow.processed_file_path === null || documentRow.processed_file_path === '') {
|
|
277
|
+
let cta = 'processImageData-started';
|
|
278
|
+
let extra = {
|
|
279
|
+
msg: 'processImageData-started',
|
|
280
|
+
fName: documentRow.file_name && documentRow.file_name.length != 0 ? documentRow.file_name.substring(4) : '',
|
|
281
|
+
dName: documentRow.fms_folder_id && documentRow.fms_folder_id.length != 0 ? documentRow.fms_folder_id.substring(4) : '',
|
|
282
|
+
dispId: documentRow.dispatch_id && documentRow.dispatch_id.length != 0 ? documentRow.dispatch_id.substring(9) : ''
|
|
283
|
+
};
|
|
284
|
+
fireEventWithScreenName({
|
|
285
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
286
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
287
|
+
screenName: cta,
|
|
288
|
+
cta: cta,
|
|
289
|
+
extraParams: extra
|
|
290
|
+
});
|
|
291
|
+
Logger.getInstance().logEvent(cta, flattenObject(extra), LOG_TYPE.SDK_ERROR);
|
|
140
292
|
let pFilePath = 'processed_' + documentRow.file_name; // File name for processed file.
|
|
141
293
|
let strGeoStamp = documentRow.geo_timestamp; // Saved geostamp string
|
|
142
294
|
let objGeoStamp = JSON.parse(strGeoStamp); // Conversion to geostamp object
|
|
@@ -201,6 +353,21 @@ export default class DocumentSyncManager {
|
|
|
201
353
|
documentRow.processed_file_path = completeFilePath;
|
|
202
354
|
}
|
|
203
355
|
}
|
|
356
|
+
let cta = 'processImageData-completed';
|
|
357
|
+
let extra = {
|
|
358
|
+
msg: 'processImageData-completed',
|
|
359
|
+
fName: documentRow.file_name && documentRow.file_name.length != 0 ? documentRow.file_name.substring(4) : '',
|
|
360
|
+
dName: documentRow.fms_folder_id && documentRow.fms_folder_id.length != 0 ? documentRow.fms_folder_id.substring(4) : '',
|
|
361
|
+
dispId: documentRow.dispatch_id && documentRow.dispatch_id.length != 0 ? documentRow.dispatch_id.substring(9) : ''
|
|
362
|
+
};
|
|
363
|
+
fireEventWithScreenName({
|
|
364
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
365
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
366
|
+
screenName: cta,
|
|
367
|
+
cta: cta,
|
|
368
|
+
extraParams: extra
|
|
369
|
+
});
|
|
370
|
+
Logger.getInstance().logEvent(cta, flattenObject(extra), LOG_TYPE.SDK_ERROR);
|
|
204
371
|
return documentRow;
|
|
205
372
|
}
|
|
206
373
|
|
|
@@ -208,6 +375,21 @@ export default class DocumentSyncManager {
|
|
|
208
375
|
async processBase64Data(documentRow) {
|
|
209
376
|
// If base64 overlayed data already existing then do not generate it again.
|
|
210
377
|
if (documentRow.processed_file_path === null || documentRow.processed_file_path === '') {
|
|
378
|
+
let cta = 'processBase64Data-started';
|
|
379
|
+
let extra = {
|
|
380
|
+
msg: 'processBase64Data-started',
|
|
381
|
+
fName: documentRow.file_name && documentRow.file_name.length != 0 ? documentRow.file_name.substring(4) : '',
|
|
382
|
+
dName: documentRow.fms_folder_id && documentRow.fms_folder_id.length != 0 ? documentRow.fms_folder_id.substring(4) : '',
|
|
383
|
+
dispId: documentRow.dispatch_id && documentRow.dispatch_id.length != 0 ? documentRow.dispatch_id.substring(9) : ''
|
|
384
|
+
};
|
|
385
|
+
fireEventWithScreenName({
|
|
386
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
387
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
388
|
+
screenName: cta,
|
|
389
|
+
cta: cta,
|
|
390
|
+
extraParams: extra
|
|
391
|
+
});
|
|
392
|
+
Logger.getInstance().logEvent(cta, flattenObject(extra), LOG_TYPE.SDK_ERROR);
|
|
211
393
|
let filePath = '';
|
|
212
394
|
// If templrary base 64 file already exist then do not create again
|
|
213
395
|
if (documentRow.file_path === null || documentRow.file_path === '') {
|
|
@@ -275,6 +457,21 @@ export default class DocumentSyncManager {
|
|
|
275
457
|
documentRow.processed_file_path = splittedDase64Data[1];
|
|
276
458
|
}
|
|
277
459
|
}
|
|
460
|
+
let cta = 'processBase64Data-completed';
|
|
461
|
+
let extra = {
|
|
462
|
+
msg: 'processBase64Data-completed',
|
|
463
|
+
fName: documentRow.file_name && documentRow.file_name.length != 0 ? documentRow.file_name.substring(4) : '',
|
|
464
|
+
dName: documentRow.fms_folder_id && documentRow.fms_folder_id.length != 0 ? documentRow.fms_folder_id.substring(4) : '',
|
|
465
|
+
dispId: documentRow.dispatch_id && documentRow.dispatch_id.length != 0 ? documentRow.dispatch_id.substring(9) : ''
|
|
466
|
+
};
|
|
467
|
+
fireEventWithScreenName({
|
|
468
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
469
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
470
|
+
screenName: cta,
|
|
471
|
+
cta: cta,
|
|
472
|
+
extraParams: extra
|
|
473
|
+
});
|
|
474
|
+
Logger.getInstance().logEvent(cta, flattenObject(extra), LOG_TYPE.SDK_ERROR);
|
|
278
475
|
return documentRow;
|
|
279
476
|
}
|
|
280
477
|
|
|
@@ -289,25 +486,61 @@ export default class DocumentSyncManager {
|
|
|
289
486
|
async uploadDocToServer(documentRow) {
|
|
290
487
|
try {
|
|
291
488
|
var _this$documentHttpCli;
|
|
292
|
-
let docRow =
|
|
489
|
+
let docRow = documentRow;
|
|
490
|
+
let cta = 'uploadDocToServer-geoStamp';
|
|
491
|
+
let geoStampAvailable = false;
|
|
492
|
+
if (documentRow.geo_timestamp && documentRow.geo_timestamp.length != 0) {
|
|
493
|
+
geoStampAvailable = true;
|
|
494
|
+
docRow = await this.processPODData(documentRow);
|
|
495
|
+
}
|
|
496
|
+
let extra = {
|
|
497
|
+
msg: geoStampAvailable ? "geoStamp availale" : 'geoStamp not availale',
|
|
498
|
+
fName: docRow.file_name && docRow.file_name.length != 0 ? docRow.file_name.substring(4) : '',
|
|
499
|
+
dName: docRow.fms_folder_id && docRow.fms_folder_id.length != 0 ? docRow.fms_folder_id.substring(4) : '',
|
|
500
|
+
dispId: docRow.dispatch_id && docRow.dispatch_id.length != 0 ? docRow.dispatch_id.substring(9) : ''
|
|
501
|
+
};
|
|
502
|
+
fireEventWithScreenName({
|
|
503
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
504
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
505
|
+
screenName: cta,
|
|
506
|
+
cta: cta,
|
|
507
|
+
extraParams: extra
|
|
508
|
+
});
|
|
509
|
+
Logger.getInstance().logEvent(cta, flattenObject(extra), LOG_TYPE.SDK_ERROR);
|
|
293
510
|
console.log('uploadDocToServer999:', docRow);
|
|
294
|
-
let fmsID = await ((_this$documentHttpCli = this.documentHttpClient) === null || _this$documentHttpCli === void 0 ? void 0 : _this$documentHttpCli.uploadDocument(
|
|
511
|
+
let fmsID = await ((_this$documentHttpCli = this.documentHttpClient) === null || _this$documentHttpCli === void 0 ? void 0 : _this$documentHttpCli.uploadDocument(docRow));
|
|
295
512
|
let extraParameters = {
|
|
296
513
|
fmsID: fmsID ?? '',
|
|
297
|
-
|
|
298
|
-
|
|
514
|
+
fName: docRow.file_name && docRow.file_name.length != 0 ? docRow.file_name.substring(4) : '',
|
|
515
|
+
dName: docRow.fms_folder_id && docRow.fms_folder_id.length != 0 ? docRow.fms_folder_id.substring(4) : '',
|
|
516
|
+
dispId: docRow.dispatch_id && docRow.dispatch_id.length != 0 ? docRow.dispatch_id.substring(9) : ''
|
|
299
517
|
};
|
|
300
518
|
// TODO: SOLELY DEPENDS ON FMS_ID WHICH IS WRONG => IT SHOULD BE Response.status = 202
|
|
301
519
|
if (fmsID) {
|
|
520
|
+
// Calling function updating document row along with attempt count and sync as true.
|
|
521
|
+
await this.updateDocumentWithAttempt(documentRow, fmsID, this._retries + 1, 1);
|
|
302
522
|
this._retries = 0;
|
|
303
|
-
await this.updateDocument(docRow, fmsID);
|
|
523
|
+
// await this.updateDocument(docRow, fmsID);
|
|
304
524
|
} else {
|
|
525
|
+
// Calling function updating document row withalong attempt count and sync as false.
|
|
526
|
+
await this.updateDocumentWithAttempt(documentRow, '', this._retries + 1, 0);
|
|
305
527
|
this._retries++;
|
|
306
|
-
|
|
528
|
+
let cta = 'uploadDocToServer-empty-fms-id';
|
|
529
|
+
fireEventWithScreenName({
|
|
530
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
531
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
532
|
+
screenName: cta,
|
|
533
|
+
cta: cta,
|
|
534
|
+
extraParams: extraParameters
|
|
535
|
+
});
|
|
536
|
+
Logger.getInstance().logEvent(cta, flattenObject(extraParameters), LOG_TYPE.SDK_ERROR);
|
|
537
|
+
this.startSyncAfterMaxRetry(extraParameters, null);
|
|
307
538
|
await this.updateDocError(docRow, 'Unexpected Error');
|
|
308
539
|
}
|
|
309
540
|
} catch (error) {
|
|
310
541
|
var _error$response, _error$response2;
|
|
542
|
+
// Calling function updating document row withalong attempt count and sync as false.
|
|
543
|
+
await this.updateDocumentWithAttempt(documentRow, '', this._retries + 1, 0);
|
|
311
544
|
const cta = 'uploadDocToServer-error';
|
|
312
545
|
fireEventWithScreenName({
|
|
313
546
|
severityLevel: SeverityLevelValue.ERROR,
|
|
@@ -315,11 +548,12 @@ export default class DocumentSyncManager {
|
|
|
315
548
|
screenName: cta,
|
|
316
549
|
cta: cta,
|
|
317
550
|
extraParams: {
|
|
318
|
-
error: error
|
|
551
|
+
error: flattenObject(error)
|
|
319
552
|
}
|
|
320
553
|
});
|
|
554
|
+
Logger.getInstance().logEvent(cta, flattenObject(error), LOG_TYPE.SDK_ERROR);
|
|
321
555
|
this._retries++;
|
|
322
|
-
|
|
556
|
+
this.startSyncAfterMaxRetry(null, error);
|
|
323
557
|
await this.updateDocError(documentRow, JSON.stringify({
|
|
324
558
|
message: error.message,
|
|
325
559
|
error: JSON.stringify(error === null || error === void 0 || (_error$response = error.response) === null || _error$response === void 0 ? void 0 : _error$response.data),
|
|
@@ -327,6 +561,28 @@ export default class DocumentSyncManager {
|
|
|
327
561
|
}));
|
|
328
562
|
}
|
|
329
563
|
}
|
|
564
|
+
async startSyncAfterMaxRetry(extraParameters, error) {
|
|
565
|
+
if (this.retries >= this.maxRetryCount) {
|
|
566
|
+
let cta = 'startSyncAfterMaxRetry-max-retry-reached';
|
|
567
|
+
fireEventWithScreenName({
|
|
568
|
+
severityLevel: SeverityLevelValue.LOG,
|
|
569
|
+
eventName: SentryEventNameSdkConstants.APP_LOG,
|
|
570
|
+
screenName: cta,
|
|
571
|
+
cta: cta,
|
|
572
|
+
extraParams: extraParameters ? extraParameters : error
|
|
573
|
+
});
|
|
574
|
+
Logger.getInstance().logEvent(cta, extraParameters ? flattenObject(extraParameters) : error, LOG_TYPE.SDK_ERROR);
|
|
575
|
+
if (!this.docManager) {
|
|
576
|
+
this.docManager = await DocumentManager.getInstance();
|
|
577
|
+
}
|
|
578
|
+
let documentRows = await this.docManager.getUnsyncedDocument();
|
|
579
|
+
if ((documentRows === null || documentRows === void 0 ? void 0 : documentRows.length) > 0) {
|
|
580
|
+
await this.docManager.updateDocPriority(documentRows[0].id, documentRows[0].priority + 1);
|
|
581
|
+
this._retries = 0;
|
|
582
|
+
this.startDocumentSync();
|
|
583
|
+
}
|
|
584
|
+
}
|
|
585
|
+
}
|
|
330
586
|
async getAllDocuments(dispatchID) {
|
|
331
587
|
if (!this.docManager) this.docManager = await DocumentManager.getInstance();
|
|
332
588
|
return this.docManager.getAllDocuments(dispatchID);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["DocumentManager","DocumentHttpClient","isEmptyOrBlank","flattenObject","BaseError","BaseErrorCodes","InvalidArgumentsError","InvalidBaseURL","SyncManagerNotInitialized","Logger","LOG_TYPE","NetworkUtil","Marker","Position","TextBackgroundType","ImageFormat","RNFS","Platform","SentryEventNameSdkConstants","SeverityLevelValue","fireEventWithScreenName","latlngToDms","require","DocumentSyncManager","retries","_retries","value","constructor","_defineProperty","init","baseURL","retryCount","maxRetryCount","documentHttpClient","getInstance","instance","startDocumentSync","inProgress","hasNetwork","isAvailableAsync","checkForInitialization","docManager","documentRows","getUnsyncedDocument","length","uploadDocToServer","logEvent","SDK_INFO","error","isSyncPending","leftDocuments","getAllUnsyncedDocs","insertDocument","fmsFolderID","data","base64","desc","dspID","filePath","fileType","fileName","geoTimeStamp","processedFilePath","priority","arguments","undefined","InvalidArgumentError","_this$docManager","console","log","insertResponse","forceDocumentSync","updateDocument","documentRow","fmsID","markDocumentSynced","id","err","message","SDK_WARNING","updateDocumentProcessedPath","origialFilePath","processedPath","updateProcesedFilePath","updateDocError","uploadError","updateDocSyncError","processImageData","processed_file_path","pFilePath","file_name","strGeoStamp","geo_timestamp","objGeoStamp","JSON","parse","dateTime","lat","lng","accuracy","strDMS","strDMSWithAccuracy","fontSize","OS","options","backgroundImage","src","file_path","scale","watermarkTexts","text","position","topLeft","style","color","fontName","textBackgroundStyle","padding","type","none","quality","filename","saveFormat","jpg","markText","completeFilePath","includes","processBase64Data","imagePath","TemporaryDirectoryPath","writeFile","processedBase64","splittedDase64Data","split","processPODData","_this$documentHttpCli","docRow","uploadDocument","extraParameters","folderName","fms_folder_id","SDK_ERROR","_error$response","_error$response2","cta","severityLevel","ERROR","eventName","API_ERROR","screenName","extraParams","stringify","response","status","getAllDocuments","dispatchID","clearSyncedDocs","deleteAllSyncedDocuments","_class"],"sources":["DocumentSyncManager.ts"],"sourcesContent":["import type { DocumentRow } from '../DBConfig';\nimport DocumentManager from './DocumentManager';\nimport DocumentHttpClient from './DocumentHttpClient';\nimport { isEmptyOrBlank, flattenObject } from '../../../utils/utils';\nimport { BaseError } from '../../../errors/BaseError';\nimport BaseErrorCodes, {\n InvalidArgumentsError,\n InvalidBaseURL,\n SyncManagerNotInitialized,\n} from '../../../errors/ErrorCodes';\nimport Logger, { LOG_TYPE } from '../../../utils/Logger';\nimport type { SQLResultSet } from 'expo-sqlite';\nimport NetworkUtil from '../../../utils/NetworkUtil';\nimport Marker, {\n Position,\n TextBackgroundType,\n ImageFormat,\n} from 'react-native-image-marker';\nimport RNFS from 'react-native-fs';\nimport Storage from '../../../utils/storage';\nimport { Platform } from 'react-native';\nimport { ScreenNameSdkConstants, SentryEventNameSdkConstants, SeverityLevelValue } from '../../../analytics/sentry/SentrySdkConstants';\nimport { fireEventWithScreenName } from '../../../analytics/sentry/SentryAnalyticsUtils';\nconst latlngToDms = require('latlng-to-dms');\n\n\nexport default class DocumentSyncManager {\n private documentHttpClient: DocumentHttpClient | undefined;\n private inProgress: boolean = false;\n private static instance: DocumentSyncManager;\n private docManager: DocumentManager | undefined;\n private maxRetryCount: number = 3;\n private _retries = 0;\n\n get retries(): number {\n return this._retries;\n }\n\n set retries(value: number) {\n this._retries = value;\n }\n\n private constructor() {}\n\n public init(baseURL: string, retryCount: number) {\n if (isEmptyOrBlank(baseURL))\n throw new BaseError(BaseErrorCodes.InvalidBaseURL, InvalidBaseURL);\n this.maxRetryCount = retryCount;\n this.documentHttpClient = new DocumentHttpClient(baseURL);\n }\n\n public static getInstance(): DocumentSyncManager {\n if (!DocumentSyncManager.instance) {\n DocumentSyncManager.instance = new DocumentSyncManager();\n }\n return DocumentSyncManager.instance;\n }\n\n public async startDocumentSync(): Promise<void> {\n if (!this.inProgress && this._retries < this.maxRetryCount) {\n this.inProgress = true;\n const hasNetwork = await NetworkUtil.isAvailableAsync();\n try {\n this.checkForInitialization();\n if (!this.docManager) {\n this.docManager = await DocumentManager.getInstance();\n }\n if (hasNetwork) {\n let documentRows: DocumentRow[] =\n await this.docManager.getUnsyncedDocument();\n if (documentRows?.length > 0) {\n await this.uploadDocToServer(documentRows[0]);\n } else {\n Logger.getInstance().logEvent(\n 'startDocumentSync',\n 'No data to sync',\n LOG_TYPE.SDK_INFO\n );\n }\n } else {\n Logger.getInstance().logEvent(\n 'startDocumentSync',\n 'No Network',\n LOG_TYPE.SDK_INFO\n );\n }\n } catch (error: any) {\n } finally {\n this.inProgress = false;\n if ((await this.isSyncPending()) && hasNetwork) {\n await this.startDocumentSync();\n }\n }\n } else {\n Logger.getInstance().logEvent(\n 'startDocumentSync',\n 'sync already in progress ',\n LOG_TYPE.SDK_INFO\n );\n }\n }\n\n public async isSyncPending(): Promise<boolean> {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n let leftDocuments = await this.docManager.getAllUnsyncedDocs();\n return leftDocuments?.length > 0 && this._retries < this.maxRetryCount;\n }\n\n public async insertDocument(\n fmsFolderID: string | null,\n data: string | null,\n base64: boolean,\n desc: string,\n dspID: string,\n // jobID: string,\n // objRef: string,\n filePath: string | null,\n fileType: string,\n fileName: string,\n geoTimeStamp: string,\n processedFilePath: string,\n priority: number = 1\n ): Promise<SQLResultSet> {\n if (\n isEmptyOrBlank(desc) ||\n isEmptyOrBlank(dspID) ||\n // isEmptyOrBlank(jobID) ||\n // isEmptyOrBlank(objRef) ||\n isEmptyOrBlank(fileType) ||\n isEmptyOrBlank(fileName) ||\n (base64 && isEmptyOrBlank(data)) ||\n (!base64 && isEmptyOrBlank(filePath))\n )\n throw new BaseError(\n BaseErrorCodes.InvalidArgumentError,\n InvalidArgumentsError\n );\n else {\n if (!this.docManager) {\n Logger.getInstance().logEvent(\n 'insertDocument',\n 'INIT DOC SYNC AGAIN',\n LOG_TYPE.SDK_INFO\n );\n this.docManager = await DocumentManager.getInstance();\n }\n console.log('insertDocument1:',fmsFolderID);\n let insertResponse = await this.docManager?.insertDocument(\n fmsFolderID,\n desc,\n dspID,\n // jobID,\n // objRef,\n base64,\n fileName,\n fileType,\n data,\n filePath,\n geoTimeStamp,\n processedFilePath,\n priority\n );\n return insertResponse;\n }\n }\n\n public async forceDocumentSync() {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n this._retries = 0;\n await this.startDocumentSync();\n }\n\n private async updateDocument(documentRow: DocumentRow, fmsID: string) {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n try {\n await this.docManager.markDocumentSynced(documentRow.id, fmsID);\n } catch (err: any) {\n Logger.getInstance().logEvent(\n 'updateDocument',\n err.message,\n LOG_TYPE.SDK_WARNING\n );\n }\n }\n\n // This function is updating processed_file_path column for the base64 overlayed data and overlayed image file for POD. Also if it is base 64 then it is also storing temprary file path in file_path as original bae64 image.\n private async updateDocumentProcessedPath(\n documentRow: DocumentRow,\n origialFilePath: String,\n processedPath: String\n ) {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n try {\n await this.docManager.updateProcesedFilePath(\n documentRow.id,\n origialFilePath,\n processedPath\n );\n } catch (err: any) {\n Logger.getInstance().logEvent(\n 'updateDocument',\n err.message,\n LOG_TYPE.SDK_WARNING\n );\n }\n }\n\n private async updateDocError(documentRow: DocumentRow, uploadError: string) {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n try {\n await this.docManager.updateDocSyncError(documentRow.id, uploadError);\n } catch (err: any) {\n Logger.getInstance().logEvent(\n 'updateDocError',\n err.message,\n LOG_TYPE.SDK_WARNING\n );\n }\n }\n private checkForInitialization() {\n if (!this.documentHttpClient) {\n throw new BaseError(\n BaseErrorCodes.SyncManagerNotInitialized,\n SyncManagerNotInitialized\n );\n }\n }\n\n // This function will generate overlay image and update documents table for processed_file_path columns with overlayed image path.\n private async processImageData(documentRow: DocumentRow) {\n // If processed_file_path of overlayed image already existing then do not generate it again.\n if (\n documentRow.processed_file_path === null ||\n documentRow.processed_file_path === ''\n ) {\n let pFilePath = 'processed_' + documentRow.file_name; // File name for processed file.\n let strGeoStamp = documentRow.geo_timestamp; // Saved geostamp string\n let objGeoStamp = JSON.parse(strGeoStamp); // Conversion to geostamp object\n let dateTime = objGeoStamp.dateTime; // Date time stamp in UTC format\n let lat = objGeoStamp.lat; // Latitide\n let lng = objGeoStamp.lng; // Longitude\n let accuracy = objGeoStamp.accuracy; // Location accuracy\n let strDMS = latlngToDms(`${lat}, ${lng}`); // Location in degree format\n let strDMSWithAccuracy = strDMS; \n if (accuracy !== '') {\n strDMSWithAccuracy = strDMS + ' (Accuracy: ' + accuracy + 'm)'; // Appedning accuracy in location \n }\n let fontSize = 14;\n if (Platform.OS !== 'android') {\n fontSize = 28;\n }\n const options = {\n backgroundImage: { // Image for overlay\n src: documentRow.file_path,\n scale: 1,\n },\n watermarkTexts: [ \n {\n text: `${dateTime}\\n${strDMSWithAccuracy}`, //Overlay text\n position: {\n position: Position.topLeft, // Overlay text position\n },\n style: { // Style for overlay\n color: '#ffffff',\n fontSize: fontSize,\n fontName: 'Arial',\n textBackgroundStyle: {\n padding: '1% 1%',\n type: TextBackgroundType.none,\n color: '#444444CC',\n },\n },\n },\n ],\n scale: 0,\n quality: 100, \n filename: pFilePath,\n saveFormat: ImageFormat.jpg, // Saving in jpeg format\n };\n let processedFilePath = await Marker.markText(options); // Generating overlay image\n if (processedFilePath !== null && processedFilePath !== '') {\n let completeFilePath = processedFilePath;\n // If processd image file path does not have prefix file:// then we are addding manually\n if (!processedFilePath.includes('file')) {\n completeFilePath = 'file://' + processedFilePath;\n }\n // Updating document document table with overlayed image path\n this.updateDocumentProcessedPath(\n documentRow,\n documentRow.file_path, //original file path catprued from camera\n completeFilePath // completeFilePath is the path with file:// of processed file \n );\n documentRow.processed_file_path = completeFilePath; \n }\n }\n return documentRow;\n }\n\n // This function will generate overlay base64 data and update documents table for processed_file_path columns with overlayed base64 data.\n private async processBase64Data(documentRow: DocumentRow) {\n // If base64 overlayed data already existing then do not generate it again.\n if (\n documentRow.processed_file_path === null ||\n documentRow.processed_file_path === ''\n ) {\n let filePath = '';\n // If templrary base 64 file already exist then do not create again\n if (documentRow.file_path === null || documentRow.file_path === '') {\n const imagePath = `${RNFS.TemporaryDirectoryPath}/${documentRow.file_name}`;\n await RNFS.writeFile(imagePath, documentRow.data, 'base64'); // Write file to temprary location\n filePath = imagePath;\n // If file generated frommbase64 data does not have file:// then we are adding manually.\n if (!imagePath.includes('file')) {\n filePath = `file://${imagePath}`;\n }\n documentRow.file_path = filePath;\n } else {\n filePath = documentRow.file_path;\n }\n let pFilePath = 'processed_' + documentRow.file_name; // File name for processed file.\n let strGeoStamp = documentRow.geo_timestamp; // Saved geostamp string\n let objGeoStamp = JSON.parse(strGeoStamp); // Conversion to geostamp object\n let dateTime = objGeoStamp.dateTime; // Date time stamp in UTC format\n let lat = objGeoStamp.lat; // Latitide\n let lng = objGeoStamp.lng; // Longitude\n let accuracy = objGeoStamp.accuracy; // Location accuracy\n let strDMS = latlngToDms(`${lat}, ${lng}`); // Location in degree format\n let strDMSWithAccuracy = strDMS; \n if (accuracy !== '') {\n strDMSWithAccuracy = strDMS + ' (Accuracy: ' + accuracy + 'm)'; // Appedning accuracy in location \n }\n const options = {\n backgroundImage: {\n src: filePath, // Image for overlay\n scale: 1,\n },\n watermarkTexts: [\n {\n text: `${dateTime}\\n${strDMSWithAccuracy}`, // Ooverlay text\n position: {\n position: Position.topLeft, // Overlay text position\n },\n style: { // Style for overlay\n color: '#ffffff',\n fontSize: 14,\n fontName: 'Arial',\n textBackgroundStyle: {\n padding: '1% 1%',\n type: TextBackgroundType.none,\n color: '#444444CC',\n },\n },\n },\n ],\n scale: 1,\n quality: 100,\n filename: pFilePath,\n saveFormat: ImageFormat.base64, // Saving in base6 format\n };\n let processedBase64 = await Marker.markText(options); // Generating overlay image\n if (processedBase64 !== null && processedBase64 !== '') {\n // Fetching base64 data from processed data.\n var splittedDase64Data = processedBase64.split(\n 'data:image/png;base64,'\n );\n // Updating document document table with overlayed base64 data\n await this.updateDocumentProcessedPath(\n documentRow,\n filePath,\n splittedDase64Data[1]\n );\n documentRow.processed_file_path = splittedDase64Data[1];\n }\n }\n return documentRow;\n }\n\n // This function will calling respective overlay method for base64 (for signature POD) or image (for image POD).\n private async processPODData(documentRow: DocumentRow) {\n if (documentRow.base64 && documentRow.data != null) {\n return await this.processBase64Data(documentRow);\n } else {\n return await this.processImageData(documentRow);\n }\n }\n\n private async uploadDocToServer(documentRow: DocumentRow) {\n try {\n let docRow = await this.processPODData(documentRow);\n console.log('uploadDocToServer999:', docRow);\n let fmsID = await this.documentHttpClient?.uploadDocument(documentRow);\n\n let extraParameters = {\n fmsID: fmsID ?? '',\n fileName: docRow.file_name,\n folderName: docRow.fms_folder_id\n };\n // TODO: SOLELY DEPENDS ON FMS_ID WHICH IS WRONG => IT SHOULD BE Response.status = 202\n if (fmsID) {\n this._retries = 0;\n await this.updateDocument(docRow, fmsID);\n } else {\n this._retries++;\n Logger.getInstance().logEvent(\n 'uploadDocToServer-empty-fms-id',\n flattenObject(extraParameters),\n LOG_TYPE.SDK_ERROR\n );\n await this.updateDocError(docRow, 'Unexpected Error');\n }\n } catch (error: any) {\n const cta = 'uploadDocToServer-error';\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.ERROR,\n eventName: SentryEventNameSdkConstants.API_ERROR,\n screenName: cta,\n cta: cta,\n extraParams: {\n error: error.message,\n },\n });\n this._retries++;\n Logger.getInstance().logEvent(\n 'uploadDocToServer-sync-error',\n error.message,\n LOG_TYPE.SDK_ERROR\n );\n await this.updateDocError(\n documentRow,\n JSON.stringify({\n message: error.message,\n error: JSON.stringify(error?.response?.data),\n status: error?.response?.status,\n })\n );\n }\n }\n\n public async getAllDocuments(dispatchID?: string): Promise<DocumentRow[]> {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n return this.docManager.getAllDocuments(dispatchID);\n }\n\n public async clearSyncedDocs(dspID: string) {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n if (dspID) await this.docManager.deleteAllSyncedDocuments(dspID);\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["DocumentManager","DocumentHttpClient","isEmptyOrBlank","flattenObject","BaseError","BaseErrorCodes","InvalidArgumentsError","InvalidBaseURL","SyncManagerNotInitialized","Logger","LOG_TYPE","NetworkUtil","ETEventsManager","LAST_SYNCED_EVENT_ID","MAX_RETRY_COUNT","POD_DOC","EventsSyncManager","Marker","Position","TextBackgroundType","ImageFormat","RNFS","Storage","Platform","SentryEventNameSdkConstants","SeverityLevelValue","fireEventWithScreenName","latlngToDms","require","DocumentSyncManager","retries","_retries","value","constructor","_defineProperty","init","baseURL","retryCount","maxRetryCount","documentHttpClient","getInstance","instance","startDocumentSync","inProgress","hasNetwork","isAvailableAsync","checkForInitialization","docManager","documentRows","getUnsyncedDocument","length","uploadDocToServer","cta","severityLevel","LOG","eventName","APP_LOG","screenName","extraParams","msg","logEvent","SDK_ERROR","error","syncPending","isSyncPending","extraParameters","pending","leftDocuments","getAllUnsyncedDocs","insertDocument","fmsFolderID","data","base64","desc","dspID","filePath","fileType","fileName","geoTimeStamp","processedFilePath","priority","arguments","undefined","InvalidArgumentError","_this$docManager","console","log","insertResponse","forceDocumentSync","updateDocumentWithAttempt","documentRow","fmsID","attempt","sync","markDocumentSyncedWithAttempt","id","eventsManager","podId","markPODDocEventSynced","lastSyncedEventId","getSharedItem","syncEventId","parseInt","setSharedItem","startSync","err","SDK_WARNING","updateDocumentProcessedPath","origialFilePath","processedPath","updateProcesedFilePath","ERROR","APP_ERROR","updateDocError","uploadError","updateDocSyncError","processImageData","processed_file_path","extra","fName","file_name","substring","dName","fms_folder_id","dispId","dispatch_id","pFilePath","strGeoStamp","geo_timestamp","objGeoStamp","JSON","parse","dateTime","lat","lng","accuracy","strDMS","strDMSWithAccuracy","fontSize","OS","options","backgroundImage","src","file_path","scale","watermarkTexts","text","position","topLeft","style","color","fontName","textBackgroundStyle","padding","type","none","quality","filename","saveFormat","jpg","markText","completeFilePath","includes","processBase64Data","imagePath","TemporaryDirectoryPath","writeFile","processedBase64","splittedDase64Data","split","processPODData","_this$documentHttpCli","docRow","geoStampAvailable","uploadDocument","startSyncAfterMaxRetry","_error$response","_error$response2","API_ERROR","stringify","message","response","status","updateDocPriority","getAllDocuments","dispatchID","clearSyncedDocs","deleteAllSyncedDocuments","_class"],"sources":["DocumentSyncManager.ts"],"sourcesContent":["import type { DocumentRow } from '../DBConfig';\nimport DocumentManager from './DocumentManager';\nimport DocumentHttpClient from './DocumentHttpClient';\nimport { isEmptyOrBlank, flattenObject } from '../../../utils/utils';\nimport { BaseError } from '../../../errors/BaseError';\nimport BaseErrorCodes, {\n InvalidArgumentsError,\n InvalidBaseURL,\n SyncManagerNotInitialized,\n} from '../../../errors/ErrorCodes';\nimport Logger, { LOG_TYPE } from '../../../utils/Logger';\nimport type { SQLResultSet } from 'expo-sqlite';\nimport NetworkUtil from '../../../utils/NetworkUtil';\nimport ETEventsManager from '../events/ETEventsManager';\nimport { LAST_SYNCED_EVENT_ID, MAX_RETRY_COUNT, POD_DOC } from '../../syncmanager/constants';\nimport EventsSyncManager from '../events/EventsSyncManager';\nimport Marker, {\n Position,\n TextBackgroundType,\n ImageFormat,\n} from 'react-native-image-marker';\nimport RNFS from 'react-native-fs';\nimport Storage from '../../../utils/storage';\nimport { Platform } from 'react-native';\nimport { ScreenNameSdkConstants, SentryEventNameSdkConstants, SeverityLevelValue } from '../../../analytics/sentry/SentrySdkConstants';\nimport { fireEventWithScreenName } from '../../../analytics/sentry/SentryAnalyticsUtils';\nconst latlngToDms = require('latlng-to-dms');\n\n\nexport default class DocumentSyncManager {\n private documentHttpClient: DocumentHttpClient | undefined;\n private inProgress: boolean = false;\n private static instance: DocumentSyncManager;\n private docManager: DocumentManager | undefined;\n private maxRetryCount: number = MAX_RETRY_COUNT;\n private _retries = 0;\n get retries(): number {\n return this._retries;\n }\n\n set retries(value: number) {\n this._retries = value;\n }\n\n private constructor() {}\n\n public init(baseURL: string, retryCount: number) {\n if (isEmptyOrBlank(baseURL))\n throw new BaseError(BaseErrorCodes.InvalidBaseURL, InvalidBaseURL);\n this.maxRetryCount = retryCount;\n this.documentHttpClient = new DocumentHttpClient(baseURL);\n }\n\n public static getInstance(): DocumentSyncManager {\n if (!DocumentSyncManager.instance) {\n DocumentSyncManager.instance = new DocumentSyncManager();\n }\n return DocumentSyncManager.instance;\n }\n\n public async startDocumentSync(): Promise<void> {\n if (!this.inProgress && this._retries < this.maxRetryCount) {\n this.inProgress = true;\n const hasNetwork = await NetworkUtil.isAvailableAsync();\n try {\n this.checkForInitialization();\n if (!this.docManager) {\n this.docManager = await DocumentManager.getInstance();\n }\n if (hasNetwork) {\n let documentRows: DocumentRow[] =\n await this.docManager.getUnsyncedDocument();\n if (documentRows?.length > 0) {\n await this.uploadDocToServer(documentRows[0]);\n } else {\n let cta = 'startDocumentSync-NoData'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:'No data to sync'\n },\n });\n Logger.getInstance().logEvent(\n cta,\n 'No data to sync',\n LOG_TYPE.SDK_ERROR\n );\n }\n } else {\n let cta = 'startDocumentSync-NoNetwork'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:'No Network'\n },\n });\n Logger.getInstance().logEvent(\n cta,\n 'No Network',\n LOG_TYPE.SDK_ERROR\n );\n }\n } catch (error: any) {\n let cta = 'startDocumentSync-error'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:flattenObject(error)\n },\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(error),\n LOG_TYPE.SDK_ERROR\n );\n } finally {\n this.inProgress = false;\n let syncPending = await this.isSyncPending();\n if (syncPending && hasNetwork) {\n await this.startDocumentSync();\n }else{\n let cta = 'startDocumentSync-error'\n let extraParameters = {\n hasNetwork: hasNetwork,\n pending: syncPending,\n };\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:flattenObject(extraParameters)\n },\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(extraParameters),\n LOG_TYPE.SDK_ERROR\n );\n }\n }\n } else {\n let cta = 'startDocumentSync'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:'sync already in progress or max count reached'\n },\n });\n Logger.getInstance().logEvent(\n cta,\n 'sync already in progress or max count reached',\n LOG_TYPE.SDK_ERROR\n );\n }\n }\n\n public async isSyncPending(): Promise<boolean> {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n let leftDocuments = await this.docManager.getAllUnsyncedDocs();\n return leftDocuments?.length > 0 && this._retries < this.maxRetryCount;\n }\n\n public async insertDocument(\n fmsFolderID: string | null,\n data: string | null,\n base64: boolean,\n desc: string,\n dspID: string,\n // jobID: string,\n // objRef: string,\n filePath: string | null,\n fileType: string,\n fileName: string,\n geoTimeStamp: string,\n processedFilePath: string,\n priority: number = 1\n ): Promise<SQLResultSet> {\n if (\n isEmptyOrBlank(desc) ||\n isEmptyOrBlank(dspID) ||\n // isEmptyOrBlank(jobID) ||\n // isEmptyOrBlank(objRef) ||\n isEmptyOrBlank(fileType) ||\n isEmptyOrBlank(fileName) ||\n (base64 && isEmptyOrBlank(data)) ||\n (!base64 && isEmptyOrBlank(filePath))\n )\n throw new BaseError(\n BaseErrorCodes.InvalidArgumentError,\n InvalidArgumentsError\n );\n else {\n if (!this.docManager) {\n let cta = 'insertDocument'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:'INIT DOC SYNC AGAIN'\n },\n });\n Logger.getInstance().logEvent(\n cta,\n 'INIT DOC SYNC AGAIN',\n LOG_TYPE.SDK_ERROR\n );\n this.docManager = await DocumentManager.getInstance();\n }\n console.log('insertDocument1:',fmsFolderID);\n let insertResponse = await this.docManager?.insertDocument(\n fmsFolderID,\n desc,\n dspID,\n // jobID,\n // objRef,\n base64,\n fileName,\n fileType,\n data,\n filePath,\n geoTimeStamp,\n processedFilePath,\n priority\n );\n return insertResponse;\n }\n }\n\n public async forceDocumentSync() {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n this._retries = 0;\n await this.startDocumentSync();\n }\n\n // private async updateDocument(documentRow: DocumentRow, fmsID: string) {\n // if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n // try {\n // await this.docManager.markDocumentSynced(documentRow.id, fmsID);\n // let eventsManager = await ETEventsManager.getInstance();\n // let podId = POD_DOC + '_' + documentRow.id;\n // await eventsManager.markPODDocEventSynced(1, 1, podId);\n // EventsSyncManager.getInstance().startSync();\n // } catch (err: any) {\n // Logger.getInstance().logEvent(\n // 'updateDocument',\n // err.message,\n // LOG_TYPE.SDK_WARNING\n // );\n // }\n // }\n\n // This function will update document row with attempt count and sync status\n private async updateDocumentWithAttempt(\n documentRow: DocumentRow,\n fmsID: string,\n attempt: number,\n sync: number\n ) {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n try {\n // Calling document row update method for attempt count and sync.\n await this.docManager.markDocumentSyncedWithAttempt(\n documentRow.id,\n fmsID,\n attempt,\n sync\n );\n let eventsManager = await ETEventsManager.getInstance();\n let podId = POD_DOC + '_' + documentRow.id;\n\n let extraParameters = {\n podId: podId,\n };\n Logger.getInstance().logEvent(\n 'updateDocumentWithAttempt-success',\n flattenObject(extraParameters),\n LOG_TYPE.SDK_ERROR\n );\n // Calling update method for attempt count and sync to update event row of type POD_DOC\n await eventsManager.markPODDocEventSynced(sync, attempt, podId);\n if(sync == 1){\n const lastSyncedEventId = await Storage.getInstance().getSharedItem(\n LAST_SYNCED_EVENT_ID\n );\n const syncEventId = parseInt(lastSyncedEventId) + 1;\n await Storage.getInstance().setSharedItem(\n LAST_SYNCED_EVENT_ID,\n `${syncEventId}`\n );\n }\n EventsSyncManager.getInstance().startSync();\n } catch (err: any) {\n let cta = 'updateDocumentWithAttempt'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:flattenObject(err)\n },\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(err),\n LOG_TYPE.SDK_WARNING\n );\n }\n }\n\n // This function is updating processed_file_path column for the base64 overlayed data and overlayed image file for POD. Also if it is base 64 then it is also storing temprary file path in file_path as original bae64 image.\n private async updateDocumentProcessedPath(\n documentRow: DocumentRow,\n origialFilePath: String,\n processedPath: String\n ) {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n try {\n await this.docManager.updateProcesedFilePath(\n documentRow.id,\n origialFilePath,\n processedPath\n );\n } catch (err: any) {\n let cta = 'updateDocument-updateDocumentProcessedPath'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.ERROR,\n eventName: SentryEventNameSdkConstants.APP_ERROR,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:flattenObject(err)\n },\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(err),\n LOG_TYPE.SDK_WARNING\n );\n }\n }\n\n private async updateDocError(documentRow: DocumentRow, uploadError: string) {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n try {\n await this.docManager.updateDocSyncError(documentRow.id, uploadError);\n } catch (err: any) {\n let cta = 'updateDocError'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.ERROR,\n eventName: SentryEventNameSdkConstants.APP_ERROR,\n screenName: cta,\n cta: cta,\n extraParams: {\n msg:flattenObject(err)\n },\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(err),\n LOG_TYPE.SDK_WARNING\n );\n }\n }\n private checkForInitialization() {\n if (!this.documentHttpClient) {\n throw new BaseError(\n BaseErrorCodes.SyncManagerNotInitialized,\n SyncManagerNotInitialized\n );\n }\n }\n\n // This function will generate overlay image and update documents table for processed_file_path columns with overlayed image path.\n private async processImageData(documentRow: DocumentRow) {\n // If processed_file_path of overlayed image already existing then do not generate it again.\n if (\n documentRow.processed_file_path === null ||\n documentRow.processed_file_path === ''\n ) {\n let cta = 'processImageData-started';\n let extra = {\n msg: 'processImageData-started',\n fName: documentRow.file_name && documentRow.file_name.length != 0 ? documentRow.file_name.substring(4): '',\n dName: documentRow.fms_folder_id && documentRow.fms_folder_id.length != 0 ? documentRow.fms_folder_id.substring(4): '',\n dispId: documentRow.dispatch_id && documentRow.dispatch_id.length != 0 ? documentRow.dispatch_id.substring(9): ''\n };\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: extra,\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(extra),\n LOG_TYPE.SDK_ERROR\n );\n let pFilePath = 'processed_' + documentRow.file_name; // File name for processed file.\n let strGeoStamp = documentRow.geo_timestamp; // Saved geostamp string\n let objGeoStamp = JSON.parse(strGeoStamp); // Conversion to geostamp object\n let dateTime = objGeoStamp.dateTime; // Date time stamp in UTC format\n let lat = objGeoStamp.lat; // Latitide\n let lng = objGeoStamp.lng; // Longitude\n let accuracy = objGeoStamp.accuracy; // Location accuracy\n let strDMS = latlngToDms(`${lat}, ${lng}`); // Location in degree format\n let strDMSWithAccuracy = strDMS; \n if (accuracy !== '') {\n strDMSWithAccuracy = strDMS + ' (Accuracy: ' + accuracy + 'm)'; // Appedning accuracy in location \n }\n let fontSize = 14;\n if (Platform.OS !== 'android') {\n fontSize = 28;\n }\n const options = {\n backgroundImage: { // Image for overlay\n src: documentRow.file_path,\n scale: 1,\n },\n watermarkTexts: [ \n {\n text: `${dateTime}\\n${strDMSWithAccuracy}`, //Overlay text\n position: {\n position: Position.topLeft, // Overlay text position\n },\n style: { // Style for overlay\n color: '#ffffff',\n fontSize: fontSize,\n fontName: 'Arial',\n textBackgroundStyle: {\n padding: '1% 1%',\n type: TextBackgroundType.none,\n color: '#444444CC',\n },\n },\n },\n ],\n scale: 0,\n quality: 100, \n filename: pFilePath,\n saveFormat: ImageFormat.jpg, // Saving in jpeg format\n };\n let processedFilePath = await Marker.markText(options); // Generating overlay image\n if (processedFilePath !== null && processedFilePath !== '') {\n let completeFilePath = processedFilePath;\n // If processd image file path does not have prefix file:// then we are addding manually\n if (!processedFilePath.includes('file')) {\n completeFilePath = 'file://' + processedFilePath;\n }\n // Updating document document table with overlayed image path\n this.updateDocumentProcessedPath(\n documentRow,\n documentRow.file_path, //original file path catprued from camera\n completeFilePath // completeFilePath is the path with file:// of processed file \n );\n documentRow.processed_file_path = completeFilePath; \n }\n }\n let cta = 'processImageData-completed';\n let extra = {\n msg: 'processImageData-completed',\n fName: documentRow.file_name && documentRow.file_name.length != 0 ? documentRow.file_name.substring(4): '',\n dName: documentRow.fms_folder_id && documentRow.fms_folder_id.length != 0 ? documentRow.fms_folder_id.substring(4): '',\n dispId: documentRow.dispatch_id && documentRow.dispatch_id.length != 0 ? documentRow.dispatch_id.substring(9): ''\n };\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: extra,\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(extra),\n LOG_TYPE.SDK_ERROR\n );\n return documentRow;\n }\n\n // This function will generate overlay base64 data and update documents table for processed_file_path columns with overlayed base64 data.\n private async processBase64Data(documentRow: DocumentRow) {\n // If base64 overlayed data already existing then do not generate it again.\n if (\n documentRow.processed_file_path === null ||\n documentRow.processed_file_path === ''\n ) {\n let cta = 'processBase64Data-started';\n let extra = {\n msg: 'processBase64Data-started',\n fName: documentRow.file_name && documentRow.file_name.length != 0 ? documentRow.file_name.substring(4): '',\n dName: documentRow.fms_folder_id && documentRow.fms_folder_id.length != 0 ? documentRow.fms_folder_id.substring(4): '',\n dispId: documentRow.dispatch_id && documentRow.dispatch_id.length != 0 ? documentRow.dispatch_id.substring(9): ''\n };\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: extra,\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(extra),\n LOG_TYPE.SDK_ERROR\n );\n let filePath = '';\n // If templrary base 64 file already exist then do not create again\n if (documentRow.file_path === null || documentRow.file_path === '') {\n const imagePath = `${RNFS.TemporaryDirectoryPath}/${documentRow.file_name}`;\n await RNFS.writeFile(imagePath, documentRow.data, 'base64'); // Write file to temprary location\n filePath = imagePath;\n // If file generated frommbase64 data does not have file:// then we are adding manually.\n if (!imagePath.includes('file')) {\n filePath = `file://${imagePath}`;\n }\n documentRow.file_path = filePath;\n } else {\n filePath = documentRow.file_path;\n }\n let pFilePath = 'processed_' + documentRow.file_name; // File name for processed file.\n let strGeoStamp = documentRow.geo_timestamp; // Saved geostamp string\n let objGeoStamp = JSON.parse(strGeoStamp); // Conversion to geostamp object\n let dateTime = objGeoStamp.dateTime; // Date time stamp in UTC format\n let lat = objGeoStamp.lat; // Latitide\n let lng = objGeoStamp.lng; // Longitude\n let accuracy = objGeoStamp.accuracy; // Location accuracy\n let strDMS = latlngToDms(`${lat}, ${lng}`); // Location in degree format\n let strDMSWithAccuracy = strDMS; \n if (accuracy !== '') {\n strDMSWithAccuracy = strDMS + ' (Accuracy: ' + accuracy + 'm)'; // Appedning accuracy in location \n }\n const options = {\n backgroundImage: {\n src: filePath, // Image for overlay\n scale: 1,\n },\n watermarkTexts: [\n {\n text: `${dateTime}\\n${strDMSWithAccuracy}`, // Ooverlay text\n position: {\n position: Position.topLeft, // Overlay text position\n },\n style: { // Style for overlay\n color: '#ffffff',\n fontSize: 14,\n fontName: 'Arial',\n textBackgroundStyle: {\n padding: '1% 1%',\n type: TextBackgroundType.none,\n color: '#444444CC',\n },\n },\n },\n ],\n scale: 1,\n quality: 100,\n filename: pFilePath,\n saveFormat: ImageFormat.base64, // Saving in base6 format\n };\n let processedBase64 = await Marker.markText(options); // Generating overlay image\n if (processedBase64 !== null && processedBase64 !== '') {\n // Fetching base64 data from processed data.\n var splittedDase64Data = processedBase64.split(\n 'data:image/png;base64,'\n );\n // Updating document document table with overlayed base64 data\n await this.updateDocumentProcessedPath(\n documentRow,\n filePath,\n splittedDase64Data[1]\n );\n documentRow.processed_file_path = splittedDase64Data[1];\n }\n }\n let cta = 'processBase64Data-completed';\n let extra = {\n msg: 'processBase64Data-completed',\n fName: documentRow.file_name && documentRow.file_name.length != 0 ? documentRow.file_name.substring(4): '',\n dName: documentRow.fms_folder_id && documentRow.fms_folder_id.length != 0 ? documentRow.fms_folder_id.substring(4): '',\n dispId: documentRow.dispatch_id && documentRow.dispatch_id.length != 0 ? documentRow.dispatch_id.substring(9): ''\n };\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: extra,\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(extra),\n LOG_TYPE.SDK_ERROR\n );\n return documentRow;\n }\n\n // This function will calling respective overlay method for base64 (for signature POD) or image (for image POD).\n private async processPODData(documentRow: DocumentRow) {\n if (documentRow.base64 && documentRow.data != null) {\n return await this.processBase64Data(documentRow);\n } else {\n return await this.processImageData(documentRow);\n }\n }\n\n private async uploadDocToServer(documentRow: DocumentRow) {\n try {\n let docRow = documentRow;\n let cta = 'uploadDocToServer-geoStamp';\n let geoStampAvailable = false\n if(documentRow.geo_timestamp && documentRow.geo_timestamp.length != 0){\n geoStampAvailable = true;\n docRow = await this.processPODData(documentRow);\n }\n let extra = {\n msg: geoStampAvailable ? \"geoStamp availale\" : 'geoStamp not availale',\n fName: docRow.file_name && docRow.file_name.length != 0 ? docRow.file_name.substring(4): '',\n dName: docRow.fms_folder_id && docRow.fms_folder_id.length != 0 ? docRow.fms_folder_id.substring(4): '',\n dispId: docRow.dispatch_id && docRow.dispatch_id.length != 0 ? docRow.dispatch_id.substring(9): ''\n };\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: extra,\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(extra),\n LOG_TYPE.SDK_ERROR\n );\n console.log('uploadDocToServer999:', docRow);\n let fmsID = await this.documentHttpClient?.uploadDocument(docRow);\n\n let extraParameters = {\n fmsID: fmsID ?? '',\n fName: docRow.file_name && docRow.file_name.length != 0 ? docRow.file_name.substring(4): '',\n dName: docRow.fms_folder_id && docRow.fms_folder_id.length != 0 ? docRow.fms_folder_id.substring(4): '',\n dispId: docRow.dispatch_id && docRow.dispatch_id.length != 0 ? docRow.dispatch_id.substring(9): ''\n };\n // TODO: SOLELY DEPENDS ON FMS_ID WHICH IS WRONG => IT SHOULD BE Response.status = 202\n if (fmsID) {\n // Calling function updating document row along with attempt count and sync as true.\n await this.updateDocumentWithAttempt(\n documentRow,\n fmsID,\n this._retries + 1,\n 1\n );\n this._retries = 0;\n // await this.updateDocument(docRow, fmsID);\n } else {\n // Calling function updating document row withalong attempt count and sync as false.\n await this.updateDocumentWithAttempt(\n documentRow,\n '',\n this._retries + 1,\n 0\n );\n this._retries++;\n let cta = 'uploadDocToServer-empty-fms-id'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: extraParameters,\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(extraParameters),\n LOG_TYPE.SDK_ERROR\n );\n this.startSyncAfterMaxRetry(extraParameters, null);\n await this.updateDocError(docRow, 'Unexpected Error');\n }\n } catch (error: any) {\n // Calling function updating document row withalong attempt count and sync as false.\n await this.updateDocumentWithAttempt(\n documentRow,\n '',\n this._retries + 1,\n 0\n );\n const cta = 'uploadDocToServer-error';\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.ERROR,\n eventName: SentryEventNameSdkConstants.API_ERROR,\n screenName: cta,\n cta: cta,\n extraParams: {\n error: flattenObject(error),\n },\n });\n Logger.getInstance().logEvent(\n cta,\n flattenObject(error),\n LOG_TYPE.SDK_ERROR\n );\n this._retries++;\n this.startSyncAfterMaxRetry(null, error);\n await this.updateDocError(\n documentRow,\n JSON.stringify({\n message: error.message,\n error: JSON.stringify(error?.response?.data),\n status: error?.response?.status,\n })\n );\n }\n }\n\n private async startSyncAfterMaxRetry(extraParameters:any, error:any){\n if(this.retries >= this.maxRetryCount){\n let cta = 'startSyncAfterMaxRetry-max-retry-reached'\n fireEventWithScreenName({\n severityLevel: SeverityLevelValue.LOG,\n eventName: SentryEventNameSdkConstants.APP_LOG,\n screenName: cta,\n cta: cta,\n extraParams: extraParameters ? extraParameters : error,\n });\n Logger.getInstance().logEvent(\n cta,\n extraParameters ? flattenObject(extraParameters) : error,\n LOG_TYPE.SDK_ERROR\n );\n if (!this.docManager) {\n this.docManager = await DocumentManager.getInstance();\n }\n let documentRows: DocumentRow[] =\n await this.docManager.getUnsyncedDocument();\n if (documentRows?.length > 0) {\n await this.docManager.updateDocPriority(documentRows[0].id, documentRows[0].priority + 1);\n this._retries = 0;\n this.startDocumentSync();\n }\n }\n }\n\n public async getAllDocuments(dispatchID?: string): Promise<DocumentRow[]> {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n return this.docManager.getAllDocuments(dispatchID);\n }\n\n public async clearSyncedDocs(dspID: string) {\n if (!this.docManager) this.docManager = await DocumentManager.getInstance();\n if (dspID) await this.docManager.deleteAllSyncedDocuments(dspID);\n }\n}\n"],"mappings":"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"}
|