2023-09-02 22:40:55 +08:00
|
|
|
import React, { PureComponent, ComponentType } from 'react';
|
|
|
|
import {
|
|
|
|
Platform,
|
|
|
|
Alert,
|
|
|
|
Linking,
|
|
|
|
AppState,
|
|
|
|
NativeEventSubscription,
|
|
|
|
} from 'react-native';
|
2021-10-09 13:12:09 +08:00
|
|
|
|
|
|
|
import {
|
|
|
|
isFirstTime,
|
|
|
|
isRolledBack,
|
|
|
|
checkUpdate,
|
|
|
|
downloadUpdate,
|
|
|
|
switchVersion,
|
|
|
|
switchVersionLater,
|
|
|
|
markSuccess,
|
|
|
|
downloadAndInstallApk,
|
2023-10-28 18:28:23 +08:00
|
|
|
onPushyEvents,
|
2021-10-09 13:12:09 +08:00
|
|
|
} from './main';
|
2023-08-31 19:24:00 +08:00
|
|
|
import { UpdateEventsListener } from './type';
|
2021-10-09 13:12:09 +08:00
|
|
|
|
2023-08-31 19:24:00 +08:00
|
|
|
export function simpleUpdate(
|
2023-09-02 22:40:55 +08:00
|
|
|
WrappedComponent: ComponentType,
|
2023-10-28 18:28:23 +08:00
|
|
|
options: { appKey?: string; onPushyEvents?: UpdateEventsListener } = {},
|
2023-08-31 19:24:00 +08:00
|
|
|
) {
|
2023-10-28 18:28:23 +08:00
|
|
|
const { appKey, onPushyEvents: eventListeners } = options;
|
2022-07-04 18:14:51 +08:00
|
|
|
if (!appKey) {
|
|
|
|
throw new Error('appKey is required for simpleUpdate()');
|
|
|
|
}
|
2023-08-31 19:24:00 +08:00
|
|
|
if (typeof eventListeners === 'function') {
|
2023-10-28 18:28:23 +08:00
|
|
|
onPushyEvents(eventListeners);
|
2023-08-31 19:24:00 +08:00
|
|
|
}
|
2021-10-09 13:12:09 +08:00
|
|
|
return __DEV__
|
|
|
|
? WrappedComponent
|
2023-08-31 19:24:00 +08:00
|
|
|
: class AppUpdate extends PureComponent {
|
2023-09-02 22:40:55 +08:00
|
|
|
stateListener: NativeEventSubscription;
|
2021-10-09 13:12:09 +08:00
|
|
|
componentDidMount() {
|
|
|
|
if (isRolledBack) {
|
|
|
|
Alert.alert('抱歉', '刚刚更新遭遇错误,已为您恢复到更新前版本');
|
|
|
|
} else if (isFirstTime) {
|
|
|
|
markSuccess();
|
|
|
|
}
|
|
|
|
this.stateListener = AppState.addEventListener(
|
|
|
|
'change',
|
|
|
|
(nextAppState) => {
|
|
|
|
if (nextAppState === 'active') {
|
|
|
|
this.checkUpdate();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
);
|
|
|
|
this.checkUpdate();
|
|
|
|
}
|
|
|
|
componentWillUnmount() {
|
2021-11-10 22:31:23 +08:00
|
|
|
this.stateListener && this.stateListener.remove();
|
2021-10-09 13:12:09 +08:00
|
|
|
}
|
|
|
|
doUpdate = async (info) => {
|
|
|
|
try {
|
|
|
|
const hash = await downloadUpdate(info);
|
2021-11-04 16:35:34 +08:00
|
|
|
if (!hash) {
|
|
|
|
return;
|
|
|
|
}
|
2021-11-10 22:31:23 +08:00
|
|
|
this.stateListener && this.stateListener.remove();
|
2021-10-09 13:12:09 +08:00
|
|
|
Alert.alert('提示', '下载完毕,是否立即更新?', [
|
|
|
|
{
|
|
|
|
text: '以后再说',
|
|
|
|
style: 'cancel',
|
|
|
|
onPress: () => {
|
|
|
|
switchVersionLater(hash);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
{
|
|
|
|
text: '立即更新',
|
|
|
|
style: 'default',
|
|
|
|
onPress: () => {
|
|
|
|
switchVersion(hash);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
} catch (err) {
|
|
|
|
Alert.alert('更新失败', err.message);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
checkUpdate = async () => {
|
|
|
|
let info;
|
|
|
|
try {
|
2023-09-02 22:40:55 +08:00
|
|
|
info = await checkUpdate(appKey!);
|
2021-10-09 13:12:09 +08:00
|
|
|
} catch (err) {
|
|
|
|
Alert.alert('更新检查失败', err.message);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (info.expired) {
|
|
|
|
Alert.alert('提示', '您的应用版本已更新,点击确定下载安装新版本', [
|
|
|
|
{
|
|
|
|
text: '确定',
|
|
|
|
onPress: () => {
|
|
|
|
if (info.downloadUrl) {
|
|
|
|
if (
|
|
|
|
Platform.OS === 'android' &&
|
|
|
|
info.downloadUrl.endsWith('.apk')
|
|
|
|
) {
|
|
|
|
downloadAndInstallApk({
|
|
|
|
url: info.downloadUrl,
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
Linking.openURL(info.downloadUrl);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
},
|
|
|
|
]);
|
2021-11-04 17:52:30 +08:00
|
|
|
} else if (info.update) {
|
2021-10-09 13:12:09 +08:00
|
|
|
Alert.alert(
|
|
|
|
'提示',
|
|
|
|
'检查到新的版本' + info.name + ',是否下载?\n' + info.description,
|
|
|
|
[
|
|
|
|
{ text: '否', style: 'cancel' },
|
|
|
|
{
|
|
|
|
text: '是',
|
|
|
|
style: 'default',
|
|
|
|
onPress: () => {
|
|
|
|
this.doUpdate(info);
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
render() {
|
|
|
|
return <WrappedComponent {...this.props} />;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}
|