From 7971274f719e44f45de7e3349b2b4a4a255abf01 Mon Sep 17 00:00:00 2001 From: cdOut <88325488+cdOut@users.noreply.github.com> Date: Thu, 15 Feb 2024 11:32:27 +0100 Subject: [PATCH] add offline support for switching between animation and video --- .../OnboardingWelcomeVideoModal.tsx | 40 +++++++++++++++++-- 1 file changed, 36 insertions(+), 4 deletions(-) diff --git a/src/components/OnboardingWelcomeVideoModal.tsx b/src/components/OnboardingWelcomeVideoModal.tsx index cfc9ed42a4a1..60052484c8ac 100644 --- a/src/components/OnboardingWelcomeVideoModal.tsx +++ b/src/components/OnboardingWelcomeVideoModal.tsx @@ -1,4 +1,4 @@ -import React, {useCallback, useState} from 'react'; +import React, {useCallback, useEffect, useState} from 'react'; import {View} from 'react-native'; import useLocalize from '@hooks/useLocalize'; import useNetwork from '@hooks/useNetwork'; @@ -17,43 +17,75 @@ const BASE_VIDEO_ASPECT_RATIO = 2; const MODAL_PADDING = 16; -type VideoLoadedEvent = { +type VideoLoadedEventType = { srcElement: { videoWidth: number; videoHeight: number; }; }; +type VideoPlaybackStatusEventType = { + isLoaded: boolean; +}; + +type VideoStatus = 'video' | 'animation'; + function OnboardingWelcomeVideoModal() { const {translate} = useLocalize(); const styles = useThemeStyles(); const {isSmallScreenWidth, windowHeight, windowWidth} = useWindowDimensions(); const [isModalOpen, setIsModalOpen] = useState(true); + const [welcomeVideoStatus, setWelcomeVideoStatus] = useState('video'); + const [isWelcomeVideoStatusLocked, setIsWelcomeVideoStatusLocked] = useState(false); + const [isVideoLoaded, setIsVideoLoaded] = useState(false); const [videoAspectRatio, setVideoAspectRatio] = useState(BASE_VIDEO_ASPECT_RATIO); const {isOffline} = useNetwork(); + useEffect(() => { + if (isWelcomeVideoStatusLocked) { + return; + } + + if (isOffline) { + setWelcomeVideoStatus('animation'); + setIsWelcomeVideoStatusLocked(true); + } else if (!isOffline && isVideoLoaded) { + setWelcomeVideoStatus('video'); + setIsWelcomeVideoStatusLocked(true); + } + }, [isOffline, isVideoLoaded, isWelcomeVideoStatusLocked]); + const closeModal = useCallback(() => { setIsModalOpen(false); }, []); - const onVideoLoaded = (e: VideoLoadedEvent) => { + const onVideoLoaded = (e: VideoLoadedEventType) => { setVideoAspectRatio(e.srcElement.videoWidth / e.srcElement.videoHeight); }; + const onPlaybackStatusUpdate = (e: VideoPlaybackStatusEventType) => { + if (e.isLoaded === isVideoLoaded) { + return; + } + setIsVideoLoaded(e.isLoaded); + }; + const getWelcomeVideo = () => { - if (!isOffline) { + if (welcomeVideoStatus === 'video') { let videoWidth = isSmallScreenWidth ? windowWidth - MODAL_PADDING : BASE_VIDEO_WIDTH; if (!videoWidth) { videoWidth = BASE_VIDEO_WIDTH; } + // Temporary file supplied for testing purposes, to be changed when correct one gets uploaded on backend return (