Objectives
Build and deploy an Astro Starlight Documentation site to GitHub Pages. Explore features and customization - validate its use as reusable template.
Astro is a free, open-source option for static site generation that bills itself as the all-in-one web framework designed for speed. Three features that make it interesting:
- Islands architecture - with zero client-side JS
- Plays well with others - bring your own components
- Rich ecosystem - content focused & community-driven
This gives you the benefits of performance & flexibility, with rich themes and integrations for quickstart adoption. It's a rising star for JS frameworks and used by industry teams - stability ftw.
Astro has a large collection of themes supporting different site categories and frontend technology components. The "Official" filter identifies themes created by the Astro team. Starlight is the default documentation focused framework from Astro, currently in very early release. It promises:
- fast, accessible, easy-to-use websites
- site-navigation, search, i18n, SEO support
- code highlighting, dark mode, easy-to-read typography
- write in Markdown, MDX or Markdoc
Plus all Astro benefits (e.g., bring your own UI components).
-
Verify you have Node.js installed. I use
nvm
and default to the LTS version for Node.js.$ nvm use --lts Now using node v18.16.0 (npm v9.6.7)
-
Scaffold out a Starlight project with Astro.
$ npm create astro@latest -- --template starlight
As part of setup, you define the destination folder (
website
), install dependencies and configure Typescript, git usage if needed. You can also disable telemetry capture usingnpx astro telemetry disable
at this time. -
Preview the default Starlight site.
$ cd website $ npm run dev
This runs a dev server on
http://localhost:3001
which watchessrc/content
for changes (hot reload). -
Open the browser to that URL and let's see what we got:
A Landing Page (Light Mode)
A Landing Page (Dark Mode)
A Documentation Page (Default)
The Documentation Page Updated (Hot Reload)
The Search Feature (oh-oh!)
-
Alright, let's try to build the production version of the site locally.
$ cd website $ npm run build ... ... Finished in 0.13 seconds 08:53:44 PM [build] 4 page(s) built in 4.61s 08:53:44 PM [build] Complete!
-
You'll notice this builds the production version in the
dist
folder. Let's preview it.$ npm run preview
The output indicates the production server is running at
http://localhost:3000
- let's open that up. You see the same pages as before - but now let's try search. In fact, let's search for the changed text from above to see if it can be found.Search for "Related References" in Production
OMG - it works!! We didn't have to do anything extra to activate search indexes. Basic keyword search out of the box!
Before we explore deploying the production build to GitHub Pages, let's commit the current version. Done!
Now, let's deploy the Astro Site to GitHub Pages. Astro provides an official withastro/action
that should make this easy.
- Set
site
andbase
options inastro.config.js
- Create
.github/workflows/deploy.yml
and copy the provided workflow. - Since we have our site source in the
website/
subfolder (vs. root of repo), uncomment thewith
section of the install steps in workflow and set thepath
to./website
- Go to the GitHub repo's Settings > Pages configuration. Choose
GitHub Actions
as the Source of your site.
Commit the changes in your code to GitHub. You should see the deploy action run. If successful, the GitHub Pages endpoint should show the deployed site. It's LIVE! https://30daysof.github.io/astro-starlight-ghpages/!!
Issue: Hero links not resolving base path correctly
The "Example Guide" button on the landing page is mapped to "/guides/example/" but when clicked, does not take base prefix (repo path) into account, resulting in a 404. The same route used from the sidebar works just fine. I am assuming this has to do with the difference in how links are resolved in frontmatter vs. markdown Issue raised in community chat. Waiting for response.
The Starlight Blog plugin from the community adds the blog feature to the default Starlight theme. Let's try it out.
-
Install the plugin.
$ npm install starlight-blog --save
-
Add the plugin to
astro.config.mjs
and configure it.import starlight from '@astrojs/starlight' import { defineConfig } from 'astro/config' import starlightBlog from 'starlight-blog' export default defineConfig({ integrations: [ starlight({ plugins: [starlightBlog()], title: 'My Docs', }), ], })
-
Customize configuration if needed.
import starlight from '@astrojs/starlight' import { defineConfig } from 'astro/config' import starlightBlog from 'starlight-blog' export default defineConfig({ integrations: [ starlight({ plugins: [ starlightBlog({ title: "Blog", postCount: 7, recentPostCount: 1, authors: { nitya: { name: "Nitya", picture: "https://github.com/nitya.png", url: "https://github.com/nitya", title: "AI, Art & Advocacy @Microsoft", } }, }), ], title: 'My Docs', }), ], })
-
Extend the frontmatter schema
import { defineCollection } from 'astro:content';
import { docsSchema, i18nSchema } from '@astrojs/starlight/schema';
import { blogSchema } from 'starlight-blog/schema'
export const collections = {
docs: defineCollection({ schema: docsSchema({ extend: blogSchema() }) }),
i18n: defineCollection({ type: 'data', schema: i18nSchema() }),
};
- Now write your first blog post under
src/content/docs/blog
and see it show up in sidebar of blog. Update the link paths if needed.