2024-03-24 10:37:28 +00:00
|
|
|
import React from 'react';
|
|
|
|
import { Box } from '@chakra-ui/react';
|
2023-06-27 01:18:08 +00:00
|
|
|
|
2024-03-24 10:37:28 +00:00
|
|
|
import { RainbowText } from './rainbowText';
|
2023-08-14 01:34:50 +00:00
|
|
|
|
|
|
|
export const TextAnimation1 = (props) => {
|
2023-06-27 01:18:08 +00:00
|
|
|
const texts = React.useMemo(() => {
|
2023-11-08 06:27:12 +00:00
|
|
|
if (props?.texts?.length) {
|
2024-03-24 10:37:28 +00:00
|
|
|
return props?.texts;
|
2023-11-08 06:27:12 +00:00
|
|
|
}
|
|
|
|
|
2023-06-27 01:18:08 +00:00
|
|
|
return [
|
2024-03-24 10:37:28 +00:00
|
|
|
'Thingtime',
|
|
|
|
'Vibrant',
|
|
|
|
'Infinite',
|
|
|
|
'Creative',
|
|
|
|
'Powerful',
|
|
|
|
'Magical',
|
|
|
|
'Inspiring',
|
|
|
|
'Love'
|
2023-06-28 07:53:34 +00:00
|
|
|
// 'tt'
|
2024-03-24 10:37:28 +00:00
|
|
|
];
|
|
|
|
}, [props?.texts]);
|
2023-06-27 01:18:08 +00:00
|
|
|
|
2024-03-24 10:37:28 +00:00
|
|
|
const [titleText, setTitleText] = React.useState(texts[0]);
|
2023-06-27 01:18:08 +00:00
|
|
|
|
2024-03-24 10:37:28 +00:00
|
|
|
const [usedTexts, setUsedTexts] = React.useState(['Thingtime']);
|
2023-06-28 07:53:34 +00:00
|
|
|
|
2024-03-24 10:37:28 +00:00
|
|
|
const state: any = React.useRef({});
|
2023-06-28 07:53:34 +00:00
|
|
|
|
2023-06-27 01:18:08 +00:00
|
|
|
React.useEffect(() => {
|
2024-03-24 10:37:28 +00:00
|
|
|
state.current = { titleText, texts, usedTexts };
|
|
|
|
}, [titleText, texts, usedTexts]);
|
2023-06-28 07:53:34 +00:00
|
|
|
|
|
|
|
React.useEffect(() => {
|
2024-03-24 10:37:28 +00:00
|
|
|
const newTimeout = Math.random() * 1500 + 2500 + (titleText === 'thingtime' ? 750 : 0);
|
2023-06-27 08:09:21 +00:00
|
|
|
|
2024-03-24 10:37:28 +00:00
|
|
|
const timeout = setTimeout(() => {
|
2023-06-28 07:53:34 +00:00
|
|
|
// choose an unused text or pick texts[0]
|
2024-03-24 10:37:28 +00:00
|
|
|
const usedTexts = state.current?.usedTexts;
|
|
|
|
const unusedTexts = texts.filter((text) => !usedTexts.includes(text));
|
2023-06-28 07:53:34 +00:00
|
|
|
// pick a random unused text
|
2024-03-24 10:37:28 +00:00
|
|
|
const randomIdx = Math.floor(Math.random() * unusedTexts.length);
|
|
|
|
const wasThingtime = false && titleText === 'Thingtime';
|
|
|
|
const newText = wasThingtime ? 'is' : unusedTexts.length > 0 ? unusedTexts[randomIdx] : texts[0];
|
|
|
|
console.log('nik newText', newText);
|
|
|
|
console.log('nik wasThingtime', wasThingtime);
|
|
|
|
console.log('nik usedTexts', usedTexts);
|
2023-06-28 07:53:34 +00:00
|
|
|
if (!unusedTexts.length) {
|
2024-03-24 10:37:28 +00:00
|
|
|
setUsedTexts(['Thingtime']);
|
2023-06-28 07:53:34 +00:00
|
|
|
} else {
|
2024-03-24 10:37:28 +00:00
|
|
|
setUsedTexts([...usedTexts, newText]);
|
2023-06-28 07:53:34 +00:00
|
|
|
}
|
2024-03-24 10:37:28 +00:00
|
|
|
setTitleText(newText);
|
|
|
|
}, newTimeout);
|
2023-06-27 01:18:08 +00:00
|
|
|
|
2024-03-24 10:37:28 +00:00
|
|
|
return () => {
|
|
|
|
// cleanup
|
|
|
|
|
|
|
|
clearTimeout(timeout);
|
|
|
|
};
|
|
|
|
}, [titleText]);
|
|
|
|
|
|
|
|
return <RainbowText ce={props?.ce}>{titleText}</RainbowText>;
|
|
|
|
};
|