diff --git a/NOTES.md b/NOTES.md new file mode 100644 index 0000000..53cb3db --- /dev/null +++ b/NOTES.md @@ -0,0 +1,3 @@ +Notes for next 4.x release. + +- Minimum react version updated to 16.8.0 (hooks) diff --git a/babel.config.json b/babel.config.json index 7dd5e9d..fa82860 100644 --- a/babel.config.json +++ b/babel.config.json @@ -1,3 +1,7 @@ { - "presets": ["@babel/preset-react"] + "presets": [ + "@babel/preset-env", + ["@babel/preset-react", { "runtime": "automatic" }], + "@babel/preset-typescript" + ] } diff --git a/jest.config.js b/jest.config.js index 2f2923d..5ab6e97 100644 --- a/jest.config.js +++ b/jest.config.js @@ -7,8 +7,6 @@ const config = { collectCoverage: true, coverageDirectory: 'temp/coverage', coverageProvider: 'v8', - // The maximum amount of workers used to run your tests. Can be specified as % or a number. E.g. maxWorkers: 10% will use 10% of your CPU amount + 1 as the maximum worker number. maxWorkers: 2 will use a maximum of 2 workers. - // maxWorkers: "50%", // An array of directory names to be searched recursively up from the requiring module's location // moduleDirectories: [ @@ -39,35 +37,12 @@ const config = { // An enum that specifies notification mode. Requires { notify: true } // notifyMode: "failure-change", - // A preset that is used as a base for Jest's configuration - // preset: undefined, - - // Run tests from one or more projects - // projects: undefined, - - // Use this configuration option to add custom reporters to Jest - // reporters: undefined, - - // Automatically reset mock state before every test - // resetMocks: false, - // Reset the module registry before running each individual test // resetModules: false, // A path to a custom resolver // resolver: undefined, - // Automatically restore mock state and implementation before every test - // restoreMocks: false, - - // The root directory that Jest should scan for tests and modules within - // rootDir: undefined, - - // A list of paths to directories that Jest should use to search for files in - // roots: [ - // "" - // ], - // Allows you to use a custom runner instead of Jest's default test runner // runner: "jest-runner", @@ -117,7 +92,7 @@ const config = { // An array of regexp pattern strings that are matched against all source file paths, matched files will skip transformation // transformIgnorePatterns: [ - // "/node_modules/", + // '/node_modules/', // "\\.pnp\\.[^\\/]+$" // ], diff --git a/package.json b/package.json index 9587f4e..48bacda 100644 --- a/package.json +++ b/package.json @@ -21,8 +21,8 @@ "deploy": "gh-pages -d example/build" }, "peerDependencies": { - "react": ">=15", - "react-dom": ">=15" + "react": ">=16.8.0", + "react-dom": ">=16.8.0" }, "devDependencies": { "@babel/core": "^7.26.0", @@ -30,6 +30,7 @@ "@babel/preset-env": "^7.26.0", "@babel/preset-stage-0": "^7.8.3", "@babel/preset-react": "^7.25.9", + "@babel/preset-typescript": "^7.26.0", "country-region-data": "^3.1.0", "cross-env": "^5.1.4", "eslint": "^8.57.1", @@ -37,8 +38,8 @@ "jest-environment-jsdom": "^29.7.0", "gh-pages": "^1.2.0", "minimalist": "^1.0.0", - "react": "^16.4.1", - "react-dom": "^16.4.1", + "react": "^18.3.1", + "react-dom": "^18.3.1", "rollup": "^4.27.4", "typescript": "^5.7.2", "@rollup/plugin-babel": "^6.0.4", diff --git a/src/RegionDropdown.tsx b/src/RegionDropdown.tsx index 7718062..82da03c 100644 --- a/src/RegionDropdown.tsx +++ b/src/RegionDropdown.tsx @@ -6,8 +6,8 @@ import type { RegionDropdownProps } from './rcrs.types'; export const RegionDropdown: FC = ({ onChange, + value, country = '', - value = '', onBlur = () => null, id = '', name = 'rcrs-region', diff --git a/src/__tests__/CountryDropdown.js b/src/__tests__/CountryDropdown.js new file mode 100644 index 0000000..6c34784 --- /dev/null +++ b/src/__tests__/CountryDropdown.js @@ -0,0 +1,167 @@ +// import React from 'react'; +// import { CountryDropdown, CountryRegionData } from '../../dist/rcrs.es'; +// import Enzyme, { shallow } from 'enzyme'; + +// const Adapter = require('enzyme-adapter-react-16'); +// Enzyme.configure({ adapter: new Adapter() }); + +// describe('CountryDropdown', () => { +// it('sets ID attribute', () => { +// const wrapper = shallow(); +// expect(wrapper.find('#id-attribute').length).toBe(1); +// expect(wrapper.find('#fake-id-attribute').length).toBe(0); +// }); + +// it('classes attribute gets recognized', () => { +// const wrapper = shallow(); +// expect(wrapper.find('select').hasClass('one two three')).toBe(true); +// }); + +// it('passes arbitrary properties', () => { +// const wrapper = shallow( +// +// ); +// expect(wrapper.find('select').getElement().props.style.color).toBe('red'); +// expect(wrapper.find('select').getElement().props['data-whatever']).toBe( +// '5' +// ); +// }); + +// describe('name attribute', () => { +// it('falls back on default name attribute when not specified', () => { +// const wrapper = shallow(); +// expect(wrapper.find('select').getElement().props.name).toBe( +// 'rcrs-country' +// ); +// }); + +// it('sets explicit name attribute', () => { +// const wrapper = shallow(); +// expect(wrapper.find('select[name="name-attribute"]').length).toBe(1); +// expect(wrapper.find('select[name="fake-name-attribute"]').length).toBe(0); +// }); +// }); + +// describe('disabled attribute', () => { +// it('disabled attribute not on by default', () => { +// const wrapper = shallow(); +// expect(wrapper.find('select').getElement().props.disabled).toBe(false); +// }); +// it('disabled attribute', () => { +// const wrapper = shallow(); +// expect(wrapper.find('select').getElement().props.disabled).toBe(true); +// }); +// }); + +// describe('default blank option', () => { +// it('showDefaultOption = false removes the default option', () => { +// const wrapper = shallow(); +// expect(wrapper.find('option').length).toBe(CountryRegionData.length); +// }); + +// it('confirm default label is "Select Country"', () => { +// const wrapper = shallow(); +// expect(wrapper.find('select').childAt(0).text()).toBe('Select Country'); +// }); + +// it('defaultOptionLabel', () => { +// const customLabel = 'Holy moly I am a custom label!'; +// const wrapper = shallow( +// +// ); +// expect(wrapper.find('select').childAt(0).text()).toBe(customLabel); +// }); +// }); + +// describe('country list', () => { +// it('outputs the list of countries', () => { +// const wrapper = shallow(); +// expect(wrapper.find('option').length).toBe(CountryRegionData.length + 1); // 1 for the "Select Country" default option +// }); + +// it('respects the blacklist', () => { +// const blacklist = ['GB', 'CA', 'US']; +// const wrapper = shallow( +// +// ); +// expect(wrapper.find('option').length).toBe( +// CountryRegionData.length - blacklist.length +// ); + +// // confirm a non-blacklist item appears +// expect(wrapper.find('option[value="Afghanistan"]').length).toBe(1); + +// // confirm none of the blacklist item appears +// expect(wrapper.find('option[value="United Kingdom"]').length).toBe(0); +// expect(wrapper.find('option[value="Canada"]').length).toBe(0); +// expect(wrapper.find('option[value="United States"]').length).toBe(0); +// }); + +// it('respects the whitelist', () => { +// const whitelist = ['GB', 'CA', 'US']; +// const wrapper = shallow( +// +// ); +// expect(wrapper.find('option').length).toBe(whitelist.length); + +// // confirm the expected items appear +// expect(wrapper.find('option[value="United Kingdom"]').length).toBe(1); +// expect(wrapper.find('option[value="Canada"]').length).toBe(1); +// expect(wrapper.find('option[value="United States"]').length).toBe(1); +// }); +// }); + +// describe('valueType', () => { +// it('confirm value is full country name by default', () => { +// const wrapper = shallow(); +// expect(wrapper.find('select').childAt(0).getElement().props.value).toBe( +// CountryRegionData[0][0] +// ); +// }); + +// it('confirm explicit valueType="full" also sets full country name', () => { +// const wrapper = shallow( +// +// ); +// expect(wrapper.find('select').childAt(0).getElement().props.value).toBe( +// CountryRegionData[0][0] +// ); +// }); + +// it('confirm valueType="short" outputs country short code', () => { +// const wrapper = shallow( +// +// ); +// expect(wrapper.find('select').childAt(0).getElement().props.value).toBe( +// CountryRegionData[0][1] +// ); +// }); +// }); + +// describe('labelType', () => { +// it('confirm label type is full country name by default', () => { +// const wrapper = shallow(); +// expect(wrapper.find('select').childAt(0).text()).toBe( +// CountryRegionData[0][0] +// ); +// }); + +// it('confirm label type is full country name when explicitly set', () => { +// const wrapper = shallow( +// +// ); +// expect(wrapper.find('select').childAt(0).text()).toBe( +// CountryRegionData[0][0] +// ); +// }); + +// it('confirm label type is the country shortcode when set', () => { +// const wrapper = shallow( +// +// ); +// expect(wrapper.find('select').childAt(0).text()).toBe( +// CountryRegionData[0][1] +// ); +// }); +// }); +// }); diff --git a/src/__tests__/CountryDropdown.test.js b/src/__tests__/CountryDropdown.test.js deleted file mode 100644 index e01d698..0000000 --- a/src/__tests__/CountryDropdown.test.js +++ /dev/null @@ -1,167 +0,0 @@ -import React from 'react'; -import { CountryDropdown, CountryRegionData } from '../../dist/rcrs.es'; -import Enzyme, { shallow } from 'enzyme'; - -const Adapter = require('enzyme-adapter-react-16'); -Enzyme.configure({ adapter: new Adapter() }); - -describe('CountryDropdown', () => { - it('sets ID attribute', () => { - const wrapper = shallow(); - expect(wrapper.find('#id-attribute').length).toBe(1); - expect(wrapper.find('#fake-id-attribute').length).toBe(0); - }); - - it('classes attribute gets recognized', () => { - const wrapper = shallow(); - expect(wrapper.find('select').hasClass('one two three')).toBe(true); - }); - - it('passes arbitrary properties', () => { - const wrapper = shallow( - - ); - expect(wrapper.find('select').getElement().props.style.color).toBe('red'); - expect(wrapper.find('select').getElement().props['data-whatever']).toBe( - '5' - ); - }); - - describe('name attribute', () => { - it('falls back on default name attribute when not specified', () => { - const wrapper = shallow(); - expect(wrapper.find('select').getElement().props.name).toBe( - 'rcrs-country' - ); - }); - - it('sets explicit name attribute', () => { - const wrapper = shallow(); - expect(wrapper.find('select[name="name-attribute"]').length).toBe(1); - expect(wrapper.find('select[name="fake-name-attribute"]').length).toBe(0); - }); - }); - - describe('disabled attribute', () => { - it('disabled attribute not on by default', () => { - const wrapper = shallow(); - expect(wrapper.find('select').getElement().props.disabled).toBe(false); - }); - it('disabled attribute', () => { - const wrapper = shallow(); - expect(wrapper.find('select').getElement().props.disabled).toBe(true); - }); - }); - - describe('default blank option', () => { - it('showDefaultOption = false removes the default option', () => { - const wrapper = shallow(); - expect(wrapper.find('option').length).toBe(CountryRegionData.length); - }); - - it('confirm default label is "Select Country"', () => { - const wrapper = shallow(); - expect(wrapper.find('select').childAt(0).text()).toBe('Select Country'); - }); - - it('defaultOptionLabel', () => { - const customLabel = 'Holy moly I am a custom label!'; - const wrapper = shallow( - - ); - expect(wrapper.find('select').childAt(0).text()).toBe(customLabel); - }); - }); - - describe('country list', () => { - it('outputs the list of countries', () => { - const wrapper = shallow(); - expect(wrapper.find('option').length).toBe(CountryRegionData.length + 1); // 1 for the "Select Country" default option - }); - - it('respects the blacklist', () => { - const blacklist = ['GB', 'CA', 'US']; - const wrapper = shallow( - - ); - expect(wrapper.find('option').length).toBe( - CountryRegionData.length - blacklist.length - ); - - // confirm a non-blacklist item appears - expect(wrapper.find('option[value="Afghanistan"]').length).toBe(1); - - // confirm none of the blacklist item appears - expect(wrapper.find('option[value="United Kingdom"]').length).toBe(0); - expect(wrapper.find('option[value="Canada"]').length).toBe(0); - expect(wrapper.find('option[value="United States"]').length).toBe(0); - }); - - it('respects the whitelist', () => { - const whitelist = ['GB', 'CA', 'US']; - const wrapper = shallow( - - ); - expect(wrapper.find('option').length).toBe(whitelist.length); - - // confirm the expected items appear - expect(wrapper.find('option[value="United Kingdom"]').length).toBe(1); - expect(wrapper.find('option[value="Canada"]').length).toBe(1); - expect(wrapper.find('option[value="United States"]').length).toBe(1); - }); - }); - - describe('valueType', () => { - it('confirm value is full country name by default', () => { - const wrapper = shallow(); - expect(wrapper.find('select').childAt(0).getElement().props.value).toBe( - CountryRegionData[0][0] - ); - }); - - it('confirm explicit valueType="full" also sets full country name', () => { - const wrapper = shallow( - - ); - expect(wrapper.find('select').childAt(0).getElement().props.value).toBe( - CountryRegionData[0][0] - ); - }); - - it('confirm valueType="short" outputs country short code', () => { - const wrapper = shallow( - - ); - expect(wrapper.find('select').childAt(0).getElement().props.value).toBe( - CountryRegionData[0][1] - ); - }); - }); - - describe('labelType', () => { - it('confirm label type is full country name by default', () => { - const wrapper = shallow(); - expect(wrapper.find('select').childAt(0).text()).toBe( - CountryRegionData[0][0] - ); - }); - - it('confirm label type is full country name when explicitly set', () => { - const wrapper = shallow( - - ); - expect(wrapper.find('select').childAt(0).text()).toBe( - CountryRegionData[0][0] - ); - }); - - it('confirm label type is the country shortcode when set', () => { - const wrapper = shallow( - - ); - expect(wrapper.find('select').childAt(0).text()).toBe( - CountryRegionData[0][1] - ); - }); - }); -}); diff --git a/src/__tests__/RegionDropdown.test.tsx b/src/__tests__/RegionDropdown.test.tsx index 17aaa6f..6c1024d 100644 --- a/src/__tests__/RegionDropdown.test.tsx +++ b/src/__tests__/RegionDropdown.test.tsx @@ -1,13 +1,18 @@ import React from 'react'; -import { RegionDropdown } from '../../dist/rcrs.es'; +import { RegionDropdown } from '../RegionDropdown'; import { render } from '@testing-library/react'; import { screen } from '@testing-library/dom'; +import { RegionDropdownProps } from '../rcrs.types'; describe('RegionDropdown', () => { + const setupTest = (props: Partial) => { + return render( null} value="" {...props} />); + }; + it('sets ID attribute', () => { - render(); + const { container } = setupTest({ id: 'id-attribute' }); - screen.debug(); + expect(container.firstChild).toHaveProperty('id'); // expect(wrapper.find('#id-attribute').length).toBe(1); // expect(wrapper.find('#fake-id-attribute').length).toBe(0); @@ -17,6 +22,7 @@ describe('RegionDropdown', () => { // const wrapper = shallow(); // expect(wrapper.find('select').hasClass('one two three')).toBe(true); // }); + // describe('name attribute', () => { // it('falls back on default name attribute when not specified', () => { // const wrapper = shallow(); diff --git a/src/rcrs.types.ts b/src/rcrs.types.ts index a5e4650..ae87837 100644 --- a/src/rcrs.types.ts +++ b/src/rcrs.types.ts @@ -21,21 +21,21 @@ export interface CountryDropdownProps { } export type RegionDropdownProps = { - readonly country: string; - readonly value?: string | number; + readonly value: string | number; + readonly onChange: (value: string, event: any) => null; + readonly country?: string; readonly id?: string; readonly name?: string; readonly blankOptionLabel?: string; readonly classes?: string; readonly showDefaultOption?: boolean; - readonly defaultOptionLabel: string; + readonly defaultOptionLabel?: string; readonly disabled?: boolean; readonly disableWhenEmpty?: boolean; readonly labelType?: ValueType; readonly countryValueType?: ValueType; readonly valueType?: ValueType; - readonly customOptions: ValueType[]; - readonly onChange?: (value: string, event: any) => null; + readonly customOptions?: ValueType[]; readonly onBlur?: (value: string, event: any) => null; readonly whitelist?: object; readonly blacklist?: object; diff --git a/yarn.lock b/yarn.lock index 8d6a905..80f162b 100644 --- a/yarn.lock +++ b/yarn.lock @@ -397,7 +397,7 @@ dependencies: "@babel/helper-plugin-utils" "^7.14.5" -"@babel/plugin-syntax-typescript@^7.7.2": +"@babel/plugin-syntax-typescript@^7.25.9", "@babel/plugin-syntax-typescript@^7.7.2": version "7.25.9" resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.25.9.tgz#67dda2b74da43727cf21d46cf9afef23f4365399" integrity sha512-hjMgRy5hb8uJJjUcdWunWVcoi9bGpJp8p5Ol1229PoN6aytsLwNMgmdftO23wnCLMfVmTwZDWMPNq/D1SY60JQ== @@ -803,6 +803,17 @@ dependencies: "@babel/helper-plugin-utils" "^7.25.9" +"@babel/plugin-transform-typescript@^7.25.9": + version "7.25.9" + resolved "https://registry.yarnpkg.com/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.25.9.tgz#69267905c2b33c2ac6d8fe765e9dc2ddc9df3849" + integrity sha512-7PbZQZP50tzv2KGGnhh82GSyMB01yKY9scIjf1a+GfZCtInOWqUH5+1EBU4t9fyR5Oykkkc9vFTs4OHrhHXljQ== + dependencies: + "@babel/helper-annotate-as-pure" "^7.25.9" + "@babel/helper-create-class-features-plugin" "^7.25.9" + "@babel/helper-plugin-utils" "^7.25.9" + "@babel/helper-skip-transparent-expression-wrappers" "^7.25.9" + "@babel/plugin-syntax-typescript" "^7.25.9" + "@babel/plugin-transform-unicode-escapes@^7.25.9": version "7.25.9" resolved "https://registry.yarnpkg.com/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.25.9.tgz#a75ef3947ce15363fccaa38e2dd9bc70b2788b82" @@ -935,6 +946,17 @@ resolved "https://registry.yarnpkg.com/@babel/preset-stage-0/-/preset-stage-0-7.8.3.tgz#b6a0eca1a3b72e07f9caf58f998e97568028f6f5" integrity sha512-+l6FlG1j73t4wh78W41StbcCz0/9a1/y+vxfnjtHl060kSmcgMfGzK9MEkLvrCOXfhp9RCX+d88sm6rOqxEIEQ== +"@babel/preset-typescript@^7.26.0": + version "7.26.0" + resolved "https://registry.yarnpkg.com/@babel/preset-typescript/-/preset-typescript-7.26.0.tgz#4a570f1b8d104a242d923957ffa1eaff142a106d" + integrity sha512-NMk1IGZ5I/oHhoXEElcm+xUnL/szL6xflkFZmoEU9xj1qSJXpiS7rsspYo92B4DRCDvZn2erT5LdsCeXAKNCkg== + dependencies: + "@babel/helper-plugin-utils" "^7.25.9" + "@babel/helper-validator-option" "^7.25.9" + "@babel/plugin-syntax-jsx" "^7.25.9" + "@babel/plugin-transform-modules-commonjs" "^7.25.9" + "@babel/plugin-transform-typescript" "^7.25.9" + "@babel/runtime@^7.12.5", "@babel/runtime@^7.8.4": version "7.26.0" resolved "https://registry.yarnpkg.com/@babel/runtime/-/runtime-7.26.0.tgz#8600c2f595f277c60815256418b85356a65173c1" @@ -3318,7 +3340,7 @@ lodash@^4.17.10: resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== -loose-envify@^1.1.0, loose-envify@^1.4.0: +loose-envify@^1.1.0: version "1.4.0" resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.4.0.tgz#71ee51fa7be4caec1a63839f7e682d8132d30caf" integrity sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q== @@ -3464,7 +3486,7 @@ nwsapi@^2.2.2: resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.13.tgz#e56b4e98960e7a040e5474536587e599c4ff4655" integrity sha512-cTGB9ptp9dY9A5VbMSe7fQBcl/tt22Vcqdq8+eN93rblOuE0aCFu4aZ2vMwct/2t+lFnosm8RkQW1I0Omb1UtQ== -object-assign@^4.0.1, object-assign@^4.1.0, object-assign@^4.1.1: +object-assign@^4.0.1, object-assign@^4.1.0: version "4.1.1" resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" integrity sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg== @@ -3657,15 +3679,6 @@ prompts@^2.0.1: kleur "^3.0.3" sisteransi "^1.0.5" -prop-types@^15.6.2: - version "15.8.1" - resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.8.1.tgz#67d87bf1a694f48435cf332c24af10214a3140b5" - integrity sha512-oj87CgZICdulUohogVAR7AjlC0327U4el4L6eAvOqCeudMDVU0NThNaV+b9Df4dXgSP1gXMTnPdhfe/2qDH5cg== - dependencies: - loose-envify "^1.4.0" - object-assign "^4.1.1" - react-is "^16.13.1" - psl@^1.1.33: version "1.13.0" resolved "https://registry.yarnpkg.com/psl/-/psl-1.13.0.tgz#8b2357f13ef3cf546af3f52de00543a94da86cfa" @@ -3708,20 +3721,13 @@ randombytes@^2.1.0: dependencies: safe-buffer "^5.1.0" -react-dom@^16.4.1: - version "16.14.0" - resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-16.14.0.tgz#7ad838ec29a777fb3c75c3a190f661cf92ab8b89" - integrity sha512-1gCeQXDLoIqMgqD3IO2Ah9bnf0w9kzhwN5q4FGnHZ67hBm9yePzB5JJAIQCc8x3pFnNlwFq4RidZggNAAkzWWw== +react-dom@^18.3.1: + version "18.3.1" + resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-18.3.1.tgz#c2265d79511b57d479b3dd3fdfa51536494c5cb4" + integrity sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw== dependencies: loose-envify "^1.1.0" - object-assign "^4.1.1" - prop-types "^15.6.2" - scheduler "^0.19.1" - -react-is@^16.13.1: - version "16.13.1" - resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4" - integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ== + scheduler "^0.23.2" react-is@^17.0.1: version "17.0.2" @@ -3733,14 +3739,12 @@ react-is@^18.0.0: resolved "https://registry.yarnpkg.com/react-is/-/react-is-18.3.1.tgz#e83557dc12eae63a99e003a46388b1dcbb44db7e" integrity sha512-/LLMVyas0ljjAtoYiPqYiL8VWXzUUdThrmU5+n20DZv+a+ClRoevUzw5JxU+Ieh5/c87ytoTBV9G1FiKfNJdmg== -react@^16.4.1: - version "16.14.0" - resolved "https://registry.yarnpkg.com/react/-/react-16.14.0.tgz#94d776ddd0aaa37da3eda8fc5b6b18a4c9a3114d" - integrity sha512-0X2CImDkJGApiAlcf0ODKIneSwBPhqJawOa5wCtKbu7ZECrmS26NvtSILynQ66cgkT/RJ4LidJOc3bUESwmU8g== +react@^18.3.1: + version "18.3.1" + resolved "https://registry.yarnpkg.com/react/-/react-18.3.1.tgz#49ab892009c53933625bd16b2533fc754cab2891" + integrity sha512-wS+hAgJShR0KhEvPJArfuPVN1+Hz1t0Y6n5jLrGQbkb4urgPE/0Rve+1kMB1v/oWgHgm4WIcV+i7F2pTVj+2iQ== dependencies: loose-envify "^1.1.0" - object-assign "^4.1.1" - prop-types "^15.6.2" regenerate-unicode-properties@^10.2.0: version "10.2.0" @@ -3901,13 +3905,12 @@ saxes@^6.0.0: dependencies: xmlchars "^2.2.0" -scheduler@^0.19.1: - version "0.19.1" - resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.19.1.tgz#4f3e2ed2c1a7d65681f4c854fa8c5a1ccb40f196" - integrity sha512-n/zwRWRYSUj0/3g/otKDRPMh6qv2SYMWNq85IEa8iZyAv8od9zDYpGSnpBEjNgcMNq6Scbu5KfIPxNF72R/2EA== +scheduler@^0.23.2: + version "0.23.2" + resolved "https://registry.yarnpkg.com/scheduler/-/scheduler-0.23.2.tgz#414ba64a3b282892e944cf2108ecc078d115cdc3" + integrity sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ== dependencies: loose-envify "^1.1.0" - object-assign "^4.1.1" semver@^5.5.0: version "5.7.2"