2023-08-20 18:45:07 +02:00
|
|
|
import { useCallback, useState } from "react";
|
|
|
|
import Sticky from "react-stickynode";
|
|
|
|
|
|
|
|
import { ThinContainer } from "@/components/layout/ThinContainer";
|
|
|
|
import { SearchBarInput } from "@/components/SearchBar";
|
2023-10-23 23:06:24 +02:00
|
|
|
import { HeroTitle } from "@/components/text/HeroTitle";
|
2023-10-25 16:58:38 +02:00
|
|
|
import { useRandomTranslation } from "@/hooks/useRandomTranslation";
|
2023-08-20 18:45:07 +02:00
|
|
|
import { useSearchQuery } from "@/hooks/useSearchQuery";
|
2023-10-21 21:44:08 +02:00
|
|
|
import { useBannerSize } from "@/stores/banner";
|
2023-08-20 18:45:07 +02:00
|
|
|
|
|
|
|
export interface HeroPartProps {
|
|
|
|
setIsSticky: (val: boolean) => void;
|
|
|
|
searchParams: ReturnType<typeof useSearchQuery>;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function HeroPart({ setIsSticky, searchParams }: HeroPartProps) {
|
2023-10-25 16:58:38 +02:00
|
|
|
const { t } = useRandomTranslation();
|
2023-08-20 18:45:07 +02:00
|
|
|
const [search, setSearch, setSearchUnFocus] = searchParams;
|
|
|
|
const [, setShowBg] = useState(false);
|
|
|
|
const bannerSize = useBannerSize();
|
|
|
|
const stickStateChanged = useCallback(
|
|
|
|
({ status }: Sticky.Status) => {
|
|
|
|
const val = status === Sticky.STATUS_FIXED;
|
|
|
|
setShowBg(val);
|
|
|
|
setIsSticky(val);
|
|
|
|
},
|
|
|
|
[setShowBg, setIsSticky]
|
|
|
|
);
|
|
|
|
|
2023-10-25 16:58:38 +02:00
|
|
|
let time = "night";
|
|
|
|
const hour = new Date().getHours();
|
|
|
|
if (hour < 12) time = "morning";
|
2023-10-25 18:16:25 +02:00
|
|
|
else if (hour < 19) time = "day";
|
|
|
|
|
2023-10-25 16:58:38 +02:00
|
|
|
const title = t(`search.title.${time}`);
|
|
|
|
|
2023-08-20 18:45:07 +02:00
|
|
|
return (
|
|
|
|
<ThinContainer>
|
|
|
|
<div className="mt-44 space-y-16 text-center">
|
|
|
|
<div className="relative z-10 mb-16">
|
2023-10-25 16:58:38 +02:00
|
|
|
<HeroTitle className="mx-auto max-w-xs">{title}</HeroTitle>
|
2023-08-20 18:45:07 +02:00
|
|
|
</div>
|
|
|
|
<div className="relative z-30">
|
|
|
|
<Sticky
|
|
|
|
enabled
|
|
|
|
top={16 + bannerSize}
|
|
|
|
onStateChange={stickStateChanged}
|
|
|
|
>
|
|
|
|
<SearchBarInput
|
|
|
|
onChange={setSearch}
|
|
|
|
value={search}
|
|
|
|
onUnFocus={setSearchUnFocus}
|
|
|
|
placeholder={
|
|
|
|
t("search.placeholder") || "What do you want to watch?"
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</Sticky>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</ThinContainer>
|
|
|
|
);
|
|
|
|
}
|