ffdb5abf63
* Save * Save * Add pulse * Adjust footer ad * Adjust tile ad * Adjust tile ad hover * Fix premium badge alignment in tile grid * Adjust livestream icon * Adjust livestream icon * Save scheduled livestreasm & tile ad * Fix scheduled callback * Fix playlist icon size on file page * Fix grid distortion in 3 & 4 column layout * - * Fix grid on category & channel page * Fix Premium Plus Grid * Add custom tile for adblockers * Reset env * Remove collapsed tiles * Remove setLoaded on scheduled livestreams page * - * Make isHidden optional * Remove px * Review adjustments * Inject Premium+ ads * Fix injection * Fix injection when using the last tile * Fix injection when using the last tile * Enable stripe dev * Create PremiumPlusTile component and add list view design * Create PremiumPlusTile component and add list view design * Adjust ads in list view * Remove setState from render loop * Clean code * Fix livestream margin in list view * Rewrite & tune some logic - Homepage & Channel page * Clean details... * Clean details... * Requested review changes Signed-off-by: Raphael Wickihalder <raphael.wickihalder@odysee.com> * Requested review changes Signed-off-by: Raphael Wickihalder <raphael.wickihalder@odysee.com>
136 lines
4.3 KiB
JavaScript
136 lines
4.3 KiB
JavaScript
// @flow
|
|
|
|
import React from 'react';
|
|
import * as CS from 'constants/claim_search';
|
|
import moment from 'moment';
|
|
import * as ICONS from 'constants/icons';
|
|
import { useIsLargeScreen, useIsMobile } from 'effects/use-screensize';
|
|
import ClaimListDiscover from 'component/claimListDiscover';
|
|
import Button from 'component/button';
|
|
import { LIVESTREAM_UPCOMING_BUFFER } from 'constants/livestream';
|
|
import { SCHEDULED_LIVESTREAM_TAG } from 'constants/tags';
|
|
import * as SETTINGS from 'constants/settings';
|
|
|
|
type Props = {
|
|
channelIds: Array<string>,
|
|
tileLayout: boolean,
|
|
liveUris: Array<string>,
|
|
limitClaimsPerChannel?: number,
|
|
onLoad: (number) => void,
|
|
showHideSetting: boolean,
|
|
// --- perform ---
|
|
setClientSetting: (string, boolean | string | number, boolean) => void,
|
|
doShowSnackBar: (string) => void,
|
|
};
|
|
|
|
/* NEKO MARK */
|
|
const ScheduledStreams = (props: Props) => {
|
|
const {
|
|
channelIds,
|
|
// tileLayout,
|
|
liveUris = [],
|
|
limitClaimsPerChannel,
|
|
setClientSetting,
|
|
doShowSnackBar,
|
|
onLoad,
|
|
showHideSetting = true,
|
|
} = props;
|
|
|
|
const isMobileScreen = useIsMobile();
|
|
const isLargeScreen = useIsLargeScreen();
|
|
|
|
const [totalUpcomingLivestreams, setTotalUpcomingLivestreams] = React.useState(0);
|
|
const [showAllUpcoming, setShowAllUpcoming] = React.useState(false);
|
|
|
|
const showUpcomingLivestreams = totalUpcomingLivestreams > 0;
|
|
const useSwipeLayout = totalUpcomingLivestreams > 1 && isMobileScreen;
|
|
|
|
const upcomingMax = React.useMemo(() => {
|
|
if (showAllUpcoming || useSwipeLayout) return 50;
|
|
if (isLargeScreen) return 6;
|
|
if (isMobileScreen) return 3;
|
|
return 4;
|
|
}, [showAllUpcoming, isMobileScreen, isLargeScreen, useSwipeLayout]);
|
|
|
|
const loadedCallback = (total) => {
|
|
setTotalUpcomingLivestreams(total);
|
|
if (typeof onLoad === 'function') onLoad(total);
|
|
};
|
|
|
|
const hideScheduledStreams = () => {
|
|
setClientSetting(SETTINGS.HIDE_SCHEDULED_LIVESTREAMS, true, true);
|
|
doShowSnackBar(__('Scheduled streams hidden, you can re-enable them in settings.'));
|
|
};
|
|
|
|
const Header = () => {
|
|
return (
|
|
<div>
|
|
{__('Upcoming Livestreams')}
|
|
{showHideSetting && (
|
|
<Button button="link" label={__('Hide')} onClick={hideScheduledStreams} className={'ml-s text-s'} />
|
|
)}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
return (
|
|
<div className={'mb-m mt-m md:mb-xl'} style={{ display: showUpcomingLivestreams ? 'block' : 'none' }}>
|
|
<ClaimListDiscover
|
|
swipeLayout={useSwipeLayout}
|
|
useSkeletonScreen={false}
|
|
channelIds={channelIds}
|
|
limitClaimsPerChannel={limitClaimsPerChannel}
|
|
pageSize={50}
|
|
streamType={'all'}
|
|
hasNoSource
|
|
orderBy={CS.ORDER_BY_NEW_ASC}
|
|
// List-layout is not scrollable, and doesn't look good either. Force
|
|
// to tile-only until we can fix it. If we decide to always use
|
|
// tile-only, then remove the parameter for ScheduledStreams
|
|
// tileLayout={tileLayout}
|
|
tileLayout
|
|
tags={[SCHEDULED_LIVESTREAM_TAG]}
|
|
claimType={[CS.CLAIM_STREAM]}
|
|
releaseTime={`>${moment().subtract(LIVESTREAM_UPCOMING_BUFFER, 'minutes').startOf('minute').unix()}`}
|
|
hideAdvancedFilter
|
|
hideFilters
|
|
infiniteScroll={false}
|
|
showNoSourceClaims
|
|
hideLayoutButton
|
|
// header={__('🔴 Upcoming Livestreams')}
|
|
header={<Header />}
|
|
maxClaimRender={upcomingMax}
|
|
excludeUris={liveUris}
|
|
loadedCallback={loadedCallback}
|
|
/>
|
|
{totalUpcomingLivestreams > upcomingMax && !showAllUpcoming && !useSwipeLayout && (
|
|
<div className="livestream-list--view-more">
|
|
<Button
|
|
label={__('Show more upcoming livestreams')}
|
|
button="link"
|
|
iconRight={ICONS.ARROW_RIGHT}
|
|
className="claim-grid__title--secondary"
|
|
onClick={() => {
|
|
setShowAllUpcoming(true);
|
|
}}
|
|
/>
|
|
</div>
|
|
)}
|
|
{showAllUpcoming && (
|
|
<div className="livestream-list--view-more">
|
|
<Button
|
|
label={__('Show less upcoming livestreams')}
|
|
button="link"
|
|
iconRight={ICONS.ARROW_RIGHT}
|
|
className="claim-grid__title--secondary"
|
|
onClick={() => {
|
|
setShowAllUpcoming(false);
|
|
}}
|
|
/>
|
|
</div>
|
|
)}
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default ScheduledStreams;
|