add structured randomized titles + make hero title wider + add final randomized titles in lang files

Co-authored-by: William Oldham <github@binaryoverload.co.uk>
This commit is contained in:
mrjvs 2023-12-06 22:04:50 +01:00
parent 08f378bc72
commit d0dca6b853
3 changed files with 25 additions and 9 deletions

View file

@ -218,9 +218,18 @@
"stopEditing": "Stop editing" "stopEditing": "Stop editing"
}, },
"titles": { "titles": {
"morning": ["Morning title"], "morning": {
"day": ["Day title"], "default": "What would you like to watch this morning?",
"night": ["Night title"] "extra": ["I hear Before Sunrise is good"]
},
"day": {
"default": "What would you like to watch this afternoon?",
"extra": []
},
"night": {
"default": "What would you like to watch tonight?",
"extra": ["Tired? I hear The Excorcist is good."]
}
}, },
"search": { "search": {
"loading": "Loading...", "loading": "Loading...",

View file

@ -1,19 +1,26 @@
import { useCallback, useMemo } from "react"; import { useCallback, useMemo } from "react";
import { useTranslation } from "react-i18next"; import { useTranslation } from "react-i18next";
// 10% chance of getting a joke title
const shouldGiveJokeTitle = () => Math.floor(Math.random() * 10) === 0;
export function useRandomTranslation() { export function useRandomTranslation() {
const { t } = useTranslation(); const { t } = useTranslation();
const seed = useMemo(() => Math.random(), []); const seed = useMemo(() => Math.random(), []);
const getRandomTranslation = useCallback( const getRandomTranslation = useCallback(
(key: string) => { (key: string): string => {
const res = t(key, { returnObjects: true }); const shouldRandom = shouldGiveJokeTitle();
const defaultTitle = t(`${key}.default`) ?? "";
if (!shouldRandom) return defaultTitle;
if (Array.isArray(res)) { const keys = t(`${key}.extra`, { returnObjects: true });
return res[Math.floor(seed * res.length)]; if (Array.isArray(keys)) {
if (keys.length === 0) return defaultTitle;
return keys[Math.floor(seed * keys.length)];
} }
return res; return typeof keys === "string" ? keys : defaultTitle;
}, },
[t, seed] [t, seed]
); );

View file

@ -41,7 +41,7 @@ export function HeroPart({ setIsSticky, searchParams }: HeroPartProps) {
<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">{title}</HeroTitle> <HeroTitle className="mx-auto max-w-md">{title}</HeroTitle>
</div> </div>
<div className="relative h-20 z-30"> <div className="relative h-20 z-30">
<Sticky <Sticky