Skip to content

Publish latest frontend image #25

Publish latest frontend image

Publish latest frontend image #25

name: Publish latest frontend image
on:
push:
branches:
- main
jobs:
build:
name: Build Vue
runs-on: ubuntu-latest
steps:
- name: ↩️ Checkout
uses: actions/checkout@v4
- name: 🏗️ Install Node.js 18.x
uses: actions/setup-node@v4
with:
node-version: 18.x
cache: 'npm'
cache-dependency-path: 'frontend/package-lock.json'
- name: 🏗️ Install packages
run: cd frontend && npm ci
- name: ⚙️ Build application
run: cd frontend && npm run build
- name: 🗄️ Upload Artifact
uses: actions/upload-artifact@v4
with:
name: frontend
path: frontend/dist/*
image:
name: Build Docker image
runs-on: ubuntu-latest
needs:
- build
steps:
- name: ↩️ Checkout
uses: actions/checkout@v4
- name: 🗄️ Download artifact
uses: actions/download-artifact@v4
with:
name: frontend
path: frontend/dist/
- name: ℹ️ Docker meta
id: docker_meta
uses: docker/metadata-action@v5
with:
images: ghcr.io/poeschl/brettbutler:frontend
- name: 🏗️ Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: 🔑 GHCR Login
uses: docker/login-action@v3
with:
registry: ghcr.io
username: ${{ github.repository_owner }}
password: ${{ secrets.GITHUB_TOKEN }}
- name: 🚀 Build and push
uses: docker/build-push-action@v5
with:
context: frontend
file: frontend/docker/Dockerfile
push: true
tags: ghcr.io/poeschl/brettbutler:frontend
labels: ${{ steps.docker_meta.outputs.labels }}