|
1 | | -# Sample workflow for building and deploying a Next.js site to GitHub Pages |
2 | | -# |
3 | | -# To get started with Next.js see: https://nextjs.org/docs/getting-started |
4 | | -# |
5 | | -name: Deploy Next.js site to Pages |
| 1 | +name: Deploy Vite + React App to GitHub Pages |
6 | 2 |
|
7 | 3 | on: |
8 | | - # Runs on pushes targeting the default branch |
9 | 4 | push: |
10 | | - branches: ["main"] |
| 5 | + branches: |
| 6 | + - main # or your default branch |
11 | 7 |
|
12 | | - # Allows you to run this workflow manually from the Actions tab |
13 | | - workflow_dispatch: |
14 | | - |
15 | | -# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages |
16 | 8 | permissions: |
17 | 9 | contents: read |
18 | 10 | pages: write |
19 | 11 | id-token: write |
20 | 12 |
|
21 | | -# Allow only one concurrent deployment, skipping runs queued between the run in-progress and latest queued. |
22 | | -# However, do NOT cancel in-progress runs as we want to allow these production deployments to complete. |
23 | 13 | concurrency: |
24 | | - group: "pages" |
25 | | - cancel-in-progress: false |
| 14 | + group: 'pages' |
| 15 | + cancel-in-progress: true |
26 | 16 |
|
27 | 17 | jobs: |
28 | | - # Build job |
29 | 18 | build: |
30 | 19 | runs-on: ubuntu-latest |
31 | 20 | steps: |
32 | | - - name: Checkout |
| 21 | + - name: Checkout Repository |
33 | 22 | uses: actions/checkout@v4 |
34 | | - - name: Detect package manager |
| 23 | + |
| 24 | + - name: Detect Package Manager |
35 | 25 | id: detect-package-manager |
36 | 26 | run: | |
37 | 27 | if [ -f "${{ github.workspace }}/yarn.lock" ]; then |
38 | 28 | echo "manager=yarn" >> $GITHUB_OUTPUT |
39 | | - echo "command=install" >> $GITHUB_OUTPUT |
| 29 | + echo "install=install" >> $GITHUB_OUTPUT |
40 | 30 | echo "runner=yarn" >> $GITHUB_OUTPUT |
41 | 31 | exit 0 |
42 | | - elif [ -f "${{ github.workspace }}/package.json" ]; then |
| 32 | + elif [ -f "${{ github.workspace }}/package-lock.json" ]; then |
43 | 33 | echo "manager=npm" >> $GITHUB_OUTPUT |
44 | | - echo "command=ci" >> $GITHUB_OUTPUT |
| 34 | + echo "install=ci" >> $GITHUB_OUTPUT |
45 | 35 | echo "runner=npx --no-install" >> $GITHUB_OUTPUT |
46 | 36 | exit 0 |
47 | 37 | else |
48 | 38 | echo "Unable to determine package manager" |
49 | 39 | exit 1 |
50 | 40 | fi |
| 41 | +
|
51 | 42 | - name: Setup Node |
52 | 43 | uses: actions/setup-node@v4 |
53 | 44 | with: |
54 | | - node-version: "20" |
| 45 | + node-version: '20' |
55 | 46 | cache: ${{ steps.detect-package-manager.outputs.manager }} |
56 | | - - name: Setup Pages |
57 | | - uses: actions/configure-pages@v5 |
58 | | - with: |
59 | | - # Automatically inject basePath in your Next.js configuration file and disable |
60 | | - # server side image optimization (https://nextjs.org/docs/api-reference/next/image#unoptimized). |
61 | | - # |
62 | | - # You may remove this line if you want to manage the configuration yourself. |
63 | | - static_site_generator: next |
64 | | - - name: Restore cache |
65 | | - uses: actions/cache@v4 |
66 | | - with: |
67 | | - path: | |
68 | | - .next/cache |
69 | | - # Generate a new cache whenever packages or source files change. |
70 | | - key: ${{ runner.os }}-nextjs-${{ hashFiles('**/package-lock.json', '**/yarn.lock') }}-${{ hashFiles('**.[jt]s', '**.[jt]sx') }} |
71 | | - # If source files changed but packages didn't, rebuild from a prior cache. |
72 | | - restore-keys: | |
73 | | - ${{ runner.os }}-nextjs-${{ hashFiles('**/package-lock.json', '**/yarn.lock') }}- |
74 | | - - name: Install dependencies |
75 | | - run: ${{ steps.detect-package-manager.outputs.manager }} ${{ steps.detect-package-manager.outputs.command }} |
76 | | - - name: Build with Next.js |
77 | | - run: ${{ steps.detect-package-manager.outputs.runner }} next build |
78 | | - - name: Upload artifact |
| 47 | + |
| 48 | + - name: Install Dependencies |
| 49 | + run: ${{ steps.detect-package-manager.outputs.manager }} ${{ steps.detect-package-manager.outputs.install }} |
| 50 | + |
| 51 | + - name: Build Vite App |
| 52 | + run: ${{ steps.detect-package-manager.outputs.runner }} vite build |
| 53 | + |
| 54 | + - name: Upload Artifact |
79 | 55 | uses: actions/upload-pages-artifact@v3 |
80 | 56 | with: |
81 | | - path: ./out |
| 57 | + path: dist |
82 | 58 |
|
83 | | - # Deployment job |
84 | 59 | deploy: |
| 60 | + needs: build |
| 61 | + runs-on: ubuntu-latest |
85 | 62 | environment: |
86 | 63 | name: github-pages |
87 | 64 | url: ${{ steps.deployment.outputs.page_url }} |
88 | | - runs-on: ubuntu-latest |
89 | | - needs: build |
90 | 65 | steps: |
91 | 66 | - name: Deploy to GitHub Pages |
92 | 67 | id: deployment |
|
0 commit comments