aboutsummaryrefslogtreecommitdiff
path: root/examples/starlog
diff options
context:
space:
mode:
Diffstat (limited to 'examples/starlog')
-rw-r--r--examples/starlog/.gitignore24
-rw-r--r--examples/starlog/README.md7
-rw-r--r--examples/starlog/astro.config.mjs7
-rw-r--r--examples/starlog/package.json16
-rw-r--r--examples/starlog/public/favicon.svg9
-rw-r--r--examples/starlog/src/assets/starlog-placeholder-1.jpgbin0 -> 408855 bytes
-rw-r--r--examples/starlog/src/assets/starlog-placeholder-14.jpgbin0 -> 363691 bytes
-rw-r--r--examples/starlog/src/assets/starlog-placeholder-18.jpgbin0 -> 385009 bytes
-rw-r--r--examples/starlog/src/assets/starlog-placeholder-2.jpgbin0 -> 453830 bytes
-rw-r--r--examples/starlog/src/components/BaseHead.astro21
-rw-r--r--examples/starlog/src/components/Footer.astro12
-rw-r--r--examples/starlog/src/components/FormattedDate.astro25
-rw-r--r--examples/starlog/src/components/Header.astro54
-rw-r--r--examples/starlog/src/components/SEO.astro87
-rw-r--r--examples/starlog/src/consts.ts5
-rw-r--r--examples/starlog/src/content.config.ts22
-rw-r--r--examples/starlog/src/content/releases/1_0.md29
-rw-r--r--examples/starlog/src/content/releases/1_4.md29
-rw-r--r--examples/starlog/src/content/releases/1_8.md29
-rw-r--r--examples/starlog/src/content/releases/2_0.md38
-rw-r--r--examples/starlog/src/layouts/IndexLayout.astro22
-rw-r--r--examples/starlog/src/layouts/PostLayout.astro39
-rw-r--r--examples/starlog/src/pages/index.astro36
-rw-r--r--examples/starlog/src/pages/releases/[slug].astro21
-rw-r--r--examples/starlog/src/styles/colors.scss63
-rw-r--r--examples/starlog/src/styles/global.scss3
-rw-r--r--examples/starlog/src/styles/layout.scss295
-rw-r--r--examples/starlog/src/styles/type.scss70
-rw-r--r--examples/starlog/tsconfig.json5
29 files changed, 968 insertions, 0 deletions
diff --git a/examples/starlog/.gitignore b/examples/starlog/.gitignore
new file mode 100644
index 000000000..16d54bb13
--- /dev/null
+++ b/examples/starlog/.gitignore
@@ -0,0 +1,24 @@
+# build output
+dist/
+# generated types
+.astro/
+
+# dependencies
+node_modules/
+
+# logs
+npm-debug.log*
+yarn-debug.log*
+yarn-error.log*
+pnpm-debug.log*
+
+
+# environment variables
+.env
+.env.production
+
+# macOS-specific files
+.DS_Store
+
+# jetbrains setting folder
+.idea/
diff --git a/examples/starlog/README.md b/examples/starlog/README.md
new file mode 100644
index 000000000..da5cb142c
--- /dev/null
+++ b/examples/starlog/README.md
@@ -0,0 +1,7 @@
+# Starlog
+
+## Release notes theme for Astro
+
+![starlog-gh](https://github.com/doodlemarks/starlog/assets/2244813/9c5c2e46-665a-437e-a971-053db4dbff63)
+
+Built with Astro and Sass. Supports both dark and light modes.
diff --git a/examples/starlog/astro.config.mjs b/examples/starlog/astro.config.mjs
new file mode 100644
index 000000000..759bb082c
--- /dev/null
+++ b/examples/starlog/astro.config.mjs
@@ -0,0 +1,7 @@
+// @ts-check
+import { defineConfig } from 'astro/config';
+
+// https://astro.build/config
+export default defineConfig({
+ site: 'https://example.com',
+});
diff --git a/examples/starlog/package.json b/examples/starlog/package.json
new file mode 100644
index 000000000..51561ab3e
--- /dev/null
+++ b/examples/starlog/package.json
@@ -0,0 +1,16 @@
+{
+ "name": "@example/starlog",
+ "type": "module",
+ "version": "0.0.1",
+ "scripts": {
+ "dev": "astro dev",
+ "build": "astro build",
+ "preview": "astro preview",
+ "astro": "astro"
+ },
+ "dependencies": {
+ "astro": "^5.9.0",
+ "sass": "^1.86.3",
+ "sharp": "^0.33.3"
+ }
+}
diff --git a/examples/starlog/public/favicon.svg b/examples/starlog/public/favicon.svg
new file mode 100644
index 000000000..f157bd1c5
--- /dev/null
+++ b/examples/starlog/public/favicon.svg
@@ -0,0 +1,9 @@
+<svg xmlns="http://www.w3.org/2000/svg" fill="none" viewBox="0 0 128 128">
+ <path d="M50.4 78.5a75.1 75.1 0 0 0-28.5 6.9l24.2-65.7c.7-2 1.9-3.2 3.4-3.2h29c1.5 0 2.7 1.2 3.4 3.2l24.2 65.7s-11.6-7-28.5-7L67 45.5c-.4-1.7-1.6-2.8-2.9-2.8-1.3 0-2.5 1.1-2.9 2.7L50.4 78.5Zm-1.1 28.2Zm-4.2-20.2c-2 6.6-.6 15.8 4.2 20.2a17.5 17.5 0 0 1 .2-.7 5.5 5.5 0 0 1 5.7-4.5c2.8.1 4.3 1.5 4.7 4.7.2 1.1.2 2.3.2 3.5v.4c0 2.7.7 5.2 2.2 7.4a13 13 0 0 0 5.7 4.9v-.3l-.2-.3c-1.8-5.6-.5-9.5 4.4-12.8l1.5-1a73 73 0 0 0 3.2-2.2 16 16 0 0 0 6.8-11.4c.3-2 .1-4-.6-6l-.8.6-1.6 1a37 37 0 0 1-22.4 2.7c-5-.7-9.7-2-13.2-6.2Z" />
+ <style>
+ path { fill: #000; }
+ @media (prefers-color-scheme: dark) {
+ path { fill: #FFF; }
+ }
+ </style>
+</svg>
diff --git a/examples/starlog/src/assets/starlog-placeholder-1.jpg b/examples/starlog/src/assets/starlog-placeholder-1.jpg
new file mode 100644
index 000000000..846bdcd45
--- /dev/null
+++ b/examples/starlog/src/assets/starlog-placeholder-1.jpg
Binary files differ
diff --git a/examples/starlog/src/assets/starlog-placeholder-14.jpg b/examples/starlog/src/assets/starlog-placeholder-14.jpg
new file mode 100644
index 000000000..e2e0acb9e
--- /dev/null
+++ b/examples/starlog/src/assets/starlog-placeholder-14.jpg
Binary files differ
diff --git a/examples/starlog/src/assets/starlog-placeholder-18.jpg b/examples/starlog/src/assets/starlog-placeholder-18.jpg
new file mode 100644
index 000000000..211c85cf5
--- /dev/null
+++ b/examples/starlog/src/assets/starlog-placeholder-18.jpg
Binary files differ
diff --git a/examples/starlog/src/assets/starlog-placeholder-2.jpg b/examples/starlog/src/assets/starlog-placeholder-2.jpg
new file mode 100644
index 000000000..2251c1c49
--- /dev/null
+++ b/examples/starlog/src/assets/starlog-placeholder-2.jpg
Binary files differ
diff --git a/examples/starlog/src/components/BaseHead.astro b/examples/starlog/src/components/BaseHead.astro
new file mode 100644
index 000000000..901b042cf
--- /dev/null
+++ b/examples/starlog/src/components/BaseHead.astro
@@ -0,0 +1,21 @@
+---
+import { ClientRouter } from 'astro:transitions';
+import SEO, { type Props as SEOProps } from './SEO.astro';
+import { SiteTitle, SiteDescription } from '../consts';
+
+export type Props = Partial<SEOProps>;
+const { title = SiteTitle, name = SiteTitle, description = SiteDescription, ...seo } = Astro.props;
+---
+
+<meta charset="utf-8" />
+<meta name="viewport" content="width=device-width,initial-scale=1.0" />
+<SEO {title} {description} {name} {...seo} />
+
+<link rel="preconnect" href="https://fonts.googleapis.com" />
+<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin />
+<link
+ href="https://fonts.googleapis.com/css2?family=Lato:wght@400;700&family=Source+Code+Pro&display=swap"
+ rel="stylesheet"
+/>
+
+<ClientRouter />
diff --git a/examples/starlog/src/components/Footer.astro b/examples/starlog/src/components/Footer.astro
new file mode 100644
index 000000000..276550d4a
--- /dev/null
+++ b/examples/starlog/src/components/Footer.astro
@@ -0,0 +1,12 @@
+---
+import '../styles/global.scss';
+---
+
+<footer>
+ <p>ยฉ 2023</p>
+ <div class="footer_links">
+ <a href="#">Discord</a>
+ <a href="#">X</a>
+ <a href="#">GitHub</a>
+ </div>
+</footer>
diff --git a/examples/starlog/src/components/FormattedDate.astro b/examples/starlog/src/components/FormattedDate.astro
new file mode 100644
index 000000000..377286d9f
--- /dev/null
+++ b/examples/starlog/src/components/FormattedDate.astro
@@ -0,0 +1,25 @@
+---
+import type { HTMLAttributes } from 'astro/types';
+
+type Props = HTMLAttributes<'time'> & {
+ date: Date;
+};
+
+const { date, ...attrs } = Astro.props;
+---
+
+<time datetime={date.toISOString()} {...attrs}>
+ {
+ date.toLocaleDateString('en-us', {
+ year: 'numeric',
+ month: 'short',
+ day: 'numeric',
+ })
+ }
+</time>
+
+<style>
+ time {
+ display: block;
+ }
+</style>
diff --git a/examples/starlog/src/components/Header.astro b/examples/starlog/src/components/Header.astro
new file mode 100644
index 000000000..bbdaf1e70
--- /dev/null
+++ b/examples/starlog/src/components/Header.astro
@@ -0,0 +1,54 @@
+---
+import '../styles/global.scss';
+import { SiteTitle } from '../consts';
+---
+
+<header>
+ <nav>
+ <h2 id="site_title">
+ <a href="/">
+ <svg
+ aria-hidden="true"
+ xmlns="http://www.w3.org/2000/svg"
+ width="24"
+ height="24"
+ fill="none"
+ ><path
+ fill="url(#a)"
+ fill-rule="evenodd"
+ d="M.654 3.276C0 4.56 0 6.24 0 9.6v4.8c0 3.36 0 5.04.654 6.324a6 6 0 0 0 2.622 2.622C4.56 24 6.24 24 9.6 24h4.8c3.36 0 5.04 0 6.324-.654a6 6 0 0 0 2.622-2.622C24 19.44 24 17.76 24 14.4V9.6c0-3.36 0-5.04-.654-6.324A6 6 0 0 0 20.724.654C19.44 0 17.76 0 14.4 0H9.6C6.24 0 4.56 0 3.276.654A6 6 0 0 0 .654 3.276Zm10.875 16.41a.5.5 0 0 0 .942 0l.628-1.754a8 8 0 0 1 4.833-4.833l1.754-.628a.5.5 0 0 0 0-.942l-1.754-.628A8 8 0 0 1 13.1 6.068l-.628-1.754a.5.5 0 0 0-.942 0l-.628 1.754A8 8 0 0 1 6.068 10.9l-1.754.628a.5.5 0 0 0 0 .942l1.754.628a8 8 0 0 1 4.833 4.833l.628 1.754Z"
+ clip-rule="evenodd"></path><path
+ stroke="url(#b)"
+ stroke-opacity=".5"
+ stroke-width=".5"
+ d="M.25 9.6c0-1.684 0-2.932.08-3.92.081-.985.24-1.69.547-2.29A5.75 5.75 0 0 1 3.39.877C3.99.57 4.695.41 5.68.33 6.668.25 7.916.25 9.6.25h4.8c1.684 0 2.932 0 3.92.08.985.081 1.69.24 2.29.547a5.75 5.75 0 0 1 2.513 2.513c.306.6.466 1.305.546 2.29.08.988.081 2.236.081 3.92v4.8c0 1.684 0 2.932-.08 3.92-.081.985-.24 1.69-.547 2.29a5.75 5.75 0 0 1-2.513 2.513c-.6.306-1.305.466-2.29.546-.988.08-2.236.081-3.92.081H9.6c-1.684 0-2.932 0-3.92-.08-.985-.081-1.69-.24-2.29-.547A5.75 5.75 0 0 1 .877 20.61C.57 20.01.41 19.305.33 18.32.25 17.332.25 16.084.25 14.4V9.6Zm11.044 10.17c.237.663 1.175.663 1.412 0l.628-1.753a7.75 7.75 0 0 1 4.683-4.683l1.753-.628c.663-.237.663-1.175 0-1.412l-1.753-.628a7.75 7.75 0 0 1-4.683-4.683l-.628-1.753c-.237-.663-1.175-.663-1.412 0l-.628 1.753a7.75 7.75 0 0 1-4.683 4.683l-1.753.628c-.663.237-.663 1.175 0 1.412l1.753.628a7.75 7.75 0 0 1 4.683 4.683l.628 1.753Z"
+ ></path><defs
+ ><radialGradient
+ id="a"
+ cx="0"
+ cy="0"
+ r="1"
+ gradientTransform="rotate(-40.136 32.164 11.75) scale(33.3542)"
+ gradientUnits="userSpaceOnUse"
+ ><stop offset=".639" stop-color="#9818E7"></stop><stop offset="1" stop-color="#DF7F4F"
+ ></stop></radialGradient
+ ><linearGradient id="b" x1="12" x2="12" y1="0" y2="24" gradientUnits="userSpaceOnUse"
+ ><stop stop-color="#fff"></stop><stop offset="1" stop-color="#fff" stop-opacity="0"
+ ></stop></linearGradient
+ ></defs
+ ></svg
+ >
+ {SiteTitle}
+ </a>
+ </h2>
+ <div class="links">
+ <a href="mailto:contactus@yourwebsite.com">Contact</a>
+ </div>
+ </nav>
+</header>
+
+<style>
+ .links a {
+ text-decoration: none;
+ }
+</style>
diff --git a/examples/starlog/src/components/SEO.astro b/examples/starlog/src/components/SEO.astro
new file mode 100644
index 000000000..1e2ddcca2
--- /dev/null
+++ b/examples/starlog/src/components/SEO.astro
@@ -0,0 +1,87 @@
+---
+import type { ImageMetadata } from 'astro';
+type Image = {
+ src: string | ImageMetadata;
+ alt: string;
+};
+
+type SEOMetadata = {
+ name: string;
+ title: string;
+ description: string;
+ image?: Image | undefined;
+ canonicalURL?: URL | string | undefined;
+ locale?: string;
+};
+
+type OpenGraph = Partial<SEOMetadata> & {
+ type?: string;
+};
+
+type Twitter = Partial<SEOMetadata> & {
+ handle?: string;
+ card?: 'summary' | 'summary_large_image';
+};
+
+export type Props = SEOMetadata & {
+ og?: OpenGraph;
+ twitter?: Twitter;
+};
+
+const {
+ name,
+ title,
+ description,
+ image,
+ locale = 'en',
+ canonicalURL = new URL(Astro.url.pathname, Astro.site),
+} = Astro.props;
+
+const og = {
+ name,
+ title,
+ description,
+ canonicalURL,
+ image,
+ locale,
+ type: 'website',
+ ...(Astro.props.og ?? {}),
+} satisfies OpenGraph;
+
+const twitter = {
+ name,
+ title,
+ description,
+ canonicalURL,
+ image,
+ locale,
+ card: 'summary_large_image',
+ ...Astro.props.twitter,
+};
+
+function normalizeImageUrl(image: string | ImageMetadata) {
+ return typeof image === 'string' ? image : image.src;
+}
+---
+
+<!-- Page Metadata -->
+<link rel="canonical" href={canonicalURL} />
+<meta name="description" content={description} />
+
+<!-- OpenGraph Tags -->
+<meta property="og:title" content={og.title} />
+<meta property="og:type" content={og.type} />
+<meta property="og:url" content={canonicalURL} />
+<meta property="og:locale" content={og.locale} />
+<meta property="og:description" content={og.description} />
+<meta property="og:site_name" content={og.name} />
+{og.image && <meta property="og:image" content={normalizeImageUrl(og.image.src)} />}
+{og.image && <meta property="og:image:alt" content={og.image.alt} />}
+
+<!-- Twitter Tags -->
+<meta name="twitter:card" content={twitter.card} />
+<meta name="twitter:site" content={twitter.handle} />
+<meta name="twitter:title" content={twitter.title} />
+<meta name="twitter:description" content={twitter.description} />
+{twitter.image && <meta name="twitter:image" content={normalizeImageUrl(twitter.image.src)} />}
+{twitter.image && <meta name="twitter:image:alt" content={twitter.image.alt} />}
diff --git a/examples/starlog/src/consts.ts b/examples/starlog/src/consts.ts
new file mode 100644
index 000000000..3e91752e1
--- /dev/null
+++ b/examples/starlog/src/consts.ts
@@ -0,0 +1,5 @@
+// Place any global data in this file.
+// You can import this data from anywhere in your site by using the `import` keyword.
+
+export const SiteTitle = 'Starlog';
+export const SiteDescription = 'Welcome to my website!';
diff --git a/examples/starlog/src/content.config.ts b/examples/starlog/src/content.config.ts
new file mode 100644
index 000000000..26986525a
--- /dev/null
+++ b/examples/starlog/src/content.config.ts
@@ -0,0 +1,22 @@
+import { glob } from 'astro/loaders';
+import { defineCollection, z } from 'astro:content';
+
+const releases = defineCollection({
+ // Load Markdown files in the src/content/releases directory.
+ loader: glob({ base: './src/content/releases', pattern: '**/*.md' }),
+ // Type-check frontmatter using a schema
+ schema: ({ image }) =>
+ z.object({
+ title: z.string(),
+ description: z.string(),
+ versionNumber: z.string(),
+ image: z.object({
+ src: image(),
+ alt: z.string(),
+ }),
+ // Transform string to Date object
+ date: z.date({ coerce: true }),
+ }),
+});
+
+export const collections = { releases };
diff --git a/examples/starlog/src/content/releases/1_0.md b/examples/starlog/src/content/releases/1_0.md
new file mode 100644
index 000000000..a5eeff437
--- /dev/null
+++ b/examples/starlog/src/content/releases/1_0.md
@@ -0,0 +1,29 @@
+---
+title: 'Introducing Nebulous 1.0!'
+date: '2022-03-21'
+versionNumber: '1.0'
+description: 'This is the first post of my new Astro blog.'
+image:
+ src: '../../assets/starlog-placeholder-1.jpg'
+ alt: 'The full Astro logo.'
+---
+
+## A New World with 1.0
+
+![Nebulous 2.0 Release](../../assets/starlog-placeholder-1.jpg)
+
+Hey there, Nebulous users! We're back with some exciting updates that will turbocharge your Nebulous experience. Here's the lowdown:
+
+### ๐Ÿฟ New Features & Enhancements
+
+- **NebulaProtect Supercharged:** Enjoy beefed-up security and real-time monitoring to keep your digital fortress unbreachable.
+- **NebulaConnect for Teams:** Collaboration is a breeze with integrated project management tools.
+- **Speed Boost Galore:** We've fine-tuned Nebulous for ultimate speed and responsiveness.
+
+### ๐Ÿž Bug Fixes
+
+- Kicked pesky crashes out the door for NebulaSync.
+- Fixed rare data hiccups during file transfers.
+- Nebulous is now even friendly with older devices.
+
+Thank you for making Nebulous your tech partner. We thrive on your feedback, so if you have ideas or run into bumps, don't hesitate to drop a line to our support wizards. Together, we're taking Nebulous to the next level!
diff --git a/examples/starlog/src/content/releases/1_4.md b/examples/starlog/src/content/releases/1_4.md
new file mode 100644
index 000000000..aacab8a84
--- /dev/null
+++ b/examples/starlog/src/content/releases/1_4.md
@@ -0,0 +1,29 @@
+---
+title: 'Introducing Nebulous 1.8!'
+date: '2022-04-16'
+versionNumber: '1.4'
+description: 'This is the first post of my new Astro blog.'
+image:
+ src: '../../assets/starlog-placeholder-14.jpg'
+ alt: 'The full Astro logo.'
+---
+
+## Go further with 1.4
+
+![Nebulous 1.4 Release](../../assets/starlog-placeholder-14.jpg)
+
+Hello, Nebulous enthusiasts! It's that time againโ€”time for us to unveil the latest and greatest in our tech universe. Buckle up as we introduce you to the future of Nebulous:
+
+### ๐Ÿฟ New Features & Enhancements
+
+- **NebulaSync Quantum:** Prepare for a mind-blowing file syncing experience. It's faster, smarter, and more intuitive than ever before.
+- **NebulaAI Odyssey:** Welcome to the era of NebulaAI Odysseyโ€”a journey into the boundless possibilities of artificial intelligence. From image manipulation to language translation, Odyssey empowers you like never before.
+
+### ๐Ÿž Bug Fixes
+
+- Squashed even more bugs, making NebulaSync and other features more reliable than ever.
+- Streamlined data transfer processes for flawless file exchanges.
+- Extended support for older devices to ensure everyone enjoys Nebulous.
+- Elevating error handling to the next level, ensuring a hiccup-free experience.
+
+Thank you for being a part of the Nebulous journey. Your feedback fuels our innovation, so don't hesitate to share your thoughts or report any hiccups with our dedicated support team. Together, we're shaping the future of tech with Nebulous!
diff --git a/examples/starlog/src/content/releases/1_8.md b/examples/starlog/src/content/releases/1_8.md
new file mode 100644
index 000000000..d300f964c
--- /dev/null
+++ b/examples/starlog/src/content/releases/1_8.md
@@ -0,0 +1,29 @@
+---
+title: 'Introducing Nebulous 1.8!'
+date: '2022-06-01'
+versionNumber: '1.8'
+description: 'This is the first post of my new Astro blog.'
+image:
+ src: '../../assets/starlog-placeholder-18.jpg'
+ alt: 'The full Astro logo.'
+---
+
+## Faster, Stronger, Betterer
+
+![Nebulous 2.0 Release](../../assets/starlog-placeholder-18.jpg)
+
+Hey there, Nebulous users! We're back with some exciting updates that will turbocharge your Nebulous experience. Here's the lowdown:
+
+### New Features & Enhancements
+
+- **NebulaProtect Supercharged:** Enjoy beefed-up security and real-time monitoring to keep your digital fortress unbreachable.
+- **NebulaConnect for Teams:** Collaboration is a breeze with integrated project management tools.
+- **Speed Boost Galore:** We've fine-tuned Nebulous for ultimate speed and responsiveness.
+
+### ๐Ÿž Bug Fixes
+
+- Kicked pesky crashes out the door for NebulaSync.
+- Fixed rare data hiccups during file transfers.
+- Nebulous is now even friendly with older devices.
+
+Thank you for making Nebulous your tech partner. We thrive on your feedback, so if you have ideas or run into bumps, don't hesitate to drop a line to our support wizards. Together, we're taking Nebulous to the next level!
diff --git a/examples/starlog/src/content/releases/2_0.md b/examples/starlog/src/content/releases/2_0.md
new file mode 100644
index 000000000..6a01d76fc
--- /dev/null
+++ b/examples/starlog/src/content/releases/2_0.md
@@ -0,0 +1,38 @@
+---
+title: 'Introducing Nebulous 2.0!'
+date: '2022-07-01'
+versionNumber: '2.0'
+description: 'This is the first post of my new Astro blog.'
+image:
+ src: '../../assets/starlog-placeholder-2.jpg'
+ alt: 'The full Astro logo.'
+---
+
+## Introducing Nebulous 2.0!
+
+![Nebulous 2.0 Release](../../assets/starlog-placeholder-2.jpg)
+
+Greetings, Nebulous users! We're excited to bring you the latest updates in our [ever-evolving tech ecosystem](#). In this release, we're introducing some exciting new features and squashing a few pesky bugs. Let's dive in!
+
+### ๐Ÿฟ New Features & Enhancements
+
+- **NebulaSync v2.0:** We're thrilled to introduce NebulaSync 2.0, our revamped file synchronization tool. It now offers blazing-fast sync speeds, improved reliability, and enhanced cross-device compatibility.
+- **Enhanced NebulaProtect:** NebulaProtect, our comprehensive security suite, has received a major update. Enjoy advanced threat detection, and real-time monitoring.
+- **NebulaConnect for Teams:** Collaborate effortlessly with NebulaConnect for Teams. This powerful feature allows seamless integration with your favorite project management tools, enabling you to manage tasks, share documents, and track progress in real-time.
+
+### ๐Ÿž Bug Fixes
+
+- Resolved occasional crashing issues when using NebulaSync.
+- Fixed a bug causing data corruption in rare cases during file transfers.
+- Improved compatibility with older devices to ensure a seamless experience for all users.
+- Enhanced error handling and reporting for a smoother user experience.
+
+### ๐Ÿ‘€ Coming Soon
+
+We can't spill all the beans just yet, but we're thrilled to give you a sneak peek of what's coming in the next Nebulous release:
+
+- **NebulaWallet:** A secure and user-friendly cryptocurrency wallet integrated directly into Nebulous for seamless digital asset management.
+- **NebulaConnect Mobile:** Take your collaboration to the next level with our upcoming mobile app, enabling you to work on the go.
+- **NebulaLabs:** Our developer tools and API enhancements, providing you with even more customization options and possibilities.
+
+If you have any suggestions or encounter any issues, don't hesitate to reach out to our support team. Together, we'll continue to make Nebulous the ultimate tech solution for you.
diff --git a/examples/starlog/src/layouts/IndexLayout.astro b/examples/starlog/src/layouts/IndexLayout.astro
new file mode 100644
index 000000000..117c57f0b
--- /dev/null
+++ b/examples/starlog/src/layouts/IndexLayout.astro
@@ -0,0 +1,22 @@
+---
+import BaseHead, { type Props as HeadProps } from '../components/BaseHead.astro';
+import Header from '../components/Header.astro';
+import Footer from '../components/Footer.astro';
+
+type Props = HeadProps;
+
+const { ...head } = Astro.props;
+---
+
+<!doctype html>
+<html lang="en">
+ <head>
+ <BaseHead {...head} />
+ </head>
+ <body>
+ <div class="glow"></div>
+ <Header />
+ <slot />
+ <Footer />
+ </body>
+</html>
diff --git a/examples/starlog/src/layouts/PostLayout.astro b/examples/starlog/src/layouts/PostLayout.astro
new file mode 100644
index 000000000..9c87a7b88
--- /dev/null
+++ b/examples/starlog/src/layouts/PostLayout.astro
@@ -0,0 +1,39 @@
+---
+import type { CollectionEntry } from 'astro:content';
+import BaseHead from '../components/BaseHead.astro';
+import FormattedDate from '../components/FormattedDate.astro';
+import Header from '../components/Header.astro';
+import Footer from '../components/Footer.astro';
+
+type Props = {
+ release: CollectionEntry<'releases'>;
+};
+
+const { release } = Astro.props;
+---
+
+<!doctype html>
+<html lang="en">
+ <head>
+ <BaseHead
+ title={release.data.title}
+ description={release.data.description}
+ image={release.data.image}
+ />
+ </head><body>
+ <div class="glow"></div>
+ <Header />
+ <div class="post single" transition:persist transition:name="post">
+ <div class="version_wrapper">
+ <div class="version_info">
+ <div class="version_number">{release.data.versionNumber}</div>
+ <FormattedDate class="date" date={release.data.date} />
+ </div>
+ </div>
+ <div class="content">
+ <slot />
+ </div>
+ </div>
+ <Footer />
+ </body>
+</html>
diff --git a/examples/starlog/src/pages/index.astro b/examples/starlog/src/pages/index.astro
new file mode 100644
index 000000000..3cf04af62
--- /dev/null
+++ b/examples/starlog/src/pages/index.astro
@@ -0,0 +1,36 @@
+---
+import { getCollection, render } from 'astro:content';
+import FormattedDate from '../components/FormattedDate.astro';
+import Layout from '../layouts/IndexLayout.astro';
+
+const posts = await getCollection('releases');
+posts.sort((a, b) => +b.data.date - +a.data.date);
+---
+
+<Layout>
+ <main>
+ <h1 class="page_title">Changelog</h1>
+ <hr />
+ <ul class="posts" transition:name="post">
+ {
+ posts.map((post) => (
+ <li class="post">
+ <div class="version_wrapper">
+ <div class="version_info">
+ <a href={`/releases/${post.id}`}>
+ <div class="version_number">{post.data.versionNumber}</div>
+ <FormattedDate class="date" date={post.data.date} />
+ </a>
+ </div>
+ </div>
+ <div class="content">
+ {render(post).then(({ Content }) => (
+ <Content />
+ ))}
+ </div>
+ </li>
+ ))
+ }
+ </ul>
+ </main>
+</Layout>
diff --git a/examples/starlog/src/pages/releases/[slug].astro b/examples/starlog/src/pages/releases/[slug].astro
new file mode 100644
index 000000000..8c3119a8f
--- /dev/null
+++ b/examples/starlog/src/pages/releases/[slug].astro
@@ -0,0 +1,21 @@
+---
+import { getCollection, render } from 'astro:content';
+import Layout from '../../layouts/PostLayout.astro';
+
+export async function getStaticPaths() {
+ const releases = await getCollection('releases');
+
+ return releases.map((release) => ({
+ params: { slug: release.id },
+ props: { release },
+ }));
+}
+
+const { release } = Astro.props;
+
+const { Content } = await render(release);
+---
+
+<Layout {release}>
+ <Content />
+</Layout>
diff --git a/examples/starlog/src/styles/colors.scss b/examples/starlog/src/styles/colors.scss
new file mode 100644
index 000000000..43b9ee957
--- /dev/null
+++ b/examples/starlog/src/styles/colors.scss
@@ -0,0 +1,63 @@
+@use 'sass:map';
+
+@function color($color, $tone) {
+ // @warn map.get($palette,$color);
+
+ @if map.has-key($palette, $color) {
+ $color: map.get($palette, $color);
+
+ @if map.has-key($color, $tone) {
+ $tone: map.get($color, $tone);
+ @return $tone;
+ }
+
+ @warn "unknown tone `#{$tone}` in color";
+ @return null;
+ }
+
+ @warn "unknown color `#{$color}` in palette";
+ @return null;
+}
+
+$white: #ffffff;
+$palette: (
+ purple: (
+ 50: #f2e8fd,
+ 100: #e6d1fa,
+ 200: #cfa3f5,
+ 300: #ba75f0,
+ 400: #a846ec,
+ 500: #9818e7,
+ 600: #7b13b4,
+ 700: #5b0e81,
+ 800: #3a084e,
+ 900: #15031c,
+ 950: #020002,
+ ),
+ orange: (
+ 50: #fbf0ea,
+ 100: #f8e3d9,
+ 200: #f2cab7,
+ 300: #ecb194,
+ 400: #e59872,
+ 500: #df7f4f,
+ 600: #d05f26,
+ 700: #a1491d,
+ 800: #713315,
+ 900: #421e0c,
+ 950: #2a1308,
+ ),
+ gray: (
+ 50: #f6f6f9,
+ 100: #e6e7ef,
+ 200: #c7c9db,
+ 300: #a8abc7,
+ 400: #898eb4,
+ 500: #6a71a0,
+ 600: #545b83,
+ 700: #404664,
+ 800: #2c3145,
+ 900: #181b26,
+ 950: #0e1016,
+ ),
+);
diff --git a/examples/starlog/src/styles/global.scss b/examples/starlog/src/styles/global.scss
new file mode 100644
index 000000000..39b21e91b
--- /dev/null
+++ b/examples/starlog/src/styles/global.scss
@@ -0,0 +1,3 @@
+@use 'colors.scss';
+@use 'type.scss';
+@use 'layout.scss';
diff --git a/examples/starlog/src/styles/layout.scss b/examples/starlog/src/styles/layout.scss
new file mode 100644
index 000000000..3a5f8d173
--- /dev/null
+++ b/examples/starlog/src/styles/layout.scss
@@ -0,0 +1,295 @@
+@use 'sass:color';
+@use './colors.scss' as colors;
+@use './type.scss' as type;
+
+$container: 1040px;
+$tablet: 768px;
+$mobile: 420px;
+
+* {
+ box-sizing: border-box;
+}
+
+body {
+ margin: 0 auto;
+ padding: 0 1em;
+ width: 1040px;
+ max-width: 100%;
+ background-color: colors.$white;
+ @media (prefers-color-scheme: dark) {
+ background-color: colors.color(gray, 950);
+ }
+ @media (max-width: $tablet) {
+ font-size: 16px;
+ }
+}
+
+.glow {
+ width: 100%;
+ height: 100%;
+ position: absolute;
+ z-index: -1;
+ top: 0;
+ left: 0;
+ overflow: hidden;
+
+ &:after {
+ content: '';
+ display: block;
+ position: absolute;
+ top: -120px;
+ left: calc(50% - 360px);
+ width: 720px;
+ height: 240px;
+ background: radial-gradient(
+ 50% 50% at 50% 50%,
+ rgba(colors.color(orange, 500), 0.2) 0%,
+ rgba(colors.color(orange, 500), 0) 100%
+ );
+ @media (prefers-color-scheme: dark) {
+ background: radial-gradient(
+ 50% 50% at 50% 50%,
+ rgba(255, 255, 255, 0.06) 0%,
+ rgba(255, 255, 255, 0) 100%
+ );
+ }
+ }
+}
+
+::selection {
+ background: colors.color(orange, 200);
+ @media (prefers-color-scheme: dark) {
+ background: colors.color(orange, 600);
+ }
+}
+
+a,
+a:visited {
+ color: colors.color(orange, 600);
+ transition: 0.1s ease;
+ @media (prefers-color-scheme: dark) {
+ color: colors.color(orange, 300);
+ }
+
+ &:hover {
+ color: colors.color(orange, 500);
+ }
+}
+
+hr {
+ margin: 1em 0;
+ border: 0;
+ border-bottom: 1px solid colors.color(gray, 100);
+ @media (prefers-color-scheme: dark) {
+ border-color: colors.color(gray, 900);
+ }
+}
+
+nav {
+ display: flex;
+ align-items: center;
+ justify-content: space-between;
+ margin: 0 0 2em 0;
+ padding: 2em 0;
+
+ a {
+ transition: 0.1s ease;
+ &:hover {
+ opacity: 0.6;
+ }
+ }
+
+ #site_title {
+ margin: 0;
+ }
+ #site_title a {
+ display: flex;
+ align-items: center;
+ gap: 10px;
+ color: colors.color(gray, 950);
+ font-size: 16px;
+ font-weight: 700;
+ letter-spacing: 2px;
+ line-height: 1;
+ text-decoration: none;
+ text-transform: uppercase;
+ @media (prefers-color-scheme: dark) {
+ color: colors.$white;
+ }
+ }
+ .links a {
+ margin-left: 1em;
+ color: colors.color(gray, 800);
+ @media (prefers-color-scheme: dark) {
+ color: colors.color(gray, 200);
+ }
+ }
+}
+
+.content {
+ ol,
+ ul {
+ padding-left: 2em;
+ margin-bottom: 1em;
+ }
+
+ ul {
+ list-style: none;
+
+ li {
+ position: relative;
+ margin-bottom: 0.75em;
+
+ &:before {
+ content: '';
+ display: block;
+ position: absolute;
+ left: -1em;
+ top: 0.63em;
+ width: 8px;
+ height: 8px;
+ background: linear-gradient(25deg, colors.color(purple, 500), colors.color(orange, 500));
+ border-radius: 99px;
+ }
+ }
+ }
+}
+
+.page_title {
+ margin: 1.5em 0;
+ @media (max-width: $tablet) {
+ margin: 0.5em 0;
+ }
+}
+
+.posts {
+ list-style: none;
+ padding: 0;
+}
+
+.post {
+ display: flex;
+ width: 100%;
+ @media (max-width: $tablet) {
+ flex-flow: column;
+ }
+
+ &:last-child .content,
+ &.single .content {
+ border-bottom: 0;
+ }
+}
+
+.version_wrapper {
+ flex-basis: 260px;
+ flex-grow: 0;
+ flex-shrink: 0;
+ margin: 4.5em 0 0 0;
+ @media (max-width: $container) {
+ flex-basis: 140px;
+ }
+ @media (max-width: $tablet) {
+ flex-basis: 0;
+ margin-top: 2em;
+ }
+
+ .version_info {
+ position: sticky;
+ top: 1em;
+ @media (max-width: $tablet) {
+ position: relative;
+ top: 0;
+ }
+ }
+
+ a {
+ float: left;
+ color: colors.$white;
+ text-decoration: none;
+ transition: 0.1s ease;
+
+ &:hover {
+ opacity: 0.6;
+ }
+ }
+}
+
+.version_number {
+ display: inline-block;
+ font-family: type.$codeFont;
+ line-height: 1;
+ margin-bottom: 8px;
+ padding: 4px 12px;
+ color: colors.$white;
+ background: linear-gradient(
+ 25deg,
+ colors.color(purple, 800),
+ colors.color(purple, 700),
+ color.mix(colors.color(purple, 500), colors.color(orange, 500)),
+ colors.color(orange, 500)
+ );
+ border-radius: 8px;
+}
+
+.date {
+ clear: both;
+ color: colors.color(gray, 800);
+ font-family: type.$codeFont;
+ font-size: type.$fontSizeSmall;
+ @media (max-width: $tablet) {
+ display: inline;
+ margin-left: 1em;
+ }
+ @media (prefers-color-scheme: dark) {
+ color: colors.color(gray, 200);
+ }
+}
+
+.content {
+ margin: 0;
+ padding: 4em 0;
+ border-bottom: 1px solid colors.color(gray, 100);
+ @media (max-width: $tablet) {
+ margin: 1em 0;
+ padding: 0 0 2em 0;
+ }
+ @media (prefers-color-scheme: dark) {
+ border-color: colors.color(gray, 900);
+ }
+ *:first-child {
+ margin-top: 0;
+ }
+ img {
+ max-width: 100%;
+ height: auto;
+ border-radius: 12px;
+ border: 1px solid colors.color(gray, 200);
+ @media (prefers-color-scheme: dark) {
+ border-color: colors.color(gray, 800);
+ }
+ }
+}
+
+footer {
+ display: flex;
+ padding: 2em 0;
+ color: colors.color(gray, 500);
+ justify-content: space-between;
+ border-top: 1px solid colors.color(gray, 100);
+ @media (max-width: $tablet) {
+ padding: 1em 0;
+ }
+ @media (prefers-color-scheme: dark) {
+ border-color: colors.color(gray, 900);
+ }
+
+ a {
+ margin-left: 1em;
+ color: colors.color(gray, 500);
+ text-decoration: none;
+ &:hover {
+ color: colors.color(gray, 500);
+ opacity: 0.6;
+ }
+ }
+}
diff --git a/examples/starlog/src/styles/type.scss b/examples/starlog/src/styles/type.scss
new file mode 100644
index 000000000..0bb5a86d1
--- /dev/null
+++ b/examples/starlog/src/styles/type.scss
@@ -0,0 +1,70 @@
+@use './colors.scss' as colors;
+
+$baseFont: 'Lato', sans-serif;
+$codeFont: 'Source Code Pro', monospace;
+$fontSizeSmall: 15px;
+
+body {
+ font-family: $baseFont;
+ font-size: 18px;
+ line-height: 1.65;
+ font-weight: 400;
+ color: colors.color(gray, 800);
+ -webkit-font-smoothing: antialiased;
+ -moz-osx-font-smoothing: grayscale;
+ text-rendering: optimizeLegibility;
+
+ @media (prefers-color-scheme: dark) {
+ color: colors.color(gray, 200);
+ }
+}
+
+h1,
+h2,
+h3,
+h4,
+h5 {
+ line-height: 1.2;
+ margin: 1em 0 0.5em 0;
+ color: colors.color(gray, 950);
+ font-weight: 700;
+
+ @media (prefers-color-scheme: dark) {
+ color: colors.$white;
+ }
+}
+
+h1 {
+ font-size: 3.052em;
+}
+h2 {
+ font-size: 2.441em;
+}
+h3 {
+ font-size: 1.953em;
+}
+h4 {
+ font-size: 1.563em;
+}
+h5 {
+ font-size: 1.25em;
+}
+
+p {
+ margin: 0 0 1em 0;
+}
+
+code {
+ font-family: $codeFont;
+}
+
+b,
+strong {
+ font-weight: 700;
+ color: #fff;
+ color: colors.color(gray, 950);
+
+ @media (prefers-color-scheme: dark) {
+ color: colors.$white;
+ }
+}
diff --git a/examples/starlog/tsconfig.json b/examples/starlog/tsconfig.json
new file mode 100644
index 000000000..8bf91d3bb
--- /dev/null
+++ b/examples/starlog/tsconfig.json
@@ -0,0 +1,5 @@
+{
+ "extends": "astro/tsconfigs/strict",
+ "include": [".astro/types.d.ts", "**/*"],
+ "exclude": ["dist"]
+}