@zezosoft/zezo-ott-react-native-ui-kit 1.1.2 → 1.1.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/module/components/Auth/AuthProvider/AuthProvider.js +5 -2
- package/lib/module/components/Auth/AuthProvider/AuthProvider.js.map +1 -1
- package/lib/module/components/Auth/One/ForgotPassword/ForgotPassword.js +232 -0
- package/lib/module/components/Auth/One/ForgotPassword/ForgotPassword.js.map +1 -0
- package/lib/module/components/Auth/One/Login/LoginWithEmail.js +324 -0
- package/lib/module/components/Auth/One/Login/LoginWithEmail.js.map +1 -0
- package/lib/module/components/Auth/{Login → One/Login}/LoginWithPhone.js +13 -11
- package/lib/module/components/Auth/One/Login/LoginWithPhone.js.map +1 -0
- package/lib/module/components/Auth/One/OTP/OTP.js +301 -0
- package/lib/module/components/Auth/One/OTP/OTP.js.map +1 -0
- package/lib/module/components/Auth/One/QrLogin/QrLogin.js +479 -0
- package/lib/module/components/Auth/One/QrLogin/QrLogin.js.map +1 -0
- package/lib/module/components/Auth/One/QrLogin/components/QrViewArea.js +295 -0
- package/lib/module/components/Auth/One/QrLogin/components/QrViewArea.js.map +1 -0
- package/lib/module/components/Auth/One/SignUp/SignUp.js +362 -0
- package/lib/module/components/Auth/One/SignUp/SignUp.js.map +1 -0
- package/lib/module/components/Auth/{SplashScreen → One/SplashScreen}/SplashScreen.js +8 -5
- package/lib/module/components/Auth/One/SplashScreen/SplashScreen.js.map +1 -0
- package/lib/module/components/Auth/One/SplashScreen/components/SplashImage/SplashImage.js +80 -0
- package/lib/module/components/Auth/One/SplashScreen/components/SplashImage/SplashImage.js.map +1 -0
- package/lib/module/components/Auth/{SplashScreen → One/SplashScreen}/components/SplashLottie/SplashLottie.js +1 -1
- package/lib/module/components/Auth/One/SplashScreen/components/SplashLottie/SplashLottie.js.map +1 -0
- package/lib/module/components/Auth/{SplashScreen → One/SplashScreen}/components/SplashVideo/SplashVideo.js +42 -21
- package/lib/module/components/Auth/One/SplashScreen/components/SplashVideo/SplashVideo.js.map +1 -0
- package/lib/module/components/Auth/One/index.js +25 -0
- package/lib/module/components/Auth/One/index.js.map +1 -0
- package/lib/module/components/Auth/Two/AuthHeader/AuthHeader.js +93 -0
- package/lib/module/components/Auth/Two/AuthHeader/AuthHeader.js.map +1 -0
- package/lib/module/components/Auth/{ForgotPassword → Two/ForgotPassword}/ForgotPassword.js +55 -28
- package/lib/module/components/Auth/Two/ForgotPassword/ForgotPassword.js.map +1 -0
- package/lib/module/components/Auth/Two/Login/AuthLoginShell.js +138 -0
- package/lib/module/components/Auth/Two/Login/AuthLoginShell.js.map +1 -0
- package/lib/module/components/Auth/Two/Login/LoginWithEmail.js +226 -0
- package/lib/module/components/Auth/Two/Login/LoginWithEmail.js.map +1 -0
- package/lib/module/components/Auth/Two/Login/LoginWithPhone.js +143 -0
- package/lib/module/components/Auth/Two/Login/LoginWithPhone.js.map +1 -0
- package/lib/module/components/Auth/{OTP → Two/OTP}/OTP.js +93 -63
- package/lib/module/components/Auth/Two/OTP/OTP.js.map +1 -0
- package/lib/module/components/Auth/Two/QrLogin/QrLogin.js +479 -0
- package/lib/module/components/Auth/Two/QrLogin/QrLogin.js.map +1 -0
- package/lib/module/components/Auth/Two/QrLogin/components/QrViewArea.js +295 -0
- package/lib/module/components/Auth/Two/QrLogin/components/QrViewArea.js.map +1 -0
- package/lib/module/components/Auth/Two/SignUp/SignUp.js +379 -0
- package/lib/module/components/Auth/Two/SignUp/SignUp.js.map +1 -0
- package/lib/module/components/Auth/Two/SplashScreen/SplashScreen.js +141 -0
- package/lib/module/components/Auth/Two/SplashScreen/SplashScreen.js.map +1 -0
- package/lib/module/components/Auth/{SplashScreen → Two/SplashScreen}/components/SplashImage/SplashImage.js +1 -1
- package/lib/module/components/Auth/Two/SplashScreen/components/SplashImage/SplashImage.js.map +1 -0
- package/lib/module/components/Auth/Two/SplashScreen/components/SplashLottie/SplashLottie.js +63 -0
- package/lib/module/components/Auth/Two/SplashScreen/components/SplashLottie/SplashLottie.js.map +1 -0
- package/lib/module/components/Auth/Two/SplashScreen/components/SplashVideo/SplashVideo.js +157 -0
- package/lib/module/components/Auth/Two/SplashScreen/components/SplashVideo/SplashVideo.js.map +1 -0
- package/lib/module/components/Auth/Two/index.js +29 -0
- package/lib/module/components/Auth/Two/index.js.map +1 -0
- package/lib/module/components/Auth/index.js +7 -22
- package/lib/module/components/Auth/index.js.map +1 -1
- package/lib/module/components/BackgroundLayout/BackgroundLayout.js +7 -3
- package/lib/module/components/BackgroundLayout/BackgroundLayout.js.map +1 -1
- package/lib/module/components/BackgroundLayout/BackgroundLayoutOne.js +52 -0
- package/lib/module/components/BackgroundLayout/BackgroundLayoutOne.js.map +1 -0
- package/lib/module/components/BottomSheet/BottomSheet.js +7 -3
- package/lib/module/components/BottomSheet/BottomSheet.js.map +1 -1
- package/lib/module/components/BottomSheet/BottomSheetOne.js +170 -0
- package/lib/module/components/BottomSheet/BottomSheetOne.js.map +1 -0
- package/lib/module/components/BottomSheet/index.js +1 -0
- package/lib/module/components/BottomSheet/index.js.map +1 -1
- package/lib/module/components/Button/PrimaryBtn.js +16 -6
- package/lib/module/components/Button/PrimaryBtn.js.map +1 -1
- package/lib/module/components/Content/Card/Category/Category.js +88 -13
- package/lib/module/components/Content/Card/Category/Category.js.map +1 -1
- package/lib/module/components/Content/Card/Category/CategroyTwo.js +287 -0
- package/lib/module/components/Content/Card/Category/CategroyTwo.js.map +1 -0
- package/lib/module/components/Content/Card/NowWatching/NowWatching.js +237 -108
- package/lib/module/components/Content/Card/NowWatching/NowWatching.js.map +1 -1
- package/lib/module/components/Content/Card/Sliders/Styles/One.js +191 -132
- package/lib/module/components/Content/Card/Sliders/Styles/One.js.map +1 -1
- package/lib/module/components/Content/Card/Sliders/Styles/Three.js +714 -0
- package/lib/module/components/Content/Card/Sliders/Styles/Three.js.map +1 -0
- package/lib/module/components/Content/Card/Sliders/Styles/Two.js +139 -92
- package/lib/module/components/Content/Card/Sliders/Styles/Two.js.map +1 -1
- package/lib/module/components/Content/Card/Sliders/index.js +3 -1
- package/lib/module/components/Content/Card/Sliders/index.js.map +1 -1
- package/lib/module/components/Content/Card/Styles/Five.js +132 -48
- package/lib/module/components/Content/Card/Styles/Five.js.map +1 -1
- package/lib/module/components/Content/Card/Styles/Four.js +127 -59
- package/lib/module/components/Content/Card/Styles/Four.js.map +1 -1
- package/lib/module/components/Content/Card/Styles/One.js +126 -50
- package/lib/module/components/Content/Card/Styles/One.js.map +1 -1
- package/lib/module/components/Content/Card/Styles/RotateInOut.js +139 -53
- package/lib/module/components/Content/Card/Styles/RotateInOut.js.map +1 -1
- package/lib/module/components/Content/Card/Styles/Six.js +207 -115
- package/lib/module/components/Content/Card/Styles/Six.js.map +1 -1
- package/lib/module/components/Content/Card/Styles/Three.js +119 -94
- package/lib/module/components/Content/Card/Styles/Three.js.map +1 -1
- package/lib/module/components/Content/Card/Styles/TopTen.js +187 -171
- package/lib/module/components/Content/Card/Styles/TopTen.js.map +1 -1
- package/lib/module/components/Content/Card/Styles/Two.js +145 -64
- package/lib/module/components/Content/Card/Styles/Two.js.map +1 -1
- package/lib/module/components/Content/Card/components/AdsPoster.js +162 -0
- package/lib/module/components/Content/Card/components/AdsPoster.js.map +1 -0
- package/lib/module/components/Content/Card/components/CardPoster.js +217 -135
- package/lib/module/components/Content/Card/components/CardPoster.js.map +1 -1
- package/lib/module/components/Content/Card/components/NavigateToMore.js +26 -2
- package/lib/module/components/Content/Card/components/NavigateToMore.js.map +1 -1
- package/lib/module/components/Content/Card/components/index.js +4 -0
- package/lib/module/components/Content/Card/components/index.js.map +1 -0
- package/lib/module/components/Content/Content.js +90 -33
- package/lib/module/components/Content/Content.js.map +1 -1
- package/lib/module/components/Content/Sections.js +41 -11
- package/lib/module/components/Content/Sections.js.map +1 -1
- package/lib/module/components/Content/types.js +4 -0
- package/lib/module/components/Content/types.js.map +1 -0
- package/lib/module/components/ContentView/MoreContentList.js +1 -0
- package/lib/module/components/ContentView/MoreContentList.js.map +1 -1
- package/lib/module/components/ContentView/{ContentView.js → One/ContentViewOne.js} +6 -5
- package/lib/module/components/ContentView/One/ContentViewOne.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/AboutSection.js +2 -2
- package/lib/module/components/ContentView/One/components/AboutSection.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/CastCard.js +2 -2
- package/lib/module/components/ContentView/One/components/CastCard.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/EpisodeCard.js +5 -6
- package/lib/module/components/ContentView/One/components/EpisodeCard.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/GenreTags.js +2 -2
- package/lib/module/components/ContentView/One/components/GenreTags.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/HeroBanner.js +45 -44
- package/lib/module/components/ContentView/One/components/HeroBanner.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/MiniInfo.js +50 -5
- package/lib/module/components/ContentView/One/components/MiniInfo.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/PlayButton.js +1 -1
- package/lib/module/components/ContentView/One/components/PlayButton.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/Title.js +1 -1
- package/lib/module/components/ContentView/One/components/Title.js.map +1 -0
- package/lib/module/components/ContentView/{components → One/components}/TrailerButton.js +2 -2
- package/lib/module/components/ContentView/One/components/TrailerButton.js.map +1 -0
- package/lib/module/components/ContentView/Two/ContentViewTwo.js +220 -0
- package/lib/module/components/ContentView/Two/ContentViewTwo.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/AboutSection.js +150 -0
- package/lib/module/components/ContentView/Two/components/AboutSection.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/Details.js +156 -0
- package/lib/module/components/ContentView/Two/components/Details.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/EpisodeCard.js +425 -0
- package/lib/module/components/ContentView/Two/components/EpisodeCard.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/GenreTags.js +86 -0
- package/lib/module/components/ContentView/Two/components/GenreTags.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/HeroBanner.js +339 -0
- package/lib/module/components/ContentView/Two/components/HeroBanner.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/LikeShareActions.js +88 -0
- package/lib/module/components/ContentView/Two/components/LikeShareActions.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/MoreLikeThisContentList .js +235 -0
- package/lib/module/components/ContentView/Two/components/MoreLikeThisContentList .js.map +1 -0
- package/lib/module/components/ContentView/Two/components/PlayOrTrailer.js +120 -0
- package/lib/module/components/ContentView/Two/components/PlayOrTrailer.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/SectionTabs.js +112 -0
- package/lib/module/components/ContentView/Two/components/SectionTabs.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/Title.js +146 -0
- package/lib/module/components/ContentView/Two/components/Title.js.map +1 -0
- package/lib/module/components/ContentView/Two/components/index.js +18 -0
- package/lib/module/components/ContentView/Two/components/index.js.map +1 -0
- package/lib/module/components/ContentView/index.js +6 -1
- package/lib/module/components/ContentView/index.js.map +1 -1
- package/lib/module/components/Headers/Four.js +68 -0
- package/lib/module/components/Headers/Four.js.map +1 -0
- package/lib/module/components/Headers/Three.js +75 -24
- package/lib/module/components/Headers/Three.js.map +1 -1
- package/lib/module/components/Headers/index.js +3 -1
- package/lib/module/components/Headers/index.js.map +1 -1
- package/lib/module/components/Input/Input.js +5 -1
- package/lib/module/components/Input/Input.js.map +1 -1
- package/lib/module/components/Input/InputThree.js +157 -0
- package/lib/module/components/Input/InputThree.js.map +1 -0
- package/lib/module/components/Input/PhoneNumberInput.js.map +1 -1
- package/lib/module/components/Input/PhoneNumberInputTwo.js +316 -0
- package/lib/module/components/Input/PhoneNumberInputTwo.js.map +1 -0
- package/lib/module/components/Loader/Loader.js +14 -6
- package/lib/module/components/Loader/Loader.js.map +1 -1
- package/lib/module/components/Logo/Logo.js +42 -17
- package/lib/module/components/Logo/Logo.js.map +1 -1
- package/lib/module/components/NewRelease/NewReleaseSheet.js +227 -0
- package/lib/module/components/NewRelease/NewReleaseSheet.js.map +1 -0
- package/lib/module/components/NewRelease/index.js +4 -0
- package/lib/module/components/NewRelease/index.js.map +1 -0
- package/lib/module/components/Reels/ReelsSeries/MediaControls/BottomControls.js +92 -17
- package/lib/module/components/Reels/ReelsSeries/MediaControls/BottomControls.js.map +1 -1
- package/lib/module/components/Reels/ReelsSeries/MediaControls/MediaControlsProvider.js +65 -2
- package/lib/module/components/Reels/ReelsSeries/MediaControls/MediaControlsProvider.js.map +1 -1
- package/lib/module/components/Reels/ReelsSeries/MediaControls/RightControls.js +2 -1
- package/lib/module/components/Reels/ReelsSeries/MediaControls/RightControls.js.map +1 -1
- package/lib/module/components/Reels/ReelsSeries/Model/SettingModal.js +4 -2
- package/lib/module/components/Reels/ReelsSeries/Model/SettingModal.js.map +1 -1
- package/lib/module/components/Reels/ReelsSeries/ReelsSeries.js +80 -46
- package/lib/module/components/Reels/ReelsSeries/ReelsSeries.js.map +1 -1
- package/lib/module/components/Reels/ReelsSeries/ReelsSeriesItem.js +78 -29
- package/lib/module/components/Reels/ReelsSeries/ReelsSeriesItem.js.map +1 -1
- package/lib/module/components/Reels/ReelsSeries/components/VideoControls/QualityControl.js +21 -34
- package/lib/module/components/Reels/ReelsSeries/components/VideoControls/QualityControl.js.map +1 -1
- package/lib/module/components/Reels/ReelsSeries/useReelsWatchProgress.js +58 -0
- package/lib/module/components/Reels/ReelsSeries/useReelsWatchProgress.js.map +1 -0
- package/lib/module/components/Reels/ReelsSeries/utils/quality.js +44 -0
- package/lib/module/components/Reels/ReelsSeries/utils/quality.js.map +1 -0
- package/lib/module/components/Reels/index.js +1 -0
- package/lib/module/components/Reels/index.js.map +1 -1
- package/lib/module/components/Search/One.js +7 -4
- package/lib/module/components/Search/One.js.map +1 -1
- package/lib/module/components/Search/components/SearchCard.js +59 -7
- package/lib/module/components/Search/components/SearchCard.js.map +1 -1
- package/lib/module/components/User/PurchaseHistory/PurchaseHistory.js +2 -1
- package/lib/module/components/User/PurchaseHistory/PurchaseHistory.js.map +1 -1
- package/lib/module/components/User/WatchHistory/WatchHistory.js +1 -0
- package/lib/module/components/User/WatchHistory/WatchHistory.js.map +1 -1
- package/lib/module/components/User/WatchLater/WatchLater.js +1 -0
- package/lib/module/components/User/WatchLater/WatchLater.js.map +1 -1
- package/lib/module/components/common/AppStatusBar.js +2 -1
- package/lib/module/components/common/AppStatusBar.js.map +1 -1
- package/lib/module/components/index.js +1 -0
- package/lib/module/components/index.js.map +1 -1
- package/lib/module/constants/dummySections.js +47 -5
- package/lib/module/constants/dummySections.js.map +1 -1
- package/lib/module/hooks/Images/index.js +5 -0
- package/lib/module/hooks/Images/index.js.map +1 -0
- package/lib/module/hooks/Images/useImageLoader.js +168 -0
- package/lib/module/hooks/Images/useImageLoader.js.map +1 -0
- package/lib/module/hooks/Images/useImageValidation.js +36 -0
- package/lib/module/hooks/Images/useImageValidation.js.map +1 -0
- package/lib/module/hooks/index.js +3 -0
- package/lib/module/hooks/index.js.map +1 -1
- package/lib/module/hooks/useAdTracking.js +270 -0
- package/lib/module/hooks/useAdTracking.js.map +1 -0
- package/lib/module/hooks/useCards.js +164 -0
- package/lib/module/hooks/useCards.js.map +1 -0
- package/lib/module/hooks/usePaginatedSection.js +11 -6
- package/lib/module/hooks/usePaginatedSection.js.map +1 -1
- package/lib/module/hooks/useSplashCache.js +78 -60
- package/lib/module/hooks/useSplashCache.js.map +1 -1
- package/lib/module/theme/ThemeProvider.js +14 -2
- package/lib/module/theme/ThemeProvider.js.map +1 -1
- package/lib/module/theme/hook/index.js +0 -1
- package/lib/module/theme/hook/index.js.map +1 -1
- package/lib/module/theme/hook/useInternalTheme.js +21 -7
- package/lib/module/theme/hook/useInternalTheme.js.map +1 -1
- package/lib/module/theme/themes.js +2 -0
- package/lib/module/theme/themes.js.map +1 -1
- package/lib/module/theme/utils/validateColor.js +84 -0
- package/lib/module/theme/utils/validateColor.js.map +1 -0
- package/lib/module/utils/colorUtils.js +68 -0
- package/lib/module/utils/colorUtils.js.map +1 -0
- package/lib/typescript/src/components/Auth/{ForgotPassword → One/ForgotPassword}/ForgotPassword.d.ts +1 -1
- package/lib/typescript/src/components/Auth/One/ForgotPassword/ForgotPassword.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/{Login → One/Login}/LoginWithEmail.d.ts +1 -1
- package/lib/typescript/src/components/Auth/One/Login/LoginWithEmail.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/{Login → One/Login}/LoginWithPhone.d.ts +1 -1
- package/lib/typescript/src/components/Auth/One/Login/LoginWithPhone.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/{OTP → One/OTP}/OTP.d.ts +1 -1
- package/lib/typescript/src/components/Auth/One/OTP/OTP.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/{QrLogin → One/QrLogin}/QrLogin.d.ts +3 -1
- package/lib/typescript/src/components/Auth/One/QrLogin/QrLogin.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/{QrLogin → One/QrLogin}/components/QrViewArea.d.ts +1 -1
- package/lib/typescript/src/components/Auth/One/QrLogin/components/QrViewArea.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/{SignUp → One/SignUp}/SignUp.d.ts +1 -1
- package/lib/typescript/src/components/Auth/One/SignUp/SignUp.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/{SplashScreen → One/SplashScreen}/SplashScreen.d.ts +1 -1
- package/lib/typescript/src/components/Auth/One/SplashScreen/SplashScreen.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/One/SplashScreen/components/SplashImage/SplashImage.d.ts +14 -0
- package/lib/typescript/src/components/Auth/One/SplashScreen/components/SplashImage/SplashImage.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/One/SplashScreen/components/SplashLottie/SplashLottie.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/One/SplashScreen/components/SplashVideo/SplashVideo.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/One/index.d.ts +234 -0
- package/lib/typescript/src/components/Auth/One/index.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/AuthHeader/AuthHeader.d.ts +16 -0
- package/lib/typescript/src/components/Auth/Two/AuthHeader/AuthHeader.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/ForgotPassword/ForgotPassword.d.ts +53 -0
- package/lib/typescript/src/components/Auth/Two/ForgotPassword/ForgotPassword.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/Login/AuthLoginShell.d.ts +17 -0
- package/lib/typescript/src/components/Auth/Two/Login/AuthLoginShell.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/Login/LoginWithEmail.d.ts +52 -0
- package/lib/typescript/src/components/Auth/Two/Login/LoginWithEmail.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/Login/LoginWithPhone.d.ts +37 -0
- package/lib/typescript/src/components/Auth/Two/Login/LoginWithPhone.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/OTP/OTP.d.ts +63 -0
- package/lib/typescript/src/components/Auth/Two/OTP/OTP.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/QrLogin/QrLogin.d.ts +19 -0
- package/lib/typescript/src/components/Auth/Two/QrLogin/QrLogin.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/QrLogin/components/QrViewArea.d.ts +14 -0
- package/lib/typescript/src/components/Auth/Two/QrLogin/components/QrViewArea.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/SignUp/SignUp.d.ts +67 -0
- package/lib/typescript/src/components/Auth/Two/SignUp/SignUp.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/SplashScreen/SplashScreen.d.ts +35 -0
- package/lib/typescript/src/components/Auth/Two/SplashScreen/SplashScreen.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/SplashScreen/components/SplashImage/SplashImage.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/SplashScreen/components/SplashLottie/SplashLottie.d.ts +17 -0
- package/lib/typescript/src/components/Auth/Two/SplashScreen/components/SplashLottie/SplashLottie.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/SplashScreen/components/SplashVideo/SplashVideo.d.ts +20 -0
- package/lib/typescript/src/components/Auth/Two/SplashScreen/components/SplashVideo/SplashVideo.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/Two/index.d.ts +220 -0
- package/lib/typescript/src/components/Auth/Two/index.d.ts.map +1 -0
- package/lib/typescript/src/components/Auth/index.d.ts +447 -232
- package/lib/typescript/src/components/Auth/index.d.ts.map +1 -1
- package/lib/typescript/src/components/BackgroundLayout/BackgroundLayout.d.ts.map +1 -1
- package/lib/typescript/src/components/BackgroundLayout/BackgroundLayoutOne.d.ts +7 -0
- package/lib/typescript/src/components/BackgroundLayout/BackgroundLayoutOne.d.ts.map +1 -0
- package/lib/typescript/src/components/BottomSheet/BottomSheet.d.ts.map +1 -1
- package/lib/typescript/src/components/BottomSheet/BottomSheetOne.d.ts +19 -0
- package/lib/typescript/src/components/BottomSheet/BottomSheetOne.d.ts.map +1 -0
- package/lib/typescript/src/components/BottomSheet/index.d.ts +2 -0
- package/lib/typescript/src/components/BottomSheet/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Button/PrimaryBtn.d.ts +1 -0
- package/lib/typescript/src/components/Button/PrimaryBtn.d.ts.map +1 -1
- package/lib/typescript/src/components/Button/index.d.ts +1 -0
- package/lib/typescript/src/components/Button/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Category/Category.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Category/CategroyTwo.d.ts +26 -0
- package/lib/typescript/src/components/Content/Card/Category/CategroyTwo.d.ts.map +1 -0
- package/lib/typescript/src/components/Content/Card/NowWatching/NowWatching.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Sliders/Styles/One.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Sliders/Styles/Three.d.ts +19 -0
- package/lib/typescript/src/components/Content/Card/Sliders/Styles/Three.d.ts.map +1 -0
- package/lib/typescript/src/components/Content/Card/Sliders/Styles/Two.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Sliders/index.d.ts +11 -0
- package/lib/typescript/src/components/Content/Card/Sliders/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Styles/Five.d.ts +13 -1
- package/lib/typescript/src/components/Content/Card/Styles/Five.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Styles/Four.d.ts +13 -1
- package/lib/typescript/src/components/Content/Card/Styles/Four.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Styles/One.d.ts +15 -3
- package/lib/typescript/src/components/Content/Card/Styles/One.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Styles/RotateInOut.d.ts +13 -1
- package/lib/typescript/src/components/Content/Card/Styles/RotateInOut.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Styles/Six.d.ts +1 -0
- package/lib/typescript/src/components/Content/Card/Styles/Six.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Styles/Three.d.ts +13 -5
- package/lib/typescript/src/components/Content/Card/Styles/Three.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Styles/TopTen.d.ts +1 -0
- package/lib/typescript/src/components/Content/Card/Styles/TopTen.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/Styles/Two.d.ts +13 -1
- package/lib/typescript/src/components/Content/Card/Styles/Two.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/components/AdsPoster.d.ts +26 -0
- package/lib/typescript/src/components/Content/Card/components/AdsPoster.d.ts.map +1 -0
- package/lib/typescript/src/components/Content/Card/components/CardPoster.d.ts +4 -1
- package/lib/typescript/src/components/Content/Card/components/CardPoster.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/components/NavigateToMore.d.ts +3 -0
- package/lib/typescript/src/components/Content/Card/components/NavigateToMore.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Card/components/index.d.ts +2 -0
- package/lib/typescript/src/components/Content/Card/components/index.d.ts.map +1 -0
- package/lib/typescript/src/components/Content/Card/index.d.ts +76 -6
- package/lib/typescript/src/components/Content/Card/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Content.d.ts +2 -51
- package/lib/typescript/src/components/Content/Content.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/Sections.d.ts +2 -39
- package/lib/typescript/src/components/Content/Sections.d.ts.map +1 -1
- package/lib/typescript/src/components/Content/types.d.ts +149 -0
- package/lib/typescript/src/components/Content/types.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/MoreContentList.d.ts.map +1 -1
- package/lib/typescript/src/components/ContentView/One/ContentViewOne.d.ts +15 -0
- package/lib/typescript/src/components/ContentView/One/ContentViewOne.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/{components → One/components}/AboutSection.d.ts +1 -1
- package/lib/typescript/src/components/ContentView/One/components/AboutSection.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/{components → One/components}/CastCard.d.ts +1 -1
- package/lib/typescript/src/components/ContentView/One/components/CastCard.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/{components → One/components}/EpisodeCard.d.ts +1 -1
- package/lib/typescript/src/components/ContentView/One/components/EpisodeCard.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/{components → One/components}/GenreTags.d.ts +1 -1
- package/lib/typescript/src/components/ContentView/One/components/GenreTags.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/{components → One/components}/HeroBanner.d.ts +1 -1
- package/lib/typescript/src/components/ContentView/One/components/HeroBanner.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/{components → One/components}/MiniInfo.d.ts +1 -1
- package/lib/typescript/src/components/ContentView/One/components/MiniInfo.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/One/components/PlayButton.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/{components → One/components}/Title.d.ts +1 -1
- package/lib/typescript/src/components/ContentView/One/components/Title.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/One/components/TrailerButton.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/ContentViewTwo.d.ts +18 -0
- package/lib/typescript/src/components/ContentView/Two/ContentViewTwo.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/AboutSection.d.ts +27 -0
- package/lib/typescript/src/components/ContentView/Two/components/AboutSection.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/Details.d.ts +15 -0
- package/lib/typescript/src/components/ContentView/Two/components/Details.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/EpisodeCard.d.ts +23 -0
- package/lib/typescript/src/components/ContentView/Two/components/EpisodeCard.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/GenreTags.d.ts +22 -0
- package/lib/typescript/src/components/ContentView/Two/components/GenreTags.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/HeroBanner.d.ts +8 -0
- package/lib/typescript/src/components/ContentView/Two/components/HeroBanner.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/LikeShareActions.d.ts +25 -0
- package/lib/typescript/src/components/ContentView/Two/components/LikeShareActions.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/MoreLikeThisContentList .d.ts +26 -0
- package/lib/typescript/src/components/ContentView/Two/components/MoreLikeThisContentList .d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/PlayOrTrailer.d.ts +21 -0
- package/lib/typescript/src/components/ContentView/Two/components/PlayOrTrailer.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/SectionTabs.d.ts +28 -0
- package/lib/typescript/src/components/ContentView/Two/components/SectionTabs.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/Title.d.ts +34 -0
- package/lib/typescript/src/components/ContentView/Two/components/Title.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/Two/components/index.d.ts +15 -0
- package/lib/typescript/src/components/ContentView/Two/components/index.d.ts.map +1 -0
- package/lib/typescript/src/components/ContentView/index.d.ts +6 -1
- package/lib/typescript/src/components/ContentView/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Headers/Four.d.ts +18 -0
- package/lib/typescript/src/components/Headers/Four.d.ts.map +1 -0
- package/lib/typescript/src/components/Headers/Three.d.ts +9 -1
- package/lib/typescript/src/components/Headers/Three.d.ts.map +1 -1
- package/lib/typescript/src/components/Headers/index.d.ts +1 -0
- package/lib/typescript/src/components/Headers/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Input/Input.d.ts +2 -0
- package/lib/typescript/src/components/Input/Input.d.ts.map +1 -1
- package/lib/typescript/src/components/Input/InputThree.d.ts +22 -0
- package/lib/typescript/src/components/Input/InputThree.d.ts.map +1 -0
- package/lib/typescript/src/components/Input/PhoneNumberInput.d.ts.map +1 -1
- package/lib/typescript/src/components/Input/PhoneNumberInputTwo.d.ts +26 -0
- package/lib/typescript/src/components/Input/PhoneNumberInputTwo.d.ts.map +1 -0
- package/lib/typescript/src/components/Loader/Loader.d.ts +2 -0
- package/lib/typescript/src/components/Loader/Loader.d.ts.map +1 -1
- package/lib/typescript/src/components/Logo/Logo.d.ts +1 -1
- package/lib/typescript/src/components/Logo/Logo.d.ts.map +1 -1
- package/lib/typescript/src/components/NewRelease/NewReleaseSheet.d.ts +10 -0
- package/lib/typescript/src/components/NewRelease/NewReleaseSheet.d.ts.map +1 -0
- package/lib/typescript/src/components/NewRelease/index.d.ts +2 -0
- package/lib/typescript/src/components/NewRelease/index.d.ts.map +1 -0
- package/lib/typescript/src/components/Reels/ReelsSeries/MediaControls/BottomControls.d.ts +2 -0
- package/lib/typescript/src/components/Reels/ReelsSeries/MediaControls/BottomControls.d.ts.map +1 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/MediaControls/MediaControlsProvider.d.ts +1 -0
- package/lib/typescript/src/components/Reels/ReelsSeries/MediaControls/MediaControlsProvider.d.ts.map +1 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/MediaControls/RightControls.d.ts.map +1 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/Model/SettingModal.d.ts +2 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/Model/SettingModal.d.ts.map +1 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/ReelsSeries.d.ts +9 -2
- package/lib/typescript/src/components/Reels/ReelsSeries/ReelsSeries.d.ts.map +1 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/ReelsSeriesItem.d.ts +11 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/ReelsSeriesItem.d.ts.map +1 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/components/VideoControls/QualityControl.d.ts +11 -0
- package/lib/typescript/src/components/Reels/ReelsSeries/components/VideoControls/QualityControl.d.ts.map +1 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/types.d.ts +15 -0
- package/lib/typescript/src/components/Reels/ReelsSeries/types.d.ts.map +1 -1
- package/lib/typescript/src/components/Reels/ReelsSeries/useReelsWatchProgress.d.ts +34 -0
- package/lib/typescript/src/components/Reels/ReelsSeries/useReelsWatchProgress.d.ts.map +1 -0
- package/lib/typescript/src/components/Reels/ReelsSeries/utils/quality.d.ts +10 -0
- package/lib/typescript/src/components/Reels/ReelsSeries/utils/quality.d.ts.map +1 -0
- package/lib/typescript/src/components/Reels/index.d.ts +1 -0
- package/lib/typescript/src/components/Reels/index.d.ts.map +1 -1
- package/lib/typescript/src/components/Search/One.d.ts.map +1 -1
- package/lib/typescript/src/components/Search/components/SearchCard.d.ts +1 -0
- package/lib/typescript/src/components/Search/components/SearchCard.d.ts.map +1 -1
- package/lib/typescript/src/components/User/PurchaseHistory/PurchaseHistory.d.ts.map +1 -1
- package/lib/typescript/src/components/User/WatchHistory/WatchHistory.d.ts.map +1 -1
- package/lib/typescript/src/components/User/WatchLater/WatchLater.d.ts.map +1 -1
- package/lib/typescript/src/components/common/AppStatusBar.d.ts +1 -0
- package/lib/typescript/src/components/common/AppStatusBar.d.ts.map +1 -1
- package/lib/typescript/src/components/index.d.ts +1 -0
- package/lib/typescript/src/components/index.d.ts.map +1 -1
- package/lib/typescript/src/constants/dummySections.d.ts +8 -1
- package/lib/typescript/src/constants/dummySections.d.ts.map +1 -1
- package/lib/typescript/src/hooks/Images/index.d.ts +3 -0
- package/lib/typescript/src/hooks/Images/index.d.ts.map +1 -0
- package/lib/typescript/src/hooks/Images/useImageLoader.d.ts +36 -0
- package/lib/typescript/src/hooks/Images/useImageLoader.d.ts.map +1 -0
- package/lib/typescript/src/hooks/Images/useImageValidation.d.ts +17 -0
- package/lib/typescript/src/hooks/Images/useImageValidation.d.ts.map +1 -0
- package/lib/typescript/src/hooks/index.d.ts +3 -0
- package/lib/typescript/src/hooks/index.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useAdTracking.d.ts +39 -0
- package/lib/typescript/src/hooks/useAdTracking.d.ts.map +1 -0
- package/lib/typescript/src/hooks/useCards.d.ts +36 -0
- package/lib/typescript/src/hooks/useCards.d.ts.map +1 -0
- package/lib/typescript/src/hooks/usePaginatedSection.d.ts +12 -2
- package/lib/typescript/src/hooks/usePaginatedSection.d.ts.map +1 -1
- package/lib/typescript/src/hooks/useSplashCache.d.ts.map +1 -1
- package/lib/typescript/src/theme/ThemeProvider.d.ts +2 -0
- package/lib/typescript/src/theme/ThemeProvider.d.ts.map +1 -1
- package/lib/typescript/src/theme/hook/index.d.ts +0 -1
- package/lib/typescript/src/theme/hook/index.d.ts.map +1 -1
- package/lib/typescript/src/theme/hook/useInternalTheme.d.ts.map +1 -1
- package/lib/typescript/src/theme/themes.d.ts +1 -0
- package/lib/typescript/src/theme/themes.d.ts.map +1 -1
- package/lib/typescript/src/theme/utils/validateColor.d.ts +21 -0
- package/lib/typescript/src/theme/utils/validateColor.d.ts.map +1 -0
- package/lib/typescript/src/types/content/content-view.types.d.ts +40 -1
- package/lib/typescript/src/types/content/content-view.types.d.ts.map +1 -1
- package/lib/typescript/src/types/sections/index.d.ts +7 -4
- package/lib/typescript/src/types/sections/index.d.ts.map +1 -1
- package/lib/typescript/src/utils/colorUtils.d.ts +19 -0
- package/lib/typescript/src/utils/colorUtils.d.ts.map +1 -0
- package/package.json +13 -4
- package/src/components/Auth/AuthProvider/AuthProvider.tsx +6 -2
- package/src/components/Auth/One/ForgotPassword/ForgotPassword.tsx +324 -0
- package/src/components/Auth/One/Login/LoginWithEmail.tsx +455 -0
- package/src/components/Auth/{Login → One/Login}/LoginWithPhone.tsx +12 -12
- package/src/components/Auth/One/OTP/OTP.tsx +465 -0
- package/src/components/Auth/One/QrLogin/QrLogin.tsx +602 -0
- package/src/components/Auth/One/QrLogin/components/QrViewArea.tsx +423 -0
- package/src/components/Auth/One/SignUp/SignUp.tsx +479 -0
- package/src/components/Auth/{SplashScreen → One/SplashScreen}/SplashScreen.tsx +10 -6
- package/src/components/Auth/One/SplashScreen/components/SplashImage/SplashImage.tsx +103 -0
- package/src/components/Auth/{SplashScreen → One/SplashScreen}/components/SplashLottie/SplashLottie.tsx +1 -1
- package/src/components/Auth/{SplashScreen → One/SplashScreen}/components/SplashVideo/SplashVideo.tsx +35 -25
- package/src/components/Auth/One/index.ts +24 -0
- package/src/components/Auth/Two/AuthHeader/AuthHeader.tsx +108 -0
- package/src/components/Auth/{ForgotPassword → Two/ForgotPassword}/ForgotPassword.tsx +62 -35
- package/src/components/Auth/Two/Login/AuthLoginShell.tsx +173 -0
- package/src/components/Auth/Two/Login/LoginWithEmail.tsx +279 -0
- package/src/components/Auth/Two/Login/LoginWithPhone.tsx +188 -0
- package/src/components/Auth/{OTP → Two/OTP}/OTP.tsx +92 -81
- package/src/components/Auth/Two/QrLogin/QrLogin.tsx +602 -0
- package/src/components/Auth/Two/QrLogin/components/QrViewArea.tsx +423 -0
- package/src/components/Auth/Two/SignUp/SignUp.tsx +472 -0
- package/src/components/Auth/Two/SplashScreen/SplashScreen.tsx +248 -0
- package/src/components/Auth/{SplashScreen → Two/SplashScreen}/components/SplashImage/SplashImage.tsx +1 -1
- package/src/components/Auth/Two/SplashScreen/components/SplashLottie/SplashLottie.tsx +77 -0
- package/src/components/Auth/Two/SplashScreen/components/SplashVideo/SplashVideo.tsx +178 -0
- package/src/components/Auth/Two/index.ts +28 -0
- package/src/components/Auth/index.ts +7 -22
- package/src/components/BackgroundLayout/BackgroundLayout.tsx +2 -0
- package/src/components/BackgroundLayout/BackgroundLayoutOne.tsx +56 -0
- package/src/components/BottomSheet/BottomSheet.tsx +6 -1
- package/src/components/BottomSheet/BottomSheetOne.tsx +220 -0
- package/src/components/BottomSheet/index.ts +2 -0
- package/src/components/Button/PrimaryBtn.tsx +10 -2
- package/src/components/Content/Card/Category/Category.tsx +104 -10
- package/src/components/Content/Card/Category/CategroyTwo.tsx +429 -0
- package/src/components/Content/Card/NowWatching/NowWatching.tsx +281 -136
- package/src/components/Content/Card/Sliders/Styles/One.tsx +248 -152
- package/src/components/Content/Card/Sliders/Styles/Three.tsx +935 -0
- package/src/components/Content/Card/Sliders/Styles/Two.tsx +171 -102
- package/src/components/Content/Card/Sliders/index.ts +2 -0
- package/src/components/Content/Card/Styles/Five.tsx +162 -62
- package/src/components/Content/Card/Styles/Four.tsx +165 -85
- package/src/components/Content/Card/Styles/One.tsx +162 -71
- package/src/components/Content/Card/Styles/RotateInOut.tsx +158 -60
- package/src/components/Content/Card/Styles/Six.tsx +242 -142
- package/src/components/Content/Card/Styles/Three.tsx +160 -162
- package/src/components/Content/Card/Styles/TopTen.tsx +231 -191
- package/src/components/Content/Card/Styles/Two.tsx +183 -79
- package/src/components/Content/Card/components/AdsPoster.tsx +202 -0
- package/src/components/Content/Card/components/CardPoster.tsx +250 -151
- package/src/components/Content/Card/components/NavigateToMore.tsx +29 -1
- package/src/components/Content/Card/components/index.ts +1 -0
- package/src/components/Content/Content.tsx +103 -119
- package/src/components/Content/Sections.tsx +51 -45
- package/src/components/Content/types.ts +176 -0
- package/src/components/ContentView/MoreContentList.tsx +1 -0
- package/src/components/ContentView/{ContentView.tsx → One/ContentViewOne.tsx} +8 -7
- package/src/components/ContentView/{components → One/components}/AboutSection.tsx +3 -3
- package/src/components/ContentView/{components → One/components}/CastCard.tsx +3 -3
- package/src/components/ContentView/{components → One/components}/EpisodeCard.tsx +7 -8
- package/src/components/ContentView/{components → One/components}/GenreTags.tsx +3 -3
- package/src/components/ContentView/{components → One/components}/HeroBanner.tsx +44 -59
- package/src/components/ContentView/{components → One/components}/MiniInfo.tsx +69 -5
- package/src/components/ContentView/{components → One/components}/PlayButton.tsx +1 -1
- package/src/components/ContentView/{components → One/components}/Title.tsx +2 -2
- package/src/components/ContentView/{components → One/components}/TrailerButton.tsx +2 -2
- package/src/components/ContentView/Two/ContentViewTwo.tsx +343 -0
- package/src/components/ContentView/Two/components/AboutSection.tsx +216 -0
- package/src/components/ContentView/Two/components/Details.tsx +193 -0
- package/src/components/ContentView/Two/components/EpisodeCard.tsx +602 -0
- package/src/components/ContentView/Two/components/GenreTags.tsx +123 -0
- package/src/components/ContentView/Two/components/HeroBanner.tsx +402 -0
- package/src/components/ContentView/Two/components/LikeShareActions.tsx +125 -0
- package/src/components/ContentView/Two/components/MoreLikeThisContentList .tsx +305 -0
- package/src/components/ContentView/Two/components/PlayOrTrailer.tsx +133 -0
- package/src/components/ContentView/Two/components/SectionTabs.tsx +177 -0
- package/src/components/ContentView/Two/components/Title.tsx +226 -0
- package/src/components/ContentView/Two/components/index.ts +15 -0
- package/src/components/ContentView/index.ts +7 -1
- package/src/components/Headers/Four.tsx +83 -0
- package/src/components/Headers/Three.tsx +88 -25
- package/src/components/Headers/index.ts +2 -0
- package/src/components/Input/Input.ts +4 -0
- package/src/components/Input/InputThree.tsx +212 -0
- package/src/components/Input/PhoneNumberInput.tsx +4 -2
- package/src/components/Input/PhoneNumberInputTwo.tsx +418 -0
- package/src/components/Loader/Loader.tsx +25 -9
- package/src/components/Logo/Logo.tsx +53 -34
- package/src/components/NewRelease/NewReleaseSheet.tsx +250 -0
- package/src/components/NewRelease/index.ts +1 -0
- package/src/components/Reels/ReelsSeries/MediaControls/BottomControls.tsx +92 -27
- package/src/components/Reels/ReelsSeries/MediaControls/MediaControlsProvider.tsx +81 -1
- package/src/components/Reels/ReelsSeries/MediaControls/RightControls.tsx +4 -1
- package/src/components/Reels/ReelsSeries/Model/SettingModal.tsx +6 -3
- package/src/components/Reels/ReelsSeries/ReelsSeries.tsx +88 -55
- package/src/components/Reels/ReelsSeries/ReelsSeriesItem.tsx +92 -30
- package/src/components/Reels/ReelsSeries/components/VideoControls/QualityControl.tsx +35 -38
- package/src/components/Reels/ReelsSeries/types.ts +16 -0
- package/src/components/Reels/ReelsSeries/useReelsWatchProgress.ts +85 -0
- package/src/components/Reels/ReelsSeries/utils/quality.ts +48 -0
- package/src/components/Reels/index.ts +1 -0
- package/src/components/Search/One.tsx +8 -5
- package/src/components/Search/components/SearchCard.tsx +68 -11
- package/src/components/User/PurchaseHistory/PurchaseHistory.tsx +1 -0
- package/src/components/User/WatchHistory/WatchHistory.tsx +1 -0
- package/src/components/User/WatchLater/WatchLater.tsx +1 -0
- package/src/components/common/AppStatusBar.tsx +7 -1
- package/src/components/index.ts +1 -0
- package/src/constants/dummySections.ts +54 -3
- package/src/hooks/Images/index.ts +2 -0
- package/src/hooks/Images/useImageLoader.ts +206 -0
- package/src/hooks/Images/useImageValidation.ts +36 -0
- package/src/hooks/index.ts +3 -0
- package/src/hooks/useAdTracking.ts +349 -0
- package/src/hooks/useCards.ts +228 -0
- package/src/hooks/usePaginatedSection.ts +26 -7
- package/src/hooks/useSplashCache.ts +88 -69
- package/src/theme/ThemeProvider.tsx +15 -2
- package/src/theme/hook/index.ts +0 -1
- package/src/theme/hook/useInternalTheme.ts +22 -13
- package/src/theme/themes.ts +3 -0
- package/src/theme/utils/validateColor.ts +127 -0
- package/src/types/content/content-view.types.ts +43 -1
- package/src/types/sections/index.ts +7 -4
- package/src/utils/colorUtils.ts +70 -0
- package/lib/module/components/Auth/ForgotPassword/ForgotPassword.js.map +0 -1
- package/lib/module/components/Auth/Login/LoginWithEmail.js +0 -314
- package/lib/module/components/Auth/Login/LoginWithEmail.js.map +0 -1
- package/lib/module/components/Auth/Login/LoginWithPhone.js.map +0 -1
- package/lib/module/components/Auth/OTP/OTP.js.map +0 -1
- package/lib/module/components/Auth/QrLogin/QrLogin.js +0 -313
- package/lib/module/components/Auth/QrLogin/QrLogin.js.map +0 -1
- package/lib/module/components/Auth/QrLogin/components/QrViewArea.js +0 -243
- package/lib/module/components/Auth/QrLogin/components/QrViewArea.js.map +0 -1
- package/lib/module/components/Auth/SignUp/SignUp.js +0 -352
- package/lib/module/components/Auth/SignUp/SignUp.js.map +0 -1
- package/lib/module/components/Auth/SplashScreen/SplashScreen.js.map +0 -1
- package/lib/module/components/Auth/SplashScreen/components/SplashImage/SplashImage.js.map +0 -1
- package/lib/module/components/Auth/SplashScreen/components/SplashLottie/SplashLottie.js.map +0 -1
- package/lib/module/components/Auth/SplashScreen/components/SplashVideo/SplashVideo.js.map +0 -1
- package/lib/module/components/ContentView/ContentView.js.map +0 -1
- package/lib/module/components/ContentView/components/AboutSection.js.map +0 -1
- package/lib/module/components/ContentView/components/CastCard.js.map +0 -1
- package/lib/module/components/ContentView/components/EpisodeCard.js.map +0 -1
- package/lib/module/components/ContentView/components/GenreTags.js.map +0 -1
- package/lib/module/components/ContentView/components/HeroBanner.js.map +0 -1
- package/lib/module/components/ContentView/components/MiniInfo.js.map +0 -1
- package/lib/module/components/ContentView/components/PlayButton.js.map +0 -1
- package/lib/module/components/ContentView/components/Title.js.map +0 -1
- package/lib/module/components/ContentView/components/TrailerButton.js.map +0 -1
- package/lib/module/theme/hook/useThemeStatusBar.js +0 -33
- package/lib/module/theme/hook/useThemeStatusBar.js.map +0 -1
- package/lib/typescript/src/components/Auth/ForgotPassword/ForgotPassword.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/Login/LoginWithEmail.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/Login/LoginWithPhone.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/OTP/OTP.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/QrLogin/QrLogin.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/QrLogin/components/QrViewArea.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/SignUp/SignUp.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/SplashScreen/SplashScreen.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/SplashScreen/components/SplashImage/SplashImage.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/SplashScreen/components/SplashLottie/SplashLottie.d.ts.map +0 -1
- package/lib/typescript/src/components/Auth/SplashScreen/components/SplashVideo/SplashVideo.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/ContentView.d.ts +0 -15
- package/lib/typescript/src/components/ContentView/ContentView.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/AboutSection.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/CastCard.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/EpisodeCard.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/GenreTags.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/HeroBanner.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/MiniInfo.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/PlayButton.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/Title.d.ts.map +0 -1
- package/lib/typescript/src/components/ContentView/components/TrailerButton.d.ts.map +0 -1
- package/lib/typescript/src/theme/hook/useThemeStatusBar.d.ts +0 -10
- package/lib/typescript/src/theme/hook/useThemeStatusBar.d.ts.map +0 -1
- package/src/components/Auth/Login/LoginWithEmail.tsx +0 -441
- package/src/components/Auth/QrLogin/QrLogin.tsx +0 -342
- package/src/components/Auth/QrLogin/components/QrViewArea.tsx +0 -329
- package/src/components/Auth/SignUp/SignUp.tsx +0 -462
- package/src/theme/hook/useThemeStatusBar.ts +0 -42
- /package/lib/typescript/src/components/Auth/{SplashScreen → One/SplashScreen}/components/SplashLottie/SplashLottie.d.ts +0 -0
- /package/lib/typescript/src/components/Auth/{SplashScreen → One/SplashScreen}/components/SplashVideo/SplashVideo.d.ts +0 -0
- /package/lib/typescript/src/components/Auth/{SplashScreen → Two/SplashScreen}/components/SplashImage/SplashImage.d.ts +0 -0
- /package/lib/typescript/src/components/ContentView/{components → One/components}/PlayButton.d.ts +0 -0
- /package/lib/typescript/src/components/ContentView/{components → One/components}/TrailerButton.d.ts +0 -0
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @author Naresh Dhamu
|
|
3
|
+
* @lastModified Wed 26 Nov 2025 at 02:19 PM
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
const IMAGE_URL_REGEX = /\.(jpg|jpeg|png|webp|gif|bmp)$/i;
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Utility function to check if URL is a local file path
|
|
10
|
+
* @param url - The URL to check
|
|
11
|
+
* @returns true if the URL is a local file path, false otherwise
|
|
12
|
+
*/
|
|
13
|
+
export const isLocalFile = (url: string): boolean => {
|
|
14
|
+
return url?.startsWith?.('file://') || url?.startsWith?.('/');
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Utility function to validate image URL (supports both cloud URIs and local file paths)
|
|
19
|
+
* @param url - The URL to validate
|
|
20
|
+
* @returns true if the URL is a valid image URL, false otherwise
|
|
21
|
+
*/
|
|
22
|
+
export const isValidImageUrl = (url: string | null | undefined): boolean => {
|
|
23
|
+
if (!url || typeof url !== 'string') return false;
|
|
24
|
+
const cleaned = url.trim();
|
|
25
|
+
|
|
26
|
+
// Check for local file paths
|
|
27
|
+
if (isLocalFile(cleaned)) {
|
|
28
|
+
return IMAGE_URL_REGEX.test(cleaned) || cleaned.length > 0;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
// Check for cloud URIs (http/https)
|
|
32
|
+
return (
|
|
33
|
+
(cleaned?.startsWith?.('http://') || cleaned?.startsWith?.('https://')) &&
|
|
34
|
+
IMAGE_URL_REGEX.test(cleaned)
|
|
35
|
+
);
|
|
36
|
+
};
|
package/src/hooks/index.ts
CHANGED
|
@@ -0,0 +1,349 @@
|
|
|
1
|
+
import { useRef, useMemo, useCallback, useEffect } from 'react';
|
|
2
|
+
import { type View, Dimensions } from 'react-native';
|
|
3
|
+
import type { IServeAd } from '@zezosoft/zezo-ott-api-client';
|
|
4
|
+
|
|
5
|
+
const CHECK_INTERVAL = 500;
|
|
6
|
+
const INITIAL_CHECK_DELAY = 100;
|
|
7
|
+
|
|
8
|
+
export interface ViewportOffsets {
|
|
9
|
+
top: number;
|
|
10
|
+
bottom: number;
|
|
11
|
+
left: number;
|
|
12
|
+
right: number;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export interface ScreenDimensions {
|
|
16
|
+
width: number;
|
|
17
|
+
height: number;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export interface UseAdTrackingOptions {
|
|
21
|
+
ad: IServeAd;
|
|
22
|
+
onDisplayAds?: (ad: IServeAd) => void;
|
|
23
|
+
isLoading?: boolean;
|
|
24
|
+
screenDimensions?: ScreenDimensions;
|
|
25
|
+
viewportOffsets?: ViewportOffsets;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export interface UseAdTrackingReturn {
|
|
29
|
+
viewRef: React.RefObject<View | null>;
|
|
30
|
+
layoutRef: React.MutableRefObject<{
|
|
31
|
+
x: number;
|
|
32
|
+
y: number;
|
|
33
|
+
width: number;
|
|
34
|
+
height: number;
|
|
35
|
+
} | null>;
|
|
36
|
+
hasDisplayed: React.MutableRefObject<boolean>;
|
|
37
|
+
adUniqueId: string;
|
|
38
|
+
handleLayout: () => void;
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// Global set to track displayed ads - prevents duplicate tracking
|
|
42
|
+
const globalDisplayedAds = new Set<string>();
|
|
43
|
+
// Lock to prevent race conditions when checking and adding ads
|
|
44
|
+
const trackingLock = new Map<string, boolean>();
|
|
45
|
+
|
|
46
|
+
export const extractToken = (trackingUrl?: string): string => {
|
|
47
|
+
if (!trackingUrl) return '';
|
|
48
|
+
try {
|
|
49
|
+
const url = new URL(trackingUrl);
|
|
50
|
+
return url.searchParams.get('token') || '';
|
|
51
|
+
} catch {
|
|
52
|
+
const match = trackingUrl.match(/[?&]token=([^&]+)/);
|
|
53
|
+
return match?.[1] || '';
|
|
54
|
+
}
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Creates a unique ID for an ad to prevent duplicate tracking
|
|
59
|
+
* Priority: _id > token > mediaUrl > fallback
|
|
60
|
+
*/
|
|
61
|
+
export const createAdUniqueId = (ad: IServeAd): string => {
|
|
62
|
+
// First try to use _id if available (most reliable)
|
|
63
|
+
if ('_id' in ad && ad._id) {
|
|
64
|
+
return `ad-${String(ad._id)}`;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
// Then try token from tracking URL
|
|
68
|
+
const token = extractToken(ad.tracking?.impression);
|
|
69
|
+
if (token) {
|
|
70
|
+
return `ad-token-${token}`;
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
// Then use mediaUrl
|
|
74
|
+
const mediaUrl = ad.mediaUrl || '';
|
|
75
|
+
if (mediaUrl) {
|
|
76
|
+
return `ad-media-${mediaUrl}`;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
// Last resort: use a combination of available fields
|
|
80
|
+
const clickUrl = ad.tracking?.click || '';
|
|
81
|
+
if (clickUrl) {
|
|
82
|
+
return `ad-click-${clickUrl}`;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// Fallback (should rarely happen)
|
|
86
|
+
return `ad-fallback-${Date.now()}-${Math.random()}`;
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
export const useAdTracking = (
|
|
90
|
+
options: UseAdTrackingOptions
|
|
91
|
+
): UseAdTrackingReturn => {
|
|
92
|
+
const {
|
|
93
|
+
ad,
|
|
94
|
+
onDisplayAds,
|
|
95
|
+
isLoading = false,
|
|
96
|
+
screenDimensions: propScreenDimensions,
|
|
97
|
+
viewportOffsets: propViewportOffsets,
|
|
98
|
+
} = options;
|
|
99
|
+
|
|
100
|
+
const viewRef = useRef<View>(null);
|
|
101
|
+
const layoutRef = useRef<{
|
|
102
|
+
x: number;
|
|
103
|
+
y: number;
|
|
104
|
+
width: number;
|
|
105
|
+
height: number;
|
|
106
|
+
} | null>(null);
|
|
107
|
+
const hasDisplayedRef = useRef<boolean>(false);
|
|
108
|
+
|
|
109
|
+
const onDisplayAdsRef = useRef(onDisplayAds);
|
|
110
|
+
const adRef = useRef(ad);
|
|
111
|
+
const isLoadingRef = useRef(isLoading);
|
|
112
|
+
|
|
113
|
+
useEffect(() => {
|
|
114
|
+
onDisplayAdsRef.current = onDisplayAds;
|
|
115
|
+
adRef.current = ad;
|
|
116
|
+
isLoadingRef.current = isLoading;
|
|
117
|
+
}, [onDisplayAds, ad, isLoading]);
|
|
118
|
+
|
|
119
|
+
const adUniqueId = useMemo(() => createAdUniqueId(ad), [ad]);
|
|
120
|
+
|
|
121
|
+
const screenDimensions = useMemo(
|
|
122
|
+
() => propScreenDimensions || Dimensions.get('window'),
|
|
123
|
+
[propScreenDimensions]
|
|
124
|
+
);
|
|
125
|
+
|
|
126
|
+
const viewportOffsets = useMemo(
|
|
127
|
+
() => ({
|
|
128
|
+
top: propViewportOffsets?.top ?? 50,
|
|
129
|
+
bottom: propViewportOffsets?.bottom ?? 100,
|
|
130
|
+
left: propViewportOffsets?.left ?? 20,
|
|
131
|
+
right: propViewportOffsets?.right ?? 20,
|
|
132
|
+
}),
|
|
133
|
+
[
|
|
134
|
+
propViewportOffsets?.top,
|
|
135
|
+
propViewportOffsets?.bottom,
|
|
136
|
+
propViewportOffsets?.left,
|
|
137
|
+
propViewportOffsets?.right,
|
|
138
|
+
]
|
|
139
|
+
);
|
|
140
|
+
|
|
141
|
+
const viewportBounds = useMemo(() => {
|
|
142
|
+
const { width: screenWidth, height: screenHeight } = screenDimensions;
|
|
143
|
+
return {
|
|
144
|
+
left: viewportOffsets.left,
|
|
145
|
+
right: screenWidth - viewportOffsets.right,
|
|
146
|
+
top: viewportOffsets.top,
|
|
147
|
+
bottom: screenHeight - viewportOffsets.bottom,
|
|
148
|
+
};
|
|
149
|
+
}, [screenDimensions, viewportOffsets]);
|
|
150
|
+
|
|
151
|
+
const checkVisibility = useCallback((): boolean => {
|
|
152
|
+
const layout = layoutRef.current;
|
|
153
|
+
if (!layout) {
|
|
154
|
+
return false;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
const { x, y, width, height } = layout;
|
|
158
|
+
|
|
159
|
+
const isVisible =
|
|
160
|
+
x + width > viewportBounds.left &&
|
|
161
|
+
x < viewportBounds.right &&
|
|
162
|
+
y + height > viewportBounds.top &&
|
|
163
|
+
y < viewportBounds.bottom;
|
|
164
|
+
|
|
165
|
+
return isVisible;
|
|
166
|
+
}, [viewportBounds]);
|
|
167
|
+
|
|
168
|
+
const measureInWindow = useCallback((): void => {
|
|
169
|
+
const view = viewRef.current;
|
|
170
|
+
if (!view) return;
|
|
171
|
+
|
|
172
|
+
view.measureInWindow((x, y, width, height) => {
|
|
173
|
+
layoutRef.current = { x, y, width, height };
|
|
174
|
+
});
|
|
175
|
+
}, []);
|
|
176
|
+
|
|
177
|
+
/**
|
|
178
|
+
* Atomically checks and tracks ad display to prevent duplicate tracking
|
|
179
|
+
* Uses a lock mechanism to ensure only one instance can track the same ad
|
|
180
|
+
*/
|
|
181
|
+
const trackAdDisplay = useCallback((): boolean => {
|
|
182
|
+
const currentOnDisplayAds = onDisplayAdsRef.current;
|
|
183
|
+
const currentIsLoading = isLoadingRef.current;
|
|
184
|
+
|
|
185
|
+
if (!currentOnDisplayAds || currentIsLoading) {
|
|
186
|
+
return false;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
// Early return if already displayed by this instance
|
|
190
|
+
if (hasDisplayedRef.current) {
|
|
191
|
+
return false;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
// Atomic check-and-set: if ad is already being tracked or displayed, return false
|
|
195
|
+
if (globalDisplayedAds.has(adUniqueId)) {
|
|
196
|
+
// Mark this instance as displayed to prevent further checks
|
|
197
|
+
hasDisplayedRef.current = true;
|
|
198
|
+
return false;
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
// Set lock to prevent other instances from tracking the same ad
|
|
202
|
+
if (trackingLock.get(adUniqueId) === true) {
|
|
203
|
+
return false;
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
// Acquire lock
|
|
207
|
+
trackingLock.set(adUniqueId, true);
|
|
208
|
+
|
|
209
|
+
try {
|
|
210
|
+
// Double-check after acquiring lock (another instance might have added it)
|
|
211
|
+
if (globalDisplayedAds.has(adUniqueId)) {
|
|
212
|
+
hasDisplayedRef.current = true;
|
|
213
|
+
return false;
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
// Mark as displayed in both local and global state
|
|
217
|
+
hasDisplayedRef.current = true;
|
|
218
|
+
globalDisplayedAds.add(adUniqueId);
|
|
219
|
+
|
|
220
|
+
// Call the tracking callback
|
|
221
|
+
currentOnDisplayAds(adRef.current);
|
|
222
|
+
|
|
223
|
+
return true;
|
|
224
|
+
} finally {
|
|
225
|
+
// Release lock after a short delay to ensure callback completes
|
|
226
|
+
setTimeout(() => {
|
|
227
|
+
trackingLock.delete(adUniqueId);
|
|
228
|
+
}, 100);
|
|
229
|
+
}
|
|
230
|
+
}, [adUniqueId]);
|
|
231
|
+
|
|
232
|
+
const checkAndTrackVisibility = useCallback((): void => {
|
|
233
|
+
// Early exit if already displayed
|
|
234
|
+
if (hasDisplayedRef.current) {
|
|
235
|
+
return;
|
|
236
|
+
}
|
|
237
|
+
|
|
238
|
+
// Early exit if ad is already tracked globally or locked
|
|
239
|
+
if (
|
|
240
|
+
globalDisplayedAds.has(adUniqueId) ||
|
|
241
|
+
trackingLock.get(adUniqueId) === true
|
|
242
|
+
) {
|
|
243
|
+
// Mark this instance as displayed to prevent further checks
|
|
244
|
+
hasDisplayedRef.current = true;
|
|
245
|
+
return;
|
|
246
|
+
}
|
|
247
|
+
|
|
248
|
+
// Check visibility before tracking
|
|
249
|
+
if (!checkVisibility()) {
|
|
250
|
+
return;
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
// Attempt to track (will handle duplicate prevention internally)
|
|
254
|
+
trackAdDisplay();
|
|
255
|
+
}, [adUniqueId, checkVisibility, trackAdDisplay]);
|
|
256
|
+
|
|
257
|
+
const handleLayout = useCallback(() => {
|
|
258
|
+
const view = viewRef.current;
|
|
259
|
+
if (!view) return;
|
|
260
|
+
|
|
261
|
+
view.measureInWindow((x, y, width, height) => {
|
|
262
|
+
layoutRef.current = { x, y, width, height };
|
|
263
|
+
requestAnimationFrame(() => {
|
|
264
|
+
checkAndTrackVisibility();
|
|
265
|
+
});
|
|
266
|
+
});
|
|
267
|
+
}, [checkAndTrackVisibility]);
|
|
268
|
+
|
|
269
|
+
useEffect(() => {
|
|
270
|
+
if (isLoadingRef.current) {
|
|
271
|
+
return undefined;
|
|
272
|
+
}
|
|
273
|
+
|
|
274
|
+
let timeoutId: NodeJS.Timeout | null = null;
|
|
275
|
+
let rafId: number | null = null;
|
|
276
|
+
|
|
277
|
+
rafId = requestAnimationFrame(() => {
|
|
278
|
+
timeoutId = setTimeout(() => {
|
|
279
|
+
measureInWindow();
|
|
280
|
+
requestAnimationFrame(() => {
|
|
281
|
+
checkAndTrackVisibility();
|
|
282
|
+
});
|
|
283
|
+
}, INITIAL_CHECK_DELAY);
|
|
284
|
+
});
|
|
285
|
+
|
|
286
|
+
return () => {
|
|
287
|
+
if (rafId !== null) {
|
|
288
|
+
cancelAnimationFrame(rafId);
|
|
289
|
+
}
|
|
290
|
+
if (timeoutId !== null) {
|
|
291
|
+
clearTimeout(timeoutId);
|
|
292
|
+
}
|
|
293
|
+
};
|
|
294
|
+
}, [isLoading, checkAndTrackVisibility, measureInWindow]);
|
|
295
|
+
|
|
296
|
+
useEffect(() => {
|
|
297
|
+
if (
|
|
298
|
+
!onDisplayAdsRef.current ||
|
|
299
|
+
hasDisplayedRef.current ||
|
|
300
|
+
isLoadingRef.current
|
|
301
|
+
) {
|
|
302
|
+
return undefined;
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
let rafId: number | null = null;
|
|
306
|
+
let lastCheckTime = 0;
|
|
307
|
+
|
|
308
|
+
const checkWithThrottle = () => {
|
|
309
|
+
const now = Date.now();
|
|
310
|
+
|
|
311
|
+
if (now - lastCheckTime < CHECK_INTERVAL) {
|
|
312
|
+
rafId = requestAnimationFrame(checkWithThrottle);
|
|
313
|
+
return;
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
lastCheckTime = now;
|
|
317
|
+
|
|
318
|
+
if (hasDisplayedRef.current || !viewRef.current) {
|
|
319
|
+
return;
|
|
320
|
+
}
|
|
321
|
+
|
|
322
|
+
measureInWindow();
|
|
323
|
+
requestAnimationFrame(() => {
|
|
324
|
+
if (!hasDisplayedRef.current) {
|
|
325
|
+
checkAndTrackVisibility();
|
|
326
|
+
}
|
|
327
|
+
if (!hasDisplayedRef.current) {
|
|
328
|
+
rafId = requestAnimationFrame(checkWithThrottle);
|
|
329
|
+
}
|
|
330
|
+
});
|
|
331
|
+
};
|
|
332
|
+
|
|
333
|
+
rafId = requestAnimationFrame(checkWithThrottle);
|
|
334
|
+
|
|
335
|
+
return () => {
|
|
336
|
+
if (rafId !== null) {
|
|
337
|
+
cancelAnimationFrame(rafId);
|
|
338
|
+
}
|
|
339
|
+
};
|
|
340
|
+
}, [checkAndTrackVisibility, measureInWindow]);
|
|
341
|
+
|
|
342
|
+
return {
|
|
343
|
+
viewRef,
|
|
344
|
+
layoutRef,
|
|
345
|
+
hasDisplayed: hasDisplayedRef,
|
|
346
|
+
adUniqueId,
|
|
347
|
+
handleLayout,
|
|
348
|
+
};
|
|
349
|
+
};
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Global Card Hook (No duplicates + single data key)
|
|
3
|
+
*
|
|
4
|
+
* Provides a unified interface for managing card data with:
|
|
5
|
+
* - Automatic deduplication
|
|
6
|
+
* - Skeleton loading states
|
|
7
|
+
* - Pagination support
|
|
8
|
+
* - Optimized performance
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
import { useMemo, useCallback } from 'react';
|
|
12
|
+
import type { IContentData } from '@zezosoft/zezo-ott-api-client';
|
|
13
|
+
import { usePaginatedSection } from './usePaginatedSection';
|
|
14
|
+
import type { IAdItem, MoreFetchData } from '../types';
|
|
15
|
+
import { dummyContentData } from '../constants/dummySections';
|
|
16
|
+
|
|
17
|
+
export type CardSource =
|
|
18
|
+
| { data: (IContentData | IAdItem)[] }
|
|
19
|
+
| (IContentData | IAdItem)[]
|
|
20
|
+
| null;
|
|
21
|
+
|
|
22
|
+
export type UseCardsOptions = {
|
|
23
|
+
sectionId: string;
|
|
24
|
+
data?: CardSource;
|
|
25
|
+
fetchMore?: MoreFetchData<IContentData>;
|
|
26
|
+
loading?: boolean;
|
|
27
|
+
initialSkeleton?: number;
|
|
28
|
+
pagingSkeleton?: number;
|
|
29
|
+
adsRender?: boolean; // If false, ads will be filtered out from listData
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
export type UseCardsReturn = {
|
|
33
|
+
listData: (IContentData | IAdItem)[]; // ✔ Mixed array of content and ads
|
|
34
|
+
pagination: {
|
|
35
|
+
hasNextPage: boolean;
|
|
36
|
+
nextPage: number | null;
|
|
37
|
+
} | null;
|
|
38
|
+
isPaging: boolean;
|
|
39
|
+
hasMore: boolean;
|
|
40
|
+
loadMore: (page: number | null) => Promise<void>;
|
|
41
|
+
isEmpty: boolean;
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
// -----------------------------------------------------------
|
|
45
|
+
// Constants
|
|
46
|
+
// -----------------------------------------------------------
|
|
47
|
+
|
|
48
|
+
const DEFAULT_INITIAL_SKELETON = 5;
|
|
49
|
+
const DEFAULT_PAGING_SKELETON = 3;
|
|
50
|
+
|
|
51
|
+
// -----------------------------------------------------------
|
|
52
|
+
// Helpers
|
|
53
|
+
// -----------------------------------------------------------
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Normalizes different data source formats into a single array
|
|
57
|
+
*/
|
|
58
|
+
const normalize = (src: CardSource): (IContentData | IAdItem)[] => {
|
|
59
|
+
if (!src) return [];
|
|
60
|
+
if (Array.isArray(src)) return src;
|
|
61
|
+
return src.data ?? [];
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Removes duplicate items by _id using Map for O(n) performance
|
|
66
|
+
* Preserves order of first occurrence
|
|
67
|
+
* Handles both IContentData and IAdItem types
|
|
68
|
+
*/
|
|
69
|
+
const uniqueById = (
|
|
70
|
+
list: (IContentData | IAdItem)[]
|
|
71
|
+
): (IContentData | IAdItem)[] => {
|
|
72
|
+
if (list.length === 0) return [];
|
|
73
|
+
|
|
74
|
+
const seen = new Map<string, IContentData | IAdItem>();
|
|
75
|
+
const result: (IContentData | IAdItem)[] = [];
|
|
76
|
+
|
|
77
|
+
for (const item of list) {
|
|
78
|
+
// Handle ads - check for type property and use appropriate ID field
|
|
79
|
+
if ('type' in item && item.type === 'ads') {
|
|
80
|
+
const adItem = item as IAdItem;
|
|
81
|
+
// Ads might have _id (from IServeAd) or use mediaUrl as identifier
|
|
82
|
+
let id: string;
|
|
83
|
+
if ('_id' in adItem && adItem._id) {
|
|
84
|
+
id = String(adItem._id);
|
|
85
|
+
} else if ('mediaUrl' in adItem && adItem.mediaUrl) {
|
|
86
|
+
id = `ad-${adItem.mediaUrl}`;
|
|
87
|
+
} else {
|
|
88
|
+
id = `ad-${Math.random()}`;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
if (!seen.has(id)) {
|
|
92
|
+
seen.set(id, adItem);
|
|
93
|
+
result.push(adItem);
|
|
94
|
+
}
|
|
95
|
+
continue;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
// Handle content items
|
|
99
|
+
const contentItem = item as IContentData;
|
|
100
|
+
if (!contentItem?._id) continue; // Skip items without valid IDs
|
|
101
|
+
|
|
102
|
+
const id = String(contentItem._id);
|
|
103
|
+
if (!seen.has(id)) {
|
|
104
|
+
seen.set(id, contentItem);
|
|
105
|
+
result.push(contentItem);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
return result;
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
/**
|
|
113
|
+
* Creates skeleton items for loading states
|
|
114
|
+
* Memoized by count to avoid unnecessary recreations
|
|
115
|
+
* Returns IContentData[] for skeleton loading (ads don't need skeletons)
|
|
116
|
+
*/
|
|
117
|
+
const createSkeletonItems = (count: number, prefix: string): IContentData[] => {
|
|
118
|
+
if (count <= 0) return [];
|
|
119
|
+
return Array.from({ length: count }, (_, i) =>
|
|
120
|
+
dummyContentData(`${prefix}-${i}`)
|
|
121
|
+
);
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
// -----------------------------------------------------------
|
|
125
|
+
// Hook
|
|
126
|
+
// -----------------------------------------------------------
|
|
127
|
+
|
|
128
|
+
export function useCards({
|
|
129
|
+
sectionId,
|
|
130
|
+
data,
|
|
131
|
+
fetchMore,
|
|
132
|
+
loading = false,
|
|
133
|
+
initialSkeleton = DEFAULT_INITIAL_SKELETON,
|
|
134
|
+
pagingSkeleton = DEFAULT_PAGING_SKELETON,
|
|
135
|
+
adsRender = false,
|
|
136
|
+
}: UseCardsOptions): UseCardsReturn {
|
|
137
|
+
// Normalize input data
|
|
138
|
+
const baseItems = useMemo(() => normalize(data ?? { data: [] }), [data]);
|
|
139
|
+
|
|
140
|
+
// Use pagination hook for data management
|
|
141
|
+
const {
|
|
142
|
+
data: list,
|
|
143
|
+
pagination,
|
|
144
|
+
loadMoreData,
|
|
145
|
+
isPaginating,
|
|
146
|
+
hasMore,
|
|
147
|
+
} = usePaginatedSection<IContentData | IAdItem>(
|
|
148
|
+
sectionId,
|
|
149
|
+
fetchMore,
|
|
150
|
+
baseItems,
|
|
151
|
+
loading
|
|
152
|
+
);
|
|
153
|
+
|
|
154
|
+
// Apply deduplication to the list (handles both content and ads)
|
|
155
|
+
const uniqueList = useMemo(
|
|
156
|
+
() => uniqueById(list as (IContentData | IAdItem)[]),
|
|
157
|
+
[list]
|
|
158
|
+
);
|
|
159
|
+
|
|
160
|
+
// Memoize skeleton items - only recreate when count changes
|
|
161
|
+
const initialSkeletonItems = useMemo(
|
|
162
|
+
() => createSkeletonItems(initialSkeleton, 'sk'),
|
|
163
|
+
[initialSkeleton]
|
|
164
|
+
);
|
|
165
|
+
|
|
166
|
+
const pagingSkeletonItems = useMemo(
|
|
167
|
+
() => createSkeletonItems(pagingSkeleton, 'pagination-skeleton'),
|
|
168
|
+
[pagingSkeleton]
|
|
169
|
+
);
|
|
170
|
+
|
|
171
|
+
// Filter ads if adsRender is false
|
|
172
|
+
const filteredList = useMemo(() => {
|
|
173
|
+
if (adsRender) return uniqueList;
|
|
174
|
+
return uniqueList.filter(
|
|
175
|
+
(item): item is IContentData => item.type !== 'ads'
|
|
176
|
+
);
|
|
177
|
+
}, [uniqueList, adsRender]);
|
|
178
|
+
|
|
179
|
+
// Final data array for UI rendering
|
|
180
|
+
// Handles loading states and pagination skeletons
|
|
181
|
+
// Returns mixed array of IContentData | IAdItem (or only IContentData if adsRender is false)
|
|
182
|
+
const items = useMemo(() => {
|
|
183
|
+
// Show initial skeleton during initial load
|
|
184
|
+
if (loading) return initialSkeletonItems as (IContentData | IAdItem)[];
|
|
185
|
+
|
|
186
|
+
// Show data with pagination skeleton when loading more
|
|
187
|
+
if (isPaginating && filteredList.length > 0) {
|
|
188
|
+
return [
|
|
189
|
+
...filteredList,
|
|
190
|
+
...(pagingSkeletonItems as (IContentData | IAdItem)[]),
|
|
191
|
+
];
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
// Return filtered list (with or without ads based on adsRender)
|
|
195
|
+
return filteredList;
|
|
196
|
+
}, [
|
|
197
|
+
loading,
|
|
198
|
+
isPaginating,
|
|
199
|
+
filteredList,
|
|
200
|
+
initialSkeletonItems,
|
|
201
|
+
pagingSkeletonItems,
|
|
202
|
+
]);
|
|
203
|
+
|
|
204
|
+
// Determine if section is empty (only when not loading and no data)
|
|
205
|
+
const isEmpty = useMemo(
|
|
206
|
+
() => !loading && filteredList.length === 0,
|
|
207
|
+
[loading, filteredList.length]
|
|
208
|
+
);
|
|
209
|
+
|
|
210
|
+
// Memoize loadMore callback to prevent unnecessary re-renders
|
|
211
|
+
const handleLoadMore = useCallback(
|
|
212
|
+
async (page: number | null) => {
|
|
213
|
+
if (page && hasMore && !isPaginating) {
|
|
214
|
+
await loadMoreData(page);
|
|
215
|
+
}
|
|
216
|
+
},
|
|
217
|
+
[loadMoreData, hasMore, isPaginating]
|
|
218
|
+
);
|
|
219
|
+
|
|
220
|
+
return {
|
|
221
|
+
listData: items,
|
|
222
|
+
pagination,
|
|
223
|
+
isPaging: isPaginating,
|
|
224
|
+
hasMore,
|
|
225
|
+
loadMore: handleLoadMore,
|
|
226
|
+
isEmpty,
|
|
227
|
+
};
|
|
228
|
+
}
|
|
@@ -3,7 +3,21 @@
|
|
|
3
3
|
* @lastModified Wed 25 Jun 2025 at 12:00 PM
|
|
4
4
|
*/
|
|
5
5
|
import React, { useCallback, useState } from 'react';
|
|
6
|
-
import type {
|
|
6
|
+
import type { ISectionMeta } from '../types';
|
|
7
|
+
|
|
8
|
+
export type MoreFetchData<T> = ({
|
|
9
|
+
sectionId,
|
|
10
|
+
meta,
|
|
11
|
+
}: {
|
|
12
|
+
sectionId: string;
|
|
13
|
+
meta: {
|
|
14
|
+
hasNextPage: boolean;
|
|
15
|
+
nextPage: number;
|
|
16
|
+
};
|
|
17
|
+
}) => Promise<{
|
|
18
|
+
data: T[];
|
|
19
|
+
meta: ISectionMeta;
|
|
20
|
+
} | null>;
|
|
7
21
|
|
|
8
22
|
export function usePaginatedSection<T>(
|
|
9
23
|
sectionId: string,
|
|
@@ -19,7 +33,7 @@ export function usePaginatedSection<T>(
|
|
|
19
33
|
hasNextPage: true,
|
|
20
34
|
nextPage: 2,
|
|
21
35
|
});
|
|
22
|
-
const [
|
|
36
|
+
const [isPaginating, setIsPaginating] = useState(false);
|
|
23
37
|
|
|
24
38
|
// Sync initial data on mount or loading complete
|
|
25
39
|
React.useEffect(() => {
|
|
@@ -30,9 +44,9 @@ export function usePaginatedSection<T>(
|
|
|
30
44
|
|
|
31
45
|
const loadMoreData = useCallback(
|
|
32
46
|
async (page: number | null) => {
|
|
33
|
-
if (!page ||
|
|
47
|
+
if (!page || isPaginating || !pagination.hasNextPage || !fetchFn) return;
|
|
34
48
|
|
|
35
|
-
|
|
49
|
+
setIsPaginating(true);
|
|
36
50
|
try {
|
|
37
51
|
const res = await fetchFn({
|
|
38
52
|
sectionId,
|
|
@@ -44,6 +58,11 @@ export function usePaginatedSection<T>(
|
|
|
44
58
|
|
|
45
59
|
if (!res || !res.data || !res.meta?.pagination) {
|
|
46
60
|
console.warn(`⚠️ Invalid response for section: ${sectionId}`, res);
|
|
61
|
+
// Stop further pagination attempts for this section
|
|
62
|
+
setPagination({
|
|
63
|
+
hasNextPage: false,
|
|
64
|
+
nextPage: null,
|
|
65
|
+
});
|
|
47
66
|
return;
|
|
48
67
|
}
|
|
49
68
|
|
|
@@ -66,16 +85,16 @@ export function usePaginatedSection<T>(
|
|
|
66
85
|
} catch (err) {
|
|
67
86
|
console.error(`❌ Error loading section [${sectionId}]:`, err);
|
|
68
87
|
} finally {
|
|
69
|
-
|
|
88
|
+
setIsPaginating(false);
|
|
70
89
|
}
|
|
71
90
|
},
|
|
72
|
-
[
|
|
91
|
+
[isPaginating, pagination.hasNextPage, fetchFn, sectionId]
|
|
73
92
|
);
|
|
74
93
|
|
|
75
94
|
return {
|
|
76
95
|
data,
|
|
77
96
|
pagination,
|
|
78
|
-
|
|
97
|
+
isPaginating,
|
|
79
98
|
hasMore: pagination.hasNextPage,
|
|
80
99
|
loadMoreData,
|
|
81
100
|
};
|