@bleedingdev/modern-js-plugin-styled-components 3.2.0-ultramodern.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2021-present Modern.js
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
@@ -0,0 +1,57 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ StreamStyledExtender: ()=>StreamStyledExtender
28
+ });
29
+ const external_styled_components_namespaceObject = require("styled-components");
30
+ class StreamStyledExtender {
31
+ init(params) {
32
+ this.sheet = new external_styled_components_namespaceObject.ServerStyleSheet();
33
+ this.rootElement = this.sheet.collectStyles(params.rootElement);
34
+ this.forceStream2String = params.forceStream2String;
35
+ }
36
+ modifyRootElement(rootElement) {
37
+ return this.rootElement || rootElement;
38
+ }
39
+ getStyleTags() {
40
+ return this.forceStream2String && this.sheet ? this.sheet.getStyleTags() : '';
41
+ }
42
+ processStream(stream) {
43
+ return this.sheet ? this.sheet.interleaveWithNodeStream(stream) : stream;
44
+ }
45
+ constructor(){
46
+ this.sheet = null;
47
+ this.rootElement = null;
48
+ this.forceStream2String = false;
49
+ }
50
+ }
51
+ exports.StreamStyledExtender = __webpack_exports__.StreamStyledExtender;
52
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
53
+ "StreamStyledExtender"
54
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
55
+ Object.defineProperty(exports, '__esModule', {
56
+ value: true
57
+ });
@@ -0,0 +1,98 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ RenderLevel: ()=>string_RenderLevel,
28
+ StyledCollector: ()=>StyledCollector
29
+ });
30
+ const external_styled_components_namespaceObject = require("styled-components");
31
+ function _check_private_redeclaration(obj, privateCollection) {
32
+ if (privateCollection.has(obj)) throw new TypeError("Cannot initialize the same private elements twice on an object");
33
+ }
34
+ function _class_apply_descriptor_get(receiver, descriptor) {
35
+ if (descriptor.get) return descriptor.get.call(receiver);
36
+ return descriptor.value;
37
+ }
38
+ function _class_apply_descriptor_set(receiver, descriptor, value) {
39
+ if (descriptor.set) descriptor.set.call(receiver, value);
40
+ else {
41
+ if (!descriptor.writable) throw new TypeError("attempted to set read only private field");
42
+ descriptor.value = value;
43
+ }
44
+ }
45
+ function _class_extract_field_descriptor(receiver, privateMap, action) {
46
+ if (!privateMap.has(receiver)) throw new TypeError("attempted to " + action + " private field on non-instance");
47
+ return privateMap.get(receiver);
48
+ }
49
+ function _class_private_field_get(receiver, privateMap) {
50
+ var descriptor = _class_extract_field_descriptor(receiver, privateMap, "get");
51
+ return _class_apply_descriptor_get(receiver, descriptor);
52
+ }
53
+ function _class_private_field_init(obj, privateMap, value) {
54
+ _check_private_redeclaration(obj, privateMap);
55
+ privateMap.set(obj, value);
56
+ }
57
+ function _class_private_field_set(receiver, privateMap, value) {
58
+ var descriptor = _class_extract_field_descriptor(receiver, privateMap, "set");
59
+ _class_apply_descriptor_set(receiver, descriptor, value);
60
+ return value;
61
+ }
62
+ var string_RenderLevel = /*#__PURE__*/ function(RenderLevel) {
63
+ RenderLevel[RenderLevel["CLIENT_RENDER"] = 0] = "CLIENT_RENDER";
64
+ RenderLevel[RenderLevel["SERVER_PREFETCH"] = 1] = "SERVER_PREFETCH";
65
+ RenderLevel[RenderLevel["SERVER_RENDER"] = 2] = "SERVER_RENDER";
66
+ return RenderLevel;
67
+ }({});
68
+ var _sheet = /*#__PURE__*/ new WeakMap(), _chunkSet = /*#__PURE__*/ new WeakMap();
69
+ class StyledCollector {
70
+ collect(comopnent) {
71
+ return _class_private_field_get(this, _sheet).collectStyles(comopnent);
72
+ }
73
+ effect() {
74
+ const css = _class_private_field_get(this, _sheet).getStyleTags();
75
+ _class_private_field_get(this, _chunkSet).cssChunk += css;
76
+ }
77
+ constructor(chunkSet){
78
+ _class_private_field_init(this, _sheet, {
79
+ writable: true,
80
+ value: void 0
81
+ });
82
+ _class_private_field_init(this, _chunkSet, {
83
+ writable: true,
84
+ value: void 0
85
+ });
86
+ _class_private_field_set(this, _sheet, new external_styled_components_namespaceObject.ServerStyleSheet());
87
+ _class_private_field_set(this, _chunkSet, chunkSet);
88
+ }
89
+ }
90
+ exports.RenderLevel = __webpack_exports__.RenderLevel;
91
+ exports.StyledCollector = __webpack_exports__.StyledCollector;
92
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
93
+ "RenderLevel",
94
+ "StyledCollector"
95
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
96
+ Object.defineProperty(exports, '__esModule', {
97
+ value: true
98
+ });
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ default: ()=>src,
28
+ styledComponentsPlugin: ()=>styledComponentsPlugin
29
+ });
30
+ const plugin_styled_components_namespaceObject = require("@rsbuild/plugin-styled-components");
31
+ const styledComponentsPlugin = (options)=>({
32
+ name: '@modern-js/plugin-styled-components',
33
+ setup (api) {
34
+ api.config(()=>{
35
+ const { metaName } = api.getAppContext();
36
+ return {
37
+ builderPlugins: [
38
+ (0, plugin_styled_components_namespaceObject.pluginStyledComponents)({
39
+ ...options,
40
+ topLevelImportPaths: [
41
+ `@${metaName}/plugin-styled-components/styled`
42
+ ]
43
+ })
44
+ ],
45
+ resolve: {
46
+ alias: {
47
+ 'styled-components': require.resolve('styled-components')
48
+ }
49
+ }
50
+ };
51
+ });
52
+ api._internalRuntimePlugins(async ({ entrypoint, plugins })=>{
53
+ const { metaName } = api.getAppContext();
54
+ plugins.push({
55
+ name: 'styledComponents',
56
+ path: `@${metaName}/plugin-styled-components/runtime`,
57
+ config: {}
58
+ });
59
+ return {
60
+ entrypoint,
61
+ plugins
62
+ };
63
+ });
64
+ }
65
+ });
66
+ const src = styledComponentsPlugin;
67
+ exports["default"] = __webpack_exports__["default"];
68
+ exports.styledComponentsPlugin = __webpack_exports__.styledComponentsPlugin;
69
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
70
+ "default",
71
+ "styledComponentsPlugin"
72
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
73
+ Object.defineProperty(exports, '__esModule', {
74
+ value: true
75
+ });
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ styledComponentsPlugin: ()=>styledComponentsPlugin
28
+ });
29
+ const stream_js_namespaceObject = require("./extender/stream.js");
30
+ const string_js_namespaceObject = require("./extender/string.js");
31
+ const styledComponentsPlugin = ()=>({
32
+ name: '@modern-js/plugin-styled-components',
33
+ setup (api) {
34
+ api.extendStringSSRCollectors(({ chunkSet })=>new string_js_namespaceObject.StyledCollector(chunkSet));
35
+ api.extendStreamSSR(()=>new stream_js_namespaceObject.StreamStyledExtender());
36
+ }
37
+ });
38
+ exports.styledComponentsPlugin = __webpack_exports__.styledComponentsPlugin;
39
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
40
+ "styledComponentsPlugin"
41
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
42
+ Object.defineProperty(exports, '__esModule', {
43
+ value: true
44
+ });
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ var __webpack_modules__ = {
3
+ "styled-components" (module) {
4
+ module.exports = require("styled-components");
5
+ }
6
+ };
7
+ var __webpack_module_cache__ = {};
8
+ function __webpack_require__(moduleId) {
9
+ var cachedModule = __webpack_module_cache__[moduleId];
10
+ if (void 0 !== cachedModule) return cachedModule.exports;
11
+ var module = __webpack_module_cache__[moduleId] = {
12
+ exports: {}
13
+ };
14
+ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
15
+ return module.exports;
16
+ }
17
+ (()=>{
18
+ __webpack_require__.n = (module)=>{
19
+ var getter = module && module.__esModule ? ()=>module['default'] : ()=>module;
20
+ __webpack_require__.d(getter, {
21
+ a: getter
22
+ });
23
+ return getter;
24
+ };
25
+ })();
26
+ (()=>{
27
+ __webpack_require__.d = (exports1, definition)=>{
28
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
29
+ enumerable: true,
30
+ get: definition[key]
31
+ });
32
+ };
33
+ })();
34
+ (()=>{
35
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
36
+ })();
37
+ (()=>{
38
+ __webpack_require__.r = (exports1)=>{
39
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
40
+ value: 'Module'
41
+ });
42
+ Object.defineProperty(exports1, '__esModule', {
43
+ value: true
44
+ });
45
+ };
46
+ })();
47
+ var __webpack_exports__ = {};
48
+ (()=>{
49
+ __webpack_require__.r(__webpack_exports__);
50
+ __webpack_require__.d(__webpack_exports__, {
51
+ default: ()=>__rspack_default_export
52
+ });
53
+ var styled_components__rspack_import_0 = __webpack_require__("styled-components");
54
+ var __rspack_reexport = {};
55
+ for(const __rspack_import_key in styled_components__rspack_import_0)if ("default" !== __rspack_import_key) __rspack_reexport[__rspack_import_key] = ()=>styled_components__rspack_import_0[__rspack_import_key];
56
+ __webpack_require__.d(__webpack_exports__, __rspack_reexport);
57
+ function resolveStyledComponents() {
58
+ const moduleExports = styled_components__rspack_import_0;
59
+ if (moduleExports.default?.default !== void 0) return moduleExports.default.default;
60
+ return moduleExports.default ?? moduleExports;
61
+ }
62
+ const styled = resolveStyledComponents();
63
+ const __rspack_default_export = styled;
64
+ })();
65
+ exports["default"] = __webpack_exports__["default"];
66
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
67
+ "default"
68
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
69
+ Object.defineProperty(exports, '__esModule', {
70
+ value: true
71
+ });
@@ -0,0 +1,23 @@
1
+ import { ServerStyleSheet } from "styled-components";
2
+ class StreamStyledExtender {
3
+ init(params) {
4
+ this.sheet = new ServerStyleSheet();
5
+ this.rootElement = this.sheet.collectStyles(params.rootElement);
6
+ this.forceStream2String = params.forceStream2String;
7
+ }
8
+ modifyRootElement(rootElement) {
9
+ return this.rootElement || rootElement;
10
+ }
11
+ getStyleTags() {
12
+ return this.forceStream2String && this.sheet ? this.sheet.getStyleTags() : '';
13
+ }
14
+ processStream(stream) {
15
+ return this.sheet ? this.sheet.interleaveWithNodeStream(stream) : stream;
16
+ }
17
+ constructor(){
18
+ this.sheet = null;
19
+ this.rootElement = null;
20
+ this.forceStream2String = false;
21
+ }
22
+ }
23
+ export { StreamStyledExtender };
@@ -0,0 +1,61 @@
1
+ import { ServerStyleSheet } from "styled-components";
2
+ function _check_private_redeclaration(obj, privateCollection) {
3
+ if (privateCollection.has(obj)) throw new TypeError("Cannot initialize the same private elements twice on an object");
4
+ }
5
+ function _class_apply_descriptor_get(receiver, descriptor) {
6
+ if (descriptor.get) return descriptor.get.call(receiver);
7
+ return descriptor.value;
8
+ }
9
+ function _class_apply_descriptor_set(receiver, descriptor, value) {
10
+ if (descriptor.set) descriptor.set.call(receiver, value);
11
+ else {
12
+ if (!descriptor.writable) throw new TypeError("attempted to set read only private field");
13
+ descriptor.value = value;
14
+ }
15
+ }
16
+ function _class_extract_field_descriptor(receiver, privateMap, action) {
17
+ if (!privateMap.has(receiver)) throw new TypeError("attempted to " + action + " private field on non-instance");
18
+ return privateMap.get(receiver);
19
+ }
20
+ function _class_private_field_get(receiver, privateMap) {
21
+ var descriptor = _class_extract_field_descriptor(receiver, privateMap, "get");
22
+ return _class_apply_descriptor_get(receiver, descriptor);
23
+ }
24
+ function _class_private_field_init(obj, privateMap, value) {
25
+ _check_private_redeclaration(obj, privateMap);
26
+ privateMap.set(obj, value);
27
+ }
28
+ function _class_private_field_set(receiver, privateMap, value) {
29
+ var descriptor = _class_extract_field_descriptor(receiver, privateMap, "set");
30
+ _class_apply_descriptor_set(receiver, descriptor, value);
31
+ return value;
32
+ }
33
+ var string_RenderLevel = /*#__PURE__*/ function(RenderLevel) {
34
+ RenderLevel[RenderLevel["CLIENT_RENDER"] = 0] = "CLIENT_RENDER";
35
+ RenderLevel[RenderLevel["SERVER_PREFETCH"] = 1] = "SERVER_PREFETCH";
36
+ RenderLevel[RenderLevel["SERVER_RENDER"] = 2] = "SERVER_RENDER";
37
+ return RenderLevel;
38
+ }({});
39
+ var _sheet = /*#__PURE__*/ new WeakMap(), _chunkSet = /*#__PURE__*/ new WeakMap();
40
+ class StyledCollector {
41
+ collect(comopnent) {
42
+ return _class_private_field_get(this, _sheet).collectStyles(comopnent);
43
+ }
44
+ effect() {
45
+ const css = _class_private_field_get(this, _sheet).getStyleTags();
46
+ _class_private_field_get(this, _chunkSet).cssChunk += css;
47
+ }
48
+ constructor(chunkSet){
49
+ _class_private_field_init(this, _sheet, {
50
+ writable: true,
51
+ value: void 0
52
+ });
53
+ _class_private_field_init(this, _chunkSet, {
54
+ writable: true,
55
+ value: void 0
56
+ });
57
+ _class_private_field_set(this, _sheet, new ServerStyleSheet());
58
+ _class_private_field_set(this, _chunkSet, chunkSet);
59
+ }
60
+ }
61
+ export { StyledCollector, string_RenderLevel as RenderLevel };
@@ -0,0 +1,39 @@
1
+ import { pluginStyledComponents } from "@rsbuild/plugin-styled-components";
2
+ const styledComponentsPlugin = (options)=>({
3
+ name: '@modern-js/plugin-styled-components',
4
+ setup (api) {
5
+ api.config(()=>{
6
+ const { metaName } = api.getAppContext();
7
+ return {
8
+ builderPlugins: [
9
+ pluginStyledComponents({
10
+ ...options,
11
+ topLevelImportPaths: [
12
+ `@${metaName}/plugin-styled-components/styled`
13
+ ]
14
+ })
15
+ ],
16
+ resolve: {
17
+ alias: {
18
+ 'styled-components': require.resolve('styled-components')
19
+ }
20
+ }
21
+ };
22
+ });
23
+ api._internalRuntimePlugins(async ({ entrypoint, plugins })=>{
24
+ const { metaName } = api.getAppContext();
25
+ plugins.push({
26
+ name: 'styledComponents',
27
+ path: `@${metaName}/plugin-styled-components/runtime`,
28
+ config: {}
29
+ });
30
+ return {
31
+ entrypoint,
32
+ plugins
33
+ };
34
+ });
35
+ }
36
+ });
37
+ const src = styledComponentsPlugin;
38
+ export default src;
39
+ export { styledComponentsPlugin };
@@ -0,0 +1,10 @@
1
+ import { StreamStyledExtender } from "./extender/stream.mjs";
2
+ import { StyledCollector } from "./extender/string.mjs";
3
+ const styledComponentsPlugin = ()=>({
4
+ name: '@modern-js/plugin-styled-components',
5
+ setup (api) {
6
+ api.extendStringSSRCollectors(({ chunkSet })=>new StyledCollector(chunkSet));
7
+ api.extendStreamSSR(()=>new StreamStyledExtender());
8
+ }
9
+ });
10
+ export { styledComponentsPlugin };
@@ -0,0 +1,10 @@
1
+ import * as __rspack_external_styled_components_326b429a from "styled-components";
2
+ export * from "styled-components";
3
+ function resolveStyledComponents() {
4
+ const moduleExports = __rspack_external_styled_components_326b429a;
5
+ if (moduleExports.default?.default !== void 0) return moduleExports.default.default;
6
+ return moduleExports.default ?? moduleExports;
7
+ }
8
+ const styled = resolveStyledComponents();
9
+ const src_styled = styled;
10
+ export default src_styled;
@@ -0,0 +1,24 @@
1
+ import "node:module";
2
+ import { ServerStyleSheet } from "styled-components";
3
+ class StreamStyledExtender {
4
+ init(params) {
5
+ this.sheet = new ServerStyleSheet();
6
+ this.rootElement = this.sheet.collectStyles(params.rootElement);
7
+ this.forceStream2String = params.forceStream2String;
8
+ }
9
+ modifyRootElement(rootElement) {
10
+ return this.rootElement || rootElement;
11
+ }
12
+ getStyleTags() {
13
+ return this.forceStream2String && this.sheet ? this.sheet.getStyleTags() : '';
14
+ }
15
+ processStream(stream) {
16
+ return this.sheet ? this.sheet.interleaveWithNodeStream(stream) : stream;
17
+ }
18
+ constructor(){
19
+ this.sheet = null;
20
+ this.rootElement = null;
21
+ this.forceStream2String = false;
22
+ }
23
+ }
24
+ export { StreamStyledExtender };
@@ -0,0 +1,62 @@
1
+ import "node:module";
2
+ import { ServerStyleSheet } from "styled-components";
3
+ function _check_private_redeclaration(obj, privateCollection) {
4
+ if (privateCollection.has(obj)) throw new TypeError("Cannot initialize the same private elements twice on an object");
5
+ }
6
+ function _class_apply_descriptor_get(receiver, descriptor) {
7
+ if (descriptor.get) return descriptor.get.call(receiver);
8
+ return descriptor.value;
9
+ }
10
+ function _class_apply_descriptor_set(receiver, descriptor, value) {
11
+ if (descriptor.set) descriptor.set.call(receiver, value);
12
+ else {
13
+ if (!descriptor.writable) throw new TypeError("attempted to set read only private field");
14
+ descriptor.value = value;
15
+ }
16
+ }
17
+ function _class_extract_field_descriptor(receiver, privateMap, action) {
18
+ if (!privateMap.has(receiver)) throw new TypeError("attempted to " + action + " private field on non-instance");
19
+ return privateMap.get(receiver);
20
+ }
21
+ function _class_private_field_get(receiver, privateMap) {
22
+ var descriptor = _class_extract_field_descriptor(receiver, privateMap, "get");
23
+ return _class_apply_descriptor_get(receiver, descriptor);
24
+ }
25
+ function _class_private_field_init(obj, privateMap, value) {
26
+ _check_private_redeclaration(obj, privateMap);
27
+ privateMap.set(obj, value);
28
+ }
29
+ function _class_private_field_set(receiver, privateMap, value) {
30
+ var descriptor = _class_extract_field_descriptor(receiver, privateMap, "set");
31
+ _class_apply_descriptor_set(receiver, descriptor, value);
32
+ return value;
33
+ }
34
+ var string_RenderLevel = /*#__PURE__*/ function(RenderLevel) {
35
+ RenderLevel[RenderLevel["CLIENT_RENDER"] = 0] = "CLIENT_RENDER";
36
+ RenderLevel[RenderLevel["SERVER_PREFETCH"] = 1] = "SERVER_PREFETCH";
37
+ RenderLevel[RenderLevel["SERVER_RENDER"] = 2] = "SERVER_RENDER";
38
+ return RenderLevel;
39
+ }({});
40
+ var _sheet = /*#__PURE__*/ new WeakMap(), _chunkSet = /*#__PURE__*/ new WeakMap();
41
+ class StyledCollector {
42
+ collect(comopnent) {
43
+ return _class_private_field_get(this, _sheet).collectStyles(comopnent);
44
+ }
45
+ effect() {
46
+ const css = _class_private_field_get(this, _sheet).getStyleTags();
47
+ _class_private_field_get(this, _chunkSet).cssChunk += css;
48
+ }
49
+ constructor(chunkSet){
50
+ _class_private_field_init(this, _sheet, {
51
+ writable: true,
52
+ value: void 0
53
+ });
54
+ _class_private_field_init(this, _chunkSet, {
55
+ writable: true,
56
+ value: void 0
57
+ });
58
+ _class_private_field_set(this, _sheet, new ServerStyleSheet());
59
+ _class_private_field_set(this, _chunkSet, chunkSet);
60
+ }
61
+ }
62
+ export { StyledCollector, string_RenderLevel as RenderLevel };
@@ -0,0 +1,41 @@
1
+ import __rslib_shim_module__ from "node:module";
2
+ const require = /*#__PURE__*/ __rslib_shim_module__.createRequire(/*#__PURE__*/ (()=>import.meta.url)());
3
+ import { pluginStyledComponents } from "@rsbuild/plugin-styled-components";
4
+ const styledComponentsPlugin = (options)=>({
5
+ name: '@modern-js/plugin-styled-components',
6
+ setup (api) {
7
+ api.config(()=>{
8
+ const { metaName } = api.getAppContext();
9
+ return {
10
+ builderPlugins: [
11
+ pluginStyledComponents({
12
+ ...options,
13
+ topLevelImportPaths: [
14
+ `@${metaName}/plugin-styled-components/styled`
15
+ ]
16
+ })
17
+ ],
18
+ resolve: {
19
+ alias: {
20
+ 'styled-components': require.resolve('styled-components')
21
+ }
22
+ }
23
+ };
24
+ });
25
+ api._internalRuntimePlugins(async ({ entrypoint, plugins })=>{
26
+ const { metaName } = api.getAppContext();
27
+ plugins.push({
28
+ name: 'styledComponents',
29
+ path: `@${metaName}/plugin-styled-components/runtime`,
30
+ config: {}
31
+ });
32
+ return {
33
+ entrypoint,
34
+ plugins
35
+ };
36
+ });
37
+ }
38
+ });
39
+ const src = styledComponentsPlugin;
40
+ export default src;
41
+ export { styledComponentsPlugin };
@@ -0,0 +1,11 @@
1
+ import "node:module";
2
+ import { StreamStyledExtender } from "./extender/stream.mjs";
3
+ import { StyledCollector } from "./extender/string.mjs";
4
+ const styledComponentsPlugin = ()=>({
5
+ name: '@modern-js/plugin-styled-components',
6
+ setup (api) {
7
+ api.extendStringSSRCollectors(({ chunkSet })=>new StyledCollector(chunkSet));
8
+ api.extendStreamSSR(()=>new StreamStyledExtender());
9
+ }
10
+ });
11
+ export { styledComponentsPlugin };
@@ -0,0 +1,11 @@
1
+ import "node:module";
2
+ import * as __rspack_external_styled_components_326b429a from "styled-components";
3
+ export * from "styled-components";
4
+ function resolveStyledComponents() {
5
+ const moduleExports = __rspack_external_styled_components_326b429a;
6
+ if (moduleExports.default?.default !== void 0) return moduleExports.default.default;
7
+ return moduleExports.default ?? moduleExports;
8
+ }
9
+ const styled = resolveStyledComponents();
10
+ const src_styled = styled;
11
+ export default src_styled;
@@ -0,0 +1,12 @@
1
+ export declare class StreamStyledExtender {
2
+ private sheet;
3
+ private rootElement;
4
+ private forceStream2String;
5
+ init(params: {
6
+ rootElement: React.ReactElement;
7
+ forceStream2String: boolean;
8
+ }): void;
9
+ modifyRootElement(rootElement: React.ReactElement): import("react").ReactElement<unknown, string | import("react").JSXElementConstructor<any>>;
10
+ getStyleTags(): any;
11
+ processStream(stream: NodeJS.ReadWriteStream): any;
12
+ }
@@ -0,0 +1,21 @@
1
+ export interface Collector {
2
+ collect?: (comopnent: React.ReactElement) => React.ReactElement;
3
+ effect: () => void | Promise<void>;
4
+ }
5
+ export declare enum RenderLevel {
6
+ CLIENT_RENDER = 0,
7
+ SERVER_PREFETCH = 1,
8
+ SERVER_RENDER = 2
9
+ }
10
+ export type ChunkSet = {
11
+ renderLevel: RenderLevel;
12
+ ssrScripts: string;
13
+ jsChunk: string;
14
+ cssChunk: string;
15
+ };
16
+ export declare class StyledCollector implements Collector {
17
+ #private;
18
+ constructor(chunkSet: ChunkSet);
19
+ collect(comopnent: React.ReactElement): import("react").JSX.Element;
20
+ effect(): void;
21
+ }
@@ -0,0 +1,4 @@
1
+ import type { AppTools, CliPlugin } from '@modern-js/app-tools';
2
+ import { type PluginStyledComponentsOptions } from '@rsbuild/plugin-styled-components';
3
+ export declare const styledComponentsPlugin: (options?: PluginStyledComponentsOptions) => CliPlugin<AppTools>;
4
+ export default styledComponentsPlugin;
@@ -0,0 +1,2 @@
1
+ import type { RuntimePlugin } from '@modern-js/runtime';
2
+ export declare const styledComponentsPlugin: () => RuntimePlugin;
@@ -0,0 +1,158 @@
1
+ import * as styledComponents from 'styled-components';
2
+ declare const styled: (<Target extends styledComponents.WebTarget, InjectedProps extends object = import("styled-components/dist/types").BaseObject>(tag: Target) => styledComponents.StyledInstance<"web", Target, Target extends import("styled-components/dist/types").KnownTarget ? React.ComponentPropsWithRef<Target> & InjectedProps : InjectedProps, import("styled-components/dist/types").BaseObject, never>) & {
3
+ symbol: styledComponents.StyledInstance<"web", "symbol", import("react").SVGProps<SVGSymbolElement>, import("styled-components/dist/types").BaseObject, never>;
4
+ object: styledComponents.StyledInstance<"web", "object", import("react").DetailedHTMLProps<import("react").ObjectHTMLAttributes<HTMLObjectElement>, HTMLObjectElement>, import("styled-components/dist/types").BaseObject, never>;
5
+ main: styledComponents.StyledInstance<"web", "main", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
6
+ output: styledComponents.StyledInstance<"web", "output", import("react").DetailedHTMLProps<import("react").OutputHTMLAttributes<HTMLOutputElement>, HTMLOutputElement>, import("styled-components/dist/types").BaseObject, never>;
7
+ search: styledComponents.StyledInstance<"web", "search", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
8
+ small: styledComponents.StyledInstance<"web", "small", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
9
+ sub: styledComponents.StyledInstance<"web", "sub", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
10
+ sup: styledComponents.StyledInstance<"web", "sup", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
11
+ map: styledComponents.StyledInstance<"web", "map", import("react").DetailedHTMLProps<import("react").MapHTMLAttributes<HTMLMapElement>, HTMLMapElement>, import("styled-components/dist/types").BaseObject, never>;
12
+ filter: styledComponents.StyledInstance<"web", "filter", import("react").SVGProps<SVGFilterElement>, import("styled-components/dist/types").BaseObject, never>;
13
+ label: styledComponents.StyledInstance<"web", "label", import("react").DetailedHTMLProps<import("react").LabelHTMLAttributes<HTMLLabelElement>, HTMLLabelElement>, import("styled-components/dist/types").BaseObject, never>;
14
+ pre: styledComponents.StyledInstance<"web", "pre", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLPreElement>, HTMLPreElement>, import("styled-components/dist/types").BaseObject, never>;
15
+ use: styledComponents.StyledInstance<"web", "use", import("react").SVGProps<SVGUseElement>, import("styled-components/dist/types").BaseObject, never>;
16
+ html: styledComponents.StyledInstance<"web", "html", import("react").DetailedHTMLProps<import("react").HtmlHTMLAttributes<HTMLHtmlElement>, HTMLHtmlElement>, import("styled-components/dist/types").BaseObject, never>;
17
+ option: styledComponents.StyledInstance<"web", "option", import("react").DetailedHTMLProps<import("react").OptionHTMLAttributes<HTMLOptionElement>, HTMLOptionElement>, import("styled-components/dist/types").BaseObject, never>;
18
+ header: styledComponents.StyledInstance<"web", "header", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
19
+ body: styledComponents.StyledInstance<"web", "body", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLBodyElement>, HTMLBodyElement>, import("styled-components/dist/types").BaseObject, never>;
20
+ a: styledComponents.StyledInstance<"web", "a", import("react").DetailedHTMLProps<import("react").AnchorHTMLAttributes<HTMLAnchorElement>, HTMLAnchorElement>, import("styled-components/dist/types").BaseObject, never>;
21
+ b: styledComponents.StyledInstance<"web", "b", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
22
+ code: styledComponents.StyledInstance<"web", "code", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
23
+ path: styledComponents.StyledInstance<"web", "path", import("react").SVGProps<SVGPathElement>, import("styled-components/dist/types").BaseObject, never>;
24
+ form: styledComponents.StyledInstance<"web", "form", import("react").DetailedHTMLProps<import("react").FormHTMLAttributes<HTMLFormElement>, HTMLFormElement>, import("styled-components/dist/types").BaseObject, never>;
25
+ text: styledComponents.StyledInstance<"web", "text", import("react").SVGTextElementAttributes<SVGTextElement>, import("styled-components/dist/types").BaseObject, never>;
26
+ data: styledComponents.StyledInstance<"web", "data", import("react").DetailedHTMLProps<import("react").DataHTMLAttributes<HTMLDataElement>, HTMLDataElement>, import("styled-components/dist/types").BaseObject, never>;
27
+ svg: styledComponents.StyledInstance<"web", "svg", import("react").SVGProps<SVGSVGElement>, import("styled-components/dist/types").BaseObject, never>;
28
+ template: styledComponents.StyledInstance<"web", "template", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLTemplateElement>, HTMLTemplateElement>, import("styled-components/dist/types").BaseObject, never>;
29
+ summary: styledComponents.StyledInstance<"web", "summary", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
30
+ footer: styledComponents.StyledInstance<"web", "footer", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
31
+ var: styledComponents.StyledInstance<"web", "var", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
32
+ u: styledComponents.StyledInstance<"web", "u", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
33
+ input: styledComponents.StyledInstance<"web", "input", import("react").DetailedHTMLProps<import("react").InputHTMLAttributes<HTMLInputElement>, HTMLInputElement>, import("styled-components/dist/types").BaseObject, never>;
34
+ circle: styledComponents.StyledInstance<"web", "circle", import("react").SVGProps<SVGCircleElement>, import("styled-components/dist/types").BaseObject, never>;
35
+ table: styledComponents.StyledInstance<"web", "table", import("react").DetailedHTMLProps<import("react").TableHTMLAttributes<HTMLTableElement>, HTMLTableElement>, import("styled-components/dist/types").BaseObject, never>;
36
+ abbr: styledComponents.StyledInstance<"web", "abbr", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
37
+ address: styledComponents.StyledInstance<"web", "address", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
38
+ area: styledComponents.StyledInstance<"web", "area", import("react").DetailedHTMLProps<import("react").AreaHTMLAttributes<HTMLAreaElement>, HTMLAreaElement>, import("styled-components/dist/types").BaseObject, never>;
39
+ article: styledComponents.StyledInstance<"web", "article", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
40
+ aside: styledComponents.StyledInstance<"web", "aside", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
41
+ audio: styledComponents.StyledInstance<"web", "audio", import("react").DetailedHTMLProps<import("react").AudioHTMLAttributes<HTMLAudioElement>, HTMLAudioElement>, import("styled-components/dist/types").BaseObject, never>;
42
+ bdi: styledComponents.StyledInstance<"web", "bdi", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
43
+ bdo: styledComponents.StyledInstance<"web", "bdo", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
44
+ blockquote: styledComponents.StyledInstance<"web", "blockquote", import("react").DetailedHTMLProps<import("react").BlockquoteHTMLAttributes<HTMLQuoteElement>, HTMLQuoteElement>, import("styled-components/dist/types").BaseObject, never>;
45
+ br: styledComponents.StyledInstance<"web", "br", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLBRElement>, HTMLBRElement>, import("styled-components/dist/types").BaseObject, never>;
46
+ button: styledComponents.StyledInstance<"web", "button", import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, import("styled-components/dist/types").BaseObject, never>;
47
+ canvas: styledComponents.StyledInstance<"web", "canvas", import("react").DetailedHTMLProps<import("react").CanvasHTMLAttributes<HTMLCanvasElement>, HTMLCanvasElement>, import("styled-components/dist/types").BaseObject, never>;
48
+ caption: styledComponents.StyledInstance<"web", "caption", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
49
+ cite: styledComponents.StyledInstance<"web", "cite", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
50
+ col: styledComponents.StyledInstance<"web", "col", import("react").DetailedHTMLProps<import("react").ColHTMLAttributes<HTMLTableColElement>, HTMLTableColElement>, import("styled-components/dist/types").BaseObject, never>;
51
+ colgroup: styledComponents.StyledInstance<"web", "colgroup", import("react").DetailedHTMLProps<import("react").ColgroupHTMLAttributes<HTMLTableColElement>, HTMLTableColElement>, import("styled-components/dist/types").BaseObject, never>;
52
+ datalist: styledComponents.StyledInstance<"web", "datalist", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDataListElement>, HTMLDataListElement>, import("styled-components/dist/types").BaseObject, never>;
53
+ dd: styledComponents.StyledInstance<"web", "dd", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
54
+ del: styledComponents.StyledInstance<"web", "del", import("react").DetailedHTMLProps<import("react").DelHTMLAttributes<HTMLModElement>, HTMLModElement>, import("styled-components/dist/types").BaseObject, never>;
55
+ details: styledComponents.StyledInstance<"web", "details", import("react").DetailedHTMLProps<import("react").DetailsHTMLAttributes<HTMLDetailsElement>, HTMLDetailsElement>, import("styled-components/dist/types").BaseObject, never>;
56
+ dfn: styledComponents.StyledInstance<"web", "dfn", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
57
+ dialog: styledComponents.StyledInstance<"web", "dialog", import("react").DetailedHTMLProps<import("react").DialogHTMLAttributes<HTMLDialogElement>, HTMLDialogElement>, import("styled-components/dist/types").BaseObject, never>;
58
+ div: styledComponents.StyledInstance<"web", "div", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, import("styled-components/dist/types").BaseObject, never>;
59
+ dl: styledComponents.StyledInstance<"web", "dl", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDListElement>, HTMLDListElement>, import("styled-components/dist/types").BaseObject, never>;
60
+ dt: styledComponents.StyledInstance<"web", "dt", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
61
+ em: styledComponents.StyledInstance<"web", "em", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
62
+ embed: styledComponents.StyledInstance<"web", "embed", import("react").DetailedHTMLProps<import("react").EmbedHTMLAttributes<HTMLEmbedElement>, HTMLEmbedElement>, import("styled-components/dist/types").BaseObject, never>;
63
+ fieldset: styledComponents.StyledInstance<"web", "fieldset", import("react").DetailedHTMLProps<import("react").FieldsetHTMLAttributes<HTMLFieldSetElement>, HTMLFieldSetElement>, import("styled-components/dist/types").BaseObject, never>;
64
+ figcaption: styledComponents.StyledInstance<"web", "figcaption", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
65
+ figure: styledComponents.StyledInstance<"web", "figure", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
66
+ h1: styledComponents.StyledInstance<"web", "h1", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, import("styled-components/dist/types").BaseObject, never>;
67
+ h2: styledComponents.StyledInstance<"web", "h2", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, import("styled-components/dist/types").BaseObject, never>;
68
+ h3: styledComponents.StyledInstance<"web", "h3", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, import("styled-components/dist/types").BaseObject, never>;
69
+ h4: styledComponents.StyledInstance<"web", "h4", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, import("styled-components/dist/types").BaseObject, never>;
70
+ h5: styledComponents.StyledInstance<"web", "h5", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, import("styled-components/dist/types").BaseObject, never>;
71
+ h6: styledComponents.StyledInstance<"web", "h6", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHeadingElement>, HTMLHeadingElement>, import("styled-components/dist/types").BaseObject, never>;
72
+ hgroup: styledComponents.StyledInstance<"web", "hgroup", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
73
+ hr: styledComponents.StyledInstance<"web", "hr", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLHRElement>, HTMLHRElement>, import("styled-components/dist/types").BaseObject, never>;
74
+ i: styledComponents.StyledInstance<"web", "i", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
75
+ iframe: styledComponents.StyledInstance<"web", "iframe", import("react").DetailedHTMLProps<import("react").IframeHTMLAttributes<HTMLIFrameElement>, HTMLIFrameElement>, import("styled-components/dist/types").BaseObject, never>;
76
+ img: styledComponents.StyledInstance<"web", "img", import("react").DetailedHTMLProps<import("react").ImgHTMLAttributes<HTMLImageElement>, HTMLImageElement>, import("styled-components/dist/types").BaseObject, never>;
77
+ ins: styledComponents.StyledInstance<"web", "ins", import("react").DetailedHTMLProps<import("react").InsHTMLAttributes<HTMLModElement>, HTMLModElement>, import("styled-components/dist/types").BaseObject, never>;
78
+ kbd: styledComponents.StyledInstance<"web", "kbd", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
79
+ legend: styledComponents.StyledInstance<"web", "legend", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLLegendElement>, HTMLLegendElement>, import("styled-components/dist/types").BaseObject, never>;
80
+ li: styledComponents.StyledInstance<"web", "li", import("react").DetailedHTMLProps<import("react").LiHTMLAttributes<HTMLLIElement>, HTMLLIElement>, import("styled-components/dist/types").BaseObject, never>;
81
+ mark: styledComponents.StyledInstance<"web", "mark", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
82
+ menu: styledComponents.StyledInstance<"web", "menu", import("react").DetailedHTMLProps<import("react").MenuHTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
83
+ meter: styledComponents.StyledInstance<"web", "meter", import("react").DetailedHTMLProps<import("react").MeterHTMLAttributes<HTMLMeterElement>, HTMLMeterElement>, import("styled-components/dist/types").BaseObject, never>;
84
+ nav: styledComponents.StyledInstance<"web", "nav", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
85
+ ol: styledComponents.StyledInstance<"web", "ol", import("react").DetailedHTMLProps<import("react").OlHTMLAttributes<HTMLOListElement>, HTMLOListElement>, import("styled-components/dist/types").BaseObject, never>;
86
+ optgroup: styledComponents.StyledInstance<"web", "optgroup", import("react").DetailedHTMLProps<import("react").OptgroupHTMLAttributes<HTMLOptGroupElement>, HTMLOptGroupElement>, import("styled-components/dist/types").BaseObject, never>;
87
+ p: styledComponents.StyledInstance<"web", "p", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLParagraphElement>, HTMLParagraphElement>, import("styled-components/dist/types").BaseObject, never>;
88
+ picture: styledComponents.StyledInstance<"web", "picture", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
89
+ progress: styledComponents.StyledInstance<"web", "progress", import("react").DetailedHTMLProps<import("react").ProgressHTMLAttributes<HTMLProgressElement>, HTMLProgressElement>, import("styled-components/dist/types").BaseObject, never>;
90
+ q: styledComponents.StyledInstance<"web", "q", import("react").DetailedHTMLProps<import("react").QuoteHTMLAttributes<HTMLQuoteElement>, HTMLQuoteElement>, import("styled-components/dist/types").BaseObject, never>;
91
+ rp: styledComponents.StyledInstance<"web", "rp", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
92
+ rt: styledComponents.StyledInstance<"web", "rt", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
93
+ ruby: styledComponents.StyledInstance<"web", "ruby", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
94
+ s: styledComponents.StyledInstance<"web", "s", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
95
+ samp: styledComponents.StyledInstance<"web", "samp", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
96
+ section: styledComponents.StyledInstance<"web", "section", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
97
+ select: styledComponents.StyledInstance<"web", "select", import("react").DetailedHTMLProps<import("react").SelectHTMLAttributes<HTMLSelectElement>, HTMLSelectElement>, import("styled-components/dist/types").BaseObject, never>;
98
+ slot: styledComponents.StyledInstance<"web", "slot", import("react").DetailedHTMLProps<import("react").SlotHTMLAttributes<HTMLSlotElement>, HTMLSlotElement>, import("styled-components/dist/types").BaseObject, never>;
99
+ span: styledComponents.StyledInstance<"web", "span", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, import("styled-components/dist/types").BaseObject, never>;
100
+ strong: styledComponents.StyledInstance<"web", "strong", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
101
+ tbody: styledComponents.StyledInstance<"web", "tbody", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLTableSectionElement>, HTMLTableSectionElement>, import("styled-components/dist/types").BaseObject, never>;
102
+ td: styledComponents.StyledInstance<"web", "td", import("react").DetailedHTMLProps<import("react").TdHTMLAttributes<HTMLTableDataCellElement>, HTMLTableDataCellElement>, import("styled-components/dist/types").BaseObject, never>;
103
+ textarea: styledComponents.StyledInstance<"web", "textarea", import("react").DetailedHTMLProps<import("react").TextareaHTMLAttributes<HTMLTextAreaElement>, HTMLTextAreaElement>, import("styled-components/dist/types").BaseObject, never>;
104
+ tfoot: styledComponents.StyledInstance<"web", "tfoot", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLTableSectionElement>, HTMLTableSectionElement>, import("styled-components/dist/types").BaseObject, never>;
105
+ th: styledComponents.StyledInstance<"web", "th", import("react").DetailedHTMLProps<import("react").ThHTMLAttributes<HTMLTableHeaderCellElement>, HTMLTableHeaderCellElement>, import("styled-components/dist/types").BaseObject, never>;
106
+ thead: styledComponents.StyledInstance<"web", "thead", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLTableSectionElement>, HTMLTableSectionElement>, import("styled-components/dist/types").BaseObject, never>;
107
+ time: styledComponents.StyledInstance<"web", "time", import("react").DetailedHTMLProps<import("react").TimeHTMLAttributes<HTMLTimeElement>, HTMLTimeElement>, import("styled-components/dist/types").BaseObject, never>;
108
+ tr: styledComponents.StyledInstance<"web", "tr", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLTableRowElement>, HTMLTableRowElement>, import("styled-components/dist/types").BaseObject, never>;
109
+ ul: styledComponents.StyledInstance<"web", "ul", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLUListElement>, HTMLUListElement>, import("styled-components/dist/types").BaseObject, never>;
110
+ video: styledComponents.StyledInstance<"web", "video", import("react").DetailedHTMLProps<import("react").VideoHTMLAttributes<HTMLVideoElement>, HTMLVideoElement>, import("styled-components/dist/types").BaseObject, never>;
111
+ wbr: styledComponents.StyledInstance<"web", "wbr", import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLElement>, HTMLElement>, import("styled-components/dist/types").BaseObject, never>;
112
+ clipPath: styledComponents.StyledInstance<"web", "clipPath", import("react").SVGProps<SVGClipPathElement>, import("styled-components/dist/types").BaseObject, never>;
113
+ defs: styledComponents.StyledInstance<"web", "defs", import("react").SVGProps<SVGDefsElement>, import("styled-components/dist/types").BaseObject, never>;
114
+ ellipse: styledComponents.StyledInstance<"web", "ellipse", import("react").SVGProps<SVGEllipseElement>, import("styled-components/dist/types").BaseObject, never>;
115
+ feBlend: styledComponents.StyledInstance<"web", "feBlend", import("react").SVGProps<SVGFEBlendElement>, import("styled-components/dist/types").BaseObject, never>;
116
+ feColorMatrix: styledComponents.StyledInstance<"web", "feColorMatrix", import("react").SVGProps<SVGFEColorMatrixElement>, import("styled-components/dist/types").BaseObject, never>;
117
+ feComponentTransfer: styledComponents.StyledInstance<"web", "feComponentTransfer", import("react").SVGProps<SVGFEComponentTransferElement>, import("styled-components/dist/types").BaseObject, never>;
118
+ feComposite: styledComponents.StyledInstance<"web", "feComposite", import("react").SVGProps<SVGFECompositeElement>, import("styled-components/dist/types").BaseObject, never>;
119
+ feConvolveMatrix: styledComponents.StyledInstance<"web", "feConvolveMatrix", import("react").SVGProps<SVGFEConvolveMatrixElement>, import("styled-components/dist/types").BaseObject, never>;
120
+ feDiffuseLighting: styledComponents.StyledInstance<"web", "feDiffuseLighting", import("react").SVGProps<SVGFEDiffuseLightingElement>, import("styled-components/dist/types").BaseObject, never>;
121
+ feDisplacementMap: styledComponents.StyledInstance<"web", "feDisplacementMap", import("react").SVGProps<SVGFEDisplacementMapElement>, import("styled-components/dist/types").BaseObject, never>;
122
+ feDistantLight: styledComponents.StyledInstance<"web", "feDistantLight", import("react").SVGProps<SVGFEDistantLightElement>, import("styled-components/dist/types").BaseObject, never>;
123
+ feDropShadow: styledComponents.StyledInstance<"web", "feDropShadow", import("react").SVGProps<SVGFEDropShadowElement>, import("styled-components/dist/types").BaseObject, never>;
124
+ feFlood: styledComponents.StyledInstance<"web", "feFlood", import("react").SVGProps<SVGFEFloodElement>, import("styled-components/dist/types").BaseObject, never>;
125
+ feFuncA: styledComponents.StyledInstance<"web", "feFuncA", import("react").SVGProps<SVGFEFuncAElement>, import("styled-components/dist/types").BaseObject, never>;
126
+ feFuncB: styledComponents.StyledInstance<"web", "feFuncB", import("react").SVGProps<SVGFEFuncBElement>, import("styled-components/dist/types").BaseObject, never>;
127
+ feFuncG: styledComponents.StyledInstance<"web", "feFuncG", import("react").SVGProps<SVGFEFuncGElement>, import("styled-components/dist/types").BaseObject, never>;
128
+ feFuncR: styledComponents.StyledInstance<"web", "feFuncR", import("react").SVGProps<SVGFEFuncRElement>, import("styled-components/dist/types").BaseObject, never>;
129
+ feGaussianBlur: styledComponents.StyledInstance<"web", "feGaussianBlur", import("react").SVGProps<SVGFEGaussianBlurElement>, import("styled-components/dist/types").BaseObject, never>;
130
+ feImage: styledComponents.StyledInstance<"web", "feImage", import("react").SVGProps<SVGFEImageElement>, import("styled-components/dist/types").BaseObject, never>;
131
+ feMerge: styledComponents.StyledInstance<"web", "feMerge", import("react").SVGProps<SVGFEMergeElement>, import("styled-components/dist/types").BaseObject, never>;
132
+ feMergeNode: styledComponents.StyledInstance<"web", "feMergeNode", import("react").SVGProps<SVGFEMergeNodeElement>, import("styled-components/dist/types").BaseObject, never>;
133
+ feMorphology: styledComponents.StyledInstance<"web", "feMorphology", import("react").SVGProps<SVGFEMorphologyElement>, import("styled-components/dist/types").BaseObject, never>;
134
+ feOffset: styledComponents.StyledInstance<"web", "feOffset", import("react").SVGProps<SVGFEOffsetElement>, import("styled-components/dist/types").BaseObject, never>;
135
+ fePointLight: styledComponents.StyledInstance<"web", "fePointLight", import("react").SVGProps<SVGFEPointLightElement>, import("styled-components/dist/types").BaseObject, never>;
136
+ feSpecularLighting: styledComponents.StyledInstance<"web", "feSpecularLighting", import("react").SVGProps<SVGFESpecularLightingElement>, import("styled-components/dist/types").BaseObject, never>;
137
+ feSpotLight: styledComponents.StyledInstance<"web", "feSpotLight", import("react").SVGProps<SVGFESpotLightElement>, import("styled-components/dist/types").BaseObject, never>;
138
+ feTile: styledComponents.StyledInstance<"web", "feTile", import("react").SVGProps<SVGFETileElement>, import("styled-components/dist/types").BaseObject, never>;
139
+ feTurbulence: styledComponents.StyledInstance<"web", "feTurbulence", import("react").SVGProps<SVGFETurbulenceElement>, import("styled-components/dist/types").BaseObject, never>;
140
+ foreignObject: styledComponents.StyledInstance<"web", "foreignObject", import("react").SVGProps<SVGForeignObjectElement>, import("styled-components/dist/types").BaseObject, never>;
141
+ g: styledComponents.StyledInstance<"web", "g", import("react").SVGProps<SVGGElement>, import("styled-components/dist/types").BaseObject, never>;
142
+ image: styledComponents.StyledInstance<"web", "image", import("react").SVGProps<SVGImageElement>, import("styled-components/dist/types").BaseObject, never>;
143
+ line: styledComponents.StyledInstance<"web", "line", import("react").SVGLineElementAttributes<SVGLineElement>, import("styled-components/dist/types").BaseObject, never>;
144
+ linearGradient: styledComponents.StyledInstance<"web", "linearGradient", import("react").SVGProps<SVGLinearGradientElement>, import("styled-components/dist/types").BaseObject, never>;
145
+ marker: styledComponents.StyledInstance<"web", "marker", import("react").SVGProps<SVGMarkerElement>, import("styled-components/dist/types").BaseObject, never>;
146
+ mask: styledComponents.StyledInstance<"web", "mask", import("react").SVGProps<SVGMaskElement>, import("styled-components/dist/types").BaseObject, never>;
147
+ pattern: styledComponents.StyledInstance<"web", "pattern", import("react").SVGProps<SVGPatternElement>, import("styled-components/dist/types").BaseObject, never>;
148
+ polygon: styledComponents.StyledInstance<"web", "polygon", import("react").SVGProps<SVGPolygonElement>, import("styled-components/dist/types").BaseObject, never>;
149
+ polyline: styledComponents.StyledInstance<"web", "polyline", import("react").SVGProps<SVGPolylineElement>, import("styled-components/dist/types").BaseObject, never>;
150
+ radialGradient: styledComponents.StyledInstance<"web", "radialGradient", import("react").SVGProps<SVGRadialGradientElement>, import("styled-components/dist/types").BaseObject, never>;
151
+ rect: styledComponents.StyledInstance<"web", "rect", import("react").SVGProps<SVGRectElement>, import("styled-components/dist/types").BaseObject, never>;
152
+ stop: styledComponents.StyledInstance<"web", "stop", import("react").SVGProps<SVGStopElement>, import("styled-components/dist/types").BaseObject, never>;
153
+ switch: styledComponents.StyledInstance<"web", "switch", import("react").SVGProps<SVGSwitchElement>, import("styled-components/dist/types").BaseObject, never>;
154
+ textPath: styledComponents.StyledInstance<"web", "textPath", import("react").SVGProps<SVGTextPathElement>, import("styled-components/dist/types").BaseObject, never>;
155
+ tspan: styledComponents.StyledInstance<"web", "tspan", import("react").SVGProps<SVGTSpanElement>, import("styled-components/dist/types").BaseObject, never>;
156
+ };
157
+ export default styled;
158
+ export * from 'styled-components';
package/package.json ADDED
@@ -0,0 +1,92 @@
1
+ {
2
+ "name": "@bleedingdev/modern-js-plugin-styled-components",
3
+ "description": "A Modern.js plugin for styled-components.",
4
+ "license": "MIT",
5
+ "keywords": [
6
+ "react",
7
+ "framework",
8
+ "modern",
9
+ "modern.js"
10
+ ],
11
+ "version": "3.2.0-ultramodern.0",
12
+ "types": "./src/index.ts",
13
+ "main": "./dist/cjs/index.js",
14
+ "export": {
15
+ ".": {
16
+ "types": "./dist/types/index.d.ts",
17
+ "node": {
18
+ "import": "./dist/esm-node/index.mjs",
19
+ "require": "./dist/cjs/index.js"
20
+ },
21
+ "default": "./dist/cjs/index.js"
22
+ },
23
+ "./runtime": {
24
+ "types": "./dist/types/runtime.d.ts",
25
+ "default": "./dist/esm/runtime.mjs"
26
+ }
27
+ },
28
+ "dependencies": {
29
+ "@rsbuild/plugin-styled-components": "1.6.1",
30
+ "@swc/helpers": "^0.5.21"
31
+ },
32
+ "devDependencies": {
33
+ "@rslib/core": "0.21.5",
34
+ "@types/jest": "^30.0.0",
35
+ "@types/node": "^25.8.0",
36
+ "@types/styled-components": "^5.1.36",
37
+ "@typescript/native-preview": "7.0.0-dev.20260516.1",
38
+ "styled-components": "^6.4.1",
39
+ "@modern-js/app-tools": "npm:@bleedingdev/modern-js-app-tools@3.2.0-ultramodern.0",
40
+ "@modern-js/runtime": "npm:@bleedingdev/modern-js-runtime@3.2.0-ultramodern.0"
41
+ },
42
+ "peerDependencies": {
43
+ "styled-components": "^5.3.1"
44
+ },
45
+ "exports": {
46
+ ".": {
47
+ "types": "./dist/types/index.d.ts",
48
+ "node": {
49
+ "import": "./dist/esm-node/index.mjs",
50
+ "require": "./dist/cjs/index.js"
51
+ },
52
+ "default": "./dist/cjs/index.js"
53
+ },
54
+ "./runtime": {
55
+ "types": "./dist/types/runtime.d.ts",
56
+ "default": "./dist/esm/runtime.mjs"
57
+ },
58
+ "./styled": {
59
+ "types": "./dist/types/styled.d.ts",
60
+ "default": "./dist/esm/styled.mjs"
61
+ }
62
+ },
63
+ "typesVersions": {
64
+ "*": {
65
+ ".": [
66
+ "./dist/types/index.d.ts"
67
+ ],
68
+ "runtime": [
69
+ "./dist/types/runtime.d.ts"
70
+ ],
71
+ "styled": [
72
+ "./dist/types/styled.d.ts"
73
+ ]
74
+ }
75
+ },
76
+ "publishConfig": {
77
+ "access": "public",
78
+ "registry": "https://registry.npmjs.org/"
79
+ },
80
+ "scripts": {
81
+ "dev": "rslib build --watch",
82
+ "build": "rslib build"
83
+ },
84
+ "homepage": "https://github.com/BleedingDev/ultramodern.js#readme",
85
+ "bugs": {
86
+ "url": "https://github.com/BleedingDev/ultramodern.js/issues"
87
+ },
88
+ "repository": {
89
+ "type": "git",
90
+ "url": "git+https://github.com/BleedingDev/ultramodern.js.git"
91
+ }
92
+ }
@@ -0,0 +1,4 @@
1
+ import { rslibConfig } from '@modern-js/rslib';
2
+ import { defineConfig } from '@rslib/core';
3
+
4
+ export default defineConfig(rslibConfig);
@@ -0,0 +1,30 @@
1
+ import { ServerStyleSheet } from 'styled-components';
2
+
3
+ export class StreamStyledExtender {
4
+ private sheet: any | null = null;
5
+ private rootElement: React.ReactElement | null = null;
6
+ private forceStream2String = false;
7
+
8
+ init(params: {
9
+ rootElement: React.ReactElement;
10
+ forceStream2String: boolean;
11
+ }) {
12
+ this.sheet = new ServerStyleSheet();
13
+ this.rootElement = this.sheet.collectStyles(params.rootElement);
14
+ this.forceStream2String = params.forceStream2String;
15
+ }
16
+
17
+ modifyRootElement(rootElement: React.ReactElement) {
18
+ return this.rootElement || rootElement;
19
+ }
20
+
21
+ getStyleTags() {
22
+ return this.forceStream2String && this.sheet
23
+ ? this.sheet.getStyleTags()
24
+ : '';
25
+ }
26
+
27
+ processStream(stream: NodeJS.ReadWriteStream) {
28
+ return this.sheet ? this.sheet.interleaveWithNodeStream(stream) : stream;
29
+ }
30
+ }
@@ -0,0 +1,39 @@
1
+ import { ServerStyleSheet } from 'styled-components';
2
+
3
+ export interface Collector {
4
+ collect?: (comopnent: React.ReactElement) => React.ReactElement;
5
+ effect: () => void | Promise<void>;
6
+ }
7
+
8
+ export enum RenderLevel {
9
+ CLIENT_RENDER = 0,
10
+ SERVER_PREFETCH = 1,
11
+ SERVER_RENDER = 2,
12
+ }
13
+
14
+ export type ChunkSet = {
15
+ renderLevel: RenderLevel;
16
+ ssrScripts: string;
17
+ jsChunk: string;
18
+ cssChunk: string;
19
+ };
20
+
21
+ export class StyledCollector implements Collector {
22
+ #sheet: ServerStyleSheet = new ServerStyleSheet();
23
+
24
+ #chunkSet: ChunkSet;
25
+
26
+ constructor(chunkSet: ChunkSet) {
27
+ this.#chunkSet = chunkSet;
28
+ }
29
+
30
+ collect(comopnent: React.ReactElement) {
31
+ return this.#sheet.collectStyles(comopnent);
32
+ }
33
+
34
+ effect() {
35
+ const css = this.#sheet.getStyleTags();
36
+
37
+ this.#chunkSet.cssChunk += css;
38
+ }
39
+ }
package/src/index.ts ADDED
@@ -0,0 +1,47 @@
1
+ import type { AppTools, CliPlugin } from '@modern-js/app-tools';
2
+ import {
3
+ type PluginStyledComponentsOptions,
4
+ pluginStyledComponents,
5
+ } from '@rsbuild/plugin-styled-components';
6
+
7
+ export const styledComponentsPlugin = (
8
+ options?: PluginStyledComponentsOptions,
9
+ ): CliPlugin<AppTools> => ({
10
+ name: '@modern-js/plugin-styled-components',
11
+
12
+ setup(api) {
13
+ api.config(() => {
14
+ const { metaName } = api.getAppContext();
15
+
16
+ return {
17
+ builderPlugins: [
18
+ pluginStyledComponents({
19
+ ...options,
20
+ // https://github.com/styled-components/babel-plugin-styled-components/issues/287
21
+ topLevelImportPaths: [
22
+ `@${metaName}/plugin-styled-components/styled`,
23
+ ],
24
+ }),
25
+ ],
26
+ resolve: {
27
+ alias: {
28
+ 'styled-components': require.resolve('styled-components'),
29
+ },
30
+ },
31
+ };
32
+ });
33
+
34
+ api._internalRuntimePlugins(async ({ entrypoint, plugins }) => {
35
+ const { metaName } = api.getAppContext();
36
+
37
+ plugins.push({
38
+ name: 'styledComponents',
39
+ path: `@${metaName}/plugin-styled-components/runtime`,
40
+ config: {},
41
+ });
42
+ return { entrypoint, plugins };
43
+ });
44
+ },
45
+ });
46
+
47
+ export default styledComponentsPlugin;
package/src/runtime.ts ADDED
@@ -0,0 +1,16 @@
1
+ import type { RuntimePlugin } from '@modern-js/runtime';
2
+ import { StreamStyledExtender } from './extender/stream';
3
+ import { StyledCollector } from './extender/string';
4
+
5
+ export const styledComponentsPlugin = (): RuntimePlugin => ({
6
+ name: '@modern-js/plugin-styled-components',
7
+ setup(api) {
8
+ api.extendStringSSRCollectors(({ chunkSet }) => {
9
+ return new StyledCollector(chunkSet);
10
+ });
11
+
12
+ api.extendStreamSSR(() => {
13
+ return new StreamStyledExtender();
14
+ });
15
+ },
16
+ });
package/src/styled.ts ADDED
@@ -0,0 +1,23 @@
1
+ import * as styledComponents from 'styled-components';
2
+
3
+ type StyledExport = typeof styledComponents.default;
4
+
5
+ /**
6
+ * Safely resolves the styled-components default export.
7
+ * This helper function handles potential interoperability issues between CJS and ESM,
8
+ * where the default export might be nested or directly attached.
9
+ */
10
+ function resolveStyledComponents(): StyledExport {
11
+ const moduleExports = styledComponents as any;
12
+
13
+ if (moduleExports.default?.default !== undefined) {
14
+ return moduleExports.default.default;
15
+ }
16
+
17
+ return moduleExports.default ?? moduleExports;
18
+ }
19
+
20
+ const styled = resolveStyledComponents();
21
+
22
+ export default styled;
23
+ export * from 'styled-components';
package/tsconfig.json ADDED
@@ -0,0 +1,9 @@
1
+ {
2
+ "extends": "@modern-js/tsconfig/base",
3
+ "compilerOptions": {
4
+ "outDir": "./dist",
5
+ "rootDir": "./src",
6
+ "esModuleInterop": true
7
+ },
8
+ "include": ["src"]
9
+ }