mirror of
https://github.com/roleypoly/roleypoly.git
synced 2025-04-25 11:59:11 +00:00
* chore: restructure project into yarn workspaces, remove next * fix tests, remove webapp from terraform * remove more ui deployment bits * remove pages, fix FUNDING.yml * remove isomorphism * remove next providers * fix linting issues * feat: start basis of new web ui system on CRA * chore: move types to @roleypoly/types package * chore: move src/common/utils to @roleypoly/misc-utils * chore: remove roleypoly/ path remappers * chore: renmove vercel config * chore: re-add worker-types to api package * chore: fix type linting scope for api * fix(web): craco should include all of packages dir * fix(ci): change api webpack path for wrangler * chore: remove GAR actions from CI * chore: update codeql job * chore: test better github dar matcher in lint-staged
53 lines
1.7 KiB
TypeScript
53 lines
1.7 KiB
TypeScript
import { Typist } from '@roleypoly/design-system/atoms/typist';
|
|
import { demoData } from '@roleypoly/types/demoData';
|
|
import * as React from 'react';
|
|
import {
|
|
Base,
|
|
InputBox,
|
|
InputTextAlignment,
|
|
Line,
|
|
TextParts,
|
|
Timestamp,
|
|
Username,
|
|
} from './DemoDiscord.styled';
|
|
|
|
export const DemoDiscord = () => {
|
|
const time = new Date();
|
|
const timeString = time.toTimeString();
|
|
|
|
const [easterEggCount, setEasterEggCount] = React.useState(0);
|
|
|
|
return (
|
|
<Base>
|
|
<Timestamp>
|
|
{time.getHours() % 12}:{timeString.slice(3, 5)}
|
|
{time.getHours() <= 12 ? 'AM' : 'PM'}
|
|
</Timestamp>
|
|
<Username onClick={() => setEasterEggCount(easterEggCount + 1)}>
|
|
okano cat
|
|
</Username>
|
|
<TextParts>
|
|
{easterEggCount >= 15
|
|
? `NYAAAAAAA${'A'.repeat(easterEggCount - 15)}`
|
|
: easterEggCount >= 11
|
|
? `I'm.. I'm gonna...`
|
|
: easterEggCount >= 10
|
|
? `S-senpai... Be careful...`
|
|
: easterEggCount >= 5
|
|
? `H-hey... Stop that..`
|
|
: `Hey, I'd like some roles!`}
|
|
</TextParts>
|
|
<InputBox>
|
|
<InputTextAlignment>
|
|
|
|
<Typist
|
|
resetTimeout={2000}
|
|
charTimeout={75}
|
|
lines={demoData.map((role) => `.iam ${role.name}`)}
|
|
/>
|
|
<Line />
|
|
</InputTextAlignment>
|
|
</InputBox>
|
|
</Base>
|
|
);
|
|
};
|