react-native-3rddigital-appupdate 1.0.16 → 1.0.17
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/README.md +20 -2
- package/lib/module/checkOTAUpdate.js +9 -3
- package/lib/module/checkOTAUpdate.js.map +1 -1
- package/lib/module/index.js +1 -1
- package/lib/module/index.js.map +1 -1
- package/lib/typescript/src/checkOTAUpdate.d.ts +3 -1
- package/lib/typescript/src/checkOTAUpdate.d.ts.map +1 -1
- package/lib/typescript/src/index.d.ts +1 -1
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/package.json +1 -1
- package/scripts/bundle.js +59 -23
- package/src/checkOTAUpdate.ts +12 -2
- package/src/index.tsx +1 -0
package/README.md
CHANGED
|
@@ -33,14 +33,17 @@ cd ios && pod install
|
|
|
33
33
|
|
|
34
34
|
```sh
|
|
35
35
|
import React, { useEffect } from 'react';
|
|
36
|
-
import { Alert, View, Text } from 'react-native';
|
|
36
|
+
import { Alert, Button, View, Text } from 'react-native';
|
|
37
37
|
import {
|
|
38
38
|
OTAProvider,
|
|
39
39
|
checkOTAUpdate,
|
|
40
40
|
consumeOTAUpdateSuccessState,
|
|
41
|
+
reloadAppForOTAUpdate,
|
|
41
42
|
} from 'react-native-3rddigital-appupdate';
|
|
42
43
|
|
|
43
44
|
const App = () => {
|
|
45
|
+
const [pendingUpdate, setPendingUpdate] = React.useState(null);
|
|
46
|
+
|
|
44
47
|
useEffect(() => {
|
|
45
48
|
const initializeOTAUpdate = async () => {
|
|
46
49
|
const updateState = await consumeOTAUpdateSuccessState();
|
|
@@ -57,8 +60,11 @@ const App = () => {
|
|
|
57
60
|
key: 'YOUR_PROJECT_KEY',
|
|
58
61
|
iosPackage: 'com.example.ios',
|
|
59
62
|
androidPackage: 'com.example.android',
|
|
60
|
-
restartAfterInstall:
|
|
63
|
+
restartAfterInstall: false,
|
|
61
64
|
restartDelay: 1000,
|
|
65
|
+
onUpdateInstalled: (state) => {
|
|
66
|
+
setPendingUpdate(state);
|
|
67
|
+
},
|
|
62
68
|
loaderOptions: {
|
|
63
69
|
text: 'Downloading update...',
|
|
64
70
|
showProgress: true,
|
|
@@ -77,6 +83,12 @@ const App = () => {
|
|
|
77
83
|
<OTAProvider>
|
|
78
84
|
<View>
|
|
79
85
|
<Text>My App Content</Text>
|
|
86
|
+
{pendingUpdate ? (
|
|
87
|
+
<Button
|
|
88
|
+
title={`Reload to apply OTA v${pendingUpdate.version}`}
|
|
89
|
+
onPress={reloadAppForOTAUpdate}
|
|
90
|
+
/>
|
|
91
|
+
) : null}
|
|
80
92
|
</View>
|
|
81
93
|
</OTAProvider>
|
|
82
94
|
);
|
|
@@ -103,6 +115,7 @@ Options:
|
|
|
103
115
|
| `androidPackage` | string | ✅ | Android bundle/package identifier |
|
|
104
116
|
| `restartAfterInstall` | boolean | ❌ | Whether the app should restart automatically after OTA install. Defaults to `true` |
|
|
105
117
|
| `restartDelay` | number | ❌ | Delay in milliseconds before restart after install. Defaults to `1000` |
|
|
118
|
+
| `onUpdateInstalled` | `(state: OTAUpdateSuccessState) => void` | ❌ | Called after the OTA bundle is installed, useful when `restartAfterInstall` is `false` and you want to trigger reload manually |
|
|
106
119
|
| `loaderOptions` | object | ❌ | Customize loader UI (see below) |
|
|
107
120
|
| `dialogOptions` | object | ❌ | Customize alert dialog UI (see below) |
|
|
108
121
|
|
|
@@ -125,6 +138,11 @@ Returns:
|
|
|
125
138
|
| `appVersion` | string | Native app version associated with bundle |
|
|
126
139
|
| `installedAt` | string | ISO timestamp when install completed |
|
|
127
140
|
|
|
141
|
+
🔹 reloadAppForOTAUpdate()
|
|
142
|
+
|
|
143
|
+
- Manually reloads the app so an installed OTA bundle becomes active.
|
|
144
|
+
- Useful together with `restartAfterInstall: false` and `onUpdateInstalled`.
|
|
145
|
+
|
|
128
146
|
🔹 Loader (AppLoader)
|
|
129
147
|
|
|
130
148
|
- Global loader shown when downloading an update.
|
|
@@ -43,6 +43,9 @@ export const consumeOTAUpdateSuccessState = async () => {
|
|
|
43
43
|
}
|
|
44
44
|
return state;
|
|
45
45
|
};
|
|
46
|
+
export const reloadAppForOTAUpdate = () => {
|
|
47
|
+
hotUpdate.resetApp();
|
|
48
|
+
};
|
|
46
49
|
export const checkOTAUpdate = async ({
|
|
47
50
|
key,
|
|
48
51
|
iosPackage,
|
|
@@ -51,7 +54,8 @@ export const checkOTAUpdate = async ({
|
|
|
51
54
|
dialogOptions,
|
|
52
55
|
baseUrl,
|
|
53
56
|
restartAfterInstall = true,
|
|
54
|
-
restartDelay = 1000
|
|
57
|
+
restartDelay = 1000,
|
|
58
|
+
onUpdateInstalled
|
|
55
59
|
}) => {
|
|
56
60
|
try {
|
|
57
61
|
const API_URL = baseUrl;
|
|
@@ -77,12 +81,13 @@ export const checkOTAUpdate = async ({
|
|
|
77
81
|
}
|
|
78
82
|
},
|
|
79
83
|
updateSuccess: () => {
|
|
80
|
-
|
|
84
|
+
const updateState = {
|
|
81
85
|
bundleId,
|
|
82
86
|
version,
|
|
83
87
|
appVersion: bundleAppVersion,
|
|
84
88
|
installedAt: new Date().toISOString()
|
|
85
|
-
}
|
|
89
|
+
};
|
|
90
|
+
persistOTAUpdateSuccessState(updateState).finally(() => {
|
|
86
91
|
axios.post(`${API_URL}bundles/${bundleId}/count`, {
|
|
87
92
|
status: 'success'
|
|
88
93
|
}, {
|
|
@@ -93,6 +98,7 @@ export const checkOTAUpdate = async ({
|
|
|
93
98
|
}).catch(error => {
|
|
94
99
|
console.warn('Failed to finalize OTA update success handling:', error);
|
|
95
100
|
});
|
|
101
|
+
onUpdateInstalled?.(updateState);
|
|
96
102
|
},
|
|
97
103
|
updateFail: error => {
|
|
98
104
|
axios.post(`${API_URL}bundles/${bundleId}/count`, {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["axios","Platform","ReactNativeBlobUtil","DeviceInfo","hotUpdate","AppAlertDialog","AppLoader","OTA_UPDATE_SUCCESS_FILE","fs","dirs","CacheDir","persistOTAUpdateSuccessState","state","writeFile","JSON","stringify","error","console","warn","readOTAUpdateSuccessState","exists","content","readFile","parse","consumeOTAUpdateSuccessState","unlink","checkOTAUpdate","key","iosPackage","androidPackage","loaderOptions","dialogOptions","baseUrl","restartAfterInstall","restartDelay","API_URL","response","get","currentVersion","getCurrentVersion","data","OS","android","ios","version","forceUpdate","url","bundleId","currentAppVersion","getVersion","bundleAppVersion","appVersion","downloadAndReport","show","downloadBundleUri","progress","received","total","showProgress","percentage","Number","toFixed","updateProgress","updateSuccess","installedAt","Date","toISOString","finally","post","status","headers","hide","catch","updateFail","deviceInfo","model","getModel","brand","getBrand","systemName","getSystemName","systemVersion","getSystemVersion","showMessage","title","message","confirmText","cancelText","onConfirm","onCancel","err"],"sourceRoot":"../../src","sources":["checkOTAUpdate.ts"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,QAAQ,QAAQ,cAAc;AACvC,OAAOC,mBAAmB,MAAM,wBAAwB;AACxD,OAAOC,UAAU,MAAM,0BAA0B;AACjD,OAAOC,SAAS,MAAM,6BAA6B;AACnD,SAASC,cAAc,QAA4B,qBAAkB;AACrE,SAASC,SAAS,QAA4B,gBAAa;
|
|
1
|
+
{"version":3,"names":["axios","Platform","ReactNativeBlobUtil","DeviceInfo","hotUpdate","AppAlertDialog","AppLoader","OTA_UPDATE_SUCCESS_FILE","fs","dirs","CacheDir","persistOTAUpdateSuccessState","state","writeFile","JSON","stringify","error","console","warn","readOTAUpdateSuccessState","exists","content","readFile","parse","consumeOTAUpdateSuccessState","unlink","reloadAppForOTAUpdate","resetApp","checkOTAUpdate","key","iosPackage","androidPackage","loaderOptions","dialogOptions","baseUrl","restartAfterInstall","restartDelay","onUpdateInstalled","API_URL","response","get","currentVersion","getCurrentVersion","data","OS","android","ios","version","forceUpdate","url","bundleId","currentAppVersion","getVersion","bundleAppVersion","appVersion","downloadAndReport","show","downloadBundleUri","progress","received","total","showProgress","percentage","Number","toFixed","updateProgress","updateSuccess","updateState","installedAt","Date","toISOString","finally","post","status","headers","hide","catch","updateFail","deviceInfo","model","getModel","brand","getBrand","systemName","getSystemName","systemVersion","getSystemVersion","showMessage","title","message","confirmText","cancelText","onConfirm","onCancel","err"],"sourceRoot":"../../src","sources":["checkOTAUpdate.ts"],"mappings":"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","ignoreList":[]}
|
package/lib/module/index.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
export { checkOTAUpdate, consumeOTAUpdateSuccessState } from "./checkOTAUpdate.js";
|
|
3
|
+
export { checkOTAUpdate, consumeOTAUpdateSuccessState, reloadAppForOTAUpdate } from "./checkOTAUpdate.js";
|
|
4
4
|
export { OTAProvider } from "./OTAProvider.js";
|
|
5
5
|
//# sourceMappingURL=index.js.map
|
package/lib/module/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["checkOTAUpdate","consumeOTAUpdateSuccessState","OTAProvider"],"sourceRoot":"../../src","sources":["index.tsx"],"mappings":";;AAAA,SACEA,cAAc,EACdC,4BAA4B,
|
|
1
|
+
{"version":3,"names":["checkOTAUpdate","consumeOTAUpdateSuccessState","reloadAppForOTAUpdate","OTAProvider"],"sourceRoot":"../../src","sources":["index.tsx"],"mappings":";;AAAA,SACEA,cAAc,EACdC,4BAA4B,EAC5BC,qBAAqB,QAGhB,qBAAkB;AACzB,SAASC,WAAW,QAAQ,kBAAe","ignoreList":[]}
|
|
@@ -9,6 +9,7 @@ export type OTAUpdateProps = {
|
|
|
9
9
|
baseUrl: string;
|
|
10
10
|
restartAfterInstall?: boolean;
|
|
11
11
|
restartDelay?: number;
|
|
12
|
+
onUpdateInstalled?: (state: OTAUpdateSuccessState) => void;
|
|
12
13
|
};
|
|
13
14
|
export type OTAUpdateSuccessState = {
|
|
14
15
|
bundleId: string;
|
|
@@ -17,5 +18,6 @@ export type OTAUpdateSuccessState = {
|
|
|
17
18
|
installedAt: string;
|
|
18
19
|
};
|
|
19
20
|
export declare const consumeOTAUpdateSuccessState: () => Promise<OTAUpdateSuccessState | null>;
|
|
20
|
-
export declare const
|
|
21
|
+
export declare const reloadAppForOTAUpdate: () => void;
|
|
22
|
+
export declare const checkOTAUpdate: ({ key, iosPackage, androidPackage, loaderOptions, dialogOptions, baseUrl, restartAfterInstall, restartDelay, onUpdateInstalled, }: OTAUpdateProps) => Promise<void>;
|
|
21
23
|
//# sourceMappingURL=checkOTAUpdate.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"checkOTAUpdate.d.ts","sourceRoot":"","sources":["../../../src/checkOTAUpdate.ts"],"names":[],"mappings":"AAKA,OAAO,EAAkB,KAAK,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAa,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5D,MAAM,MAAM,cAAc,GAAG;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,aAAa,CAAC,EAAE,IAAI,CAAC,aAAa,EAAE,WAAW,GAAG,UAAU,CAAC,CAAC;IAC9D,OAAO,EAAE,MAAM,CAAC;IAChB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"checkOTAUpdate.d.ts","sourceRoot":"","sources":["../../../src/checkOTAUpdate.ts"],"names":[],"mappings":"AAKA,OAAO,EAAkB,KAAK,aAAa,EAAE,MAAM,kBAAkB,CAAC;AACtE,OAAO,EAAa,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AAE5D,MAAM,MAAM,cAAc,GAAG;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,UAAU,EAAE,MAAM,CAAC;IACnB,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,CAAC,EAAE,aAAa,CAAC;IAC9B,aAAa,CAAC,EAAE,IAAI,CAAC,aAAa,EAAE,WAAW,GAAG,UAAU,CAAC,CAAC;IAC9D,OAAO,EAAE,MAAM,CAAC;IAChB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,iBAAiB,CAAC,EAAE,CAAC,KAAK,EAAE,qBAAqB,KAAK,IAAI,CAAC;CAC5D,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;CACrB,CAAC;AAmCF,eAAO,MAAM,4BAA4B,6CAkBxC,CAAC;AAEF,eAAO,MAAM,qBAAqB,YAEjC,CAAC;AAEF,eAAO,MAAM,cAAc,GAAU,mIAUlC,cAAc,kBAmGhB,CAAC"}
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export { checkOTAUpdate, consumeOTAUpdateSuccessState, type OTAUpdateProps, type OTAUpdateSuccessState, } from './checkOTAUpdate';
|
|
1
|
+
export { checkOTAUpdate, consumeOTAUpdateSuccessState, reloadAppForOTAUpdate, type OTAUpdateProps, type OTAUpdateSuccessState, } from './checkOTAUpdate';
|
|
2
2
|
export { OTAProvider } from './OTAProvider';
|
|
3
3
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,4BAA4B,EAC5B,KAAK,cAAc,EACnB,KAAK,qBAAqB,GAC3B,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACd,4BAA4B,EAC5B,qBAAqB,EACrB,KAAK,cAAc,EACnB,KAAK,qBAAqB,GAC3B,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-native-3rddigital-appupdate",
|
|
3
|
-
"version": "1.0.
|
|
3
|
+
"version": "1.0.17",
|
|
4
4
|
"description": "A React Native library for seamless over-the-air (OTA) updates with version checks, automatic bundle download, and customizable user prompts for iOS and Android.",
|
|
5
5
|
"main": "./lib/module/index.js",
|
|
6
6
|
"types": "./lib/typescript/src/index.d.ts",
|
package/scripts/bundle.js
CHANGED
|
@@ -340,6 +340,15 @@ function isAppLikeTarget(targetName, productType) {
|
|
|
340
340
|
].some((suffix) => targetName.endsWith(suffix));
|
|
341
341
|
}
|
|
342
342
|
|
|
343
|
+
function choosePreferredBuildConfig(buildConfigs, preferredNames = []) {
|
|
344
|
+
for (const preferredName of preferredNames) {
|
|
345
|
+
const match = buildConfigs.find((config) => config.name === preferredName);
|
|
346
|
+
if (match) return match;
|
|
347
|
+
}
|
|
348
|
+
|
|
349
|
+
return buildConfigs[0] ?? null;
|
|
350
|
+
}
|
|
351
|
+
|
|
343
352
|
function getAndroidBuildGradlePath(projectRoot) {
|
|
344
353
|
return findFirstExistingPath([
|
|
345
354
|
path.join(projectRoot, 'android', 'app', 'build.gradle'),
|
|
@@ -534,34 +543,61 @@ function getIosTargetMetadata() {
|
|
|
534
543
|
.map((configId) => configMap.get(configId))
|
|
535
544
|
.filter(Boolean) ?? [];
|
|
536
545
|
|
|
537
|
-
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
546
|
+
if (!buildConfigs.length) return null;
|
|
547
|
+
|
|
548
|
+
const configsByIdentity = new Map();
|
|
549
|
+
|
|
550
|
+
for (const buildConfig of buildConfigs) {
|
|
551
|
+
const identity = `${buildConfig.appId ?? 'no-app-id'}::${buildConfig.name ?? 'no-config-name'}`;
|
|
552
|
+
if (!configsByIdentity.has(identity)) {
|
|
553
|
+
configsByIdentity.set(identity, []);
|
|
554
|
+
}
|
|
555
|
+
|
|
556
|
+
configsByIdentity.get(identity).push(buildConfig);
|
|
557
|
+
}
|
|
558
|
+
|
|
559
|
+
const distinctConfigs = Array.from(configsByIdentity.values())
|
|
560
|
+
.map((configGroup) =>
|
|
561
|
+
choosePreferredBuildConfig(configGroup, [
|
|
562
|
+
configList?.defaultName,
|
|
563
|
+
'Release',
|
|
564
|
+
'Profile',
|
|
565
|
+
'Debug',
|
|
566
|
+
])
|
|
567
|
+
)
|
|
568
|
+
.filter(Boolean);
|
|
569
|
+
|
|
570
|
+
return distinctConfigs.map((selectedConfig) => {
|
|
571
|
+
const buildConfigurationLabel = selectedConfig.name
|
|
572
|
+
? ` [${selectedConfig.name}]`
|
|
573
|
+
: '';
|
|
574
|
+
|
|
575
|
+
const appIdLabel = selectedConfig.appId
|
|
576
|
+
? ` (${selectedConfig.appId})`
|
|
577
|
+
: '';
|
|
578
|
+
|
|
579
|
+
return {
|
|
580
|
+
name: `${targetName}::${selectedConfig.name ?? 'default'}::${selectedConfig.appId ?? 'no-app-id'}`,
|
|
581
|
+
targetName,
|
|
582
|
+
label: `${targetName}${buildConfigurationLabel}${appIdLabel}`,
|
|
583
|
+
appId: selectedConfig.appId ?? null,
|
|
584
|
+
version: selectedConfig.version ?? null,
|
|
585
|
+
productName: selectedConfig.productName ?? targetName,
|
|
586
|
+
buildConfiguration: selectedConfig.name ?? null,
|
|
587
|
+
};
|
|
588
|
+
});
|
|
558
589
|
})
|
|
590
|
+
.flat()
|
|
559
591
|
.filter(Boolean);
|
|
560
592
|
|
|
561
593
|
const uniqueTargets = targets.filter(
|
|
562
594
|
(target, index, allTargets) =>
|
|
563
|
-
allTargets.findIndex(
|
|
564
|
-
|
|
595
|
+
allTargets.findIndex(
|
|
596
|
+
(candidate) =>
|
|
597
|
+
candidate.targetName === target.targetName &&
|
|
598
|
+
candidate.appId === target.appId &&
|
|
599
|
+
candidate.buildConfiguration === target.buildConfiguration
|
|
600
|
+
) === index
|
|
565
601
|
);
|
|
566
602
|
|
|
567
603
|
return {
|
package/src/checkOTAUpdate.ts
CHANGED
|
@@ -15,6 +15,7 @@ export type OTAUpdateProps = {
|
|
|
15
15
|
baseUrl: string;
|
|
16
16
|
restartAfterInstall?: boolean;
|
|
17
17
|
restartDelay?: number;
|
|
18
|
+
onUpdateInstalled?: (state: OTAUpdateSuccessState) => void;
|
|
18
19
|
};
|
|
19
20
|
|
|
20
21
|
export type OTAUpdateSuccessState = {
|
|
@@ -77,6 +78,10 @@ export const consumeOTAUpdateSuccessState = async () => {
|
|
|
77
78
|
return state;
|
|
78
79
|
};
|
|
79
80
|
|
|
81
|
+
export const reloadAppForOTAUpdate = () => {
|
|
82
|
+
hotUpdate.resetApp();
|
|
83
|
+
};
|
|
84
|
+
|
|
80
85
|
export const checkOTAUpdate = async ({
|
|
81
86
|
key,
|
|
82
87
|
iosPackage,
|
|
@@ -86,6 +91,7 @@ export const checkOTAUpdate = async ({
|
|
|
86
91
|
baseUrl,
|
|
87
92
|
restartAfterInstall = true,
|
|
88
93
|
restartDelay = 1000,
|
|
94
|
+
onUpdateInstalled,
|
|
89
95
|
}: OTAUpdateProps) => {
|
|
90
96
|
try {
|
|
91
97
|
const API_URL = baseUrl;
|
|
@@ -120,12 +126,14 @@ export const checkOTAUpdate = async ({
|
|
|
120
126
|
}
|
|
121
127
|
},
|
|
122
128
|
updateSuccess: () => {
|
|
123
|
-
|
|
129
|
+
const updateState = {
|
|
124
130
|
bundleId,
|
|
125
131
|
version,
|
|
126
132
|
appVersion: bundleAppVersion,
|
|
127
133
|
installedAt: new Date().toISOString(),
|
|
128
|
-
}
|
|
134
|
+
};
|
|
135
|
+
|
|
136
|
+
persistOTAUpdateSuccessState(updateState)
|
|
129
137
|
.finally(() => {
|
|
130
138
|
axios
|
|
131
139
|
.post(
|
|
@@ -141,6 +149,8 @@ export const checkOTAUpdate = async ({
|
|
|
141
149
|
error
|
|
142
150
|
);
|
|
143
151
|
});
|
|
152
|
+
|
|
153
|
+
onUpdateInstalled?.(updateState);
|
|
144
154
|
},
|
|
145
155
|
updateFail: (error) => {
|
|
146
156
|
axios
|