|
1 | 1 | // @flow |
2 | 2 | import * as PAGES from 'constants/pages'; |
| 3 | +import * as MODALS from 'constants/modal_types'; |
| 4 | +import * as SETTINGS from 'constants/settings'; |
3 | 5 | import React, { useEffect, useState } from 'react'; |
4 | 6 | import { lazyImport } from 'util/lazyImport'; |
5 | 7 | import { tusUnlockAndNotify, tusHandleTabUpdates } from 'util/tus'; |
@@ -57,6 +59,8 @@ const LATEST_PATH = `/$/${PAGES.LATEST}/`; |
57 | 59 | const LIVE_PATH = `/$/${PAGES.LIVE_NOW}/`; |
58 | 60 | const EMBED_PATH = `/$/${PAGES.EMBED}/`; |
59 | 61 |
|
| 62 | +type HomepageOrder = { active: ?Array<string>, hidden: ?Array<string> }; |
| 63 | + |
60 | 64 | type Props = { |
61 | 65 | language: string, |
62 | 66 | languages: Array<string>, |
@@ -89,10 +93,15 @@ type Props = { |
89 | 93 | defaultChannelClaim: ?any, |
90 | 94 | nagsShown: boolean, |
91 | 95 | announcement: string, |
| 96 | + homepageOrder: HomepageOrder, |
| 97 | + isFypModalShown: boolean, |
| 98 | + personalRecommendations: { gid: string, uris: Array<string>, fetched: boolean }, |
92 | 99 | doOpenAnnouncements: () => void, |
93 | 100 | doSetLastViewedAnnouncement: (hash: string) => void, |
94 | 101 | doSetDefaultChannel: (claimId: string) => void, |
95 | 102 | doSetAssignedLbrynetServer: (server: string) => void, |
| 103 | + doOpenModal: (id: string, ?{}) => void, |
| 104 | + doSetClientSetting: (string, boolean, ?boolean) => void, |
96 | 105 | }; |
97 | 106 |
|
98 | 107 | export const AppContext = React.createContext<any>(); |
@@ -127,10 +136,15 @@ function App(props: Props) { |
127 | 136 | fetchModAmIList, |
128 | 137 | defaultChannelClaim, |
129 | 138 | announcement, |
| 139 | + homepageOrder, |
| 140 | + isFypModalShown, |
| 141 | + personalRecommendations, |
130 | 142 | doOpenAnnouncements, |
131 | 143 | doSetLastViewedAnnouncement, |
132 | 144 | doSetDefaultChannel, |
133 | 145 | doSetAssignedLbrynetServer, |
| 146 | + doOpenModal, |
| 147 | + doSetClientSetting, |
134 | 148 | } = props; |
135 | 149 |
|
136 | 150 | const isMobile = useIsMobile(); |
@@ -335,6 +349,51 @@ function App(props: Props) { |
335 | 349 | } |
336 | 350 | }, [activeChannelClaim, defaultChannelClaim, doSetDefaultChannel, hasMyChannels, prefsReady]); |
337 | 351 |
|
| 352 | + useEffect(() => { |
| 353 | + if ( |
| 354 | + isFypModalShown || |
| 355 | + !prefsReady || |
| 356 | + // $FlowIgnore |
| 357 | + homepageOrder.active?.includes('FYP') || |
| 358 | + // $FlowIgnore |
| 359 | + homepageOrder.hidden?.includes('FYP') || |
| 360 | + !personalRecommendations.uris.length |
| 361 | + ) { |
| 362 | + return; |
| 363 | + } |
| 364 | + |
| 365 | + doOpenModal(MODALS.CONFIRM, { |
| 366 | + title: __('Homepage recommendations available'), |
| 367 | + subtitle: __( |
| 368 | + 'Would you like to enable them? Homepage recommendations placement can be configured from the homepage customization.' |
| 369 | + ), |
| 370 | + labelOk: __('Yes!'), |
| 371 | + labelCancel: __('Customize'), |
| 372 | + onConfirm: (closeModal) => { |
| 373 | + closeModal(); |
| 374 | + |
| 375 | + const newHomePageOrder = { |
| 376 | + ...homepageOrder, |
| 377 | + active: homepageOrder?.active ? ['FYP', ...homepageOrder.active] : ['FYP'], |
| 378 | + }; |
| 379 | + doSetClientSetting(SETTINGS.HOMEPAGE_ORDER, newHomePageOrder, true); |
| 380 | + doSetClientSetting(SETTINGS.FYP_MODAL_SHOWN, true, true); |
| 381 | + }, |
| 382 | + onCancel: (closeModal) => { |
| 383 | + closeModal(); |
| 384 | + |
| 385 | + const newHomePageOrder = { |
| 386 | + ...homepageOrder, |
| 387 | + hidden: homepageOrder?.hidden ? ['FYP', ...homepageOrder.hidden] : ['FYP'], |
| 388 | + }; |
| 389 | + doSetClientSetting(SETTINGS.HOMEPAGE_ORDER, newHomePageOrder, true); |
| 390 | + doSetClientSetting(SETTINGS.FYP_MODAL_SHOWN, true, true); |
| 391 | + |
| 392 | + doOpenModal(MODALS.CUSTOMIZE_HOMEPAGE); |
| 393 | + }, |
| 394 | + }); |
| 395 | + }, [isFypModalShown, prefsReady, homepageOrder, personalRecommendations, doSetClientSetting, doOpenModal]); |
| 396 | + |
338 | 397 | useEffect(() => { |
339 | 398 | // $FlowFixMe |
340 | 399 | document.documentElement.setAttribute('lang', language); |
|
0 commit comments