Skip to content

Build and deploy Astro Starlight Documentation Site to GitHub Pages. Reuse as template for projects.

License

Notifications You must be signed in to change notification settings

30DaysOf/astro-starlight-ghpages

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Astro Starlight On GitHub Pages

Objectives

Build and deploy an Astro Starlight Documentation site to GitHub Pages. Explore features and customization - validate its use as reusable template.


1. Why Astro?

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.


2. Why Starlight?

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).


3. Quickstart

  1. 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)
  2. 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 using npx astro telemetry disable at this time.

  3. Preview the default Starlight site.

    $ cd website
    $ npm run dev

    This runs a dev server on http://localhost:3001 which watches src/content for changes (hot reload).

  4. Open the browser to that URL and let's see what we got:

    A Landing Page (Light Mode)

    Starlight Landing Page, Light mode

    A Landing Page (Dark Mode)

    Starlight Landing Page, Dark mode

    A Documentation Page (Default)

    Starlight Documentation Page, Default

    The Documentation Page Updated (Hot Reload)

    Starlight Documentation Page, Updated

    The Search Feature (oh-oh!)

    Starlight Search Feature, Disabled

  5. 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!
  6. 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!

    Starlight Production Preview, search


4. Deployment

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.

  1. Set site and base options in astro.config.js
  2. Create .github/workflows/deploy.yml and copy the provided workflow.
  3. Since we have our site source in the website/ subfolder (vs. root of repo), uncomment the with section of the install steps in workflow and set the path to ./website
  4. 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.


7. Adding Blog

The Starlight Blog plugin from the community adds the blog feature to the default Starlight theme. Let's try it out.

  1. Install the plugin.

    $ npm install starlight-blog --save
  2. 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',
        }),
      ],
    })
  3. 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',
        }),
      ],
    })
  4. 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() }),
};
  1. 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.

About

Build and deploy Astro Starlight Documentation Site to GitHub Pages. Reuse as template for projects.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published