Files
address-verification-app/App.tsx

227 lines
7.4 KiB
TypeScript
Raw Normal View History

2024-05-14 20:50:45 +05:30
import AsyncStorage from '@react-native-async-storage/async-storage';
import { NavigationContainer } from '@react-navigation/native';
import React, { useEffect } from 'react';
import {
2023-04-18 01:27:28 +05:30
AppState,
LogBox,
PermissionsAndroid,
Platform,
StatusBar,
2024-05-14 20:50:45 +05:30
type Permission,
} from 'react-native';
import {
default as codePush,
default as CodePush,
DownloadProgress,
DownloadProgressCallback,
SyncStatusChangedCallback,
} from 'react-native-code-push';
import { Provider } from 'react-redux';
import { PersistGate } from 'redux-persist/integration/react';
2023-08-31 14:51:03 +05:30
import store, { persistor } from './src/store/store';
2022-12-06 18:22:09 +05:30
import FullScreenLoader from './RN-UI-LIB/src/components/FullScreenLoader';
2023-04-18 01:27:28 +05:30
import { toastConfigs, ToastContainer } from './RN-UI-LIB/src/components/toast';
2024-08-26 17:00:35 +05:30
import { navigationRef } from '@utils/navigationUtlis';
import { sendDeviceDetailsToClickstream } from '@components/utlis/commonFunctions';
import { linkingConf } from '@components/utlis/deeplinkingUtils';
2024-08-26 17:04:06 +05:30
import { getBuildFlavour } from '@components/utlis/DeviceUtils';
import { GLOBAL, setGlobalBuildFlavour } from '@constants/Global';
import analytics from '@react-native-firebase/analytics';
import dayJs from 'dayjs';
2024-08-26 17:00:35 +05:30
import { COLORS } from '@rn-ui-lib/colors';
import { MILLISECONDS_IN_A_SECOND } from '@rn-ui-lib/utils/common';
import { hydrateGlobalImageMap } from '@common/CachedImage';
import { CLICKSTREAM_EVENT_NAMES, LocalStorageKeys } from '@common/Constants';
2023-04-18 01:27:28 +05:30
import ErrorBoundary from './src/common/ErrorBoundary';
2024-08-26 17:00:35 +05:30
import { getPermissionsToRequest } from '@utils/PermissionUtils';
import ScreenshotBlocker from './src/components/utlis/ScreenshotBlocker';
import { setItem } from './src/components/utlis/storageHelper';
import { ENV } from './src/constants/config';
import AuthRouter from './src/screens/auth/AuthRouter';
2024-08-26 17:00:35 +05:30
import { type TDocumentObj } from '@screens/caseDetails/interface';
import Permissions from './src/screens/permissions/Permissions';
2024-08-26 17:00:35 +05:30
import { addClickstreamEvent } from '@services/clickstreamEventService';
import { setJsErrorHandler } from '@services/exception-handler.service';
import fetchUpdatedRemoteConfig from './src/services/firebaseFetchAndUpdate.service';
import { StorageKeys } from './src/types/storageKeys';
import CodePushLoadingModal, { CodePushLoadingModalRef } from './CodePushModal';
2024-11-11 16:56:00 +05:30
import { initSentry } from '@components/utlis/sentry';
2025-01-15 19:37:26 +05:30
import { AppStates } from '@interfaces/appStates';
import syncSelfCallData from '@services/syncSelfCallData';
2024-11-11 16:56:00 +05:30
if (!__DEV__) {
initSentry();
}
2023-06-05 12:26:34 +05:30
if (ENV !== 'prod') {
// mockApiServer();
}
2023-05-25 13:55:15 +05:30
setJsErrorHandler();
LogBox.ignoreAllLogs();
export let GlobalDocumentMap: Record<string, TDocumentObj | string> = {};
async function checkCodePushAndSync(
onSyncStatusChange: SyncStatusChangedCallback,
onDownloadProgress: DownloadProgressCallback
) {
2023-04-18 01:27:28 +05:30
try {
await CodePush.sync(
{
installMode: codePush.InstallMode.IMMEDIATE,
},
onSyncStatusChange,
onDownloadProgress
);
2023-04-18 01:27:28 +05:30
} catch (error) {}
}
function handleAppStateChange(
nextAppState: any,
onSyncStatusChange: SyncStatusChangedCallback,
onDownloadProgress: DownloadProgressCallback
) {
2023-04-18 01:27:28 +05:30
if (nextAppState == 'active') {
checkCodePushAndSync(onSyncStatusChange, onDownloadProgress);
2023-04-18 01:27:28 +05:30
}
}
const PERMISSION_CHECK_POLL_INTERVAL = 5 * MILLISECONDS_IN_A_SECOND;
2023-08-31 14:51:03 +05:30
function App() {
2023-04-18 01:27:28 +05:30
const [permissions, setPermissions] = React.useState(true);
const modalRef = React.useRef<CodePushLoadingModalRef>(null);
2023-08-29 17:00:05 +05:30
const askForPermissions = async () => {
const permissionsToRequest = await getPermissionsToRequest();
2023-08-29 17:00:05 +05:30
if (Platform.OS === 'android') {
PermissionsAndroid.requestMultiple(permissionsToRequest)
2023-08-29 17:00:05 +05:30
.then(async (result) => {
let isAllPermissionsGranted = true;
for (const permission in result) {
if (result?.[permission as Permission] !== PermissionsAndroid.RESULTS.GRANTED) {
isAllPermissionsGranted = false;
break;
}
}
setPermissions(isAllPermissionsGranted);
})
.catch((err) => {
setPermissions(false);
});
}
};
const onSyncStatusChange = (syncStatus: codePush.SyncStatus) => {
switch (syncStatus) {
case codePush.SyncStatus.DOWNLOADING_PACKAGE:
modalRef.current?.show();
break;
case codePush.SyncStatus.INSTALLING_UPDATE:
addClickstreamEvent(CLICKSTREAM_EVENT_NAMES.FA_INSTALLING_CODEPUSH, {});
break;
case codePush.SyncStatus.UP_TO_DATE:
modalRef.current?.hide();
break;
2024-12-02 15:41:47 +05:30
case codePush.SyncStatus.UNKNOWN_ERROR:
addClickstreamEvent(CLICKSTREAM_EVENT_NAMES.FA_CODEPUSH_UNKNOWN_ERROR, {});
modalRef.current?.hide();
break;
default:
addClickstreamEvent(CLICKSTREAM_EVENT_NAMES.FA_CODEPUSH_DEFAULT_STATUS, {});
modalRef.current?.hide();
break;
}
};
const onDownloadProgress = (downloadProgress: DownloadProgress) => {
if (downloadProgress) {
modalRef.current?.updateProgress(downloadProgress);
}
};
2023-09-06 18:09:10 +05:30
const getActiveRouteName = (state) => {
if (!state || typeof state.index !== 'number') {
return 'Unknown';
}
const route = state.routes[state.index];
if (route.state) {
return getActiveRouteName(route.state);
}
return route?.name || '';
};
2023-09-19 12:49:35 +05:30
async function setForegroundTimeStampAndClickstream() {
const now = dayJs().toString();
await setItem(StorageKeys.APP_FOREGROUND_TIMESTAMP, now);
addClickstreamEvent(CLICKSTREAM_EVENT_NAMES.AV_APP_FOREGROUND, { now }, true);
}
useEffect(() => {
ScreenshotBlocker.unblockScreenshots();
2023-12-26 22:10:47 +05:30
getBuildFlavour().then((flavour) => {
setGlobalBuildFlavour(flavour);
});
2024-04-04 12:22:18 +05:30
// Device Details
2024-04-04 17:25:49 +05:30
sendDeviceDetailsToClickstream();
}, []);
2023-04-18 01:27:28 +05:30
React.useEffect(() => {
fetchUpdatedRemoteConfig();
askForPermissions();
2023-08-29 13:17:02 +05:30
const appStateChange = AppState.addEventListener('change', async (change) => {
2025-01-24 14:53:48 +05:30
if (change === AppStates.ACTIVE) {
2025-01-15 19:37:26 +05:30
askForPermissions();
if (GLOBAL.AGENT_ID) {
syncSelfCallData(GLOBAL.AGENT_ID);
}
2025-01-15 19:37:26 +05:30
}
handleAppStateChange(change, onSyncStatusChange, onDownloadProgress);
2023-09-13 14:50:17 +05:30
hydrateGlobalImageMap();
2023-04-18 01:27:28 +05:30
});
(async () => {
const data = await AsyncStorage.getItem(LocalStorageKeys.GLOBAL_DOCUMENT_MAP);
if (data) {
const parsedData = JSON.parse(data);
GlobalDocumentMap = parsedData;
}
})();
checkCodePushAndSync(onSyncStatusChange, onDownloadProgress);
2023-09-19 12:49:35 +05:30
setForegroundTimeStampAndClickstream();
2023-04-18 01:27:28 +05:30
return () => {
appStateChange.remove();
};
}, []);
return (
<Provider store={store}>
2023-09-07 13:34:19 +05:30
<PersistGate
loading={<FullScreenLoader loading isTranslucent={false} />}
persistor={persistor}
>
2023-08-31 14:51:03 +05:30
<NavigationContainer
2024-01-24 16:00:09 +05:30
linking={linkingConf}
2023-08-31 14:51:03 +05:30
ref={navigationRef}
onStateChange={async (state) => {
const currentRouteName = getActiveRouteName(state);
await analytics().logScreenView({
screen_name: currentRouteName,
screen_class: currentRouteName,
});
2023-08-31 14:51:03 +05:30
}}
>
2023-04-18 01:27:28 +05:30
<StatusBar backgroundColor={COLORS.BACKGROUND.INDIGO_DARK} />
<ErrorBoundary>{permissions ? <AuthRouter /> : <Permissions />}</ErrorBoundary>
2023-04-18 01:27:28 +05:30
</NavigationContainer>
2023-05-11 18:48:56 +05:30
<ToastContainer config={toastConfigs} position="top" topOffset={18} />
<CodePushLoadingModal ref={modalRef} />
2023-04-18 01:27:28 +05:30
</PersistGate>
</Provider>
);
2023-08-31 14:51:03 +05:30
}
2022-11-30 10:13:33 +05:30
export default App;