feat: implement command menu for keyboard navigation #54
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: cypress | |
on: | |
pull_request: | |
branches: [ main ] | |
paths: [ "apps/admin-panel/**" ] | |
push: | |
branches: [ main ] | |
paths: [ "apps/admin-panel/**" ] | |
workflow_dispatch: | |
jobs: | |
cypress-test-run-in-browserstack: | |
name: browserstack / local tunnel into tilt up | |
runs-on: ubuntu-latest | |
steps: | |
- uses: docker/login-action@v3 | |
with: | |
registry: gcr.io | |
username: _json_key | |
password: ${{ secrets.GCR_JSON_KEY }} | |
- uses: DeterminateSystems/nix-installer-action@v4 | |
- uses: DeterminateSystems/magic-nix-cache-action@v8 | |
- uses: actions/checkout@v4 | |
- uses: "google-github-actions/auth@v2" | |
with: | |
credentials_json: "${{ secrets.GOOGLE_CREDENTIALS }}" | |
- name: build backend | |
run: nix develop -c make build-for-tests | |
- name: sync dataform-branch | |
run: nix develop -c make push-dataform-branch | |
env: | |
DATAFORM_BRANCH: "gha-dataform" | |
- name: keep tilt running | |
run: nix develop -c make tilt-in-ci | |
env: | |
GOOGLE_CREDENTIALS: ${{ secrets.GOOGLE_CREDENTIALS }} | |
TF_VAR_sa_creds: ${{ secrets.GOOGLE_SA_BASE64 }} | |
SA_CREDS_BASE64: ${{ secrets.GOOGLE_SA_BASE64 }} | |
SUMSUB_KEY: ${{ secrets.SUMSUB_KEY }} | |
SUMSUB_SECRET: ${{ secrets.SUMSUB_SECRET }} | |
TF_VAR_name_prefix: "gha" | |
- name: system info | |
run: | | |
free -h | |
df -h | |
- name: run cypress tests | |
run: nix develop -c make test-cypress-in-ci-through-browserstack | |
env: | |
BROWSERSTACK_USERNAME: ${{ secrets.BROWSERSTACK_USERNAME }} | |
BROWSERSTACK_ACCESS_KEY: ${{ secrets.BROWSERSTACK_ACCESS_KEY }} | |
- name: upload cypress screenshots | |
uses: actions/upload-artifact@v4 | |
with: | |
name: screenshots | |
path: apps/admin-panel/cypress/manuals/screenshots/* | |
manual-generation: | |
name: manual pdfs / upload to lana-manuals | |
needs: cypress-test-run-in-browserstack | |
runs-on: ubuntu-latest | |
steps: | |
- uses: DeterminateSystems/nix-installer-action@v4 | |
- uses: DeterminateSystems/magic-nix-cache-action@v8 | |
- uses: actions/checkout@v4 | |
- run: mkdir -p apps/admin-panel/cypress/manuals/screenshots | |
- uses: actions/download-artifact@v4 | |
with: | |
name: screenshots | |
path: apps/admin-panel/cypress/manuals/screenshots | |
- name: generate pdfs | |
run: cd apps/admin-panel && nix develop -c pnpm run local:pdf | |
- run: ls -R apps/admin-panel/cypress/manuals | |
- uses: actions/upload-artifact@v4 | |
with: | |
name: pdfs | |
path: apps/admin-panel/cypress/manuals/results/* | |
- name: generate manual page | |
run: | | |
cd apps/admin-panel/cypress/manuals/results | |
cat <<EOF > index.html | |
<!DOCTYPE html> | |
<html lang="en"> | |
<head> | |
<meta charset="UTF-8"> | |
<meta name="viewport" content="width=device-width, initial-scale=1.0"> | |
<title>Lana Bank Manuals</title> | |
<script src="https://cdn.tailwindcss.com"></script> | |
</head> | |
<body class="bg-gray-100 font-sans"> | |
<div class="max-w-5xl mx-auto mt-10 p-5"> | |
<h1 class="text-3xl font-bold text-center text-gray-800 mb-6"> | |
Lana Bank - Manuals for Regulators | |
</h1> | |
<div class="overflow-x-auto"> | |
<table class="w-full border-collapse bg-white shadow-md rounded-lg"> | |
<thead> | |
<tr class="bg-gray-800 text-white"> | |
<th class="py-3 px-5 text-left">#</th> | |
<th class="py-3 px-5 text-left">Manual Name</th> | |
<th class="py-3 px-5 text-left">View</th> | |
</tr> | |
</thead> | |
<tbody> | |
EOF | |
COUNTER=1 | |
for pdf in *.pdf; do | |
echo "<tr class='hover:bg-gray-50 border-b'> | |
<td class='py-3 px-5'>$COUNTER</td> | |
<td class='py-3 px-5'>${pdf%.pdf}</td> | |
<td class='py-3 px-5'> | |
<a href='$pdf' class='text-blue-600 hover:underline' target='_blank'>Open</a> | |
</td> | |
</tr>" >> index.html | |
((COUNTER++)) | |
done | |
cat <<EOF >> index.html | |
</tbody> | |
</table> | |
</div> | |
</div> | |
</body> | |
</html> | |
EOF | |
- name: Install Netlify CLI | |
run: npm install -g netlify-cli | |
- name: Deploy to Netlify (Pull Request) | |
id: netlify_deploy | |
if: github.event_name == 'pull_request' | |
env: | |
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }} | |
NETLIFY_SITE_ID: 61296920-bd52-43a3-9253-78db17a78d9c | |
run: | | |
GITHUB_SHA="${{ github.sha }}" | |
SHORT_SHA="${GITHUB_SHA::7}" | |
ALIAS="pr-${{ github.event.pull_request.number }}-commit-${SHORT_SHA}" | |
netlify deploy \ | |
--dir=apps/admin-panel/cypress/manuals/results \ | |
--site=$NETLIFY_SITE_ID \ | |
--auth=$NETLIFY_AUTH_TOKEN \ | |
--alias="$ALIAS" \ | |
--message="Manuals Preview for PR #${{ github.event.pull_request.number }} Commit $GITHUB_SHA" \ | |
--json > deploy-info.json | |
DEPLOY_URL=$(jq -r '.deploy_url' deploy-info.json) | |
echo "deploy_url=$DEPLOY_URL" >> $GITHUB_OUTPUT | |
- name: Deploy to Netlify (Push to Main) | |
if: github.event_name == 'push' | |
env: | |
NETLIFY_AUTH_TOKEN: ${{ secrets.NETLIFY_AUTH_TOKEN }} | |
NETLIFY_SITE_ID: 61296920-bd52-43a3-9253-78db17a78d9c | |
run: | | |
netlify deploy \ | |
--prod \ | |
--dir=apps/admin-panel/cypress/manuals/results \ | |
--site=$NETLIFY_SITE_ID \ | |
--auth=$NETLIFY_AUTH_TOKEN \ | |
--message="Manuals Build for Commit ${{ github.sha }}" \ | |
--json > deploy-info.json | |
DEPLOY_URL=$(jq -r '.deploy_url' deploy-info.json) | |
echo "deploy_url=$DEPLOY_URL" >> $GITHUB_OUTPUT | |
- name: Create or Update Preview Comment | |
if: github.event_name == 'pull_request' | |
uses: actions/github-script@v6 | |
with: | |
script: | | |
const prNumber = context.payload.pull_request.number; | |
const deployUrl = '${{ steps.netlify_deploy.outputs.deploy_url }}'; | |
const commentBody = `<!-- Manuals Preview Comment -->\nManuals preview: [Link to Manuals](${deployUrl})`; | |
// Fetch existing comments on the PR | |
const { data: comments } = await github.rest.issues.listComments({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: prNumber, | |
}); | |
// Identify if the bot has already made a comment | |
const botLogin = 'github-actions[bot]' | |
const existingComment = comments.find( | |
comment => comment.user.login === botLogin && comment.body.includes('<!-- Manuals Preview Comment -->') | |
); | |
if (existingComment) { | |
// Update the existing comment | |
await github.rest.issues.updateComment({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
comment_id: existingComment.id, | |
body: commentBody, | |
}); | |
} else { | |
// Create a new comment | |
await github.rest.issues.createComment({ | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
issue_number: prNumber, | |
body: commentBody, | |
}); | |
} |