Skip to content

style: update donor alert heading for consistency (#35) #49

style: update donor alert heading for consistency (#35)

style: update donor alert heading for consistency (#35) #49

name: Firebase Auto Deploy
on:
push:
branches:
- main
paths:
- 'src/**'
- 'public/**'
- 'firebase.json'
- 'package.json'
- 'index.html'
- 'vitest.config.js'
- '.firebaserc'
- '.github/workflows/*'
concurrency:
group: firebase-deploy-${{ github.ref }}
cancel-in-progress: true
jobs:
build-and-deploy:
name: πŸ› οΈ Build, Test, and Deploy
runs-on: ubuntu-latest
steps:
# Step 1: Checkout the code
- name: πŸ“₯ Checkout Code
uses: actions/checkout@v4
# Step 2: Setup Node.js and enable caching
- name: πŸ› οΈ Setup Node
uses: actions/setup-node@v4
with:
node-version: 'lts/*'
cache: 'npm'
# Step 3: Restore dependencies cache
- name: πŸ“‚ Restore npm cache
uses: actions/cache@v4
with:
path: ~/.npm
key: ${{ runner.os }}-npm-cache-${{ hashFiles('package-lock.json') }}
restore-keys: |
${{ runner.os }}-npm-cache-
# Step 4: Install dependencies
- name: πŸ“‚ Install Packages
run: npm ci
# Step 5: Run linter
- name: 🚨 Lint Code
run: npm run lint:fix
# Step 6: Format code
- name: 🎨 Format Code
run: npm run format
# Step 7: Build the project
- name: 🧱 Build Project
run: npm run build
# Step 8: Cache the build output
- name: πŸ“¦ Cache build output
uses: actions/cache@v4
with:
path: |
dist
key: ${{ runner.os }}-build-cache-${{ hashFiles('src/**', 'public/**') }}
restore-keys: |
${{ runner.os }}-build-cache-
# Step 9: Run tests
- name: πŸ§ͺ Run Tests with Vitest
if: success()
run: npm run test:ci
# Step 10: Install Firebase CLI (use cache for global installs)
- name: 🌍 Install Firebase Tools
if: success()
run: npm install -g firebase-tools
# Step 11: Deploy to Firebase
- name: πŸš€ Deploy to Firebase
if: success()
env:
FIREBASE_TOKEN: ${{ secrets.FIREBASE_TOKEN }}
run: firebase deploy --non-interactive