Skip to content

CI: consolidate docs deployment workflows and add PR previews #24

CI: consolidate docs deployment workflows and add PR previews

CI: consolidate docs deployment workflows and add PR previews #24

Workflow file for this run

name: Publish Docs
on:
push:
branches: [master]
pull_request:
branches: [master]
workflow_dispatch:
inputs:
pr_number:
description: 'PR number to deploy preview for'
required: true
type: number
run_id:
description: 'Run ID of the build workflow (from the PR checks)'
required: true
type: string
permissions:
contents: write
pull-requests: write
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup Node.js
uses: actions/setup-node@v4
with:
node-version: 20
- name: Install dependencies
run: npm ci
- name: Build
run: npm run build
- name: Upload build artifact
uses: actions/upload-artifact@v4
with:
name: site
path: build/
deploy-pr-preview:
if: ${{ github.event_name == 'workflow_dispatch' }}
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Download build artifact
uses: actions/download-artifact@v4
with:
name: site
path: site
run-id: ${{ inputs.run_id }}
github-token: ${{ secrets.GITHUB_TOKEN }}
- name: Deploy PR Preview
uses: JamesIves/github-pages-deploy-action@v4
with:
branch: gh-pages-pr-previews
folder: site
target-folder: pr-${{ inputs.pr_number }}
- name: Comment Preview URL
uses: marocchino/sticky-pull-request-comment@v2
with:
recreate: true
number: ${{ inputs.pr_number }}
message: |
🚀 **Preview Ready!**
Your docs preview for this PR is available here:
**https://${{ github.repository_owner }}.github.io/${{ github.event.repository.name }}/pr-${{ inputs.pr_number }}/**
deploy-production:
if: ${{ github.event_name == 'push' && github.ref == 'refs/heads/master' }}
runs-on: ubuntu-latest
needs: build
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Download build artifact
uses: actions/download-artifact@v4
with:
name: site
path: site
- name: Deploy to GitHub Pages
uses: JamesIves/github-pages-deploy-action@v4
with:
branch: gh-pages
folder: site