Skip to content

chore: Modify the icon optimization + component generation in a pipeline, instead of doing it every build #24

chore: Modify the icon optimization + component generation in a pipeline, instead of doing it every build

chore: Modify the icon optimization + component generation in a pipeline, instead of doing it every build #24

Workflow file for this run

name: Icon Generator
# Pnpm setup based on https://github.com/pnpm/action-setup#use-cache-to-reduce-installation-time
on:
pull_request:
paths:
- "packages/svg-icons/src/icons/**"
permissions:
contents: write
env:
CI: true
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Install Node.js
uses: actions/setup-node@v4
with:
node-version-file: ".nvmrc"
- uses: pnpm/action-setup@v2
name: Install pnpm
id: pnpm-install
with:
version: 8
run_install: false
- name: Get pnpm store directory
id: pnpm-cache
shell: bash
run: |
echo "STORE_PATH=$(pnpm store path)" >> $GITHUB_OUTPUT
- name: Setup pnpm cache
uses: actions/cache@v3
with:
path: ${{ steps.pnpm-cache.outputs.STORE_PATH }}
key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }}
restore-keys: |
${{ runner.os }}-pnpm-store-
- name: Install dependencies
run: pnpm i --frozen-lockfile
- name: Test packages #we make sure the icons are in the correct format before generating them
run: pnpm test
- name: Generate icons
run: pnpm generate-icons
- name: Check for changes
id: check-changes
run: |
if git diff --name-only --quiet; then
echo "result=No changes" >> $GITHUB_OUTPUT
else
echo "result=Changes detected" >> $GITHUB_OUTPUT
fi
- name: Commit and Push changes
if: steps.check-changes.outputs.result == 'Changes detected'
run: |
echo >> "Fetch the files, should only fetch the branch we want, but wtv"
git fetch --depth=1
echo >> "Checkout"
git checkout -B ${{ github.head_ref }}
git config --local user.email "[email protected]"
git config --local user.name "GitHub Actions"
echo >> "Add the files"
git add .
echo >> "Next, we commit"
git commit -m "Update icons [skip ci]"
echo >> "We pull"
git pull origin {{ github.head_ref }}
echo >> "We push"
git push --set-upstream origin "HEAD:${{ github.head_ref }}"
- name: Comment on pull request
if: steps.check-changes.outputs.result == 'Changes detected'
uses: actions/github-script@v7
with:
script: |
const comment = 'Optimized icons have been automatically generated and pushed to the repository. Don't forget to add a changeset file for @hopper-ui/svg-icons and @hopper-ui/icons.';
github.issues.createComment({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: context.issue.number,
body: comment
});