diff --git a/.changeset/amaranth-owls-dream.md b/.changeset/amaranth-owls-dream.md new file mode 100644 index 0000000000..38b5f13f77 --- /dev/null +++ b/.changeset/amaranth-owls-dream.md @@ -0,0 +1,6 @@ +--- +'@emotion/styled': major +'@emotion/react': major +--- + +Dropped support for older React versions. React 19 becomes the only compatible version with this package. diff --git a/.github/workflows/main.yml b/.github/workflows/main.yml index f6933c340e..71d76eb687 100644 --- a/.github/workflows/main.yml +++ b/.github/workflows/main.yml @@ -41,16 +41,6 @@ jobs: - name: Check Types run: yarn tsc:all - test_react18: - name: Test React 18 - runs-on: ubuntu-latest - steps: - - uses: actions/checkout@v3 - - uses: ./.github/actions/ci-setup - - - name: Run Tests with React 18 - run: yarn test:react18:ci - test_prod: name: Test Prod runs-on: ubuntu-latest diff --git a/.yarn/patches/@definitelytyped-typescript-versions-npm-0.0.112-f668f50e03.patch b/.yarn/patches/@definitelytyped-typescript-versions-npm-0.0.112-f668f50e03.patch new file mode 100644 index 0000000000..4e828d0aa5 --- /dev/null +++ b/.yarn/patches/@definitelytyped-typescript-versions-npm-0.0.112-f668f50e03.patch @@ -0,0 +1,16 @@ +diff --git a/dist/index.js b/dist/index.js +index 0a9abde5fbe918397794db0c0962129cf6bec3fa..26fe2b048b7fa898282d2d9d0dbd1719384b1f60 100644 +--- a/dist/index.js ++++ b/dist/index.js +@@ -8,9 +8,9 @@ const assert_1 = __importDefault(require("assert")); + var TypeScriptVersion; + (function (TypeScriptVersion) { + /** Add to this list when a version actually ships. */ +- TypeScriptVersion.shipped = ["3.9", "4.0", "4.1", "4.2", "4.3", "4.4", "4.5", "4.6"]; ++ TypeScriptVersion.shipped = ["3.9", "4.0", "4.1", "4.2", "4.3", "4.4", "4.5", "4.6", "4.7", "4.8", "4.9", "5.0", "5.1", "5.2", "5.3", "5.4", "5.5", "5.6", "5.7"]; + /** Add to this list when a version is available as typescript@next */ +- TypeScriptVersion.supported = [...TypeScriptVersion.shipped, "4.7"]; ++ TypeScriptVersion.supported = [...TypeScriptVersion.shipped, "5.8"]; + /** Add to this list when it will no longer be supported on Definitely Typed */ + TypeScriptVersion.unsupported = [ + "2.0", diff --git a/docs/testing.mdx b/docs/testing.mdx index cd4b92ad1a..447265df72 100644 --- a/docs/testing.mdx +++ b/docs/testing.mdx @@ -34,11 +34,11 @@ expect.addSnapshotSerializer(createSerializer()) ### Writing a test -Writing a test with `@emotion/jest` involves creating a snapshot from the `react-test-renderer`'s resulting JSON. +Writing a test with `@emotion/jest` involves creating a snapshot from the `@testing-library/react`'s result. ```jsx import React from 'react' -import renderer from 'react-test-renderer' +import { render } from '@testing-library/react' const Button = props => ( ).toJSON() + render().container ).toMatchSnapshot() }) ``` @@ -67,7 +67,7 @@ exports[`Button renders correctly 1`] = ` }
This is hotpink.
diff --git a/jest-react18.config.js b/jest-react18.config.js deleted file mode 100644 index 119490a9b6..0000000000 --- a/jest-react18.config.js +++ /dev/null @@ -1,9 +0,0 @@ -const baseConfig = require('./jest.config.js') - -module.exports = Object.assign({}, baseConfig, { - moduleNameMapper: { - '^react($|\\/.+)': 'react18$1', - '^react-dom($|\\/.+)': 'react18-dom$1', - '^react-test-renderer($|\\/.+)': 'react18-test-renderer$1' - } -}) diff --git a/package.json b/package.json index fba49a4d31..0dc1dae885 100644 --- a/package.json +++ b/package.json @@ -9,10 +9,8 @@ "test:size": "npm-run-all build size", "test:debug": "node --inspect-brk ./node_modules/jest/bin/jest.js --runInBand --watch", "test": "jest", - "test:react18": "jest -c jest-react18.config.js", "test:typescript": "yarn workspaces foreach --verbose --exclude emotion-monorepo run test:typescript", "test:ci": "jest --coverage --no-cache --ci --runInBand", - "test:react18:ci": "yarn test:react18 --coverage --no-cache --ci --runInBand", "test:dist": "yarn build && jest -c jest.dist.js --no-cache --ci --runInBand", "test:prod": "jest -c jest.prod.js --no-cache --ci --runInBand", "lint:check": "eslint .", @@ -185,10 +183,11 @@ "@changesets/cli": "^2.27.7", "@manypkg/cli": "^0.19.1", "@preconstruct/cli": "^2.8.8", - "@testing-library/react": "13.0.0-alpha.5", + "@testing-library/dom": "^10.4.0", + "@testing-library/react": "^16.1.0", "@types/jest": "^29.5.12", "@types/node": "^12.20.37", - "@types/react": "18.3.12", + "@types/react": "19.0.1", "@typescript-eslint/eslint-plugin": "^7.13.0", "@typescript-eslint/parser": "^7.13.0", "babel-check-duplicated-nodes": "^1.0.0", @@ -226,14 +225,11 @@ "polished": "^1.2.1", "prettier": "^3.3.2", "raf": "^3.4.0", - "react": "16.14.0", - "react-dom": "16.14.0", + "react": "19.0.0", + "react-dom": "19.0.0", "react-native": "^0.63.2", "react-primitives": "^0.8.1", - "react-test-renderer": "16.8.6", - "react18": "npm:react@18.0.0-rc.0-next-aa8f2bdbc-20211215", - "react18-dom": "npm:react-dom@18.0.0-rc.0-next-aa8f2bdbc-20211215", - "react18-test-renderer": "npm:react-test-renderer@18.0.0-rc.0-next-aa8f2bdbc-20211215", + "react-test-renderer": "19.0.0", "svg-tag-names": "^1.1.1", "through": "^2.3.8", "typescript": "^5.4.5", @@ -242,6 +238,7 @@ }, "packageManager": "yarn@3.2.3", "resolutions": { - "@definitelytyped/dtslint@0.0.112": "patch:@definitelytyped/dtslint@npm%3A0.0.112#./.yarn/patches/@definitelytyped-dtslint-npm-0.0.112-1e6b842976.patch" + "@definitelytyped/dtslint@0.0.112": "patch:@definitelytyped/dtslint@npm%3A0.0.112#./.yarn/patches/@definitelytyped-dtslint-npm-0.0.112-1e6b842976.patch", + "@definitelytyped/typescript-versions@^0.0.112": "patch:@definitelytyped/typescript-versions@npm%3A0.0.112#./.yarn/patches/@definitelytyped-typescript-versions-npm-0.0.112-f668f50e03.patch" } } diff --git a/packages/css/test/__snapshots__/component-selector.test.js.snap b/packages/css/test/__snapshots__/component-selector.test.js.snap index 0831e50cb4..f5816e1d25 100644 --- a/packages/css/test/__snapshots__/component-selector.test.js.snap +++ b/packages/css/test/__snapshots__/component-selector.test.js.snap @@ -10,10 +10,10 @@ exports[`component selector should be converted to use the emotion target classN }
`; diff --git a/packages/css/test/__snapshots__/css.test.js.snap b/packages/css/test/__snapshots__/css.test.js.snap index fcf9de1124..c4b2a1a926 100644 --- a/packages/css/test/__snapshots__/css.test.js.snap +++ b/packages/css/test/__snapshots__/css.test.js.snap @@ -8,7 +8,7 @@ exports[`css @supports 1`] = ` }
`; @@ -19,7 +19,7 @@ exports[`css array fallback 1`] = ` }
`; @@ -32,7 +32,7 @@ exports[`css array with explicit false 1`] = ` }
`; @@ -45,7 +45,7 @@ exports[`css array with explicit true 1`] = ` }
`; @@ -63,7 +63,7 @@ exports[`css auto px 1`] = ` }
`; @@ -76,7 +76,7 @@ exports[`css boolean as value 1`] = ` }
`; @@ -89,7 +89,7 @@ exports[`css composition stuff 1`] = ` }
`; @@ -102,7 +102,7 @@ exports[`css composition stuff 2`] = ` }
`; @@ -136,7 +136,7 @@ exports[`css composition with objects 1`] = ` }
`; @@ -147,7 +147,7 @@ exports[`css computed key is only dynamic 1`] = ` }
`; @@ -158,7 +158,7 @@ exports[`css css variables 1`] = ` }
`; @@ -171,7 +171,7 @@ exports[`css explicit & 1`] = ` }
`; @@ -186,7 +186,7 @@ exports[`css explicit & 2`] = ` exports[`css explicit false 1`] = `
`; @@ -199,7 +199,7 @@ exports[`css falsy property value in object 1`] = ` }
`; @@ -209,7 +209,7 @@ exports[`css falsy value in nested selector on object 1`] = ` }
`; @@ -219,7 +219,7 @@ exports[`css float property 1`] = ` }
`; @@ -232,13 +232,13 @@ exports[`css flushes correctly 1`] = ` }
`; exports[`css flushes correctly 2`] = `
`; @@ -249,7 +249,7 @@ exports[`css handles array of objects 1`] = ` }
`; @@ -270,7 +270,7 @@ exports[`css handles more than 10 dynamic properties 1`] = ` }
`; @@ -288,7 +288,7 @@ exports[`css handles objects 1`] = ` }
`; @@ -298,7 +298,7 @@ exports[`css manually use label property 1`] = ` }
`; @@ -338,7 +338,7 @@ exports[`css media query specificity 2`] = ` }
`; @@ -349,7 +349,7 @@ exports[`css multiline declaration 1`] = ` }
`; @@ -359,7 +359,7 @@ exports[`css multiline selector 1`] = ` }
`; @@ -386,13 +386,13 @@ exports[`css nested 1`] = ` }
@@ -417,7 +417,7 @@ exports[`css nested array 1`] = ` }
`; @@ -435,19 +435,52 @@ exports[`css nested at rule 1`] = ` }
+`; + +exports[`css nested at rules 1`] = ` +@supports (display: grid) { + .emotion-0 { + display: grid; + } + + @supports (display: flex) { + .emotion-0 { + display: -webkit-box; + display: -webkit-flex; + display: -ms-flexbox; + display: flex; + } + } +} + +@media (min-width: 420px) { + .emotion-0 { + color: pink; + } + + @media (max-width: 500px) { + .emotion-0 { + color: hotpink; + } + } +} + +
`; exports[`css null rule 1`] = `
`; exports[`css null value 1`] = `
`; @@ -467,7 +500,7 @@ exports[`css random expression 1`] = ` }
`; @@ -480,7 +513,7 @@ exports[`css random interpolation with undefined values 1`] = ` }
`; @@ -494,7 +527,7 @@ exports[`css registered styles as nested selector value in object 1`] = ` }
`; @@ -510,7 +543,7 @@ exports[`css rule after media query 1`] = ` }
`; @@ -531,7 +564,7 @@ exports[`css simple composition 1`] = ` }
`; @@ -544,7 +577,7 @@ exports[`css weakmap 1`] = ` }
`; @@ -557,6 +590,6 @@ exports[`css weakmap 2`] = ` }
`; diff --git a/packages/css/test/__snapshots__/cx.test.js.snap b/packages/css/test/__snapshots__/cx.test.js.snap index 4c80ffe3ed..5fae78ea10 100644 --- a/packages/css/test/__snapshots__/cx.test.js.snap +++ b/packages/css/test/__snapshots__/cx.test.js.snap @@ -11,7 +11,7 @@ exports[`cx all types 1`] = ` }