Skip to content

Deploy Jekyll with GitHub Pages #33

Deploy Jekyll with GitHub Pages

Deploy Jekyll with GitHub Pages #33

name: Deploy Jekyll with GitHub Pages
on:
pull_request:
types: [closed]
paths:
- "src/**"
- "assets/**"
- "README.MD"
- "README.0.9.2.MD"
# Allows you to run this workflow manually from the Actions tab
workflow_dispatch:
# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages
permissions:
contents: write
pages: write
id-token: write
pull-requests: write
# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued.
# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete.
concurrency:
group: "pages"
cancel-in-progress: false
jobs:
# Build job
build:
runs-on: ubuntu-latest
if: github.event.pull_request.merged == true
steps:
- name: Checkout
uses: actions/checkout@v3
- uses: actions/setup-node@v2
with:
node-version: 16
- name: Install dependencies
run: npm install
- name: Build docs
run: npm run docs
- name: Setup Pages
uses: actions/configure-pages@v3
- name: Build with Jekyll
uses: actions/jekyll-build-pages@v1
with:
source: ./docs/latest
destination: ./_site
- name: Upload artifact
uses: actions/upload-pages-artifact@v1
- name: Build with Jekyll v1.0.1
uses: actions/jekyll-build-pages@v1
with:
source: ./docs/v1.0.x
destination: ./_site/v1.0.x
- name: Upload artifact
uses: actions/upload-pages-artifact@v1
# Deployment job
deploy:
environment:
name: github-pages
url: ${{ steps.deployment.outputs.page_url }}
runs-on: ubuntu-latest
needs: build
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v2