Merge pull request #2779 from ecency/nt/waves-check-tab-active

checking new waves on tab reactive
This commit is contained in:
Feruz M 2023-10-17 13:32:58 +03:00 committed by GitHub
commit 65b0ff5c3b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,5 +1,5 @@
import React, { useEffect, useRef, useState } from 'react'; import React, { useEffect, useRef, useState } from 'react';
import { ActivityIndicator, NativeScrollEvent, NativeSyntheticEvent, RefreshControl, View, FlatList, AppState, Alert } from 'react-native'; import { ActivityIndicator, NativeScrollEvent, NativeSyntheticEvent, RefreshControl, View, FlatList, AppState } from 'react-native';
import { Comments, EmptyScreen, Header, PostOptionsModal } from '../../../components'; import { Comments, EmptyScreen, Header, PostOptionsModal } from '../../../components';
import styles from '../styles/wavesScreen.styles'; import styles from '../styles/wavesScreen.styles';
import { wavesQueries } from '../../../providers/queries'; import { wavesQueries } from '../../../providers/queries';
@ -8,29 +8,34 @@ import WavesHeader from '../children/wavesHeader';
import { PostTypes } from '../../../constants/postTypes'; import { PostTypes } from '../../../constants/postTypes';
import ScrollTopPopup from '../../../components/tabbedPosts/view/scrollTopPopup'; import ScrollTopPopup from '../../../components/tabbedPosts/view/scrollTopPopup';
import { debounce } from 'lodash'; import { debounce } from 'lodash';
import reactotron from 'reactotron-react-native'; import { useNavigationState } from '@react-navigation/native';
const SCROLL_POPUP_THRESHOLD = 5000; const SCROLL_POPUP_THRESHOLD = 5000;
const WavesScreen = () => { const WavesScreen = ({ route }) => {
//refs //refs
const postOptionsModalRef = useRef<any>(null); const postOptionsModalRef = useRef<any>(null);
const postsListRef = useRef<FlatList>(); const postsListRef = useRef<FlatList>();
const blockPopupRef = useRef(false); const blockPopupRef = useRef(false);
const scrollOffsetRef = useRef(0); const scrollOffsetRef = useRef(0);
const appState = useRef(AppState.currentState); const appState = useRef(AppState.currentState);
const isFirstRender = useRef(true);
const wavesQuery = wavesQueries.useWavesQuery('ecency.waves'); const wavesQuery = wavesQueries.useWavesQuery('ecency.waves');
const isDarkTheme = useAppSelector(state => state.application.isDarkTheme) const isDarkTheme = useAppSelector(state => state.application.isDarkTheme)
const navState = useNavigationState(state => state);
const [enableScrollTop, setEnableScrollTop] = useState(false); const [enableScrollTop, setEnableScrollTop] = useState(false);
const [popupAvatars, setPopupAvatars] = useState<any[]>([]) const [popupAvatars, setPopupAvatars] = useState<any[]>([])
useEffect(() => { useEffect(() => {
const _stateSub = AppState.addEventListener('change', _handleAppStateChange); const _stateSub = AppState.addEventListener('change', _handleAppStateChange);
return () => { return () => {
_stateSub.remove(); _stateSub.remove();
@ -38,6 +43,15 @@ const WavesScreen = () => {
}, []) }, [])
useEffect(() => {
if (navState.routeNames[navState.index] === route.name && !isFirstRender.current) {
_latestWavesCheck();
}
isFirstRender.current = false;
}, [navState.index])
//actions //actions
const _handleAppStateChange = async (nextAppState) => { const _handleAppStateChange = async (nextAppState) => {
@ -45,16 +59,21 @@ const WavesScreen = () => {
appState.current.match(/inactive|background/) && appState.current.match(/inactive|background/) &&
nextAppState === 'active' nextAppState === 'active'
) { ) {
const latestWaves = await wavesQuery.latestWavesFetch() _latestWavesCheck()
if (latestWaves.length > 0) {
setPopupAvatars(latestWaves.map((item) => item.avatar))
setEnableScrollTop(true)
}
} }
appState.current = nextAppState; appState.current = nextAppState;
}; };
const _latestWavesCheck = async () => {
const latestWaves = await wavesQuery.latestWavesFetch()
if (latestWaves.length > 0) {
setPopupAvatars(latestWaves.map((item) => item.avatar))
setEnableScrollTop(true)
}
}
const _fetchData = (fetchProps: any) => { const _fetchData = (fetchProps: any) => {
if (fetchProps?.refresh) { if (fetchProps?.refresh) {
wavesQuery.refresh(); wavesQuery.refresh();