50 lines
1.6 KiB
TypeScript
50 lines
1.6 KiB
TypeScript
|
import { useFocusEffect } from '@react-navigation/native';
|
||
|
import { StackNavigationProp } from '@react-navigation/stack';
|
||
|
import React, { useCallback, useEffect } from 'react';
|
||
|
import { useDispatch } from 'react-redux';
|
||
|
|
||
|
import { initTroubleshootingNotification } from '../../actions/troubleshootingNotification';
|
||
|
import * as List from '../../containers/List';
|
||
|
import SafeAreaView from '../../containers/SafeAreaView';
|
||
|
import StatusBar from '../../containers/StatusBar';
|
||
|
import I18n from '../../i18n';
|
||
|
import { SettingsStackParamList } from '../../stacks/types';
|
||
|
// import CommunityEditionPushQuota from './components/CommunityEditionPushQuota';
|
||
|
import DeviceNotificationSettings from './components/DeviceNotificationSettings';
|
||
|
import NotificationDelay from './components/NotificationDelay';
|
||
|
import PushGatewayConnection from './components/PushGatewayConnection';
|
||
|
|
||
|
interface IPushTroubleshootViewProps {
|
||
|
navigation: StackNavigationProp<SettingsStackParamList, 'PushTroubleshootView'>;
|
||
|
}
|
||
|
|
||
|
const PushTroubleshootView = ({ navigation }: IPushTroubleshootViewProps): JSX.Element => {
|
||
|
const dispatch = useDispatch();
|
||
|
|
||
|
useFocusEffect(
|
||
|
useCallback(() => {
|
||
|
dispatch(initTroubleshootingNotification());
|
||
|
}, [])
|
||
|
);
|
||
|
|
||
|
useEffect(() => {
|
||
|
navigation.setOptions({
|
||
|
title: I18n.t('Push_Troubleshooting')
|
||
|
});
|
||
|
}, [navigation]);
|
||
|
|
||
|
return (
|
||
|
<SafeAreaView testID='push-troubleshoot-view'>
|
||
|
<StatusBar />
|
||
|
<List.Container testID='push-troubleshoot-view-list'>
|
||
|
<DeviceNotificationSettings />
|
||
|
{/* <CommunityEditionPushQuota /> */}
|
||
|
<PushGatewayConnection />
|
||
|
<NotificationDelay />
|
||
|
</List.Container>
|
||
|
</SafeAreaView>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default PushTroubleshootView;
|