Skip to content

Set the types property in package.json #2

Set the types property in package.json

Set the types property in package.json #2

name: Build Push Deploy
on:
push:
branches:
- main
jobs:
build:
name: Build
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Setup node
uses: actions/setup-node@v4
with:
node-version: 20
cache: yarn
- name: Install dependencies
run: |
yarn config set network-timeout 300000
yarn install --prefer-offline
- name: Build
continue-on-error: false
run: yarn build
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
name: dist
path: dist
retention-days: 30
push:
name: Push
needs: build
runs-on: ubuntu-latest
permissions:
contents: write
env:
BRANCH_NAME: ${{ github.head_ref || github.ref_name }}
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Download artifact
uses: actions/download-artifact@v4
with:
name: dist
path: dist
- name: Push distribution
run: |
MSG="$(printf "Publish distribution\n[skip ci]")"
git config --global user.name "github-actions[bot]"
git config --global user.email "github-actions[bot]@users.noreply.github.com"
git add dist/index.min.* -f
git commit -m "$MSG" --no-verify --signoff
git push origin $BRANCH_NAME
deploy:
name: Deploy
needs: build
runs-on: ubuntu-latest
permissions:
id-token: write
contents: read
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Download artifact
uses: actions/download-artifact@v4
with:
name: dist
path: dist
- name: Configure AWS credentials
uses: aws-actions/configure-aws-credentials@v4
with:
role-to-assume: ${{ secrets.AWS_GITHUB_ACTION_ROLE }}
aws-region: us-east-2
- name: Sync files to S3 bucket
run: |
PACKAGE_VERSION=$(npm pkg get version --workspaces=false | tr -d \")
aws s3 sync dist s3://cdn.zigurous.com/forge-react@$PACKAGE_VERSION/dist --delete --exclude "*.ts"