name: Deploy frontend preview on: pull_request: paths: - 'apps/frontend/**/*' - 'packages/ui/**/*' - 'packages/utils/**/*' - 'packages/assets/**/*' - '**/wrangler.jsonc' - '**/pnpm-*.yaml' - '.github/workflows/frontend-preview.yml' jobs: deploy: if: github.repository_owner == 'modrinth' && github.event.pull_request.head.repo.full_name == github.repository uses: ./.github/workflows/frontend-deploy.yml secrets: inherit strategy: matrix: environment: [staging-preview, production-preview] with: environment: ${{ matrix.environment }} deploy-storybook: if: github.repository_owner == 'modrinth' && github.event.pull_request.head.repo.full_name == github.repository runs-on: ubuntu-latest permissions: contents: read deployments: write steps: - name: Checkout code uses: actions/checkout@v4 - name: Setup pnpm uses: pnpm/action-setup@v4 - name: Setup Node uses: actions/setup-node@v4 with: node-version-file: .nvmrc cache: pnpm - name: Install dependencies working-directory: ./packages/ui run: pnpm install - name: Build Storybook working-directory: ./packages/ui run: pnpm run build-storybook - name: Configure short SHA id: meta run: echo "sha_short=${GITHUB_SHA::8}" >> $GITHUB_OUTPUT - name: Deploy Storybook preview uses: cloudflare/wrangler-action@v3 with: apiToken: ${{ secrets.CF_API_TOKEN }} accountId: ${{ secrets.CF_ACCOUNT_ID }} workingDirectory: ./packages/ui packageManager: pnpm wranglerVersion: '4.54.0' command: versions upload --preview-alias git-${{ steps.meta.outputs.sha_short }} comment: if: github.repository_owner == 'modrinth' && github.event.pull_request.head.repo.full_name == github.repository runs-on: ubuntu-latest needs: [deploy, deploy-storybook] steps: - name: Download deployment URLs uses: actions/download-artifact@v7 with: pattern: deployment-url-* merge-multiple: true - name: Read deployment URLs id: urls run: | STAGING_PREVIEW_URL=$(cat deployment-url-staging-preview.txt) PRODUCTION_PREVIEW_URL=$(cat deployment-url-production-preview.txt) echo "Production preview URL: $PRODUCTION_PREVIEW_URL" echo "Staging preview URL: $STAGING_PREVIEW_URL" echo "staging-preview-url=$STAGING_PREVIEW_URL" >> $GITHUB_OUTPUT echo "production-preview-url=$PRODUCTION_PREVIEW_URL" >> $GITHUB_OUTPUT echo "storybook-preview-url=https://git-${GITHUB_SHA::8}-storybook.modrinth.workers.dev" >> $GITHUB_OUTPUT - name: Find comment if: github.event_name == 'pull_request' uses: peter-evans/find-comment@v3 id: fc with: token: ${{ secrets.CROWDIN_GH_TOKEN }} issue-number: ${{ github.event.pull_request.number }} body-includes: Frontend previews - name: Comment deploy URL on PR if: github.event_name == 'pull_request' uses: peter-evans/create-or-update-comment@v5 with: token: ${{ secrets.CROWDIN_GH_TOKEN }} issue-number: ${{ github.event.pull_request.number }} comment-id: ${{ steps.fc.outputs.comment-id }} body: | ## Frontend previews Last deployed commit is [${{ github.sha }}](${{ github.event.pull_request.head.repo.html_url }}/commit/${{ github.sha }}) | Environment | URL | |-------------|-----| | staging | ${{ steps.urls.outputs.staging-preview-url }} | | production | ${{ steps.urls.outputs.production-preview-url }} | | storybook | ${{ steps.urls.outputs.storybook-preview-url }} | edit-mode: replace