Compare commits
No commits in common. "e3ce3c90c779921c20be1f55cb2e80afad24c647" and "e0fa242e6998bdbcd2a85525d42bc3786644331d" have entirely different histories.
e3ce3c90c7
...
e0fa242e69
15 changed files with 262 additions and 296 deletions
|
@ -1,34 +1,34 @@
|
||||||
import { style } from '@vanilla-extract/css';
|
import { style } from '@vanilla-extract/css';
|
||||||
|
|
||||||
export const beeg_container = style({
|
export const beeg_container = style({
|
||||||
position: 'relative',
|
position: 'relative',
|
||||||
width: 'max-content',
|
width: 'max-content',
|
||||||
height: 'max-content',
|
height: 'max-content',
|
||||||
});
|
});
|
||||||
|
|
||||||
const beeg = style({
|
const beeg = style({
|
||||||
position: 'absolute',
|
position: 'absolute',
|
||||||
fontSize: '1.75em',
|
fontSize: '1.75em',
|
||||||
'@media': {
|
'@media': {
|
||||||
'screen and (min-width: 768px)': {
|
'screen and (min-width: 768px)': {
|
||||||
fontSize: '3em',
|
fontSize: '3em',
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
export const beeg_dummy = style([beeg, {
|
export const beeg_dummy = style([beeg, {
|
||||||
position: 'static',
|
position: 'static',
|
||||||
color: 'transparent',
|
color: 'transparent',
|
||||||
}]);
|
}]);
|
||||||
|
|
||||||
export const beeg_foreground = style([beeg, {
|
export const beeg_foreground = style([beeg, {
|
||||||
background: 'linear-gradient(90deg, rgba(255,0,0,1) 0%, rgba(255,255,0,1) 16%, rgba(0,255,0,1) 33%, rgba(0,255,255,1) 50%, rgba(0,0,255,1) 66%, rgba(255,0,255,1) 83%, rgba(255,0,0,1) 100%)',
|
background: 'linear-gradient(90deg, rgba(255,0,0,1) 0%, rgba(255,255,0,1) 16%, rgba(0,255,0,1) 33%, rgba(0,255,255,1) 50%, rgba(0,0,255,1) 66%, rgba(255,0,255,1) 83%, rgba(255,0,0,1) 100%)',
|
||||||
backgroundClip: 'text',
|
backgroundClip: 'text',
|
||||||
color: 'transparent',
|
color: 'transparent',
|
||||||
}]);
|
}]);
|
||||||
|
|
||||||
export const beeg_background = style([beeg, {
|
export const beeg_background = style([beeg, {
|
||||||
left: '-0.1em',
|
left: '-0.1em',
|
||||||
top: ' 0.1em',
|
top: ' 0.1em',
|
||||||
color: 'black',
|
color: 'black',
|
||||||
}]);
|
}]);
|
||||||
|
|
|
@ -1,16 +1,16 @@
|
||||||
import {
|
import {
|
||||||
beeg_container,
|
beeg_container,
|
||||||
beeg_dummy,
|
beeg_dummy,
|
||||||
beeg_foreground,
|
beeg_foreground,
|
||||||
beeg_background,
|
beeg_background,
|
||||||
} from './BeegText.css';
|
} from './BeegText.css';
|
||||||
|
|
||||||
export default function BeegText({ children }: { children: React.ReactNode }) {
|
export default function BeegText({ children }: { children: React.ReactNode }) {
|
||||||
return (
|
return (
|
||||||
<div className={beeg_container}>
|
<div className={beeg_container}>
|
||||||
<p className={beeg_background}>{children}</p>
|
<p className={beeg_background}>{children}</p>
|
||||||
<p className={beeg_foreground}>{children}</p>
|
<p className={beeg_foreground}>{children}</p>
|
||||||
<p className={beeg_dummy} >{children}</p>
|
<p className={beeg_dummy} >{children}</p>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,38 +1,30 @@
|
||||||
import { style, keyframes } from '@vanilla-extract/css';
|
import { style, keyframes } from '@vanilla-extract/css';
|
||||||
|
|
||||||
export const marquee_container = style({
|
export const marquee_container = style({
|
||||||
display: 'flex',
|
display: 'flex',
|
||||||
width: '100%',
|
width: '100%',
|
||||||
height: 'max-content',
|
height: 'max-content',
|
||||||
overflow: 'hidden',
|
overflow: 'hidden',
|
||||||
backgroundColor: 'black',
|
backgroundColor: 'black',
|
||||||
fontSize: '0.75em',
|
});
|
||||||
'@media': {
|
|
||||||
'screen and (min-width: 768px)': {
|
const scroll_marquee = keyframes({
|
||||||
fontSize: '1em',
|
'0%': { left: ' 0%' },
|
||||||
}
|
'100%': { left: '-100%' },
|
||||||
}
|
});
|
||||||
});
|
|
||||||
|
export const marquee_content = style({
|
||||||
export const marquee_sneaky = style({
|
position: 'relative',
|
||||||
position: 'absolute',
|
fontSize: '0.75em',
|
||||||
visibility: 'hidden',
|
color: 'magenta',
|
||||||
whiteSpace: 'pre',
|
whiteSpace: 'nowrap',
|
||||||
width: 'max-content',
|
animationName: scroll_marquee,
|
||||||
});
|
animationDuration: '8s',
|
||||||
|
animationTimingFunction: 'linear',
|
||||||
const scroll_marquee = keyframes({
|
animationIterationCount: 'infinite',
|
||||||
'0%': { left: ' 0%' },
|
'@media': {
|
||||||
'100%': { left: '-100%' },
|
'screen and (min-width: 768px)': {
|
||||||
});
|
fontSize: '1em',
|
||||||
|
}
|
||||||
export const marquee_content = style({
|
}
|
||||||
position: 'relative',
|
});
|
||||||
color: 'magenta',
|
|
||||||
whiteSpace: 'pre',
|
|
||||||
width: 'max-content',
|
|
||||||
animationName: scroll_marquee,
|
|
||||||
animationDuration: '2s',
|
|
||||||
animationTimingFunction: 'linear',
|
|
||||||
animationIterationCount: 'infinite',
|
|
||||||
});
|
|
||||||
|
|
|
@ -1,47 +1,13 @@
|
||||||
'use client'
|
import {
|
||||||
|
marquee_container,
|
||||||
import { useRef, useEffect, useLayoutEffect } from 'react';
|
marquee_content,
|
||||||
|
} from './Marquee.css';
|
||||||
import * as style from './Marquee.css';
|
|
||||||
|
export default function Marquee({ children }: { children: React.ReactNode }) {
|
||||||
export default function Marquee({ children }: { children: React.ReactNode }) {
|
return (
|
||||||
const target_ref = useRef<HTMLDivElement | null>(null);
|
<div className={marquee_container}>
|
||||||
const scroll_ref = useRef<HTMLDivElement | null>(null);
|
<p className={marquee_content}>{children}</p>
|
||||||
const sneaky_ref = useRef<HTMLParagraphElement | null>(null);
|
<p className={marquee_content}>{children}</p>
|
||||||
const not_so_sneaky_ref = useRef<HTMLParagraphElement | null>(null);
|
</div>
|
||||||
|
);
|
||||||
function expand_content() {
|
}
|
||||||
function strip_px(px: string) {
|
|
||||||
return Number(px.substring(0, px.length - 2));
|
|
||||||
}
|
|
||||||
const text = `${children}`;
|
|
||||||
let content = text;
|
|
||||||
const sneaky_width = strip_px(window.getComputedStyle(sneaky_ref.current!).getPropertyValue("width"));
|
|
||||||
let target_width = strip_px(window.getComputedStyle(target_ref.current!).getPropertyValue("width"));
|
|
||||||
while (target_width > 0) {
|
|
||||||
content += text;
|
|
||||||
target_width -= sneaky_width;
|
|
||||||
}
|
|
||||||
scroll_ref.current!.style.width = `${sneaky_width}px`;
|
|
||||||
not_so_sneaky_ref.current!.textContent = content;
|
|
||||||
}
|
|
||||||
|
|
||||||
useLayoutEffect(expand_content);
|
|
||||||
|
|
||||||
useEffect(() => {
|
|
||||||
window.addEventListener("resize", expand_content);
|
|
||||||
|
|
||||||
return () => {
|
|
||||||
window.removeEventListener("resize", expand_content);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
return (
|
|
||||||
<div ref={target_ref} className={style.marquee_container}>
|
|
||||||
<p ref={sneaky_ref} className={style.marquee_sneaky}>{children}</p>
|
|
||||||
<div ref={scroll_ref}>
|
|
||||||
<p ref={not_so_sneaky_ref} className={style.marquee_content}></p>
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,17 +0,0 @@
|
||||||
import { style } from '@vanilla-extract/css';
|
|
||||||
|
|
||||||
export const center_vertical = style({
|
|
||||||
position: 'relative',
|
|
||||||
display: 'flex',
|
|
||||||
flexDirection: 'column',
|
|
||||||
alignItems: 'center',
|
|
||||||
margin: 'auto',
|
|
||||||
width: '100%',
|
|
||||||
border: '0.3em solid purple',
|
|
||||||
'@media': {
|
|
||||||
'screen and (min-width: 768px)': {
|
|
||||||
width: '50%',
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
|
@ -1,13 +0,0 @@
|
||||||
import Marquee from './components/Marquee';
|
|
||||||
|
|
||||||
import * as style from './layout.css';
|
|
||||||
|
|
||||||
export default function ExcellentLayout({ children }: { children: React.ReactNode }) {
|
|
||||||
return (
|
|
||||||
<div className={style.center_vertical}>
|
|
||||||
<Marquee>THE SNACK IS WATCHING YOU </Marquee>
|
|
||||||
{children}
|
|
||||||
<Marquee>THE SNACK IS WATCHING YOU </Marquee>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
|
|
@ -1,4 +1,4 @@
|
||||||
import { style } from '@vanilla-extract/css';
|
import { style } from "@vanilla-extract/css";
|
||||||
|
|
||||||
export const message_style = style({
|
export const message_style = style({
|
||||||
boxSizing: 'border-box',
|
boxSizing: 'border-box',
|
||||||
|
@ -8,12 +8,10 @@ export const message_style = style({
|
||||||
border: 'none',
|
border: 'none',
|
||||||
padding: '0.5em',
|
padding: '0.5em',
|
||||||
fontSize: '1em',
|
fontSize: '1em',
|
||||||
fontFamily: 'inherit',
|
|
||||||
color: 'magenta',
|
color: 'magenta',
|
||||||
backgroundColor: 'black',
|
backgroundColor: 'black',
|
||||||
overflowWrap: 'break-word',
|
overflowWrap: 'break-word',
|
||||||
textAlign: 'center',
|
textAlign: 'center',
|
||||||
resize: 'none',
|
|
||||||
':focus': {
|
':focus': {
|
||||||
outline: 'none',
|
outline: 'none',
|
||||||
},
|
},
|
||||||
|
|
|
@ -1,9 +1,8 @@
|
||||||
'use client'
|
'use client'
|
||||||
|
|
||||||
import { useRef, useEffect, useLayoutEffect } from 'react';
|
import { useEffect, useRef } from 'react';
|
||||||
import { useSearchParams } from 'next/navigation';
|
import { useSearchParams } from 'next/navigation';
|
||||||
|
|
||||||
import comic_sans from '../../../../comic.ts';
|
|
||||||
import { message_style } from '../components/Input.css';
|
import { message_style } from '../components/Input.css';
|
||||||
|
|
||||||
export default function Input() {
|
export default function Input() {
|
||||||
|
@ -14,8 +13,6 @@ export default function Input() {
|
||||||
const encoded = btoa(message);
|
const encoded = btoa(message);
|
||||||
const new_url = `${window.location.protocol}//${window.location.host}${window.location.pathname}?e=${encoded}`;
|
const new_url = `${window.location.protocol}//${window.location.host}${window.location.pathname}?e=${encoded}`;
|
||||||
window.history.replaceState(null, '', new_url);
|
window.history.replaceState(null, '', new_url);
|
||||||
input_ref.current!.style.height = "";
|
|
||||||
input_ref.current!.style.height = `${input_ref.current!.scrollHeight}px`;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const message = search_params.get('e') ?
|
const message = search_params.get('e') ?
|
||||||
|
@ -26,30 +23,17 @@ export default function Input() {
|
||||||
);
|
);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
function resize_handler() {
|
|
||||||
input_ref.current!.style.height = "";
|
|
||||||
input_ref.current!.style.height = `${input_ref.current!.scrollHeight}px`;
|
|
||||||
}
|
|
||||||
|
|
||||||
window.addEventListener("resize", resize_handler);
|
|
||||||
|
|
||||||
return () => {
|
|
||||||
window.removeEventListener("resize", resize_handler);
|
|
||||||
};
|
|
||||||
});
|
|
||||||
|
|
||||||
useLayoutEffect(() => {
|
|
||||||
set_message(message);
|
set_message(message);
|
||||||
});
|
});
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<textarea
|
<p
|
||||||
ref={input_ref}
|
ref={input_ref}
|
||||||
className={message_style}
|
className={message_style}
|
||||||
type="text"
|
|
||||||
rows="1"
|
|
||||||
onInput={() => set_message(input_ref.current!.textContent ?? '')}
|
onInput={() => set_message(input_ref.current!.textContent ?? '')}
|
||||||
defaultValue={message}
|
contentEditable
|
||||||
/>
|
>
|
||||||
|
{message}
|
||||||
|
</p>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +1,10 @@
|
||||||
import { Metadata } from 'next'
|
import { Metadata } from 'next'
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = {
|
||||||
title: 'The Ministry of Truth',
|
title: 'The Ministry of Truth',
|
||||||
description: 'The Ministry of Truth',
|
description: 'The Ministry of Truth',
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function Layout({ children }: { children: React.ReactNode }) {
|
export default function Layout({ children }: { children: React.ReactNode }) {
|
||||||
return <>{children}</>
|
return <>{children}</>
|
||||||
}
|
}
|
|
@ -1,13 +1,29 @@
|
||||||
import { keyframes, style } from "@vanilla-extract/css";
|
import { keyframes, style } from "@vanilla-extract/css";
|
||||||
|
|
||||||
export const border = style({
|
export const center_vertical = style({
|
||||||
width: '61%',
|
boxSizing: 'border-box',
|
||||||
marginBottom: '4em',
|
position: 'relative',
|
||||||
border: '0.3em solid purple',
|
display: 'flex',
|
||||||
});
|
flexDirection: 'column',
|
||||||
|
alignItems: 'center',
|
||||||
export const big_brother_style = style({
|
margin: 'auto',
|
||||||
display: 'block',
|
width: '100%',
|
||||||
width: '100%',
|
border: '0.3em solid purple',
|
||||||
height: 'auto',
|
'@media': {
|
||||||
});
|
'screen and (min-width: 768px)': {
|
||||||
|
width: '50%',
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
export const border = style({
|
||||||
|
width: '61%',
|
||||||
|
marginBottom: '4em',
|
||||||
|
border: '0.3em solid purple',
|
||||||
|
});
|
||||||
|
|
||||||
|
export const big_brother_style = style({
|
||||||
|
display: 'block',
|
||||||
|
width: '100%',
|
||||||
|
height: 'auto',
|
||||||
|
});
|
||||||
|
|
|
@ -1,17 +1,26 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import Image from 'next/image';
|
import Image from 'next/image';
|
||||||
import BeegText from '../components/BeegText';
|
import BeegText from '../components/BeegText';
|
||||||
import Input from './components/Input';
|
import Marquee from '../components/Marquee';
|
||||||
import * as style from './page.css';
|
import Input from './components/Input';
|
||||||
|
import {
|
||||||
export default function Home() {
|
center_vertical,
|
||||||
return <>
|
border,
|
||||||
<BeegText>THE MINISTRY OF TRUTH</BeegText>
|
big_brother_style,
|
||||||
<div className={style.border}>
|
} from './page.css';
|
||||||
<Image className={style.big_brother_style} width={400} height={300} src='/big_brother_screen.gif' alt='Big Brother' />
|
|
||||||
<React.Suspense>
|
export default function Home() {
|
||||||
<Input />
|
return (
|
||||||
</React.Suspense>
|
<div className={center_vertical}>
|
||||||
</div>
|
<Marquee>THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU </Marquee>
|
||||||
</>;
|
<BeegText>THE MINISTRY OF TRUTH</BeegText>
|
||||||
}
|
<div className={border}>
|
||||||
|
<Image className={big_brother_style} width={400} height={300} src='/big_brother_screen.gif' alt='Big Brother' />
|
||||||
|
<React.Suspense>
|
||||||
|
<Input />
|
||||||
|
</React.Suspense>
|
||||||
|
</div>
|
||||||
|
<Marquee>THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU </Marquee>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
|
@ -1,37 +1,52 @@
|
||||||
import { keyframes, style } from "@vanilla-extract/css";
|
import { keyframes, style } from "@vanilla-extract/css";
|
||||||
|
|
||||||
export const big_brother_style = style({
|
export const center_vertical = style({
|
||||||
width: '60%',
|
position: 'relative',
|
||||||
height: 'auto',
|
display: 'flex',
|
||||||
border: '0.3em solid purple',
|
flexDirection: 'column',
|
||||||
'@media': {
|
alignItems: 'center',
|
||||||
'screen and (min-width: 768px)': {
|
margin: 'auto',
|
||||||
width: '40%',
|
width: '100%',
|
||||||
}
|
border: '0.3em solid purple',
|
||||||
}
|
'@media': {
|
||||||
});
|
'screen and (min-width: 768px)': {
|
||||||
|
width: '50%',
|
||||||
export const cats_div = style({
|
}
|
||||||
display: 'flex',
|
}
|
||||||
flexDirection: 'row',
|
});
|
||||||
justifyContent: 'space-between',
|
|
||||||
width: '100%',
|
export const big_brother_style = style({
|
||||||
borderTop: '0.3em solid purple'
|
width: '60%',
|
||||||
});
|
height: 'auto',
|
||||||
|
border: '0.3em solid purple',
|
||||||
export const subcats_div = style({
|
'@media': {
|
||||||
display: 'flex',
|
'screen and (min-width: 768px)': {
|
||||||
justifyContent: 'flex-start',
|
width: '40%',
|
||||||
width: '50%',
|
}
|
||||||
height: 'max-content',
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
export const reverse_subcats_div = style([subcats_div, {
|
export const cats_div = style({
|
||||||
transform: 'scale(-1, 1)'
|
display: 'flex',
|
||||||
}]);
|
flexDirection: 'row',
|
||||||
|
justifyContent: 'space-between',
|
||||||
export const cat = style({
|
width: '100%',
|
||||||
display: 'block',
|
borderTop: '0.3em solid purple'
|
||||||
width: '25%',
|
});
|
||||||
height: 'auto',
|
|
||||||
});
|
export const subcats_div = style({
|
||||||
|
display: 'flex',
|
||||||
|
justifyContent: 'flex-start',
|
||||||
|
width: '50%',
|
||||||
|
height: 'max-content',
|
||||||
|
});
|
||||||
|
|
||||||
|
export const reverse_subcats_div = style([subcats_div, {
|
||||||
|
transform: 'scale(-1, 1)'
|
||||||
|
}]);
|
||||||
|
|
||||||
|
export const cat = style({
|
||||||
|
display: 'block',
|
||||||
|
width: '25%',
|
||||||
|
height: 'auto',
|
||||||
|
});
|
||||||
|
|
|
@ -1,29 +1,41 @@
|
||||||
import { Metadata } from 'next';
|
import { Metadata } from 'next'
|
||||||
import Image from 'next/image';
|
import Image from 'next/image'
|
||||||
import BeegText from './components/BeegText';
|
import Marquee from './components/Marquee'
|
||||||
import * as style from './page.css';
|
import BeegText from './components/BeegText'
|
||||||
|
import {
|
||||||
|
center_vertical,
|
||||||
|
big_brother_style,
|
||||||
|
cats_div,
|
||||||
|
subcats_div,
|
||||||
|
reverse_subcats_div,
|
||||||
|
cat,
|
||||||
|
} from './page.css'
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = {
|
||||||
title: 'The Snack is Watching You',
|
title: 'The Snack is Watching You',
|
||||||
description: 'The Snack is Watching You',
|
description: 'The Snack is Watching You',
|
||||||
};
|
}
|
||||||
|
|
||||||
export default function Home() {
|
export default function Home() {
|
||||||
return <>
|
return (
|
||||||
<BeegText>THE SNACK IS</BeegText>
|
<div className={center_vertical}>
|
||||||
<Image className={style.big_brother_style} width={256} height={256} src='/big_brother.png' alt='Big Brother' />
|
<Marquee>THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU </Marquee>
|
||||||
<BeegText>WATCHING YOU</BeegText>
|
<BeegText>THE SNACK IS</BeegText>
|
||||||
<div className={style.cats_div}>
|
<Image className={big_brother_style} width={256} height={256} src='/big_brother.png' alt='Big Brother' />
|
||||||
<div className={style.subcats_div}>
|
<BeegText>WATCHING YOU</BeegText>
|
||||||
<Image className={style.cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
<div className={cats_div}>
|
||||||
<Image className={style.cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
<div className={subcats_div}>
|
||||||
<Image className={style.cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
<Image className={cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
||||||
</div>
|
<Image className={cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
||||||
<div className={style.reverse_subcats_div}>
|
<Image className={cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
||||||
<Image className={style.cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
</div>
|
||||||
<Image className={style.cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
<div className={reverse_subcats_div}>
|
||||||
<Image className={style.cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
<Image className={cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
||||||
|
<Image className={cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
||||||
|
<Image className={cat} width={128} height={128} src='/praising_cat.gif' alt='Cat praising Big Brother' />
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<Marquee>THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU THE SNACK IS WATCHING YOU </Marquee>
|
||||||
</div>
|
</div>
|
||||||
</>;
|
)
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
import { globalStyle } from "@vanilla-extract/css";
|
import { globalStyle } from "@vanilla-extract/css";
|
||||||
|
|
||||||
export const global_style = globalStyle('html,body', {
|
export const global_style = globalStyle('html,body', {
|
||||||
margin: '0',
|
margin: '0',
|
||||||
width: '100%',
|
width: '100%',
|
||||||
height: '100%',
|
height: '100%',
|
||||||
backgroundImage: 'url("/background.png")',
|
backgroundImage: 'url("/background.png")',
|
||||||
backgroundRepeat: 'repeat'
|
backgroundRepeat: 'repeat'
|
||||||
});
|
});
|
||||||
|
|
|
@ -7,7 +7,11 @@ const comic_sans = localFont({
|
||||||
weight: '100',
|
weight: '100',
|
||||||
});
|
});
|
||||||
|
|
||||||
export default function RootLayout({ children }: { children: React.ReactNode }) {
|
export default function RootLayout({
|
||||||
|
children,
|
||||||
|
}: {
|
||||||
|
children: React.ReactNode
|
||||||
|
}) {
|
||||||
return (
|
return (
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<body className={comic_sans.className}>{children}</body>
|
<body className={comic_sans.className}>{children}</body>
|
||||||
|
|
Loading…
Reference in a new issue