From 305f3197703c8f873072890a6efcb6df5316d6f2 Mon Sep 17 00:00:00 2001 From: Davide Francescon Date: Mon, 21 Aug 2023 11:16:44 +0200 Subject: [PATCH 1/9] fix: return type of setValue in docs did not match the function typing --- docs/api/formik.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/api/formik.md b/docs/api/formik.md index 4da6b9ea2..09c0c159b 100644 --- a/docs/api/formik.md +++ b/docs/api/formik.md @@ -216,7 +216,7 @@ Set `touched` imperatively. Calling this will trigger validation to run if `vali If `validateOnBlur` is set to `true` and there are errors, they will be resolved in the returned `Promise`. -#### `setValues: (fields: React.SetStateAction<{ [field: string]: any }>, shouldValidate?: boolean) => void` +#### `setValues: (fields: React.SetStateAction<{ [field: string]: any }>, shouldValidate?: boolean) => Promise>` Set `values` imperatively. Calling this will trigger validation to run if `validateOnChange` is set to `true` (which it is by default). You can also explicitly prevent/skip validation by passing a second argument as `false`. From 07d8cc5bcdb2d6732193a5c4117fbe864dd5bb3d Mon Sep 17 00:00:00 2001 From: Sean Nessworthy Date: Wed, 6 Sep 2023 16:40:57 +0100 Subject: [PATCH 2/9] docs: Expand on cleanup behaviour for submission handlers Cover use cases for both using a submission handler that returns a promise, and for a one which does not. Add FAQ entry about submission handler cleanup. --- docs/guides/form-submission.md | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/docs/guides/form-submission.md b/docs/guides/form-submission.md index 6c0ea4e2a..9762e11fb 100644 --- a/docs/guides/form-submission.md +++ b/docs/guides/form-submission.md @@ -23,8 +23,10 @@ To submit a form in Formik, you need to somehow fire off the provided `handleSub ### Submission -- Proceed with running your submission handler (i.e.`onSubmit` or `handleSubmit`) -- _you call `setSubmitting(false)`_ in your handler to finish the cycle +- Proceed with running your submission handler (i.e. `onSubmit` or `handleSubmit`) +- Did the submit handler return a promise? + - Yes: Wait until it is resolved or rejected, then set `setSubmitting` to `false` + - No: _You call `setSubmitting(false)`_ in your handler to finish the cycle ## Frequently Asked Questions @@ -55,3 +57,8 @@ Disable whatever is triggering submission if `isSubmitting` is `true`. If `isValidating` is `true` and `isSubmitting` is `true`. +Why does `isSubmitting` remain `true` after submission? +
+ If the submission handler is returning a promise, make sure the promise has resolved or rejected. + If the submission handler is not returning a promise, make sure `setSubmitting(false)` is called at the end of the handler. +
From b3190f25268d0496b2448db6f2cc02599f8914f2 Mon Sep 17 00:00:00 2001 From: Sean Nessworthy Date: Wed, 6 Sep 2023 16:48:00 +0100 Subject: [PATCH 3/9] docs: Adjust language for submission cleanup --- docs/guides/form-submission.md | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/guides/form-submission.md b/docs/guides/form-submission.md index 9762e11fb..6032840f4 100644 --- a/docs/guides/form-submission.md +++ b/docs/guides/form-submission.md @@ -59,6 +59,6 @@ If `isValidating` is `true` and `isSubmitting` is `true`. Why does `isSubmitting` remain `true` after submission?
- If the submission handler is returning a promise, make sure the promise has resolved or rejected. - If the submission handler is not returning a promise, make sure `setSubmitting(false)` is called at the end of the handler. + If the submission handler returns a promise, make sure it is correctly resolved or rejected when called. + If the submission handler does not return a promise, make sure `setSubmitting(false)` is called at the end of the handler.
From 868b8f09945f98ce36e00a54ee875aee0d4d747b Mon Sep 17 00:00:00 2001 From: Sean Nessworthy Date: Wed, 6 Sep 2023 16:50:07 +0100 Subject: [PATCH 4/9] docs: Fix `isSubmitting` FAQ entry Wrap FAQ entry in `details correctly. Remove use of inline code markers in `summary` as it seems like they are not supported. --- docs/guides/form-submission.md | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/docs/guides/form-submission.md b/docs/guides/form-submission.md index 6032840f4..a7520195e 100644 --- a/docs/guides/form-submission.md +++ b/docs/guides/form-submission.md @@ -57,8 +57,9 @@ Disable whatever is triggering submission if `isSubmitting` is `true`. If `isValidating` is `true` and `isSubmitting` is `true`. -Why does `isSubmitting` remain `true` after submission? +
+Why does isSubmitting remain true after submission? If the submission handler returns a promise, make sure it is correctly resolved or rejected when called. If the submission handler does not return a promise, make sure `setSubmitting(false)` is called at the end of the handler.
From a235013585ffb6a49863f2b6195b669da4a0f3a9 Mon Sep 17 00:00:00 2001 From: Sean Nessworthy Date: Wed, 6 Sep 2023 16:52:13 +0100 Subject: [PATCH 5/9] docs: Fix incorrect submission FAQ formatting Add spacing between lines to support proper inline code formatting. --- docs/guides/form-submission.md | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/docs/guides/form-submission.md b/docs/guides/form-submission.md index a7520195e..de84edfc0 100644 --- a/docs/guides/form-submission.md +++ b/docs/guides/form-submission.md @@ -60,6 +60,9 @@ If `isValidating` is `true` and `isSubmitting` is `true`.
Why does isSubmitting remain true after submission? - If the submission handler returns a promise, make sure it is correctly resolved or rejected when called. - If the submission handler does not return a promise, make sure `setSubmitting(false)` is called at the end of the handler. + +If the submission handler returns a promise, make sure it is correctly resolved or rejected when called. + +If the submission handler does not return a promise, make sure `setSubmitting(false)` is called at the end of the handler. +
From 09f68a77366e761304abdca787622ba3a1bc5a01 Mon Sep 17 00:00:00 2001 From: Evan Jacobs <570070+probablyup@users.noreply.github.com> Date: Fri, 8 Sep 2023 09:53:49 -0400 Subject: [PATCH 6/9] chore: more impersonal language --- docs/guides/form-submission.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/docs/guides/form-submission.md b/docs/guides/form-submission.md index de84edfc0..fe359488b 100644 --- a/docs/guides/form-submission.md +++ b/docs/guides/form-submission.md @@ -23,10 +23,10 @@ To submit a form in Formik, you need to somehow fire off the provided `handleSub ### Submission -- Proceed with running your submission handler (i.e. `onSubmit` or `handleSubmit`) +- Proceed with running the submission handler (i.e. `onSubmit` or `handleSubmit`) - Did the submit handler return a promise? - Yes: Wait until it is resolved or rejected, then set `setSubmitting` to `false` - - No: _You call `setSubmitting(false)`_ in your handler to finish the cycle + - No: _Call `setSubmitting(false)`_ to finish the cycle ## Frequently Asked Questions @@ -59,7 +59,7 @@ If `isValidating` is `true` and `isSubmitting` is `true`.
-Why does isSubmitting remain true after submission? +Why does `isSubmitting` remain true after submission? If the submission handler returns a promise, make sure it is correctly resolved or rejected when called. From aa1cf43fccbccec1467a6eeca85d37b398c99ec2 Mon Sep 17 00:00:00 2001 From: Fuad Herac Date: Mon, 11 Sep 2023 16:17:55 +0200 Subject: [PATCH 7/9] #2594: Remove the duplicate word from the blog post (#3703) - Link to the issue: [#2594](https://github.com/jaredpalmer/formik/issues/2594) - Screenshot: Screenshot 2022-12-20 at 19 02 15 --- website/src/blog/new-docs.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/website/src/blog/new-docs.md b/website/src/blog/new-docs.md index 9d0be2303..6a2aa8d41 100644 --- a/website/src/blog/new-docs.md +++ b/website/src/blog/new-docs.md @@ -117,7 +117,7 @@ I accidentally discovered the new version of docsearch.js while working on the d ![/images/blog/algolia-docsearch-screenshot.png](/images/blog/algolia-docsearch-screenshot.png) -Overall, I'm pretty happy with the new docs site. For the first time in a while, I'm excited to write docs again. There's still a decent amount of features still missing, but I'm very happy with the end-user experience and the developer experience that this stack provides. Next.js gives us a great foundation for building more app-like features into the docs site. The first of these will be a brand new interactive tutorial as well as a new searchable example and boilerplate directory. As always, if you're if you're interested helping out or diving deeper, the [full source code of the new docs is available on GitHub](https://github.com/formik/formik). +Overall, I'm pretty happy with the new docs site. For the first time in a while, I'm excited to write docs again. There's still a decent amount of features still missing, but I'm very happy with the end-user experience and the developer experience that this stack provides. Next.js gives us a great foundation for building more app-like features into the docs site. The first of these will be a brand new interactive tutorial as well as a new searchable example and boilerplate directory. As always, if you're interested helping out or diving deeper, the [full source code of the new docs is available on GitHub](https://github.com/formik/formik). So with that, go poke around, but be gentle. If you find any bugs, [file an issue.](https://github.com/formik/formik/issues/new?template=Bug_report.md) With this new Notion-powered blog, I'll be posting a lot more often, so enter your email and slap that subscribe button in the footer to join the Formik mailing list. From fe4ed7e048b14331a75e40cabf48e4787d9b2b71 Mon Sep 17 00:00:00 2001 From: Marks Polakovs Date: Mon, 11 Sep 2023 15:21:37 +0100 Subject: [PATCH 8/9] Mark `formik` as side-effect free (#3501) This will allow Formik's code to be removed by tree-shaking bundlers like Webpack or esbuild. --- .changeset/wise-games-battle.md | 5 +++++ packages/formik/package.json | 1 + 2 files changed, 6 insertions(+) create mode 100644 .changeset/wise-games-battle.md diff --git a/.changeset/wise-games-battle.md b/.changeset/wise-games-battle.md new file mode 100644 index 000000000..14e2abe54 --- /dev/null +++ b/.changeset/wise-games-battle.md @@ -0,0 +1,5 @@ +--- +"formik": patch +--- + +Mark `formik` as side-effect free in `package.json` diff --git a/packages/formik/package.json b/packages/formik/package.json index d991b48ca..37c47935d 100644 --- a/packages/formik/package.json +++ b/packages/formik/package.json @@ -37,6 +37,7 @@ "peerDependencies": { "react": ">=16.8.0" }, + "sideEffects": false, "scripts": { "test": "tsdx test --env=jsdom", "test:watch": "npm run test -- --watchAll", From 5edbd856a13b3a61449b13d4e453c15bd543a177 Mon Sep 17 00:00:00 2001 From: Evan Jacobs <570070+probablyup@users.noreply.github.com> Date: Thu, 14 Sep 2023 12:36:23 -0400 Subject: [PATCH 9/9] chore: skip actions if source files have not changed (#3880) * chore: skip benchmark action if source files have not changed * chore: test alternate strategy * chore: standardize around nvmrc file * chore: try shared setup * chore: watch for relevant changes * chore: consolidate workflows * chore: normalize names --------- Co-authored-by: kodiakhq[bot] <49736102+kodiakhq[bot]@users.noreply.github.com> --- .github/workflows/benchmark.yml | 60 ------------ .github/workflows/ci.yml | 152 +++++++++++++++++++++++++++++++ .github/workflows/playwright.yml | 45 --------- .github/workflows/release.yml | 2 +- .github/workflows/size.yml | 16 ---- .github/workflows/test.yml | 37 -------- .nvmrc | 1 + 7 files changed, 154 insertions(+), 159 deletions(-) delete mode 100644 .github/workflows/benchmark.yml create mode 100644 .github/workflows/ci.yml delete mode 100644 .github/workflows/playwright.yml delete mode 100644 .github/workflows/size.yml delete mode 100644 .github/workflows/test.yml create mode 100644 .nvmrc diff --git a/.github/workflows/benchmark.yml b/.github/workflows/benchmark.yml deleted file mode 100644 index 0d3976027..000000000 --- a/.github/workflows/benchmark.yml +++ /dev/null @@ -1,60 +0,0 @@ -name: Performance - -on: - pull_request: - push: - branches: [main] - -jobs: - benchmark: - runs-on: ubuntu-latest - - strategy: - fail-fast: false - matrix: - node: ['18.x'] - - name: Test on node ${{ matrix.node }} - - steps: - - uses: actions/checkout@v3 - - - name: Use Node.js ${{ matrix.node }} - uses: actions/setup-node@v3 - with: - cache: yarn - node-version: ${{ matrix.node }} - - - name: Install & build - run: | - node --version - npm --version - yarn --version - yarn install --frozen-lockfile - yarn build:benchmark - - - name: Download previous benchmark data - uses: actions/cache@v3 - with: - path: ./benchmark-cache - key: ${{ runner.os }}-benchmark - - - name: Run benchmark - run: yarn benchmark - - - name: Store benchmark result - uses: benchmark-action/github-action-benchmark@v1 - with: - tool: benchmarkjs - external-data-json-path: ./benchmark-cache/benchmark-data.json - output-file-path: output.txt - # comment for PRs that's updated with current perf relative to baseline (main) - summary-always: true - # warn if slowness is detected; might be transient on rerun - alert-threshold: 110% - comment-on-alert: true - fail-on-alert: true - # if things get considerably slower, deny the PR - fail-threshold: 120% - # needed for commenting on PRs - github-token: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml new file mode 100644 index 000000000..9a36bf0fb --- /dev/null +++ b/.github/workflows/ci.yml @@ -0,0 +1,152 @@ +name: ci + +on: + pull_request: + push: + branches: [main] + +jobs: + detectChangedSourceFiles: + name: 'determine changes' + runs-on: ubuntu-latest + outputs: + changes: ${{ steps.changed-files-yaml.outputs.src_any_changed }} + steps: + - uses: actions/checkout@v3 + - name: Detect changed files + id: changed-files-yaml + uses: tj-actions/changed-files@v39 + with: + files_yaml: | + src: + - packages/formik/src/** + - packages/formik/package.json + - packages/formik-native/src/** + - packages/formik-native/package.json + benchmark: + if: needs.detectChangedSourceFiles.outputs.changes == 'true' + runs-on: ubuntu-latest + strategy: + fail-fast: false + steps: + - uses: actions/checkout@v3 + + - uses: actions/setup-node@v3 + with: + cache: yarn + node-version-file: .nvmrc + + - name: Detect changed files + id: changed-files-yaml + uses: tj-actions/changed-files@v39 + with: + files_yaml: | + src: + - packages/formik/src/** + - packages/formik-native/src/** + + - name: Install & build + run: | + node --version + npm --version + yarn --version + yarn install --frozen-lockfile + yarn build:benchmark + + - name: Download previous benchmark data + uses: actions/cache@v3 + with: + path: ./benchmark-cache + key: ${{ runner.os }}-benchmark + + - name: Run benchmark + run: yarn benchmark + + - name: Store benchmark result + uses: benchmark-action/github-action-benchmark@v1 + with: + tool: benchmarkjs + external-data-json-path: ./benchmark-cache/benchmark-data.json + output-file-path: output.txt + # comment for PRs that's updated with current perf relative to baseline (main) + summary-always: true + # warn if slowness is detected; might be transient on rerun + alert-threshold: 110% + comment-on-alert: true + fail-on-alert: true + # if things get considerably slower, deny the PR + fail-threshold: 120% + # needed for commenting on PRs + github-token: ${{ secrets.GITHUB_TOKEN }} + interaction: + if: needs.detectChangedSourceFiles.outputs.changes == 'true' + timeout-minutes: 10 + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + - uses: actions/setup-node@v3 + with: + cache: yarn + node-version-file: .nvmrc + + - name: Install dependencies + run: yarn install --frozen-lockfile + + - name: Get installed Playwright version + id: playwright-version + run: echo "PLAYWRIGHT_VERSION=$(node -e "console.log(require('./package-lock.json').dependencies['@playwright/test'].version)")" >> $GITHUB_ENV + + - name: Cache playwright binaries + uses: actions/cache@v3 + id: playwright-cache + with: + path: | + ~/.cache/ms-playwright + key: ${{ runner.os }}-playwright-${{ env.PLAYWRIGHT_VERSION }} + + - name: Install Playwright Browsers + run: yarn playwright install --with-deps + if: steps.playwright-cache.outputs.cache-hit != 'true' + - run: yarn playwright install-deps + if: steps.playwright-cache.outputs.cache-hit != 'true' + + - name: Run Playwright tests + run: yarn playwright test + - uses: actions/upload-artifact@v3 + if: always() + with: + name: playwright-report + path: playwright-report/ + retention-days: 5 + size: + if: needs.detectChangedSourceFiles.outputs.changes == 'true' + runs-on: ubuntu-latest + steps: + - uses: actions/checkout@v3 + with: + fetch-depth: 1 + - uses: preactjs/compressed-size-action@v2 + with: + repo-token: '${{ secrets.GITHUB_TOKEN }}' + build-script: 'turbo run build --filter {./packages/*}...' + unit: + if: needs.detectChangedSourceFiles.outputs.changes == 'true' + runs-on: ubuntu-latest + strategy: + fail-fast: false + steps: + - uses: actions/checkout@v3 + - uses: actions/setup-node@v3 + with: + cache: yarn + node-version-file: .nvmrc + - name: Install deps, build, and test + run: | + node --version + npm --version + yarn --version + yarn install --frozen-lockfile + yarn test --coverage + env: + CI: true + NODE_OPTIONS: --max-old-space-size=4096 \ No newline at end of file diff --git a/.github/workflows/playwright.yml b/.github/workflows/playwright.yml deleted file mode 100644 index a720fa902..000000000 --- a/.github/workflows/playwright.yml +++ /dev/null @@ -1,45 +0,0 @@ -name: Playwright Tests -on: - push: - branches: [main] - pull_request: -jobs: - test: - timeout-minutes: 10 - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - uses: actions/setup-node@v3 - with: - cache: yarn - node-version: 18 - - - name: Install dependencies - run: yarn install --frozen-lockfile - - - name: Get installed Playwright version - id: playwright-version - run: echo "PLAYWRIGHT_VERSION=$(node -e "console.log(require('./package-lock.json').dependencies['@playwright/test'].version)")" >> $GITHUB_ENV - - - name: Cache playwright binaries - uses: actions/cache@v3 - id: playwright-cache - with: - path: | - ~/.cache/ms-playwright - key: ${{ runner.os }}-playwright-${{ env.PLAYWRIGHT_VERSION }} - - - name: Install Playwright Browsers - run: yarn playwright install --with-deps - if: steps.playwright-cache.outputs.cache-hit != 'true' - - run: yarn playwright install-deps - if: steps.playwright-cache.outputs.cache-hit != 'true' - - - name: Run Playwright tests - run: yarn playwright test - - uses: actions/upload-artifact@v3 - if: always() - with: - name: playwright-report - path: playwright-report/ - retention-days: 5 diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 3770d5738..83f605fa1 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -16,7 +16,7 @@ jobs: - uses: actions/setup-node@v3 with: cache: yarn - node-version: 18 + node-version-file: .nvmrc - name: Install Dependencies run: yarn install diff --git a/.github/workflows/size.yml b/.github/workflows/size.yml deleted file mode 100644 index 7c515450a..000000000 --- a/.github/workflows/size.yml +++ /dev/null @@ -1,16 +0,0 @@ -name: Compressed Size - -on: [pull_request] - -jobs: - build: - runs-on: ubuntu-latest - - steps: - - uses: actions/checkout@v3 - with: - fetch-depth: 1 - - uses: preactjs/compressed-size-action@v2 - with: - repo-token: '${{ secrets.GITHUB_TOKEN }}' - build-script: 'turbo run build --filter {./packages/*}...' diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml deleted file mode 100644 index 7d06aaaa0..000000000 --- a/.github/workflows/test.yml +++ /dev/null @@ -1,37 +0,0 @@ -name: Unit Test - -on: - pull_request: - push: - branches: [main] - -jobs: - test: - runs-on: ubuntu-latest - - strategy: - fail-fast: false - matrix: - node: ['18.x'] - - name: Test on node ${{ matrix.node }} - - steps: - - uses: actions/checkout@v3 - - - name: Use Node.js ${{ matrix.node }} - uses: actions/setup-node@v3 - with: - cache: yarn - node-version: ${{ matrix.node }} - - - name: Install deps, build, and test - run: | - node --version - npm --version - yarn --version - yarn install --frozen-lockfile - yarn test --coverage - env: - CI: true - NODE_OPTIONS: --max-old-space-size=4096 diff --git a/.nvmrc b/.nvmrc new file mode 100644 index 000000000..3f430af82 --- /dev/null +++ b/.nvmrc @@ -0,0 +1 @@ +v18