Reorganize duplicated tailwind code and formatting

This commit is contained in:
prototypa
2022-08-27 01:52:23 -04:00
parent ca01eecc24
commit 212331215b
28 changed files with 424 additions and 950 deletions

View File

@ -2,11 +2,11 @@
"prettier.documentSelectors": ["**/*.astro"], "prettier.documentSelectors": ["**/*.astro"],
"editor.defaultFormatter": "esbenp.prettier-vscode", "editor.defaultFormatter": "esbenp.prettier-vscode",
"[astro]": { "[astro]": {
"editor.formatOnSave": true, "editor.formatOnSave": false,
"editor.defaultFormatter": "esbenp.prettier-vscode" "editor.defaultFormatter": "esbenp.prettier-vscode"
}, },
"[javascript]": { "[javascript]": {
"editor.formatOnSave": true, "editor.formatOnSave": false,
"editor.defaultFormatter": "esbenp.prettier-vscode" "editor.defaultFormatter": "esbenp.prettier-vscode"
} }
} }

View File

@ -1,5 +1,5 @@
--- ---
const {} = Astro.props; const { } = Astro.props;
--- ---
<script is:inline> <script is:inline>
@ -48,4 +48,4 @@ const {} = Astro.props;
} }
document.getElementById("menu")?.classList.add("hidden"); document.getElementById("menu")?.classList.add("hidden");
}; };
</script> </script>

View File

@ -19,8 +19,8 @@ const image =
typeof _image === "string" typeof _image === "string"
? new URL(_image, Astro.site) ? new URL(_image, Astro.site)
: _image && typeof _image["src"] !== "undefined" : _image && typeof _image["src"] !== "undefined"
? new URL(getRelativeUrlByFilePath(_image.src), Astro.site) ? new URL(getRelativeUrlByFilePath(_image.src), Astro.site)
: null; : null;
--- ---
<meta charset="UTF-8" /> <meta charset="UTF-8" />
@ -29,35 +29,35 @@ const image =
<title>{title}</title> <title>{title}</title>
<meta name="description" content={description} /> <meta name="description" content={description} />
{canonical && <link rel="canonical" href={canonical} />} {canonical &&
<link rel="canonical" href={canonical} />}
<!-- Google / Search Engine Tags --> <!-- Google / Search Engine Tags -->
<meta itemprop="name" content={title} /> <meta itemprop="name" content={title} />
<meta itemprop="description" content={description} /> <meta itemprop="description" content={description} />
{image && <meta itemprop="image" content={image} />} {image &&
<meta itemprop="image" content={image} />}
<!-- Facebook Meta Tags --> <!-- Facebook Meta Tags -->
{canonical && <meta property="og:url" content={canonical} />} {canonical &&
<meta property="og:url" content={canonical} />}
<meta property="og:type" content="website" /> <meta property="og:type" content="website" />
<meta property="og:title" content={title} /> <meta property="og:title" content={title} />
<meta property="og:description" content={description} /> <meta property="og:description" content={description} />
{image && <meta property="og:image" content={image} />} {image &&
<meta property="og:image" content={image} />}
<!-- Twitter Meta Tags --> <!-- Twitter Meta Tags -->
{canonical && <meta name="twitter:url" content={canonical} />} {canonical &&
<meta name="twitter:url" content={canonical} />}
<meta name="twitter:card" content="summary_large_image" /> <meta name="twitter:card" content="summary_large_image" />
<meta name="twitter:title" content={title} /> <meta name="twitter:title" content={title} />
<meta name="twitter:description" content={description} /> <meta name="twitter:description" content={description} />
{image && <meta name="twitter:image" content={image} />} {image &&
<meta name="twitter:image" content={image} />}
<!-- Fonts --> <!-- Fonts -->
<link <link href="https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;700&display=swap" rel="stylesheet" />
href="https://fonts.googleapis.com/css2?family=IBM+Plex+Sans:wght@400;500;700&display=swap"
rel="stylesheet"
/>
<!-- Google Site Verification --> <!-- Google Site Verification -->
<meta <meta name="google-site-verification" content="orcPxI47GSa-cRvY11tUe6iGg2IO_RPvnA1q95iEM3M" />
name="google-site-verification"
content="orcPxI47GSa-cRvY11tUe6iGg2IO_RPvnA1q95iEM3M"
/>

View File

@ -1,18 +1,13 @@
--- ---
const {} = Astro.props; const { } = Astro.props;
--- ---
<section class="relative"> <section class="relative">
<div class="max-w-6xl mx-auto px-4 sm:px-6"> <div class="max-w-6xl mx-auto px-4 sm:px-6">
<div class="py-12 md:py-20"> <div class="py-12 md:py-20">
<div <div class="max-w-3xl mx-auto text-center p-6 rounded-md shadow-xl dark:shadow-none">
class="max-w-3xl mx-auto text-center p-6 rounded-md shadow-xl dark:shadow-none" <h2 class="text-4xl md:text-5xl font-bold leading-tighter tracking-tighter mb-4">
> <span>Astro</span> + <span class="whitespace-nowrap">Tailwind CSS
<h2
class="text-4xl md:text-5xl font-bold leading-tighter tracking-tighter mb-4"
>
<span>Astro</span> + <span class="whitespace-nowrap"
>Tailwind CSS
</span> </span>
</h2> </h2>
<p class="text-xl text-gray-600 dark:text-slate-400"> <p class="text-xl text-gray-600 dark:text-slate-400">
@ -21,15 +16,11 @@ const {} = Astro.props;
</p> </p>
<div class="mt-6"> <div class="mt-6">
<a <a class="btn text-white bg-blue-600 hover:bg-blue-800 sm:mb-0 font-bold"
class="btn text-white bg-blue-600 hover:bg-blue-800 sm:mb-0 font-bold" href="https://github.com/onwidget/astrowind" target="_blank" rel="noopener">Get template
href="https://github.com/onwidget/astrowind"
target="_blank"
rel="noopener"
>Get template
</a> </a>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</section> </section>

View File

@ -1,122 +0,0 @@
---
import { Icon } from "astro-icon";
const {} = Astro.props;
---
<div class="px-4 py-16 mx-auto max-w-6xl lg:py-20">
<div class="max-w-xl sm:mx-auto lg:max-w-2xl">
<div class="max-w-xl mb-10 md:mx-auto sm:text-center lg:max-w-2xl md:mb-12">
<h2
class="max-w-lg mb-4 font-sans text-3xl font-bold leading-none tracking-tight sm:text-4xl md:mx-auto"
>
Frequently Asked Questions
</h2>
</div>
</div>
<div class="max-w-screen-xl sm:mx-auto">
<div class="grid grid-cols-1 gap-8 lg:gap-16 row-gap-8 md:grid-cols-2">
<div class="space-y-8">
<div>
<p class="mb-4 text-xl font-bold">
<Icon
name="tabler:arrow-down-right"
class="w-7 h-7 text-blue-500 inline-block icon-bold"
/>
What do I need to start?
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
Space, the final frontier. These are the voyages of the Starship
Enterprise. Its five-year mission: to explore strange new worlds.
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
Many say exploration is part of our destiny, but its actually our
duty to future generations.
</p>
</div>
<div>
<p class="mb-4 text-xl font-bold">
<Icon
name="tabler:arrow-down-right"
class="w-7 h-7 text-blue-500 inline-block icon-bold"
/>
How to install the Astro + Tailwind CSS template?
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
Well, the way they make shows is, they make one show. That show's
called a pilot.
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
Then they show that show to the people who make shows, and on the
strength of that one show they decide if they're going to make more
shows. Some pilots get picked and become television programs.Some
don't, become nothing. She starred in one of the ones that became
nothing.
</p>
</div>
<div>
<p class="mb-4 text-xl font-bold">
<Icon
name="tabler:arrow-down-right"
class="w-7 h-7 text-blue-500 inline-block icon-bold"
/>
What's something that you completely don't understand?
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
A flower in my garden, a mystery in my panties. Heart attack never
stopped old Big Bear. I didn't even know we were calling him Big
Bear.
</p>
</div>
</div>
<div class="space-y-8">
<div>
<p class="mb-4 text-xl font-bold">
<Icon
name="tabler:arrow-down-right"
class="w-7 h-7 text-blue-500 inline-block icon-bold"
/>
What's an example of when you changed your mind?
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
Michael Knight a young loner on a crusade to champion the cause of
the innocent. The helpless. The powerless in a world of criminals
who operate above the law. Here he comes Here comes Speed Racer.
He's a demon on wheels.
</p>
</div>
<div>
<p class="mb-4 text-xl font-bold">
<Icon
name="tabler:arrow-down-right"
class="w-7 h-7 text-blue-500 inline-block icon-bold"
/>
What is something that you would really like to try again?
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
A business big enough that it could be listed on the NASDAQ goes
belly up. Disappears!
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
It ceases to exist without me. No, you clearly don't know who you're
talking to, so let me clue you in.
</p>
</div>
<div>
<p class="mb-4 text-xl font-bold">
<Icon
name="tabler:arrow-down-right"
class="w-7 h-7 text-blue-500 inline-block icon-bold"
/>
If you could only ask one question to each person you meet, what would
that question be?
</p>
<p class="text-gray-700 dark:text-gray-400 mb-2">
This is not about revenge. This is about justice. A lot of things
can change in twelve years, Admiral. Well, that's certainly good to
know. About four years. I got tired of hearing how young I looked.
</p>
</div>
</div>
</div>
</div>
</div>

View File

@ -1,114 +1,73 @@
--- ---
import { Icon } from "astro-icon"; import { Icon } from "astro-icon";
const {} = Astro.props; const { } = Astro.props;
const items = [
{
title: "Headers",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore.",
icon: "flat-color-icons:home"
},
{
title: "Footers",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore.",
icon: "flat-color-icons:faq"
},
{
title: "Features",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore.",
icon: "flat-color-icons:video-projector"
},
{
title: "Call-to-Action",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore.",
icon: "flat-color-icons:video-projector"
},
{
title: "Pricing",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore.",
icon: "flat-color-icons:calculator"
},
{
title: "Testimonial",
description: "Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore.",
icon: "flat-color-icons:voice-presentation"
}
]
--- ---
<section class="relative"> <section class="relative">
<div <div class="absolute inset-0 bg-blue-50 dark:bg-slate-800 pointer-events-none mb-32" aria-hidden="true">
class="absolute inset-0 bg-blue-50 dark:bg-slate-800 pointer-events-none mb-32"
aria-hidden="true"
>
</div> </div>
<div class="relative max-w-6xl mx-auto px-4 sm:px-6"> <div class="relative max-w-6xl mx-auto px-4 sm:px-6">
<div class="py-4 pt-8 sm:py-6 lg:py-8 lg:pt-12"> <div class="py-4 pt-8 sm:py-6 lg:py-8 lg:pt-12">
<div class="mb-8 text-center"> <div class="mb-8 text-center">
<p <p class="text-base text-blue-600 dark:text-blue-200 font-semibold tracking-wide uppercase">
class="text-base text-blue-600 dark:text-blue-200 font-semibold tracking-wide uppercase"
>
Components Components
</p> </p>
<h2 <h2 class="text-4xl md:text-5xl font-bold leading-tighter tracking-tighter mb-4">
class="text-4xl md:text-5xl font-bold leading-tighter tracking-tighter mb-4"
>
Most used widgets Most used widgets
</h2> </h2>
<p <p class="max-w-3xl mx-auto text-center text-xl text-gray-600 dark:text-slate-400">
class="max-w-3xl mx-auto text-center text-xl text-gray-600 dark:text-slate-400"
>
Provides frequently used components for building websites using Provides frequently used components for building websites using
Tailwind CSS Tailwind CSS
</p> </p>
</div> </div>
<div <div class="grid gap-6 md:grid-cols-2 lg:grid-cols-3 items-start my-12 dark:text-white">
class="grid gap-6 md:grid-cols-2 lg:grid-cols-3 items-start my-12 dark:text-white" {items.map(({ title, description, icon }) => (
> <div
<div class="relative flex flex-col p-6 bg-white dark:bg-slate-900 rounded shadow-xl hover:shadow-lg transition dark:border dark:border-slate-800">
class="relative flex flex-col p-6 bg-white dark:bg-slate-900 rounded shadow-xl hover:shadow-lg transition dark:border dark:border-slate-800"
>
<div class="flex items-center mb-4"> <div class="flex items-center mb-4">
<Icon name="flat-color-icons:home" class="w-12 h-12" /> <Icon name={icon} class="w-12 h-12" />
<div class="ml-4 text-xl font-bold">Headers</div> <div class="ml-4 text-xl font-bold">{title}</div>
</div> </div>
<p class="text-gray-500 dark:text-gray-400 text-md"> <p class="text-gray-500 dark:text-gray-400 text-md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do {description}
eiusmod tempor incididunt ut labore et dolore.
</p>
</div>
<div
class="relative flex flex-col p-6 bg-white dark:bg-slate-900 rounded shadow-xl hover:shadow-lg transition dark:border dark:border-slate-800"
>
<div class="flex items-center mb-4">
<Icon name="flat-color-icons:faq" class="w-12 h-12" />
<div class="ml-4 text-xl font-bold">Footers</div>
</div>
<p class="text-gray-500 dark:text-gray-400 text-md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore.
</p>
</div>
<div
class="relative flex flex-col p-6 bg-white dark:bg-slate-900 rounded shadow-xl hover:shadow-lg transition dark:border dark:border-slate-800"
>
<div class="flex items-center mb-4">
<Icon name="flat-color-icons:video-projector" class="w-12 h-12" />
<div class="ml-4 text-xl font-bold">Features</div>
</div>
<p class="text-gray-500 dark:text-gray-400 text-md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore.
</p>
</div>
<div
class="relative flex flex-col p-6 bg-white dark:bg-slate-900 rounded shadow-xl hover:shadow-lg transition dark:border dark:border-slate-800"
>
<div class="flex items-center mb-4">
<Icon name="flat-color-icons:in-transit" class="w-12 h-12" />
<div class="ml-4 text-xl font-bold">Call-to-Action</div>
</div>
<p class="text-gray-500 dark:text-gray-400 text-md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore.
</p>
</div>
<div
class="relative flex flex-col p-6 bg-white dark:bg-slate-900 rounded shadow-xl hover:shadow-lg transition dark:border dark:border-slate-800"
>
<div class="flex items-center mb-4">
<Icon name="flat-color-icons:calculator" class="w-12 h-12" />
<div class="ml-4 text-xl font-bold">Pricing</div>
</div>
<p class="text-gray-500 dark:text-gray-400 text-md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore.
</p>
</div>
<div
class="relative flex flex-col p-6 bg-white dark:bg-slate-900 rounded shadow-xl hover:shadow-lg transition dark:border dark:border-slate-800"
>
<div class="flex items-center mb-4">
<Icon name="flat-color-icons:voice-presentation" class="w-12 h-12"
/>
<div class="ml-4 text-xl font-bold">Testimonial</div>
</div>
<p class="text-gray-500 dark:text-gray-400 text-md">
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do
eiusmod tempor incididunt ut labore et dolore.
</p> </p>
</div> </div>
))}
</div> </div>
</div> </div>
</div> </div>
</section> </section>

View File

@ -7,31 +7,25 @@ const { page } = Astro.props;
<section class="px-4 sm:px-6 py-8 sm:py-16 lg:py-20 mx-auto max-w-3xl"> <section class="px-4 sm:px-6 py-8 sm:py-16 lg:py-20 mx-auto max-w-3xl">
<header> <header>
<h1 <h1 class="text-center text-5xl md:text-[3.50rem] font-bold leading-tighter tracking-tighter mb-8 md:mb-16">
class="text-center text-5xl md:text-[3.50rem] font-bold leading-tighter tracking-tighter mb-8 md:mb-16"
style="
"
>
News and step-by-step guides about News and step-by-step guides about
<span <span class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500">AstroWind
class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500"
>AstroWind
</span> </span>
</h1> </h1>
</header> </header>
<ul> <ul>
{ {
page.data.map((post) => ( page.data.map((post) => (
<li class="mb-10 md:mb-16"> <li class="mb-10 md:mb-16">
<BlogListItem post={post} /> <BlogListItem post={post} />
</li> </li>
)) ))
} }
</ul> </ul>
{ {
(page.url.prev || page.url.next) && ( (page.url.prev || page.url.next) && (
<Pagination prevUrl={page.url.prev} nextUrl={page.url.next} /> <Pagination prevUrl={page.url.prev} nextUrl={page.url.next} />
) )
} }
</section> </section>

View File

@ -1,36 +1,26 @@
--- ---
import Picture from "~/components/core/Picture.astro"; import Picture from "~/components/core/Picture.astro";
import { findImage } from "~/utils/findImage"; import { findImage } from "~/utils/findImage";
import { getFormattedDate } from "~/utils/getFormatedDate";
const { post } = Astro.props; const { post } = Astro.props;
const image = await findImage(post.image); const image = await findImage(post.image);
--- ---
<article <article class="max-w-md mx-auto md:max-w-none grid md:grid-cols-2 gap-6 md:gap-8">
class="max-w-md mx-auto md:max-w-none grid md:grid-cols-2 gap-6 md:gap-8"
>
<a class="relative block group" href="#0"> <a class="relative block group" href="#0">
<div <div
class="relative h-0 pb-[56.25%] md:pb-[75%] md:h-80 lg:pb-[56.25%] overflow-hidden bg-gray-400 dark:bg-slate-700 rounded shadow-lg" class="relative h-0 pb-[56.25%] md:pb-[75%] md:h-80 lg:pb-[56.25%] overflow-hidden bg-gray-400 dark:bg-slate-700 rounded shadow-lg">
> <Picture src={image} class="absolute inset-0 w-full h-full object-cover mb-6 rounded shadow-lg" widths={[400,
<Picture 768]} sizes="(max-width: 767px) 400px, 768px" alt={post.description} aspectRatio={1} />
src={image}
class="absolute inset-0 w-full h-full object-cover mb-6 rounded shadow-lg"
widths={[400, 768]}
sizes="(max-width: 767px) 400px, 768px"
alt={post.description}
aspectRatio={1}
/>
</div> </div>
</a> </a>
<div> <div>
<header> <header>
<h2 class="text-xl sm:text-2xl font-bold leading-snug mb-2"> <h2 class="text-xl sm:text-2xl font-bold leading-snug mb-2">
<a <a class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200"
class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200" href={`/blog/${post.slug}`}>
href={`/blog/${post.slug}`}
>
{post.title} {post.title}
</a> </a>
</h2> </h2>
@ -41,17 +31,9 @@ const image = await findImage(post.image);
<footer class="flex items-center mt-4"> <footer class="flex items-center mt-4">
<div> <div>
<span class="text-gray-500 dark:text-slate-400"> <span class="text-gray-500 dark:text-slate-400">
<time datetime={""}> <time datetime={post.pubDate}>{getFormattedDate(post.pubDate)}</time>
{
new Date(post.pubDate).toLocaleDateString("en-us", {
year: "numeric",
month: "short",
day: "numeric",
})
}
</time>
</span> </span>
</div> </div>
</footer> </footer>
</div> </div>
</article> </article>

View File

@ -1,5 +1,6 @@
--- ---
import Picture from "~/components/core/Picture.astro"; import Picture from "~/components/core/Picture.astro";
import { getFormattedDate } from "~/utils/getFormatedDate";
const { post } = Astro.props; const { post } = Astro.props;
--- ---
@ -8,39 +9,24 @@ const { post } = Astro.props;
<article> <article>
<header> <header>
<p class="max-w-3xl mx-auto text-center"> <p class="max-w-3xl mx-auto text-center">
<time datetime={post.pubDate}> <time datetime={post.pubDate}>{getFormattedDate(post.pubDate)}</time> ~ {Math.ceil(post.readingTime)} min
{
new Date(post.pubDate).toLocaleDateString("en-us", {
year: "numeric",
month: "short",
day: "numeric",
})
}
</time> ~ {Math.ceil(post.readingTime)} min
</p> </p>
<h1 <h1
class="px-4 sm:px-6 max-w-3xl mx-auto text-center text-5xl md:text-[3.50rem] font-bold leading-tighter tracking-tighter mb-6 md:mb-8" class="px-4 sm:px-6 max-w-3xl mx-auto text-center text-5xl md:text-[3.50rem] font-bold leading-tighter tracking-tighter mb-6 md:mb-8">
>
{post.title} {post.title}
</h1> </h1>
{ {
post.image && ( post.image && (
<Picture <Picture src={post.image}
src={post.image} class="max-w-full lg:max-w-6xl mx-auto mt-4 mb-6 sm:rounded-md bg-gray-400 dark:bg-slate-700" widths={[400,
class="max-w-full lg:max-w-6xl mx-auto mt-4 mb-6 sm:rounded-md bg-gray-400 dark:bg-slate-700" 900]} sizes="(max-width: 900px) 400px, 900px" alt={post.description} aspectRatio="16:9" />
widths={[400, 900]} )
sizes="(max-width: 900px) 400px, 900px"
alt={post.description}
aspectRatio="16:9"
/>
)
} }
</header> </header>
<div <div
class="container mx-auto px-4 sm:px-6 max-w-3xl prose prose-lg lg:prose-xl dark:prose-invert dark:prose-headings:text-slate-300 prose-md prose-headings:leading-tighter prose-headings:tracking-tighter prose-headings:font-bold prose-a:text-blue-600 dark:prose-a:text-blue-400 prose-img:rounded-md prose-img:shadow-lg mt-8" class="container mx-auto px-4 sm:px-6 max-w-3xl prose prose-lg lg:prose-xl dark:prose-invert dark:prose-headings:text-slate-300 prose-md prose-headings:leading-tighter prose-headings:tracking-tighter prose-headings:font-bold prose-a:text-blue-600 dark:prose-a:text-blue-400 prose-img:rounded-md prose-img:shadow-lg mt-8">
>
<Fragment set:html={post.body} /> <Fragment set:html={post.body} />
</div> </div>
</article> </article>
</section> </section>

View File

@ -2,15 +2,11 @@
--- ---
<section class="flex items-center h-full p-16"> <section class="flex items-center h-full p-16">
<div <div class="container flex flex-col items-center justify-center px-5 mx-auto my-8">
class="container flex flex-col items-center justify-center px-5 mx-auto my-8"
>
<div class="max-w-md text-center"> <div class="max-w-md text-center">
<h2 class="mb-8 font-bold text-9xl"> <h2 class="mb-8 font-bold text-9xl">
<span class="sr-only">Error</span> <span class="sr-only">Error</span>
<span <span class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500">404
class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500"
>404
</span> </span>
</h2> </h2>
<p class="text-3xl font-semibold md:text-3xl"> <p class="text-3xl font-semibold md:text-3xl">
@ -19,12 +15,10 @@
<p class="mt-4 mb-8 text-lg text-gray-600 dark:text-slate-400"> <p class="mt-4 mb-8 text-lg text-gray-600 dark:text-slate-400">
But dont worry, you can find plenty of other things on our homepage. But dont worry, you can find plenty of other things on our homepage.
</p> </p>
<a <a rel="noopener noreferrer" href="/"
rel="noopener noreferrer" class="btn text-white bg-gray-900 hover:bg-gray-800 dark:bg-gray-700 dark:hover:bg-gray-800 ml-4">Back to
href="/" homepage
class="btn text-white bg-gray-900 hover:bg-gray-800 dark:bg-gray-700 dark:hover:bg-gray-800 ml-4"
>Back to homepage
</a> </a>
</div> </div>
</div> </div>
</section> </section>

View File

@ -0,0 +1,73 @@
---
import { Icon } from "astro-icon";
const { } = Astro.props;
const items = [
[
{
question: "What do I need to start?",
answer: `Space, the final frontier. These are the voyages of the Starship Enterprise. Its five-year mission: to explore strange new worlds.
Many say exploration is part of our destiny, but its actually our duty to future generations.`,
},
{
question: "How to install the Astro + Tailwind CSS template?",
answer: `Well, the way they make shows is, they make one show. That show's called a pilot.
Then they show that show to the people who make shows, and on the strength of that one show they decide if they're going to make more shows. Some pilots get picked and become television programs. Some don't, become nothing. She starred in one of the ones that became nothing.`,
},
{
question: "What's something that you completely don't understand?",
answer: `A flower in my garden, a mystery in my panties. Heart attack never stopped old Big Bear. I didn't even know we were calling him Big Bear.`,
},
],
[
{
question: "What's an example of when you changed your mind?",
answer: `Michael Knight a young loner on a crusade to champion the cause of the innocent. The helpless. The powerless in a world of criminals who operate above the law. Here he comes Here comes Speed Racer. He's a demon on wheels.`,
},
{
question: "What is something that you would really like to try again?",
answer: `A business big enough that it could be listed on the NASDAQ goes belly up. Disappears!
It ceases to exist without me. No, you clearly don't know who you're talking to, so let me clue you in.`,
},
{
question:
"If you could only ask one question to each person you meet, what would that question be?",
answer: `This is not about revenge. This is about justice. A lot of things can change in twelve years, Admiral. Well, that's certainly good to know. About four years. I got tired of hearing how young I looked.`,
},
],
];
---
<div class="px-4 py-16 mx-auto max-w-6xl lg:py-20">
<div class="max-w-xl sm:mx-auto lg:max-w-2xl">
<div class="max-w-xl mb-10 md:mx-auto sm:text-center lg:max-w-2xl md:mb-12">
<h2 class="max-w-lg mb-4 font-sans text-3xl font-bold leading-none tracking-tight sm:text-4xl md:mx-auto">
Frequently Asked Questions
</h2>
</div>
</div>
<div class="max-w-screen-xl sm:mx-auto">
<div class="grid grid-cols-1 gap-x-8 gap-y-8 lg:gap-x-16 md:grid-cols-2">
{
items.map((subitems) => (
<div class="space-y-8">
{subitems.map(({ question, answer }) => (
<div>
<p class="mb-4 text-xl font-bold">
<Icon name="tabler:arrow-down-right" class="w-7 h-7 text-blue-500 inline-block icon-bold" />
{question}
</p>
{answer.split("\n\n").map((paragraph) => (
<p class="text-gray-700 dark:text-gray-400 mb-2" set:html={paragraph} />
))}
</div>
))}
</div>
))
}
</div>
</div>
</div>

View File

@ -1,28 +1,22 @@
--- ---
import { Icon } from "astro-icon"; import { Icon } from "astro-icon";
const {} = Astro.props; const { } = Astro.props;
--- ---
<footer> <footer>
<div class="max-w-6xl mx-auto px-4 sm:px-6"> <div class="max-w-6xl mx-auto px-4 sm:px-6">
<div <div class="grid grid-cols-12 gap-4 gap-y-8 sm:gap-8 py-8 md:py-12 border-t border-gray-200 dark:border-slate-800">
class="grid grid-cols-12 gap-4 gap-y-8 sm:gap-8 py-8 md:py-12 border-t border-gray-200 dark:border-slate-800"
>
<div class="col-span-12 lg:col-span-3"> <div class="col-span-12 lg:col-span-3">
<div class="mb-2"> <div class="mb-2">
<a class="inline-block font-bold text-xl" href="/">AstroWind</a> <a class="inline-block font-bold text-xl" href="/">AstroWind</a>
</div> </div>
<div class="text-sm text-gray-600"> <div class="text-sm text-gray-600">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 hover:underline transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 hover:underline transition duration-150 ease-in-out" href="#">Terms
href="#"
>Terms
</a> · </a> ·
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 hover:underline transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 hover:underline transition duration-150 ease-in-out" href="#">Privacy Policy
href="#"
>Privacy Policy
</a> </a>
</div> </div>
</div> </div>
@ -32,38 +26,28 @@ const {} = Astro.props;
</div> </div>
<ul class="text-sm"> <ul class="text-sm">
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Web Studio
href="#"
>Web Studio
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">DynamicBox Flex
href="#"
>DynamicBox Flex
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Programming Forms
href="#"
>Programming Forms
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Integrations
href="#"
>Integrations
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Command-line
href="#"
>Command-line
</a> </a>
</li> </li>
</ul> </ul>
@ -74,38 +58,28 @@ const {} = Astro.props;
</div> </div>
<ul class="text-sm"> <ul class="text-sm">
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Documentation
href="#"
>Documentation
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Tutorials &amp; Guides
href="#"
>Tutorials &amp; Guides
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Blog
href="#"
>Blog
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Support Center
href="#"
>Support Center
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Partners
href="#"
>Partners
</a> </a>
</li> </li>
</ul> </ul>
@ -116,38 +90,28 @@ const {} = Astro.props;
</div> </div>
<ul class="text-sm"> <ul class="text-sm">
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Home
href="#"
>Home
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">About us
href="#"
>About us
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Company values
href="#"
>Company values
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Pricing
href="#"
>Pricing
</a> </a>
</li> </li>
<li class="mb-2"> <li class="mb-2">
<a <a class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out"
class="text-gray-600 hover:text-gray-700 dark:text-gray-400 transition duration-150 ease-in-out" href="#">Privacy Policy
href="#"
>Privacy Policy
</a> </a>
</li> </li>
</ul> </ul>
@ -162,29 +126,17 @@ const {} = Astro.props;
<form> <form>
<div class="flex flex-wrap mb-4"> <div class="flex flex-wrap mb-4">
<div class="w-full"> <div class="w-full">
<label class="block text-sm sr-only" for="newsletter" <label class="block text-sm sr-only" for="newsletter">Email
>Email
</label> </label>
<div class="relative flex items-center max-w-xs"> <div class="relative flex items-center max-w-xs">
<input <input id="newsletter" type="email"
id="newsletter"
type="email"
class="form-input w-full text-gray-800 px-3 py-2 pr-12 text-sm border rounded-sm dark:bg-transparent dark:border-slate-600 dark:text-gray-400" class="form-input w-full text-gray-800 px-3 py-2 pr-12 text-sm border rounded-sm dark:bg-transparent dark:border-slate-600 dark:text-gray-400"
placeholder="Your email" placeholder="Your email" />
/> <button type="submit" class="absolute inset-0 left-auto" aria-label="Subscribe">
<button <span class="absolute inset-0 right-auto w-px -ml-px my-2 bg-gray-300 dark:bg-slate-600"
type="submit"
class="absolute inset-0 left-auto"
aria-label="Subscribe"
>
<span
class="absolute inset-0 right-auto w-px -ml-px my-2 bg-gray-300 dark:bg-slate-600"
aria-hidden="true"></span> aria-hidden="true"></span>
<Icon <Icon name="tabler:arrow-right" class="w-5 h-5 text-blue-600 mx-3 flex-shrink-0" />
name="tabler:arrow-right"
class="w-5 h-5 text-blue-600 mx-3 flex-shrink-0"
/>
</button> </button>
</div> </div>
</div> </div>
@ -195,54 +147,38 @@ const {} = Astro.props;
<div class="md:flex md:items-center md:justify-between py-4 md:py-8"> <div class="md:flex md:items-center md:justify-between py-4 md:py-8">
<ul class="flex mb-6 md:order-1 md:ml-4 md:mb-0"> <ul class="flex mb-6 md:order-1 md:ml-4 md:mb-0">
<li> <li>
<a <a class="flex justify-center items-center text-gray-600 hover:text-gray-700 bg-white hover:bg-white-100 rounded-full shadow transition duration-150 ease-in-out dark:bg-gray-800 dark:text-gray-400 p-1.5"
class="flex justify-center items-center text-gray-600 hover:text-gray-700 dark:text-gray-400 bg-white hover:bg-white-100 rounded-full shadow transition duration-150 ease-in-out dark:bg-gray-800 dark:text-gray-400 p-1.5" aria-label="Twitter" href="#">
aria-label="Twitter"
href="#"
>
<Icon name="tabler:brand-twitter" class="w-5 h-5" /> <Icon name="tabler:brand-twitter" class="w-5 h-5" />
</a> </a>
</li> </li>
<li class="ml-4"> <li class="ml-4">
<a <a class="flex justify-center items-center text-gray-600 hover:text-gray-700 bg-white hover:bg-white-100 rounded-full shadow transition duration-150 ease-in-out dark:bg-gray-800 dark:text-gray-400 p-1.5"
class="flex justify-center items-center text-gray-600 hover:text-gray-700 dark:text-gray-400 bg-white hover:bg-white-100 rounded-full shadow transition duration-150 ease-in-out dark:bg-gray-800 dark:text-gray-400 p-1.5" aria-label="Instagram" href="#">
aria-label="Instagram"
href="#"
>
<Icon name="tabler:brand-instagram" class="w-5 h-5" /> <Icon name="tabler:brand-instagram" class="w-5 h-5" />
</a> </a>
</li> </li>
<li class="ml-4"> <li class="ml-4">
<a <a class="flex justify-center items-center text-gray-600 hover:text-gray-700 bg-white hover:bg-white-100 rounded-full shadow transition duration-150 ease-in-out dark:bg-gray-800 dark:text-gray-400 p-1.5"
class="flex justify-center items-center text-gray-600 hover:text-gray-700 dark:text-gray-400 bg-white hover:bg-white-100 rounded-full shadow transition duration-150 ease-in-out dark:bg-gray-800 dark:text-gray-400 p-1.5" aria-label="Facebook" href="#">
aria-label="Facebook"
href="#"
>
<Icon name="tabler:brand-facebook" class="w-5 h-5" /> <Icon name="tabler:brand-facebook" class="w-5 h-5" />
</a> </a>
</li> </li>
<li class="ml-4"> <li class="ml-4">
<a <a class="flex justify-center items-center text-gray-600 hover:text-gray-700 bg-white hover:bg-white-100 rounded-full shadow transition duration-150 ease-in-out dark:bg-gray-800 dark:text-gray-400 p-1.5"
class="flex justify-center items-center text-gray-600 hover:text-gray-700 dark:text-gray-400 bg-white hover:bg-white-100 rounded-full shadow transition duration-150 ease-in-out dark:bg-gray-800 dark:text-gray-400 p-1.5" aria-label="Twitter" href="/rss.xml">
aria-label="Twitter"
href="/rss.xml"
>
<Icon name="tabler:rss" class="w-5 h-5" /> <Icon name="tabler:rss" class="w-5 h-5" />
</a> </a>
</li> </li>
</ul> </ul>
<div class="text-sm text-gray-700 mr-4 dark:text-slate-400"> <div class="text-sm text-gray-700 mr-4 dark:text-slate-400">
<span <span
class="w-5 h-5 md:w-6 md:h-6 md:-mt-0.5 bg-cover mr-1.5 float-left rounded-sm bg-[url(https://onwidget.com/favicon/favicon-32x32.png)]" class="w-5 h-5 md:w-6 md:h-6 md:-mt-0.5 bg-cover mr-1.5 float-left rounded-sm bg-[url(https://onwidget.com/favicon/favicon-32x32.png)]">
>
</span> </span>
Made by <a Made by <a class="text-blue-600 hover:underline dark:text-gray-200" href="https://onwidget.com/">
class="text-blue-600 hover:underline dark:text-gray-200"
href="https://onwidget.com/"
>
onWidget onWidget
</a>. All rights reserved. </a>. All rights reserved.
</div> </div>
</div> </div>
</div> </div>
</footer> </footer>

View File

@ -2,99 +2,69 @@
import { Icon } from "astro-icon"; import { Icon } from "astro-icon";
import Logo from "~/components/widgets/Logo.astro"; import Logo from "~/components/widgets/Logo.astro";
const {} = Astro.props; const { } = Astro.props;
--- ---
<header <header
class="sticky top-0 z-40 flex-none mx-auto w-full bg-white/90 dark:bg-slate-900/90 backdrop-blur-sm border-b dark:border-b-0" class="sticky top-0 z-40 flex-none mx-auto w-full bg-white/90 dark:bg-slate-900/90 backdrop-blur-sm border-b dark:border-b-0">
> <div class="py-3 px-3 mx-auto w-full md:flex md:justify-between max-w-6xl md:px-4">
<div
class="py-3 px-3 mx-auto w-full md:flex md:justify-between max-w-6xl md:px-4"
>
<div class="flex justify-between"> <div class="flex justify-between">
<a class="flex items-center" href="/"> <a class="flex items-center" href="/">
<Logo /> <Logo />
</a> </a>
<div class="flex items-center md:hidden"> <div class="flex items-center md:hidden">
<button <button type="button"
type="button"
class="text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 inline-flex items-center" class="text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 inline-flex items-center"
aria-label="Toggle between Dark and Light mode" aria-label="Toggle between Dark and Light mode" data-aw-toggle-color-scheme>
data-aw-toggle-color-scheme
>
<Icon name="tabler:sun" class="w-6 h-6" /> <Icon name="tabler:sun" class="w-6 h-6" />
</button> </button>
<button <button
class="ml-1.5 text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-800 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 inline-flex items-center transition" class="ml-1.5 text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-800 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 inline-flex items-center transition"
aria-label="Toggle Menu" aria-label="Toggle Menu" data-aw-toggle-menu>
data-aw-toggle-menu
>
<Icon name="tabler:menu" class="w-6 h-6" /> <Icon name="tabler:menu" class="w-6 h-6" />
</button> </button>
</div> </div>
</div> </div>
<nav <nav class="items-center w-full md:w-auto hidden md:flex text-gray-600 dark:text-slate-200"
class="items-center w-full md:w-auto hidden md:flex text-gray-600 dark:text-slate-200" aria-label="Main navigation" id="menu">
aria-label="Main navigation"
id="menu"
>
<ul <ul
class="flex flex-col pt-8 md:pt-0 md:flex-row md:self-center collapse w-full md:w-auto collapsed text-xl md:text-base" class="flex flex-col pt-8 md:pt-0 md:flex-row md:self-center collapse w-full md:w-auto collapsed text-xl md:text-base">
>
<li> <li>
<a <a class="font-medium hover:text-gray-900 dark:hover:text-white px-4 py-3 flex items-center transition duration-150 ease-in-out"
class="font-medium hover:text-gray-900 dark:hover:text-white px-4 py-3 flex items-center transition duration-150 ease-in-out" href="#">Pages
href="#"
>Pages
</a> </a>
</li> </li>
<li> <li>
<a <a class="font-medium hover:text-gray-900 dark:hover:text-white px-4 py-3 flex items-center transition duration-150 ease-in-out"
class="font-medium hover:text-gray-900 dark:hover:text-white px-4 py-3 flex items-center transition duration-150 ease-in-out" href="#">Resources
href="#"
>Resources
</a> </a>
</li> </li>
<li> <li>
<a <a class="font-medium hover:text-gray-900 dark:hover:text-white px-4 py-3 flex items-center transition duration-150 ease-in-out"
class="font-medium hover:text-gray-900 dark:hover:text-white px-4 py-3 flex items-center transition duration-150 ease-in-out" href="/blog">Blog
href="/blog"
>Blog
</a> </a>
</li> </li>
<li class="md:hidden"> <li class="md:hidden">
<a <a class="font-bold hover:text-gray-900 dark:hover:text-white px-4 py-3 flex items-center transition duration-150 ease-in-out"
class="font-bold hover:text-gray-900 dark:hover:text-white px-4 py-3 flex items-center transition duration-150 ease-in-out" href="https://github.com/onwidget/astrowind">
href="https://github.com/onwidget/astrowind"
>
Github Github
</a> </a>
</li> </li>
</ul> </ul>
<div <div class="md:self-center flex items-center mb-4 md:mb-0 collapse collapsed">
class="md:self-center flex items-center mb-4 md:mb-0 collapse collapsed"
>
<div class="hidden items-center mr-3 md:flex"> <div class="hidden items-center mr-3 md:flex">
<button <button type="button"
type="button"
class="text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 inline-flex items-center" class="text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 inline-flex items-center"
aria-label="Toggle between Dark and Light mode" aria-label="Toggle between Dark and Light mode" data-aw-toggle-color-scheme>
data-aw-toggle-color-scheme
>
<Icon name="tabler:sun" class="w-5 h-5" /> <Icon name="tabler:sun" class="w-5 h-5" />
</button> </button>
<a <a class="text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 inline-flex items-center"
class="text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 inline-flex items-center" aria-label="RSS Feed" href="/rss.xml">
aria-label="RSS Feed"
href="/rss.xml"
>
<Icon name="tabler:rss" class="w-5 h-5" /> <Icon name="tabler:rss" class="w-5 h-5" />
</a> </a>
<a <a href="https://github.com/onwidget/astrowind"
href="https://github.com/onwidget/astrowind"
class="inline-block text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 mr-1" class="inline-block text-gray-500 dark:text-gray-400 hover:bg-gray-100 dark:hover:bg-gray-700 focus:outline-none focus:ring-4 focus:ring-gray-200 dark:focus:ring-gray-700 rounded-lg text-sm p-2.5 mr-1"
aria-label="Astrowind Github" aria-label="Astrowind Github">
>
<Icon name="tabler:brand-github" class="w-5 h-5" /> <Icon name="tabler:brand-github" class="w-5 h-5" />
</a> </a>
</div> </div>
@ -111,4 +81,4 @@ const {} = Astro.props;
[data-aw-toggle-menu].expanded .line2 { [data-aw-toggle-menu].expanded .line2 {
transform: rotate(45deg) translate(4px, -16px); transform: rotate(45deg) translate(4px, -16px);
} }
</style> </style>

View File

@ -1,23 +1,19 @@
--- ---
import Picture from "~/components/core/Picture.astro"; import Picture from "~/components/core/Picture.astro";
const {} = Astro.props; const { } = Astro.props;
--- ---
<section> <section>
<div class="max-w-6xl mx-auto px-4 sm:px-6"> <div class="max-w-6xl mx-auto px-4 sm:px-6">
<div class="py-12 md:py-20"> <div class="py-12 md:py-20">
<div class="text-center pb-12 md:pb-16"> <div class="text-center pb-12 md:pb-16">
<h1 <h1 class="text-5xl md:text-[3.50rem] font-bold leading-tighter tracking-tighter mb-4">
class="text-5xl md:text-[3.50rem] font-bold leading-tighter tracking-tighter mb-4"
>
Your website with Your website with
<span <span class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500">Astro
class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500"
>Astro
</span> + </span> +
<span <span
class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500 whitespace-nowrap" class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500 whitespace-nowrap">Tailwind
>Tailwind CSS CSS
</span> </span>
</h1> </h1>
<div class="max-w-3xl mx-auto"> <div class="max-w-3xl mx-auto">
@ -29,19 +25,13 @@ const {} = Astro.props;
</p> </p>
<div class="max-w-none flex justify-center"> <div class="max-w-none flex justify-center">
<div> <div>
<a <a class="btn text-white bg-blue-600 hover:bg-blue-800 mb-4 sm:mb-0 font-bold"
class="btn text-white bg-blue-600 hover:bg-blue-800 mb-4 sm:mb-0 font-bold" href="https://github.com/onwidget/astrowind" target="_blank" rel="noopener">Get template
href="https://github.com/onwidget/astrowind"
target="_blank"
rel="noopener"
>Get template
</a> </a>
</div> </div>
<div> <div>
<a <a class="btn text-white bg-gray-900 hover:bg-gray-800 dark:bg-gray-700 dark:hover:bg-gray-800 ml-4"
class="btn text-white bg-gray-900 hover:bg-gray-800 dark:bg-gray-700 dark:hover:bg-gray-800 ml-4" href="#features">Learn more
href="#features"
>Learn more
</a> </a>
</div> </div>
</div> </div>
@ -50,17 +40,12 @@ const {} = Astro.props;
<div> <div>
<div class="relative flex justify-center mb-8"> <div class="relative flex justify-center mb-8">
<div class="flex flex-col justify-center"> <div class="flex flex-col justify-center">
<Picture <Picture src={import("~/assets/images/hero.jpg")}
src={import("~/assets/images/hero.jpg")} class="mx-auto rounded-md shadow-lg bg-gray-400 dark:bg-slate-700" widths={[400, 768]}
class="mx-auto rounded-md shadow-lg bg-gray-400 dark:bg-slate-700" sizes=" (max-width: 767px) 400px, 768px" alt="Hero Image" aspectRatio="16:9" />
widths={[400, 768]}
sizes=" (max-width: 767px) 400px, 768px"
alt="Hero Image"
aspectRatio="16:9"
/>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</section> </section>

View File

@ -1,15 +1,12 @@
--- ---
import Picture from "~/components/core/Picture.astro"; import Picture from "~/components/core/Picture.astro";
const {} = Astro.props; const { } = Astro.props;
--- ---
<section class="px-4 py-16 mx-auto max-w-6xl lg:py-20"> <section class="px-4 py-16 mx-auto max-w-6xl lg:py-20">
<div class="flex flex-col mb-6 lg:justify-between lg:flex-row md:mb-8"> <div class="flex flex-col mb-6 lg:justify-between lg:flex-row md:mb-8">
<h2 <h2 class="max-w-lg mb-2 font-sans text-3xl font-bold tracking-tight sm:text-4xl sm:leading-none lg:mb-5 group">
class="max-w-lg mb-2 font-sans text-3xl font-bold tracking-tight sm:text-4xl sm:leading-none lg:mb-5 group" <span class="inline-block mb-1 sm:mb-4">Find out more content<br class="hidden md:block" /> in our Blog
>
<span class="inline-block mb-1 sm:mb-4"
>Find out more content<br class="hidden md:block" /> in our Blog
</span> </span>
</h2> </h2>
<p class="text-gray-700 dark:text-slate-400 lg:text-sm lg:max-w-md"> <p class="text-gray-700 dark:text-slate-400 lg:text-sm lg:max-w-md">
@ -22,18 +19,13 @@ const {} = Astro.props;
<div class="grid gap-6 row-gap-5 md:grid-cols-2 lg:grid-cols-4 -mb-6"> <div class="grid gap-6 row-gap-5 md:grid-cols-2 lg:grid-cols-4 -mb-6">
<div class="mb-6 transition"> <div class="mb-6 transition">
<Picture <Picture src={import("~/assets/images/steps.jpg")}
src={import("~/assets/images/steps.jpg")} class="object-cover w-full h-64 mb-6 rounded shadow-lg bg-gray-400 dark:bg-slate-700" widths={[400]}
class="object-cover w-full h-64 mb-6 rounded shadow-lg bg-gray-400 dark:bg-slate-700" alt="Post 2 Image" aspectRatio="16:9" />
widths={[400]}
alt="Post 2 Image"
aspectRatio="16:9"
/>
<h3 class="mb-2 text-xl font-bold leading-snug sm:text-2xl"> <h3 class="mb-2 text-xl font-bold leading-snug sm:text-2xl">
<a <a href="/blog/get-started-website-with-astro-tailwind-css"
href="/blog/get-started-website-with-astro-tailwind-css" class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200">Get
class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200" started with AstroWind to create a website using Astro and
>Get started with AstroWind to create a website using Astro and
Tailwind CSS Tailwind CSS
</a> </a>
</h3> </h3>
@ -45,18 +37,13 @@ const {} = Astro.props;
</div> </div>
<div class="mb-6 transition"> <div class="mb-6 transition">
<Picture <Picture src={import("~/assets/images/colors.jpg")}
src={import("~/assets/images/colors.jpg")} class="object-cover w-full h-64 mb-6 rounded shadow-lg bg-gray-400 dark:bg-slate-700" widths={[400]}
class="object-cover w-full h-64 mb-6 rounded shadow-lg bg-gray-400 dark:bg-slate-700" alt="Post 1 Image" aspectRatio="16:9" />
widths={[400]}
alt="Post 1 Image"
aspectRatio="16:9"
/>
<h3 class="mb-2 text-xl font-bold leading-snug sm:text-2xl"> <h3 class="mb-2 text-xl font-bold leading-snug sm:text-2xl">
<a <a href="/blog/how-to-customize-astrowind-to-your-brand"
href="/blog/how-to-customize-astrowind-to-your-brand" class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200">How
class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200" to customize AstroWind template to suit your branding
>How to customize AstroWind template to suit your branding
</a> </a>
</h3> </h3>
<p class="text-gray-700 dark:text-gray-400"> <p class="text-gray-700 dark:text-gray-400">
@ -67,18 +54,13 @@ const {} = Astro.props;
</div> </div>
<div class="mb-6 transition"> <div class="mb-6 transition">
<Picture <Picture src={import("~/assets/images/tools.jpg")}
src={import("~/assets/images/tools.jpg")} class="object-cover w-full h-64 mb-6 rounded shadow-lg bg-gray-400 dark:bg-slate-700" widths={[400]}
class="object-cover w-full h-64 mb-6 rounded shadow-lg bg-gray-400 dark:bg-slate-700" alt="Post 3 Image" aspectRatio="16:9" />
widths={[400]}
alt="Post 3 Image"
aspectRatio="16:9"
/>
<h3 class="mb-2 text-xl font-bold leading-snug sm:text-2xl"> <h3 class="mb-2 text-xl font-bold leading-snug sm:text-2xl">
<a <a href="/blog/useful-resources-to-create-websites"
href="/blog/useful-resources-to-create-websites" class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200">Useful
class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200" tools and resources to create a professional website
>Useful tools and resources to create a professional website
</a> </a>
</h3> </h3>
<p class="text-gray-700 dark:text-gray-400"> <p class="text-gray-700 dark:text-gray-400">
@ -89,18 +71,13 @@ const {} = Astro.props;
</div> </div>
<div class="mb-6 transition"> <div class="mb-6 transition">
<Picture <Picture src={import("~/assets/images/hero.jpg")}
src={import("~/assets/images/hero.jpg")} class="object-cover w-full h-64 mb-6 rounded shadow-lg bg-gray-400 dark:bg-slate-700" widths={[400]}
class="object-cover w-full h-64 mb-6 rounded shadow-lg bg-gray-400 dark:bg-slate-700" alt="Post 2 Image" aspectRatio="16:9" />
widths={[400]}
alt="Post 2 Image"
aspectRatio="16:9"
/>
<h3 class="mb-2 text-xl font-bold leading-snug sm:text-2xl"> <h3 class="mb-2 text-xl font-bold leading-snug sm:text-2xl">
<a <a href="/blog/astrowind-template-in-depth"
href="/blog/astrowind-template-in-depth" class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200">AstroWind
class="hover:text-blue-600 underline underline-offset-4 decoration-1 decoration-dotted transition ease-in duration-200" template in depth
>AstroWind template in depth
</a> </a>
</h3> </h3>
<p class="text-gray-700 dark:text-gray-400"> <p class="text-gray-700 dark:text-gray-400">
@ -110,4 +87,4 @@ const {} = Astro.props;
</p> </p>
</div> </div>
</div> </div>
</section> </section>

View File

@ -1,8 +1,6 @@
--- ---
--- ---
<span <span class="self-center ml-2 text-2xl font-extrabold text-gray-900 whitespace-nowrap dark:text-white">
class="self-center ml-2 text-2xl font-extrabold text-gray-900 whitespace-nowrap dark:text-white"
>
🚀 AstroWind 🚀 AstroWind
</span> </span>

View File

@ -4,47 +4,27 @@ const { prevUrl, nextUrl } = Astro.props;
<div class="container flex"> <div class="container flex">
<div class="flex flex-row mx-auto container justify-between"> <div class="flex flex-row mx-auto container justify-between">
<a <a href={prevUrl} class={`btn font-medium text-gray-600 hover:text-gray-900 dark:hover:text-white shadow-none mr-2
href={prevUrl} ${ !prevUrl ? "invisible" : "" }`}>
class={`btn font-medium text-gray-600 hover:text-gray-900 dark:hover:text-white shadow-none mr-2 ${
!prevUrl ? "invisible" : ""
}`}
>
<div class="flex flex-row align-middle"> <div class="flex flex-row align-middle">
<svg <svg class="w-5 mr-2" fill="currentColor" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg">
class="w-5 mr-2" <path fill-rule="evenodd"
fill="currentColor"
viewBox="0 0 20 20"
xmlns="http://www.w3.org/2000/svg"
>
<path
fill-rule="evenodd"
d="M7.707 14.707a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414l4-4a1 1 0 011.414 1.414L5.414 9H17a1 1 0 110 2H5.414l2.293 2.293a1 1 0 010 1.414z" d="M7.707 14.707a1 1 0 01-1.414 0l-4-4a1 1 0 010-1.414l4-4a1 1 0 011.414 1.414L5.414 9H17a1 1 0 110 2H5.414l2.293 2.293a1 1 0 010 1.414z"
clip-rule="evenodd"></path> clip-rule="evenodd"></path>
</svg> </svg>
<p class="ml-2">Newer posts</p> <p class="ml-2">Newer posts</p>
</div> </div>
</a> </a>
<a <a href={nextUrl} class={`btn font-medium text-gray-600 hover:text-gray-900 dark:hover:text-white shadow-none ${
href={nextUrl} !nextUrl ? "invisible" : "" }`}>
class={`btn font-medium text-gray-600 hover:text-gray-900 dark:hover:text-white shadow-none ${
!nextUrl ? "invisible" : ""
}`}
>
<div class="flex flex-row align-middle"> <div class="flex flex-row align-middle">
<span class="mr-2">Older posts</span> <span class="mr-2">Older posts</span>
<svg <svg class="w-5 ml-2" fill="currentColor" viewBox="0 0 20 20" xmlns="http://www.w3.org/2000/svg">
class="w-5 ml-2" <path fill-rule="evenodd"
fill="currentColor"
viewBox="0 0 20 20"
xmlns="http://www.w3.org/2000/svg"
>
<path
fill-rule="evenodd"
d="M12.293 5.293a1 1 0 011.414 0l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414-1.414L14.586 11H3a1 1 0 110-2h11.586l-2.293-2.293a1 1 0 010-1.414z" d="M12.293 5.293a1 1 0 011.414 0l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414-1.414L14.586 11H3a1 1 0 110-2h11.586l-2.293-2.293a1 1 0 010-1.414z"
clip-rule="evenodd"></path> clip-rule="evenodd"></path>
</svg> </svg>
</div> </div>
</a> </a>
</div> </div>
</div> </div>

View File

@ -1,18 +1,14 @@
--- ---
const {} = Astro.props; const { } = Astro.props;
--- ---
<div <div class="px-4 py-8 md:py-16 sm:px-6 mx-auto md:px-24 lg:px-8 lg:py-20 max-w-6xl">
class="px-4 py-8 md:py-16 sm:px-6 mx-auto md:px-24 lg:px-8 lg:py-20 max-w-6xl"
>
<div class="grid grid-cols-2 row-gap-8 md:grid-cols-4"> <div class="grid grid-cols-2 row-gap-8 md:grid-cols-4">
<div class="text-center md:border-r dark:md:border-slate-500 mb-10 md:mb-0"> <div class="text-center md:border-r dark:md:border-slate-500 mb-10 md:mb-0">
<div class="text-4xl font-bold lg:text-5xl xl:text-6xl text-blue-500"> <div class="text-4xl font-bold lg:text-5xl xl:text-6xl text-blue-500">
132K 132K
</div> </div>
<p <p class="text-sm font-medium tracking-widest text-gray-800 dark:text-slate-400 uppercase lg:text-base">
class="text-sm font-medium tracking-widest text-gray-800 dark:text-slate-400 uppercase lg:text-base"
>
Downloads Downloads
</p> </p>
</div> </div>
@ -20,9 +16,7 @@ const {} = Astro.props;
<div class="text-4xl font-bold lg:text-5xl xl:text-6xl text-blue-500"> <div class="text-4xl font-bold lg:text-5xl xl:text-6xl text-blue-500">
24.8K 24.8K
</div> </div>
<p <p class="text-sm font-medium tracking-widest text-gray-800 dark:text-slate-400 uppercase lg:text-base">
class="text-sm font-medium tracking-widest text-gray-800 dark:text-slate-400 uppercase lg:text-base"
>
Stars Stars
</p> </p>
</div> </div>
@ -30,9 +24,7 @@ const {} = Astro.props;
<div class="text-4xl font-bold lg:text-5xl xl:text-6xl text-blue-500"> <div class="text-4xl font-bold lg:text-5xl xl:text-6xl text-blue-500">
10.3K 10.3K
</div> </div>
<p <p class="text-sm font-medium tracking-widest text-gray-800 dark:text-slate-400 uppercase lg:text-base">
class="text-sm font-medium tracking-widest text-gray-800 dark:text-slate-400 uppercase lg:text-base"
>
Forks Forks
</p> </p>
</div> </div>
@ -40,11 +32,9 @@ const {} = Astro.props;
<div class="text-4xl font-bold lg:text-5xl xl:text-6xl text-blue-500"> <div class="text-4xl font-bold lg:text-5xl xl:text-6xl text-blue-500">
48.4K 48.4K
</div> </div>
<p <p class="text-sm font-medium tracking-widest text-gray-800 dark:text-slate-400 uppercase lg:text-base">
class="text-sm font-medium tracking-widest text-gray-800 dark:text-slate-400 uppercase lg:text-base"
>
Users Users
</p> </p>
</div> </div>
</div> </div>
</div> </div>

View File

@ -1,5 +1,5 @@
--- ---
const {} = Astro.props; const { } = Astro.props;
--- ---
<section> <section>
@ -20,12 +20,8 @@ const {} = Astro.props;
tincidunt vehicula. Fusce sit amet dui tellus. tincidunt vehicula. Fusce sit amet dui tellus.
</p> </p>
<div class="w-full"> <div class="w-full">
<a <a class="btn bg-blue-600 hover:bg-blue-700 text-white font-bold"
class="btn bg-blue-600 hover:bg-blue-700 text-white font-bold" href="https://github.com/onwidget/astrowind" target="_blank" rel="noopener">
href="https://github.com/onwidget/astrowind"
target="_blank"
rel="noopener"
>
Get template Get template
</a> </a>
</div> </div>
@ -36,8 +32,7 @@ const {} = Astro.props;
<li class="flex md:-mx-4"> <li class="flex md:-mx-4">
<div class="pr-4 sm:pl-4"> <div class="pr-4 sm:pl-4">
<span <span
class="flex w-16 h-16 mx-auto items-center justify-center text-2xl font-bold font-heading rounded-full bg-blue-50 text-blue-600" class="flex w-16 h-16 mx-auto items-center justify-center text-2xl font-bold font-heading rounded-full bg-blue-50 text-blue-600">
>
1 1
</span> </span>
</div> </div>
@ -55,8 +50,7 @@ const {} = Astro.props;
<li class="flex md:-mx-4"> <li class="flex md:-mx-4">
<div class="pr-4 sm:pl-4"> <div class="pr-4 sm:pl-4">
<span <span
class="flex w-16 h-16 mx-auto items-center justify-center text-2xl font-bold font-heading rounded-full bg-blue-50 text-blue-600" class="flex w-16 h-16 mx-auto items-center justify-center text-2xl font-bold font-heading rounded-full bg-blue-50 text-blue-600">
>
2 2
</span> </span>
</div> </div>
@ -72,8 +66,7 @@ const {} = Astro.props;
<li class="flex md:-mx-4"> <li class="flex md:-mx-4">
<div class="pr-4 sm:pl-4"> <div class="pr-4 sm:pl-4">
<span <span
class="flex w-16 h-16 mx-auto items-center justify-center text-2xl font-bold font-heading rounded-full bg-blue-50 text-blue-600" class="flex w-16 h-16 mx-auto items-center justify-center text-2xl font-bold font-heading rounded-full bg-blue-50 text-blue-600">
>
3 3
</span> </span>
</div> </div>
@ -92,4 +85,4 @@ const {} = Astro.props;
</div> </div>
</div> </div>
</div> </div>
</section> </section>

View File

@ -2,7 +2,7 @@
import { Icon } from "astro-icon"; import { Icon } from "astro-icon";
import Picture from "~/components/core/Picture.astro"; import Picture from "~/components/core/Picture.astro";
const {} = Astro.props; const { } = Astro.props;
--- ---
<section class="px-4 py-16 sm:px-6 mx-auto lg:px-8 lg:py-20 max-w-6xl"> <section class="px-4 py-16 sm:px-6 mx-auto lg:px-8 lg:py-20 max-w-6xl">
@ -11,13 +11,8 @@ const {} = Astro.props;
<div class="flex"> <div class="flex">
<div class="flex flex-col items-center mr-4"> <div class="flex flex-col items-center mr-4">
<div> <div>
<div <div class="flex items-center justify-center w-10 h-10 rounded-full border-pink-500 border-2">
class="flex items-center justify-center w-10 h-10 rounded-full border-pink-500 border-2" <Icon name="tabler:arrow-down" class="w-6 h-6 text-gray-600 dark:text-slate-200 icon-bold" />
>
<Icon
name="tabler:arrow-down"
class="w-6 h-6 text-gray-600 dark:text-slate-200 icon-bold"
/>
</div> </div>
</div> </div>
<div class="w-px h-full bg-gray-300 dark:bg-slate-500"></div> <div class="w-px h-full bg-gray-300 dark:bg-slate-500"></div>
@ -37,13 +32,8 @@ const {} = Astro.props;
<div class="flex"> <div class="flex">
<div class="flex flex-col items-center mr-4"> <div class="flex flex-col items-center mr-4">
<div> <div>
<div <div class="flex items-center justify-center w-10 h-10 rounded-full border-pink-500 border-2">
class="flex items-center justify-center w-10 h-10 rounded-full border-pink-500 border-2" <Icon name="tabler:arrow-down" class="w-6 h-6 text-gray-600 dark:text-slate-200 icon-bold" />
>
<Icon
name="tabler:arrow-down"
class="w-6 h-6 text-gray-600 dark:text-slate-200 icon-bold"
/>
</div> </div>
</div> </div>
<div class="w-px h-full bg-gray-300 dark:bg-slate-500"></div> <div class="w-px h-full bg-gray-300 dark:bg-slate-500"></div>
@ -62,13 +52,8 @@ const {} = Astro.props;
<div class="flex"> <div class="flex">
<div class="flex flex-col items-center mr-4"> <div class="flex flex-col items-center mr-4">
<div> <div>
<div <div class="flex items-center justify-center w-10 h-10 rounded-full border-pink-500 border-2">
class="flex items-center justify-center w-10 h-10 rounded-full border-pink-500 border-2" <Icon name="tabler:arrow-down" class="w-6 h-6 text-gray-600 dark:text-slate-200 icon-bold" />
>
<Icon
name="tabler:arrow-down"
class="w-6 h-6 text-gray-600 dark:text-slate-200 icon-bold"
/>
</div> </div>
</div> </div>
<div class="w-px h-full bg-gray-300 dark:bg-slate-500"></div> <div class="w-px h-full bg-gray-300 dark:bg-slate-500"></div>
@ -87,13 +72,8 @@ const {} = Astro.props;
<div class="flex"> <div class="flex">
<div class="flex flex-col items-center mr-4"> <div class="flex flex-col items-center mr-4">
<div> <div>
<div <div class="flex items-center justify-center w-10 h-10 rounded-full border-blue-600 border-2">
class="flex items-center justify-center w-10 h-10 rounded-full border-blue-600 border-2" <Icon name="tabler:check" class="w-6 h-6 text-gray-600 dark:text-slate-200 icon-bold" />
>
<Icon
name="tabler:check"
class="w-6 h-6 text-gray-600 dark:text-slate-200 icon-bold"
/>
</div> </div>
</div> </div>
</div> </div>
@ -108,12 +88,8 @@ const {} = Astro.props;
<div class="relative"> <div class="relative">
<Picture <Picture
class="inset-0 object-cover object-top w-full rounded-md shadow-lg md:absolute md:h-full bg-gray-400 dark:bg-slate-700" class="inset-0 object-cover object-top w-full rounded-md shadow-lg md:absolute md:h-full bg-gray-400 dark:bg-slate-700"
src={import("~/assets/images/astronaut.jpg")} src={import("~/assets/images/astronaut.jpg")} widths={[400, 768]} sizes="(max-width: 768px) 100vw, 432px"
widths={[400, 768]} alt="Astronaut" aspectRatio="432:768" />
sizes="(max-width: 768px) 100vw, 432px"
alt="Astronaut"
aspectRatio="432:768"
/>
</div> </div>
</div> </div>
</section> </section>

View File

@ -1,60 +1,74 @@
--- ---
const {} = Astro.props; const { } = Astro.props;
const items = [
[
{
title: "Integration with Tailwind CSS",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi sagittis, quam nec venenatis lobortis, mi risus tempus nulla.",
},
{
title: "Ready-to-use Components",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi sagittis, quam nec venenatis lobortis, mi risus tempus nulla.",
},
{
title: "Best Practices",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi sagittis, quam nec venenatis lobortis, mi risus tempus nulla.",
},
],
[
{
title: "Excelent Page Speed",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi sagittis, quam nec venenatis lobortis, mi risus tempus nulla.",
},
{
title: "Frequently updated",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi sagittis, quam nec venenatis lobortis, mi risus tempus nulla.",
},
{
title: "Open to new ideas and contributions",
description:
"Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi sagittis, quam nec venenatis lobortis, mi risus tempus nulla.",
},
],
];
--- ---
<section class="scroll-mt-16" id="features"> <section class="scroll-mt-16" id="features">
<div <div class="px-4 py-16 mx-auto max-w-6xl lg:px-8 lg:py-20 bg-blue-50 dark:bg-slate-800">
class="px-4 py-16 mx-auto max-w-6xl lg:px-8 lg:py-20 bg-blue-50 dark:bg-slate-800"
>
<div class="max-w-xl mb-10 md:mx-auto sm:text-center lg:max-w-2xl md:mb-12"> <div class="max-w-xl mb-10 md:mx-auto sm:text-center lg:max-w-2xl md:mb-12">
<p <p class="text-base text-blue-600 dark:text-blue-200 font-semibold tracking-wide uppercase">
class="text-base text-blue-600 dark:text-blue-200 font-semibold tracking-wide uppercase"
>
Features Features
</p> </p>
<h2 <h2 class="text-4xl md:text-5xl font-bold leading-tighter tracking-tighter mb-4">
class="text-4xl md:text-5xl font-bold leading-tighter tracking-tighter mb-4"
>
What's interesting about <span What's interesting about <span
class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500 whitespace-nowrap" class="bg-clip-text text-transparent bg-gradient-to-r from-blue-500 to-pink-500 whitespace-nowrap">AstroWind
>AstroWind
</span> </span>
</h2> </h2>
<p <p class="max-w-3xl mx-auto sm:text-center text-xl text-gray-600 dark:text-slate-400">
class="max-w-3xl mx-auto sm:text-center text-xl text-gray-600 dark:text-slate-400"
>
Sed ut perspiciatis unde omnis iste natus error sit voluptatem Sed ut perspiciatis unde omnis iste natus error sit voluptatem
accusantium doloremque rem aperiam, eaque ipsa quae. accusantium doloremque rem aperiam, eaque ipsa quae.
</p> </p>
</div> </div>
<div class="grid mx-auto space-y-6 md:grid-cols-2 md:space-y-0"> <div class="grid mx-auto space-y-6 md:grid-cols-2 md:space-y-0">
{
items.map((subitems) => (
<div class="space-y-8 sm:px-8"> <div class="space-y-8 sm:px-8">
{subitems.map(({ title, description }) => (
<div class="flex flex-row max-w-md"> <div class="flex flex-row max-w-md">
<div class="mb-4 mr-4"> <div class="mb-4 mr-4">
<div <div class="flex items-center justify-center w-12 h-12 rounded-full bg-blue-500">
class="flex items-center justify-center w-12 h-12 rounded-full bg-blue-500" <svg class="w-12 h-12 p-0.5" viewBox="0 0 64 64" xmlns="http://www.w3.org/2000/svg">
>
<svg
class="w-12 h-12 p-0.5"
viewBox="0 0 64 64"
xmlns="http://www.w3.org/2000/svg"
>
<g fill="none" fill-rule="evenodd"> <g fill="none" fill-rule="evenodd">
<rect <rect class="fill-current text-blue-600" width="64" height="64" rx="32" />
class="fill-current text-blue-600"
width="64"
height="64"
rx="32"></rect>
<g stroke-linecap="square" stroke-width="2"> <g stroke-linecap="square" stroke-width="2">
<path <path class="stroke-current text-white" d="M20.571 20.571h13.714v17.143H20.571z"></path>
class="stroke-current text-white" <path class="stroke-current text-blue-300" d="M38.858 26.993l6.397 1.73-4.473 16.549-13.24-3.58">
d="M20.571 20.571h13.714v17.143H20.571z"
>
</path>
<path
class="stroke-current text-blue-300"
d="M38.858 26.993l6.397 1.73-4.473 16.549-13.24-3.58"
>
</path> </path>
</g> </g>
</g> </g>
@ -63,219 +77,17 @@ const {} = Astro.props;
</div> </div>
<div> <div>
<h3 class="mb-3 text-xl font-bold"> <h3 class="mb-3 text-xl font-bold">
Integration with Tailwind CSS {title}
</h3> </h3>
<p> <p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi {description}
sagittis, quam nec venenatis lobortis, mi risus tempus nulla.
</p>
</div>
</div>
<div class="flex flex-row max-w-md">
<div class="mb-4 mr-4">
<div
class="flex items-center justify-center w-12 h-12 rounded-full bg-blue-500"
>
<svg
class="w-12 h-12 p-0.5"
viewBox="0 0 64 64"
xmlns="http://www.w3.org/2000/svg"
>
<g fill="none" fill-rule="evenodd">
<rect
class="fill-current text-blue-600"
width="64"
height="64"
rx="32"></rect>
<g stroke-linecap="square" stroke-width="2">
<path
class="stroke-current text-white"
d="M20.571 20.571h13.714v17.143H20.571z"
>
</path>
<path
class="stroke-current text-blue-300"
d="M38.858 26.993l6.397 1.73-4.473 16.549-13.24-3.58"
>
</path>
</g>
</g>
</svg>
</div>
</div>
<div>
<h3 class="mb-3 text-xl font-bold">Ready-to-use Components</h3>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi
sagittis, quam nec venenatis lobortis, mi risus tempus nulla.
</p>
</div>
</div>
<div class="flex flex-row max-w-md">
<div class="mb-4 mr-4">
<div
class="flex items-center justify-center w-12 h-12 rounded-full bg-blue-500"
>
<svg
class="w-12 h-12 p-0.5"
viewBox="0 0 64 64"
xmlns="http://www.w3.org/2000/svg"
>
<g fill="none" fill-rule="evenodd">
<rect
class="fill-current text-blue-600"
width="64"
height="64"
rx="32"></rect>
<g stroke-linecap="square" stroke-width="2">
<path
class="stroke-current text-white"
d="M20.571 20.571h13.714v17.143H20.571z"
>
</path>
<path
class="stroke-current text-blue-300"
d="M38.858 26.993l6.397 1.73-4.473 16.549-13.24-3.58"
>
</path>
</g>
</g>
</svg>
</div>
</div>
<div>
<h3 class="mb-3 text-xl font-bold">Best Practices</h3>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi
sagittis, quam nec venenatis lobortis, mi risus tempus nulla.
</p>
</div>
</div>
</div>
<div class="space-y-8 sm:px-8">
<div class="flex flex-row max-w-md">
<div class="mb-4 mr-4">
<div
class="flex items-center justify-center w-12 h-12 rounded-full bg-blue-500"
>
<svg
class="w-12 h-12 p-0.5"
viewBox="0 0 64 64"
xmlns="http://www.w3.org/2000/svg"
>
<g fill="none" fill-rule="evenodd">
<rect
class="fill-current text-blue-600"
width="64"
height="64"
rx="32"></rect>
<g stroke-linecap="square" stroke-width="2">
<path
class="stroke-current text-white"
d="M20.571 20.571h13.714v17.143H20.571z"
>
</path>
<path
class="stroke-current text-blue-300"
d="M38.858 26.993l6.397 1.73-4.473 16.549-13.24-3.58"
>
</path>
</g>
</g>
</svg>
</div>
</div>
<div>
<h3 class="mb-3 text-xl font-bold">Excelent Page Speed</h3>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi
sagittis, quam nec venenatis lobortis, mi risus tempus nulla.
</p>
</div>
</div>
<div class="flex flex-row max-w-md">
<div class="mb-4 mr-4">
<div
class="flex items-center justify-center w-12 h-12 rounded-full bg-blue-500"
>
<svg
class="w-12 h-12 p-0.5"
viewBox="0 0 64 64"
xmlns="http://www.w3.org/2000/svg"
>
<g fill="none" fill-rule="evenodd">
<rect
class="fill-current text-blue-600"
width="64"
height="64"
rx="32"></rect>
<g stroke-linecap="square" stroke-width="2">
<path
class="stroke-current text-white"
d="M20.571 20.571h13.714v17.143H20.571z"
>
</path>
<path
class="stroke-current text-blue-300"
d="M38.858 26.993l6.397 1.73-4.473 16.549-13.24-3.58"
>
</path>
</g>
</g>
</svg>
</div>
</div>
<div>
<h3 class="mb-3 text-xl font-bold">Frequently updated</h3>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi
sagittis, quam nec venenatis lobortis, mi risus tempus nulla.
</p>
</div>
</div>
<div class="flex flex-row max-w-md">
<div class="mb-4 mr-4">
<div
class="flex items-center justify-center w-12 h-12 rounded-full bg-blue-500"
>
<svg
class="w-12 h-12 p-0.5"
viewBox="0 0 64 64"
xmlns="http://www.w3.org/2000/svg"
>
<g fill="none" fill-rule="evenodd">
<rect
class="fill-current text-blue-600"
width="64"
height="64"
rx="32"></rect>
<g stroke-linecap="square" stroke-width="2">
<path
class="stroke-current text-white"
d="M20.571 20.571h13.714v17.143H20.571z"
>
</path>
<path
class="stroke-current text-blue-300"
d="M38.858 26.993l6.397 1.73-4.473 16.549-13.24-3.58"
>
</path>
</g>
</g>
</svg>
</div>
</div>
<div>
<h3 class="mb-3 text-xl font-bold">
Open to new ideas and contributions
</h3>
<p>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi
sagittis, quam nec venenatis lobortis, mi risus tempus nulla.
</p> </p>
</div> </div>
</div> </div>
))}
</div> </div>
))
}
</div> </div>
</div> </div>
</section> </section>

View File

@ -9,14 +9,14 @@ const { meta = {} } = Astro.props;
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en" class="motion-safe:scroll-smooth 2xl:text-[24px]"> <html lang="en" class="motion-safe:scroll-smooth 2xl:text-[24px]">
<head>
<MetaTags {...meta} />
</head>
<body <head>
class="antialiased text-gray-900 dark:text-slate-300 tracking-tight bg-white dark:bg-slate-900" <MetaTags {...meta} />
> </head>
<slot />
<BasicScripts /> <body class="antialiased text-gray-900 dark:text-slate-300 tracking-tight bg-white dark:bg-slate-900">
</body> <slot />
</html> <BasicScripts />
</body>
</html>

View File

@ -11,4 +11,4 @@ const { meta } = Astro.props;
<Header /> <Header />
<slot /> <slot />
<Footer /> <Footer />
</Layout> </Layout>

View File

@ -10,4 +10,4 @@ const title = `Error 404 — ${SITE.name}`;
<main> <main>
<Error404 /> <Error404 />
</main> </main>
</Layout> </Layout>

View File

@ -18,9 +18,8 @@ const { page } = Astro.props;
const currentPage = page.currentPage ?? 1; const currentPage = page.currentPage ?? 1;
const title = `Blog ${currentPage > 1 ? `— Page ${currentPage} ` : ""}— ${ const title = `Blog ${currentPage > 1 ? `— Page ${currentPage} ` : ""}— ${SITE.name
SITE.name }`;
}`;
const description = "News and step-by-step guides about AstroWind"; const description = "News and step-by-step guides about AstroWind";
const canonical = new URL(page.url.current, Astro.site); const canonical = new URL(page.url.current, Astro.site);
--- ---
@ -29,4 +28,4 @@ const canonical = new URL(page.url.current, Astro.site);
<main> <main>
<BlogList page={page} /> <BlogList page={page} />
</main> </main>
</Layout> </Layout>

View File

@ -24,15 +24,8 @@ const canonical = post.canonical || new URL(`blog/${post.slug}`, Astro.site);
const image = await findImage(post.image); const image = await findImage(post.image);
--- ---
<Layout <Layout meta={{ title, description, canonical, image, }}>
meta={{
title,
description,
canonical,
image,
}}
>
<main> <main>
<BlogPost post={{ ...post, image }} /> <BlogPost post={{ ...post, image }} />
</main> </main>
</Layout> </Layout>

View File

@ -7,7 +7,7 @@ import Hero from "~/components/widgets/Hero.astro";
import BasicCTA from "~/components/widgets/BasicCTA.astro"; import BasicCTA from "~/components/widgets/BasicCTA.astro";
import BasicFeatures from "~/components/widgets/BasicFeatures.astro"; import BasicFeatures from "~/components/widgets/BasicFeatures.astro";
import StepsFeatures from "~/components/widgets/StepsFeatures.astro"; import StepsFeatures from "~/components/widgets/StepsFeatures.astro";
import BasicFAQs from "~/components/widgets/BasicFAQs.astro"; import FAQs from "~/components/widgets/FAQs.astro";
import TwoColsFeatures from "~/components/widgets/TwoColsFeatures.astro"; import TwoColsFeatures from "~/components/widgets/TwoColsFeatures.astro";
import StepsLeft from "~/components/widgets/StepsLeft.astro"; import StepsLeft from "~/components/widgets/StepsLeft.astro";
import HighlightedPosts from "~/components/widgets/HighlightedPosts.astro"; import HighlightedPosts from "~/components/widgets/HighlightedPosts.astro";
@ -27,8 +27,8 @@ const canonical = new URL("", Astro.site);
<TwoColsFeatures /> <TwoColsFeatures />
<StepsFeatures /> <StepsFeatures />
<HighlightedPosts /> <HighlightedPosts />
<BasicFAQs /> <FAQs />
<Stats /> <Stats />
<BasicCTA /> <BasicCTA />
</main> </main>
</Layout> </Layout>

View File

@ -0,0 +1,8 @@
export const getFormattedDate = (date) =>
date
? new Date(date).toLocaleDateString("en-us", {
year: "numeric",
month: "short",
day: "numeric",
})
: "";