From 13af132543b3307a64b6ba45c0afc7b87688f2d9 Mon Sep 17 00:00:00 2001 From: "o.lyttleton@ucl.ac.uk" Date: Fri, 31 May 2024 13:19:02 +0100 Subject: [PATCH] Setup next on github pages --- .github/workflows/setup-node/action.yml | 22 ++++++++++ .github/workflows/setup-node/publish.yml | 52 ++++++++++++++++++++++++ next.config.js | 7 ++++ 3 files changed, 81 insertions(+) create mode 100644 .github/workflows/setup-node/action.yml create mode 100644 .github/workflows/setup-node/publish.yml create mode 100644 next.config.js diff --git a/.github/workflows/setup-node/action.yml b/.github/workflows/setup-node/action.yml new file mode 100644 index 0000000..41d4904 --- /dev/null +++ b/.github/workflows/setup-node/action.yml @@ -0,0 +1,22 @@ +# File: .github/workflows/setup-node/action.yml +name: setup-node +description: "Setup Node.js - Cache dependencies - Install dependencies" +runs: + using: "composite" + steps: + - name: Setup Node.js + uses: actions/setup-node@v4 + with: + node-version: 20 + + - name: Cache dependencies + id: cache_dependencies + uses: actions/cache@v3 + with: + path: node_modules + key: node-modules-${{ hashFiles('package-lock.json') }} + + - name: Install dependencies + shell: bash + if: steps.cache_dependencies.outputs.cache-hit != 'true' + run: npm ci \ No newline at end of file diff --git a/.github/workflows/setup-node/publish.yml b/.github/workflows/setup-node/publish.yml new file mode 100644 index 0000000..3c6f4fa --- /dev/null +++ b/.github/workflows/setup-node/publish.yml @@ -0,0 +1,52 @@ +# File: .github/workflows/publish.yml +name: publish-to-github-pages +on: + push: + branches: + - master + +permissions: + contents: read + pages: write + id-token: write + +concurrency: + group: "pages" + cancel-in-progress: false + +jobs: + build: + runs-on: ubuntu-latest + + steps: + - name: Checkout + uses: actions/checkout@v4 + + - name: Setup Node.js - Cache dependencies - Install dependencies + uses: ./.github/workflows/setup-node + + - name: Setup Pages + uses: actions/configure-pages@v4 + with: + static_site_generator: next + + - name: Build with Next.js + run: npx next build + + - name: Upload artifact + uses: actions/upload-pages-artifact@v3 + with: + path: ./out + + deploy: + environment: + name: github-pages + url: ${{ steps.deployment.outputs.page_url }} + + runs-on: ubuntu-latest + needs: build + + steps: + - name: Publish to GitHub Pages + id: deployment + uses: actions/deploy-pages@v4 \ No newline at end of file diff --git a/next.config.js b/next.config.js new file mode 100644 index 0000000..bcff1cd --- /dev/null +++ b/next.config.js @@ -0,0 +1,7 @@ +/** @type {import('next').NextConfig} */ +const nextConfig = { + output: "export", // <=== enables static exports + reactStrictMode: true, + }; + + module.exports = nextConfig; \ No newline at end of file