diff --git a/.distignore b/.distignore index 98a1c1aafa95..99e10329d4bb 100644 --- a/.distignore +++ b/.distignore @@ -76,7 +76,6 @@ phpunit-integration-multisite.xml.dist README.md rollup.config.js scoper.inc.php -SECURITY.md tsconfig.json tsconfig.shared.json webpack.config.cjs diff --git a/.eslintrc b/.eslintrc index feed133814ff..657a0ef25401 100644 --- a/.eslintrc +++ b/.eslintrc @@ -343,11 +343,8 @@ ], "parser": "@typescript-eslint/parser", "parserOptions": { - "EXPERIMENTAL_useProjectService": true, - "warnOnUnsupportedTypeScriptVersion": false, - "project": [ - ".tsconfig.json" - ] + "projectService": true, + "warnOnUnsupportedTypeScriptVersion": false }, "rules": { "@typescript-eslint/no-shadow": ["error", diff --git a/.github/workflows/build-and-deploy.yml b/.github/workflows/build-and-deploy.yml index ca774904c7e4..b916b383576a 100644 --- a/.github/workflows/build-and-deploy.yml +++ b/.github/workflows/build-and-deploy.yml @@ -83,7 +83,7 @@ jobs: github.event.pull_request.user.login != 'dependabot[bot]' steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-file-monitoring: true egress-policy: block @@ -129,7 +129,7 @@ jobs: github.event.pull_request.user.login != 'dependabot[bot]' steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs diff --git a/.github/workflows/cleanup-pr-assets.yml b/.github/workflows/cleanup-pr-assets.yml index a66162865cd4..cc5316d5bb3f 100644 --- a/.github/workflows/cleanup-pr-assets.yml +++ b/.github/workflows/cleanup-pr-assets.yml @@ -21,7 +21,7 @@ jobs: github.event.pull_request.user.login != 'dependabot[bot]' steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-file-monitoring: true disable-sudo: true diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index 1eff8fa5d49f..bd458b889123 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -44,9 +44,9 @@ jobs: uses: actions/checkout@11bd71901bbe5b1630ceea73d27597364c9af683 - name: Initialize CodeQL - uses: github/codeql-action/init@662472033e021d55d94146f66f6058822b0b39fd + uses: github/codeql-action/init@f09c1c0a94de965c15400f5634aa42fac8fb8f88 with: languages: javascript - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@662472033e021d55d94146f66f6058822b0b39fd + uses: github/codeql-action/analyze@f09c1c0a94de965c15400f5634aa42fac8fb8f88 diff --git a/.github/workflows/lint-css-js-md.yml b/.github/workflows/lint-css-js-md.yml index 68e009907655..4661b5f36cf3 100644 --- a/.github/workflows/lint-css-js-md.yml +++ b/.github/workflows/lint-css-js-md.yml @@ -61,7 +61,7 @@ jobs: timeout-minutes: 20 steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-sudo: true disable-file-monitoring: true diff --git a/.github/workflows/lint-i18n.yml b/.github/workflows/lint-i18n.yml index 656439eab021..4190ab748b53 100644 --- a/.github/workflows/lint-i18n.yml +++ b/.github/workflows/lint-i18n.yml @@ -42,7 +42,7 @@ jobs: timeout-minutes: 10 steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs @@ -57,7 +57,7 @@ jobs: tools: wp-cli - name: Install latest version of i18n-command - run: wp package install wp-cli/i18n-command:dev-main + run: wp package install wp-cli/i18n-command:@stable - name: Setup Node uses: actions/setup-node@39370e3970a6d050c480ffad4ff0ed4d3fdee5af diff --git a/.github/workflows/lint-php.yml b/.github/workflows/lint-php.yml index e3b9a9f0f36b..63a4edf409e7 100644 --- a/.github/workflows/lint-php.yml +++ b/.github/workflows/lint-php.yml @@ -41,7 +41,7 @@ jobs: timeout-minutes: 5 steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-file-monitoring: true egress-policy: block diff --git a/.github/workflows/lint-plugin-check.yml b/.github/workflows/lint-plugin-check.yml index 9c9e2ef9fd4d..4bc8532a4b6f 100644 --- a/.github/workflows/lint-plugin-check.yml +++ b/.github/workflows/lint-plugin-check.yml @@ -42,7 +42,7 @@ jobs: timeout-minutes: 10 steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs diff --git a/.github/workflows/npm-release.yml b/.github/workflows/npm-release.yml index 493d3e9fc853..7cea28fdc619 100644 --- a/.github/workflows/npm-release.yml +++ b/.github/workflows/npm-release.yml @@ -102,7 +102,7 @@ jobs: needs: [dry-run] steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs diff --git a/.github/workflows/plugin-release.yml b/.github/workflows/plugin-release.yml index 780d85f03047..5c2582ab0cce 100644 --- a/.github/workflows/plugin-release.yml +++ b/.github/workflows/plugin-release.yml @@ -41,7 +41,7 @@ jobs: environment: Production steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs @@ -104,7 +104,7 @@ jobs: needs: [checks] steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs @@ -245,7 +245,7 @@ jobs: release_name: ${{ steps.release_branch.outputs.release_name }} steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs @@ -408,7 +408,7 @@ jobs: needs: [build] steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs @@ -423,7 +423,7 @@ jobs: - name: Publish Release id: create_release - uses: softprops/action-gh-release@e7a8f85e1c67a31e6ed99a94b41bd0b71bbee6b8 + uses: softprops/action-gh-release@01570a1f39cb168c169c802c3bceb9e93fb10974 with: tag_name: ${{ env.TAG_NAME }} name: ${{ env.release_name }} @@ -444,7 +444,7 @@ jobs: if: ${{ ! startsWith(github.ref, 'refs/heads/release/') && ! contains(github.event.inputs.version, 'rc') }} steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs @@ -500,7 +500,7 @@ jobs: SVN_PASSWORD: ${{ secrets.SVN_PASSWORD }} steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs diff --git a/.github/workflows/scorecards.yml b/.github/workflows/scorecards.yml index 4ebfd97f1b00..4538a3e329d1 100644 --- a/.github/workflows/scorecards.yml +++ b/.github/workflows/scorecards.yml @@ -25,7 +25,7 @@ jobs: steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs @@ -56,6 +56,6 @@ jobs: # Upload the results to GitHub's code scanning dashboard. - name: 'Upload to code-scanning' - uses: github/codeql-action/upload-sarif@662472033e021d55d94146f66f6058822b0b39fd + uses: github/codeql-action/upload-sarif@f09c1c0a94de965c15400f5634aa42fac8fb8f88 with: sarif_file: results.sarif diff --git a/.github/workflows/tests-e2e.yml b/.github/workflows/tests-e2e.yml index 72c3357df73a..9e68f815b572 100644 --- a/.github/workflows/tests-e2e.yml +++ b/.github/workflows/tests-e2e.yml @@ -70,7 +70,7 @@ jobs: timeout-minutes: 30 steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs @@ -149,7 +149,7 @@ jobs: steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-file-monitoring: true egress-policy: audit diff --git a/.github/workflows/tests-karma-dashboard.yml b/.github/workflows/tests-karma-dashboard.yml index b3911a46b138..fc46f8f23baa 100644 --- a/.github/workflows/tests-karma-dashboard.yml +++ b/.github/workflows/tests-karma-dashboard.yml @@ -47,7 +47,7 @@ jobs: timeout-minutes: 30 steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-file-monitoring: true egress-policy: block @@ -97,7 +97,7 @@ jobs: DISABLE_ERROR_BOUNDARIES: true - name: Upload code coverage report - uses: codecov/codecov-action@b9fd7d16f6d7d1b5d2bec1a2887e65ceed900238 + uses: codecov/codecov-action@015f24e6818733317a2da2edd6290ab26238649a with: file: build/logs/karma-coverage/dashboard/lcov.info flags: karmatests diff --git a/.github/workflows/tests-karma-editor.yml b/.github/workflows/tests-karma-editor.yml index 4804bd8fdb84..0817fa0ecf2e 100644 --- a/.github/workflows/tests-karma-editor.yml +++ b/.github/workflows/tests-karma-editor.yml @@ -83,7 +83,7 @@ jobs: ] steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-file-monitoring: true egress-policy: block @@ -138,7 +138,7 @@ jobs: SHARD: ${{ matrix.shard }} - name: Upload code coverage report - uses: codecov/codecov-action@b9fd7d16f6d7d1b5d2bec1a2887e65ceed900238 + uses: codecov/codecov-action@015f24e6818733317a2da2edd6290ab26238649a with: file: build/logs/karma-coverage/story-editor/lcov.info flags: karmatests diff --git a/.github/workflows/tests-unit-js.yml b/.github/workflows/tests-unit-js.yml index 7175f467c197..474e9adde32e 100644 --- a/.github/workflows/tests-unit-js.yml +++ b/.github/workflows/tests-unit-js.yml @@ -51,7 +51,7 @@ jobs: shard: ['1/2', '2/2'] steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-sudo: true disable-file-monitoring: true @@ -103,7 +103,7 @@ jobs: AMP_VALIDATOR_FILE: ${{ env.validator_file }} - name: Upload code coverage report - uses: codecov/codecov-action@b9fd7d16f6d7d1b5d2bec1a2887e65ceed900238 + uses: codecov/codecov-action@015f24e6818733317a2da2edd6290ab26238649a with: file: build/logs/lcov.info flags: unittests diff --git a/.github/workflows/tests-unit-php.yml b/.github/workflows/tests-unit-php.yml index bb17f5ccabbc..ea4313ce6fc7 100644 --- a/.github/workflows/tests-unit-php.yml +++ b/.github/workflows/tests-unit-php.yml @@ -80,7 +80,7 @@ jobs: steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: disable-file-monitoring: true egress-policy: audit @@ -178,7 +178,7 @@ jobs: if: ${{ matrix.random }} - name: Upload code coverage report - uses: codecov/codecov-action@b9fd7d16f6d7d1b5d2bec1a2887e65ceed900238 + uses: codecov/codecov-action@015f24e6818733317a2da2edd6290ab26238649a with: file: build/logs/*.xml token: ${{ secrets.CODECOV_TOKEN }} diff --git a/.github/workflows/update-browserslist.yml b/.github/workflows/update-browserslist.yml index 1071c4f92e85..6c6e8de66714 100644 --- a/.github/workflows/update-browserslist.yml +++ b/.github/workflows/update-browserslist.yml @@ -22,7 +22,7 @@ jobs: steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs diff --git a/.github/workflows/update-google-fonts.yml b/.github/workflows/update-google-fonts.yml index a5667c7fa1b9..1acf6e99ca6c 100644 --- a/.github/workflows/update-google-fonts.yml +++ b/.github/workflows/update-google-fonts.yml @@ -22,7 +22,7 @@ jobs: steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs diff --git a/.github/workflows/update-product-schema.yml b/.github/workflows/update-product-schema.yml index 27d1117a3653..983b29d83508 100644 --- a/.github/workflows/update-product-schema.yml +++ b/.github/workflows/update-product-schema.yml @@ -22,7 +22,7 @@ jobs: steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs diff --git a/.github/workflows/update-templates.yml b/.github/workflows/update-templates.yml index 4376d643aaa5..32128a656f94 100644 --- a/.github/workflows/update-templates.yml +++ b/.github/workflows/update-templates.yml @@ -22,7 +22,7 @@ jobs: steps: - name: Harden Runner - uses: step-security/harden-runner@91182cccc01eb5e619899d80e4e971d6181294a7 + uses: step-security/harden-runner@0080882f6c36860b6ba35c610c98ce87d4e2f26f with: egress-policy: audit # TODO: change to 'egress-policy: block' after couple of runs diff --git a/.nvmrc b/.nvmrc index 209e3ef4b624..2bd5a0a98a36 100644 --- a/.nvmrc +++ b/.nvmrc @@ -1 +1 @@ -20 +22 diff --git a/babel.config.cjs b/babel.config.cjs index 29099dd32c83..c1deb5e8f40d 100644 --- a/babel.config.cjs +++ b/babel.config.cjs @@ -32,7 +32,7 @@ module.exports = function (api) { shippedProposals: true, targets, useBuiltIns: 'usage', - corejs: '3.35.1', + corejs: '3.39.0', }, ], [ diff --git a/composer.json b/composer.json index 0d621b4862a2..f348d1fd0e0f 100644 --- a/composer.json +++ b/composer.json @@ -27,14 +27,14 @@ "phpcompatibility/phpcompatibility-wp": "^2.1", "phpmd/phpmd": "^2.9", "phpstan/extension-installer": "^1.1", - "phpstan/phpstan-deprecation-rules": "^1.1", - "phpstan/phpstan-phpunit": "^1.2", + "phpstan/phpstan-deprecation-rules": "^2.0.1", + "phpstan/phpstan-phpunit": "^2.0.1", "roave/security-advisories": "dev-latest", "sirbrillig/phpcs-variable-analysis": "^2.8", "slevomat/coding-standard": "^8.0.0", "sniccowp/php-scoper-wordpress-excludes": "^6.0", - "swissspidy/phpstan-no-private": "^0.2.0", - "szepeviktor/phpstan-wordpress": "^1.1.3", + "swissspidy/phpstan-no-private": "^1.0.0", + "szepeviktor/phpstan-wordpress": "^2.0.0", "wp-coding-standards/wpcs": "^3.0.0", "yoast/wp-test-utils": "^1.0.0" }, diff --git a/composer.lock b/composer.lock index c354437d2e78..4e937b7ddf2c 100644 --- a/composer.lock +++ b/composer.lock @@ -4,7 +4,7 @@ "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#installing-dependencies", "This file is @generated automatically" ], - "content-hash": "ee23bdcfe0de62daa1254fab27c92be2", + "content-hash": "b40d5f35eea45b1280af53fe80661e4c", "packages": [ { "name": "ampproject/amp-toolbox", @@ -3018,20 +3018,20 @@ }, { "name": "phpstan/phpstan", - "version": "1.12.11", + "version": "2.0.3", "source": { "type": "git", "url": "https://github.com/phpstan/phpstan.git", - "reference": "0d1fc20a962a91be578bcfe7cf939e6e1a2ff733" + "reference": "46b4d3529b12178112d9008337beda0cc2a1a6b4" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpstan/phpstan/zipball/0d1fc20a962a91be578bcfe7cf939e6e1a2ff733", - "reference": "0d1fc20a962a91be578bcfe7cf939e6e1a2ff733", + "url": "https://api.github.com/repos/phpstan/phpstan/zipball/46b4d3529b12178112d9008337beda0cc2a1a6b4", + "reference": "46b4d3529b12178112d9008337beda0cc2a1a6b4", "shasum": "" }, "require": { - "php": "^7.2|^8.0" + "php": "^7.4|^8.0" }, "conflict": { "phpstan/phpstan-shim": "*" @@ -3072,30 +3072,30 @@ "type": "github" } ], - "time": "2024-11-17T14:08:01+00:00" + "time": "2024-11-28T22:19:37+00:00" }, { "name": "phpstan/phpstan-deprecation-rules", - "version": "1.2.1", + "version": "2.0.1", "source": { "type": "git", "url": "https://github.com/phpstan/phpstan-deprecation-rules.git", - "reference": "f94d246cc143ec5a23da868f8f7e1393b50eaa82" + "reference": "1cc1259cb91ee4cfbb5c39bca9f635f067c910b4" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpstan/phpstan-deprecation-rules/zipball/f94d246cc143ec5a23da868f8f7e1393b50eaa82", - "reference": "f94d246cc143ec5a23da868f8f7e1393b50eaa82", + "url": "https://api.github.com/repos/phpstan/phpstan-deprecation-rules/zipball/1cc1259cb91ee4cfbb5c39bca9f635f067c910b4", + "reference": "1cc1259cb91ee4cfbb5c39bca9f635f067c910b4", "shasum": "" }, "require": { - "php": "^7.2 || ^8.0", - "phpstan/phpstan": "^1.12" + "php": "^7.4 || ^8.0", + "phpstan/phpstan": "^2.0" }, "require-dev": { "php-parallel-lint/php-parallel-lint": "^1.2", - "phpstan/phpstan-phpunit": "^1.0", - "phpunit/phpunit": "^9.5" + "phpstan/phpstan-phpunit": "^2.0", + "phpunit/phpunit": "^9.6" }, "type": "phpstan-extension", "extra": { @@ -3117,36 +3117,35 @@ "description": "PHPStan rules for detecting usage of deprecated classes, methods, properties, constants and traits.", "support": { "issues": "https://github.com/phpstan/phpstan-deprecation-rules/issues", - "source": "https://github.com/phpstan/phpstan-deprecation-rules/tree/1.2.1" + "source": "https://github.com/phpstan/phpstan-deprecation-rules/tree/2.0.1" }, - "time": "2024-09-11T15:52:35+00:00" + "time": "2024-11-28T21:56:36+00:00" }, { "name": "phpstan/phpstan-phpunit", - "version": "1.4.1", + "version": "2.0.1", "source": { "type": "git", "url": "https://github.com/phpstan/phpstan-phpunit.git", - "reference": "11d4235fbc6313ecbf93708606edfd3222e44949" + "reference": "4b6ad7fab8683ff4efd7887ba26ef8ee171c7475" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/phpstan/phpstan-phpunit/zipball/11d4235fbc6313ecbf93708606edfd3222e44949", - "reference": "11d4235fbc6313ecbf93708606edfd3222e44949", + "url": "https://api.github.com/repos/phpstan/phpstan-phpunit/zipball/4b6ad7fab8683ff4efd7887ba26ef8ee171c7475", + "reference": "4b6ad7fab8683ff4efd7887ba26ef8ee171c7475", "shasum": "" }, "require": { - "php": "^7.2 || ^8.0", - "phpstan/phpstan": "^1.12" + "php": "^7.4 || ^8.0", + "phpstan/phpstan": "^2.0" }, "conflict": { "phpunit/phpunit": "<7.0" }, "require-dev": { - "nikic/php-parser": "^4.13.0", "php-parallel-lint/php-parallel-lint": "^1.2", - "phpstan/phpstan-strict-rules": "^1.5.1", - "phpunit/phpunit": "^9.5" + "phpstan/phpstan-strict-rules": "^2.0", + "phpunit/phpunit": "^9.6" }, "type": "phpstan-extension", "extra": { @@ -3169,9 +3168,9 @@ "description": "PHPUnit extensions and rules for PHPStan", "support": { "issues": "https://github.com/phpstan/phpstan-phpunit/issues", - "source": "https://github.com/phpstan/phpstan-phpunit/tree/1.4.1" + "source": "https://github.com/phpstan/phpstan-phpunit/tree/2.0.1" }, - "time": "2024-11-12T12:43:59+00:00" + "time": "2024-11-12T12:48:00+00:00" }, { "name": "phpunit/php-code-coverage", @@ -3749,12 +3748,12 @@ "source": { "type": "git", "url": "https://github.com/Roave/SecurityAdvisories.git", - "reference": "b33a18b5d222c63472a4b41f6fa3e15e591c9595" + "reference": "fff26f7a91a7458bf6eea5afdd71b4aba1f1d3ea" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/Roave/SecurityAdvisories/zipball/b33a18b5d222c63472a4b41f6fa3e15e591c9595", - "reference": "b33a18b5d222c63472a4b41f6fa3e15e591c9595", + "url": "https://api.github.com/repos/Roave/SecurityAdvisories/zipball/fff26f7a91a7458bf6eea5afdd71b4aba1f1d3ea", + "reference": "fff26f7a91a7458bf6eea5afdd71b4aba1f1d3ea", "shasum": "" }, "conflict": { @@ -4335,6 +4334,7 @@ "socialiteproviders/steam": "<1.1", "spatie/browsershot": "<3.57.4", "spatie/image-optimizer": "<1.7.3", + "spencer14420/sp-php-email-handler": "<1", "spipu/html2pdf": "<5.2.8", "spoon/library": "<1.4.1", "spoonity/tcpdf": "<6.2.22", @@ -4405,7 +4405,7 @@ "t3s/content-consent": "<1.0.3|>=2,<2.0.2", "tastyigniter/tastyigniter": "<3.3", "tcg/voyager": "<=1.4", - "tecnickcom/tcpdf": "<=6.7.4", + "tecnickcom/tcpdf": "<=6.7.5", "terminal42/contao-tablelookupwizard": "<3.3.5", "thelia/backoffice-default-template": ">=2.1,<2.1.2", "thelia/thelia": ">=2.1,<2.1.3", @@ -4583,7 +4583,7 @@ "type": "tidelift" } ], - "time": "2024-11-19T21:04:39+00:00" + "time": "2024-11-27T22:05:07+00:00" }, { "name": "sebastian/cli-parser", @@ -5673,22 +5673,22 @@ }, { "name": "sniccowp/php-scoper-wordpress-excludes", - "version": "6.6.2", + "version": "6.7.1", "source": { "type": "git", "url": "https://github.com/snicco/php-scoper-wordpress-excludes.git", - "reference": "b87d7455bdf05c25f9a688fc3862bb3f2b7c8b15" + "reference": "d8e6b5fdc9e42300a8ab18b44b775836a7b52363" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/snicco/php-scoper-wordpress-excludes/zipball/b87d7455bdf05c25f9a688fc3862bb3f2b7c8b15", - "reference": "b87d7455bdf05c25f9a688fc3862bb3f2b7c8b15", + "url": "https://api.github.com/repos/snicco/php-scoper-wordpress-excludes/zipball/d8e6b5fdc9e42300a8ab18b44b775836a7b52363", + "reference": "d8e6b5fdc9e42300a8ab18b44b775836a7b52363", "shasum": "" }, "require-dev": { "php": "^7.4", "php-stubs/wordpress-globals": "0.2.0", - "php-stubs/wordpress-stubs": "6.6.2", + "php-stubs/wordpress-stubs": "6.7.1", "sniccowp/php-scoper-excludes": "dev-master" }, "type": "library", @@ -5714,9 +5714,9 @@ ], "support": { "issues": "https://github.com/snicco/php-scoper-wordpress-excludes/issues", - "source": "https://github.com/snicco/php-scoper-wordpress-excludes/tree/6.6.2" + "source": "https://github.com/snicco/php-scoper-wordpress-excludes/tree/6.7.1" }, - "time": "2024-10-01T00:32:14+00:00" + "time": "2024-11-25T00:31:50+00:00" }, { "name": "squizlabs/php_codesniffer", @@ -5800,27 +5800,28 @@ }, { "name": "swissspidy/phpstan-no-private", - "version": "v0.2.1", + "version": "v1.0.0", "source": { "type": "git", "url": "https://github.com/swissspidy/phpstan-no-private.git", - "reference": "f7a1890e350c8d8bf26370426a971d7490ae4245" + "reference": "559cb0e8d092df7314ed4254db83db0427440af2" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/swissspidy/phpstan-no-private/zipball/f7a1890e350c8d8bf26370426a971d7490ae4245", - "reference": "f7a1890e350c8d8bf26370426a971d7490ae4245", + "url": "https://api.github.com/repos/swissspidy/phpstan-no-private/zipball/559cb0e8d092df7314ed4254db83db0427440af2", + "reference": "559cb0e8d092df7314ed4254db83db0427440af2", "shasum": "" }, "require": { - "php": "^7.2 || ^8.0", - "phpstan/phpstan": "^1.10.3" + "php": "^7.4 || ^8.0", + "phpstan/phpstan": "^2.0" }, "require-dev": { "dealerdirect/phpcodesniffer-composer-installer": "^1.0.0", - "php-parallel-lint/php-parallel-lint": "^1.2", - "phpstan/phpstan-php-parser": "^1.1", - "phpstan/phpstan-phpunit": "^1.0", + "nikic/php-parser": "^v5.3.1", + "php-parallel-lint/php-parallel-lint": "^1.4", + "phpstan/phpstan-phpunit": "^2.0", + "phpstan/phpstan-strict-rules": "^2.0", "phpunit/phpunit": "^9.5", "slevomat/coding-standard": "^8.8.0", "squizlabs/php_codesniffer": "^3.5.3" @@ -5845,9 +5846,9 @@ "description": "PHPStan rules for detecting usage of pseudo-private functions, classes, and methods.", "support": { "issues": "https://github.com/swissspidy/phpstan-no-private/issues", - "source": "https://github.com/swissspidy/phpstan-no-private/tree/v0.2.1" + "source": "https://github.com/swissspidy/phpstan-no-private/tree/v1.0.0" }, - "time": "2024-06-05T10:03:17+00:00" + "time": "2024-11-11T11:04:45+00:00" }, { "name": "symfony/config", @@ -6029,16 +6030,16 @@ }, { "name": "symfony/dependency-injection", - "version": "v5.4.45", + "version": "v5.4.48", "source": { "type": "git", "url": "https://github.com/symfony/dependency-injection.git", - "reference": "0c199da64bb27e4216ccccb83f451e2ec66b3c4b" + "reference": "e5ca16dee39ef7d63e552ff0bf0a2526a1142c92" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/dependency-injection/zipball/0c199da64bb27e4216ccccb83f451e2ec66b3c4b", - "reference": "0c199da64bb27e4216ccccb83f451e2ec66b3c4b", + "url": "https://api.github.com/repos/symfony/dependency-injection/zipball/e5ca16dee39ef7d63e552ff0bf0a2526a1142c92", + "reference": "e5ca16dee39ef7d63e552ff0bf0a2526a1142c92", "shasum": "" }, "require": { @@ -6098,7 +6099,7 @@ "description": "Allows you to standardize and centralize the way objects are constructed in your application", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/dependency-injection/tree/v5.4.45" + "source": "https://github.com/symfony/dependency-injection/tree/v5.4.48" }, "funding": [ { @@ -6114,20 +6115,20 @@ "type": "tidelift" } ], - "time": "2024-10-22T18:49:16+00:00" + "time": "2024-11-20T10:51:57+00:00" }, { "name": "symfony/deprecation-contracts", - "version": "v2.5.3", + "version": "v2.5.4", "source": { "type": "git", "url": "https://github.com/symfony/deprecation-contracts.git", - "reference": "80d075412b557d41002320b96a096ca65aa2c98d" + "reference": "605389f2a7e5625f273b53960dc46aeaf9c62918" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/80d075412b557d41002320b96a096ca65aa2c98d", - "reference": "80d075412b557d41002320b96a096ca65aa2c98d", + "url": "https://api.github.com/repos/symfony/deprecation-contracts/zipball/605389f2a7e5625f273b53960dc46aeaf9c62918", + "reference": "605389f2a7e5625f273b53960dc46aeaf9c62918", "shasum": "" }, "require": { @@ -6165,7 +6166,7 @@ "description": "A generic function and convention to trigger deprecation notices", "homepage": "https://symfony.com", "support": { - "source": "https://github.com/symfony/deprecation-contracts/tree/v2.5.3" + "source": "https://github.com/symfony/deprecation-contracts/tree/v2.5.4" }, "funding": [ { @@ -6181,20 +6182,20 @@ "type": "tidelift" } ], - "time": "2023-01-24T14:02:46+00:00" + "time": "2024-09-25T14:11:13+00:00" }, { "name": "symfony/event-dispatcher-contracts", - "version": "v2.5.3", + "version": "v2.5.4", "source": { "type": "git", "url": "https://github.com/symfony/event-dispatcher-contracts.git", - "reference": "540f4c73e87fd0c71ca44a6aa305d024ac68cb73" + "reference": "e0fe3d79b516eb75126ac6fa4cbf19b79b08c99f" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/540f4c73e87fd0c71ca44a6aa305d024ac68cb73", - "reference": "540f4c73e87fd0c71ca44a6aa305d024ac68cb73", + "url": "https://api.github.com/repos/symfony/event-dispatcher-contracts/zipball/e0fe3d79b516eb75126ac6fa4cbf19b79b08c99f", + "reference": "e0fe3d79b516eb75126ac6fa4cbf19b79b08c99f", "shasum": "" }, "require": { @@ -6244,7 +6245,7 @@ "standards" ], "support": { - "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v2.5.3" + "source": "https://github.com/symfony/event-dispatcher-contracts/tree/v2.5.4" }, "funding": [ { @@ -6260,7 +6261,7 @@ "type": "tidelift" } ], - "time": "2024-01-23T13:51:25+00:00" + "time": "2024-09-25T14:11:13+00:00" }, { "name": "symfony/filesystem", @@ -6788,16 +6789,16 @@ }, { "name": "symfony/service-contracts", - "version": "v2.5.3", + "version": "v2.5.4", "source": { "type": "git", "url": "https://github.com/symfony/service-contracts.git", - "reference": "a2329596ddc8fd568900e3fc76cba42489ecc7f3" + "reference": "f37b419f7aea2e9abf10abd261832cace12e3300" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/symfony/service-contracts/zipball/a2329596ddc8fd568900e3fc76cba42489ecc7f3", - "reference": "a2329596ddc8fd568900e3fc76cba42489ecc7f3", + "url": "https://api.github.com/repos/symfony/service-contracts/zipball/f37b419f7aea2e9abf10abd261832cace12e3300", + "reference": "f37b419f7aea2e9abf10abd261832cace12e3300", "shasum": "" }, "require": { @@ -6851,7 +6852,7 @@ "standards" ], "support": { - "source": "https://github.com/symfony/service-contracts/tree/v2.5.3" + "source": "https://github.com/symfony/service-contracts/tree/v2.5.4" }, "funding": [ { @@ -6867,7 +6868,7 @@ "type": "tidelift" } ], - "time": "2023-04-21T15:04:16+00:00" + "time": "2024-09-25T14:11:13+00:00" }, { "name": "symfony/string", @@ -6957,30 +6958,29 @@ }, { "name": "szepeviktor/phpstan-wordpress", - "version": "v1.3.5", + "version": "v2.0.1", "source": { "type": "git", "url": "https://github.com/szepeviktor/phpstan-wordpress.git", - "reference": "7f8cfe992faa96b6a33bbd75c7bace98864161e7" + "reference": "f7beb13cd22998e3d913fdb897a1e2553ccd637e" }, "dist": { "type": "zip", - "url": "https://api.github.com/repos/szepeviktor/phpstan-wordpress/zipball/7f8cfe992faa96b6a33bbd75c7bace98864161e7", - "reference": "7f8cfe992faa96b6a33bbd75c7bace98864161e7", + "url": "https://api.github.com/repos/szepeviktor/phpstan-wordpress/zipball/f7beb13cd22998e3d913fdb897a1e2553ccd637e", + "reference": "f7beb13cd22998e3d913fdb897a1e2553ccd637e", "shasum": "" }, "require": { - "php": "^7.2 || ^8.0", - "php-stubs/wordpress-stubs": "^4.7 || ^5.0 || ^6.0", - "phpstan/phpstan": "^1.10.31", - "symfony/polyfill-php73": "^1.12.0" + "php": "^7.4 || ^8.0", + "php-stubs/wordpress-stubs": "^6.6.2", + "phpstan/phpstan": "^2.0" }, "require-dev": { "composer/composer": "^2.1.14", "dealerdirect/phpcodesniffer-composer-installer": "^1.0", "php-parallel-lint/php-parallel-lint": "^1.1", - "phpstan/phpstan-strict-rules": "^1.2", - "phpunit/phpunit": "^8.0 || ^9.0", + "phpstan/phpstan-strict-rules": "^2.0", + "phpunit/phpunit": "^9.0", "szepeviktor/phpcs-psr-12-neutron-hybrid-ruleset": "^1.0", "wp-coding-standards/wpcs": "3.1.0 as 2.3.0" }, @@ -7014,9 +7014,9 @@ ], "support": { "issues": "https://github.com/szepeviktor/phpstan-wordpress/issues", - "source": "https://github.com/szepeviktor/phpstan-wordpress/tree/v1.3.5" + "source": "https://github.com/szepeviktor/phpstan-wordpress/tree/v2.0.1" }, - "time": "2024-06-28T22:27:19+00:00" + "time": "2024-12-01T02:13:05+00:00" }, { "name": "thecodingmachine/safe", @@ -7480,7 +7480,7 @@ "ext-libxml": "*", "ext-mbstring": "*" }, - "platform-dev": {}, + "platform-dev": [], "platform-overrides": { "php": "7.4" }, diff --git a/includes/AMP/Meta_Sanitizer.php b/includes/AMP/Meta_Sanitizer.php index a5c936f7fbeb..bb3f70d50d24 100644 --- a/includes/AMP/Meta_Sanitizer.php +++ b/includes/AMP/Meta_Sanitizer.php @@ -52,7 +52,7 @@ class Meta_Sanitizer extends AMP_Meta_Sanitizer { * "Finally, specify the AMP boilerplate code. By putting the boilerplate code last, it prevents custom styles from * accidentally overriding the boilerplate css rules." * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.1.0 * diff --git a/includes/AMP/Sanitization.php b/includes/AMP/Sanitization.php index b486f6e39993..2666fe633ee1 100644 --- a/includes/AMP/Sanitization.php +++ b/includes/AMP/Sanitization.php @@ -128,7 +128,7 @@ public function validation_error_callback( array $error, array $data = [] ): boo /** * Adds missing scripts. * - * @SuppressWarnings(PHPMD) + * @SuppressWarnings("PHPMD") * * @since 1.1.0 * @@ -418,7 +418,7 @@ protected function is_amp_dev_mode(): bool { * accessing options from the database, requiring AMP__VERSION, * and causing conflicts with our own amp_is_request() compat shim. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.1.0 * diff --git a/includes/AMP/Traits/Sanitization_Utils.php b/includes/AMP/Traits/Sanitization_Utils.php index dd6e87968e82..83513a72dceb 100644 --- a/includes/AMP/Traits/Sanitization_Utils.php +++ b/includes/AMP/Traits/Sanitization_Utils.php @@ -71,7 +71,7 @@ private function transform_html_start_tag( $document ): void { * Removes empty data-tooltip-icon and data-tooltip-text attributes * to prevent validation issues. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.1.0 * diff --git a/includes/Admin/Activation_Notice.php b/includes/Admin/Activation_Notice.php index 35a36340217b..4e26d3181b0b 100644 --- a/includes/Admin/Activation_Notice.php +++ b/includes/Admin/Activation_Notice.php @@ -235,7 +235,7 @@ protected function is_plugins_page( $hook_suffix ): bool { /** * Sets the flag that the plugin has just been activated. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.13.0 * @@ -252,7 +252,7 @@ protected function set_activation_flag( bool $network_wide = false ): bool { /** * Gets the flag that the plugin has just been activated. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.13.0 * @@ -270,7 +270,7 @@ protected function get_activation_flag( bool $network_wide = false ): bool { /** * Deletes the flag that the plugin has just been activated. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.13.0 * diff --git a/includes/Admin/Customizer.php b/includes/Admin/Customizer.php index 69f1a7f8ea38..1fcce9b3ebbe 100644 --- a/includes/Admin/Customizer.php +++ b/includes/Admin/Customizer.php @@ -40,7 +40,7 @@ /** * Class customizer settings. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @phpstan-type ThemeSupport array{ * customizer: array{ @@ -159,9 +159,9 @@ public static function is_needed(): bool { /** * Registers web stories customizer settings. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) - * @SuppressWarnings(PHPMD.NPathComplexity) - * @SuppressWarnings(PHPMD.CyclomaticComplexity) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") + * @SuppressWarnings("PHPMD.NPathComplexity") + * @SuppressWarnings("PHPMD.CyclomaticComplexity") * * @since 1.5.0 * @@ -531,8 +531,8 @@ public function validate_number_of_columns( WP_Error $validity, int $value ): WP /** * Renders web stories based on the customizer selected options. * - * @SuppressWarnings(PHPMD.NPathComplexity) - * @SuppressWarnings(PHPMD.CyclomaticComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") + * @SuppressWarnings("PHPMD.CyclomaticComplexity") * * @since 1.5.0 */ diff --git a/includes/Admin/Dashboard.php b/includes/Admin/Dashboard.php index 634a81c0ca8f..b12d7f1c9b67 100644 --- a/includes/Admin/Dashboard.php +++ b/includes/Admin/Dashboard.php @@ -156,7 +156,7 @@ class Dashboard extends Service_Base { /** * Dashboard constructor. * - * @SuppressWarnings(PHPMD.ExcessiveParameterList) + * @SuppressWarnings("PHPMD.ExcessiveParameterList") * * @since 1.0.0 * diff --git a/includes/Admin/Editor.php b/includes/Admin/Editor.php index 565817bf8772..2d023411870d 100644 --- a/includes/Admin/Editor.php +++ b/includes/Admin/Editor.php @@ -151,7 +151,7 @@ class Editor extends Service_Base implements HasRequirements { /** * Dashboard constructor. * - * @SuppressWarnings(PHPMD.ExcessiveParameterList) + * @SuppressWarnings("PHPMD.ExcessiveParameterList") * * @since 1.0.0 * @@ -333,7 +333,7 @@ public function admin_enqueue_scripts( string $hook ): void { /** * Get editor settings as an array. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.0.0 * diff --git a/includes/Analytics.php b/includes/Analytics.php index ea05f0beb8e4..67ade9904e1a 100644 --- a/includes/Analytics.php +++ b/includes/Analytics.php @@ -89,7 +89,7 @@ public function get_tracking_id(): string { * * Note: variables in single quotes will be substituted by . * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @see https://github.com/ampproject/amphtml/blob/main/docs/spec/amp-var-substitutions.md * diff --git a/includes/Assets.php b/includes/Assets.php index 6edb82377d2a..246b4803a6bd 100644 --- a/includes/Assets.php +++ b/includes/Assets.php @@ -113,7 +113,7 @@ public function get_asset_metadata( string $handle ): array { /** * Register script using handle. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.8.0 * @@ -181,7 +181,7 @@ public function register_script_asset( string $script_handle, array $script_depe /** * Enqueue script using handle. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.8.0 * @@ -255,7 +255,7 @@ public function enqueue_style_asset( string $style_handle, array $style_dependen /** * Register a CSS stylesheet. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.8.0 * @@ -283,7 +283,7 @@ public function register_style( string $style_handle, $src, array $deps = [], $v /** * Register a new script. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.8.0 * @@ -315,7 +315,7 @@ public function register_script( string $script_handle, $src, array $deps = [], /** * Enqueue a style. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.8.0 * @@ -339,7 +339,7 @@ public function enqueue_style( string $style_handle, string $src = '', array $de /** * Enqueue a script. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.8.0 * diff --git a/includes/Block/Web_Stories_Block.php b/includes/Block/Web_Stories_Block.php index cf723dc300eb..4e9157fd0346 100644 --- a/includes/Block/Web_Stories_Block.php +++ b/includes/Block/Web_Stories_Block.php @@ -388,7 +388,7 @@ protected function initialize_block_attributes( array $block_attributes = [] ): /** * Returns arguments to be passed to the WP_Query object initialization. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.5.0 * diff --git a/includes/Experiments.php b/includes/Experiments.php index f93032b516d3..55a9e535e284 100644 --- a/includes/Experiments.php +++ b/includes/Experiments.php @@ -225,7 +225,7 @@ public function get_experiment_groups(): array { /** * Returns a list of all experiments. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.0.0 * diff --git a/includes/Infrastructure/ServiceBasedPlugin.php b/includes/Infrastructure/ServiceBasedPlugin.php index 1542912a4374..b8be48abfa7b 100644 --- a/includes/Infrastructure/ServiceBasedPlugin.php +++ b/includes/Infrastructure/ServiceBasedPlugin.php @@ -31,7 +31,7 @@ * This abstract base plugin provides all the boilerplate code for working with * the dependency injector and the service container. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @template C of Conditional * @template D of Delayed @@ -715,7 +715,7 @@ protected function instantiate_service( $class_name ): Service { * object * or into configuration files. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.6.0 * diff --git a/includes/Integrations/AMP.php b/includes/Integrations/AMP.php index da241e237228..8da5fe5e8546 100644 --- a/includes/Integrations/AMP.php +++ b/includes/Integrations/AMP.php @@ -41,7 +41,7 @@ /** * Class AMP. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @phpstan-type AMPOptions array{ * theme_support?: string, @@ -349,7 +349,7 @@ public function filter_amp_skip_post( $skipped, int $post ) { /** * Get the post type for the current request. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.2.0 */ diff --git a/includes/Integrations/Jetpack.php b/includes/Integrations/Jetpack.php index d4fae74e3762..f5d655d500ef 100644 --- a/includes/Integrations/Jetpack.php +++ b/includes/Integrations/Jetpack.php @@ -38,7 +38,7 @@ /** * Class Jetpack. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @phpstan-type AttachmentData array{ * media_details?: array{ diff --git a/includes/KSES.php b/includes/KSES.php index abdc39a52d97..45c44976a7e9 100644 --- a/includes/KSES.php +++ b/includes/KSES.php @@ -40,7 +40,7 @@ * * Provides KSES utility methods to override the ones from core. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @phpstan-type PostData array{ * post_parent: int|string|null, diff --git a/includes/Media/SVG.php b/includes/Media/SVG.php index c44bd8f2f887..e64c3e280cc2 100644 --- a/includes/Media/SVG.php +++ b/includes/Media/SVG.php @@ -302,7 +302,7 @@ private function svg_already_enabled(): bool { /** * Get SVG image size. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.3.0 * diff --git a/includes/Post_Type_Base.php b/includes/Post_Type_Base.php index 075449493a3f..74536261cb66 100644 --- a/includes/Post_Type_Base.php +++ b/includes/Post_Type_Base.php @@ -318,7 +318,7 @@ public function get_parent_controller(): WP_REST_Controller { * Identical to {@see get_post_type_archive_link()}, but also returns a URL * if the archive page has been disabled. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.14.0 * diff --git a/includes/REST_API/Embed_Controller.php b/includes/REST_API/Embed_Controller.php index c9202608d71e..9bf63d58dbd3 100644 --- a/includes/REST_API/Embed_Controller.php +++ b/includes/REST_API/Embed_Controller.php @@ -47,7 +47,7 @@ * * API endpoint to facilitate embedding web stories. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @phpstan-type SchemaEntry array{ * description: string, @@ -126,7 +126,7 @@ public function register_routes(): void { * * Returns information about the given story. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.0.0 * @@ -365,7 +365,7 @@ private function get_data_from_post( string $url ) { * * Checks are supposedly from the hosted site blog. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.2.0 * diff --git a/includes/REST_API/Font_Controller.php b/includes/REST_API/Font_Controller.php index 05f04137583a..d5390398f035 100644 --- a/includes/REST_API/Font_Controller.php +++ b/includes/REST_API/Font_Controller.php @@ -246,7 +246,7 @@ public function delete_item( $request ) { /** * Prepares a single post output for response. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.16.0 * @@ -371,7 +371,7 @@ public function get_collection_params(): array { /** * Retrieves the font's schema, conforming to JSON Schema. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.16.0 * diff --git a/includes/REST_API/Hotlinking_Controller.php b/includes/REST_API/Hotlinking_Controller.php index 717ecfa6d7eb..0faaf8442e84 100644 --- a/includes/REST_API/Hotlinking_Controller.php +++ b/includes/REST_API/Hotlinking_Controller.php @@ -42,7 +42,7 @@ * * API endpoint for pinging and hotlinking media URLs. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @phpstan-type LinkData array{ * ext?: string, @@ -203,8 +203,8 @@ public function register_routes(): void { /** * Parses a URL to return some metadata for inserting external media. * - * @SuppressWarnings(PHPMD.NPathComplexity) - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.NPathComplexity") + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.11.0 * @@ -327,7 +327,7 @@ public function parse_url( WP_REST_Request $request ) { /** * Parses a URL to return proxied file. * - * @SuppressWarnings(PHPMD.ErrorControlOperator) + * @SuppressWarnings("PHPMD.ErrorControlOperator") * * @since 1.13.0 * @@ -724,8 +724,8 @@ private function proxy_url_fallback( string $url, array $args ): void { * Like {@see wp_http_validate_url} in core, but with extra hardening * to avoid DNS rebinding issues. * - * @SuppressWarnings(PHPMD.NPathComplexity) - * @SuppressWarnings(PHPMD.CyclomaticComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") + * @SuppressWarnings("PHPMD.CyclomaticComplexity") * * @since 1.22.0 * diff --git a/includes/REST_API/Link_Controller.php b/includes/REST_API/Link_Controller.php index df7201c596a2..81f77e6784b5 100644 --- a/includes/REST_API/Link_Controller.php +++ b/includes/REST_API/Link_Controller.php @@ -122,9 +122,9 @@ public function register_routes(): void { /** * Parses a URL to return some metadata for inserting links. * - * @SuppressWarnings(PHPMD.CyclomaticComplexity) - * @SuppressWarnings(PHPMD.NPathComplexity) - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + * @SuppressWarnings("PHPMD.NPathComplexity") + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.0.0 * diff --git a/includes/REST_API/Products_Controller.php b/includes/REST_API/Products_Controller.php index fc85d66a140d..73da3a1ea2c3 100644 --- a/includes/REST_API/Products_Controller.php +++ b/includes/REST_API/Products_Controller.php @@ -163,7 +163,7 @@ public function get_items_permissions_check( $request ) { /** * Retrieves all products. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.20.0 * @@ -227,7 +227,7 @@ public function get_items( $request ) { /** * Prepares a single post output for response. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.20.0 * @@ -323,7 +323,7 @@ public function prepare_item_for_response( $item, $request ): WP_REST_Response { /** * Retrieves the product schema, conforming to JSON Schema. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.20.0 * diff --git a/includes/REST_API/Stories_Base_Controller.php b/includes/REST_API/Stories_Base_Controller.php index e0516c502872..c2ea2d5d4ee3 100644 --- a/includes/REST_API/Stories_Base_Controller.php +++ b/includes/REST_API/Stories_Base_Controller.php @@ -40,7 +40,7 @@ /** * Stories_Base_Controller class. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * Override the WP_REST_Posts_Controller class to add `post_content_filtered` to REST request. * diff --git a/includes/REST_API/Stories_Controller.php b/includes/REST_API/Stories_Controller.php index afff8f7ad724..dd2954b7f93e 100644 --- a/includes/REST_API/Stories_Controller.php +++ b/includes/REST_API/Stories_Controller.php @@ -41,7 +41,7 @@ /** * Stories_Controller class. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @phpstan-type QueryArgs array{ * posts_per_page?: int, @@ -71,8 +71,8 @@ class Stories_Controller extends Stories_Base_Controller { /** * Prepares a single story output for response. Add post_content_filtered field to output. * - * @SuppressWarnings(PHPMD.CyclomaticComplexity) - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.CyclomaticComplexity") + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.0.0 * @@ -484,7 +484,7 @@ protected function get_attached_post_ids( array $posts ): array { /** * Add response headers, with post counts. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.12.0 * diff --git a/includes/REST_API/Stories_Lock_Controller.php b/includes/REST_API/Stories_Lock_Controller.php index 6d575ebcbef5..85ff42d0f4a7 100644 --- a/includes/REST_API/Stories_Lock_Controller.php +++ b/includes/REST_API/Stories_Lock_Controller.php @@ -261,8 +261,8 @@ public function delete_item_permissions_check( $request ) { /** * Prepares a single lock output for response. * - * @SuppressWarnings(PHPMD.NPathComplexity) - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.NPathComplexity") + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.6.0 * diff --git a/includes/REST_API/Stories_Users_Controller.php b/includes/REST_API/Stories_Users_Controller.php index 2575ff7d8e5f..8075813ead15 100644 --- a/includes/REST_API/Stories_Users_Controller.php +++ b/includes/REST_API/Stories_Users_Controller.php @@ -233,7 +233,7 @@ public function get_item_permissions_check( $request ) { * * Wraps {@see count_user_posts()} results in a cache. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.10.0 * diff --git a/includes/Renderer/Stories/Carousel_Renderer.php b/includes/Renderer/Stories/Carousel_Renderer.php index acd8f09a476b..5c937e7905f3 100644 --- a/includes/Renderer/Stories/Carousel_Renderer.php +++ b/includes/Renderer/Stories/Carousel_Renderer.php @@ -79,7 +79,7 @@ public function load_assets(): void { /** * Renders the stories output for given attributes. * - * @SuppressWarnings(PHPMD.UnusedLocalVariable) + * @SuppressWarnings("PHPMD.UnusedLocalVariable") * * @since 1.5.0 * diff --git a/includes/Renderer/Stories/Generic_Renderer.php b/includes/Renderer/Stories/Generic_Renderer.php index 6ad68611c18a..f603e0c90687 100644 --- a/includes/Renderer/Stories/Generic_Renderer.php +++ b/includes/Renderer/Stories/Generic_Renderer.php @@ -60,7 +60,7 @@ public function init(): void { /** * Renders the stories output for given attributes. * - * @SuppressWarnings(PHPMD.UnusedLocalVariable) + * @SuppressWarnings("PHPMD.UnusedLocalVariable") * * @since 1.5.0 * @@ -86,7 +86,7 @@ function () { $this->render_single_story_content(); $this->next(); }, - $this->stories + $this->stories ); $this->maybe_render_archive_link(); ?> diff --git a/includes/Renderer/Stories/Renderer.php b/includes/Renderer/Stories/Renderer.php index 82058fc1f0d7..f1ac41677983 100644 --- a/includes/Renderer/Stories/Renderer.php +++ b/includes/Renderer/Stories/Renderer.php @@ -42,8 +42,8 @@ /** * Renderer class. * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) - * @SuppressWarnings(PHPMD.TooManyPublicMethods) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") + * @SuppressWarnings("PHPMD.TooManyPublicMethods") * * @phpstan-import-type StoryAttributes from \Google\Web_Stories\Story_Query * @@ -304,7 +304,7 @@ public function add_amp_post_template_css(): void { /** * Returns story item data. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.5.0 * diff --git a/includes/Renderer/Story/Embed.php b/includes/Renderer/Story/Embed.php index b2053cc89cc6..5c33406faa25 100644 --- a/includes/Renderer/Story/Embed.php +++ b/includes/Renderer/Story/Embed.php @@ -77,7 +77,7 @@ public function __construct( Story $story, Assets $assets, Context $context ) { /** * Renders the block output in default context. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.0.0 * diff --git a/includes/Renderer/Story/Singleton.php b/includes/Renderer/Story/Singleton.php index d53c47f1f5eb..30f3eccdf137 100644 --- a/includes/Renderer/Story/Singleton.php +++ b/includes/Renderer/Story/Singleton.php @@ -83,7 +83,7 @@ public function __construct( Story $story, Assets $assets ) { /** * Renders the block output in default context. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.30.0 * diff --git a/includes/Settings.php b/includes/Settings.php index 629c95d895f9..04d5a3b76fbc 100644 --- a/includes/Settings.php +++ b/includes/Settings.php @@ -183,7 +183,7 @@ public function prime_option_caches(): void { /** * Register settings. * - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.0.0 */ @@ -218,7 +218,7 @@ public function register(): void { 'description' => __( 'Ad Network', 'web-stories' ), 'type' => 'string', 'default' => 'none', - 'enum' => [ 'none', 'adsense', 'admanager' ], + 'enum' => [ 'none', 'adsense', 'admanager', 'mgid' ], 'show_in_rest' => true, ] ); @@ -454,7 +454,7 @@ public function register(): void { /** * Returns the value for a given setting. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.12.0 * diff --git a/includes/Widgets/Stories.php b/includes/Widgets/Stories.php index 823678caf09d..5b7395dd08e7 100644 --- a/includes/Widgets/Stories.php +++ b/includes/Widgets/Stories.php @@ -32,7 +32,7 @@ /** * Class Stories * - * @SuppressWarnings(PHPMD.ExcessiveClassComplexity) + * @SuppressWarnings("PHPMD.ExcessiveClassComplexity") * * @phpstan-type InputArgs array{ * type?: string, @@ -167,8 +167,8 @@ public function widget( $args, $instance ): void { /** * Display widget form. * - * @SuppressWarnings(PHPMD.NPathComplexity) - * @SuppressWarnings(PHPMD.ExcessiveMethodLength) + * @SuppressWarnings("PHPMD.NPathComplexity") + * @SuppressWarnings("PHPMD.ExcessiveMethodLength") * * @since 1.5.0 * @@ -409,7 +409,7 @@ public function form( $instance ): string { /** * Update widget settings. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.5.0 * diff --git a/includes/data/fonts/fonts.json b/includes/data/fonts/fonts.json index 6e27f49eaa19..c82312346b02 100644 --- a/includes/data/fonts/fonts.json +++ b/includes/data/fonts/fonts.json @@ -11129,6 +11129,41 @@ "lGap": 0 } }, + { + "family": "Doto", + "fallbacks": ["sans-serif"], + "weights": [100, 200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular"], + "variants": [ + [0, 100], + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 950, + "des": -250, + "tAsc": 950, + "tDes": -250, + "tLGap": 0, + "wAsc": 900, + "wDes": 300, + "xH": 500, + "capH": 700, + "yMin": -300, + "yMax": 900, + "hAsc": 950, + "hDes": -250, + "lGap": 0 + } + }, { "family": "Dr Sugiyama", "fallbacks": ["cursive"], @@ -11406,6 +11441,36 @@ "lGap": 0 } }, + { + "family": "Edu AU VIC WA NT Arrows", + "fallbacks": ["cursive"], + "weights": [400, 500, 600, 700], + "styles": ["regular"], + "variants": [ + [0, 400], + [0, 500], + [0, 600], + [0, 700] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 2000, + "asc": 2576, + "des": -903, + "tAsc": 2576, + "tDes": -903, + "tLGap": 0, + "wAsc": 3205, + "wDes": 903, + "xH": 995, + "capH": 1847, + "yMin": -857, + "yMax": 2002, + "hAsc": 2576, + "hDes": -903, + "lGap": 0 + } + }, { "family": "Edu AU VIC WA NT Dots", "fallbacks": ["cursive"], @@ -11496,6 +11561,36 @@ "lGap": 0 } }, + { + "family": "Edu AU VIC WA NT Pre", + "fallbacks": ["cursive"], + "weights": [400, 500, 600, 700], + "styles": ["regular"], + "variants": [ + [0, 400], + [0, 500], + [0, 600], + [0, 700] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 2000, + "asc": 2576, + "des": -903, + "tAsc": 2576, + "tDes": -903, + "tLGap": 0, + "wAsc": 3205, + "wDes": 903, + "xH": 995, + "capH": 1847, + "yMin": -861, + "yMax": 2751, + "hAsc": 2576, + "hDes": -903, + "lGap": 0 + } + }, { "family": "Edu NSW ACT Foundation", "fallbacks": ["cursive"], @@ -12438,6 +12533,31 @@ "lGap": 0 } }, + { + "family": "Faculty Glyphic", + "fallbacks": ["sans-serif"], + "weights": [400], + "styles": ["regular"], + "variants": [[0, 400]], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1037, + "des": -262, + "tAsc": 1037, + "tDes": -262, + "tLGap": 0, + "wAsc": 1010, + "wDes": 280, + "xH": 550, + "capH": 775, + "yMin": -276, + "yMax": 1010, + "hAsc": 1037, + "hDes": -262, + "lGap": 0 + } + }, { "family": "Fahkwang", "fallbacks": ["sans-serif"], @@ -13877,6 +13997,76 @@ "lGap": 0 } }, + { + "family": "Funnel Display", + "fallbacks": ["cursive"], + "weights": [300, 400, 500, 600, 700, 800], + "styles": ["regular"], + "variants": [ + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1200, + "asc": 1200, + "des": -300, + "tAsc": 1200, + "tDes": -300, + "tLGap": 0, + "wAsc": 1200, + "wDes": 330, + "xH": 600, + "capH": 810, + "yMin": -336, + "yMax": 1132, + "hAsc": 1200, + "hDes": -300, + "lGap": 0 + } + }, + { + "family": "Funnel Sans", + "fallbacks": ["sans-serif"], + "weights": [300, 400, 500, 600, 700, 800], + "styles": ["regular", "italic"], + "variants": [ + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1200, + "asc": 1200, + "des": -300, + "tAsc": 1200, + "tDes": -300, + "tLGap": 0, + "wAsc": 1200, + "wDes": 330, + "xH": 600, + "capH": 810, + "yMin": -336, + "yMax": 1132, + "hAsc": 1200, + "hDes": -300, + "lGap": 0 + } + }, { "family": "Fustat", "fallbacks": ["sans-serif"], @@ -14325,6 +14515,76 @@ "lGap": 0 } }, + { + "family": "Geist", + "fallbacks": ["sans-serif"], + "weights": [100, 200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular"], + "variants": [ + [0, 100], + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1005, + "des": -295, + "tAsc": 1005, + "tDes": -295, + "tLGap": 0, + "wAsc": 1012, + "wDes": 262, + "xH": 530, + "capH": 710, + "yMin": -240, + "yMax": 940, + "hAsc": 1005, + "hDes": -295, + "lGap": 0 + } + }, + { + "family": "Geist Mono", + "fallbacks": ["monospace"], + "weights": [100, 200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular"], + "variants": [ + [0, 100], + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1005, + "des": -295, + "tAsc": 1005, + "tDes": -295, + "tLGap": 0, + "wAsc": 1012, + "wDes": 262, + "xH": 530, + "capH": 710, + "yMin": -247, + "yMax": 1012, + "hAsc": 1005, + "hDes": -295, + "lGap": 0 + } + }, { "family": "Gelasio", "fallbacks": ["serif"], @@ -16773,6 +17033,44 @@ "lGap": 0 } }, + { + "family": "Host Grotesk", + "fallbacks": ["sans-serif"], + "weights": [300, 400, 500, 600, 700, 800], + "styles": ["regular", "italic"], + "variants": [ + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1015, + "des": -315, + "tAsc": 1015, + "tDes": -315, + "tLGap": 0, + "wAsc": 977, + "wDes": 372, + "xH": 496, + "capH": 700, + "yMin": -341, + "yMax": 968, + "hAsc": 1015, + "hDes": -315, + "lGap": 0 + } + }, { "family": "Hubballi", "fallbacks": ["sans-serif"], @@ -16798,6 +17096,48 @@ "lGap": 0 } }, + { + "family": "Hubot Sans", + "fallbacks": ["sans-serif"], + "weights": [200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular", "italic"], + "variants": [ + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900], + [1, 200], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800], + [1, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1090, + "des": -320, + "tAsc": 1090, + "tDes": -320, + "tLGap": 0, + "wAsc": 1090, + "wDes": 320, + "xH": 525, + "capH": 729, + "yMin": -267, + "yMax": 1057, + "hAsc": 1090, + "hDes": -320, + "lGap": 0 + } + }, { "family": "Hurricane", "fallbacks": ["cursive"], @@ -25507,6 +25847,48 @@ "lGap": 0 } }, + { + "family": "Mona Sans", + "fallbacks": ["sans-serif"], + "weights": [200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular", "italic"], + "variants": [ + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900], + [1, 200], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800], + [1, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1090, + "des": -320, + "tAsc": 1090, + "tDes": -320, + "tLGap": 0, + "wAsc": 1090, + "wDes": 320, + "xH": 525, + "capH": 729, + "yMin": -242, + "yMax": 1047, + "hAsc": 1090, + "hDes": -320, + "lGap": 0 + } + }, { "family": "Monda", "fallbacks": ["sans-serif"], @@ -25779,11 +26161,11 @@ "tDes": -251, "tLGap": 0, "wAsc": 1109, - "wDes": 270, - "xH": 517, + "wDes": 453, + "xH": 525, "capH": 700, - "yMin": -262, - "yMax": 1043, + "yMin": -459, + "yMax": 1018, "hAsc": 968, "hDes": -251, "lGap": 0 @@ -26582,20 +26964,20 @@ "service": "fonts.google.com", "metrics": { "upm": 1000, - "asc": 920, - "des": -230, - "tAsc": 800, - "tDes": -200, - "tLGap": 0, - "wAsc": 920, - "wDes": 230, - "xH": 500, - "capH": 700, - "yMin": -200, - "yMax": 802, - "hAsc": 920, - "hDes": -230, - "lGap": 0 + "asc": 630, + "des": -370, + "tAsc": 630, + "tDes": -370, + "tLGap": 250, + "wAsc": 635, + "wDes": 372, + "xH": 300, + "capH": 460, + "yMin": -370, + "yMax": 632, + "hAsc": 630, + "hDes": -370, + "lGap": 250 } }, { @@ -26611,19 +26993,19 @@ "service": "fonts.google.com", "metrics": { "upm": 1000, - "asc": 920, - "des": -230, - "tAsc": 800, - "tDes": -200, - "tLGap": 0, - "wAsc": 920, - "wDes": 230, - "xH": 500, - "capH": 700, - "yMin": -200, - "yMax": 801, - "hAsc": 920, - "hDes": -230, + "asc": 844, + "des": -156, + "tAsc": 856, + "tDes": -144, + "tLGap": 250, + "wAsc": 885, + "wDes": 198, + "xH": 542, + "capH": 743, + "yMin": -198, + "yMax": 844, + "hAsc": 844, + "hDes": -156, "lGap": 0 } }, @@ -26668,20 +27050,20 @@ "service": "fonts.google.com", "metrics": { "upm": 1024, - "asc": 942, - "des": -236, + "asc": 819, + "des": -205, "tAsc": 819, "tDes": -205, - "tLGap": 0, - "wAsc": 942, - "wDes": 236, + "tLGap": 256, + "wAsc": 932, + "wDes": 247, "xH": 480, "capH": 755, - "yMin": -239, - "yMax": 978, - "hAsc": 942, - "hDes": -236, - "lGap": 0 + "yMin": -237, + "yMax": 929, + "hAsc": 819, + "hDes": -205, + "lGap": 256 } }, { @@ -26693,20 +27075,20 @@ "service": "fonts.google.com", "metrics": { "upm": 1000, - "asc": 920, - "des": -230, + "asc": 800, + "des": -200, "tAsc": 800, "tDes": -200, - "tLGap": 0, - "wAsc": 920, - "wDes": 230, + "tLGap": 250, + "wAsc": 809, + "wDes": 202, "xH": 476, "capH": 674, "yMin": -200, - "yMax": 800, - "hAsc": 920, - "hDes": -230, - "lGap": 0 + "yMax": 801, + "hAsc": 800, + "hDes": -200, + "lGap": 250 } }, { @@ -27517,7 +27899,7 @@ "wDes": 395, "xH": 536, "capH": 714, - "yMin": -394, + "yMin": -508, "yMax": 1067, "hAsc": 1069, "hDes": -293, @@ -27633,12 +28015,12 @@ "tAsc": 1374, "tDes": -738, "tLGap": 0, - "wAsc": 1374, + "wAsc": 1431, "wDes": 738, - "xH": 374, - "capH": 416, - "yMin": -573, - "yMax": 1114, + "xH": 536, + "capH": 714, + "yMin": -548, + "yMax": 1431, "hAsc": 1374, "hDes": -738, "lGap": 0 @@ -33757,12 +34139,12 @@ "tAsc": 1070, "tDes": -510, "tLGap": 0, - "wAsc": 1070, + "wAsc": 1141, "wDes": 510, "xH": 696, "capH": 760, - "yMin": -506, - "yMax": 1066, + "yMin": -507, + "yMax": 1141, "hAsc": 1070, "hDes": -510, "lGap": 0 @@ -34846,6 +35228,38 @@ "lGap": 0 } }, + { + "family": "Parkinsans", + "fallbacks": ["sans-serif"], + "weights": [300, 400, 500, 600, 700, 800], + "styles": ["regular"], + "variants": [ + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1050, + "des": -350, + "tAsc": 1050, + "tDes": -350, + "tLGap": 0, + "wAsc": 1050, + "wDes": 350, + "xH": 549, + "capH": 693, + "yMin": -275, + "yMax": 975, + "hAsc": 1050, + "hDes": -350, + "lGap": 0 + } + }, { "family": "Passero One", "fallbacks": ["cursive"], @@ -35311,6 +35725,32 @@ "lGap": 0 } }, + { + "family": "Phetsarath", + "fallbacks": ["serif"], + "weights": [400, 700], + "styles": ["regular"], + "variants": [ + [0, 400], + [0, 700] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 2048, + "asc": 2123, + "des": -857, + "tAsc": 2123, + "tDes": -857, + "tLGap": 0, + "wAsc": 2123, + "wDes": 857, + "yMin": -857, + "yMax": 2123, + "hAsc": 2123, + "hDes": -857, + "lGap": 0 + } + }, { "family": "Philosopher", "fallbacks": ["sans-serif"], @@ -37558,6 +37998,31 @@ "lGap": 0 } }, + { + "family": "Ponnala", + "fallbacks": ["cursive"], + "weights": [400], + "styles": ["regular"], + "variants": [[0, 400]], + "service": "fonts.google.com", + "metrics": { + "upm": 1024, + "asc": 938, + "des": -861, + "tAsc": 938, + "tDes": -861, + "tLGap": 0, + "wAsc": 938, + "wDes": 861, + "xH": 0, + "capH": 0, + "yMin": -861, + "yMax": 938, + "hAsc": 938, + "hDes": -861, + "lGap": 0 + } + }, { "family": "Pontano Sans", "fallbacks": ["sans-serif"], @@ -44197,6 +44662,50 @@ "lGap": 0 } }, + { + "family": "Sour Gummy", + "fallbacks": ["sans-serif"], + "weights": [100, 200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular", "italic"], + "variants": [ + [0, 100], + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900], + [1, 100], + [1, 200], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800], + [1, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 996, + "des": -296, + "tAsc": 996, + "tDes": -296, + "tLGap": 0, + "wAsc": 950, + "wDes": 508, + "xH": 500, + "capH": 700, + "yMin": -275, + "yMax": 866, + "hAsc": 996, + "hDes": -296, + "lGap": 0 + } + }, { "family": "Source Code Pro", "fallbacks": ["monospace"], @@ -49553,11 +50062,13 @@ "family": "Zain", "fallbacks": ["sans-serif"], "weights": [200, 300, 400, 700, 800, 900], - "styles": ["regular"], + "styles": ["italic", "regular"], "variants": [ [0, 200], [0, 300], + [1, 300], [0, 400], + [1, 400], [0, 700], [0, 800], [0, 900] diff --git a/includes/namespace.php b/includes/namespace.php index c0a0d4c57347..1eddc13cbf1a 100644 --- a/includes/namespace.php +++ b/includes/namespace.php @@ -35,7 +35,7 @@ /** * Handles plugin activation. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.0.0 * @@ -110,7 +110,7 @@ function remove_site( WP_Error $error, $site ): void { /** * Handles plugin deactivation. * - * @SuppressWarnings(PHPMD.BooleanArgumentFlag) + * @SuppressWarnings("PHPMD.BooleanArgumentFlag") * * @since 1.0.0 * @@ -163,7 +163,7 @@ function load_functions(): void { * * Like rest_preload_api_request() in core, but embeds links and removes trailing slashes. * - * @SuppressWarnings(PHPMD.NPathComplexity) + * @SuppressWarnings("PHPMD.NPathComplexity") * * @since 1.2.0 * diff --git a/package-lock.json b/package-lock.json index 237b0882c280..b588243694d8 100644 --- a/package-lock.json +++ b/package-lock.json @@ -15,7 +15,7 @@ "@babel/preset-env": "^7.26.0", "@babel/preset-react": "^7.25.9", "@babel/preset-typescript": "^7.26.0", - "@eslint-community/eslint-plugin-eslint-comments": "^4.4.0", + "@eslint-community/eslint-plugin-eslint-comments": "^4.4.1", "@googleforcreators/dashboard": "*", "@googleforcreators/design-system": "*", "@googleforcreators/fonts": "*", @@ -29,39 +29,39 @@ "@prettier/plugin-xml": "^3.4.1", "@rollup/plugin-babel": "^6.0.4", "@rollup/plugin-commonjs": "^25.0.7", - "@rollup/plugin-dynamic-import-vars": "^2.1.3", + "@rollup/plugin-dynamic-import-vars": "^2.1.5", "@rollup/plugin-json": "^6.1.0", - "@rollup/plugin-node-resolve": "^15.2.3", + "@rollup/plugin-node-resolve": "^15.3.0", "@rollup/plugin-terser": "^0.4.4", "@rollup/plugin-url": "^8.0.2", - "@storybook/addon-a11y": "^8.4.1", - "@storybook/addon-backgrounds": "^8.4.1", - "@storybook/addon-docs": "^8.4.1", - "@storybook/addon-essentials": "^8.4.1", - "@storybook/addon-links": "^8.4.1", - "@storybook/addon-viewport": "^8.4.1", + "@storybook/addon-a11y": "^8.4.6", + "@storybook/addon-backgrounds": "^8.4.6", + "@storybook/addon-docs": "^8.4.6", + "@storybook/addon-essentials": "^8.4.6", + "@storybook/addon-links": "^8.4.6", + "@storybook/addon-viewport": "^8.4.6", "@storybook/addon-webpack5-compiler-babel": "^3.0.3", "@storybook/client-api": "^7.6.17", - "@storybook/client-logger": "^8.4.1", - "@storybook/csf": "^0.1.8", - "@storybook/csf-tools": "^8.4.1", - "@storybook/react": "^8.4.1", - "@storybook/react-webpack5": "^8.4.1", + "@storybook/client-logger": "^8.4.6", + "@storybook/csf": "^0.1.12", + "@storybook/csf-tools": "^8.4.6", + "@storybook/react": "^8.4.6", + "@storybook/react-webpack5": "^8.4.6", "@stylelint/postcss-css-in-js": "^0.38.0", "@svgr/rollup": "^8.0.1", "@svgr/webpack": "^8.0.1", "@testing-library/dom": "^10.4.0", - "@testing-library/jest-dom": "^6.6.2", + "@testing-library/jest-dom": "^6.6.3", "@testing-library/react": "^12.1.5", "@testing-library/react-hooks": "^8.0.1", "@testing-library/user-event": "^14.5.2", "@types/jest": "^29.5.14", "@types/jsdom": "^21.1.7", - "@types/node": "^22.8.6", + "@types/node": "^22.9.3", "@types/styled-components": "^5.1.26", "@types/uuid": "^10.0.0", - "@typescript-eslint/eslint-plugin": "^6.19.1", - "@typescript-eslint/parser": "^6.19.1", + "@typescript-eslint/eslint-plugin": "^8.16.0", + "@typescript-eslint/parser": "^8.16.0", "@web-stories-wp/e2e-tests": "*", "@web-stories-wp/eslint-import-resolver": "*", "@web-stories-wp/jest-amp": "*", @@ -81,7 +81,7 @@ "babel-plugin-transform-react-remove-prop-types": "^0.4.24", "browserslist": "^4.24.2", "circular-dependency-plugin": "^5.2.2", - "core-js": "^3.38.1", + "core-js": "^3.39.0", "cross-env": "^7.0.3", "css-loader": "^7.1.2", "css-minimizer-webpack-plugin": "^7.0.0", @@ -91,23 +91,23 @@ "eslint-plugin-header": "^3.1.0", "eslint-plugin-import": "^2.31.0", "eslint-plugin-jasmine": "^4.2.2", - "eslint-plugin-jest": "^28.8.3", - "eslint-plugin-jest-dom": "^5.4.0", + "eslint-plugin-jest": "^28.9.0", + "eslint-plugin-jest-dom": "^5.5.0", "eslint-plugin-jest-extended": "^2.4.0", - "eslint-plugin-jsdoc": "^50.4.3", - "eslint-plugin-jsx-a11y": "^6.10.1", + "eslint-plugin-jsdoc": "^50.5.0", + "eslint-plugin-jsx-a11y": "^6.10.2", "eslint-plugin-markdown": "^5.1.0", "eslint-plugin-node": "^11.1.0", - "eslint-plugin-oxlint": "^0.10.1", + "eslint-plugin-oxlint": "^0.14.0", "eslint-plugin-prettier": "^5.2.1", "eslint-plugin-react": "^7.37.2", "eslint-plugin-react-compiler": "0.0.0-experimental-34d04b6-20241024", "eslint-plugin-react-hooks": "^5.0.0", "eslint-plugin-security": "^3.0.1", - "eslint-plugin-styled-components-a11y": "^2.1.35", - "eslint-plugin-testing-library": "^6.4.0", - "html-webpack-plugin": "^5.6.0", - "husky": "^9.1.6", + "eslint-plugin-styled-components-a11y": "^2.1.36", + "eslint-plugin-testing-library": "^7.0.0", + "html-webpack-plugin": "^5.6.3", + "husky": "^9.1.7", "jest": "^29.7.0", "jest-axe": "^9.0.0", "jest-canvas-mock": "^2.5.2", @@ -125,15 +125,15 @@ "karma-sourcemap-loader": "^0.4.0", "karma-webpack": "^5.0.1", "lint-staged": "^15.2.10", - "markdownlint-cli": "^0.42.0", - "mini-css-extract-plugin": "^2.9.0", + "markdownlint-cli": "^0.43.0", + "mini-css-extract-plugin": "^2.9.2", "mockdate": "^3.0.5", "npm-package-json-lint": "^8.0.0", "npm-run-all": "^4.1.5", - "oxlint": "^0.10.3", + "oxlint": "^0.14.0", "patch-package": "^8.0.0", "postcss-jsx": "^0.36.4", - "postcss-styled-syntax": "^0.6.4", + "postcss-styled-syntax": "^0.7.0", "postcss-syntax": "^0.36.2", "prettier": "^3.3.3", "puppeteer": "^21.9.0", @@ -153,17 +153,17 @@ "stylelint-prettier": "^5.0.2", "stylis-plugin-rtl": "^1.0.0", "terser-webpack-plugin": "^5.3.10", - "typescript": "^5.6.3", - "webpack": "^5.95.0", + "typescript": "^5.7.2", + "webpack": "^5.96.1", "webpack-bundle-analyzer": "^4.10.2", "webpack-cli": "^5.1.4", "webpack-dev-server": "^5.1.0", - "webpackbar": "^6.0.1", + "webpackbar": "^7.0.0", "worker-loader": "^3.0.8", "workspaces-run": "^1.0.2" }, "engines": { - "node": ">= 20", + "node": ">= 22", "npm": ">= 10" }, "workspaces": { @@ -2827,6 +2827,7 @@ "ppc64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "aix" @@ -2843,6 +2844,7 @@ "arm" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "android" @@ -2859,6 +2861,7 @@ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "android" @@ -2875,6 +2878,7 @@ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "android" @@ -2891,6 +2895,7 @@ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "darwin" @@ -2907,6 +2912,7 @@ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "darwin" @@ -2923,6 +2929,7 @@ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "freebsd" @@ -2939,6 +2946,7 @@ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "freebsd" @@ -2955,6 +2963,7 @@ "arm" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -2971,6 +2980,7 @@ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -2987,6 +2997,7 @@ "ia32" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -3003,6 +3014,7 @@ "loong64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -3019,6 +3031,7 @@ "mips64el" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -3035,6 +3048,7 @@ "ppc64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -3051,6 +3065,7 @@ "riscv64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -3067,6 +3082,7 @@ "s390x" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -3083,6 +3099,7 @@ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" @@ -3099,6 +3116,7 @@ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "netbsd" @@ -3115,6 +3133,7 @@ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "openbsd" @@ -3131,6 +3150,7 @@ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "openbsd" @@ -3147,6 +3167,7 @@ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "sunos" @@ -3163,6 +3184,7 @@ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "win32" @@ -3179,6 +3201,7 @@ "ia32" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "win32" @@ -3195,6 +3218,7 @@ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "win32" @@ -3204,9 +3228,9 @@ } }, "node_modules/@eslint-community/eslint-plugin-eslint-comments": { - "version": "4.4.0", - "resolved": "https://registry.npmjs.org/@eslint-community/eslint-plugin-eslint-comments/-/eslint-plugin-eslint-comments-4.4.0.tgz", - "integrity": "sha512-yljsWl5Qv3IkIRmJ38h3NrHXFCm4EUl55M8doGTF6hvzvFF8kRpextgSrg2dwHev9lzBZyafCr9RelGIyQm6fw==", + "version": "4.4.1", + "resolved": "https://registry.npmjs.org/@eslint-community/eslint-plugin-eslint-comments/-/eslint-plugin-eslint-comments-4.4.1.tgz", + "integrity": "sha512-lb/Z/MzbTf7CaVYM9WCFNQZ4L1yi3ev2fsFPF99h31ljhSEyUoyEsKsNWiU+qD1glbYTDJdqgyaLKtyTkkqtuQ==", "dev": true, "license": "MIT", "dependencies": { @@ -3269,10 +3293,11 @@ } }, "node_modules/@eslint-community/regexpp": { - "version": "4.9.0", - "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.9.0.tgz", - "integrity": "sha512-zJmuCWj2VLBt4c25CfBIbMZLGLyhkvs7LznyVX5HfpzeocThgIj5XQK4L+g3U36mMcx8bPMhGyPpwCATamC4jQ==", + "version": "4.12.1", + "resolved": "https://registry.npmjs.org/@eslint-community/regexpp/-/regexpp-4.12.1.tgz", + "integrity": "sha512-CCZCDJuduB9OUkFkY2IgppNZMi2lBQgD2qzwXkEia16cge2pijY/aXi96CJMquDMn3nJdlPV1A5KrJEXwfLNzQ==", "dev": true, + "license": "MIT", "engines": { "node": "^12.0.0 || ^14.0.0 || >=16.0.0" } @@ -4767,104 +4792,112 @@ } }, "node_modules/@oxlint/darwin-arm64": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/@oxlint/darwin-arm64/-/darwin-arm64-0.10.3.tgz", - "integrity": "sha512-1zcWSqr9DmhbSrV1SEZRywp81CNq8ZidIcFGB8tGUMnlBNYiHnxyHHh2GIZsr1C2exmkBUGXruM1P8eQ9BWGuQ==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@oxlint/darwin-arm64/-/darwin-arm64-0.14.0.tgz", + "integrity": "sha512-TnGzzJ5BWfj4d3GYdtiMNrCswr00i/f3UwUL5gD71J67nyMAagYwyJI5atCV8LKoa9DJnuc7//HfuPHhQoNKdA==", "cpu": [ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "darwin" ] }, "node_modules/@oxlint/darwin-x64": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/@oxlint/darwin-x64/-/darwin-x64-0.10.3.tgz", - "integrity": "sha512-lPAXCwYb+wZgjWAMhtPjGn7n1h8HvTulj6XCRyIgUu/aTGDRtnsae9IPXsJ9LJwYu5wyzkcWow0nhlIxkDaZ+w==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@oxlint/darwin-x64/-/darwin-x64-0.14.0.tgz", + "integrity": "sha512-MUbf9R2CjTuPQD+HOk9V+Aq05aWlzr2jj8cnIMUDiiwX2hTkprJKcoXyAIJp/OCDd1ufHpo9n7fKTyYtpJUFzA==", "cpu": [ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "darwin" ] }, "node_modules/@oxlint/linux-arm64-gnu": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/@oxlint/linux-arm64-gnu/-/linux-arm64-gnu-0.10.3.tgz", - "integrity": "sha512-OmzpNVRwhjuI/RtoG4ROrwxRICTLoBB3ua4/Mh2iC3RelOog2xhlAAJHenKtzgQXNmebWof/0EckFpMfID7fMw==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@oxlint/linux-arm64-gnu/-/linux-arm64-gnu-0.14.0.tgz", + "integrity": "sha512-ofWwFpdD8to59cjOVE+fgIS+uJLX5VbJkkYB2MCpahdzffiWTTvZCVU2TSDJxVr8VpXrF1E8SWDnmHNHzke4bg==", "cpu": [ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@oxlint/linux-arm64-musl": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/@oxlint/linux-arm64-musl/-/linux-arm64-musl-0.10.3.tgz", - "integrity": "sha512-QQzlIW6rKOoGZK19gz/kbAbIFROJEV6ER0smcoBA7FzwsQ/ji796qx3TdITelgJwJt5x+OG5ZHztIjyzC871ZQ==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@oxlint/linux-arm64-musl/-/linux-arm64-musl-0.14.0.tgz", + "integrity": "sha512-yypOsNETNE/8DQELHbw34It1Ab0HxfIooNjmK4YrJBCbVYqr6HOl/oHHb/KauZrAAfoABOMPu5G1igyXNgPvlg==", "cpu": [ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@oxlint/linux-x64-gnu": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/@oxlint/linux-x64-gnu/-/linux-x64-gnu-0.10.3.tgz", - "integrity": "sha512-m4ZUKsQNXxXmHUYBEaO7KN83DPVsLTq8KaRO4qj0Cs1RgD8O3YYCCDewVe8x/9yskQrCCTP4mL0G4IZgDJ3Gpg==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@oxlint/linux-x64-gnu/-/linux-x64-gnu-0.14.0.tgz", + "integrity": "sha512-E9ZSFo+phvUKM9+pjKCxx6GeT+DfWK8fPxupCpFljWD0zgZQKiXv1FY5+TOPjJqI7aMjLfGuC5VfGjVRgs87Ug==", "cpu": [ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@oxlint/linux-x64-musl": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/@oxlint/linux-x64-musl/-/linux-x64-musl-0.10.3.tgz", - "integrity": "sha512-XKvAUYxE9bHjvWE4wmOlIdaVQN7pzZAH3Rx1EFg0MfGBVjyDm+uf0P3so+gx2PowqvBnBneL9tth2AS3Bcjl6g==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@oxlint/linux-x64-musl/-/linux-x64-musl-0.14.0.tgz", + "integrity": "sha512-MmtNF/g0u15smzyYJd5QGlyhAU8V6ZMQrFAXGhoRo5AfWzbNyOOUFmJVNLa/yvs4F+1m7oEfaegxk3BeVyufPQ==", "cpu": [ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "linux" ] }, "node_modules/@oxlint/win32-arm64": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/@oxlint/win32-arm64/-/win32-arm64-0.10.3.tgz", - "integrity": "sha512-8xhYVvnwrveMHyXAgQAaDjJWFij4mZP6jtMlBIjk6pZSrjUzX+9o7Wh1zgH6kYApmcPDAzomYJLSYvyF5PzluA==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@oxlint/win32-arm64/-/win32-arm64-0.14.0.tgz", + "integrity": "sha512-67dJ57QImulc8qu9xuF5NsQAHvwr1N3Fpy1j/gaGZE973pEVoW9fFO88tnmY2L5SjWf9o3nHwti1tlU99JuOlw==", "cpu": [ "arm64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "win32" ] }, "node_modules/@oxlint/win32-x64": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/@oxlint/win32-x64/-/win32-x64-0.10.3.tgz", - "integrity": "sha512-dQiHruLd42aock1WHp5BFvRvaz+Pe436dQkcmlCVmInhmOjRpDEVKPUUWamrImV6S8VM63bn4Jp60vpprjJQdQ==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/@oxlint/win32-x64/-/win32-x64-0.14.0.tgz", + "integrity": "sha512-fw8IEW7osGYIgfEMEW4AqPg1q8/kZd0cpO51ixvekVOuhZNC8PX8Wdx97U+XTowOFrkCcr3+szR9PZEjKyR1FQ==", "cpu": [ "x64" ], "dev": true, + "license": "MIT", "optional": true, "os": [ "win32" @@ -5781,10 +5814,11 @@ } }, "node_modules/@rollup/plugin-dynamic-import-vars": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/@rollup/plugin-dynamic-import-vars/-/plugin-dynamic-import-vars-2.1.3.tgz", - "integrity": "sha512-9ZuItXkvbx0NUeEO0TMIYY7KAK/c7biumCTVrk6nwW81om7apA3/yju6JUm1pFMWmF/bZbyrom20NupRZWk9Wg==", + "version": "2.1.5", + "resolved": "https://registry.npmjs.org/@rollup/plugin-dynamic-import-vars/-/plugin-dynamic-import-vars-2.1.5.tgz", + "integrity": "sha512-Mymi24fd9hlRifdZV/jYIFj1dn99F34imiYu3KzlAcgBcRi3i9SucgW/VRo5SQ9K4NuQ7dCep6pFWgNyhRdFHQ==", "dev": true, + "license": "MIT", "dependencies": { "@rollup/pluginutils": "^5.0.1", "astring": "^1.8.5", @@ -5825,15 +5859,15 @@ } }, "node_modules/@rollup/plugin-node-resolve": { - "version": "15.2.3", - "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-15.2.3.tgz", - "integrity": "sha512-j/lym8nf5E21LwBT4Df1VD6hRO2L2iwUeUmP7litikRsVp1H6NWx20NEp0Y7su+7XGc476GnXXc4kFeZNGmaSQ==", + "version": "15.3.0", + "resolved": "https://registry.npmjs.org/@rollup/plugin-node-resolve/-/plugin-node-resolve-15.3.0.tgz", + "integrity": "sha512-9eO5McEICxMzJpDW9OnMYSv4Sta3hmt7VtBFz5zR9273suNOydOyq/FrGeGy+KsTRFm8w0SLVhzig2ILFT63Ag==", "dev": true, + "license": "MIT", "dependencies": { "@rollup/pluginutils": "^5.0.1", "@types/resolve": "1.20.2", "deepmerge": "^4.2.2", - "is-builtin-module": "^3.2.1", "is-module": "^1.0.0", "resolve": "^1.22.1" }, @@ -6028,12 +6062,13 @@ "integrity": "sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA==" }, "node_modules/@storybook/addon-a11y": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-a11y/-/addon-a11y-8.4.1.tgz", - "integrity": "sha512-yRT7sCTze91oRE03TOBu1/01He2eCuxQwFNLeACCEBd10tS+zCvSIql8+VWnuT2kIVLPsbZ/E2x+PNTerWciuw==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-a11y/-/addon-a11y-8.4.6.tgz", + "integrity": "sha512-Z6x/yfStplSROgmBTtiJ8LJgTqPgzW3Q7KXi+l+KoZ0pht6Nz9cYfcyygLCaftBk1ZaL7SDDIrjCP0H1NwfYiQ==", "dev": true, + "license": "MIT", "dependencies": { - "@storybook/addon-highlight": "8.4.1", + "@storybook/addon-highlight": "8.4.6", "axe-core": "^4.2.0" }, "funding": { @@ -6041,14 +6076,15 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-actions": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-actions/-/addon-actions-8.4.1.tgz", - "integrity": "sha512-D6KohTIA4JCHNol1X7Whp4LpOVU4cS5FfyOorwYo/WIzpHrUYc4Pw/+ex6DOmU/kgrk14mr8d9obVehKW7iNtA==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-actions/-/addon-actions-8.4.6.tgz", + "integrity": "sha512-vbplwjMj7UXbdzoFhQkqFHLQAPJX8OVGTM9Q+yjuWDHViaKKUlgRWp0jclT7aIDNJQU2a6wJbTimHgJeF16Vhg==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/global": "^5.0.0", "@types/uuid": "^9.0.1", @@ -6061,20 +6097,22 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-actions/node_modules/@types/uuid": { "version": "9.0.8", "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-9.0.8.tgz", "integrity": "sha512-jg+97EGIcY9AGHJJRaaPVgetKDsrTgbRjQ5Msgjh/DQKEFl0DtyRr/VCOyD1T2R1MNeWPK/u7JoGhlDZnKBAfA==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/@storybook/addon-backgrounds": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-backgrounds/-/addon-backgrounds-8.4.1.tgz", - "integrity": "sha512-DIT1E9R9Sds8KTC+0m2X5cVa8hTNcKY1XKYTI9QdzQvdZzOt+K93AJqq2x8k5glingqUVpB6v2fSDmCUXp4+4g==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-backgrounds/-/addon-backgrounds-8.4.6.tgz", + "integrity": "sha512-RSjJ3iElxlQXebZrz1s5LeoLpAXr9LAGifX7w0abMzN5sg6QSwNeUHko2eT3V57M3k1Fa/5Eelso/QBQifFEog==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/global": "^5.0.0", "memoizerific": "^1.11.3", @@ -6085,14 +6123,15 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-controls": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-controls/-/addon-controls-8.4.1.tgz", - "integrity": "sha512-3ahbYdDx7iFUd4X1KelMSuPqVnladc0bH4m6DQZyN+wkRxdRlOD6iOGuOe2qi1Gv0b2VuVAt253i75tK/TPNLw==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-controls/-/addon-controls-8.4.6.tgz", + "integrity": "sha512-70pEGWh0C2g8s0DYsISElOzsMbQS6p/K9iU5EqfotDF+hvEqstjsV/bTbR5f3OK4vR/7Gxamk7j8RVd14Nql6A==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/global": "^5.0.0", "dequal": "^2.0.2", @@ -6103,19 +6142,20 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-docs": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-docs/-/addon-docs-8.4.1.tgz", - "integrity": "sha512-yPD/NssJf7pMJzaKvma02C6yX8ykPVnEjhRbNYcBNM8s8g/cT5JkROvIB+FOb4T81yhdfbGg9bGkpAXGX270IQ==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-docs/-/addon-docs-8.4.6.tgz", + "integrity": "sha512-olxz61W7PW/EsXrKhLrYbI3rn9GMBhY3KIOF/6tumbRkh0Siu/qe4EAImaV9NNwiC1R7+De/1OIVMY6o0EIZVw==", "dev": true, + "license": "MIT", "dependencies": { "@mdx-js/react": "^3.0.0", - "@storybook/blocks": "8.4.1", - "@storybook/csf-plugin": "8.4.1", - "@storybook/react-dom-shim": "8.4.1", + "@storybook/blocks": "8.4.6", + "@storybook/csf-plugin": "8.4.6", + "@storybook/react-dom-shim": "8.4.6", "react": "^16.8.0 || ^17.0.0 || ^18.0.0", "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0", "ts-dedent": "^2.0.0" @@ -6125,24 +6165,25 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-essentials": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-essentials/-/addon-essentials-8.4.1.tgz", - "integrity": "sha512-Hmb5fpVzQgyCacDtHeE7HJqIfolzeOnedsLyJVYVpKns/uOWXqpDuU8Fc0s3yTjr1QPIRKtbqV1STxoyXj2how==", - "dev": true, - "dependencies": { - "@storybook/addon-actions": "8.4.1", - "@storybook/addon-backgrounds": "8.4.1", - "@storybook/addon-controls": "8.4.1", - "@storybook/addon-docs": "8.4.1", - "@storybook/addon-highlight": "8.4.1", - "@storybook/addon-measure": "8.4.1", - "@storybook/addon-outline": "8.4.1", - "@storybook/addon-toolbars": "8.4.1", - "@storybook/addon-viewport": "8.4.1", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-essentials/-/addon-essentials-8.4.6.tgz", + "integrity": "sha512-TbFqyvWFUKw8LBpVcZuGQydzVB/3kSuHxDHi+Wj3Qas3cxBl7+w4/HjwomT2D2Tni1dZ1uPDOsAtNLmwp1POsg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@storybook/addon-actions": "8.4.6", + "@storybook/addon-backgrounds": "8.4.6", + "@storybook/addon-controls": "8.4.6", + "@storybook/addon-docs": "8.4.6", + "@storybook/addon-highlight": "8.4.6", + "@storybook/addon-measure": "8.4.6", + "@storybook/addon-outline": "8.4.6", + "@storybook/addon-toolbars": "8.4.6", + "@storybook/addon-viewport": "8.4.6", "ts-dedent": "^2.0.0" }, "funding": { @@ -6150,14 +6191,15 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-highlight": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-highlight/-/addon-highlight-8.4.1.tgz", - "integrity": "sha512-BBkUd6+i7lUEWZwoJDlUIwrs7EXkk+EoREUi27iiA1Lilw+NNhoC3kcBmj3+MccjRyeMeIWAgYyXF5qeB2s/JQ==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-highlight/-/addon-highlight-8.4.6.tgz", + "integrity": "sha512-m8wedbqDMbwkP99dNHkHAiAUkx5E7FEEEyLPX1zfkhZWOGtTkavXHH235SGp50zD75LQ6eC/BvgegrzxSQa9Wg==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/global": "^5.0.0" }, @@ -6166,14 +6208,15 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-links": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-links/-/addon-links-8.4.1.tgz", - "integrity": "sha512-wg83rNKo6mq5apV7f1qMn4q8xZ8wVx/42EEWxTOmnM37Q5kXltEBu+rUyBpPNDU8zBuXr/MRKIhK5h2k4WfWcg==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-links/-/addon-links-8.4.6.tgz", + "integrity": "sha512-1KoG9ytEWWwdF/dheu1O0dayQTMsHw++Qk8afqw7bwW1Cxz5LuAJH5ZscFWMiE5f4Xq1NgaJdeAUaIavyoOcdg==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/csf": "^0.1.11", "@storybook/global": "^5.0.0", @@ -6185,7 +6228,7 @@ }, "peerDependencies": { "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", - "storybook": "^8.4.1" + "storybook": "^8.4.6" }, "peerDependenciesMeta": { "react": { @@ -6194,10 +6237,11 @@ } }, "node_modules/@storybook/addon-measure": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-measure/-/addon-measure-8.4.1.tgz", - "integrity": "sha512-Pg1ROj29hKt7grL/HmbIJ10WrkZf1Unx35SsP373bkPQ1ggYi9oxGqtfNchTF2zCb1xUpIikLYSJgkwdjqWxhA==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-measure/-/addon-measure-8.4.6.tgz", + "integrity": "sha512-N2IRpr39g5KpexCAS1vIHJT+phc9Yilwm3PULds2rQ66VMTbkxobXJDdt0NS05g5n9/eDniroNQwdCeLg4tkpw==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/global": "^5.0.0", "tiny-invariant": "^1.3.1" @@ -6207,14 +6251,15 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-outline": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-outline/-/addon-outline-8.4.1.tgz", - "integrity": "sha512-LPZ0gGHfbru66Lkw1whnc3F/r1hfnoORBoF98Hp+cjH34gR4t8te6xq5qSiupRUULGdSLdBRs/4EGRBeELfVjQ==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-outline/-/addon-outline-8.4.6.tgz", + "integrity": "sha512-EhcWx8OpK85HxQulLWzpWUHEwQpDYuAiKzsFj9ivAbfeljkIWNTG04mierfaH1xX016uL9RtLJL/zwBS5ChnFg==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/global": "^5.0.0", "ts-dedent": "^2.0.0" @@ -6224,27 +6269,29 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-toolbars": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-toolbars/-/addon-toolbars-8.4.1.tgz", - "integrity": "sha512-yrzX6BFeJM5KFY0+ZAYfRax2QgWi2e5vF6yPz+MGIPr4nhHay0wTkOHhkBhIPBjQO9x0vqc7MS2EBDydCBWqlg==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-toolbars/-/addon-toolbars-8.4.6.tgz", + "integrity": "sha512-+Xao/uGa8FnYsyUiREUkYXWNysm3Aba8tL/Bwd+HufHtdiKJGa9lrXaC7VLCqBUaEjwqM3aaPwqEWIROsthmPQ==", "dev": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-viewport": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/addon-viewport/-/addon-viewport-8.4.1.tgz", - "integrity": "sha512-O6DcuUfXQTytjl7mj4ld4ZX9x2pUUWKUx1TxiuMuH0EKb612RyYcdpXpDQQwsIzLV/f2BOetk9jmO2/MymfbWQ==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/addon-viewport/-/addon-viewport-8.4.6.tgz", + "integrity": "sha512-BuQll5YzOCpMS7p5Rsw9wcmi8hTnEKyg6+qAbkZNfiZ2JhXCa1GFUqX725fF1whpYVQULtkQxU8r+vahoRn7Yg==", "dev": true, + "license": "MIT", "dependencies": { "memoizerific": "^1.11.3" }, @@ -6253,7 +6300,7 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/addon-webpack5-compiler-babel": { @@ -6270,10 +6317,11 @@ } }, "node_modules/@storybook/blocks": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/blocks/-/blocks-8.4.1.tgz", - "integrity": "sha512-C4w5T5fhg0iONXozHQ1bh9im2Lr1BiY7Bj/9XoFjkc5YeCzxlMpujFA6Nmo4ToUFW90QbvKN7/QVhbrtY9O1Jg==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/blocks/-/blocks-8.4.6.tgz", + "integrity": "sha512-Gzbx8hM7ZQIHlQELcFIMbY1v+r1Po4mlinq0QVPtKS4lBcW4eZIsesbxOaL+uFNrxb583TLFzXo0DbRPzS46sg==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/csf": "^0.1.11", "@storybook/icons": "^1.2.12", @@ -6286,7 +6334,7 @@ "peerDependencies": { "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", - "storybook": "^8.4.1" + "storybook": "^8.4.6" }, "peerDependenciesMeta": { "react": { @@ -6298,12 +6346,13 @@ } }, "node_modules/@storybook/builder-webpack5": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/builder-webpack5/-/builder-webpack5-8.4.1.tgz", - "integrity": "sha512-rqSJcxcYiQyceNFSrT9qnI6hrW4/petb1n+oN8nG5HrRsl0zxOVzamMVyNzZxrAMKvq+VMJtLe1rQi8FnJNunw==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/builder-webpack5/-/builder-webpack5-8.4.6.tgz", + "integrity": "sha512-/ZInCFk2myJZinnAU05bATe+9iJn3+YRoxl+CUpYljxzsjoqb7iAwaNaMNolZCDOnMj24Kg2Pt87WtzAhu+ilw==", "dev": true, + "license": "MIT", "dependencies": { - "@storybook/core-webpack": "8.4.1", + "@storybook/core-webpack": "8.4.6", "@types/node": "^22.0.0", "@types/semver": "^7.3.4", "browser-assert": "^1.2.1", @@ -6334,7 +6383,7 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" }, "peerDependenciesMeta": { "typescript": { @@ -6347,6 +6396,7 @@ "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.17.1.tgz", "integrity": "sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==", "dev": true, + "license": "MIT", "dependencies": { "fast-deep-equal": "^3.1.3", "fast-uri": "^3.0.1", @@ -6363,6 +6413,7 @@ "resolved": "https://registry.npmjs.org/ajv-formats/-/ajv-formats-2.1.1.tgz", "integrity": "sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==", "dev": true, + "license": "MIT", "dependencies": { "ajv": "^8.0.0" }, @@ -6380,6 +6431,7 @@ "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-5.1.0.tgz", "integrity": "sha512-YCS/JNFAUyr5vAuhk1DWm1CBxRHW9LbJ2ozWeemrIqpbsqKjHVxYPyi5GC0rjZIT5JxJ3virVTS8wk4i/Z+krw==", "dev": true, + "license": "MIT", "dependencies": { "fast-deep-equal": "^3.1.3" }, @@ -6391,13 +6443,15 @@ "version": "2.0.20", "resolved": "https://registry.npmjs.org/colorette/-/colorette-2.0.20.tgz", "integrity": "sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/@storybook/builder-webpack5/node_modules/css-loader": { "version": "6.11.0", "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-6.11.0.tgz", "integrity": "sha512-CTJ+AEQJjq5NzLga5pE39qdiSV56F8ywCIsqNIRF0r7BDgWsN25aazToqAFg7ZrtA/U016xudB3ffgweORxX7g==", "dev": true, + "license": "MIT", "dependencies": { "icss-utils": "^5.1.0", "postcss": "^8.4.33", @@ -6432,13 +6486,15 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/@storybook/builder-webpack5/node_modules/schema-utils": { "version": "4.2.0", "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-4.2.0.tgz", "integrity": "sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw==", "dev": true, + "license": "MIT", "dependencies": { "@types/json-schema": "^7.0.9", "ajv": "^8.9.0", @@ -6458,6 +6514,7 @@ "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-6.1.3.tgz", "integrity": "sha512-A4ChP0Qj8oGociTs6UdlRUGANIGrCDL3y+pmQMc+dSsraXHCatFpmMey4mYELA+juqwUqwQsUgJJISXl1KWmiw==", "dev": true, + "license": "MIT", "dependencies": { "colorette": "^2.0.10", "memfs": "^3.4.12", @@ -6582,10 +6639,11 @@ } }, "node_modules/@storybook/client-logger": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/client-logger/-/client-logger-8.4.1.tgz", - "integrity": "sha512-r1SsV3FjDsaRcyFMJK4qNz2g503Wu4yheYRiSOL8SpTgpD1OyHhAhgBRJ6WFuGZIMdyujwEj2GuzFshKDV9cCA==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/client-logger/-/client-logger-8.4.6.tgz", + "integrity": "sha512-vFY61X7vIyqjg6R4nBHKEYn4nnpciBwYChkJ5zzVjcT+ZA6Lh2Vxw8s2iAIZjqB4DwxC9GfJ1faFKVzlcTuxLA==", "dev": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/storybook" @@ -6595,10 +6653,11 @@ } }, "node_modules/@storybook/components": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/components/-/components-8.4.1.tgz", - "integrity": "sha512-bMPclbBhrWxhFlwqrC/h4fPLl05ouoi5D8SkQTHjeVxWN9eDnMVi76xM0YDct302Z3f0x5S3plIulp+4XRxrvg==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/components/-/components-8.4.6.tgz", + "integrity": "sha512-9tKSJJCyFT5RZMRGyozTBJkr9C9Yfk1nuOE9XbDEE1Z+3/IypKR9+iwc5mfNBStDNY+rxtYWNLKBb5GPR2yhzA==", "dev": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/storybook" @@ -6608,10 +6667,11 @@ } }, "node_modules/@storybook/core": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/core/-/core-8.4.1.tgz", - "integrity": "sha512-q3Q4OFBj7MHHbIFYk/Beejlqv5j7CC3+VWhGcr0TK3SGvdCIZ7EliYuc5JIOgDlEPsnTIk+lkgWI4LAA9mLzSw==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/core/-/core-8.4.6.tgz", + "integrity": "sha512-WeojVtHy0/t50tzw/15S+DLzKsj8BN9yWdo3vJMvm+nflLFvfq1XvD9WGOWeaFp8E/o3AP+4HprXG0r42KEJtA==", "dev": true, + "license": "MIT", "dependencies": { "@storybook/csf": "^0.1.11", "better-opn": "^3.0.2", @@ -6639,10 +6699,11 @@ } }, "node_modules/@storybook/core-webpack": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/core-webpack/-/core-webpack-8.4.1.tgz", - "integrity": "sha512-TptbDGaj9a8wJMF4g+C8t02CXl4BSd0BA/qGWBvzn3j4FJqeQ/m8elOXLYZrPbQKI6PjP0J4ayHkXdX2h0/tUw==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/core-webpack/-/core-webpack-8.4.6.tgz", + "integrity": "sha512-5NE4pUy0iHKc8UKHm7A7SikxSMOO92udl7kcBUlQKwcAgrAk1rFpvfXGodDb48AVgfK+07qAOSjBm7GcZ7X1jw==", "dev": true, + "license": "MIT", "dependencies": { "@types/node": "^22.0.0", "ts-dedent": "^2.0.0" @@ -6652,7 +6713,7 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/core/node_modules/ws": { @@ -6660,6 +6721,7 @@ "resolved": "https://registry.npmjs.org/ws/-/ws-8.18.0.tgz", "integrity": "sha512-8VbfWfHLbbwu3+N6OKsOMpBdT4kXPDDB9cJk2bJ6mh9ucxdlnNvH1e+roYkKmN9Nxw2yjz7VzeO9oOz2zJ04Pw==", "dev": true, + "license": "MIT", "engines": { "node": ">=10.0.0" }, @@ -6677,19 +6739,21 @@ } }, "node_modules/@storybook/csf": { - "version": "0.1.11", - "resolved": "https://registry.npmjs.org/@storybook/csf/-/csf-0.1.11.tgz", - "integrity": "sha512-dHYFQH3mA+EtnCkHXzicbLgsvzYjcDJ1JWsogbItZogkPHgSJM/Wr71uMkcvw8v9mmCyP4NpXJuu6bPoVsOnzg==", + "version": "0.1.12", + "resolved": "https://registry.npmjs.org/@storybook/csf/-/csf-0.1.12.tgz", + "integrity": "sha512-9/exVhabisyIVL0VxTCxo01Tdm8wefIXKXfltAPTSr8cbLn5JAxGQ6QV3mjdecLGEOucfoVhAKtJfVHxEK1iqw==", "dev": true, + "license": "MIT", "dependencies": { "type-fest": "^2.19.0" } }, "node_modules/@storybook/csf-plugin": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/csf-plugin/-/csf-plugin-8.4.1.tgz", - "integrity": "sha512-MdQkyq6mJ31lBsWCG9VNtx8O0oLSc5h4kvWDPyIP6Dn58K0Hv2z9qvxxSvtFjXA7ES9X+ivjorTke1kearifhg==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/csf-plugin/-/csf-plugin-8.4.6.tgz", + "integrity": "sha512-JDIT0czC4yMgKGNf39KTZr3zm5MusAZdn6LBrTfvWb7CrTCR4iVHa4lp2yb7EJk41vHsBec0QUYDDuiFH/vV0g==", "dev": true, + "license": "MIT", "dependencies": { "unplugin": "^1.3.1" }, @@ -6698,14 +6762,15 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/csf-tools": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/csf-tools/-/csf-tools-8.4.1.tgz", - "integrity": "sha512-WfcUPdTYZJCqiVzrmpqHZxwfKraZUoYk3JNkkXBRcTxaJx0jkcv1zl6NTm4JDrCJNU97f8zrwLD+Zyi69DXCTg==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/csf-tools/-/csf-tools-8.4.6.tgz", + "integrity": "sha512-hNcPQJ0BqXGYDvVF4hwMgO0ExZCNhqM+ogQuMlp2NJCCNDyJYRclQltfCo0+KnwcW6Hmb3xraDmAnxijWJUYeA==", "dev": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/storybook" @@ -6737,6 +6802,7 @@ "resolved": "https://registry.npmjs.org/@storybook/icons/-/icons-1.2.12.tgz", "integrity": "sha512-UxgyK5W3/UV4VrI3dl6ajGfHM4aOqMAkFLWe2KibeQudLf6NJpDrDMSHwZj+3iKC4jFU7dkKbbtH2h/al4sW3Q==", "dev": true, + "license": "MIT", "engines": { "node": ">=14.0.0" }, @@ -6746,10 +6812,11 @@ } }, "node_modules/@storybook/manager-api": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/manager-api/-/manager-api-8.4.1.tgz", - "integrity": "sha512-7hb2k4zsp6lREGZbQ85QOlsC8EIMZXuY9Pg12VUgaZd+LmLjLuaqtrxRz3SwIgIWsRpFun9AHO0X37DmYNGTSw==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/manager-api/-/manager-api-8.4.6.tgz", + "integrity": "sha512-TsXlQ5m5rTl2KNT9icPFyy822AqXrx1QplZBt/L7cFn7SpqQKDeSta21FH7MG0piAvzOweXebVSqKngJ6cCWWQ==", "dev": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/storybook" @@ -6759,13 +6826,14 @@ } }, "node_modules/@storybook/preset-react-webpack": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/preset-react-webpack/-/preset-react-webpack-8.4.1.tgz", - "integrity": "sha512-Cm+u3/avHdoneEFHnvFRMPAElWtxyyOkcVsWHkM0rVhj7bxkzOyrBrenm1GiB8NamRosumsEnhREYFo2lthU2A==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/preset-react-webpack/-/preset-react-webpack-8.4.6.tgz", + "integrity": "sha512-4AdsRug6NaWras/bbcFx7KEnJY5GLt3REPlSqMtZwhdY3f7LF0W++Wyo/F2ly82f57welquGURyL+YxjQ9yFkA==", "dev": true, + "license": "MIT", "dependencies": { - "@storybook/core-webpack": "8.4.1", - "@storybook/react": "8.4.1", + "@storybook/core-webpack": "8.4.6", + "@storybook/react": "8.4.6", "@storybook/react-docgen-typescript-plugin": "1.0.6--canary.9.0c3f3b7.0", "@types/node": "^22.0.0", "@types/semver": "^7.3.4", @@ -6787,7 +6855,7 @@ "peerDependencies": { "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", - "storybook": "^8.4.1" + "storybook": "^8.4.6" }, "peerDependenciesMeta": { "typescript": { @@ -6800,6 +6868,7 @@ "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", "integrity": "sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==", "dev": true, + "license": "MIT", "dependencies": { "locate-path": "^6.0.0", "path-exists": "^4.0.0" @@ -6816,6 +6885,7 @@ "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-6.0.0.tgz", "integrity": "sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==", "dev": true, + "license": "MIT", "dependencies": { "p-locate": "^5.0.0" }, @@ -6831,6 +6901,7 @@ "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", "integrity": "sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==", "dev": true, + "license": "MIT", "dependencies": { "yocto-queue": "^0.1.0" }, @@ -6846,6 +6917,7 @@ "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-5.0.0.tgz", "integrity": "sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==", "dev": true, + "license": "MIT", "dependencies": { "p-limit": "^3.0.2" }, @@ -6861,6 +6933,7 @@ "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", "integrity": "sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==", "dev": true, + "license": "MIT", "engines": { "node": ">=4" } @@ -6870,6 +6943,7 @@ "resolved": "https://registry.npmjs.org/tsconfig-paths/-/tsconfig-paths-4.2.0.tgz", "integrity": "sha512-NoZ4roiN7LnbKn9QqE1amc9DJfzvZXxF4xDavcOWt1BPkdx+m+0gJuPM+S0vCe7zTJMYUP0R8pO2XMr+Y8oLIg==", "dev": true, + "license": "MIT", "dependencies": { "json5": "^2.2.2", "minimist": "^1.2.6", @@ -6880,10 +6954,11 @@ } }, "node_modules/@storybook/preview-api": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/preview-api/-/preview-api-8.4.1.tgz", - "integrity": "sha512-VdnESYfXCUasNtMd5s1Q8DPqMnAUdpROn8mE8UAD79Cy7DSNesI1q0SATuJqh5iYCT/+3Tpjfghsr2zC/mOh8w==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/preview-api/-/preview-api-8.4.6.tgz", + "integrity": "sha512-LbD+lR1FGvWaJBXteVx5xdgs1x1D7tyidBg2CsW2ex+cP0iJ176JgjPfutZxlWOfQnhfRYNnJ3WKoCIfxFOTKA==", "dev": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/storybook" @@ -6893,17 +6968,18 @@ } }, "node_modules/@storybook/react": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/react/-/react-8.4.1.tgz", - "integrity": "sha512-ZwszrzV47nWQEZ0X4LyNgv5OFq4iy/7LpmxW6IncIO7PWm70OWG2BVtKFNsNQx0LY+hOtllWZbvg06mPQzahFA==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/react/-/react-8.4.6.tgz", + "integrity": "sha512-QAT23beoYNLhFGAXPimtuMErvpcI7eZbZ4AlLqW1fhiTZrRYw06cjC1bs9H3tODMcHH9LS5p3Wz9b29jtV2XGw==", "dev": true, + "license": "MIT", "dependencies": { - "@storybook/components": "8.4.1", + "@storybook/components": "8.4.6", "@storybook/global": "^5.0.0", - "@storybook/manager-api": "8.4.1", - "@storybook/preview-api": "8.4.1", - "@storybook/react-dom-shim": "8.4.1", - "@storybook/theming": "8.4.1" + "@storybook/manager-api": "8.4.6", + "@storybook/preview-api": "8.4.6", + "@storybook/react-dom-shim": "8.4.6", + "@storybook/theming": "8.4.6" }, "engines": { "node": ">=18.0.0" @@ -6913,10 +6989,10 @@ "url": "https://opencollective.com/storybook" }, "peerDependencies": { - "@storybook/test": "8.4.1", + "@storybook/test": "8.4.6", "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", - "storybook": "^8.4.1", + "storybook": "^8.4.6", "typescript": ">= 4.2.x" }, "peerDependenciesMeta": { @@ -6933,6 +7009,7 @@ "resolved": "https://registry.npmjs.org/@storybook/react-docgen-typescript-plugin/-/react-docgen-typescript-plugin-1.0.6--canary.9.0c3f3b7.0.tgz", "integrity": "sha512-KUqXC3oa9JuQ0kZJLBhVdS4lOneKTOopnNBK4tUAgoxWQ3u/IjzdueZjFr7gyBrXMoU6duutk3RQR9u8ZpYJ4Q==", "dev": true, + "license": "MIT", "dependencies": { "debug": "^4.1.1", "endent": "^2.0.1", @@ -6948,10 +7025,11 @@ } }, "node_modules/@storybook/react-dom-shim": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/react-dom-shim/-/react-dom-shim-8.4.1.tgz", - "integrity": "sha512-XhvuqkpqtcUjDA8XE4osq140SCddX3VHMdj+IwlrMdoSl32CAya01TH5YDDx6YMy6hM/QQbyVKaemG7RB/oU4Q==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/react-dom-shim/-/react-dom-shim-8.4.6.tgz", + "integrity": "sha512-f7RM8GO++fqMxbjNdEzeGS1P821jXuwRnAraejk5hyjB5SqetauFxMwoFYEYfJXPaLX2qIubnIJ78hdJ/IBaEA==", "dev": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/storybook" @@ -6959,18 +7037,19 @@ "peerDependencies": { "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", - "storybook": "^8.4.1" + "storybook": "^8.4.6" } }, "node_modules/@storybook/react-webpack5": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/react-webpack5/-/react-webpack5-8.4.1.tgz", - "integrity": "sha512-P4ZedIAx5SmkyKwTH5zbwG+en+DeeQfOT1nw0sL0aybVPGcwV+swyzcCnJFnmn0UIhSxuZ1InjN36nDZ6821mw==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/react-webpack5/-/react-webpack5-8.4.6.tgz", + "integrity": "sha512-qUCOUoYW09voRhk0PzEZpZz6F5Ek9aHvVto8KW3lyYEuk6qujqUTNO6Y/X7hMraVt/C3l0+Ds4D5LEmxNBvd8g==", "dev": true, + "license": "MIT", "dependencies": { - "@storybook/builder-webpack5": "8.4.1", - "@storybook/preset-react-webpack": "8.4.1", - "@storybook/react": "8.4.1", + "@storybook/builder-webpack5": "8.4.6", + "@storybook/preset-react-webpack": "8.4.6", + "@storybook/react": "8.4.6", "@types/node": "^22.0.0" }, "engines": { @@ -6983,7 +7062,7 @@ "peerDependencies": { "react": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", "react-dom": "^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0-beta", - "storybook": "^8.4.1", + "storybook": "^8.4.6", "typescript": ">= 4.2.x" }, "peerDependenciesMeta": { @@ -6993,10 +7072,11 @@ } }, "node_modules/@storybook/theming": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/@storybook/theming/-/theming-8.4.1.tgz", - "integrity": "sha512-Sz24isryVFZaVahXkjgnCsMAQqQeeKg41AtLsldlYdesIo6fr5tc6/SkTUy+CYadK4Dkhqp+vVRDnwToYYRGhA==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/@storybook/theming/-/theming-8.4.6.tgz", + "integrity": "sha512-q7vDPN/mgj7cXIVQ9R1/V75hrzNgKkm2G0LjMo57//9/djQ+7LxvBsR1iScbFIRSEqppvMiBFzkts+2uXidySA==", "dev": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/storybook" @@ -7832,9 +7912,9 @@ } }, "node_modules/@testing-library/jest-dom": { - "version": "6.6.2", - "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.6.2.tgz", - "integrity": "sha512-P6GJD4yqc9jZLbe98j/EkyQDTPgqftohZF5FBkHY5BUERZmcf4HeO2k0XaefEg329ux2p21i1A1DmyQ1kKw2Jw==", + "version": "6.6.3", + "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-6.6.3.tgz", + "integrity": "sha512-IteBhl4XqYNkM54f4ejhLRJiZNqcSCoXUOG2CPK7qbD322KjQozM4kHQOfkG2oln9b9HTYqs+Sae8vBATubxxA==", "dev": true, "license": "MIT", "dependencies": { @@ -8250,7 +8330,8 @@ "version": "0.0.9", "resolved": "https://registry.npmjs.org/@types/doctrine/-/doctrine-0.0.9.tgz", "integrity": "sha512-eOIHzCUSH7SMfonMG1LsC2f8vxBFtho6NGBznK41R84YzPuvSBzrhEps33IsQiOW9+VL6NQ9DbjQJznk/S4uRA==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/@types/draft-js": { "version": "0.11.9", @@ -8276,18 +8357,28 @@ "resolved": "https://registry.npmjs.org/@types/eslint/-/eslint-8.56.10.tgz", "integrity": "sha512-Shavhk87gCtY2fhXDctcfS3e6FdxWkCx1iUZ9eEUbh7rTqlZT0/IzOkCOVt0fCjcFuZ9FPYfuezTBImfHCDBGQ==", "dev": true, - "optional": true, - "peer": true, "dependencies": { "@types/estree": "*", "@types/json-schema": "*" } }, + "node_modules/@types/eslint-scope": { + "version": "3.7.7", + "resolved": "https://registry.npmjs.org/@types/eslint-scope/-/eslint-scope-3.7.7.tgz", + "integrity": "sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==", + "dev": true, + "license": "MIT", + "dependencies": { + "@types/eslint": "*", + "@types/estree": "*" + } + }, "node_modules/@types/estree": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.5.tgz", - "integrity": "sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==", - "dev": true + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/@types/estree/-/estree-1.0.6.tgz", + "integrity": "sha512-AYnb1nQyY49te+VRAVgmzfcgjYS91mY5P0TKUDCLEM+gNnA+3T6rWITXRLYCpahpqSQbN5cE+gHpnPyXjHWxcw==", + "dev": true, + "license": "MIT" }, "node_modules/@types/express": { "version": "4.17.21", @@ -8511,9 +8602,10 @@ "integrity": "sha512-F0oAily9Q9QQpv9JKxKn0zMKfOo36KHCW7myYsmUyf2t0g+sBTbG3UleTPoguHdE1z3GLFr3p7/wiOio52QFjQ==" }, "node_modules/@types/node": { - "version": "22.8.6", - "resolved": "https://registry.npmjs.org/@types/node/-/node-22.8.6.tgz", - "integrity": "sha512-tosuJYKrIqjQIlVCM4PEGxOmyg3FCPa/fViuJChnGeEIhjA46oy8FMVoF9su1/v8PNs2a8Q0iFNyOx0uOF91nw==", + "version": "22.9.3", + "resolved": "https://registry.npmjs.org/@types/node/-/node-22.9.3.tgz", + "integrity": "sha512-F3u1fs/fce3FFk+DAxbxc78DF8x0cY09RRL8GnXLmkJ1jvx3TtPdWoTT5/NiYfI5ASqXBmfqJi9dZ3gxMx4lzw==", + "license": "MIT", "dependencies": { "undici-types": "~6.19.8" } @@ -8826,33 +8918,32 @@ } }, "node_modules/@typescript-eslint/eslint-plugin": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-6.19.1.tgz", - "integrity": "sha512-roQScUGFruWod9CEyoV5KlCYrubC/fvG8/1zXuT0WTcxX87GnMMmnksMwSg99lo1xiKrBzw2icsJPMAw1OtKxg==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-8.16.0.tgz", + "integrity": "sha512-5YTHKV8MYlyMI6BaEG7crQ9BhSc8RxzshOReKwZwRWN0+XvvTOm+L/UYLCYxFpfwYuAAqhxiq4yae0CMFwbL7Q==", "dev": true, + "license": "MIT", "dependencies": { - "@eslint-community/regexpp": "^4.5.1", - "@typescript-eslint/scope-manager": "6.19.1", - "@typescript-eslint/type-utils": "6.19.1", - "@typescript-eslint/utils": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1", - "debug": "^4.3.4", + "@eslint-community/regexpp": "^4.10.0", + "@typescript-eslint/scope-manager": "8.16.0", + "@typescript-eslint/type-utils": "8.16.0", + "@typescript-eslint/utils": "8.16.0", + "@typescript-eslint/visitor-keys": "8.16.0", "graphemer": "^1.4.0", - "ignore": "^5.2.4", + "ignore": "^5.3.1", "natural-compare": "^1.4.0", - "semver": "^7.5.4", - "ts-api-utils": "^1.0.1" + "ts-api-utils": "^1.3.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/typescript-eslint" }, "peerDependencies": { - "@typescript-eslint/parser": "^6.0.0 || ^6.0.0-alpha", - "eslint": "^7.0.0 || ^8.0.0" + "@typescript-eslint/parser": "^8.0.0 || ^8.0.0-alpha.0", + "eslint": "^8.57.0 || ^9.0.0" }, "peerDependenciesMeta": { "typescript": { @@ -8861,16 +8952,17 @@ } }, "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/scope-manager": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.19.1.tgz", - "integrity": "sha512-4CdXYjKf6/6aKNMSly/BP4iCSOpvMmqtDzRtqFyyAae3z5kkqEjKndR5vDHL8rSuMIIWP8u4Mw4VxLyxZW6D5w==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.16.0.tgz", + "integrity": "sha512-mwsZWubQvBki2t5565uxF0EYvG+FwdFb8bMtDuGQLdCCnGPrDEDvm1gtfynuKlnpzeBRqdFCkMf9jg1fnAK8sg==", "dev": true, + "license": "MIT", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1" + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/visitor-keys": "8.16.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -8878,12 +8970,13 @@ } }, "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/types": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.19.1.tgz", - "integrity": "sha512-6+bk6FEtBhvfYvpHsDgAL3uo4BfvnTnoge5LrrCj2eJN8g3IJdLTD4B/jK3Q6vo4Ql/Hoip9I8aB6fF+6RfDqg==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.16.0.tgz", + "integrity": "sha512-NzrHj6thBAOSE4d9bsuRNMvk+BvaQvmY4dDglgkgGC0EW/tB3Kelnp3tAKH87GEwzoxgeQn9fNGRyFJM/xd+GQ==", "dev": true, + "license": "MIT", "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -8891,22 +8984,23 @@ } }, "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/typescript-estree": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.19.1.tgz", - "integrity": "sha512-aFdAxuhzBFRWhy+H20nYu19+Km+gFfwNO4TEqyszkMcgBDYQjmPJ61erHxuT2ESJXhlhrO7I5EFIlZ+qGR8oVA==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.16.0.tgz", + "integrity": "sha512-E2+9IzzXMc1iaBy9zmo+UYvluE3TW7bCGWSF41hVWUE01o8nzr1rvOQYSxelxr6StUvRcTMe633eY8mXASMaNw==", "dev": true, + "license": "BSD-2-Clause", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1", + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/visitor-keys": "8.16.0", "debug": "^4.3.4", - "globby": "^11.1.0", + "fast-glob": "^3.3.2", "is-glob": "^4.0.3", - "minimatch": "9.0.3", - "semver": "^7.5.4", - "ts-api-utils": "^1.0.1" + "minimatch": "^9.0.4", + "semver": "^7.6.0", + "ts-api-utils": "^1.3.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -8919,41 +9013,45 @@ } }, "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/utils": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.19.1.tgz", - "integrity": "sha512-JvjfEZuP5WoMqwh9SPAPDSHSg9FBHHGhjPugSRxu5jMfjvBpq5/sGTD+9M9aQ5sh6iJ8AY/Kk/oUYVEMAPwi7w==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.16.0.tgz", + "integrity": "sha512-C1zRy/mOL8Pj157GiX4kaw7iyRLKfJXBR3L82hk5kS/GyHcOFmy4YUq/zfZti72I9wnuQtA/+xzft4wCC8PJdA==", "dev": true, + "license": "MIT", "dependencies": { "@eslint-community/eslint-utils": "^4.4.0", - "@types/json-schema": "^7.0.12", - "@types/semver": "^7.5.0", - "@typescript-eslint/scope-manager": "6.19.1", - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/typescript-estree": "6.19.1", - "semver": "^7.5.4" + "@typescript-eslint/scope-manager": "8.16.0", + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/typescript-estree": "8.16.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/typescript-eslint" }, "peerDependencies": { - "eslint": "^7.0.0 || ^8.0.0" + "eslint": "^8.57.0 || ^9.0.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } } }, "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/visitor-keys": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.19.1.tgz", - "integrity": "sha512-gkdtIO+xSO/SmI0W68DBg4u1KElmIUo3vXzgHyGPs6cxgB0sa3TlptRAAE0hUY1hM6FcDKEv7aIwiTGm76cXfQ==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.16.0.tgz", + "integrity": "sha512-pq19gbaMOmFE3CbL0ZB8J8BFCo2ckfHBfaIsaOZgBIF4EoISJIdLX5xRhd0FGB0LlHReNRuzoJoMGpTjq8F2CQ==", "dev": true, + "license": "MIT", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "eslint-visitor-keys": "^3.4.1" + "@typescript-eslint/types": "8.16.0", + "eslint-visitor-keys": "^4.2.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -8965,36 +9063,40 @@ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", "dev": true, + "license": "MIT", "dependencies": { "balanced-match": "^1.0.0" } }, "node_modules/@typescript-eslint/eslint-plugin/node_modules/eslint-visitor-keys": { - "version": "3.4.3", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", - "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz", + "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==", "dev": true, + "license": "Apache-2.0", "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "url": "https://opencollective.com/eslint" } }, "node_modules/@typescript-eslint/eslint-plugin/node_modules/ignore": { - "version": "5.2.4", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.2.4.tgz", - "integrity": "sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==", + "version": "5.3.2", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.2.tgz", + "integrity": "sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==", "dev": true, + "license": "MIT", "engines": { "node": ">= 4" } }, "node_modules/@typescript-eslint/eslint-plugin/node_modules/minimatch": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", - "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", "dev": true, + "license": "ISC", "dependencies": { "brace-expansion": "^2.0.1" }, @@ -9006,26 +9108,27 @@ } }, "node_modules/@typescript-eslint/parser": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-6.19.1.tgz", - "integrity": "sha512-WEfX22ziAh6pRE9jnbkkLGp/4RhTpffr2ZK5bJ18M8mIfA8A+k97U9ZyaXCEJRlmMHh7R9MJZWXp/r73DzINVQ==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-8.16.0.tgz", + "integrity": "sha512-D7DbgGFtsqIPIFMPJwCad9Gfi/hC0PWErRRHFnaCWoEDYi5tQUDiJCTmGUbBiLzjqAck4KcXt9Ayj0CNlIrF+w==", "dev": true, + "license": "BSD-2-Clause", "dependencies": { - "@typescript-eslint/scope-manager": "6.19.1", - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/typescript-estree": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1", + "@typescript-eslint/scope-manager": "8.16.0", + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/typescript-estree": "8.16.0", + "@typescript-eslint/visitor-keys": "8.16.0", "debug": "^4.3.4" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/typescript-eslint" }, "peerDependencies": { - "eslint": "^7.0.0 || ^8.0.0" + "eslint": "^8.57.0 || ^9.0.0" }, "peerDependenciesMeta": { "typescript": { @@ -9034,16 +9137,17 @@ } }, "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/scope-manager": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.19.1.tgz", - "integrity": "sha512-4CdXYjKf6/6aKNMSly/BP4iCSOpvMmqtDzRtqFyyAae3z5kkqEjKndR5vDHL8rSuMIIWP8u4Mw4VxLyxZW6D5w==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.16.0.tgz", + "integrity": "sha512-mwsZWubQvBki2t5565uxF0EYvG+FwdFb8bMtDuGQLdCCnGPrDEDvm1gtfynuKlnpzeBRqdFCkMf9jg1fnAK8sg==", "dev": true, + "license": "MIT", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1" + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/visitor-keys": "8.16.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -9051,12 +9155,13 @@ } }, "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/types": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.19.1.tgz", - "integrity": "sha512-6+bk6FEtBhvfYvpHsDgAL3uo4BfvnTnoge5LrrCj2eJN8g3IJdLTD4B/jK3Q6vo4Ql/Hoip9I8aB6fF+6RfDqg==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.16.0.tgz", + "integrity": "sha512-NzrHj6thBAOSE4d9bsuRNMvk+BvaQvmY4dDglgkgGC0EW/tB3Kelnp3tAKH87GEwzoxgeQn9fNGRyFJM/xd+GQ==", "dev": true, + "license": "MIT", "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -9064,22 +9169,23 @@ } }, "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/typescript-estree": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.19.1.tgz", - "integrity": "sha512-aFdAxuhzBFRWhy+H20nYu19+Km+gFfwNO4TEqyszkMcgBDYQjmPJ61erHxuT2ESJXhlhrO7I5EFIlZ+qGR8oVA==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.16.0.tgz", + "integrity": "sha512-E2+9IzzXMc1iaBy9zmo+UYvluE3TW7bCGWSF41hVWUE01o8nzr1rvOQYSxelxr6StUvRcTMe633eY8mXASMaNw==", "dev": true, + "license": "BSD-2-Clause", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1", + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/visitor-keys": "8.16.0", "debug": "^4.3.4", - "globby": "^11.1.0", + "fast-glob": "^3.3.2", "is-glob": "^4.0.3", - "minimatch": "9.0.3", - "semver": "^7.5.4", - "ts-api-utils": "^1.0.1" + "minimatch": "^9.0.4", + "semver": "^7.6.0", + "ts-api-utils": "^1.3.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -9092,16 +9198,17 @@ } }, "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/visitor-keys": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.19.1.tgz", - "integrity": "sha512-gkdtIO+xSO/SmI0W68DBg4u1KElmIUo3vXzgHyGPs6cxgB0sa3TlptRAAE0hUY1hM6FcDKEv7aIwiTGm76cXfQ==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.16.0.tgz", + "integrity": "sha512-pq19gbaMOmFE3CbL0ZB8J8BFCo2ckfHBfaIsaOZgBIF4EoISJIdLX5xRhd0FGB0LlHReNRuzoJoMGpTjq8F2CQ==", "dev": true, + "license": "MIT", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "eslint-visitor-keys": "^3.4.1" + "@typescript-eslint/types": "8.16.0", + "eslint-visitor-keys": "^4.2.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -9113,27 +9220,30 @@ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", "dev": true, + "license": "MIT", "dependencies": { "balanced-match": "^1.0.0" } }, "node_modules/@typescript-eslint/parser/node_modules/eslint-visitor-keys": { - "version": "3.4.3", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", - "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz", + "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==", "dev": true, + "license": "Apache-2.0", "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "url": "https://opencollective.com/eslint" } }, "node_modules/@typescript-eslint/parser/node_modules/minimatch": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", - "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", "dev": true, + "license": "ISC", "dependencies": { "brace-expansion": "^2.0.1" }, @@ -9163,25 +9273,26 @@ } }, "node_modules/@typescript-eslint/type-utils": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-6.19.1.tgz", - "integrity": "sha512-0vdyld3ecfxJuddDjACUvlAeYNrHP/pDeQk2pWBR2ESeEzQhg52DF53AbI9QCBkYE23lgkhLCZNkHn2hEXXYIg==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-8.16.0.tgz", + "integrity": "sha512-IqZHGG+g1XCWX9NyqnI/0CX5LL8/18awQqmkZSl2ynn8F76j579dByc0jhfVSnSnhf7zv76mKBQv9HQFKvDCgg==", "dev": true, + "license": "MIT", "dependencies": { - "@typescript-eslint/typescript-estree": "6.19.1", - "@typescript-eslint/utils": "6.19.1", + "@typescript-eslint/typescript-estree": "8.16.0", + "@typescript-eslint/utils": "8.16.0", "debug": "^4.3.4", - "ts-api-utils": "^1.0.1" + "ts-api-utils": "^1.3.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/typescript-eslint" }, "peerDependencies": { - "eslint": "^7.0.0 || ^8.0.0" + "eslint": "^8.57.0 || ^9.0.0" }, "peerDependenciesMeta": { "typescript": { @@ -9190,16 +9301,17 @@ } }, "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/scope-manager": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.19.1.tgz", - "integrity": "sha512-4CdXYjKf6/6aKNMSly/BP4iCSOpvMmqtDzRtqFyyAae3z5kkqEjKndR5vDHL8rSuMIIWP8u4Mw4VxLyxZW6D5w==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.16.0.tgz", + "integrity": "sha512-mwsZWubQvBki2t5565uxF0EYvG+FwdFb8bMtDuGQLdCCnGPrDEDvm1gtfynuKlnpzeBRqdFCkMf9jg1fnAK8sg==", "dev": true, + "license": "MIT", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1" + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/visitor-keys": "8.16.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -9207,12 +9319,13 @@ } }, "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/types": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.19.1.tgz", - "integrity": "sha512-6+bk6FEtBhvfYvpHsDgAL3uo4BfvnTnoge5LrrCj2eJN8g3IJdLTD4B/jK3Q6vo4Ql/Hoip9I8aB6fF+6RfDqg==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.16.0.tgz", + "integrity": "sha512-NzrHj6thBAOSE4d9bsuRNMvk+BvaQvmY4dDglgkgGC0EW/tB3Kelnp3tAKH87GEwzoxgeQn9fNGRyFJM/xd+GQ==", "dev": true, + "license": "MIT", "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -9220,22 +9333,23 @@ } }, "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/typescript-estree": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.19.1.tgz", - "integrity": "sha512-aFdAxuhzBFRWhy+H20nYu19+Km+gFfwNO4TEqyszkMcgBDYQjmPJ61erHxuT2ESJXhlhrO7I5EFIlZ+qGR8oVA==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.16.0.tgz", + "integrity": "sha512-E2+9IzzXMc1iaBy9zmo+UYvluE3TW7bCGWSF41hVWUE01o8nzr1rvOQYSxelxr6StUvRcTMe633eY8mXASMaNw==", "dev": true, + "license": "BSD-2-Clause", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/visitor-keys": "6.19.1", + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/visitor-keys": "8.16.0", "debug": "^4.3.4", - "globby": "^11.1.0", + "fast-glob": "^3.3.2", "is-glob": "^4.0.3", - "minimatch": "9.0.3", - "semver": "^7.5.4", - "ts-api-utils": "^1.0.1" + "minimatch": "^9.0.4", + "semver": "^7.6.0", + "ts-api-utils": "^1.3.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -9248,41 +9362,45 @@ } }, "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/utils": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.19.1.tgz", - "integrity": "sha512-JvjfEZuP5WoMqwh9SPAPDSHSg9FBHHGhjPugSRxu5jMfjvBpq5/sGTD+9M9aQ5sh6iJ8AY/Kk/oUYVEMAPwi7w==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.16.0.tgz", + "integrity": "sha512-C1zRy/mOL8Pj157GiX4kaw7iyRLKfJXBR3L82hk5kS/GyHcOFmy4YUq/zfZti72I9wnuQtA/+xzft4wCC8PJdA==", "dev": true, + "license": "MIT", "dependencies": { "@eslint-community/eslint-utils": "^4.4.0", - "@types/json-schema": "^7.0.12", - "@types/semver": "^7.5.0", - "@typescript-eslint/scope-manager": "6.19.1", - "@typescript-eslint/types": "6.19.1", - "@typescript-eslint/typescript-estree": "6.19.1", - "semver": "^7.5.4" + "@typescript-eslint/scope-manager": "8.16.0", + "@typescript-eslint/types": "8.16.0", + "@typescript-eslint/typescript-estree": "8.16.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/typescript-eslint" }, "peerDependencies": { - "eslint": "^7.0.0 || ^8.0.0" + "eslint": "^8.57.0 || ^9.0.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } } }, "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/visitor-keys": { - "version": "6.19.1", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.19.1.tgz", - "integrity": "sha512-gkdtIO+xSO/SmI0W68DBg4u1KElmIUo3vXzgHyGPs6cxgB0sa3TlptRAAE0hUY1hM6FcDKEv7aIwiTGm76cXfQ==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.16.0.tgz", + "integrity": "sha512-pq19gbaMOmFE3CbL0ZB8J8BFCo2ckfHBfaIsaOZgBIF4EoISJIdLX5xRhd0FGB0LlHReNRuzoJoMGpTjq8F2CQ==", "dev": true, + "license": "MIT", "dependencies": { - "@typescript-eslint/types": "6.19.1", - "eslint-visitor-keys": "^3.4.1" + "@typescript-eslint/types": "8.16.0", + "eslint-visitor-keys": "^4.2.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "type": "opencollective", @@ -9294,27 +9412,30 @@ "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", "dev": true, + "license": "MIT", "dependencies": { "balanced-match": "^1.0.0" } }, "node_modules/@typescript-eslint/type-utils/node_modules/eslint-visitor-keys": { - "version": "3.4.3", - "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-3.4.3.tgz", - "integrity": "sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==", + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz", + "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==", "dev": true, + "license": "Apache-2.0", "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" }, "funding": { "url": "https://opencollective.com/eslint" } }, "node_modules/@typescript-eslint/type-utils/node_modules/minimatch": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", - "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", "dev": true, + "license": "ISC", "dependencies": { "brace-expansion": "^2.0.1" }, @@ -9528,148 +9649,163 @@ "link": true }, "node_modules/@webassemblyjs/ast": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.12.1.tgz", - "integrity": "sha512-EKfMUOPRRUTy5UII4qJDGPpqfwjOmZ5jeGFwid9mnoqIFK+e0vqoi1qH56JpmZSzEL53jKnNzScdmftJyG5xWg==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.14.1.tgz", + "integrity": "sha512-nuBEDgQfm1ccRp/8bCQrx1frohyufl4JlbMMZ4P1wpeOfDhF6FQkxZJ1b/e+PLwr6X1Nhw6OLme5usuBWYBvuQ==", "dev": true, + "license": "MIT", "dependencies": { - "@webassemblyjs/helper-numbers": "1.11.6", - "@webassemblyjs/helper-wasm-bytecode": "1.11.6" + "@webassemblyjs/helper-numbers": "1.13.2", + "@webassemblyjs/helper-wasm-bytecode": "1.13.2" } }, "node_modules/@webassemblyjs/floating-point-hex-parser": { - "version": "1.11.6", - "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.11.6.tgz", - "integrity": "sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==", - "dev": true + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.13.2.tgz", + "integrity": "sha512-6oXyTOzbKxGH4steLbLNOu71Oj+C8Lg34n6CqRvqfS2O71BxY6ByfMDRhBytzknj9yGUPVJ1qIKhRlAwO1AovA==", + "dev": true, + "license": "MIT" }, "node_modules/@webassemblyjs/helper-api-error": { - "version": "1.11.6", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.11.6.tgz", - "integrity": "sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==", - "dev": true + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.13.2.tgz", + "integrity": "sha512-U56GMYxy4ZQCbDZd6JuvvNV/WFildOjsaWD3Tzzvmw/mas3cXzRJPMjP83JqEsgSbyrmaGjBfDtV7KDXV9UzFQ==", + "dev": true, + "license": "MIT" }, "node_modules/@webassemblyjs/helper-buffer": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.12.1.tgz", - "integrity": "sha512-nzJwQw99DNDKr9BVCOZcLuJJUlqkJh+kVzVl6Fmq/tI5ZtEyWT1KZMyOXltXLZJmDtvLCDgwsyrkohEtopTXCw==", - "dev": true + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.14.1.tgz", + "integrity": "sha512-jyH7wtcHiKssDtFPRB+iQdxlDf96m0E39yb0k5uJVhFGleZFoNw1c4aeIcVUPPbXUVJ94wwnMOAqUHyzoEPVMA==", + "dev": true, + "license": "MIT" }, "node_modules/@webassemblyjs/helper-numbers": { - "version": "1.11.6", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.11.6.tgz", - "integrity": "sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-numbers/-/helper-numbers-1.13.2.tgz", + "integrity": "sha512-FE8aCmS5Q6eQYcV3gI35O4J789wlQA+7JrqTTpJqn5emA4U2hvwJmvFRC0HODS+3Ye6WioDklgd6scJ3+PLnEA==", "dev": true, + "license": "MIT", "dependencies": { - "@webassemblyjs/floating-point-hex-parser": "1.11.6", - "@webassemblyjs/helper-api-error": "1.11.6", + "@webassemblyjs/floating-point-hex-parser": "1.13.2", + "@webassemblyjs/helper-api-error": "1.13.2", "@xtuc/long": "4.2.2" } }, "node_modules/@webassemblyjs/helper-wasm-bytecode": { - "version": "1.11.6", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.11.6.tgz", - "integrity": "sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==", - "dev": true + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.13.2.tgz", + "integrity": "sha512-3QbLKy93F0EAIXLh0ogEVR6rOubA9AoZ+WRYhNbFyuB70j3dRdwH9g+qXhLAO0kiYGlg3TxDV+I4rQTr/YNXkA==", + "dev": true, + "license": "MIT" }, "node_modules/@webassemblyjs/helper-wasm-section": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.12.1.tgz", - "integrity": "sha512-Jif4vfB6FJlUlSbgEMHUyk1j234GTNG9dBJ4XJdOySoj518Xj0oGsNi59cUQF4RRMS9ouBUxDDdyBVfPTypa5g==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.14.1.tgz", + "integrity": "sha512-ds5mXEqTJ6oxRoqjhWDU83OgzAYjwsCV8Lo/N+oRsNDmx/ZDpqalmrtgOMkHwxsG0iI//3BwWAErYRHtgn0dZw==", "dev": true, + "license": "MIT", "dependencies": { - "@webassemblyjs/ast": "1.12.1", - "@webassemblyjs/helper-buffer": "1.12.1", - "@webassemblyjs/helper-wasm-bytecode": "1.11.6", - "@webassemblyjs/wasm-gen": "1.12.1" + "@webassemblyjs/ast": "1.14.1", + "@webassemblyjs/helper-buffer": "1.14.1", + "@webassemblyjs/helper-wasm-bytecode": "1.13.2", + "@webassemblyjs/wasm-gen": "1.14.1" } }, "node_modules/@webassemblyjs/ieee754": { - "version": "1.11.6", - "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.11.6.tgz", - "integrity": "sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.13.2.tgz", + "integrity": "sha512-4LtOzh58S/5lX4ITKxnAK2USuNEvpdVV9AlgGQb8rJDHaLeHciwG4zlGr0j/SNWlr7x3vO1lDEsuePvtcDNCkw==", "dev": true, + "license": "MIT", "dependencies": { "@xtuc/ieee754": "^1.2.0" } }, "node_modules/@webassemblyjs/leb128": { - "version": "1.11.6", - "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.11.6.tgz", - "integrity": "sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.13.2.tgz", + "integrity": "sha512-Lde1oNoIdzVzdkNEAWZ1dZ5orIbff80YPdHx20mrHwHrVNNTjNr8E3xz9BdpcGqRQbAEa+fkrCb+fRFTl/6sQw==", "dev": true, + "license": "Apache-2.0", "dependencies": { "@xtuc/long": "4.2.2" } }, "node_modules/@webassemblyjs/utf8": { - "version": "1.11.6", - "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.11.6.tgz", - "integrity": "sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==", - "dev": true + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.13.2.tgz", + "integrity": "sha512-3NQWGjKTASY1xV5m7Hr0iPeXD9+RDobLll3T9d2AO+g3my8xy5peVyjSag4I50mR1bBSN/Ct12lo+R9tJk0NZQ==", + "dev": true, + "license": "MIT" }, "node_modules/@webassemblyjs/wasm-edit": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.12.1.tgz", - "integrity": "sha512-1DuwbVvADvS5mGnXbE+c9NfA8QRcZ6iKquqjjmR10k6o+zzsRVesil54DKexiowcFCPdr/Q0qaMgB01+SQ1u6g==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.14.1.tgz", + "integrity": "sha512-RNJUIQH/J8iA/1NzlE4N7KtyZNHi3w7at7hDjvRNm5rcUXa00z1vRz3glZoULfJ5mpvYhLybmVcwcjGrC1pRrQ==", "dev": true, + "license": "MIT", "dependencies": { - "@webassemblyjs/ast": "1.12.1", - "@webassemblyjs/helper-buffer": "1.12.1", - "@webassemblyjs/helper-wasm-bytecode": "1.11.6", - "@webassemblyjs/helper-wasm-section": "1.12.1", - "@webassemblyjs/wasm-gen": "1.12.1", - "@webassemblyjs/wasm-opt": "1.12.1", - "@webassemblyjs/wasm-parser": "1.12.1", - "@webassemblyjs/wast-printer": "1.12.1" + "@webassemblyjs/ast": "1.14.1", + "@webassemblyjs/helper-buffer": "1.14.1", + "@webassemblyjs/helper-wasm-bytecode": "1.13.2", + "@webassemblyjs/helper-wasm-section": "1.14.1", + "@webassemblyjs/wasm-gen": "1.14.1", + "@webassemblyjs/wasm-opt": "1.14.1", + "@webassemblyjs/wasm-parser": "1.14.1", + "@webassemblyjs/wast-printer": "1.14.1" } }, "node_modules/@webassemblyjs/wasm-gen": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.12.1.tgz", - "integrity": "sha512-TDq4Ojh9fcohAw6OIMXqiIcTq5KUXTGRkVxbSo1hQnSy6lAM5GSdfwWeSxpAo0YzgsgF182E/U0mDNhuA0tW7w==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.14.1.tgz", + "integrity": "sha512-AmomSIjP8ZbfGQhumkNvgC33AY7qtMCXnN6bL2u2Js4gVCg8fp735aEiMSBbDR7UQIj90n4wKAFUSEd0QN2Ukg==", "dev": true, + "license": "MIT", "dependencies": { - "@webassemblyjs/ast": "1.12.1", - "@webassemblyjs/helper-wasm-bytecode": "1.11.6", - "@webassemblyjs/ieee754": "1.11.6", - "@webassemblyjs/leb128": "1.11.6", - "@webassemblyjs/utf8": "1.11.6" + "@webassemblyjs/ast": "1.14.1", + "@webassemblyjs/helper-wasm-bytecode": "1.13.2", + "@webassemblyjs/ieee754": "1.13.2", + "@webassemblyjs/leb128": "1.13.2", + "@webassemblyjs/utf8": "1.13.2" } }, "node_modules/@webassemblyjs/wasm-opt": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.12.1.tgz", - "integrity": "sha512-Jg99j/2gG2iaz3hijw857AVYekZe2SAskcqlWIZXjji5WStnOpVoat3gQfT/Q5tb2djnCjBtMocY/Su1GfxPBg==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.14.1.tgz", + "integrity": "sha512-PTcKLUNvBqnY2U6E5bdOQcSM+oVP/PmrDY9NzowJjislEjwP/C4an2303MCVS2Mg9d3AJpIGdUFIQQWbPds0Sw==", "dev": true, + "license": "MIT", "dependencies": { - "@webassemblyjs/ast": "1.12.1", - "@webassemblyjs/helper-buffer": "1.12.1", - "@webassemblyjs/wasm-gen": "1.12.1", - "@webassemblyjs/wasm-parser": "1.12.1" + "@webassemblyjs/ast": "1.14.1", + "@webassemblyjs/helper-buffer": "1.14.1", + "@webassemblyjs/wasm-gen": "1.14.1", + "@webassemblyjs/wasm-parser": "1.14.1" } }, "node_modules/@webassemblyjs/wasm-parser": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.12.1.tgz", - "integrity": "sha512-xikIi7c2FHXysxXe3COrVUPSheuBtpcfhbpFj4gmu7KRLYOzANztwUU0IbsqvMqzuNK2+glRGWCEqZo1WCLyAQ==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.14.1.tgz", + "integrity": "sha512-JLBl+KZ0R5qB7mCnud/yyX08jWFw5MsoalJ1pQ4EdFlgj9VdXKGuENGsiCIjegI1W7p91rUlcB/LB5yRJKNTcQ==", "dev": true, + "license": "MIT", "dependencies": { - "@webassemblyjs/ast": "1.12.1", - "@webassemblyjs/helper-api-error": "1.11.6", - "@webassemblyjs/helper-wasm-bytecode": "1.11.6", - "@webassemblyjs/ieee754": "1.11.6", - "@webassemblyjs/leb128": "1.11.6", - "@webassemblyjs/utf8": "1.11.6" + "@webassemblyjs/ast": "1.14.1", + "@webassemblyjs/helper-api-error": "1.13.2", + "@webassemblyjs/helper-wasm-bytecode": "1.13.2", + "@webassemblyjs/ieee754": "1.13.2", + "@webassemblyjs/leb128": "1.13.2", + "@webassemblyjs/utf8": "1.13.2" } }, "node_modules/@webassemblyjs/wast-printer": { - "version": "1.12.1", - "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.12.1.tgz", - "integrity": "sha512-+X4WAlOisVWQMikjbcvY2e0rwPsKQ9F688lksZhBcPycBBuii3O7m8FACbDMWDojpAqvjIncrG8J0XHKyQfVeA==", + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.14.1.tgz", + "integrity": "sha512-kPSSXE6De1XOR820C90RIo2ogvZG+c3KiHzqUoO/F34Y2shGzesfqv7o57xrxovZJH/MetF5UjroJ/R/3isoiw==", "dev": true, + "license": "MIT", "dependencies": { - "@webassemblyjs/ast": "1.12.1", + "@webassemblyjs/ast": "1.14.1", "@xtuc/long": "4.2.2" } }, @@ -9900,14 +10036,14 @@ } }, "node_modules/@wordpress/element": { - "version": "6.10.0", - "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-6.10.0.tgz", - "integrity": "sha512-7zW+14vHqEn45nszSLMUqE5IbzOtvgUUgF56qlMhwabpG4l/zhaj3gO3wLDI19C13ih1vOdSjzPc3At4fB3tRQ==", + "version": "6.12.0", + "resolved": "https://registry.npmjs.org/@wordpress/element/-/element-6.12.0.tgz", + "integrity": "sha512-iMRk4AcpYo5KCvpTx2YQn5rGFz/nQ5EjL19X7mPFs3J8ZLGM0CDWP7ieQZjlMynRUXZjrrdSvp3ggQN8xDkZrA==", "dependencies": { "@babel/runtime": "7.25.7", "@types/react": "^18.2.79", "@types/react-dom": "^18.2.25", - "@wordpress/escape-html": "^3.10.0", + "@wordpress/escape-html": "*", "change-case": "^4.1.2", "is-plain-object": "^5.0.0", "react": "^18.3.0", @@ -10527,13 +10663,15 @@ "version": "1.2.0", "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==", - "dev": true + "dev": true, + "license": "BSD-3-Clause" }, "node_modules/@xtuc/long": { "version": "4.2.2", "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==", - "dev": true + "dev": true, + "license": "Apache-2.0" }, "node_modules/@yarnpkg/lockfile": { "version": "1.1.0", @@ -10889,6 +11027,16 @@ "node": ">=4" } }, + "node_modules/ansis": { + "version": "3.3.2", + "resolved": "https://registry.npmjs.org/ansis/-/ansis-3.3.2.tgz", + "integrity": "sha512-cFthbBlt+Oi0i9Pv/j6YdVWJh54CtjGACaMPCIrEV4Ha7HWsIjXDwseYV79TIL0B4+KfSwD5S70PeQDkPUd1rA==", + "dev": true, + "license": "ISC", + "engines": { + "node": ">=15" + } + }, "node_modules/anymatch": { "version": "3.1.2", "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.2.tgz", @@ -11883,6 +12031,7 @@ "resolved": "https://registry.npmjs.org/better-opn/-/better-opn-3.0.2.tgz", "integrity": "sha512-aVNobHnJqLiUelTaHat9DZ1qM2w0C0Eym4LPI/3JxOnSokGVdsl1T1kN7TFvsEAD8G47A6VKQ0TVHqbBnYMJlQ==", "dev": true, + "license": "MIT", "dependencies": { "open": "^8.0.4" }, @@ -11895,6 +12044,7 @@ "resolved": "https://registry.npmjs.org/open/-/open-8.4.2.tgz", "integrity": "sha512-7x81NCL719oNbsq/3mh+hVrAWmFuEYUqrq/Iw3kUzH8ReypT9QQ0BLoJS7/G9k6N81XjW4qHWtjWwe/9eLy1EQ==", "dev": true, + "license": "MIT", "dependencies": { "define-lazy-prop": "^2.0.0", "is-docker": "^2.1.1", @@ -11908,15 +12058,13 @@ } }, "node_modules/big.js": { - "version": "6.2.1", - "resolved": "https://registry.npmjs.org/big.js/-/big.js-6.2.1.tgz", - "integrity": "sha512-bCtHMwL9LeDIozFn+oNhhFoq+yQ3BNdnsLSASUxLciOb1vgvpHsIO1dsENiGMgbb4SkP5TrzWzRiLddn8ahVOQ==", + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", + "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", + "dev": true, + "license": "MIT", "engines": { "node": "*" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/bigjs" } }, "node_modules/binary-extensions": { @@ -12116,18 +12264,6 @@ "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==" }, - "node_modules/builtin-modules": { - "version": "3.3.0", - "resolved": "https://registry.npmjs.org/builtin-modules/-/builtin-modules-3.3.0.tgz", - "integrity": "sha512-zhaCDicdLuWN5UbN5IMnFqNMhNfo919sH85y2/ea+5Yg9TsTkeZxpL+JLbp6cgYFS4sRLp3YV4S6yDuqVWHYOw==", - "dev": true, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/bundle-name": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/bundle-name/-/bundle-name-4.1.0.tgz", @@ -12302,6 +12438,7 @@ "resolved": "https://registry.npmjs.org/case-sensitive-paths-webpack-plugin/-/case-sensitive-paths-webpack-plugin-2.4.0.tgz", "integrity": "sha512-roIFONhcxog0JSSWbvVAh3OocukmSgpqOH6YpMkCvav/ySIV3JKg4Dc8vYtQjYi/UxpNE36r/9v+VqTQqgkYmw==", "dev": true, + "license": "MIT", "engines": { "node": ">=4" } @@ -12410,10 +12547,11 @@ } }, "node_modules/chrome-trace-event": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz", - "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==", + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.4.tgz", + "integrity": "sha512-rNjApaLzuwaOTjCiT8lSDdGN1APCiqkChLMJxJPWLunPAt5fy8xgU9/jNOchV84wfIxrA0lRQB7oCT8jrn/wrQ==", "dev": true, + "license": "MIT", "engines": { "node": ">=6.0" } @@ -12958,7 +13096,8 @@ "version": "1.0.0", "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", "integrity": "sha512-xFxOwqIzR/e1k1gLiWEophSCMqXcwVHIH7akf7b/vxcUeGunlj3hvZaaqxwHsTgn+IndtkQJgSztIDWeumWJDQ==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/content-disposition": { "version": "0.5.4", @@ -13032,10 +13171,11 @@ } }, "node_modules/core-js": { - "version": "3.38.1", - "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.38.1.tgz", - "integrity": "sha512-OP35aUorbU3Zvlx7pjsFdu1rGNnD4pgw/CWoYzRY3t2EzoVT7shKHY1dlAy3f41cGIO7ZDPQimhGFTlEYkG/Hw==", + "version": "3.39.0", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.39.0.tgz", + "integrity": "sha512-raM0ew0/jJUqkJ0E6e8UDtl+y/7ktFivgWvqw8dNSQeNWoSDLvQ1H/RN3aPXB9tBd4/FhyR4RDPGhsNIMsAn7g==", "hasInstallScript": true, + "license": "MIT", "funding": { "type": "opencollective", "url": "https://opencollective.com/core-js" @@ -13927,7 +14067,8 @@ "version": "0.7.0", "resolved": "https://registry.npmjs.org/dedent/-/dedent-0.7.0.tgz", "integrity": "sha512-Q6fKUPqnAHAyhiUgFU7BUzLiv0kd8saH9al7tnu5Q/okj6dnupxyTgFIBjVzJATdfIAm9NAsvXNzjaKa+bxVyA==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/deep-equal": { "version": "2.2.0", @@ -14029,6 +14170,7 @@ "resolved": "https://registry.npmjs.org/define-lazy-prop/-/define-lazy-prop-2.0.0.tgz", "integrity": "sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==", "dev": true, + "license": "MIT", "engines": { "node": ">=8" } @@ -14606,6 +14748,7 @@ "resolved": "https://registry.npmjs.org/endent/-/endent-2.1.0.tgz", "integrity": "sha512-r8VyPX7XL8U01Xgnb1CjZ3XV+z90cXIJ9JPE/R9SEC9vpw2P6CfsRPJmp20DppC5N7ZAMCmjYkJIa744Iyg96w==", "dev": true, + "license": "MIT", "dependencies": { "dedent": "^0.7.0", "fast-json-parse": "^1.0.3", @@ -14665,6 +14808,7 @@ "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.17.1.tgz", "integrity": "sha512-LMHl3dXhTcfv8gM4kEzIUeTQ+7fpdA0l2tUf34BddXPkz2A5xJ5L/Pchd5BL6rdccM9QGvu0sWZzK1Z1t4wwyg==", "dev": true, + "license": "MIT", "dependencies": { "graceful-fs": "^4.2.4", "tapable": "^2.2.0" @@ -14938,6 +15082,7 @@ "integrity": "sha512-FuLPevChGDshgSicjisSooU0cemp/sGXR841D5LHMB7mTVOmsEHcAxaH3irL53+8YDIeVNQEySh4DaYU/iuPqQ==", "dev": true, "hasInstallScript": true, + "license": "MIT", "bin": { "esbuild": "bin/esbuild" }, @@ -14976,6 +15121,7 @@ "resolved": "https://registry.npmjs.org/esbuild-register/-/esbuild-register-3.6.0.tgz", "integrity": "sha512-H2/S7Pm8a9CL1uhp9OvjwrBh5Pvx0H8qVOxNu8Wed9Y7qv56MPtq+GGM8RJpq6glYJn9Wspr8uw7l55uyinNeg==", "dev": true, + "license": "MIT", "dependencies": { "debug": "^4.3.4" }, @@ -15258,9 +15404,9 @@ } }, "node_modules/eslint-plugin-jest": { - "version": "28.8.3", - "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-28.8.3.tgz", - "integrity": "sha512-HIQ3t9hASLKm2IhIOqnu+ifw7uLZkIlR7RYNv7fMcEi/p0CIiJmfriStQS2LDkgtY4nyLbIZAD+JL347Yc2ETQ==", + "version": "28.9.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-28.9.0.tgz", + "integrity": "sha512-rLu1s1Wf96TgUUxSw6loVIkNtUjq1Re7A9QdCCHSohnvXEBAjuL420h0T/fMmkQlNsQP2GhQzEUpYHPfxBkvYQ==", "dev": true, "license": "MIT", "dependencies": { @@ -15284,10 +15430,11 @@ } }, "node_modules/eslint-plugin-jest-dom": { - "version": "5.4.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jest-dom/-/eslint-plugin-jest-dom-5.4.0.tgz", - "integrity": "sha512-yBqvFsnpS5Sybjoq61cJiUsenRkC9K32hYQBFS9doBR7nbQZZ5FyO+X7MlmfM1C48Ejx/qTuOCgukDUNyzKZ7A==", + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jest-dom/-/eslint-plugin-jest-dom-5.5.0.tgz", + "integrity": "sha512-CRlXfchTr7EgC3tDI7MGHY6QjdJU5Vv2RPaeeGtkXUHnKZf04kgzMPIJUXt4qKCvYWVVIEo9ut9Oq1vgXAykEA==", "dev": true, + "license": "MIT", "dependencies": { "@babel/runtime": "^7.16.3", "requireindex": "^1.2.0" @@ -15456,10 +15603,11 @@ } }, "node_modules/eslint-plugin-jsdoc": { - "version": "50.4.3", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-50.4.3.tgz", - "integrity": "sha512-uWtwFxGRv6B8sU63HZM5dAGDhgsatb+LONwmILZJhdRALLOkCX2HFZhdL/Kw2ls8SQMAVEfK+LmnEfxInRN8HA==", + "version": "50.5.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsdoc/-/eslint-plugin-jsdoc-50.5.0.tgz", + "integrity": "sha512-xTkshfZrUbiSHXBwZ/9d5ulZ2OcHXxSvm/NPo494H/hadLRJwOq5PMV0EUpMqsb9V+kQo+9BAgi6Z7aJtdBp2A==", "dev": true, + "license": "BSD-3-Clause", "dependencies": { "@es-joy/jsdoccomment": "~0.49.0", "are-docs-informative": "^0.0.2", @@ -15572,9 +15720,9 @@ } }, "node_modules/eslint-plugin-jsx-a11y": { - "version": "6.10.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.10.1.tgz", - "integrity": "sha512-zHByM9WTUMnfsDTafGXRiqxp6lFtNoSOWBY6FonVRn3A+BUwN1L/tdBXT40BcBJi0cZjOGTXZ0eD/rTG9fEJ0g==", + "version": "6.10.2", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.10.2.tgz", + "integrity": "sha512-scB3nz4WmG75pV8+3eRUQOHZlNSUhFNq37xnpgRkCCELU3XMvXAxLk1eqWWyE22Ki4Q01Fnsw9BA3cJHDPgn2Q==", "dev": true, "license": "MIT", "dependencies": { @@ -15586,7 +15734,6 @@ "axobject-query": "^4.1.0", "damerau-levenshtein": "^1.0.8", "emoji-regex": "^9.2.2", - "es-iterator-helpers": "^1.1.0", "hasown": "^2.0.2", "jsx-ast-utils": "^3.3.5", "language-tags": "^1.0.9", @@ -15666,11 +15813,14 @@ } }, "node_modules/eslint-plugin-oxlint": { - "version": "0.10.1", - "resolved": "https://registry.npmjs.org/eslint-plugin-oxlint/-/eslint-plugin-oxlint-0.10.1.tgz", - "integrity": "sha512-bo59mtO2ff1TqrKOOkHy515j+1zrjqtfoKKxuQ7p8vS+AUGKzIm8HnK2+ZKZ8W13xULfFA6gfUxduJ/rRjFUUg==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-oxlint/-/eslint-plugin-oxlint-0.14.0.tgz", + "integrity": "sha512-/NediRWJgQhaC/sIUUrH8qpkxC6M584Nx2POIvkcfvtdkggMmtBZuNw3W6c1iGRZvHmd14pdeI0kig1Y/XHdNg==", "dev": true, - "license": "MIT" + "license": "MIT", + "dependencies": { + "jsonc-parser": "^3.3.1" + } }, "node_modules/eslint-plugin-playwright": { "version": "0.15.3", @@ -15869,10 +16019,11 @@ } }, "node_modules/eslint-plugin-styled-components-a11y": { - "version": "2.1.35", - "resolved": "https://registry.npmjs.org/eslint-plugin-styled-components-a11y/-/eslint-plugin-styled-components-a11y-2.1.35.tgz", - "integrity": "sha512-daLOYFbRnqIy/lGCzIP6JebFXAzktZlCvyhADIh/GgZ0BVslvOvH8XCFFxR1l5nmx9na6zr/9B6jnB6/44Dwjw==", + "version": "2.1.36", + "resolved": "https://registry.npmjs.org/eslint-plugin-styled-components-a11y/-/eslint-plugin-styled-components-a11y-2.1.36.tgz", + "integrity": "sha512-fzVl6dilM00douhVWNo0VVV5fkhyq/YpS4qebyLrJgnOmhubN3zBFazjqCiXEawRPNitQ7JNwJhSXW+tg1YhzA==", "dev": true, + "license": "ISC", "dependencies": { "@babel/parser": "^7.8.4", "eslint-plugin-jsx-a11y": "^6.2.3" @@ -15882,20 +16033,167 @@ } }, "node_modules/eslint-plugin-testing-library": { - "version": "6.4.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-testing-library/-/eslint-plugin-testing-library-6.4.0.tgz", - "integrity": "sha512-yeWF+YgCgvNyPNI9UKnG0FjeE2sk93N/3lsKqcmR8dSfeXJwFT5irnWo7NjLf152HkRzfoFjh3LsBUrhvFz4eA==", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-testing-library/-/eslint-plugin-testing-library-7.0.0.tgz", + "integrity": "sha512-Bwrn5Qi08Lf5Huv4ZGDNYxwkFLAyGQIPB9lC0ALlojymP32aKsSxWnccP1NvIcI5vMhkENg4Y5Td/Q9/tLYmGQ==", "dev": true, "license": "MIT", "dependencies": { - "@typescript-eslint/utils": "^5.62.0" + "@typescript-eslint/scope-manager": "^8.15.0", + "@typescript-eslint/utils": "^8.15.0" }, "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0", - "npm": ">=6" + "node": "^18.18.0 || ^20.9.0 || >=21.1.0", + "npm": ">=9.8.1" }, "peerDependencies": { - "eslint": "^7.5.0 || ^8.0.0 || ^9.0.0" + "eslint": "^8.57.0 || ^9.0.0" + } + }, + "node_modules/eslint-plugin-testing-library/node_modules/@typescript-eslint/scope-manager": { + "version": "8.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-8.15.0.tgz", + "integrity": "sha512-QRGy8ADi4J7ii95xz4UoiymmmMd/zuy9azCaamnZ3FM8T5fZcex8UfJcjkiEZjJSztKfEBe3dZ5T/5RHAmw2mA==", + "dev": true, + "license": "MIT", + "dependencies": { + "@typescript-eslint/types": "8.15.0", + "@typescript-eslint/visitor-keys": "8.15.0" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/eslint-plugin-testing-library/node_modules/@typescript-eslint/types": { + "version": "8.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-8.15.0.tgz", + "integrity": "sha512-n3Gt8Y/KyJNe0S3yDCD2RVKrHBC4gTUcLTebVBXacPy091E6tNspFLKRXlk3hwT4G55nfr1n2AdFqi/XMxzmPQ==", + "dev": true, + "license": "MIT", + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/eslint-plugin-testing-library/node_modules/@typescript-eslint/typescript-estree": { + "version": "8.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-8.15.0.tgz", + "integrity": "sha512-1eMp2JgNec/niZsR7ioFBlsh/Fk0oJbhaqO0jRyQBMgkz7RrFfkqF9lYYmBoGBaSiLnu8TAPQTwoTUiSTUW9dg==", + "dev": true, + "license": "BSD-2-Clause", + "dependencies": { + "@typescript-eslint/types": "8.15.0", + "@typescript-eslint/visitor-keys": "8.15.0", + "debug": "^4.3.4", + "fast-glob": "^3.3.2", + "is-glob": "^4.0.3", + "minimatch": "^9.0.4", + "semver": "^7.6.0", + "ts-api-utils": "^1.3.0" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/eslint-plugin-testing-library/node_modules/@typescript-eslint/utils": { + "version": "8.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-8.15.0.tgz", + "integrity": "sha512-k82RI9yGhr0QM3Dnq+egEpz9qB6Un+WLYhmoNcvl8ltMEededhh7otBVVIDDsEEttauwdY/hQoSsOv13lxrFzQ==", + "dev": true, + "license": "MIT", + "dependencies": { + "@eslint-community/eslint-utils": "^4.4.0", + "@typescript-eslint/scope-manager": "8.15.0", + "@typescript-eslint/types": "8.15.0", + "@typescript-eslint/typescript-estree": "8.15.0" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependencies": { + "eslint": "^8.57.0 || ^9.0.0" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } + } + }, + "node_modules/eslint-plugin-testing-library/node_modules/@typescript-eslint/visitor-keys": { + "version": "8.15.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-8.15.0.tgz", + "integrity": "sha512-h8vYOulWec9LhpwfAdZf2bjr8xIp0KNKnpgqSz0qqYYKAW/QZKw3ktRndbiAtUz4acH4QLQavwZBYCc0wulA/Q==", + "dev": true, + "license": "MIT", + "dependencies": { + "@typescript-eslint/types": "8.15.0", + "eslint-visitor-keys": "^4.2.0" + }, + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/eslint-plugin-testing-library/node_modules/brace-expansion": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", + "dev": true, + "license": "MIT", + "dependencies": { + "balanced-match": "^1.0.0" + } + }, + "node_modules/eslint-plugin-testing-library/node_modules/eslint-visitor-keys": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-4.2.0.tgz", + "integrity": "sha512-UyLnSehNt62FFhSwjZlHmeokpRK59rcz29j+F1/aDgbkbRTk7wIc9XzdoasMUbRNKDM0qQt/+BJ4BrpFeABemw==", + "dev": true, + "license": "Apache-2.0", + "engines": { + "node": "^18.18.0 || ^20.9.0 || >=21.1.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" + } + }, + "node_modules/eslint-plugin-testing-library/node_modules/minimatch": { + "version": "9.0.5", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.5.tgz", + "integrity": "sha512-G6T0ZX48xgozx7587koeX9Ys2NYy6Gmv//P89sEte9V9whIapMNF4idKxnW2QtCcLiTWlb/wfCabAtAFWhhBow==", + "dev": true, + "license": "ISC", + "dependencies": { + "brace-expansion": "^2.0.1" + }, + "engines": { + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" } }, "node_modules/eslint-rule-composer": { @@ -16353,6 +16651,7 @@ "resolved": "https://registry.npmjs.org/events/-/events-3.3.0.tgz", "integrity": "sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==", "dev": true, + "license": "MIT", "engines": { "node": ">=0.8.x" } @@ -16951,7 +17250,8 @@ "version": "1.0.3", "resolved": "https://registry.npmjs.org/fast-json-parse/-/fast-json-parse-1.0.3.tgz", "integrity": "sha512-FRWsaZRWEJ1ESVNbDWmsAlqDk96gPQezzLghafp5J4GUKjbCz3OkAHuZs5TuPEtkbVQERysLp9xv6c24fBm8Aw==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/fast-json-patch": { "version": "2.2.1", @@ -17062,21 +17362,6 @@ "pend": "~1.2.0" } }, - "node_modules/figures": { - "version": "3.2.0", - "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", - "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", - "dev": true, - "dependencies": { - "escape-string-regexp": "^1.0.5" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/file-entry-cache": { "version": "6.0.1", "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-6.0.1.tgz", @@ -17180,6 +17465,7 @@ "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.2.tgz", "integrity": "sha512-wXZV5emFEjrridIgED11OoUKLxiYjAcqot/NJdAkOhlJ+vGzwhOAfcG5OX1jP+S0PcjEn8bdMJv+g2jwQ3Onig==", "dev": true, + "license": "MIT", "dependencies": { "commondir": "^1.0.1", "make-dir": "^3.0.2", @@ -17197,6 +17483,7 @@ "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.1.0.tgz", "integrity": "sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw==", "dev": true, + "license": "MIT", "dependencies": { "semver": "^6.0.0" }, @@ -17212,6 +17499,7 @@ "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", "dev": true, + "license": "ISC", "bin": { "semver": "bin/semver.js" } @@ -17439,6 +17727,7 @@ "resolved": "https://registry.npmjs.org/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-8.0.0.tgz", "integrity": "sha512-mX3qW3idpueT2klaQXBzrIM/pHw+T0B/V9KHEvNrqijTq9NFnMZU6oreVxDYcf33P8a5cW+67PjodNHthGnNVg==", "dev": true, + "license": "MIT", "dependencies": { "@babel/code-frame": "^7.16.7", "chalk": "^4.1.2", @@ -17467,6 +17756,7 @@ "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", "dev": true, + "license": "MIT", "dependencies": { "color-convert": "^2.0.1" }, @@ -17482,6 +17772,7 @@ "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", "dev": true, + "license": "MIT", "dependencies": { "ansi-styles": "^4.1.0", "supports-color": "^7.1.0" @@ -17498,6 +17789,7 @@ "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", "dev": true, + "license": "MIT", "dependencies": { "color-name": "~1.1.4" }, @@ -17509,13 +17801,15 @@ "version": "1.1.4", "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/fork-ts-checker-webpack-plugin/node_modules/has-flag": { "version": "4.0.0", "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", "dev": true, + "license": "MIT", "engines": { "node": ">=8" } @@ -17525,6 +17819,7 @@ "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", "dev": true, + "license": "MIT", "dependencies": { "@types/json-schema": "^7.0.8", "ajv": "^6.12.5", @@ -17543,6 +17838,7 @@ "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", "dev": true, + "license": "MIT", "dependencies": { "has-flag": "^4.0.0" }, @@ -17642,7 +17938,8 @@ "version": "1.0.6", "resolved": "https://registry.npmjs.org/fs-monkey/-/fs-monkey-1.0.6.tgz", "integrity": "sha512-b1FMfwetIKymC0eioW7mTywihSQE4oLzQn1dB6rZB5fx/3NpNEdAWeCSMB+60/AeT0TCXsxzAlcYVEFCTAksWg==", - "dev": true + "dev": true, + "license": "Unlicense" }, "node_modules/fs-readdir-recursive": { "version": "1.1.0", @@ -18226,7 +18523,8 @@ "version": "0.4.1", "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.4.1.tgz", "integrity": "sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==", - "dev": true + "dev": true, + "license": "BSD-2-Clause" }, "node_modules/glob/node_modules/brace-expansion": { "version": "2.0.1", @@ -18760,10 +19058,11 @@ "integrity": "sha512-t+JyFJwKDCp4ZwBp4iC/wqw0meQDDc77Qs8OFl5P7RGlIP3LQMvwpD7VXxqQfC7/TfC+GKYlFP6WDYfXTmXHfw==" }, "node_modules/html-webpack-plugin": { - "version": "5.6.0", - "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-5.6.0.tgz", - "integrity": "sha512-iwaY4wzbe48AfKLZ/Cc8k0L+FKG6oSNRaZ8x5A/T/IVDGyXcbHncM9TdDa93wn0FsSm82FhTKW7f3vS61thXAw==", + "version": "5.6.3", + "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-5.6.3.tgz", + "integrity": "sha512-QSf1yjtSAsmf7rYBV7XX86uua4W/vkhIt0xNXKbsi2foEeW7vjJQz4bhnpL3xH+l1ryl1680uNv968Z+X6jSYg==", "dev": true, + "license": "MIT", "dependencies": { "@types/html-minifier-terser": "^6.0.0", "html-minifier-terser": "^6.0.2", @@ -18936,10 +19235,11 @@ } }, "node_modules/husky": { - "version": "9.1.6", - "resolved": "https://registry.npmjs.org/husky/-/husky-9.1.6.tgz", - "integrity": "sha512-sqbjZKK7kf44hfdE94EoX8MZNk0n7HeW37O4YrVGCF4wzgQjp+akPAkfUK5LZ6KuR/6sqeAVuXHji+RzQgOn5A==", + "version": "9.1.7", + "resolved": "https://registry.npmjs.org/husky/-/husky-9.1.7.tgz", + "integrity": "sha512-5gs5ytaNjBrh5Ow3zrvdUUY+0VxIuWVL4i9irt6friV+BqdCfmV11CQTWMiBYWHbXhco+J1kHfTOUkePhCDvMA==", "dev": true, + "license": "MIT", "bin": { "husky": "bin.js" }, @@ -19278,21 +19578,6 @@ "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" }, - "node_modules/is-builtin-module": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/is-builtin-module/-/is-builtin-module-3.2.1.tgz", - "integrity": "sha512-BSLE3HnV2syZ0FK0iMA/yUGplUeMmNz4AW5fnTunbCIqZi4vG3WjJT9FHMy5D69xmAYBHXQhJdALdpwVxV501A==", - "dev": true, - "dependencies": { - "builtin-modules": "^3.3.0" - }, - "engines": { - "node": ">=6" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/is-callable": { "version": "1.2.7", "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.2.7.tgz", @@ -24110,6 +24395,7 @@ "resolved": "https://registry.npmjs.org/linkify-it/-/linkify-it-5.0.0.tgz", "integrity": "sha512-5aHCbzQRADcdP+ATqnDuhhJ/MRIqDkZX5pyjFHRRysS8vZ5AbqGEoFIb6pYHPZ+L/OC2Lc+xT8uHVVR5CAK/wQ==", "dev": true, + "license": "MIT", "dependencies": { "uc.micro": "^2.0.0" } @@ -24489,6 +24775,7 @@ "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-4.3.0.tgz", "integrity": "sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==", "dev": true, + "license": "MIT", "engines": { "node": ">=6.11.5" } @@ -24507,15 +24794,6 @@ "node": ">=8.9.0" } }, - "node_modules/loader-utils/node_modules/big.js": { - "version": "5.2.2", - "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", - "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==", - "dev": true, - "engines": { - "node": "*" - } - }, "node_modules/locate-path": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", @@ -24939,6 +25217,7 @@ "resolved": "https://registry.npmjs.org/markdown-it/-/markdown-it-14.1.0.tgz", "integrity": "sha512-a54IwgWPaeBCAAsv13YgmALOF1elABB08FxO9i+r4VFk5Vl4pKokRPeX8u5TCgSsPi6ec1otfLjdOpVcgbpshg==", "dev": true, + "license": "MIT", "dependencies": { "argparse": "^2.0.1", "entities": "^4.4.0", @@ -24955,13 +25234,15 @@ "version": "2.0.1", "resolved": "https://registry.npmjs.org/argparse/-/argparse-2.0.1.tgz", "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", - "dev": true + "dev": true, + "license": "Python-2.0" }, "node_modules/markdown-it/node_modules/entities": { "version": "4.5.0", "resolved": "https://registry.npmjs.org/entities/-/entities-4.5.0.tgz", "integrity": "sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==", "dev": true, + "license": "BSD-2-Clause", "engines": { "node": ">=0.12" }, @@ -24969,27 +25250,15 @@ "url": "https://github.com/fb55/entities?sponsor=1" } }, - "node_modules/markdown-table": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/markdown-table/-/markdown-table-2.0.0.tgz", - "integrity": "sha512-Ezda85ToJUBhM6WGaG6veasyym+Tbs3cMAw/ZhOPqXiYsr0jgocBV3j3nx+4lk47plLlIqjwuTm/ywVI+zjJ/A==", - "dev": true, - "dependencies": { - "repeat-string": "^1.0.0" - }, - "funding": { - "type": "github", - "url": "https://github.com/sponsors/wooorm" - } - }, "node_modules/markdownlint": { - "version": "0.35.0", - "resolved": "https://registry.npmjs.org/markdownlint/-/markdownlint-0.35.0.tgz", - "integrity": "sha512-wgp8yesWjFBL7bycA3hxwHRdsZGJhjhyP1dSxKVKrza0EPFYtn+mHtkVy6dvP1kGSjovyG5B8yNP6Frj0UFUJg==", + "version": "0.36.1", + "resolved": "https://registry.npmjs.org/markdownlint/-/markdownlint-0.36.1.tgz", + "integrity": "sha512-s73fU2CQN7WCgjhaQUQ8wYESQNzGRNOKDd+3xgVqu8kuTEhmwepd/mxOv1LR2oV046ONrTLBFsM7IoKWNvmy5g==", "dev": true, + "license": "MIT", "dependencies": { "markdown-it": "14.1.0", - "markdownlint-micromark": "0.1.10" + "markdownlint-micromark": "0.1.12" }, "engines": { "node": ">=18" @@ -24999,22 +25268,22 @@ } }, "node_modules/markdownlint-cli": { - "version": "0.42.0", - "resolved": "https://registry.npmjs.org/markdownlint-cli/-/markdownlint-cli-0.42.0.tgz", - "integrity": "sha512-AjkzhhZa3TmEGi/CE2Wpmny69x1IrzqK2gPB0k8SmNMRgnSAJfyEO5FgZdWTHtJ6Nrdv5FWt5c4C5pkG6Dk30A==", + "version": "0.43.0", + "resolved": "https://registry.npmjs.org/markdownlint-cli/-/markdownlint-cli-0.43.0.tgz", + "integrity": "sha512-6vwurKK4B21eyYzwgX6ph13cZS7hE6LZfcS8QyD722CyxVD2RtAvbZK2p7k+FZbbKORulEuwl+hJaEq1l6/hoQ==", "dev": true, + "license": "MIT", "dependencies": { "commander": "~12.1.0", - "get-stdin": "~9.0.0", "glob": "~11.0.0", "ignore": "~6.0.2", "js-yaml": "^4.1.0", "jsonc-parser": "~3.3.1", "jsonpointer": "5.0.1", - "markdownlint": "~0.35.0", + "markdownlint": "~0.36.1", "minimatch": "~10.0.1", "run-con": "~1.3.2", - "smol-toml": "~1.3.0" + "smol-toml": "~1.3.1" }, "bin": { "markdownlint": "markdownlint.js" @@ -25047,18 +25316,6 @@ "node": ">=18" } }, - "node_modules/markdownlint-cli/node_modules/get-stdin": { - "version": "9.0.0", - "resolved": "https://registry.npmjs.org/get-stdin/-/get-stdin-9.0.0.tgz", - "integrity": "sha512-dVKBjfWisLAicarI2Sf+JuBE/DghV4UzNAVe9yhEJuzeREd3JhOTE9cUaJTeSa77fsbQUK3pcOpJfM59+VKZaA==", - "dev": true, - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/markdownlint-cli/node_modules/glob": { "version": "11.0.0", "resolved": "https://registry.npmjs.org/glob/-/glob-11.0.0.tgz", @@ -25119,10 +25376,11 @@ } }, "node_modules/markdownlint-micromark": { - "version": "0.1.10", - "resolved": "https://registry.npmjs.org/markdownlint-micromark/-/markdownlint-micromark-0.1.10.tgz", - "integrity": "sha512-no5ZfdqAdWGxftCLlySHSgddEjyW4kui4z7amQcGsSKfYC5v/ou+8mIQVyg9KQMeEZLNtz9OPDTj7nnTnoR4FQ==", + "version": "0.1.12", + "resolved": "https://registry.npmjs.org/markdownlint-micromark/-/markdownlint-micromark-0.1.12.tgz", + "integrity": "sha512-RlB6EwMGgc0sxcIhOQ2+aq7Zw1V2fBnzbXKGgYK/mVWdT7cz34fteKSwfYeo4rL6+L/q2tyC9QtD/PgZbkdyJQ==", "dev": true, + "license": "MIT", "engines": { "node": ">=18" }, @@ -25177,7 +25435,8 @@ "version": "2.0.0", "resolved": "https://registry.npmjs.org/mdurl/-/mdurl-2.0.0.tgz", "integrity": "sha512-Lf+9+2r+Tdp5wXDXC4PcIBjTDtq4UKjCPMQhKIuzpJNW0b96kVqSwW0bT7FhRSfmAiFYgP+SCRvdrDozfh0U5w==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/media-typer": { "version": "0.3.0", @@ -25267,6 +25526,7 @@ "resolved": "https://registry.npmjs.org/memfs/-/memfs-3.5.3.tgz", "integrity": "sha512-UERzLsxzllchadvbPs5aolHh65ISpKpM+ccLbOJ8/vvpBKmAWf+la7dXFy7Mr0ySHbdHrFv5kGFCUHHe6GFEmw==", "dev": true, + "license": "Unlicense", "dependencies": { "fs-monkey": "^1.0.4" }, @@ -25505,9 +25765,9 @@ } }, "node_modules/mini-css-extract-plugin": { - "version": "2.9.0", - "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.9.0.tgz", - "integrity": "sha512-Zs1YsZVfemekSZG+44vBsYTLQORkPMwnlv+aehcxK/NLKC+EGhDB39/YePYYqx/sTk6NnYpuqikhSn7+JIevTA==", + "version": "2.9.2", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-2.9.2.tgz", + "integrity": "sha512-GJuACcS//jtq4kCtd5ii/M0SZf7OZRH+BxdqXZHaJfb8TJiVl+NgQRPwiYt2EuqeSkNydn/7vP+bcE27C5mb9w==", "dev": true, "dependencies": { "schema-utils": "^4.0.0", @@ -25860,7 +26120,8 @@ "version": "3.1.1", "resolved": "https://registry.npmjs.org/node-abort-controller/-/node-abort-controller-3.1.1.tgz", "integrity": "sha512-AGK2yQKIjRuqnc6VkX2Xj5d+QW8xZ87pa1UK6yA6ouUyuxfHuMP6umE5QK7UmTeOAymo+Zx1Fxiuw9rVx8taHQ==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/node-bitmap": { "version": "0.0.1", @@ -26523,7 +26784,8 @@ "version": "1.0.5", "resolved": "https://registry.npmjs.org/objectorarray/-/objectorarray-1.0.5.tgz", "integrity": "sha512-eJJDYkhJFFbBBAxeh8xW+weHlkI28n2ZdQV/J/DNfWfSKlGEf2xcfAbZTv3riEXHAhL9SVOTs2pRmXiSTf78xg==", - "dev": true + "dev": true, + "license": "ISC" }, "node_modules/obuf": { "version": "1.1.2", @@ -26695,10 +26957,11 @@ } }, "node_modules/oxlint": { - "version": "0.10.3", - "resolved": "https://registry.npmjs.org/oxlint/-/oxlint-0.10.3.tgz", - "integrity": "sha512-af5u5+s4adyszujeILPDRGwix0o5M1+qR1eqxNSmJhTKVRX7xdrT9s2rpNpMYxQmPyWRhC/+5Gqyb+f/PtbK9A==", + "version": "0.14.0", + "resolved": "https://registry.npmjs.org/oxlint/-/oxlint-0.14.0.tgz", + "integrity": "sha512-S0jZRxWPwgDEtLbpJfCVaMeK5/E7wvp6lYJdukwrmeLMRelgh9DjQzl2RBrSjHfmm2R6IcUwzpQ9h8BvqDH7ww==", "dev": true, + "license": "MIT", "bin": { "oxc_language_server": "bin/oxc_language_server", "oxlint": "bin/oxlint" @@ -26710,14 +26973,14 @@ "url": "https://github.com/sponsors/Boshen" }, "optionalDependencies": { - "@oxlint/darwin-arm64": "0.10.3", - "@oxlint/darwin-x64": "0.10.3", - "@oxlint/linux-arm64-gnu": "0.10.3", - "@oxlint/linux-arm64-musl": "0.10.3", - "@oxlint/linux-x64-gnu": "0.10.3", - "@oxlint/linux-x64-musl": "0.10.3", - "@oxlint/win32-arm64": "0.10.3", - "@oxlint/win32-x64": "0.10.3" + "@oxlint/darwin-arm64": "0.14.0", + "@oxlint/darwin-x64": "0.14.0", + "@oxlint/linux-arm64-gnu": "0.14.0", + "@oxlint/linux-arm64-musl": "0.14.0", + "@oxlint/linux-x64-gnu": "0.14.0", + "@oxlint/linux-x64-musl": "0.14.0", + "@oxlint/win32-arm64": "0.14.0", + "@oxlint/win32-x64": "0.14.0" } }, "node_modules/p-limit": { @@ -27158,7 +27421,8 @@ "version": "1.0.1", "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-1.0.1.tgz", "integrity": "sha512-b7uo2UCUOYZcnF/3ID0lulOJi/bafxa1xPe7ZPsammBSpjSWQkjNxlt635YGS2MiR9GjvuXCtz2emr3jbsz98g==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/path-case": { "version": "3.0.4", @@ -27908,12 +28172,13 @@ } }, "node_modules/postcss-styled-syntax": { - "version": "0.6.4", - "resolved": "https://registry.npmjs.org/postcss-styled-syntax/-/postcss-styled-syntax-0.6.4.tgz", - "integrity": "sha512-uWiLn+9rKgIghUYmTHvXMR6MnyPULMe9Gv3bV537Fg4FH6CA6cn21WMjKss2Qb98LUhT847tKfnRGG3FhSOgUQ==", + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/postcss-styled-syntax/-/postcss-styled-syntax-0.7.0.tgz", + "integrity": "sha512-OeStzPkHJ1/WDGRKm/JuVK8UdJbjt3U7AFC+zUc9omJ79SaXSxWoy+PXxJz7t8vOO8HcUgCLndNEQfLvZ74TuQ==", "dev": true, + "license": "MIT", "dependencies": { - "typescript": "^5.3.3" + "typescript": "^5.6.3" }, "engines": { "node": ">=14.17" @@ -28240,6 +28505,7 @@ "resolved": "https://registry.npmjs.org/punycode.js/-/punycode.js-2.3.1.tgz", "integrity": "sha512-uxFIHU0YlHYhDQtV4R9J6a52SLx28BCjT+4ieh7IGbgwVJWO+km431c4yRlREUAsAmt/uMjQUyQHNEPf0M39CA==", "dev": true, + "license": "MIT", "engines": { "node": ">=6" } @@ -28620,6 +28886,7 @@ "resolved": "https://registry.npmjs.org/react-docgen/-/react-docgen-7.1.0.tgz", "integrity": "sha512-APPU8HB2uZnpl6Vt/+0AFoVYgSRtfiP6FLrZgPPTDmqSb2R4qZRbgd0A3VzIFxDt5e+Fozjx79WjLWnF69DK8g==", "dev": true, + "license": "MIT", "dependencies": { "@babel/core": "^7.18.9", "@babel/traverse": "^7.18.9", @@ -28641,6 +28908,7 @@ "resolved": "https://registry.npmjs.org/react-docgen-typescript/-/react-docgen-typescript-2.2.2.tgz", "integrity": "sha512-tvg2ZtOpOi6QDwsb3GZhOjDkkX0h8Z2gipvTg6OVMUyoYoURhEiRNePT8NZItTVCDh39JJHnLdfCOkzoLbFnTg==", "dev": true, + "license": "MIT", "peerDependencies": { "typescript": ">= 4.3.x" } @@ -28650,6 +28918,7 @@ "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-4.0.0.tgz", "integrity": "sha512-mnVSV2l+Zv6BLpSD/8V87CW/y9EmmbYzGCIavsnsI6/nwn26DwffM/yztm30Z/I2DY9wdS3vXVCMnHDgZaVNoA==", "dev": true, + "license": "MIT", "dependencies": { "min-indent": "^1.0.1" }, @@ -29088,6 +29357,7 @@ "resolved": "https://registry.npmjs.org/recast/-/recast-0.23.9.tgz", "integrity": "sha512-Hx/BGIbwj+Des3+xy5uAtAbdCyqK9y9wbBcDFDYanLS9JnMqf7OeF87HQwUimE87OEc72mr6tkKUKMBBL+hF9Q==", "dev": true, + "license": "MIT", "dependencies": { "ast-types": "^0.16.1", "esprima": "~4.0.0", @@ -29104,6 +29374,7 @@ "resolved": "https://registry.npmjs.org/ast-types/-/ast-types-0.16.1.tgz", "integrity": "sha512-6t10qk83GOG8p0vKmaCr8eiilZwO171AvbROMtvvNiwrTly62t+7XkA8RdIIVbpMhCASAsxgAzdRSwh6nw/5Dg==", "dev": true, + "license": "MIT", "dependencies": { "tslib": "^2.0.1" }, @@ -29116,6 +29387,7 @@ "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==", "dev": true, + "license": "BSD-3-Clause", "engines": { "node": ">=0.10.0" } @@ -30683,10 +30955,11 @@ "dev": true }, "node_modules/smol-toml": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/smol-toml/-/smol-toml-1.3.0.tgz", - "integrity": "sha512-tWpi2TsODPScmi48b/OQZGi2lgUmBCHy6SZrhi/FdnnHiU1GwebbCfuQuxsC3nHaLwtYeJGPrDZDIeodDOc4pA==", + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/smol-toml/-/smol-toml-1.3.1.tgz", + "integrity": "sha512-tEYNll18pPKHroYSmLLrksq233j021G0giwW7P3D24jC54pQ5W5BXMsQ/Mvw1OJCmEYDgY+lrzT+3nNUtoNfXQ==", "dev": true, + "license": "BSD-3-Clause", "engines": { "node": ">= 18" }, @@ -31397,12 +31670,13 @@ } }, "node_modules/storybook": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/storybook/-/storybook-8.4.1.tgz", - "integrity": "sha512-0tfFIFghjho9FtnFoiJMoxhcs2iIdvEF81GTSVnTsDVJrYA84nB+FxN3UY1fT0BcQ8BFlbf+OhSjZL7ufqqWKA==", + "version": "8.4.6", + "resolved": "https://registry.npmjs.org/storybook/-/storybook-8.4.6.tgz", + "integrity": "sha512-J6juZSZT2u3PUW0QZYZZYxBq6zU5O0OrkSgkMXGMg/QrS9to9IHmt4FjEMEyACRbXo8POcB/fSXa3VpGe7bv3g==", "dev": true, + "license": "MIT", "dependencies": { - "@storybook/core": "8.4.1" + "@storybook/core": "8.4.6" }, "bin": { "getstorybook": "bin/index.cjs", @@ -31730,6 +32004,7 @@ "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-3.3.4.tgz", "integrity": "sha512-0WqXzrsMTyb8yjZJHDqwmnwRJvhALK9LfRtRc6B4UTWe8AijYLZYZ9thuJTZc2VfQWINADW/j+LiJnfy2RoC1w==", "dev": true, + "license": "MIT", "engines": { "node": ">= 12.13.0" }, @@ -33150,9 +33425,9 @@ } }, "node_modules/typescript": { - "version": "5.6.3", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.6.3.tgz", - "integrity": "sha512-hjcS1mhfuyi4WW8IWtjP7brDrG2cuDZukyrYrSauoXGNgx0S7zceP07adYkJycEr56BOUTNPzbInooiN3fn1qw==", + "version": "5.7.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.7.2.tgz", + "integrity": "sha512-i5t66RHxDvVN40HfDd1PsEThGNnlMCMT3jMUuoh9/0TaqWevNontacunWyN02LA9/fIbEWlcHZcgTKb9QoaLfg==", "devOptional": true, "license": "Apache-2.0", "bin": { @@ -33185,7 +33460,8 @@ "version": "2.1.0", "resolved": "https://registry.npmjs.org/uc.micro/-/uc.micro-2.1.0.tgz", "integrity": "sha512-ARDJmphmdvUk6Glw7y9DQ2bFkKBHwQHLi2lsaH6PPmz/Ka9sFOBsBluozhDltWmnv9u/cF6Rt87znRTPV+yp/A==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/uglify-js": { "version": "3.14.5", @@ -33329,24 +33605,17 @@ } }, "node_modules/unplugin": { - "version": "1.15.0", - "resolved": "https://registry.npmjs.org/unplugin/-/unplugin-1.15.0.tgz", - "integrity": "sha512-jTPIs63W+DUEDW207ztbaoO7cQ4p5aVaB823LSlxpsFEU3Mykwxf3ZGC/wzxFJeZlASZYgVrWeo7LgOrqJZ8RA==", + "version": "1.16.0", + "resolved": "https://registry.npmjs.org/unplugin/-/unplugin-1.16.0.tgz", + "integrity": "sha512-5liCNPuJW8dqh3+DM6uNM2EI3MLLpCKp/KY+9pB5M2S2SR2qvvDHhKgBOaTWEbZTAws3CXfB0rKTIolWKL05VQ==", "dev": true, + "license": "MIT", "dependencies": { "acorn": "^8.14.0", "webpack-virtual-modules": "^0.6.2" }, "engines": { "node": ">=14.0.0" - }, - "peerDependencies": { - "webpack-sources": "^3" - }, - "peerDependenciesMeta": { - "webpack-sources": { - "optional": true - } } }, "node_modules/unplugin/node_modules/acorn": { @@ -33354,6 +33623,7 @@ "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.0.tgz", "integrity": "sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==", "dev": true, + "license": "MIT", "bin": { "acorn": "bin/acorn" }, @@ -33481,6 +33751,7 @@ "resolved": "https://registry.npmjs.org/url/-/url-0.11.4.tgz", "integrity": "sha512-oCwdVC7mTuWiPyjLUz/COz5TLk6wgp0RCsN+wHZ2Ekneac9w8uuV0njcbbie2ME+Vs+d6duwmYuR3HgQXs1fOg==", "dev": true, + "license": "MIT", "dependencies": { "punycode": "^1.4.1", "qs": "^6.12.3" @@ -33503,7 +33774,8 @@ "version": "1.4.1", "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", "integrity": "sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ==", - "dev": true + "dev": true, + "license": "MIT" }, "node_modules/urlpattern-polyfill": { "version": "9.0.0", @@ -33834,10 +34106,11 @@ } }, "node_modules/watchpack": { - "version": "2.4.1", - "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.4.1.tgz", - "integrity": "sha512-8wrBCMtVhqcXP2Sup1ctSkga6uc2Bx0IIvKyT7yTFier5AXHooSI+QyQQAtTb7+E0IUCCKyTFmXqdqgum2XWGg==", + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-2.4.2.tgz", + "integrity": "sha512-TnbFSbcOCcDgjZ4piURLCbJ3nJhznVh9kw6F6iokjiFPl8ONxe9A6nMDVXDiNbrSfLILs6vB07F7wLBrwPYzJw==", "dev": true, + "license": "MIT", "dependencies": { "glob-to-regexp": "^0.4.1", "graceful-fs": "^4.1.2" @@ -33865,18 +34138,19 @@ } }, "node_modules/webpack": { - "version": "5.95.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.95.0.tgz", - "integrity": "sha512-2t3XstrKULz41MNMBF+cJ97TyHdyQ8HCt//pqErqDvNjU9YQBnZxIHa11VXsi7F3mb5/aO2tuDxdeTPdU7xu9Q==", + "version": "5.96.1", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.96.1.tgz", + "integrity": "sha512-l2LlBSvVZGhL4ZrPwyr8+37AunkcYj5qh8o6u2/2rzoPc8gxFJkLj1WxNgooi9pnoc06jh0BjuXnamM4qlujZA==", "dev": true, + "license": "MIT", "dependencies": { - "@types/estree": "^1.0.5", + "@types/eslint-scope": "^3.7.7", + "@types/estree": "^1.0.6", "@webassemblyjs/ast": "^1.12.1", "@webassemblyjs/wasm-edit": "^1.12.1", "@webassemblyjs/wasm-parser": "^1.12.1", - "acorn": "^8.7.1", - "acorn-import-attributes": "^1.9.5", - "browserslist": "^4.21.10", + "acorn": "^8.14.0", + "browserslist": "^4.24.0", "chrome-trace-event": "^1.0.2", "enhanced-resolve": "^5.17.1", "es-module-lexer": "^1.2.1", @@ -34421,6 +34695,7 @@ "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-3.2.3.tgz", "integrity": "sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==", "dev": true, + "license": "MIT", "engines": { "node": ">=10.13.0" } @@ -34432,10 +34707,11 @@ "dev": true }, "node_modules/webpack/node_modules/acorn": { - "version": "8.12.1", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.1.tgz", - "integrity": "sha512-tcpGyI9zbizT9JbV6oYE477V6mTlXvvi0T0G3SNIYE2apm/G5huBa1+K89VGeovbg+jycCrfhl3ADxErOuO6Jg==", + "version": "8.14.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.14.0.tgz", + "integrity": "sha512-cl669nCJTZBsL97OF4kUQm5g5hC2uihk0NxY3WENAC0TYdILVkAyHymAntgxGkl7K+t0cXIrH5siy5S4XkFycA==", "dev": true, + "license": "MIT", "bin": { "acorn": "bin/acorn" }, @@ -34443,20 +34719,12 @@ "node": ">=0.4.0" } }, - "node_modules/webpack/node_modules/acorn-import-attributes": { - "version": "1.9.5", - "resolved": "https://registry.npmjs.org/acorn-import-attributes/-/acorn-import-attributes-1.9.5.tgz", - "integrity": "sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ==", - "dev": true, - "peerDependencies": { - "acorn": "^8" - } - }, "node_modules/webpack/node_modules/schema-utils": { "version": "3.3.0", "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-3.3.0.tgz", "integrity": "sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==", "dev": true, + "license": "MIT", "dependencies": { "@types/json-schema": "^7.0.8", "ajv": "^6.12.5", @@ -34471,95 +34739,31 @@ } }, "node_modules/webpackbar": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/webpackbar/-/webpackbar-6.0.1.tgz", - "integrity": "sha512-TnErZpmuKdwWBdMoexjio3KKX6ZtoKHRVvLIU0A47R0VVBDtx3ZyOJDktgYixhoJokZTYTt1Z37OkO9pnGJa9Q==", + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/webpackbar/-/webpackbar-7.0.0.tgz", + "integrity": "sha512-aS9soqSO2iCHgqHoCrj4LbfGQUboDCYJPSFOAchEK+9psIjNrfSWW4Y0YEz67MKURNvMmfo0ycOg9d/+OOf9/Q==", "dev": true, + "license": "MIT", "dependencies": { - "ansi-escapes": "^4.3.2", - "chalk": "^4.1.2", + "ansis": "^3.2.0", "consola": "^3.2.3", - "figures": "^3.2.0", - "markdown-table": "^2.0.0", "pretty-time": "^1.1.0", - "std-env": "^3.7.0", - "wrap-ansi": "^7.0.0" + "std-env": "^3.7.0" }, "engines": { "node": ">=14.21.3" }, "peerDependencies": { + "@rspack/core": "*", "webpack": "3 || 4 || 5" - } - }, - "node_modules/webpackbar/node_modules/ansi-styles": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz", - "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", - "dev": true, - "dependencies": { - "color-convert": "^2.0.1" - }, - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/chalk/ansi-styles?sponsor=1" - } - }, - "node_modules/webpackbar/node_modules/chalk": { - "version": "4.1.2", - "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", - "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==", - "dev": true, - "dependencies": { - "ansi-styles": "^4.1.0", - "supports-color": "^7.1.0" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "url": "https://github.com/chalk/chalk?sponsor=1" - } - }, - "node_modules/webpackbar/node_modules/color-convert": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz", - "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", - "dev": true, - "dependencies": { - "color-name": "~1.1.4" - }, - "engines": { - "node": ">=7.0.0" - } - }, - "node_modules/webpackbar/node_modules/color-name": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz", - "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", - "dev": true - }, - "node_modules/webpackbar/node_modules/has-flag": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", - "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==", - "dev": true, - "engines": { - "node": ">=8" - } - }, - "node_modules/webpackbar/node_modules/supports-color": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", - "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==", - "dev": true, - "dependencies": { - "has-flag": "^4.0.0" }, - "engines": { - "node": ">=8" + "peerDependenciesMeta": { + "@rspack/core": { + "optional": true + }, + "webpack": { + "optional": true + } } }, "node_modules/websocket-driver": { @@ -35400,7 +35604,7 @@ "dependencies": { "@emotion/is-prop-valid": "^1.3.1", "@googleforcreators/tracking": "*", - "@wordpress/element": "^6.10.0", + "@wordpress/element": "^6.12.0", "@wordpress/i18n": "^4.47.0", "flagged": "^2.0.10", "polished": "^4.3.1", @@ -35408,7 +35612,7 @@ "stylis-plugin-rtl": "^2.1.1" }, "devDependencies": { - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/react": "^14.0.0" }, "engines": { @@ -35768,7 +35972,7 @@ "commander": "src/index.ts" }, "devDependencies": { - "@types/node": "^22.8.6", + "@types/node": "^22.9.3", "@types/semver": "^7.5.8" }, "engines": { @@ -35809,7 +36013,7 @@ }, "devDependencies": { "@googleforcreators/karma-fixture": "*", - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/react": "^12.1.5", "@testing-library/react-hooks": "^8.0.1", "@testing-library/user-event": "^14.5.2", @@ -35864,7 +36068,7 @@ "@googleforcreators/react": "*", "@googleforcreators/tracking": "*", "@types/react-modal": "^3.16.3", - "big.js": "^6.2.1", + "big.js": "^6.2.2", "mousetrap": "^1.6.5", "polished": "^4.3.1", "prop-types": "^15.8.1", @@ -35874,7 +36078,7 @@ "uuid": "^10.0.0" }, "devDependencies": { - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/react": "^12.1.5", "@testing-library/react-hooks": "^8.0.1", "@types/big.js": "^6.2.2", @@ -35893,6 +36097,19 @@ "integrity": "sha512-ubLURWoc4tCw/8Yds0P3CE9cBG5q+aoycwWBiXXx4gp7XPYZy9ch0L9+Pv6osSoSRgvuQNqJdlwEhP5QhKKl6w==", "dev": true }, + "packages/design-system/node_modules/big.js": { + "version": "6.2.2", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-6.2.2.tgz", + "integrity": "sha512-y/ie+Faknx7sZA5MfGA2xKlu0GDv8RWrXGsmlteyJQ2lvoKv9GBK/fpRMc2qlSoBAgNxrixICFCBefIq8WCQpQ==", + "license": "MIT", + "engines": { + "node": "*" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/bigjs" + } + }, "packages/design-system/node_modules/uuid": { "version": "10.0.0", "resolved": "https://registry.npmjs.org/uuid/-/uuid-10.0.0.tgz", @@ -36498,7 +36715,7 @@ }, "devDependencies": { "@rollup/plugin-babel": "^6.0.4", - "@rollup/plugin-node-resolve": "^15.2.3", + "@rollup/plugin-node-resolve": "^15.3.0", "rollup": "^2.79.2" }, "engines": { @@ -36695,7 +36912,7 @@ "@wordpress/core-data": "^6.24.0", "@wordpress/data": "^9.17.0", "@wordpress/date": "^4.47.0", - "@wordpress/element": "^6.10.0", + "@wordpress/element": "^6.12.0", "@wordpress/i18n": "^4.47.0", "@wordpress/icons": "^9.38.0", "@wordpress/notices": "^4.15.0", @@ -37635,7 +37852,7 @@ "devDependencies": { "@googleforcreators/karma-fixture": "*", "@googleforcreators/test-utils": "*", - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/dom": "^10.1.0", "@testing-library/jest-dom": "^6.5.0", "@testing-library/react": "^12.1.5", @@ -37767,7 +37984,7 @@ "@wordpress/compose": "^6.24.0", "@wordpress/data": "^9.17.0", "@wordpress/dom-ready": "^3.47.0", - "@wordpress/element": "^6.10.0", + "@wordpress/element": "^6.12.0", "@wordpress/i18n": "^4.47.0", "prop-types": "^15.8.1" }, @@ -38429,7 +38646,7 @@ "uuid": "^10.0.0" }, "devDependencies": { - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/react": "^12.1.5", "@testing-library/react-hooks": "^8.0.1", "@testing-library/user-event": "^14.5.2" diff --git a/package.json b/package.json index 11dbf4981cd8..7fd9881dea9f 100644 --- a/package.json +++ b/package.json @@ -22,7 +22,7 @@ "url": "https://github.com/googleforcreators/web-stories-wp/issues" }, "engines": { - "node": ">= 20", + "node": ">= 22", "npm": ">= 10" }, "type": "module", @@ -39,7 +39,7 @@ "@babel/preset-env": "^7.26.0", "@babel/preset-react": "^7.25.9", "@babel/preset-typescript": "^7.26.0", - "@eslint-community/eslint-plugin-eslint-comments": "^4.4.0", + "@eslint-community/eslint-plugin-eslint-comments": "^4.4.1", "@googleforcreators/dashboard": "*", "@googleforcreators/design-system": "*", "@googleforcreators/fonts": "*", @@ -53,39 +53,39 @@ "@prettier/plugin-xml": "^3.4.1", "@rollup/plugin-babel": "^6.0.4", "@rollup/plugin-commonjs": "^25.0.7", - "@rollup/plugin-dynamic-import-vars": "^2.1.3", + "@rollup/plugin-dynamic-import-vars": "^2.1.5", "@rollup/plugin-json": "^6.1.0", - "@rollup/plugin-node-resolve": "^15.2.3", + "@rollup/plugin-node-resolve": "^15.3.0", "@rollup/plugin-terser": "^0.4.4", "@rollup/plugin-url": "^8.0.2", - "@storybook/addon-a11y": "^8.4.1", - "@storybook/addon-backgrounds": "^8.4.1", - "@storybook/addon-docs": "^8.4.1", - "@storybook/addon-essentials": "^8.4.1", - "@storybook/addon-links": "^8.4.1", - "@storybook/addon-viewport": "^8.4.1", + "@storybook/addon-a11y": "^8.4.6", + "@storybook/addon-backgrounds": "^8.4.6", + "@storybook/addon-docs": "^8.4.6", + "@storybook/addon-essentials": "^8.4.6", + "@storybook/addon-links": "^8.4.6", + "@storybook/addon-viewport": "^8.4.6", "@storybook/addon-webpack5-compiler-babel": "^3.0.3", "@storybook/client-api": "^7.6.17", - "@storybook/client-logger": "^8.4.1", - "@storybook/csf": "^0.1.8", - "@storybook/csf-tools": "^8.4.1", - "@storybook/react": "^8.4.1", - "@storybook/react-webpack5": "^8.4.1", + "@storybook/client-logger": "^8.4.6", + "@storybook/csf": "^0.1.12", + "@storybook/csf-tools": "^8.4.6", + "@storybook/react": "^8.4.6", + "@storybook/react-webpack5": "^8.4.6", "@stylelint/postcss-css-in-js": "^0.38.0", "@svgr/rollup": "^8.0.1", "@svgr/webpack": "^8.0.1", "@testing-library/dom": "^10.4.0", - "@testing-library/jest-dom": "^6.6.2", + "@testing-library/jest-dom": "^6.6.3", "@testing-library/react": "^12.1.5", "@testing-library/react-hooks": "^8.0.1", "@testing-library/user-event": "^14.5.2", "@types/jest": "^29.5.14", "@types/jsdom": "^21.1.7", - "@types/node": "^22.8.6", + "@types/node": "^22.9.3", "@types/styled-components": "^5.1.26", "@types/uuid": "^10.0.0", - "@typescript-eslint/eslint-plugin": "^6.19.1", - "@typescript-eslint/parser": "^6.19.1", + "@typescript-eslint/eslint-plugin": "^8.16.0", + "@typescript-eslint/parser": "^8.16.0", "@web-stories-wp/e2e-tests": "*", "@web-stories-wp/eslint-import-resolver": "*", "@web-stories-wp/jest-amp": "*", @@ -105,7 +105,7 @@ "babel-plugin-transform-react-remove-prop-types": "^0.4.24", "browserslist": "^4.24.2", "circular-dependency-plugin": "^5.2.2", - "core-js": "^3.38.1", + "core-js": "^3.39.0", "cross-env": "^7.0.3", "css-loader": "^7.1.2", "css-minimizer-webpack-plugin": "^7.0.0", @@ -115,23 +115,23 @@ "eslint-plugin-header": "^3.1.0", "eslint-plugin-import": "^2.31.0", "eslint-plugin-jasmine": "^4.2.2", - "eslint-plugin-jest": "^28.8.3", - "eslint-plugin-jest-dom": "^5.4.0", + "eslint-plugin-jest": "^28.9.0", + "eslint-plugin-jest-dom": "^5.5.0", "eslint-plugin-jest-extended": "^2.4.0", - "eslint-plugin-jsdoc": "^50.4.3", - "eslint-plugin-jsx-a11y": "^6.10.1", + "eslint-plugin-jsdoc": "^50.5.0", + "eslint-plugin-jsx-a11y": "^6.10.2", "eslint-plugin-markdown": "^5.1.0", "eslint-plugin-node": "^11.1.0", - "eslint-plugin-oxlint": "^0.10.1", + "eslint-plugin-oxlint": "^0.14.0", "eslint-plugin-prettier": "^5.2.1", "eslint-plugin-react": "^7.37.2", "eslint-plugin-react-compiler": "0.0.0-experimental-34d04b6-20241024", "eslint-plugin-react-hooks": "^5.0.0", "eslint-plugin-security": "^3.0.1", - "eslint-plugin-styled-components-a11y": "^2.1.35", - "eslint-plugin-testing-library": "^6.4.0", - "html-webpack-plugin": "^5.6.0", - "husky": "^9.1.6", + "eslint-plugin-styled-components-a11y": "^2.1.36", + "eslint-plugin-testing-library": "^7.0.0", + "html-webpack-plugin": "^5.6.3", + "husky": "^9.1.7", "jest": "^29.7.0", "jest-axe": "^9.0.0", "jest-canvas-mock": "^2.5.2", @@ -149,15 +149,15 @@ "karma-sourcemap-loader": "^0.4.0", "karma-webpack": "^5.0.1", "lint-staged": "^15.2.10", - "markdownlint-cli": "^0.42.0", - "mini-css-extract-plugin": "^2.9.0", + "markdownlint-cli": "^0.43.0", + "mini-css-extract-plugin": "^2.9.2", "mockdate": "^3.0.5", "npm-package-json-lint": "^8.0.0", "npm-run-all": "^4.1.5", - "oxlint": "^0.10.3", + "oxlint": "^0.14.0", "patch-package": "^8.0.0", "postcss-jsx": "^0.36.4", - "postcss-styled-syntax": "^0.6.4", + "postcss-styled-syntax": "^0.7.0", "postcss-syntax": "^0.36.2", "prettier": "^3.3.3", "puppeteer": "^21.9.0", @@ -177,12 +177,12 @@ "stylelint-prettier": "^5.0.2", "stylis-plugin-rtl": "^1.0.0", "terser-webpack-plugin": "^5.3.10", - "typescript": "^5.6.3", - "webpack": "^5.95.0", + "typescript": "^5.7.2", + "webpack": "^5.96.1", "webpack-bundle-analyzer": "^4.10.2", "webpack-cli": "^5.1.4", "webpack-dev-server": "^5.1.0", - "webpackbar": "^6.0.1", + "webpackbar": "^7.0.0", "worker-loader": "^3.0.8", "workspaces-run": "^1.0.2" }, diff --git a/packages/activation-notice/package.json b/packages/activation-notice/package.json index 7b514d426df8..db402b6d6578 100644 --- a/packages/activation-notice/package.json +++ b/packages/activation-notice/package.json @@ -29,7 +29,7 @@ "dependencies": { "@emotion/is-prop-valid": "^1.3.1", "@googleforcreators/tracking": "*", - "@wordpress/element": "^6.10.0", + "@wordpress/element": "^6.12.0", "@wordpress/i18n": "^4.47.0", "flagged": "^2.0.10", "polished": "^4.3.1", @@ -37,7 +37,7 @@ "stylis-plugin-rtl": "^2.1.1" }, "devDependencies": { - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/react": "^14.0.0" } } diff --git a/packages/animation/src/components/test/animationProvider.tsx b/packages/animation/src/components/test/animationProvider.tsx index 0f6bd7176b00..e6cfbf51da00 100644 --- a/packages/animation/src/components/test/animationProvider.tsx +++ b/packages/animation/src/components/test/animationProvider.tsx @@ -24,9 +24,9 @@ import type { PropsWithChildren } from 'react'; /** * Internal dependencies */ -import { AnimationProvider, useStoryAnimationContext } from '..'; import { createAnimationPart } from '../../parts'; -import { AnimationType, type Element } from '../../types'; +import { AnimationType, type Element, type StoryAnimation } from '../../types'; +import { AnimationProvider, useStoryAnimationContext } from '..'; jest.mock('flagged'); jest.mock('../../parts', () => ({ @@ -187,13 +187,13 @@ describe('AnimationProvider', () => { rotationAngle: 0, }; const elements = [element1, element2]; - const animType = AnimationType.Move as const; + const animType = AnimationType.Move; const args = [ { bounces: 3, duration: 1000 }, { blinks: 2, offset: 20, blarks: 6, duration: 1000 }, { columns: 4, duration: 400 }, ]; - const animations = [ + const animations: StoryAnimation[] = [ { id: '1', targets: [target], type: animType, ...args[0] }, { id: '2', targets: [target], type: animType, ...args[1] }, { id: '3', targets: [target2], type: animType, ...args[2] }, diff --git a/packages/animation/src/utils/getOffPageOffset.ts b/packages/animation/src/utils/getOffPageOffset.ts index 86b81df0975f..f8a3d2dab7f5 100644 --- a/packages/animation/src/utils/getOffPageOffset.ts +++ b/packages/animation/src/utils/getOffPageOffset.ts @@ -24,27 +24,27 @@ import { type DimensionableElement, } from '@googleforcreators/units'; -function calcTopOffset(box: ElementBox, dangerZoneOffset: number) { +function calcTopOffset(box: ElementBox, dangerZoneOffset: number): number { const { y, height } = box; const toTop = dangerZoneOffset + y; - return -Number((toTop / height) * 100.0 + 100.0).toFixed(5); + return -Number(Number((toTop / height) * 100.0 + 100.0).toFixed(5)); } -function calcBottomOffset(box: ElementBox, dangerZoneOffset: number) { +function calcBottomOffset(box: ElementBox, dangerZoneOffset: number): number { const { y, height } = box; const toBottom = 100 - y + dangerZoneOffset; - return Number((toBottom / height) * 100.0).toFixed(5); + return Number(Number((toBottom / height) * 100.0).toFixed(5)); } -function calcLeftOffset(box: ElementBox) { +function calcLeftOffset(box: ElementBox): number { const { x, width } = box; - return -Number((x / width) * 100.0 + 100.0).toFixed(5); + return -Number(Number((x / width) * 100.0 + 100.0).toFixed(5)); } -function calcRightOffset(box: ElementBox) { +function calcRightOffset(box: ElementBox): number { const { x, width } = box; const toRight = 100 - x; - return Number((toRight / width) * 100.0).toFixed(5); + return Number(Number((toRight / width) * 100.0).toFixed(5)); } function getOffPageOffset(element: DimensionableElement) { diff --git a/packages/animation/src/utils/test/getTotalDuration.ts b/packages/animation/src/utils/test/getTotalDuration.ts index f53e643ec4c5..c6f5351ec823 100644 --- a/packages/animation/src/utils/test/getTotalDuration.ts +++ b/packages/animation/src/utils/test/getTotalDuration.ts @@ -24,7 +24,7 @@ const BASE_ANIMATION = { id: '1', targets: [], }; -const type = AnimationType.BlinkOn as const; +const type = AnimationType.BlinkOn; describe('getTotalDuration', () => { it('returns 0 if no animations supplied', () => { diff --git a/packages/commander/package.json b/packages/commander/package.json index dd3d2fffbaae..fbc45c5ca0ca 100644 --- a/packages/commander/package.json +++ b/packages/commander/package.json @@ -31,7 +31,7 @@ "semver": "^7.6.3" }, "devDependencies": { - "@types/node": "^22.8.6", + "@types/node": "^22.9.3", "@types/semver": "^7.5.8" }, "bin": { diff --git a/packages/dashboard/package.json b/packages/dashboard/package.json index 25cf0ccf7af7..cf300edb1e85 100644 --- a/packages/dashboard/package.json +++ b/packages/dashboard/package.json @@ -57,7 +57,7 @@ }, "devDependencies": { "@googleforcreators/karma-fixture": "*", - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/react": "^12.1.5", "@testing-library/react-hooks": "^8.0.1", "@testing-library/user-event": "^14.5.2", diff --git a/packages/design-system/package.json b/packages/design-system/package.json index dda579ec3bff..c929b5c07993 100644 --- a/packages/design-system/package.json +++ b/packages/design-system/package.json @@ -43,7 +43,7 @@ "@googleforcreators/react": "*", "@googleforcreators/tracking": "*", "@types/react-modal": "^3.16.3", - "big.js": "^6.2.1", + "big.js": "^6.2.2", "mousetrap": "^1.6.5", "polished": "^4.3.1", "prop-types": "^15.8.1", @@ -53,7 +53,7 @@ "uuid": "^10.0.0" }, "devDependencies": { - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/react": "^12.1.5", "@testing-library/react-hooks": "^8.0.1", "@types/big.js": "^6.2.2", diff --git a/packages/design-system/src/components/contextMenu/components/button.tsx b/packages/design-system/src/components/contextMenu/components/button.tsx index 2eeb2ce637e1..2600d1c563ea 100644 --- a/packages/design-system/src/components/contextMenu/components/button.tsx +++ b/packages/design-system/src/components/contextMenu/components/button.tsx @@ -123,7 +123,9 @@ const Button = forwardRef(function Button( const handleClick = (evt: MouseEvent) => { onClick(evt); - dismissOnClick && onDismiss(evt.nativeEvent); + if (dismissOnClick) { + onDismiss(evt.nativeEvent); + } }; const handleFocus = (evt: FocusEvent) => { diff --git a/packages/design-system/src/components/snackbar/snackbarMessage.tsx b/packages/design-system/src/components/snackbar/snackbarMessage.tsx index 3c452317eb2a..cdbbfa5c355f 100644 --- a/packages/design-system/src/components/snackbar/snackbarMessage.tsx +++ b/packages/design-system/src/components/snackbar/snackbarMessage.tsx @@ -230,7 +230,9 @@ function SnackbarMessage({ const handleAction = useCallback( (evt: MouseEvent) => { onAction(evt); - !isPreventActionDismiss && onDismiss(); + if (!isPreventActionDismiss) { + onDismiss(); + } }, [onAction, onDismiss, isPreventActionDismiss] ); diff --git a/packages/design-system/src/typings/styled.d.ts b/packages/design-system/src/typings/styled.d.ts index b5c4441a4dc4..9ccf3301102b 100644 --- a/packages/design-system/src/typings/styled.d.ts +++ b/packages/design-system/src/typings/styled.d.ts @@ -25,5 +25,6 @@ import 'styled-components'; import type { Theme } from '../theme'; declare module 'styled-components' { + // eslint-disable-next-line @typescript-eslint/no-empty-object-type -- On purpose. export interface DefaultTheme extends Theme {} } diff --git a/packages/dom/src/stripHTML.ts b/packages/dom/src/stripHTML.ts index 85ae43b729fe..89d460c8fef1 100644 --- a/packages/dom/src/stripHTML.ts +++ b/packages/dom/src/stripHTML.ts @@ -14,10 +14,10 @@ * limitations under the License. */ -const buffer = document.createElement('div'); +const parser = new DOMParser(); export default function stripHTML(string: string) { // @todo: implement a cheaper way to strip markup. - buffer.innerHTML = string; - return buffer.textContent || ''; + const doc = parser.parseFromString(string, 'text/html'); + return doc.body.textContent || ''; } diff --git a/packages/element-library/src/text/display.tsx b/packages/element-library/src/text/display.tsx index 7c18118853d4..4c1f707de212 100644 --- a/packages/element-library/src/text/display.tsx +++ b/packages/element-library/src/text/display.tsx @@ -22,7 +22,11 @@ import { useEffect, useRef, useMemo } from '@googleforcreators/react'; import { createSolid, type Solid } from '@googleforcreators/patterns'; import { useUnits } from '@googleforcreators/units'; import { useTransformHandler } from '@googleforcreators/transform'; -import { getHTMLFormatters, getHTMLInfo } from '@googleforcreators/rich-text'; +import { + getHTMLFormatters, + getHTMLInfo, + sanitizeEditorHtml, +} from '@googleforcreators/rich-text'; import { stripHTML } from '@googleforcreators/dom'; import { getResponsiveBorder, @@ -253,7 +257,7 @@ function TextDisplay({ target.style.fontSize = updatedFontSize ? `${dataToEditorY(updatedFontSize)}px` : ''; - const updatedMargin = transform?.updates?.marginOffset; + const updatedMargin = transform?.updates?.marginOffset as number; target.style.margin = updatedMargin ? `${dataToEditorY(-updatedMargin) / 2}px 0` : ''; @@ -314,7 +318,7 @@ function TextDisplay({ borderRadius={borderRadius} dataToEditorY={dataToEditorY} dangerouslySetInnerHTML={{ - __html: contentWithoutColor, + __html: sanitizeEditorHtml(contentWithoutColor), }} /> @@ -325,7 +329,7 @@ function TextDisplay({ ref={fgRef} {...props} dangerouslySetInnerHTML={{ - __html: content, + __html: sanitizeEditorHtml(content), }} /> @@ -351,7 +355,7 @@ function TextDisplay({ } dangerouslySetInnerHTML={{ - __html: content, + __html: sanitizeEditorHtml(content), }} previewMode={previewMode} {...props} diff --git a/packages/element-library/src/text/edit.tsx b/packages/element-library/src/text/edit.tsx index 0bc244101d52..a0bdfe5dc009 100644 --- a/packages/element-library/src/text/edit.tsx +++ b/packages/element-library/src/text/edit.tsx @@ -337,7 +337,9 @@ function TextEdit({ editWrapper.style.left = `${boxRef.current.x + dx}px`; editWrapper.style.top = `${boxRef.current.y + dy}px`; } - onResize && onResize(); + if (onResize) { + onResize(); + } } }, [dataToEditorY, editWrapper, element, onResize, top, bottom]); // Invoke on each content update. diff --git a/packages/element-library/src/text/frame.tsx b/packages/element-library/src/text/frame.tsx index 7e54f483fcaa..87ebfa5f1127 100644 --- a/packages/element-library/src/text/frame.tsx +++ b/packages/element-library/src/text/frame.tsx @@ -26,7 +26,10 @@ import type { TextElementFont, FrameProps, } from '@googleforcreators/elements'; -import { getCaretCharacterOffsetWithin } from '@googleforcreators/rich-text'; +import { + getCaretCharacterOffsetWithin, + sanitizeEditorHtml, +} from '@googleforcreators/rich-text'; /** * Internal dependencies @@ -166,7 +169,7 @@ function TextFrame({ // See https://github.com/googleforcreators/web-stories-wp/issues/7745. data-fix-caret className="syncMargin" - dangerouslySetInnerHTML={{ __html: content }} + dangerouslySetInnerHTML={{ __html: sanitizeEditorHtml(content) }} {...props} /> ); diff --git a/packages/element-library/src/typings/styled.d.ts b/packages/element-library/src/typings/styled.d.ts index aa9510a21976..df76ee45af84 100644 --- a/packages/element-library/src/typings/styled.d.ts +++ b/packages/element-library/src/typings/styled.d.ts @@ -21,5 +21,6 @@ import 'styled-components'; import type { Theme } from '@googleforcreators/design-system'; declare module 'styled-components' { + // eslint-disable-next-line @typescript-eslint/no-empty-object-type -- On purpose. export interface DefaultTheme extends Theme {} } diff --git a/packages/fonts/src/fonts.json b/packages/fonts/src/fonts.json index 6e27f49eaa19..c82312346b02 100644 --- a/packages/fonts/src/fonts.json +++ b/packages/fonts/src/fonts.json @@ -11129,6 +11129,41 @@ "lGap": 0 } }, + { + "family": "Doto", + "fallbacks": ["sans-serif"], + "weights": [100, 200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular"], + "variants": [ + [0, 100], + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 950, + "des": -250, + "tAsc": 950, + "tDes": -250, + "tLGap": 0, + "wAsc": 900, + "wDes": 300, + "xH": 500, + "capH": 700, + "yMin": -300, + "yMax": 900, + "hAsc": 950, + "hDes": -250, + "lGap": 0 + } + }, { "family": "Dr Sugiyama", "fallbacks": ["cursive"], @@ -11406,6 +11441,36 @@ "lGap": 0 } }, + { + "family": "Edu AU VIC WA NT Arrows", + "fallbacks": ["cursive"], + "weights": [400, 500, 600, 700], + "styles": ["regular"], + "variants": [ + [0, 400], + [0, 500], + [0, 600], + [0, 700] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 2000, + "asc": 2576, + "des": -903, + "tAsc": 2576, + "tDes": -903, + "tLGap": 0, + "wAsc": 3205, + "wDes": 903, + "xH": 995, + "capH": 1847, + "yMin": -857, + "yMax": 2002, + "hAsc": 2576, + "hDes": -903, + "lGap": 0 + } + }, { "family": "Edu AU VIC WA NT Dots", "fallbacks": ["cursive"], @@ -11496,6 +11561,36 @@ "lGap": 0 } }, + { + "family": "Edu AU VIC WA NT Pre", + "fallbacks": ["cursive"], + "weights": [400, 500, 600, 700], + "styles": ["regular"], + "variants": [ + [0, 400], + [0, 500], + [0, 600], + [0, 700] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 2000, + "asc": 2576, + "des": -903, + "tAsc": 2576, + "tDes": -903, + "tLGap": 0, + "wAsc": 3205, + "wDes": 903, + "xH": 995, + "capH": 1847, + "yMin": -861, + "yMax": 2751, + "hAsc": 2576, + "hDes": -903, + "lGap": 0 + } + }, { "family": "Edu NSW ACT Foundation", "fallbacks": ["cursive"], @@ -12438,6 +12533,31 @@ "lGap": 0 } }, + { + "family": "Faculty Glyphic", + "fallbacks": ["sans-serif"], + "weights": [400], + "styles": ["regular"], + "variants": [[0, 400]], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1037, + "des": -262, + "tAsc": 1037, + "tDes": -262, + "tLGap": 0, + "wAsc": 1010, + "wDes": 280, + "xH": 550, + "capH": 775, + "yMin": -276, + "yMax": 1010, + "hAsc": 1037, + "hDes": -262, + "lGap": 0 + } + }, { "family": "Fahkwang", "fallbacks": ["sans-serif"], @@ -13877,6 +13997,76 @@ "lGap": 0 } }, + { + "family": "Funnel Display", + "fallbacks": ["cursive"], + "weights": [300, 400, 500, 600, 700, 800], + "styles": ["regular"], + "variants": [ + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1200, + "asc": 1200, + "des": -300, + "tAsc": 1200, + "tDes": -300, + "tLGap": 0, + "wAsc": 1200, + "wDes": 330, + "xH": 600, + "capH": 810, + "yMin": -336, + "yMax": 1132, + "hAsc": 1200, + "hDes": -300, + "lGap": 0 + } + }, + { + "family": "Funnel Sans", + "fallbacks": ["sans-serif"], + "weights": [300, 400, 500, 600, 700, 800], + "styles": ["regular", "italic"], + "variants": [ + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1200, + "asc": 1200, + "des": -300, + "tAsc": 1200, + "tDes": -300, + "tLGap": 0, + "wAsc": 1200, + "wDes": 330, + "xH": 600, + "capH": 810, + "yMin": -336, + "yMax": 1132, + "hAsc": 1200, + "hDes": -300, + "lGap": 0 + } + }, { "family": "Fustat", "fallbacks": ["sans-serif"], @@ -14325,6 +14515,76 @@ "lGap": 0 } }, + { + "family": "Geist", + "fallbacks": ["sans-serif"], + "weights": [100, 200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular"], + "variants": [ + [0, 100], + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1005, + "des": -295, + "tAsc": 1005, + "tDes": -295, + "tLGap": 0, + "wAsc": 1012, + "wDes": 262, + "xH": 530, + "capH": 710, + "yMin": -240, + "yMax": 940, + "hAsc": 1005, + "hDes": -295, + "lGap": 0 + } + }, + { + "family": "Geist Mono", + "fallbacks": ["monospace"], + "weights": [100, 200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular"], + "variants": [ + [0, 100], + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1005, + "des": -295, + "tAsc": 1005, + "tDes": -295, + "tLGap": 0, + "wAsc": 1012, + "wDes": 262, + "xH": 530, + "capH": 710, + "yMin": -247, + "yMax": 1012, + "hAsc": 1005, + "hDes": -295, + "lGap": 0 + } + }, { "family": "Gelasio", "fallbacks": ["serif"], @@ -16773,6 +17033,44 @@ "lGap": 0 } }, + { + "family": "Host Grotesk", + "fallbacks": ["sans-serif"], + "weights": [300, 400, 500, 600, 700, 800], + "styles": ["regular", "italic"], + "variants": [ + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1015, + "des": -315, + "tAsc": 1015, + "tDes": -315, + "tLGap": 0, + "wAsc": 977, + "wDes": 372, + "xH": 496, + "capH": 700, + "yMin": -341, + "yMax": 968, + "hAsc": 1015, + "hDes": -315, + "lGap": 0 + } + }, { "family": "Hubballi", "fallbacks": ["sans-serif"], @@ -16798,6 +17096,48 @@ "lGap": 0 } }, + { + "family": "Hubot Sans", + "fallbacks": ["sans-serif"], + "weights": [200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular", "italic"], + "variants": [ + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900], + [1, 200], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800], + [1, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1090, + "des": -320, + "tAsc": 1090, + "tDes": -320, + "tLGap": 0, + "wAsc": 1090, + "wDes": 320, + "xH": 525, + "capH": 729, + "yMin": -267, + "yMax": 1057, + "hAsc": 1090, + "hDes": -320, + "lGap": 0 + } + }, { "family": "Hurricane", "fallbacks": ["cursive"], @@ -25507,6 +25847,48 @@ "lGap": 0 } }, + { + "family": "Mona Sans", + "fallbacks": ["sans-serif"], + "weights": [200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular", "italic"], + "variants": [ + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900], + [1, 200], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800], + [1, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1090, + "des": -320, + "tAsc": 1090, + "tDes": -320, + "tLGap": 0, + "wAsc": 1090, + "wDes": 320, + "xH": 525, + "capH": 729, + "yMin": -242, + "yMax": 1047, + "hAsc": 1090, + "hDes": -320, + "lGap": 0 + } + }, { "family": "Monda", "fallbacks": ["sans-serif"], @@ -25779,11 +26161,11 @@ "tDes": -251, "tLGap": 0, "wAsc": 1109, - "wDes": 270, - "xH": 517, + "wDes": 453, + "xH": 525, "capH": 700, - "yMin": -262, - "yMax": 1043, + "yMin": -459, + "yMax": 1018, "hAsc": 968, "hDes": -251, "lGap": 0 @@ -26582,20 +26964,20 @@ "service": "fonts.google.com", "metrics": { "upm": 1000, - "asc": 920, - "des": -230, - "tAsc": 800, - "tDes": -200, - "tLGap": 0, - "wAsc": 920, - "wDes": 230, - "xH": 500, - "capH": 700, - "yMin": -200, - "yMax": 802, - "hAsc": 920, - "hDes": -230, - "lGap": 0 + "asc": 630, + "des": -370, + "tAsc": 630, + "tDes": -370, + "tLGap": 250, + "wAsc": 635, + "wDes": 372, + "xH": 300, + "capH": 460, + "yMin": -370, + "yMax": 632, + "hAsc": 630, + "hDes": -370, + "lGap": 250 } }, { @@ -26611,19 +26993,19 @@ "service": "fonts.google.com", "metrics": { "upm": 1000, - "asc": 920, - "des": -230, - "tAsc": 800, - "tDes": -200, - "tLGap": 0, - "wAsc": 920, - "wDes": 230, - "xH": 500, - "capH": 700, - "yMin": -200, - "yMax": 801, - "hAsc": 920, - "hDes": -230, + "asc": 844, + "des": -156, + "tAsc": 856, + "tDes": -144, + "tLGap": 250, + "wAsc": 885, + "wDes": 198, + "xH": 542, + "capH": 743, + "yMin": -198, + "yMax": 844, + "hAsc": 844, + "hDes": -156, "lGap": 0 } }, @@ -26668,20 +27050,20 @@ "service": "fonts.google.com", "metrics": { "upm": 1024, - "asc": 942, - "des": -236, + "asc": 819, + "des": -205, "tAsc": 819, "tDes": -205, - "tLGap": 0, - "wAsc": 942, - "wDes": 236, + "tLGap": 256, + "wAsc": 932, + "wDes": 247, "xH": 480, "capH": 755, - "yMin": -239, - "yMax": 978, - "hAsc": 942, - "hDes": -236, - "lGap": 0 + "yMin": -237, + "yMax": 929, + "hAsc": 819, + "hDes": -205, + "lGap": 256 } }, { @@ -26693,20 +27075,20 @@ "service": "fonts.google.com", "metrics": { "upm": 1000, - "asc": 920, - "des": -230, + "asc": 800, + "des": -200, "tAsc": 800, "tDes": -200, - "tLGap": 0, - "wAsc": 920, - "wDes": 230, + "tLGap": 250, + "wAsc": 809, + "wDes": 202, "xH": 476, "capH": 674, "yMin": -200, - "yMax": 800, - "hAsc": 920, - "hDes": -230, - "lGap": 0 + "yMax": 801, + "hAsc": 800, + "hDes": -200, + "lGap": 250 } }, { @@ -27517,7 +27899,7 @@ "wDes": 395, "xH": 536, "capH": 714, - "yMin": -394, + "yMin": -508, "yMax": 1067, "hAsc": 1069, "hDes": -293, @@ -27633,12 +28015,12 @@ "tAsc": 1374, "tDes": -738, "tLGap": 0, - "wAsc": 1374, + "wAsc": 1431, "wDes": 738, - "xH": 374, - "capH": 416, - "yMin": -573, - "yMax": 1114, + "xH": 536, + "capH": 714, + "yMin": -548, + "yMax": 1431, "hAsc": 1374, "hDes": -738, "lGap": 0 @@ -33757,12 +34139,12 @@ "tAsc": 1070, "tDes": -510, "tLGap": 0, - "wAsc": 1070, + "wAsc": 1141, "wDes": 510, "xH": 696, "capH": 760, - "yMin": -506, - "yMax": 1066, + "yMin": -507, + "yMax": 1141, "hAsc": 1070, "hDes": -510, "lGap": 0 @@ -34846,6 +35228,38 @@ "lGap": 0 } }, + { + "family": "Parkinsans", + "fallbacks": ["sans-serif"], + "weights": [300, 400, 500, 600, 700, 800], + "styles": ["regular"], + "variants": [ + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 1050, + "des": -350, + "tAsc": 1050, + "tDes": -350, + "tLGap": 0, + "wAsc": 1050, + "wDes": 350, + "xH": 549, + "capH": 693, + "yMin": -275, + "yMax": 975, + "hAsc": 1050, + "hDes": -350, + "lGap": 0 + } + }, { "family": "Passero One", "fallbacks": ["cursive"], @@ -35311,6 +35725,32 @@ "lGap": 0 } }, + { + "family": "Phetsarath", + "fallbacks": ["serif"], + "weights": [400, 700], + "styles": ["regular"], + "variants": [ + [0, 400], + [0, 700] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 2048, + "asc": 2123, + "des": -857, + "tAsc": 2123, + "tDes": -857, + "tLGap": 0, + "wAsc": 2123, + "wDes": 857, + "yMin": -857, + "yMax": 2123, + "hAsc": 2123, + "hDes": -857, + "lGap": 0 + } + }, { "family": "Philosopher", "fallbacks": ["sans-serif"], @@ -37558,6 +37998,31 @@ "lGap": 0 } }, + { + "family": "Ponnala", + "fallbacks": ["cursive"], + "weights": [400], + "styles": ["regular"], + "variants": [[0, 400]], + "service": "fonts.google.com", + "metrics": { + "upm": 1024, + "asc": 938, + "des": -861, + "tAsc": 938, + "tDes": -861, + "tLGap": 0, + "wAsc": 938, + "wDes": 861, + "xH": 0, + "capH": 0, + "yMin": -861, + "yMax": 938, + "hAsc": 938, + "hDes": -861, + "lGap": 0 + } + }, { "family": "Pontano Sans", "fallbacks": ["sans-serif"], @@ -44197,6 +44662,50 @@ "lGap": 0 } }, + { + "family": "Sour Gummy", + "fallbacks": ["sans-serif"], + "weights": [100, 200, 300, 400, 500, 600, 700, 800, 900], + "styles": ["regular", "italic"], + "variants": [ + [0, 100], + [0, 200], + [0, 300], + [0, 400], + [0, 500], + [0, 600], + [0, 700], + [0, 800], + [0, 900], + [1, 100], + [1, 200], + [1, 300], + [1, 400], + [1, 500], + [1, 600], + [1, 700], + [1, 800], + [1, 900] + ], + "service": "fonts.google.com", + "metrics": { + "upm": 1000, + "asc": 996, + "des": -296, + "tAsc": 996, + "tDes": -296, + "tLGap": 0, + "wAsc": 950, + "wDes": 508, + "xH": 500, + "capH": 700, + "yMin": -275, + "yMax": 866, + "hAsc": 996, + "hDes": -296, + "lGap": 0 + } + }, { "family": "Source Code Pro", "fallbacks": ["monospace"], @@ -49553,11 +50062,13 @@ "family": "Zain", "fallbacks": ["sans-serif"], "weights": [200, 300, 400, 700, 800, 900], - "styles": ["regular"], + "styles": ["italic", "regular"], "variants": [ [0, 200], [0, 300], + [1, 300], [0, 400], + [1, 400], [0, 700], [0, 800], [0, 900] diff --git a/packages/media/src/seekVideo.ts b/packages/media/src/seekVideo.ts index 28faf58cd6ef..1fad2b8eaeee 100644 --- a/packages/media/src/seekVideo.ts +++ b/packages/media/src/seekVideo.ts @@ -32,7 +32,7 @@ function seekVideo(video: HTMLVideoElement, offset = 0.99): Promise { video.addEventListener('seeking', (evt) => { const wait = setTimeout(() => { clearTimeout(wait); - reject(evt); + reject(evt as unknown as Error); }, THREE_SECONDS); }); video.addEventListener('error', reject); diff --git a/packages/media/src/test/isAnimatedGif.ts b/packages/media/src/test/isAnimatedGif.ts index 9c2b05bbc3df..b74d7335f35c 100644 --- a/packages/media/src/test/isAnimatedGif.ts +++ b/packages/media/src/test/isAnimatedGif.ts @@ -32,7 +32,7 @@ describe('isAnimatedGif', () => { buffer.byteOffset, buffer.byteOffset + buffer.byteLength ); - const result = isAnimatedGif(arrayBuffer); + const result = isAnimatedGif(arrayBuffer as unknown as ArrayBuffer); expect(result).toBeTrue(); }); @@ -43,7 +43,7 @@ describe('isAnimatedGif', () => { buffer.byteOffset, buffer.byteOffset + buffer.byteLength ); - const result = isAnimatedGif(arrayBuffer); + const result = isAnimatedGif(arrayBuffer as unknown as ArrayBuffer); expect(result).toBeFalse(); }); diff --git a/packages/migration/package.json b/packages/migration/package.json index ef53cb4df1dd..c2bd7f017d0b 100644 --- a/packages/migration/package.json +++ b/packages/migration/package.json @@ -44,7 +44,7 @@ }, "devDependencies": { "@rollup/plugin-babel": "^6.0.4", - "@rollup/plugin-node-resolve": "^15.2.3", + "@rollup/plugin-node-resolve": "^15.3.0", "rollup": "^2.79.2" }, "scripts": { diff --git a/packages/rich-text/src/formatters/color.ts b/packages/rich-text/src/formatters/color.ts index 8a544b5dfa0b..107ef967832f 100644 --- a/packages/rich-text/src/formatters/color.ts +++ b/packages/rich-text/src/formatters/color.ts @@ -20,8 +20,6 @@ import { createSolid, generatePatternStyles, - getHexFromSolid, - getSolidFromHex, isPatternEqual, createSolidFromString, } from '@googleforcreators/patterns'; @@ -37,17 +35,7 @@ import { togglePrefixStyle, getPrefixStylesInSelection, } from '../styleManipulation'; -import { isStyle, getVariable } from './util'; - -/* - * Color uses PREFIX-XXXXXXXX where XXXXXXXX is the 8 digit - * hex representation of the RGBA color. - */ -const styleToColor = (style: string): Pattern => - getSolidFromHex(getVariable(style, COLOR)); - -const colorToStyle = (color: Solid): string => - `${COLOR}-${getHexFromSolid(color)}`; +import { isStyle, styleToColor, colorToStyle } from './util'; function elementToStyle(element: HTMLElement): string | null { const isSpan = element.tagName.toLowerCase() === 'span'; diff --git a/packages/rich-text/src/formatters/gradientColor.ts b/packages/rich-text/src/formatters/gradientColor.ts index f841ec93ca1c..f6fd7087c6d3 100644 --- a/packages/rich-text/src/formatters/gradientColor.ts +++ b/packages/rich-text/src/formatters/gradientColor.ts @@ -20,7 +20,6 @@ import { createSolid, generatePatternStyles, - getGradientStyleFromColor, isPatternEqual, getColorFromGradientStyle, type Gradient, @@ -38,13 +37,11 @@ import { togglePrefixStyle, getPrefixStylesInSelection, } from '../styleManipulation'; -import { isStyle, getVariable } from './util'; - -const styleToColor = (style: string): Gradient => - getColorFromGradientStyle(getVariable(style, GRADIENT_COLOR)); - -const colorToStyle = (color: Gradient): string => - `${GRADIENT_COLOR}-${getGradientStyleFromColor(color)}`; +import { + isStyle, + styleToGradientColor as styleToColor, + gradientColorToStyle as colorToStyle, +} from './util'; function elementToStyle(element: HTMLElement): string | null { const isSpan = element.tagName.toLowerCase() === 'span'; diff --git a/packages/rich-text/src/formatters/italic.ts b/packages/rich-text/src/formatters/italic.ts index ec2ff91086c7..6666b7c462eb 100644 --- a/packages/rich-text/src/formatters/italic.ts +++ b/packages/rich-text/src/formatters/italic.ts @@ -51,10 +51,7 @@ function isItalic(editorState: EditorState) { return !styles.includes(NONE); } -function toggleItalic( - editorState: EditorState, - flag?: undefined | boolean -): EditorState { +function toggleItalic(editorState: EditorState, flag?: boolean): EditorState { if (typeof flag === 'boolean') { return togglePrefixStyle(editorState, ITALIC, () => flag); } diff --git a/packages/rich-text/src/formatters/underline.ts b/packages/rich-text/src/formatters/underline.ts index a1342972dd00..be896d423d9d 100644 --- a/packages/rich-text/src/formatters/underline.ts +++ b/packages/rich-text/src/formatters/underline.ts @@ -51,7 +51,7 @@ function isUnderline(editorState: EditorState) { return !styles.includes(NONE); } -function toggleUnderline(editorState: EditorState, flag?: undefined | boolean) { +function toggleUnderline(editorState: EditorState, flag?: boolean) { if (typeof flag === 'boolean') { return togglePrefixStyle(editorState, UNDERLINE, () => flag); } diff --git a/packages/rich-text/src/formatters/uppercase.ts b/packages/rich-text/src/formatters/uppercase.ts index 59af63230c4e..47994b9a6336 100644 --- a/packages/rich-text/src/formatters/uppercase.ts +++ b/packages/rich-text/src/formatters/uppercase.ts @@ -51,7 +51,7 @@ function isUppercase(editorState: EditorState) { return !styles.includes(NONE); } -function toggleUppercase(editorState: EditorState, flag?: undefined | boolean) { +function toggleUppercase(editorState: EditorState, flag?: boolean) { if (typeof flag === 'boolean') { return togglePrefixStyle(editorState, UPPERCASE, () => flag); } diff --git a/packages/rich-text/src/formatters/util.ts b/packages/rich-text/src/formatters/util.ts index b6cecb6f58bb..9aaccb06d5b6 100644 --- a/packages/rich-text/src/formatters/util.ts +++ b/packages/rich-text/src/formatters/util.ts @@ -18,11 +18,25 @@ * External dependencies */ import type { FontWeight, FontVariantStyle } from '@googleforcreators/elements'; +import { + getColorFromGradientStyle, + getGradientStyleFromColor, + getHexFromSolid, + getSolidFromHex, + type Gradient, + type Pattern, + type Solid, +} from '@googleforcreators/patterns'; /** * Internal dependencies */ -import { type LETTERSPACING, WEIGHT } from '../customConstants'; +import { + COLOR, + GRADIENT_COLOR, + type LETTERSPACING, + WEIGHT, +} from '../customConstants'; export const isStyle = (style: string | undefined, prefix: string) => Boolean(style?.startsWith(prefix)); @@ -60,3 +74,19 @@ export function styleToNumeric( export function weightToStyle(weight: number) { return numericToStyle(WEIGHT, weight); } + +/* + * Color uses PREFIX-XXXXXXXX where XXXXXXXX is the 8 digit + * hex representation of the RGBA color. + */ +export const styleToColor = (style: string): Pattern => + getSolidFromHex(getVariable(style, COLOR)); + +export const colorToStyle = (color: Solid): string => + `${COLOR}-${getHexFromSolid(color)}`; + +export const styleToGradientColor = (style: string): Gradient => + getColorFromGradientStyle(getVariable(style, GRADIENT_COLOR)); + +export const gradientColorToStyle = (color: Gradient): string => + `${GRADIENT_COLOR}-${getGradientStyleFromColor(color)}`; diff --git a/packages/rich-text/src/formatters/weight.ts b/packages/rich-text/src/formatters/weight.ts index 76207c189a1f..262014c06a03 100644 --- a/packages/rich-text/src/formatters/weight.ts +++ b/packages/rich-text/src/formatters/weight.ts @@ -73,7 +73,7 @@ function isBold(editorState: EditorState) { return weights.every((w) => w >= SMALLEST_BOLD); } -function toggleBold(editorState: EditorState, flag?: undefined | boolean) { +function toggleBold(editorState: EditorState, flag?: boolean) { if (typeof flag === 'boolean') { if (flag) { const getDefault = () => weightToStyle(DEFAULT_BOLD); diff --git a/packages/rich-text/src/getTextColors.ts b/packages/rich-text/src/getTextColors.ts new file mode 100644 index 000000000000..763e676ec336 --- /dev/null +++ b/packages/rich-text/src/getTextColors.ts @@ -0,0 +1,48 @@ +/* + * Copyright 2024 Google LLC + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * https://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +/** + * External dependencies + */ +import { + createSolid, + getHexFromSolid, + type Solid, +} from '@googleforcreators/patterns'; + +/** + * Internal dependencies + */ +import { COLOR, NONE } from './customConstants'; +import { getSelectAllStateFromHTML } from './htmlManipulation'; +import { getPrefixStylesInSelection } from './styleManipulation'; +import { styleToColor } from './formatters/util'; + +export default function getTextColors(html: string): string[] { + const htmlState = getSelectAllStateFromHTML(html); + return getPrefixStylesInSelection(htmlState, COLOR) + .map((color) => { + if (color === NONE) { + return createSolid(0, 0, 0); + } + + return styleToColor(color) as Solid; + }) + .map( + // To remove the alpha channel. + (color) => '#' + getHexFromSolid(color).slice(0, 6) + ); +} diff --git a/packages/rich-text/src/htmlManipulation.ts b/packages/rich-text/src/htmlManipulation.ts index 61387cb676a3..cc3b16f1442d 100644 --- a/packages/rich-text/src/htmlManipulation.ts +++ b/packages/rich-text/src/htmlManipulation.ts @@ -18,6 +18,7 @@ * External dependencies */ import { EditorState } from 'draft-js'; +import { filterEditorState } from 'draftjs-filters'; /** * Internal dependencies @@ -28,6 +29,16 @@ import customImport from './customImport'; import customExport from './customExport'; import { getSelectionForAll } from './util'; import type { StyleSetter, AllowedSetterArgs } from './types'; +import { + ITALIC, + UNDERLINE, + WEIGHT, + COLOR, + LETTERSPACING, + UPPERCASE, + GRADIENT_COLOR, +} from './customConstants'; +import { getPrefixStylesInSelection } from './styleManipulation'; /** * Return an editor state object with content set to parsed HTML @@ -60,8 +71,7 @@ function updateAndReturnHTML( ...args: [AllowedSetterArgs] ) { const stateWithUpdate = updater(getSelectAllStateFromHTML(html), ...args); - const renderedHTML = customExport(stateWithUpdate); - return renderedHTML; + return customExport(stateWithUpdate); } const getHTMLFormatter = @@ -90,3 +100,32 @@ export function getHTMLInfo(html: string) { const htmlStateInfo = getStateInfo(getSelectAllStateFromHTML(html)); return htmlStateInfo; } + +export function sanitizeEditorHtml(html: string) { + const editorState = getSelectAllStateFromHTML(html); + + const styles: string[] = [ + ...getPrefixStylesInSelection(editorState, ITALIC), + ...getPrefixStylesInSelection(editorState, UNDERLINE), + ...getPrefixStylesInSelection(editorState, WEIGHT), + ...getPrefixStylesInSelection(editorState, COLOR), + ...getPrefixStylesInSelection(editorState, LETTERSPACING), + ...getPrefixStylesInSelection(editorState, UPPERCASE), + ...getPrefixStylesInSelection(editorState, GRADIENT_COLOR), + ]; + + return ( + customExport( + filterEditorState( + { + blocks: [], + styles, + entities: [], + maxNesting: 1, + whitespacedCharacters: [], + }, + editorState + ) + ) || '' + ); +} diff --git a/packages/rich-text/src/index.ts b/packages/rich-text/src/index.ts index 1ad875eee0c0..875e4ae4e835 100644 --- a/packages/rich-text/src/index.ts +++ b/packages/rich-text/src/index.ts @@ -23,6 +23,7 @@ export { default as RichTextContext } from './context'; export { default as useRichText } from './useRichText'; export { default as usePasteTextContent } from './usePasteTextContent'; export { default as getFontVariants } from './getFontVariants'; +export { default as getTextColors } from './getTextColors'; export { default as getCaretCharacterOffsetWithin } from './utils/getCaretCharacterOffsetWithin'; export * from './htmlManipulation'; diff --git a/packages/story-editor/src/components/checklist/utils/getSpansFromContent.js b/packages/rich-text/src/test/getTextColors.ts similarity index 51% rename from packages/story-editor/src/components/checklist/utils/getSpansFromContent.js rename to packages/rich-text/src/test/getTextColors.ts index 9ec25e0950ce..df79b7a69e8f 100644 --- a/packages/story-editor/src/components/checklist/utils/getSpansFromContent.js +++ b/packages/rich-text/src/test/getTextColors.ts @@ -1,5 +1,5 @@ /* - * Copyright 2021 Google LLC + * Copyright 2020 Google LLC * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -14,22 +14,19 @@ * limitations under the License. */ -let spansFromContentBuffer; /** - * - * @param {string} content the buffer containing text element content - * @return {Array} list of individual span elements from the content + * Internal dependencies */ -export function getSpansFromContent(content) { - // memoize buffer - if (!spansFromContentBuffer) { - spansFromContentBuffer = document.createElement('div'); - } +import getTextColors from '../getTextColors'; + +describe('getTextColors', () => { + it('should return a list of text colors', () => { + const htmlContent = + 'Fill in some text'; + const expected = ['#000000', '#eb0404', '#026111']; - spansFromContentBuffer.innerHTML = content; + const actual = getTextColors(htmlContent); - // return Array instead of HtmlCollection - return Array.prototype.slice.call( - spansFromContentBuffer.getElementsByTagName('span') - ); -} + expect(actual).toStrictEqual(expected); + }); +}); diff --git a/packages/rich-text/src/utils/getCaretCharacterOffsetWithin.ts b/packages/rich-text/src/utils/getCaretCharacterOffsetWithin.ts index 12ba29adfaee..7e46be0dcd67 100644 --- a/packages/rich-text/src/utils/getCaretCharacterOffsetWithin.ts +++ b/packages/rich-text/src/utils/getCaretCharacterOffsetWithin.ts @@ -44,7 +44,11 @@ interface CaretPosition { } interface SelectionDocument extends Document { - caretPositionFromPoint?: (x: number, y: number) => CaretPosition | null; + caretPositionFromPoint: ( + x: number, + y: number, + options?: CaretPositionFromPointOptions + ) => CaretPosition | null; } // Extend for wider browser support. diff --git a/packages/stories-block/package.json b/packages/stories-block/package.json index fffc9b5afc00..b7e14b326bfb 100644 --- a/packages/stories-block/package.json +++ b/packages/stories-block/package.json @@ -40,7 +40,7 @@ "@wordpress/core-data": "^6.24.0", "@wordpress/data": "^9.17.0", "@wordpress/date": "^4.47.0", - "@wordpress/element": "^6.10.0", + "@wordpress/element": "^6.12.0", "@wordpress/i18n": "^4.47.0", "@wordpress/icons": "^9.38.0", "@wordpress/notices": "^4.15.0", diff --git a/packages/story-editor/package.json b/packages/story-editor/package.json index 0e0f6267434c..c987b1703b96 100644 --- a/packages/story-editor/package.json +++ b/packages/story-editor/package.json @@ -90,7 +90,7 @@ "devDependencies": { "@googleforcreators/karma-fixture": "*", "@googleforcreators/test-utils": "*", - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/dom": "^10.1.0", "@testing-library/jest-dom": "^6.5.0", "@testing-library/react": "^12.1.5", diff --git a/packages/story-editor/src/app/canvas/useCanvasKeys.ts b/packages/story-editor/src/app/canvas/useCanvasKeys.ts index 33fc4c88a9ae..b0134effd6c6 100644 --- a/packages/story-editor/src/app/canvas/useCanvasKeys.ts +++ b/packages/story-editor/src/app/canvas/useCanvasKeys.ts @@ -179,7 +179,7 @@ function useCanvasKeys(ref: RefObject) { // Position (x/y) key handler. useGlobalKeyDownEffect( { key: ['up', 'down', 'left', 'right'], shift: true }, - ({ key, shiftKey }) => { + ({ key, shiftKey }: KeyboardEvent) => { if (isEditing || !selectedElements?.length) { return; } @@ -204,7 +204,7 @@ function useCanvasKeys(ref: RefObject) { // Layer up/down. useGlobalKeyDownEffect( { key: ['mod+up', 'mod+down', 'mod+left', 'mod+right'], shift: true }, - (evt) => { + (evt: KeyboardEvent) => { const { key, shiftKey } = evt; // Cancel the default behavior of the event: it's very jarring to run @@ -293,7 +293,7 @@ function useCanvasKeys(ref: RefObject) { ].includes(animationState); useGlobalKeyDownEffect( { key: ['mod+enter'] }, - (evt) => { + (evt: KeyboardEvent) => { evt.preventDefault(); if (currentPageNumber === 1) { return; @@ -313,7 +313,7 @@ function useCanvasKeys(ref: RefObject) { useGlobalKeyDownEffect( { key: ['mod+k'] }, - (evt) => { + (evt: KeyboardEvent) => { evt.preventDefault(); if ( !selectedElements.length || diff --git a/packages/story-editor/src/app/media/utils/heif/utils.ts b/packages/story-editor/src/app/media/utils/heif/utils.ts index db379ee986a0..f92f74e5d5c1 100644 --- a/packages/story-editor/src/app/media/utils/heif/utils.ts +++ b/packages/story-editor/src/app/media/utils/heif/utils.ts @@ -60,7 +60,7 @@ export async function decodeImage(image: DecodeResult) { if (!result) { reject(new Error('HEIF processing error')); } else { - resolve(result.data.buffer); + resolve(result.data.buffer as ArrayBuffer); } } ); diff --git a/packages/story-editor/src/app/media/utils/useFFmpeg.ts b/packages/story-editor/src/app/media/utils/useFFmpeg.ts index 21b00f49ddd9..d707123999ac 100644 --- a/packages/story-editor/src/app/media/utils/useFFmpeg.ts +++ b/packages/story-editor/src/app/media/utils/useFFmpeg.ts @@ -205,7 +205,9 @@ function useFFmpeg() { const data = ffmpeg.FS('readFile', tempFileName); return blobToFile( - new Blob([data.buffer], { type: MEDIA_POSTER_IMAGE_MIME_TYPE }), + new Blob([data.buffer as BlobPart], { + type: MEDIA_POSTER_IMAGE_MIME_TYPE, + }), outputFileName, MEDIA_POSTER_IMAGE_MIME_TYPE ); @@ -263,7 +265,9 @@ function useFFmpeg() { const data = ffmpeg.FS('readFile', tempFileName); return blobToFile( - new Blob([data.buffer], { type: MEDIA_TRANSCODED_MIME_TYPE }), + new Blob([data.buffer as BlobPart], { + type: MEDIA_TRANSCODED_MIME_TYPE, + }), outputFileName, MEDIA_TRANSCODED_MIME_TYPE ); @@ -348,7 +352,7 @@ function useFFmpeg() { .map((outputFile) => { const data = (ffmpeg as FFmpeg).FS('readFile', outputFile); return blobToFile( - new Blob([data.buffer], { type }), + new Blob([data.buffer as BlobPart], { type }), outputFile, type ); @@ -417,7 +421,7 @@ function useFFmpeg() { const data = ffmpeg.FS('readFile', tempFileName); return blobToFile( - new Blob([data.buffer], { type }), + new Blob([data.buffer as BlobPart], { type }), outputFileName, type ); @@ -478,7 +482,7 @@ function useFFmpeg() { const data = ffmpeg.FS('readFile', tempFileName); return blobToFile( - new Blob([data.buffer], { type }), + new Blob([data.buffer as BlobPart], { type }), outputFileName, type ); @@ -538,7 +542,7 @@ function useFFmpeg() { const data = ffmpeg.FS('readFile', tempFileName); return blobToFile( - new Blob([data.buffer], { type }), + new Blob([data.buffer as BlobPart], { type }), outputFileName, type ); @@ -596,7 +600,9 @@ function useFFmpeg() { const data = ffmpeg.FS('readFile', tempFileName); return blobToFile( - new Blob([data.buffer], { type: MEDIA_TRANSCODED_MIME_TYPE }), + new Blob([data.buffer as BlobPart], { + type: MEDIA_TRANSCODED_MIME_TYPE, + }), outputFileName, MEDIA_TRANSCODED_MIME_TYPE ); @@ -651,7 +657,7 @@ function useFFmpeg() { const data = ffmpeg.FS('readFile', tempFileName); return blobToFile( - new Blob([data.buffer], { type: 'audio/mpeg' }), + new Blob([data.buffer as BlobPart], { type: 'audio/mpeg' }), outputFileName, 'audio/mpeg' ); diff --git a/packages/story-editor/src/components/canvas/utils/getElementProperties.ts b/packages/story-editor/src/components/canvas/utils/getElementProperties.ts index 2d3dbc6d1ac9..f17b56eb0523 100644 --- a/packages/story-editor/src/components/canvas/utils/getElementProperties.ts +++ b/packages/story-editor/src/components/canvas/utils/getElementProperties.ts @@ -46,7 +46,7 @@ function getElementProperties(type: ElementType, element: Element) { let resource, scale, focalX, focalY, sticker; if (elementIs.sticker(element)) { sticker = element.sticker; - ratio = STICKERS?.[sticker.type as keyof typeof STICKERS]?.aspectRatio; + ratio = STICKERS?.[sticker.type]?.aspectRatio; } else if (elementIs.media(element)) { resource = element.resource; ratio = diff --git a/packages/story-editor/src/components/checklist/checks/pageBackgroundLowTextContrast/check.js b/packages/story-editor/src/components/checklist/checks/pageBackgroundLowTextContrast/check.js index bf11ed88e270..8eab4ce1708a 100644 --- a/packages/story-editor/src/components/checklist/checks/pageBackgroundLowTextContrast/check.js +++ b/packages/story-editor/src/components/checklist/checks/pageBackgroundLowTextContrast/check.js @@ -27,6 +27,7 @@ import { preloadImage, } from '@googleforcreators/media'; import { createSolidFromString } from '@googleforcreators/patterns'; +import { getTextColors } from '@googleforcreators/rich-text'; /** * Internal dependencies @@ -36,7 +37,6 @@ import { calculateLuminanceFromStyleColor, checkContrastFromLuminances, } from '../../../../utils/contrastUtils'; -import { getSpansFromContent } from '../../utils'; import getMediaBaseColor from '../../../../utils/getMediaBaseColor'; import { noop } from '../../../../utils/noop'; @@ -276,19 +276,7 @@ async function getOverlapBgColor({ bgImage, bgBox, overlapBox }) { * @return {Array} the style colors from the span tags in text element content */ function getTextStyleColors(element) { - const spans = getSpansFromContent(element.content); - const textStyleColors = spans - .map((span) => span.style?.color) - .filter(Boolean); - // if no colors were retrieved but there are spans, there is a black default color - const noColorStyleOnSpans = - textStyleColors.length === 0 && spans.length !== 0; - // if no spans were retrieved but there is content, there is a black default color - const noSpans = element.content.length !== 0 && spans.length === 0; - if (noColorStyleOnSpans || noSpans) { - textStyleColors.push('rgb(0, 0, 0)'); - } - return textStyleColors; + return getTextColors(element.content); } function getTextShapeBackgroundColor({ background }) { diff --git a/packages/story-editor/src/components/checklist/utils/index.js b/packages/story-editor/src/components/checklist/utils/index.js index 1463997c0b9d..addb438fac0a 100644 --- a/packages/story-editor/src/components/checklist/utils/index.js +++ b/packages/story-editor/src/components/checklist/utils/index.js @@ -18,5 +18,4 @@ export { characterCountForPage } from './characterCountForPage'; export { filterStoryPages } from './filterStoryPages'; export { filterStoryElements } from './filterStoryElements'; export { getVisibleThumbnails } from './getVisibleThumbnails'; -export { getSpansFromContent } from './getSpansFromContent'; export { ThumbnailPagePreview } from './thumbnailPagePreview'; diff --git a/packages/story-editor/src/components/footer/carousel/carouselContext/useCarouselKeys.ts b/packages/story-editor/src/components/footer/carousel/carouselContext/useCarouselKeys.ts index f85c5999d38d..b7506c69c681 100644 --- a/packages/story-editor/src/components/footer/carousel/carouselContext/useCarouselKeys.ts +++ b/packages/story-editor/src/components/footer/carousel/carouselContext/useCarouselKeys.ts @@ -70,7 +70,7 @@ function useCarouselKeys({ useKeyDownEffect( listElement, { key: ['up', 'down', 'left', 'right'] }, - ({ key }) => { + ({ key }: KeyboardEvent) => { // Intercept all keys, but only handle left and right. const dir = getArrowDir(key, 'ArrowRight', 'ArrowLeft', isRTL); if (dir === 0) { @@ -103,7 +103,7 @@ function useCarouselKeys({ useKeyDownEffect( listElement, { key: ['mod+up', 'mod+down', 'mod+left', 'mod+right'], shift: true }, - (evt) => { + (evt: KeyboardEvent) => { const { key, shiftKey } = evt; // Cancel the default behavior of the event: it's very jarring to run diff --git a/packages/story-editor/src/components/panels/design/link/link.js b/packages/story-editor/src/components/panels/design/link/link.js index 5efcd69b0094..f5e75aac2b79 100644 --- a/packages/story-editor/src/components/panels/design/link/link.js +++ b/packages/story-editor/src/components/panels/design/link/link.js @@ -177,7 +177,7 @@ function LinkPanel({ selectedElements, pushUpdateForObject }) { newIcon, needsProxy, }); - } catch (e) { + } catch { setIsInvalidUrl(true); } finally { setFetchingMetadata(false); diff --git a/packages/story-editor/src/karma/element-library/text/edit.karma.js b/packages/story-editor/src/karma/element-library/text/edit.karma.js index 9ffec2272cb9..ae12eaba7a85 100644 --- a/packages/story-editor/src/karma/element-library/text/edit.karma.js +++ b/packages/story-editor/src/karma/element-library/text/edit.karma.js @@ -227,7 +227,9 @@ describe('TextEdit integration', () => { let initialHeight; describe('edit mode', () => { - it('should not change height when entering and exiting edit mode', async () => { + // TODO: Fix flakey test. + // eslint-disable-next-line jasmine/no-disabled-tests + xit('should not change height when entering and exiting edit mode', async () => { await fixture.editor.library.textTab.click(); await fixture.events.click( fixture.editor.library.text.preset('Paragraph') diff --git a/packages/story-editor/src/utils/getMediaBaseColor.ts b/packages/story-editor/src/utils/getMediaBaseColor.ts index 69bc4920c062..d8b759c34ef0 100644 --- a/packages/story-editor/src/utils/getMediaBaseColor.ts +++ b/packages/story-editor/src/utils/getMediaBaseColor.ts @@ -41,7 +41,7 @@ async function extractColorFromImage(img: HTMLImageElement): Promise { if (err instanceof Error) { void trackError('image_base_color', err.message); } - reject(err); + reject(err as Error); } }); } diff --git a/packages/tinymce-button/package.json b/packages/tinymce-button/package.json index df2e7a1feeaa..d3e3502bddca 100644 --- a/packages/tinymce-button/package.json +++ b/packages/tinymce-button/package.json @@ -29,7 +29,7 @@ "@wordpress/compose": "^6.24.0", "@wordpress/data": "^9.17.0", "@wordpress/dom-ready": "^3.47.0", - "@wordpress/element": "^6.10.0", + "@wordpress/element": "^6.12.0", "@wordpress/i18n": "^4.47.0", "prop-types": "^15.8.1" }, diff --git a/packages/wp-dashboard/package.json b/packages/wp-dashboard/package.json index 82eabed15132..e1705954a3a9 100644 --- a/packages/wp-dashboard/package.json +++ b/packages/wp-dashboard/package.json @@ -48,7 +48,7 @@ "uuid": "^10.0.0" }, "devDependencies": { - "@storybook/addon-essentials": "^8.4.1", + "@storybook/addon-essentials": "^8.4.6", "@testing-library/react": "^12.1.5", "@testing-library/react-hooks": "^8.0.1", "@testing-library/user-event": "^14.5.2" diff --git a/phpstan.neon.dist b/phpstan.neon.dist index 5e86220a973b..2c74e79b84c0 100644 --- a/phpstan.neon.dist +++ b/phpstan.neon.dist @@ -17,6 +17,10 @@ parameters: ignoreErrors: - identifier: missingType.generics + - + identifier: requireOnce.fileNotFound + - + identifier: require.fileNotFound - message: '/^Parameter #2 \$args of method WP_Customize_Manager::add_setting\(\)/' path: includes/Admin/Customizer.php @@ -61,5 +65,3 @@ parameters: - IS_WPCOM - GOOGLESITEKIT_VERSION - AMP__VERSION - featureToggles: - requireFileExists: false diff --git a/readme.txt b/readme.txt index 663b52d721a9..6c56cf64fade 100644 --- a/readme.txt +++ b/readme.txt @@ -105,10 +105,26 @@ There are two ways to include analytics in your Web Stories: Web Stories are powered by [AMP](https://amp.dev/), which adds some restrictions on a page's allowed markup. In some cases, other WordPress plugins use disallowed markup. We recommend temporarily disabling these plugins and reaching out to our [support forum](https://wordpress.org/plugins/web-stories/). += Where can I report bugs? = + +For help requests, support questions, or general feedback, please reach out via the [support forum](https://wordpress.org/plugins/web-stories/). + +Reproducible bug reports can be filed [on GitHub](https://github.com/googleforcreators/web-stories-wp/). + +To report a vulnerability in this plugin, please contact the Google Security Team at [g.co/vulnz](https://g.co/vulnz). + == Changelog == For the plugin's full changelog, please see [the Releases page on GitHub](https://github.com/googleforcreators/web-stories-wp/releases). += 1.38.0 = + +* Enhancement: compatibility with WordPress 6.6 and 6.7. +* Enhancement: raises minimum WordPress version to 6.5. +* Enhancement: updated list of available Google Fonts. +* Fixed: resolved a minor issue when parsing text elements in the editor. +* Minor code quality improvements and bug fixes. + = 1.37.0 = * Feature: added support for [stickers](https://amp.dev/documentation/components/stories/amp-story-audio-sticker) for users to click and unmute the story. @@ -123,15 +139,8 @@ For the plugin's full changelog, please see [the Releases page on GitHub](https: * Fixed: resolved an issue with canvas zoom. * Fixed: resolved several layout issues with the Web Stories block. -= 1.35.0 = - -* Enhancement: compatibility with WordPress 6.4. New minimum version required is 6.2. -* Enhancement: improve captions appearance when there is also a call-to-action. -* Fixed: resolved an issue with stories not appearing in the lightbox. -* Various smaller bug fixes. - == Upgrade Notice == -= 1.3.7.0 = += 1.38.0 = -This release improves frontend performance and adds initial support for audio stickers. +This release ensures compatibility with WordPress 6.7 and contains minor bug fixes. diff --git a/tests/phpstan/src/ServiceContainerDynamicReturnTypeExtension.php b/tests/phpstan/src/ServiceContainerDynamicReturnTypeExtension.php index bd84bed79575..b974526af769 100644 --- a/tests/phpstan/src/ServiceContainerDynamicReturnTypeExtension.php +++ b/tests/phpstan/src/ServiceContainerDynamicReturnTypeExtension.php @@ -70,7 +70,8 @@ public function getTypeFromMethodCall( case 'get': return $this->getGetTypeFromMethodCall( $methodReflection, - $methodCall + $methodCall, + $scope, ); case 'has': @@ -85,9 +86,12 @@ public function getTypeFromMethodCall( private function getGetTypeFromMethodCall( MethodReflection $methodReflection, - MethodCall $methodCall + MethodCall $methodCall, + Scope $scope ): Type { - $return_type = ParametersAcceptorSelector::selectSingle( + $return_type = ParametersAcceptorSelector::selectFromArgs( + $scope, + $methodCall->getArgs(), $methodReflection->getVariants() )->getReturnType(); diff --git a/tests/phpstan/src/ServicesDynamicReturnTypeExtension.php b/tests/phpstan/src/ServicesDynamicReturnTypeExtension.php index 2947a504f0a8..0aca9fbbdab4 100644 --- a/tests/phpstan/src/ServicesDynamicReturnTypeExtension.php +++ b/tests/phpstan/src/ServicesDynamicReturnTypeExtension.php @@ -71,7 +71,8 @@ public function getTypeFromStaticMethodCall( case 'get': return $this->getGetTypeFromStaticMethodCall( $methodReflection, - $methodCall + $methodCall, + $scope ); } @@ -80,9 +81,12 @@ public function getTypeFromStaticMethodCall( private function getGetTypeFromStaticMethodCall( MethodReflection $methodReflection, - StaticCall $methodCall + StaticCall $methodCall, + Scope $scope ): Type { - $return_type = ParametersAcceptorSelector::selectSingle( + $return_type = ParametersAcceptorSelector::selectFromArgs( + $scope, + $methodCall->getArgs(), $methodReflection->getVariants() )->getReturnType(); diff --git a/tests/phpunit/integration/tests/Model/Story.php b/tests/phpunit/integration/tests/Model/Story.php index 80eaa6d935e9..86660df9e0d3 100644 --- a/tests/phpunit/integration/tests/Model/Story.php +++ b/tests/phpunit/integration/tests/Model/Story.php @@ -155,9 +155,7 @@ public function test_load_from_post_with_poster(): void { $this->assertEquals( $story->get_url(), get_permalink( $post ) ); $this->assertStringContainsString( 'paint-640x853.jpeg', $story->get_poster_portrait() ); $this->assertNotEmpty( $story->get_poster_sizes() ); - $this->assertIsString( $story->get_poster_sizes() ); $this->assertNotEmpty( $story->get_poster_srcset() ); - $this->assertIsString( $story->get_poster_srcset() ); } /** @@ -244,8 +242,6 @@ public function test_load_from_post_with_poster_and_poster_meta(): void { $this->assertEquals( $story->get_url(), get_permalink( $post ) ); $this->assertStringContainsString( 'paint-640x853.jpeg', $story->get_poster_portrait() ); $this->assertNotEmpty( $story->get_poster_sizes() ); - $this->assertIsString( $story->get_poster_sizes() ); $this->assertNotEmpty( $story->get_poster_srcset() ); - $this->assertIsString( $story->get_poster_srcset() ); } } diff --git a/tests/phpunit/integration/tests/REST_API/Stories_Controller.php b/tests/phpunit/integration/tests/REST_API/Stories_Controller.php index 4a4117f75940..fd8874f0f6b5 100644 --- a/tests/phpunit/integration/tests/REST_API/Stories_Controller.php +++ b/tests/phpunit/integration/tests/REST_API/Stories_Controller.php @@ -930,7 +930,6 @@ public function test_get_collection_params(): void { $this->assertArrayHasKey( 'web_stories_demo', $collection_params ); $this->assertArrayHasKey( 'orderby', $collection_params ); $this->assertArrayHasKey( 'enum', $collection_params['orderby'] ); - $this->assertIsArray( $collection_params['orderby'] ); $this->assertIsArray( $collection_params['orderby']['enum'] ); $this->assertContains( 'story_author', $collection_params['orderby']['enum'] ); } diff --git a/tests/phpunit/integration/tests/Tracking.php b/tests/phpunit/integration/tests/Tracking.php index 1fd7b1f821a3..0a6d78430211 100644 --- a/tests/phpunit/integration/tests/Tracking.php +++ b/tests/phpunit/integration/tests/Tracking.php @@ -187,14 +187,10 @@ public function test_get_settings(): void { $this->assertSame( 'administrator', $settings['userProperties']['userRole'] ); $this->assertSame( 'enableFoo,enableBar', $settings['userProperties']['enabledExperiments'] ); $this->assertSame( WEBSTORIES_VERSION, $settings['userProperties']['pluginVersion'] ); - $this->assertIsString( $settings['userProperties']['wpVersion'] ); - $this->assertIsString( $settings['userProperties']['phpVersion'] ); $this->assertIsInt( $settings['userProperties']['isMultisite'] ); $this->assertIsString( $settings['userProperties']['adNetwork'] ); $this->assertIsString( $settings['userProperties']['analytics'] ); $this->assertIsString( $settings['userProperties']['activePlugins'] ); - $this->assertIsString( $settings['userProperties']['serverEnvironment'] ); - $this->assertIsString( $settings['userProperties']['pluginVersion'] ); } /** diff --git a/web-stories.php b/web-stories.php index 0ece07be95a0..5933ab22f63b 100644 --- a/web-stories.php +++ b/web-stories.php @@ -9,7 +9,7 @@ * Plugin URI: https://wp.stories.google/ * Author: Google * Author URI: https://opensource.google.com/ - * Version: 1.38.0-alpha.0 + * Version: 1.39.0-alpha.0 * Requires at least: 6.5 * Requires PHP: 7.4 * Text Domain: web-stories @@ -40,7 +40,7 @@ exit; } -define( 'WEBSTORIES_VERSION', '1.38.0-alpha.0' ); +define( 'WEBSTORIES_VERSION', '1.39.0-alpha.0' ); define( 'WEBSTORIES_DB_VERSION', '3.0.16' ); define( 'WEBSTORIES_AMP_VERSION', '2.5.6-alpha' ); // Version of the AMP library included in the plugin. define( 'WEBSTORIES_PLUGIN_FILE', __FILE__ );