webbed site
This commit is contained in:
parent
6e591095b8
commit
cb470842b7
14 changed files with 910 additions and 218 deletions
|
|
@ -3,7 +3,9 @@ import { defineConfig } from 'astro/config';
|
||||||
|
|
||||||
import tailwind from '@astrojs/tailwind';
|
import tailwind from '@astrojs/tailwind';
|
||||||
|
|
||||||
|
import icon from 'astro-icon';
|
||||||
|
|
||||||
// https://astro.build/config
|
// https://astro.build/config
|
||||||
export default defineConfig({
|
export default defineConfig({
|
||||||
integrations: [tailwind()]
|
integrations: [tailwind(), icon()]
|
||||||
});
|
});
|
||||||
774
package-lock.json
generated
774
package-lock.json
generated
File diff suppressed because it is too large
Load diff
|
|
@ -11,6 +11,10 @@
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@astrojs/tailwind": "^5.1.4",
|
"@astrojs/tailwind": "^5.1.4",
|
||||||
"astro": "^5.1.2",
|
"astro": "^5.1.2",
|
||||||
|
"astro-icon": "^1.1.5",
|
||||||
"tailwindcss": "^3.4.17"
|
"tailwindcss": "^3.4.17"
|
||||||
|
},
|
||||||
|
"devDependencies": {
|
||||||
|
"@iconify-json/ri": "^1.2.5"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
BIN
public/test.gif
Normal file
BIN
public/test.gif
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 474 KiB |
8
src/components/InfoCard.astro
Normal file
8
src/components/InfoCard.astro
Normal file
|
|
@ -0,0 +1,8 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
<div class="text-center space-y-2 shadow-lg overflow-hidden border border-neutral-700/60 bg-neutral-900/40 p-8 rounded-xl">
|
||||||
|
<img class="rounded-b-full" src="https://nanoshinono.me/assets/img/ata_avatar.png" alt="Ata"/>
|
||||||
|
<h1 class="font-bold text-3xl">prefetcher</h1>
|
||||||
|
</div>
|
||||||
20
src/components/MarqueeBar.astro
Normal file
20
src/components/MarqueeBar.astro
Normal file
|
|
@ -0,0 +1,20 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
<div class="relative flex overflow-x-hidden space-y-2 shadow-lg border border-neutral-700/60 bg-neutral-900/40 p-5 rounded-xl">
|
||||||
|
<div class="animate-marquee whitespace-nowrap">
|
||||||
|
<span class="mx-4">Marquee Item 1</span>
|
||||||
|
<span class="mx-4">Marquee Item 2</span>
|
||||||
|
<span class="mx-4">Marquee Item 3</span>
|
||||||
|
<span class="mx-4">Marquee Item 4</span>
|
||||||
|
<span class="mx-4">Marquee Item 5</span>
|
||||||
|
</div>
|
||||||
|
<div class="absolute top-0 py-3 animate-marquee2 whitespace-nowrap">
|
||||||
|
<span class="mx-4">Marquee Item 1</span>
|
||||||
|
<span class="mx-4">Marquee Item 2</span>
|
||||||
|
<span class="mx-4">Marquee Item 3</span>
|
||||||
|
<span class="mx-4">Marquee Item 4</span>
|
||||||
|
<span class="mx-4">Marquee Item 5</span>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
10
src/components/Menu.astro
Normal file
10
src/components/Menu.astro
Normal file
|
|
@ -0,0 +1,10 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
<div class="space-y-2 shadow-lg overflow-hidden border border-neutral-700/60 bg-neutral-900/40 p-4 rounded-xl w-44">
|
||||||
|
<ul>
|
||||||
|
<li>main</li>
|
||||||
|
<li>projects</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
7
src/components/SlotCard.astro
Normal file
7
src/components/SlotCard.astro
Normal file
|
|
@ -0,0 +1,7 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
<div class="space-y-2 shadow-lg overflow-hidden border border-neutral-700/60 bg-neutral-900/40 p-8 rounded-xl flex-grow max-w-[700px] w-max">
|
||||||
|
<slot />
|
||||||
|
</div>
|
||||||
8
src/components/SocialIcon.astro
Normal file
8
src/components/SocialIcon.astro
Normal file
|
|
@ -0,0 +1,8 @@
|
||||||
|
---
|
||||||
|
import { Icon } from "astro-icon/components";
|
||||||
|
const { icon, link } = Astro.props;
|
||||||
|
---
|
||||||
|
|
||||||
|
<a href={link} target="_blank">
|
||||||
|
<Icon size="23" name={icon} class="hover:text-amber-400 transition-colors hover:transition-colors"/>
|
||||||
|
</a>
|
||||||
12
src/components/Socials.astro
Normal file
12
src/components/Socials.astro
Normal file
|
|
@ -0,0 +1,12 @@
|
||||||
|
---
|
||||||
|
import SocialIcon from "./SocialIcon.astro";
|
||||||
|
---
|
||||||
|
|
||||||
|
<div class="text-center flex justify-between shadow-lg overflow-hidden border border-neutral-700/60 bg-neutral-900/40 p-5 rounded-xl">
|
||||||
|
<SocialIcon icon="ri:bluesky-fill" link="https://bsky.app/profile/did:plc:xtzdbt3kmdb6ef3wumhkhktd" />
|
||||||
|
<SocialIcon icon="ri:twitter-fill" link="https://twitter.com/purifetchi" />
|
||||||
|
<SocialIcon icon="ri:fediverse-fill" link="https://miku.place/users/prefetcher" />
|
||||||
|
<SocialIcon icon="ri:github-fill" link="https://github.com/purifetchi" />
|
||||||
|
<SocialIcon icon="ri:discord-fill" link="https://discord.com/users/195991982915584000" />
|
||||||
|
<SocialIcon icon="ri:mail-fill" link="mailto:0xlunaric@gmail.com" />
|
||||||
|
</div>
|
||||||
|
|
@ -1,209 +0,0 @@
|
||||||
---
|
|
||||||
import astroLogo from '../assets/astro.svg';
|
|
||||||
import background from '../assets/background.svg';
|
|
||||||
---
|
|
||||||
|
|
||||||
<div id="container">
|
|
||||||
<img id="background" src={background.src} alt="" fetchpriority="high" />
|
|
||||||
<main>
|
|
||||||
<section id="hero">
|
|
||||||
<a href="https://astro.build"
|
|
||||||
><img src={astroLogo.src} width="115" height="48" alt="Astro Homepage" /></a
|
|
||||||
>
|
|
||||||
<h1>
|
|
||||||
To get started, open the <code><pre>src/pages</pre></code> directory in your project.
|
|
||||||
</h1>
|
|
||||||
<section id="links">
|
|
||||||
<a class="button" href="https://docs.astro.build">Read our docs</a>
|
|
||||||
<a href="https://astro.build/chat"
|
|
||||||
>Join our Discord <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 127.14 96.36"
|
|
||||||
><path
|
|
||||||
fill="currentColor"
|
|
||||||
d="M107.7 8.07A105.15 105.15 0 0 0 81.47 0a72.06 72.06 0 0 0-3.36 6.83 97.68 97.68 0 0 0-29.11 0A72.37 72.37 0 0 0 45.64 0a105.89 105.89 0 0 0-26.25 8.09C2.79 32.65-1.71 56.6.54 80.21a105.73 105.73 0 0 0 32.17 16.15 77.7 77.7 0 0 0 6.89-11.11 68.42 68.42 0 0 1-10.85-5.18c.91-.66 1.8-1.34 2.66-2a75.57 75.57 0 0 0 64.32 0c.87.71 1.76 1.39 2.66 2a68.68 68.68 0 0 1-10.87 5.19 77 77 0 0 0 6.89 11.1 105.25 105.25 0 0 0 32.19-16.14c2.64-27.38-4.51-51.11-18.9-72.15ZM42.45 65.69C36.18 65.69 31 60 31 53s5-12.74 11.43-12.74S54 46 53.89 53s-5.05 12.69-11.44 12.69Zm42.24 0C78.41 65.69 73.25 60 73.25 53s5-12.74 11.44-12.74S96.23 46 96.12 53s-5.04 12.69-11.43 12.69Z"
|
|
||||||
></path></svg
|
|
||||||
>
|
|
||||||
</a>
|
|
||||||
</section>
|
|
||||||
</section>
|
|
||||||
</main>
|
|
||||||
|
|
||||||
<a href="https://astro.build/blog/astro-5/" id="news" class="box">
|
|
||||||
<svg width="32" height="32" fill="none" xmlns="http://www.w3.org/2000/svg"
|
|
||||||
><path
|
|
||||||
d="M24.667 12c1.333 1.414 2 3.192 2 5.334 0 4.62-4.934 5.7-7.334 12C18.444 28.567 18 27.456 18 26c0-4.642 6.667-7.053 6.667-14Zm-5.334-5.333c1.6 1.65 2.4 3.43 2.4 5.333 0 6.602-8.06 7.59-6.4 17.334C13.111 27.787 12 25.564 12 22.666c0-4.434 7.333-8 7.333-16Zm-6-5.333C15.111 3.555 16 5.556 16 7.333c0 8.333-11.333 10.962-5.333 22-3.488-.774-6-4-6-8 0-8.667 8.666-10 8.666-20Z"
|
|
||||||
fill="#111827"></path></svg
|
|
||||||
>
|
|
||||||
<h2>What's New in Astro 5.0?</h2>
|
|
||||||
<p>
|
|
||||||
From content layers to server islands, click to learn more about the new features and
|
|
||||||
improvements in Astro 5.0
|
|
||||||
</p>
|
|
||||||
</a>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<style>
|
|
||||||
#background {
|
|
||||||
position: fixed;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
z-index: -1;
|
|
||||||
filter: blur(100px);
|
|
||||||
}
|
|
||||||
|
|
||||||
#container {
|
|
||||||
font-family: Inter, Roboto, 'Helvetica Neue', 'Arial Nova', 'Nimbus Sans', Arial, sans-serif;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
main {
|
|
||||||
height: 100%;
|
|
||||||
display: flex;
|
|
||||||
justify-content: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
#hero {
|
|
||||||
display: flex;
|
|
||||||
align-items: start;
|
|
||||||
flex-direction: column;
|
|
||||||
justify-content: center;
|
|
||||||
padding: 16px;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
font-size: 22px;
|
|
||||||
margin-top: 0.25em;
|
|
||||||
}
|
|
||||||
|
|
||||||
#links {
|
|
||||||
display: flex;
|
|
||||||
gap: 16px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#links a {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
padding: 10px 12px;
|
|
||||||
color: #111827;
|
|
||||||
text-decoration: none;
|
|
||||||
transition: color 0.2s;
|
|
||||||
}
|
|
||||||
|
|
||||||
#links a:hover {
|
|
||||||
color: rgb(78, 80, 86);
|
|
||||||
}
|
|
||||||
|
|
||||||
#links a svg {
|
|
||||||
height: 1em;
|
|
||||||
margin-left: 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#links a.button {
|
|
||||||
color: white;
|
|
||||||
background: linear-gradient(83.21deg, #3245ff 0%, #bc52ee 100%);
|
|
||||||
box-shadow:
|
|
||||||
inset 0 0 0 1px rgba(255, 255, 255, 0.12),
|
|
||||||
inset 0 -2px 0 rgba(0, 0, 0, 0.24);
|
|
||||||
border-radius: 10px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#links a.button:hover {
|
|
||||||
color: rgb(230, 230, 230);
|
|
||||||
box-shadow: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
pre {
|
|
||||||
font-family: ui-monospace, 'Cascadia Code', 'Source Code Pro', Menlo, Consolas,
|
|
||||||
'DejaVu Sans Mono', monospace;
|
|
||||||
font-weight: normal;
|
|
||||||
background: linear-gradient(14deg, #d83333 0%, #f041ff 100%);
|
|
||||||
-webkit-background-clip: text;
|
|
||||||
-webkit-text-fill-color: transparent;
|
|
||||||
background-clip: text;
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
h2 {
|
|
||||||
margin: 0 0 1em;
|
|
||||||
font-weight: normal;
|
|
||||||
color: #111827;
|
|
||||||
font-size: 20px;
|
|
||||||
}
|
|
||||||
|
|
||||||
p {
|
|
||||||
color: #4b5563;
|
|
||||||
font-size: 16px;
|
|
||||||
line-height: 24px;
|
|
||||||
letter-spacing: -0.006em;
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
code {
|
|
||||||
display: inline-block;
|
|
||||||
background:
|
|
||||||
linear-gradient(66.77deg, #f3cddd 0%, #f5cee7 100%) padding-box,
|
|
||||||
linear-gradient(155deg, #d83333 0%, #f041ff 18%, #f5cee7 45%) border-box;
|
|
||||||
border-radius: 8px;
|
|
||||||
border: 1px solid transparent;
|
|
||||||
padding: 6px 8px;
|
|
||||||
}
|
|
||||||
|
|
||||||
.box {
|
|
||||||
padding: 16px;
|
|
||||||
background: rgba(255, 255, 255, 1);
|
|
||||||
border-radius: 16px;
|
|
||||||
border: 1px solid white;
|
|
||||||
}
|
|
||||||
|
|
||||||
#news {
|
|
||||||
position: absolute;
|
|
||||||
bottom: 16px;
|
|
||||||
right: 16px;
|
|
||||||
max-width: 300px;
|
|
||||||
text-decoration: none;
|
|
||||||
transition: background 0.2s;
|
|
||||||
backdrop-filter: blur(50px);
|
|
||||||
}
|
|
||||||
|
|
||||||
#news:hover {
|
|
||||||
background: rgba(255, 255, 255, 0.55);
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-height: 368px) {
|
|
||||||
#news {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@media screen and (max-width: 768px) {
|
|
||||||
#container {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
}
|
|
||||||
|
|
||||||
#hero {
|
|
||||||
display: block;
|
|
||||||
padding-top: 10%;
|
|
||||||
}
|
|
||||||
|
|
||||||
#links {
|
|
||||||
flex-wrap: wrap;
|
|
||||||
}
|
|
||||||
|
|
||||||
#links a.button {
|
|
||||||
padding: 14px 18px;
|
|
||||||
}
|
|
||||||
|
|
||||||
#news {
|
|
||||||
right: 16px;
|
|
||||||
left: 16px;
|
|
||||||
bottom: 2.5rem;
|
|
||||||
max-width: 100%;
|
|
||||||
}
|
|
||||||
|
|
||||||
h1 {
|
|
||||||
line-height: 1.5;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
|
|
@ -1,3 +1,13 @@
|
||||||
|
---
|
||||||
|
|
||||||
|
import InfoCard from "../components/InfoCard.astro";
|
||||||
|
import Socials from "../components/Socials.astro";
|
||||||
|
import SlotCard from "../components/SlotCard.astro";
|
||||||
|
import MarqueeBar from "../components/MarqueeBar.astro";
|
||||||
|
import Menu from "../components/Menu.astro";
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
<!doctype html>
|
<!doctype html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
|
|
@ -7,8 +17,25 @@
|
||||||
<meta name="generator" content={Astro.generator} />
|
<meta name="generator" content={Astro.generator} />
|
||||||
<title>Astro Basics</title>
|
<title>Astro Basics</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body class="text-neutral-200 flex items-center justify-center">
|
||||||
|
<div class="fixed w-screen h-screen top-0 left-0 backdrop-blur-2xl">
|
||||||
|
|
||||||
|
</div>
|
||||||
|
<div id="container" class="w-max h-max flex flex-row space-x-3 z-10">
|
||||||
|
<div class="flex flex-col space-y-3">
|
||||||
|
<InfoCard />
|
||||||
|
<Socials />
|
||||||
|
</div>
|
||||||
|
<div class="flex flex-col space-y-3">
|
||||||
|
<div class="flex flex-grow flex-row space-x-3">
|
||||||
|
<SlotCard>
|
||||||
<slot />
|
<slot />
|
||||||
|
</SlotCard>
|
||||||
|
<Menu />
|
||||||
|
</div>
|
||||||
|
<MarqueeBar />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|
@ -18,5 +45,8 @@
|
||||||
margin: 0;
|
margin: 0;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
|
background: url("test.gif");
|
||||||
|
background-size: cover;
|
||||||
|
background-position: center;
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
|
|
|
||||||
|
|
@ -1,11 +1,22 @@
|
||||||
---
|
---
|
||||||
import Welcome from '../components/Welcome.astro';
|
|
||||||
import Layout from '../layouts/Layout.astro';
|
import Layout from '../layouts/Layout.astro';
|
||||||
|
|
||||||
// Welcome to Astro! Wondering what to do next? Check out the Astro documentation at https://docs.astro.build
|
|
||||||
// Don't want to use any of this? Delete everything in this file, the `assets`, `components`, and `layouts` directories, and start fresh.
|
|
||||||
---
|
---
|
||||||
|
|
||||||
<Layout>
|
<Layout>
|
||||||
<Welcome />
|
<h1 class="font-bold text-3xl">hi, i'm prefetcher.</h1>
|
||||||
|
<p>
|
||||||
|
yapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyap
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
yapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyap
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
yapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyap
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
yapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyap
|
||||||
|
</p>
|
||||||
|
<p>
|
||||||
|
yapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyapyap
|
||||||
|
</p>
|
||||||
</Layout>
|
</Layout>
|
||||||
|
|
|
||||||
|
|
@ -2,7 +2,22 @@
|
||||||
export default {
|
export default {
|
||||||
content: ['./src/**/*.{astro,html,js,jsx,md,mdx,svelte,ts,tsx,vue}'],
|
content: ['./src/**/*.{astro,html,js,jsx,md,mdx,svelte,ts,tsx,vue}'],
|
||||||
theme: {
|
theme: {
|
||||||
extend: {},
|
extend: {
|
||||||
|
animation: {
|
||||||
|
marquee: 'marquee 25s linear infinite',
|
||||||
|
marquee2: 'marquee2 25s linear infinite',
|
||||||
|
},
|
||||||
|
keyframes: {
|
||||||
|
marquee: {
|
||||||
|
'0%': { transform: 'translateX(0%)' },
|
||||||
|
'100%': { transform: 'translateX(-100%)' },
|
||||||
|
},
|
||||||
|
marquee2: {
|
||||||
|
'0%': { transform: 'translateX(100%)' },
|
||||||
|
'100%': { transform: 'translateX(0%)' },
|
||||||
|
},
|
||||||
|
},
|
||||||
|
},
|
||||||
},
|
},
|
||||||
plugins: [],
|
plugins: [],
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue