Fix for grid multiple images #340
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
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 }} |