Skip to content

Deploy client build to GH Pages #24

Deploy client build to GH Pages

Deploy client build to GH Pages #24

Workflow file for this run

name: Github pages overwrite
run-name: Deploy client build to GH Pages
on:
push:
branches:
- "prod"
paths:
- "client/**"
# NOTE: You may want to limit the trigger branch to be "main" or "master" etc.
workflow_dispatch:
permissions:
contents: write
pages: write
id-token: write
pull-requests: write
repository-projects: write
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Check out
uses: actions/checkout@v3
- name: Generate your content
run: echo "Optional placeholder. Put your project's static website generator command here."
- name: Set up Node.js
uses: actions/setup-node@v2
with:
node-version: 18
- name: Install dependencies
run: cd client && npm install
- name: Build static website
run: cd client && npm run build
- name: Publish current workdir (which contains generated content) to GitHub Pages
uses: rayluo/github-pages-overwriter@v1.3
with:
# Optional. Default value "." means the root directory of your project will be published.
# You can use whatever directory your project uses, for example "wwwroot".
# Such a directory does *not* have to already exist in your repo,
# it could be an output directory created dynamically by your static website builder.
source-directory: client/out
# Optional. Default value "gh-pages".
# It specifies the temporary branch which hosts the static website.
# Each build will OVERWRITE this branch.
# target-branch: gh-pages-test
deployment:
runs-on: ubuntu-latest
environment:
name: production
url: https://github.com
steps:
- name: Upload a Build Artifact
uses: actions/upload-artifact@v3.1.3
with:
# Artifact name
# name: # optional, default is artifact
# A file, directory or wildcard pattern that describes what to upload
path: arti
# The desired behavior if no files are found using the provided path.
- name: Deploy to github pages
id: deployment
uses: actions/deploy-pages@v2
# ...deployment-specific steps