mirror of
				https://github.com/jakejarvis/jarv.is.git
				synced 2025-11-04 05:20:12 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			78 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			78 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
import { useEffect } from "react";
 | 
						|
import dynamic from "next/dynamic";
 | 
						|
import { NextSeo } from "next-seo";
 | 
						|
import Layout from "../components/Layout/Layout";
 | 
						|
import Wallpaper from "../components/Wallpaper/Wallpaper";
 | 
						|
import type { ReactElement } from "react";
 | 
						|
 | 
						|
// obviously, an interactive VNC display will not work even a little bit server-side
 | 
						|
const VNC = dynamic(() => import("../components/VNC/VNC"), { ssr: false });
 | 
						|
 | 
						|
// https://github.com/jakejarvis/y2k
 | 
						|
const SOCKET_PROXY = "wss://y2k.jrvs.io";
 | 
						|
 | 
						|
const Y2K = () => {
 | 
						|
  // print a fancy console message (in browser only) just for funsies
 | 
						|
  useEffect(() => {
 | 
						|
    console.log(
 | 
						|
      `
 | 
						|
%c🤓 %cHey there, fellow nerd!%c Looking for the magic behind this page?
 | 
						|
 | 
						|
%cCheck out this post: https://jarv.is/notes/y2k-sandbox/
 | 
						|
 | 
						|
...or the source code here: https://github.com/jakejarvis/y2k
 | 
						|
`,
 | 
						|
      "font-size: 20px",
 | 
						|
      "color: black; background: yellow; font-size: 20px",
 | 
						|
      "font-size: 20px",
 | 
						|
      "font-size: 15px"
 | 
						|
    );
 | 
						|
  }, []);
 | 
						|
 | 
						|
  return (
 | 
						|
    <>
 | 
						|
      <NextSeo
 | 
						|
        title="Y2K Sandbox: Powered by Windows Me™ 💾"
 | 
						|
        description="My first website on a Windows Me-powered time machine. You've been warned."
 | 
						|
        openGraph={{
 | 
						|
          title: "Y2K Sandbox: Powered by Windows Me™",
 | 
						|
        }}
 | 
						|
      />
 | 
						|
 | 
						|
      <VNC server={SOCKET_PROXY} />
 | 
						|
    </>
 | 
						|
  );
 | 
						|
};
 | 
						|
 | 
						|
// disable layout's default styles so the wallpaper component can go edge-to-edge:
 | 
						|
Y2K.getLayout = (page: ReactElement) => {
 | 
						|
  // set a random retro Windows ME desktop tile for the entire content area
 | 
						|
  const randomTile = `/static/images/y2k/tiles/tile_${Math.floor(20 * Math.random())}.png`;
 | 
						|
 | 
						|
  return (
 | 
						|
    <Layout noContainer>
 | 
						|
      <Wallpaper
 | 
						|
        image={randomTile}
 | 
						|
        tile
 | 
						|
        style={{
 | 
						|
          display: "flex",
 | 
						|
          justifyContent: "center",
 | 
						|
          alignItems: "center",
 | 
						|
          padding: "1.5em 0",
 | 
						|
        }}
 | 
						|
      >
 | 
						|
        {page}
 | 
						|
      </Wallpaper>
 | 
						|
 | 
						|
      {/* also make the viewport a bit larger by un-sticking the nav bar */}
 | 
						|
      <style jsx global>{`
 | 
						|
        header {
 | 
						|
          position: relative !important;
 | 
						|
        }
 | 
						|
      `}</style>
 | 
						|
    </Layout>
 | 
						|
  );
 | 
						|
};
 | 
						|
 | 
						|
export default Y2K;
 |