diff --git a/.github/workflows/jekyll-gh-pages.yml b/.github/workflows/jekyll-gh-pages.yml index e31d81c5..6a8edd57 100644 --- a/.github/workflows/jekyll-gh-pages.yml +++ b/.github/workflows/jekyll-gh-pages.yml @@ -1,50 +1,51 @@ -# Sample workflow for building and deploying a Jekyll site to GitHub Pages -name: Deploy Jekyll with GitHub Pages dependencies preinstalled +# Deploy Vue.js app to GitHub Pages +name: Deploy Vue.js App to GitHub Pages on: - # Runs on pushes targeting the default branch push: - branches: ["main"] - - # Allows you to run this workflow manually from the Actions tab + branches: + - main workflow_dispatch: -# Sets permissions of the GITHUB_TOKEN to allow deployment to GitHub Pages permissions: contents: read pages: write id-token: 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 steps: - - name: Checkout + - name: Checkout repository uses: actions/checkout@v4 - - name: Setup Pages - uses: actions/configure-pages@v5 - - name: Build with Jekyll - uses: actions/jekyll-build-pages@v1 + + - name: Set up Node.js + uses: actions/setup-node@v4 with: - source: ./ - destination: ./_site - - name: Upload artifact + node-version: 18 # or the version of Node.js your app uses + + - name: Install dependencies + run: npm install + + - name: Build Vue.js app + run: npm run build + env: + NODE_ENV: production + + - name: Configure Pages artifact + uses: actions/configure-pages@v5 + + - name: Upload artifact to GitHub Pages uses: actions/upload-pages-artifact@v3 + with: + path: dist # Change 'dist' if your Vue build outputs to another folder - # Deployment job deploy: + runs-on: ubuntu-latest + needs: build environment: name: github-pages url: ${{ steps.deployment.outputs.page_url }} - runs-on: ubuntu-latest - needs: build steps: - name: Deploy to GitHub Pages id: deployment diff --git a/vue.config.js b/vue.config.js new file mode 100644 index 00000000..39b09eb3 --- /dev/null +++ b/vue.config.js @@ -0,0 +1,5 @@ +module.exports = { + publicPath: process.env.NODE_ENV === 'production' + ? '/wine-educator/' + : '/' +};