1
0
Code Issues Pull Requests Packages Projects Releases Wiki Activity GitHub Gitee
react-native-pushy/lib/simpleUpdate.tsx

136 lines
3.8 KiB
TypeScript
Raw Normal View History

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;
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} />;
}
};
}