Skip to content

Fix for grid multiple images #340

Fix for grid multiple images

Fix for grid multiple images #340

Workflow file for this run

name: Frontend CI
on:
push:
branches:
- main
paths:
- "frontend/**"
- ".github/workflows/frontend.yml"
workflow_dispatch:
env:
node-version: 16.x
jobs:
eslint:
runs-on: ubuntu-latest
defaults:
run:
working-directory: ./frontend
steps:
- name: Checkout codebase
uses: actions/checkout@v3
- name: Use Node.js ${{ env.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ env.node-version }}
cache: "yarn"
cache-dependency-path: "frontend/yarn.lock"
- name: Install packages
run: make install
- name: Lint
run: yarn run lint:ci
prettier:
runs-on: ubuntu-latest
defaults:
run:
working-directory: ./frontend
steps:
- name: Checkout codebase
uses: actions/checkout@v3
- name: Run Prettier
run: npx prettier@2.0.5 --single-quote --check 'src/**/*.{js,jsx,ts,tsx,css,scss}' --config=package.json
i18n:
name: i18n sync
runs-on: ubuntu-latest
defaults:
run:
working-directory: frontend
steps:
- name: Checkout codebase
uses: actions/checkout@v3
- name: Use Node.js ${{ env.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ env.node-version }}
cache: "yarn"
cache-dependency-path: "frontend/yarn.lock"
- name: Install packages
run: make install
- name: Test i18n sync
run: make i18n-ci
unit:
runs-on: ubuntu-latest
defaults:
run:
working-directory: ./frontend
steps:
- name: Checkout codebase
uses: actions/checkout@v3
- name: Use Node.js ${{ env.node-version }}
uses: actions/setup-node@v3
with:
node-version: ${{ env.node-version }}
cache: "yarn"
cache-dependency-path: "frontend/yarn.lock"
- name: Install packages
run: make install
- name: Test
run: make test
release:
runs-on: ubuntu-latest
needs: [eslint, prettier, i18n, unit]
permissions:
contents: read
packages: write
steps:
- name: Checkout
uses: actions/checkout@v3
- name: Docker meta
id: meta
uses: docker/metadata-action@v4
with:
images: |
intkbv/rietveld-frontend
labels: |
org.label-schema.docker.cmd=docker run -d -p 3000:3000 intkbv/rietveld-frontend:latest
flavor: latest=false
tags: |
type=ref,event=branch
type=sha
type=raw,value=latest,enable={{is_default_branch}}
- name: Set up QEMU
uses: docker/setup-qemu-action@v2
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v2
- name: Login to Container Registry
uses: docker/login-action@v2
with:
username: ${{ secrets.DOCKERHUB_USERNAME }}
password: ${{ secrets.DOCKERHUB_TOKEN }}
- name: Build and push
uses: docker/build-push-action@v3
with:
platforms: linux/amd64
context: frontend/
file: frontend/Dockerfile
push: ${{ github.event_name != 'pull_request' }}
tags: ${{ steps.meta.outputs.tags }}
labels: $${{ steps.meta.outputs.labels }}