mirror of
https://github.com/movie-web/movie-web.git
synced 2025-01-19 18:28:27 +00:00
Add random titles on home page
This commit is contained in:
parent
e267482d33
commit
6abc1cf85c
15
src/hooks/useRandomTranslation.ts
Normal file
15
src/hooks/useRandomTranslation.ts
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
import { useTranslation } from "react-i18next";
|
||||||
|
|
||||||
|
export function useRandomTranslation() {
|
||||||
|
const { t } = useTranslation();
|
||||||
|
|
||||||
|
const getRandomTranslation = (key: string) => {
|
||||||
|
const res = t(key, { returnObjects: true });
|
||||||
|
|
||||||
|
if (Array.isArray(res)) return res[Math.floor(Math.random() * res.length)];
|
||||||
|
|
||||||
|
return res;
|
||||||
|
};
|
||||||
|
|
||||||
|
return { t: getRandomTranslation };
|
||||||
|
}
|
|
@ -1,10 +1,10 @@
|
||||||
import { useCallback, useState } from "react";
|
import { useCallback, useState } from "react";
|
||||||
import { useTranslation } from "react-i18next";
|
|
||||||
import Sticky from "react-stickynode";
|
import Sticky from "react-stickynode";
|
||||||
|
|
||||||
import { ThinContainer } from "@/components/layout/ThinContainer";
|
import { ThinContainer } from "@/components/layout/ThinContainer";
|
||||||
import { SearchBarInput } from "@/components/SearchBar";
|
import { SearchBarInput } from "@/components/SearchBar";
|
||||||
import { HeroTitle } from "@/components/text/HeroTitle";
|
import { HeroTitle } from "@/components/text/HeroTitle";
|
||||||
|
import { useRandomTranslation } from "@/hooks/useRandomTranslation";
|
||||||
import { useSearchQuery } from "@/hooks/useSearchQuery";
|
import { useSearchQuery } from "@/hooks/useSearchQuery";
|
||||||
import { useBannerSize } from "@/stores/banner";
|
import { useBannerSize } from "@/stores/banner";
|
||||||
|
|
||||||
|
@ -14,7 +14,7 @@ export interface HeroPartProps {
|
||||||
}
|
}
|
||||||
|
|
||||||
export function HeroPart({ setIsSticky, searchParams }: HeroPartProps) {
|
export function HeroPart({ setIsSticky, searchParams }: HeroPartProps) {
|
||||||
const { t } = useTranslation();
|
const { t } = useRandomTranslation();
|
||||||
const [search, setSearch, setSearchUnFocus] = searchParams;
|
const [search, setSearch, setSearchUnFocus] = searchParams;
|
||||||
const [, setShowBg] = useState(false);
|
const [, setShowBg] = useState(false);
|
||||||
const bannerSize = useBannerSize();
|
const bannerSize = useBannerSize();
|
||||||
|
@ -27,13 +27,17 @@ export function HeroPart({ setIsSticky, searchParams }: HeroPartProps) {
|
||||||
[setShowBg, setIsSticky]
|
[setShowBg, setIsSticky]
|
||||||
);
|
);
|
||||||
|
|
||||||
|
let time = "night";
|
||||||
|
const hour = new Date().getHours();
|
||||||
|
if (hour < 12) time = "morning";
|
||||||
|
if (hour < 19) time = "day";
|
||||||
|
const title = t(`search.title.${time}`);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<ThinContainer>
|
<ThinContainer>
|
||||||
<div className="mt-44 space-y-16 text-center">
|
<div className="mt-44 space-y-16 text-center">
|
||||||
<div className="relative z-10 mb-16">
|
<div className="relative z-10 mb-16">
|
||||||
<HeroTitle className="mx-auto max-w-xs">
|
<HeroTitle className="mx-auto max-w-xs">{title}</HeroTitle>
|
||||||
{t("search.title")}
|
|
||||||
</HeroTitle>
|
|
||||||
</div>
|
</div>
|
||||||
<div className="relative z-30">
|
<div className="relative z-30">
|
||||||
<Sticky
|
<Sticky
|
||||||
|
|
|
@ -10,7 +10,22 @@
|
||||||
"headingTitle": "Search results",
|
"headingTitle": "Search results",
|
||||||
"bookmarks": "Bookmarks",
|
"bookmarks": "Bookmarks",
|
||||||
"continueWatching": "Continue Watching",
|
"continueWatching": "Continue Watching",
|
||||||
"title": "What to watch tonight?",
|
"title": {
|
||||||
|
"morning": [
|
||||||
|
"What would you like to watch today?",
|
||||||
|
"I hear Before Sunrise is good"
|
||||||
|
],
|
||||||
|
"day": [
|
||||||
|
"Shouldn't u be at school right now?",
|
||||||
|
"What to watch today?",
|
||||||
|
"Partially built in Holland"
|
||||||
|
],
|
||||||
|
"night": [
|
||||||
|
"What to watch tonight?",
|
||||||
|
"Tired? I hear The Excorcist is good.",
|
||||||
|
"https://youtu.be/68ugkg9RePc"
|
||||||
|
]
|
||||||
|
},
|
||||||
"placeholder": "What do you want to watch?"
|
"placeholder": "What do you want to watch?"
|
||||||
},
|
},
|
||||||
"media": {
|
"media": {
|
||||||
|
|
Loading…
Reference in a new issue