From 949b132147be8bec94d4cea91f793ad6bf7f1401 Mon Sep 17 00:00:00 2001 From: atanasster Date: Wed, 21 Oct 2020 01:35:29 -0400 Subject: [PATCH] feat: initial isomorphic css loader --- core/render/package.json | 2 ++ core/render/rollup.config.js | 2 +- core/render/src/{react.ts => react.tsx} | 15 +++++++++++++-- core/render/src/typings.d.ts | 1 + core/webpack-configs/package.json | 2 +- core/webpack-configs/src/react/index.ts | 13 +++++++++++-- yarn.lock | 13 +++++++++++-- 7 files changed, 40 insertions(+), 8 deletions(-) rename core/render/src/{react.ts => react.tsx} (72%) create mode 100644 core/render/src/typings.d.ts diff --git a/core/render/package.json b/core/render/package.json index bd1d95439..532269a5e 100644 --- a/core/render/package.json +++ b/core/render/package.json @@ -33,6 +33,7 @@ "license": "MIT", "dependencies": { "@component-controls/core": "^1.34.0", + "isomorphic-style-loader": "^5.1.0", "react": "^16.13.1", "react-dom": "^16.13.1" }, @@ -40,6 +41,7 @@ "@component-controls/ts-markdown-docs": "^1.21.0", "@types/jest": "^26.0.10", "@types/react": "^16.9.34", + "cross-env": "^5.2.1", "eslint": "^6.5.1", "jest": "^26.4.2", diff --git a/core/render/rollup.config.js b/core/render/rollup.config.js index 580ef7397..0e0e9c5f0 100644 --- a/core/render/rollup.config.js +++ b/core/render/rollup.config.js @@ -1,5 +1,5 @@ import { config } from '../../rollup-config'; export default config({ - input: ['./src/index.ts', './src/react.ts'], + input: ['./src/index.ts', './src/react.tsx'], }); diff --git a/core/render/src/react.ts b/core/render/src/react.tsx similarity index 72% rename from core/render/src/react.ts rename to core/render/src/react.tsx index 8dc609e80..71724c984 100644 --- a/core/render/src/react.ts +++ b/core/render/src/react.tsx @@ -1,10 +1,12 @@ -import { createElement } from 'react'; +/* eslint-disable react/display-name */ +import React, { createElement } from 'react'; import { StoryRenderFn, getControlValues, deepMerge, FrameworkRenderFn, } from '@component-controls/core'; +import StyleContext from 'isomorphic-style-loader/StyleContext'; export const render: FrameworkRenderFn = (story, doc, options: any = {}) => { if (!story) { @@ -41,6 +43,15 @@ export const render: FrameworkRenderFn = (story, doc, options: any = {}) => { ); } let node: any = null; - node = () => (renderFn as StoryRenderFn)(values, context); + const css = new Set(); + const insertCss = (...styles: any[]) => { + console.log(styles); + styles.forEach(style => css.add(style._getCss())); + }; + node = () => ( + + {(renderFn as StoryRenderFn)(values, context)} + + ); return createElement(node); }; diff --git a/core/render/src/typings.d.ts b/core/render/src/typings.d.ts new file mode 100644 index 000000000..5d0bb0d7c --- /dev/null +++ b/core/render/src/typings.d.ts @@ -0,0 +1 @@ +declare module 'isomorphic-style-loader/StyleContext'; diff --git a/core/webpack-configs/package.json b/core/webpack-configs/package.json index e3a30c646..1fcafa7c4 100644 --- a/core/webpack-configs/package.json +++ b/core/webpack-configs/package.json @@ -50,8 +50,8 @@ "cross-env": "^5.2.1", "eslint": "^6.5.1", "file-loader": "^6.0.0", + "isomorphic-style-loader": "^5.1.0", "jest": "^26.4.2", - "style-loader": "^2.0.0", "url-loader": "^4.1.0" }, "jest": { diff --git a/core/webpack-configs/src/react/index.ts b/core/webpack-configs/src/react/index.ts index 8cde321f0..b41e64f9b 100644 --- a/core/webpack-configs/src/react/index.ts +++ b/core/webpack-configs/src/react/index.ts @@ -62,8 +62,17 @@ export const react: PresetType = (options?: PresetOptions) => { }, }, { - test: /\.css$/i, - use: [require.resolve('style-loader'), require.resolve('css-loader')], + test: /\.css$/, + use: [ + 'isomorphic-style-loader', + { + loader: 'css-loader', + options: { + importLoaders: 1, + esModule: false, + }, + }, + ], }, { test: /\.txt$/i, diff --git a/yarn.lock b/yarn.lock index 5789eb1f9..63fa67c0a 100644 --- a/yarn.lock +++ b/yarn.lock @@ -13821,7 +13821,7 @@ hmac-drbg@^1.0.0: minimalistic-assert "^1.0.0" minimalistic-crypto-utils "^1.0.1" -hoist-non-react-statics@^3.3.0, hoist-non-react-statics@^3.3.1: +hoist-non-react-statics@^3.0.0, hoist-non-react-statics@^3.3.0, hoist-non-react-statics@^3.3.1: version "3.3.2" resolved "https://registry.yarnpkg.com/hoist-non-react-statics/-/hoist-non-react-statics-3.3.2.tgz#ece0acaf71d62c2969c2ec59feff42a4b1a85b45" integrity sha512-/gGivxi8JPKWNm/W0jSmzcMPpfpPLc3dY/6GxhX2hQ9iGj3aDfklV4ET7NjKpSinLpJ5vafa9iiGIEZg10SfBw== @@ -15215,6 +15215,15 @@ isomorphic-fetch@^2.1.1: node-fetch "^1.0.1" whatwg-fetch ">=0.10.0" +isomorphic-style-loader@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/isomorphic-style-loader/-/isomorphic-style-loader-5.1.0.tgz#4845f90bb9828f3dfecc82d0574c9ed01bbaba2d" + integrity sha512-6KBucdRvmz5U5SMrdDUhDyTQ6nRmCjzjopJBDVkfx1+xsoiyNYVlcY1OqSH1SHKYRzVWhqWXIBGgeTl5L7gViw== + dependencies: + hoist-non-react-statics "^3.0.0" + loader-utils "^1.2.3" + react "^16.3.0" + isstream@~0.1.2: version "0.1.2" resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a" @@ -20763,7 +20772,7 @@ react-textarea-autosize@^8.1.1: use-composed-ref "^1.0.0" use-latest "^1.0.0" -react@^16.12.0, react@^16.13.1, react@^16.8.0, react@^16.8.3: +react@^16.12.0, react@^16.13.1, react@^16.3.0, react@^16.8.0, react@^16.8.3: version "16.14.0" resolved "https://registry.yarnpkg.com/react/-/react-16.14.0.tgz#94d776ddd0aaa37da3eda8fc5b6b18a4c9a3114d" integrity sha512-0X2CImDkJGApiAlcf0ODKIneSwBPhqJawOa5wCtKbu7ZECrmS26NvtSILynQ66cgkT/RJ4LidJOc3bUESwmU8g==