[pull] main from nodejs:main #224
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
# This Workflow is used to comment on PRs that have changes that touch Translated Files | |
# and then comments on their PRs mentioning that they should not do so | |
name: Crowdin Checks | |
on: | |
pull_request_target: | |
branches: | |
- main | |
paths: | |
- 'pages/**/*.md' | |
- 'pages/**/*.mdx' | |
- '!pages/en/**/*.md' | |
- '!pages/en/**/*.mdx' | |
- 'i18n/locales/*.json' | |
- '!i18n/locales/en.json' | |
permissions: | |
actions: read | |
jobs: | |
comment_on_translation_pr: | |
# This comment should only be posted on PRs that come from users and not from Crowdin | |
if: | | |
github.event.pull_request.head.repo.full_name == 'nodejs/nodejs.org' && | |
github.event.pull_request.head.ref != 'chore/crowdin' | |
name: Comment on Translation PR | |
runs-on: ubuntu-latest | |
permissions: | |
# This permission is required by `thollander/actions-comment-pull-request` | |
pull-requests: write | |
steps: | |
- name: Harden Runner | |
uses: step-security/harden-runner@63c24ba6bd7ba022e95695ff85de572c04a18142 # v2.7.0 | |
with: | |
egress-policy: audit | |
- uses: thollander/actions-comment-pull-request@fabd468d3a1a0b97feee5f6b9e499eab0dd903f6 # v2.5.0 | |
with: | |
message: | | |
> [!NOTE]\ | |
> Your Pull Request seems to be updating **Translations** of the Node.js Website. | |
> | |
> Whilst we appreciate your intent; Any Translation update should be done through our [Crowdin Project](https://crowdin.com/project/nodejs-web). | |
> We recommend giving a read on our [Translation Guidelines](https://github.com/nodejs/nodejs.org/blob/main/TRANSLATION.md). | |
> | |
> Thank you! | |
comment_tag: use_crowdin | |
format_crowdin_pull_request: | |
# We should only run the automated Format Command on Crowdin-based Pull Requests | |
if: | | |
github.event.pull_request.head.repo.full_name == 'nodejs/nodejs.org' && | |
github.event.pull_request.head.ref == 'chore/crowdin' | |
name: Format Crowdin Pull Request | |
runs-on: ubuntu-latest | |
permissions: | |
# This permission is required by `stefanzweifel/git-auto-commit-action` | |
contents: write | |
steps: | |
- name: Harden Runner | |
uses: step-security/harden-runner@63c24ba6bd7ba022e95695ff85de572c04a18142 # v2.7.0 | |
with: | |
egress-policy: audit | |
- name: Git Checkout | |
uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11 # v4.1.1 | |
with: | |
# By default Git Checkout on `pull-request-target` will checkout | |
# the `default` branch of the Pull Request. We want to checkout | |
# the actual branch of the Pull Request. | |
ref: ${{ github.event.pull_request.head.ref }} | |
- name: Restore Lint Cache | |
uses: actions/cache/restore@ab5e6d0c87105b4c9c2047343972218f562e4319 # v4.0.1 | |
with: | |
path: | | |
.eslintmdcache | |
.prettiercache | |
# We want to restore Turborepo Cache and ESlint and Prettier Cache | |
# The ESLint and Prettier cache's are useful to reduce the overall runtime of ESLint and Prettier | |
# as they will only run on files that have changed since the last cached run | |
# this might of course lead to certain files not being checked against the linter, but the chances | |
# of such situation from happening are very slim as the checksums of both files would need to match | |
key: cache-lint-${{ hashFiles('package-lock.json') }}- | |
restore-keys: | | |
cache-lint-${{ hashFiles('package-lock.json') }}- | |
cache-lint- | |
- name: Set up Node.js | |
uses: actions/setup-node@60edb5dd545a775178f52524783378180af0d1f8 # v4.0.2 | |
with: | |
# We want to ensure that the Node.js version running here respects our supported versions | |
node-version-file: '.nvmrc' | |
cache: 'npm' | |
- name: Install npm packages | |
# We want to avoid npm from running the Audit Step and Funding messages on a CI environment | |
# We also use `npm i` instead of `npm ci` so that the node_modules/.cache folder doesn't get deleted | |
run: npm i --no-audit --no-fund --ignore-scripts --userconfig=/dev/null | |
- name: Run `npx lint:md --fix` | |
# This runs a specific version of ESLint with only the Translation Pages Globbing | |
# This avoid that unrelated changes get linted/modified within this PR | |
run: npx eslint "pages/**/*.md?(x)" --fix --cache --cache-strategy=metadata --cache-file=.eslintmdcache | |
- name: Run `npx prettier --write` | |
# This runs a specific version of Prettier with only the Translation Pages Globbing | |
# This avoid that unrelated changes get prettied/modified within this PR | |
run: npx prettier "{pages,i18n}/**/*.{json,md,mdx}" --check --write --cache --cache-strategy=metadata --cache-location=.prettiercache | |
- name: Push Changes back to Pull Request | |
uses: stefanzweifel/git-auto-commit-action@8756aa072ef5b4a080af5dc8fef36c5d586e521d # v5.0.0 | |
with: | |
commit_options: '--no-verify --signoff' | |
commit_message: 'chore: automated format of translated files' | |
- name: Save Lint Cache | |
uses: actions/cache/save@ab5e6d0c87105b4c9c2047343972218f562e4319 # v4.0.1 | |
with: | |
path: | | |
.eslintmdcache | |
.prettiercache | |
key: cache-lint-${{ hashFiles('package-lock.json') }}-${{ hashFiles('.eslintmdcache') }} |