[Dropdown]: Look at .value property as well as attribute when determi… #1150
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: Deploy | |
on: | |
pull_request: | |
push: | |
branches: | |
- main | |
workflow_dispatch: | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
jobs: | |
build: | |
runs-on: ubuntu-latest | |
permissions: | |
id-token: write | |
contents: read # This is required for actions/checkout | |
pull-requests: write # For actions/github-script | |
environment: | |
name: staging | |
env: | |
CLOUDFRONT_DISTRIBUTION_ID: ${{ secrets.CLOUDFRONT_DISTRIBUTION_ID }} | |
S3_BUCKET_NAME: ${{ secrets.S3_BUCKET_NAME }} | |
steps: | |
- uses: actions/checkout@f43a0e5ff2bd294095638e18286ca9a3d1956744 # v3.6.0 | |
- name: Get npm cache directory path | |
id: npm-cache-dir-path | |
run: echo "dir=$(npm config get cache)" >> $GITHUB_OUTPUT | |
- uses: actions/cache@704facf57e6136b1bc63b828d79edcd491f0ee84 # v3.3.2 | |
id: npm-cache | |
with: | |
path: ${{ steps.npm-cache-dir-path.outputs.dir }} | |
key: ${{ runner.os }}-npm-${{ hashFiles('**/package-lock.json') }} | |
restore-keys: | | |
${{ runner.os }}-npm- | |
- name: Install dependencies | |
run: | | |
npm ci --ignore-scripts | |
# Please check with Brave's security team prior to adding any packages to this list. | |
npm rebuild style-dictionary-create-react-app | |
- name: Format | |
id: format | |
run: | | |
npm run format-diff | |
- name: Build nala | |
id: build-nala | |
run: | | |
npm run build | |
- name: Audit Tokens | |
id: audit-tokens | |
run: | | |
node ./src/scripts/audit-tokens.js | |
- name: Diff Tokens | |
id: diff-tokens | |
run: | | |
curl -fsSL -o ./tokens/css/variables.old.css https://nala.bravesoftware.com/css/variables.css | |
# Note: Diff has exit code 1 for differences, and there are always | |
# some differences because the file contains a timestamp. | |
diff -u ./tokens/css/variables.old.css ./tokens/css/variables.css > ./tokens/css/variables.diff || : | |
- name: Check Types | |
id: check-types | |
run: | | |
npm run check | |
- name: Build the React example project | |
id: example-react | |
working-directory: ./examples/example-ui-react | |
run: | | |
npm install --no-save | |
npm run build | |
- name: Configure AWS credentials | |
uses: aws-actions/configure-aws-credentials@5fd3084fc36e372ff1fff382a39b10d03659f355 # v2.2.0 | |
with: | |
role-to-assume: ${{ secrets.AWS_ROLE_ARN }} | |
role-session-name: github-actions-pr-nala-${{ github.run_id }} | |
aws-region: us-west-2 | |
- name: Deploy | |
id: build-site | |
env: | |
AWS_REGION: us-west-2 | |
NODE_OPTIONS: '--max_old_space_size=6144' | |
run: | | |
shopt -s inherit_errexit | |
set -xeEo pipefail | |
HEAD_SHA=${{ github.event.pull_request.head.sha }} | |
[ -z "$AWS_ACCESS_KEY_ID" ] && exit 1 | |
BUCKET_PATH=$(jq -r .pull_request.number "$GITHUB_EVENT_PATH" | grep -E '^[0-9]+$' || true) | |
npm run build-storybook | |
echo "::group::Upload to AWS S3" | |
cd ./storybook-static | |
aws configure set default.s3.max_concurrent_requests 100 | |
aws configure set default.s3.max_queue_size 10000 | |
if [[ -z ${BUCKET_PATH} ]]; then # non PR | |
aws s3 sync . "s3://${S3_BUCKET_NAME}/" --delete --exclude 'pr-*/*' | |
else | |
aws s3 sync . "s3://${S3_BUCKET_NAME}/pr-${BUCKET_PATH}/commit-${HEAD_SHA}/" --delete | |
aws s3 sync . "s3://${S3_BUCKET_NAME}/pr-${BUCKET_PATH}/" --delete --exclude 'commit-*/*' | |
fi | |
echo "::endgroup::" | |
- name: Post GitHub comment | |
uses: actions/github-script@d7906e4ad0b1822421a7e6a35d5ca353c962f410 # v6.4.1 | |
if: ${{ github.event_name == 'pull_request' }} | |
with: | |
script: | | |
const fs = require('fs/promises') | |
const diff = await fs.readFile('./tokens/css/variables.diff', 'utf-8') | |
await github.rest.issues.createComment({ | |
issue_number: context.issue.number, | |
owner: context.repo.owner, | |
repo: context.repo.repo, | |
body: `👋 Thanks for Submitting! This PR is available for preview at the link below. | |
✅ PR tip preview: https://${context.issue.number}.pr.nala.bravesoftware.com/ | |
✅ Commit preview: https://${context.issue.number}.pr.nala.bravesoftware.com/commit-${context.payload.pull_request.head.sha}/ | |
<details> | |
<summary>Variables Diff</summary> | |
\`\`\`diff | |
${diff} | |
\`\`\` | |
</details>` | |
}) |