From f0cd5c8d935f68afbe4cb794a9d0e4c5e18f5c13 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Petter=20Walb=C3=B8=20Johnsg=C3=A5rd?= Date: Tue, 19 Jul 2022 23:05:41 +0200 Subject: [PATCH 1/2] StyleProvider: Convert component to TypeScript --- .../components/src/style-provider/index.js | 31 -------------- .../components/src/style-provider/index.tsx | 41 +++++++++++++++++++ .../components/src/style-provider/types.ts | 15 +++++++ 3 files changed, 56 insertions(+), 31 deletions(-) delete mode 100644 packages/components/src/style-provider/index.js create mode 100644 packages/components/src/style-provider/index.tsx create mode 100644 packages/components/src/style-provider/types.ts diff --git a/packages/components/src/style-provider/index.js b/packages/components/src/style-provider/index.js deleted file mode 100644 index 66849ffaef6289..00000000000000 --- a/packages/components/src/style-provider/index.js +++ /dev/null @@ -1,31 +0,0 @@ -// @ts-nocheck - -/** - * External dependencies - */ -import { CacheProvider } from '@emotion/react'; -import createCache from '@emotion/cache'; -import memoize from 'memize'; -import * as uuid from 'uuid'; - -const uuidCache = new Set(); - -const memoizedCreateCacheWithContainer = memoize( ( container ) => { - // Emotion only accepts alphabetical and hyphenated keys so we just strip the numbers from the UUID. It _should_ be fine. - let key = uuid.v4().replace( /[0-9]/g, '' ); - while ( uuidCache.has( key ) ) { - key = uuid.v4().replace( /[0-9]/g, '' ); - } - uuidCache.add( key ); - return createCache( { container, key } ); -} ); - -export default function StyleProvider( { children, document } ) { - if ( ! document ) { - return null; - } - - const cache = memoizedCreateCacheWithContainer( document.head ); - - return { children }; -} diff --git a/packages/components/src/style-provider/index.tsx b/packages/components/src/style-provider/index.tsx new file mode 100644 index 00000000000000..0fa2c5b6ca008a --- /dev/null +++ b/packages/components/src/style-provider/index.tsx @@ -0,0 +1,41 @@ +/** + * External dependencies + */ +import { CacheProvider } from '@emotion/react'; +import createCache from '@emotion/cache'; +import memoize from 'memize'; +import * as uuid from 'uuid'; + +/** + * Internal dependencies + */ +import type { StyleProviderProps } from './types'; + +const uuidCache = new Set(); + +const memoizedCreateCacheWithContainer = memoize( + ( container: HTMLElement ) => { + // Emotion only accepts alphabetical and hyphenated keys so we just + // strip the numbers from the UUID. It _should_ be fine. + let key = uuid.v4().replace( /[0-9]/g, '' ); + while ( uuidCache.has( key ) ) { + key = uuid.v4().replace( /[0-9]/g, '' ); + } + uuidCache.add( key ); + return createCache( { container, key } ); + } +); + +export function StyleProvider( props: StyleProviderProps ) { + const { children, document } = props; + + if ( ! document ) { + return null; + } + + const cache = memoizedCreateCacheWithContainer( document.head ); + + return { children }; +} + +export default StyleProvider; diff --git a/packages/components/src/style-provider/types.ts b/packages/components/src/style-provider/types.ts new file mode 100644 index 00000000000000..f06899d6c3e16d --- /dev/null +++ b/packages/components/src/style-provider/types.ts @@ -0,0 +1,15 @@ +/** + * External dependencies + */ +import type { ReactNode } from 'react'; + +export type StyleProviderProps = { + /** + * The children elements. + */ + children: ReactNode; + /** + * Current document. + */ + document: Document; +}; From 605e33b96aa199476cc0cbc5f15e337d0d28af90 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Petter=20Walb=C3=B8=20Johnsg=C3=A5rd?= Date: Tue, 19 Jul 2022 23:09:34 +0200 Subject: [PATCH 2/2] Update CHANGELOG.md --- packages/components/CHANGELOG.md | 1 + 1 file changed, 1 insertion(+) diff --git a/packages/components/CHANGELOG.md b/packages/components/CHANGELOG.md index 9a37d3f95fd0da..d03bf3a9709a29 100644 --- a/packages/components/CHANGELOG.md +++ b/packages/components/CHANGELOG.md @@ -28,6 +28,7 @@ - `BoxControl`: Refactor away from `_.isEmpty()` ([#42468](https://github.com/WordPress/gutenberg/pull/42468)). - `RadioControl`: Refactor away from `_.isEmpty()` ([#42468](https://github.com/WordPress/gutenberg/pull/42468)). - `SelectControl`: Refactor away from `_.isEmpty()` ([#42468](https://github.com/WordPress/gutenberg/pull/42468)). +- `StyleProvider`: Convert to TypeScript ([#42541](https://github.com/WordPress/gutenberg/pull/42541)). ## 19.15.0 (2022-07-13)