tailwind-styled-v4 5.0.11 → 5.0.12

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.
Files changed (107) hide show
  1. package/dist/{analyzeWorkspace-DDOQdzzI.d.ts → analyzeWorkspace-CopJNGmi.d.ts} +2 -0
  2. package/dist/{analyzeWorkspace-BS5O4rhC.d.mts → analyzeWorkspace-DpVPccjz.d.mts} +2 -0
  3. package/dist/analyzer.d.mts +4 -4
  4. package/dist/analyzer.d.ts +4 -4
  5. package/dist/analyzer.js +34 -69
  6. package/dist/analyzer.js.map +1 -1
  7. package/dist/analyzer.mjs +33 -68
  8. package/dist/analyzer.mjs.map +1 -1
  9. package/dist/animate.js +11 -11
  10. package/dist/animate.js.map +1 -1
  11. package/dist/animate.mjs +11 -11
  12. package/dist/animate.mjs.map +1 -1
  13. package/dist/atomic.js +16 -7
  14. package/dist/atomic.js.map +1 -1
  15. package/dist/atomic.mjs +16 -7
  16. package/dist/atomic.mjs.map +1 -1
  17. package/dist/cli.js +262 -190
  18. package/dist/cli.js.map +1 -1
  19. package/dist/cli.mjs +259 -187
  20. package/dist/cli.mjs.map +1 -1
  21. package/dist/compiler.d.mts +2543 -109
  22. package/dist/compiler.d.ts +2543 -109
  23. package/dist/compiler.js +1962 -435
  24. package/dist/compiler.js.map +1 -1
  25. package/dist/compiler.mjs +1816 -382
  26. package/dist/compiler.mjs.map +1 -1
  27. package/dist/devtools.js +17 -4
  28. package/dist/devtools.js.map +1 -1
  29. package/dist/devtools.mjs +17 -4
  30. package/dist/devtools.mjs.map +1 -1
  31. package/dist/engine.d.mts +11 -470
  32. package/dist/engine.d.ts +11 -470
  33. package/dist/engine.js +1442 -417
  34. package/dist/engine.js.map +1 -1
  35. package/dist/engine.mjs +1442 -417
  36. package/dist/engine.mjs.map +1 -1
  37. package/dist/index-BDQw13kn.d.ts +464 -0
  38. package/dist/index-DJv28Uzq.d.mts +464 -0
  39. package/dist/index.browser.mjs +143 -255
  40. package/dist/index.browser.mjs.map +1 -1
  41. package/dist/index.d.mts +23 -39
  42. package/dist/index.d.ts +23 -39
  43. package/dist/index.js +6000 -1463
  44. package/dist/index.js.map +1 -1
  45. package/dist/index.mjs +5995 -1458
  46. package/dist/index.mjs.map +1 -1
  47. package/dist/next.d.mts +44 -1
  48. package/dist/next.d.ts +44 -1
  49. package/dist/next.js +3197 -1128
  50. package/dist/next.js.map +1 -1
  51. package/dist/next.mjs +3196 -1129
  52. package/dist/next.mjs.map +1 -1
  53. package/dist/rspack.d.mts +9 -0
  54. package/dist/rspack.d.ts +9 -0
  55. package/dist/rspack.js +99 -61
  56. package/dist/rspack.js.map +1 -1
  57. package/dist/rspack.mjs +99 -61
  58. package/dist/rspack.mjs.map +1 -1
  59. package/dist/runtime-css.d.mts +8 -0
  60. package/dist/runtime-css.d.ts +8 -0
  61. package/dist/runtime-css.js +23 -7
  62. package/dist/runtime-css.js.map +1 -1
  63. package/dist/runtime-css.mjs +23 -7
  64. package/dist/runtime-css.mjs.map +1 -1
  65. package/dist/scanner.js +16 -37
  66. package/dist/scanner.js.map +1 -1
  67. package/dist/scanner.mjs +15 -36
  68. package/dist/scanner.mjs.map +1 -1
  69. package/dist/shared.d.mts +107 -1
  70. package/dist/shared.d.ts +107 -1
  71. package/dist/shared.js +1627 -376
  72. package/dist/shared.js.map +1 -1
  73. package/dist/shared.mjs +1620 -354
  74. package/dist/shared.mjs.map +1 -1
  75. package/dist/svelte.js +39 -35
  76. package/dist/svelte.js.map +1 -1
  77. package/dist/svelte.mjs +38 -34
  78. package/dist/svelte.mjs.map +1 -1
  79. package/dist/theme.js +85 -76
  80. package/dist/theme.js.map +1 -1
  81. package/dist/theme.mjs +83 -74
  82. package/dist/theme.mjs.map +1 -1
  83. package/dist/turbopackLoader.js +943 -76
  84. package/dist/turbopackLoader.js.map +1 -1
  85. package/dist/turbopackLoader.mjs +943 -76
  86. package/dist/turbopackLoader.mjs.map +1 -1
  87. package/dist/tw.js +262 -190
  88. package/dist/tw.js.map +1 -1
  89. package/dist/tw.mjs +259 -187
  90. package/dist/tw.mjs.map +1 -1
  91. package/dist/vite.js +1336 -296
  92. package/dist/vite.js.map +1 -1
  93. package/dist/vite.mjs +1336 -296
  94. package/dist/vite.mjs.map +1 -1
  95. package/dist/vue.js +39 -35
  96. package/dist/vue.js.map +1 -1
  97. package/dist/vue.mjs +38 -34
  98. package/dist/vue.mjs.map +1 -1
  99. package/dist/webpackLoader.js +140 -34
  100. package/dist/webpackLoader.js.map +1 -1
  101. package/dist/webpackLoader.mjs +140 -34
  102. package/dist/webpackLoader.mjs.map +1 -1
  103. package/native/index.node +0 -0
  104. package/native/tailwind-styled-native.node +0 -0
  105. package/native/tailwind-styled-native.win32-x64-msvc.node +0 -0
  106. package/package.json +9 -4
  107. package/CHANGELOG.md +0 -285
package/dist/rspack.mjs CHANGED
@@ -1,21 +1,23 @@
1
+ import 'crypto';
1
2
  import fs2 from 'fs';
2
3
  import path2 from 'path';
3
- import 'crypto';
4
4
  import 'url';
5
5
  import { createRequire } from 'module';
6
6
  import { z } from 'zod';
7
7
 
8
8
  /* tailwind-styled-v4 v5.0.4 | MIT | https://github.com/dictionar32/tailwind-styled-v4 */
9
+ var __getOwnPropNames = Object.getOwnPropertyNames;
9
10
  var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
10
11
  get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
11
12
  }) : x)(function(x) {
12
13
  if (typeof require !== "undefined") return require.apply(this, arguments);
13
14
  throw Error('Dynamic require of "' + x + '" is not supported');
14
15
  });
16
+ var __esm = (fn, res) => function __init() {
17
+ return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
18
+ };
15
19
 
16
20
  // packages/domain/shared/src/esmHelpers.ts
17
- var isBrowser = typeof window !== "undefined" || typeof document !== "undefined";
18
- var nodeModuleRef = null;
19
21
  function getNodeModuleRef() {
20
22
  if (isBrowser) return null;
21
23
  if (nodeModuleRef !== null) return nodeModuleRef;
@@ -28,8 +30,6 @@ function getNodeModuleRef() {
28
30
  return null;
29
31
  }
30
32
  }
31
- var _nodePath = null;
32
- var _nodeUrl = null;
33
33
  function getNodePath() {
34
34
  if (isBrowser) throw new Error("node:path not available in browser");
35
35
  const nodeRequire = getNodeModuleRef();
@@ -50,67 +50,86 @@ function getDirname(importMetaUrl) {
50
50
  const nodeUrl = getNodeUrl();
51
51
  return nodePath.dirname(nodeUrl.fileURLToPath(importMetaUrl));
52
52
  }
53
-
54
- // packages/domain/shared/src/index.ts
53
+ var isBrowser, nodeModuleRef, _nodePath, _nodeUrl;
54
+ var init_esmHelpers = __esm({
55
+ "packages/domain/shared/src/esmHelpers.ts"() {
56
+ isBrowser = typeof window !== "undefined" || typeof document !== "undefined";
57
+ nodeModuleRef = null;
58
+ _nodePath = null;
59
+ _nodeUrl = null;
60
+ }
61
+ });
55
62
  function formatIssuePath(path3) {
56
63
  if (!path3 || path3.length === 0) return "(root)";
57
64
  return path3.map(
58
65
  (segment) => typeof segment === "symbol" ? segment.description ?? segment.toString() : String(segment)
59
66
  ).join(".");
60
67
  }
61
- var TwError = class _TwError extends Error {
62
- /** @deprecated Gunakan source */
63
- domain;
64
- source;
65
- code;
66
- originalCause;
67
- constructor(domainOrSource, code, message, cause) {
68
- super(message);
69
- this.name = "TwError";
70
- this.domain = domainOrSource;
71
- this.source = domainOrSource;
72
- this.code = code;
73
- this.originalCause = cause;
74
- if (Error.captureStackTrace) Error.captureStackTrace(this, _TwError);
75
- }
76
- static fromIo(code, message) {
77
- return new _TwError("io", code, message);
78
- }
79
- static fromCompile(code, message) {
80
- return new _TwError("compile", code, message);
81
- }
82
- static fromRust(err) {
83
- if (err instanceof _TwError) return err;
84
- if (err instanceof Error) return new _TwError("rust", "RUST_ERROR", err.message, err);
85
- if (err && typeof err === "object") {
86
- const e = err;
87
- return new _TwError("rust", e.code ?? "RUST_ERROR", e.message ?? String(err), err);
88
- }
89
- return new _TwError("rust", "RUST_ERROR", String(err), err);
90
- }
91
- /** Buat TwError dari ZodError dukung shape Zod v3 (`errors`) dan v4 (`issues`). */
92
- static fromZod(err) {
93
- const first = err.issues?.[0] ?? err.errors?.[0];
94
- const path3 = formatIssuePath(first?.path);
95
- const message = first ? `${path3}: ${first.message}` : "Schema validation failed";
96
- return new _TwError("validation", "SCHEMA_VALIDATION_FAILED", message, err);
97
- }
98
- static wrap(source, code, err) {
99
- if (err instanceof _TwError) return err;
100
- if (err instanceof Error) return new _TwError(source, code, err.message, err);
101
- return new _TwError(source, code, String(err), err);
102
- }
103
- toString() {
104
- return `TwError [${this.source}:${this.code}] ${this.message}`;
105
- }
106
- toJSON() {
107
- return { name: this.name, source: this.source, code: this.code, message: this.message };
108
- }
109
- toCliMessage() {
110
- return `[${this.source.toUpperCase()}:${this.code}] ${this.message}`;
68
+ var TwError;
69
+ var init_src = __esm({
70
+ "packages/domain/shared/src/index.ts"() {
71
+ init_esmHelpers();
72
+ TwError = class _TwError extends Error {
73
+ /** @deprecated Gunakan source */
74
+ domain;
75
+ source;
76
+ code;
77
+ originalCause;
78
+ constructor(domainOrSource, code, message, cause) {
79
+ super(message);
80
+ this.name = "TwError";
81
+ this.domain = domainOrSource;
82
+ this.source = domainOrSource;
83
+ this.code = code;
84
+ this.originalCause = cause;
85
+ if (Error.captureStackTrace) Error.captureStackTrace(this, _TwError);
86
+ }
87
+ static fromIo(code, message) {
88
+ return new _TwError("io", code, message);
89
+ }
90
+ static fromCompile(code, message) {
91
+ return new _TwError("compile", code, message);
92
+ }
93
+ static fromRust(err) {
94
+ if (err instanceof _TwError) return err;
95
+ if (err instanceof Error) return new _TwError("rust", "RUST_ERROR", err.message, err);
96
+ if (err && typeof err === "object") {
97
+ const e = err;
98
+ return new _TwError("rust", e.code ?? "RUST_ERROR", e.message ?? String(err), err);
99
+ }
100
+ return new _TwError("rust", "RUST_ERROR", String(err), err);
101
+ }
102
+ /** Buat TwError dari ZodError dukung shape Zod v3 (`errors`) dan v4 (`issues`). */
103
+ static fromZod(err) {
104
+ const first = err.issues?.[0] ?? err.errors?.[0];
105
+ const path3 = formatIssuePath(first?.path);
106
+ const message = first ? `${path3}: ${first.message}` : "Schema validation failed";
107
+ return new _TwError("validation", "SCHEMA_VALIDATION_FAILED", message, err);
108
+ }
109
+ static wrap(source, code, err) {
110
+ if (err instanceof _TwError) return err;
111
+ if (err instanceof Error) return new _TwError(source, code, err.message, err);
112
+ return new _TwError(source, code, String(err), err);
113
+ }
114
+ toString() {
115
+ return `TwError [${this.source}:${this.code}] ${this.message}`;
116
+ }
117
+ toJSON() {
118
+ return { name: this.name, source: this.source, code: this.code, message: this.message };
119
+ }
120
+ toCliMessage() {
121
+ return `[${this.source.toUpperCase()}:${this.code}] ${this.message}`;
122
+ }
123
+ };
124
+ createRequire(import.meta.url);
111
125
  }
112
- };
113
- createRequire(import.meta.url);
126
+ });
127
+
128
+ // packages/presentation/rspack/src/index.ts
129
+ init_src();
130
+
131
+ // packages/presentation/rspack/src/schemas.ts
132
+ init_src();
114
133
  var formatIssuePath2 = (path3) => path3.length > 0 ? path3.map(
115
134
  (segment) => typeof segment === "symbol" ? segment.description ?? segment.toString() : String(segment)
116
135
  ).join(".") : "<root>";
@@ -134,7 +153,9 @@ var RspackPluginOptionsSchema = z.object({
134
153
  exclude: z.instanceof(RegExp).optional(),
135
154
  addDataAttr: z.boolean().optional(),
136
155
  analyze: z.boolean().optional(),
137
- cssEntry: z.string().optional()
156
+ cssEntry: z.string().optional(),
157
+ /** Path ke safelist CSS file. Default: <cwd>/__tw_safelist.css */
158
+ safelistPath: z.string().optional()
138
159
  });
139
160
  var parseRspackPluginOptions = (options) => parseWithSchema(RspackPluginOptionsSchema, options ?? {}, "rspack plugin options are invalid");
140
161
 
@@ -170,6 +191,22 @@ var TailwindStyledRspackPlugin = class {
170
191
  (rule2) => typeof rule2 === "object" && rule2 !== null && rule2._tailwindStyledRspackMarker === true
171
192
  );
172
193
  if (alreadyRegistered) return;
194
+ const safelistPath = this.opts.safelistPath ?? path2.join(process.cwd(), "__tw_safelist.css");
195
+ const stateStaticPath = path2.join(path2.dirname(safelistPath), "_tw-state-static.css");
196
+ if (!fs2.existsSync(stateStaticPath)) {
197
+ try {
198
+ fs2.mkdirSync(path2.dirname(stateStaticPath), { recursive: true });
199
+ fs2.writeFileSync(
200
+ stateStaticPath,
201
+ `/* _tw-state-static.css \u2014 Auto-generated by tailwind-styled-v4. DO NOT EDIT.
202
+ * Import di CSS entry: @import "./_tw-state-static.css";
203
+ */
204
+ `,
205
+ "utf-8"
206
+ );
207
+ } catch {
208
+ }
209
+ }
173
210
  const rule = {
174
211
  _tailwindStyledRspackMarker: true,
175
212
  test: this.opts.include ?? /\.[jt]sx?$/,
@@ -180,7 +217,8 @@ var TailwindStyledRspackPlugin = class {
180
217
  options: {
181
218
  mode: "zero-runtime",
182
219
  addDataAttr: this.opts.addDataAttr ?? isDev,
183
- preserveImports: true
220
+ preserveImports: true,
221
+ safelistPath
184
222
  }
185
223
  }
186
224
  ]
@@ -1 +1 @@
1
- {"version":3,"sources":["../packages/domain/shared/src/esmHelpers.ts","../packages/domain/shared/src/index.ts","../packages/presentation/rspack/src/schemas.ts","../packages/presentation/rspack/src/index.ts"],"names":["path","formatIssuePath","getDirname","fs","rule"],"mappings":"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","file":"rspack.mjs","sourcesContent":["/**\r\n * ESM-safe runtime helpers untuk monorepo.\r\n *\r\n * Menggantikan pola fragile seperti:\r\n * - `createRequire(import.meta.url)` → gunakan `createEsmRequire()`\r\n * - `__dirname` → gunakan `getDirname(import.meta.url)`\r\n * - `__filename` → gunakan `getFilename(import.meta.url)`\r\n *\r\n * Semua helper ini bekerja di ESM dan CJS.\r\n *\r\n * @module @tailwind-styled/shared/esmHelpers\r\n */\r\n\r\nconst isBrowser = typeof window !== \"undefined\" || typeof document !== \"undefined\"\r\n\r\n// Safe check for require availability - works in both CJS and ESM\r\nlet nodeModuleRef: any = null\r\nfunction getNodeModuleRef() {\r\n if (isBrowser) return null\r\n if (nodeModuleRef !== null) return nodeModuleRef\r\n try {\r\n // Test if require actually works\r\n const test = typeof require === 'function' ? require('node:module') : null\r\n nodeModuleRef = test\r\n return test\r\n } catch {\r\n nodeModuleRef = null\r\n return null\r\n }\r\n}\r\n\r\nlet _nodePath: any = null\r\nlet _nodeUrl: any = null\r\nlet _nodeFs: any = null\r\nlet _nodeCrypto: any = null\r\nlet _nodeOs: any = null\r\n\r\nfunction getNodePath() {\r\n if (isBrowser) throw new Error(\"node:path not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodePath) _nodePath = nodeRequire.createRequire(import.meta.url)(\"node:path\")\r\n return _nodePath!\r\n}\r\nfunction getNodeUrl() {\r\n if (isBrowser) throw new Error(\"node:url not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeUrl) _nodeUrl = nodeRequire.createRequire(import.meta.url)(\"node:url\")\r\n return _nodeUrl!\r\n}\r\nfunction getNodeFs() {\r\n if (isBrowser) throw new Error(\"node:fs not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeFs) _nodeFs = nodeRequire.createRequire(import.meta.url)(\"node:fs\")\r\n return _nodeFs!\r\n}\r\nfunction getNodeCrypto() {\r\n if (isBrowser) throw new Error(\"node:crypto not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeCrypto) _nodeCrypto = nodeRequire.createRequire(import.meta.url)(\"node:crypto\")\r\n return _nodeCrypto!\r\n}\r\nfunction getNodeOs() {\r\n if (isBrowser) throw new Error(\"node:os not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeOs) _nodeOs = nodeRequire.createRequire(import.meta.url)(\"node:os\")\r\n return _nodeOs!\r\n}\r\n\r\n/**\r\n * Buat `require()` function yang relative terhadap sebuah ESM module.\r\n *\r\n * @example\r\n * // Ganti: createRequire(import.meta.url)(\"some-pkg\")\r\n * const req = createEsmRequire(import.meta.url)\r\n * const mod = req(\"some-pkg\")\r\n */\r\nexport function createEsmRequire(importMetaUrl: string): NodeRequire {\r\n if (isBrowser) throw new Error(\"require not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n return nodeRequire.createRequire(importMetaUrl)\r\n}\r\n\r\n/**\r\n * Dapat `__dirname` dari `import.meta.url`.\r\n *\r\n * @example\r\n * // Ganti: const __dirname = ...\r\n * const dir = getDirname(import.meta.url)\r\n */\r\nexport function getDirname(importMetaUrl: string): string {\r\n if (isBrowser) return \"\"\r\n const nodePath = getNodePath()\r\n const nodeUrl = getNodeUrl()\r\n return nodePath.dirname(nodeUrl.fileURLToPath(importMetaUrl))\r\n}\r\n\r\n/**\r\n * Dapat `__filename` dari `import.meta.url`.\r\n */\r\nexport function getFilename(importMetaUrl: string): string {\r\n if (isBrowser) return \"\"\r\n return getNodeUrl().fileURLToPath(importMetaUrl)\r\n}\r\n\r\n/**\r\n * Resolve path dari root monorepo (bukan CWD).\r\n * Berguna untuk scripts dan tools yang dipanggil dari lokasi berbeda.\r\n *\r\n * @example\r\n * const root = resolveFromRoot(\"packages/domain/shared/src\")\r\n */\r\nexport function resolveFromRoot(...segments: string[]): string {\r\n if (isBrowser) return segments.join(\"/\")\r\n\r\n const nodePath = getNodePath()\r\n const nodeFs = getNodeFs()\r\n \r\n let dir = getDirname(import.meta.url)\r\n for (let i = 0; i < 10; i++) {\r\n const pkgPath = nodePath.join(dir, \"package.json\")\r\n try {\r\n const pkg = JSON.parse(nodeFs.readFileSync(pkgPath, \"utf-8\"))\r\n if (pkg.workspaces) {\r\n return nodePath.resolve(dir, ...segments)\r\n }\r\n } catch { /* intentionally silent */ }\r\n dir = nodePath.dirname(dir)\r\n }\r\n return nodePath.resolve(process.cwd(), ...segments)\r\n}\r\n\r\n/**\r\n * Require sebuah module dengan fallback ke null jika tidak tersedia.\r\n * Berguna untuk optional dependencies.\r\n *\r\n * @example\r\n * const oxc = tryRequire(\"oxc-parser\", import.meta.url)\r\n * if (!oxc) console.warn(\"oxc-parser not installed\")\r\n */\r\nexport function tryRequire<T = unknown>(\r\n moduleName: string,\r\n importMetaUrl: string\r\n): T | null {\r\n if (isBrowser) return null\r\n try {\r\n return createEsmRequire(importMetaUrl)(moduleName) as T\r\n } catch { /* intentionally silent — optional dep */ }\r\n return null\r\n}\r\n\r\n/**\r\n * Resolve .node binary path yang cross-platform dan ESM-safe.\r\n * Menggantikan pola `path.resolve(__dirname, \"../native.node\")`.\r\n */\r\nexport function resolveNativeNodePath(\r\n importMetaUrl: string,\r\n ...relativeSegments: string[]\r\n): string {\r\n if (isBrowser) return relativeSegments.join(\"/\")\r\n return getNodePath().resolve(getDirname(importMetaUrl), ...relativeSegments)\r\n}\r\n","import { createHash } from \"node:crypto\"\r\nimport fs from \"node:fs\"\r\nimport path from \"node:path\"\r\nimport { fileURLToPath } from \"node:url\"\r\nimport { createRequire } from \"node:module\"\r\n\r\n// Native-only: Node.js is always available. No browser fallback.\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Types\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type TokenMap = Record<string, string>\r\n\r\nexport type VariantValue = string | number | boolean | undefined\r\n\r\nexport type VariantProps = Record<string, VariantValue>\r\n\r\nexport type HtmlTagName = keyof HTMLElementTagNameMap\r\n\r\nexport type CompoundCondition = Record<string, string | number | boolean>\r\n\r\nexport type VariantMatrix = Record<string, Array<string | number | boolean>>\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Logging\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport interface Logger {\r\n warn(...args: unknown[]): void\r\n debug(...args: unknown[]): void\r\n error(...args: unknown[]): void\r\n log(...args: unknown[]): void\r\n}\r\n\r\nexport function createLogger(namespace: string): Logger {\r\n const prefix = `[${namespace}]`\r\n return {\r\n warn(...args: unknown[]) {\r\n process.stderr.write(`${prefix} ${args.map(a => typeof a === \"string\" ? a : String(a)).join(\" \")}\\n`)\r\n },\r\n debug(...args: unknown[]) {\r\n process.stderr.write(`${prefix} ${args.map(a => typeof a === \"string\" ? a : String(a)).join(\" \")}\\n`)\r\n },\r\n error(...args: unknown[]) {\r\n process.stderr.write(`${prefix} ${args.map(a => typeof a === \"string\" ? a : String(a)).join(\" \")}\\n`)\r\n },\r\n log(...args: unknown[]) {\r\n process.stderr.write(`${prefix} ${args.map(a => typeof a === \"string\" ? a : String(a)).join(\" \")}\\n`)\r\n },\r\n }\r\n}\r\n\r\nexport function createDebugLogger(namespace: string, label?: string): (msg: string) => void {\r\n const prefix = label ? `[${namespace}:${label}]` : `[${namespace}]`\r\n return (msg: string) => {\r\n if (process.env.DEBUG?.includes(namespace) || process.env.TW_DEBUG) {\r\n console.debug(prefix, msg)\r\n }\r\n }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Error handling\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type ErrorSource = \"rust\" | \"validation\" | \"compile\" | \"io\" | \"config\" | \"unknown\"\r\n\r\ntype ZodLikeIssue = {\r\n path?: readonly PropertyKey[]\r\n message?: string\r\n}\r\n\r\nfunction formatIssuePath(path?: readonly PropertyKey[]): string {\r\n if (!path || path.length === 0) return \"(root)\"\r\n return path\r\n .map((segment) =>\r\n typeof segment === \"symbol\" ? segment.description ?? segment.toString() : String(segment)\r\n )\r\n .join(\".\")\r\n}\r\n\r\nexport class TwError extends Error {\r\n /** @deprecated Gunakan source */\r\n public readonly domain: string\r\n public readonly source: ErrorSource\r\n public readonly code: string\r\n public readonly originalCause?: unknown\r\n\r\n constructor(domainOrSource: string, code: string, message: string, cause?: unknown) {\r\n super(message)\r\n this.name = \"TwError\"\r\n this.domain = domainOrSource\r\n this.source = domainOrSource as ErrorSource\r\n this.code = code\r\n this.originalCause = cause\r\n if (Error.captureStackTrace) Error.captureStackTrace(this, TwError)\r\n }\r\n\r\n static fromIo(code: string, message: string): TwError {\r\n return new TwError(\"io\", code, message)\r\n }\r\n\r\n static fromCompile(code: string, message: string): TwError {\r\n return new TwError(\"compile\", code, message)\r\n }\r\n\r\n static fromRust(err: { code?: string; message?: string } | Error | unknown): TwError {\r\n if (err instanceof TwError) return err\r\n if (err instanceof Error) return new TwError(\"rust\", \"RUST_ERROR\", err.message, err)\r\n if (err && typeof err === \"object\") {\r\n const e = err as { code?: string; message?: string }\r\n return new TwError(\"rust\", e.code ?? \"RUST_ERROR\", e.message ?? String(err), err)\r\n }\r\n return new TwError(\"rust\", \"RUST_ERROR\", String(err), err)\r\n }\r\n\r\n /** Buat TwError dari ZodError — dukung shape Zod v3 (`errors`) dan v4 (`issues`). */\r\n static fromZod(err: { issues?: ZodLikeIssue[]; errors?: ZodLikeIssue[] }): TwError {\r\n const first = err.issues?.[0] ?? err.errors?.[0]\r\n const path = formatIssuePath(first?.path)\r\n const message = first ? `${path}: ${first.message}` : \"Schema validation failed\"\r\n return new TwError(\"validation\", \"SCHEMA_VALIDATION_FAILED\", message, err)\r\n }\r\n\r\n static wrap(source: string, code: string, err: unknown): TwError {\r\n if (err instanceof TwError) return err\r\n if (err instanceof Error) return new TwError(source, code, err.message, err)\r\n return new TwError(source, code, String(err), err)\r\n }\r\n\r\n override toString(): string {\r\n return `TwError [${this.source}:${this.code}] ${this.message}`\r\n }\r\n\r\n toJSON(): { name: string; source: string; code: string; message: string } {\r\n return { name: this.name, source: this.source, code: this.code, message: this.message }\r\n }\r\n\r\n toCliMessage(): string {\r\n return `[${this.source.toUpperCase()}:${this.code}] ${this.message}`\r\n }\r\n}\r\n\r\nexport function wrapUnknownError(domain: string, code: string, error: unknown): TwError {\r\n return TwError.wrap(domain, code, error)\r\n}\r\n\r\nexport function isTwError(err: unknown): err is TwError {\r\n return err instanceof TwError\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Native binding resolution\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport interface LoadNativeBindingOptions<T> {\r\n runtimeDir: string\r\n candidates: string[]\r\n isValid: (module: unknown) => module is T\r\n invalidExportMessage: string\r\n}\r\n\r\nexport interface LoadNativeBindingResult<T> {\r\n binding: T | null\r\n loadErrors: Array<{ path: string; message: string }>\r\n loadedPath?: string\r\n}\r\n\r\nexport function loadNativeBinding<T>(options: LoadNativeBindingOptions<T>): LoadNativeBindingResult<T> {\r\n const { runtimeDir, candidates, isValid } = options\r\n const loadErrors: Array<{ path: string; message: string }> = []\r\n\r\n for (const candidate of candidates) {\r\n const candidatePath = path.resolve(runtimeDir, candidate)\r\n try {\r\n if (!fs.existsSync(candidatePath) && !fs.existsSync(candidatePath + \".node\")) {\r\n continue\r\n }\r\n const mod = requireNativeModule(candidatePath)\r\n if (mod && isValid(mod)) {\r\n return { binding: mod, loadErrors, loadedPath: candidatePath }\r\n }\r\n loadErrors.push({ path: candidatePath, message: options.invalidExportMessage })\r\n } catch (e) {\r\n loadErrors.push({ path: candidatePath, message: e instanceof Error ? e.message : String(e) })\r\n }\r\n }\r\n\r\n return { binding: null, loadErrors }\r\n}\r\n\r\nconst _require = createRequire(import.meta.url)\r\n\r\nfunction requireNativeModule(p: string): unknown {\r\n return _require(p)\r\n}\r\n\r\nexport interface ResolveCandidatesOptions {\r\n runtimeDir?: string\r\n envVarNames?: string[]\r\n includeDefaultCandidates?: boolean\r\n enforceNodeExtensionForEnvPath?: boolean\r\n /** @deprecated — ignored, kept for backward compat */\r\n packageName?: string\r\n}\r\n\r\nexport function resolveNativeBindingCandidates(options: ResolveCandidatesOptions): string[] {\r\n const {\r\n envVarNames = [\"TW_NATIVE_PATH\", \"TWS_NATIVE_PATH\"],\r\n includeDefaultCandidates = true,\r\n enforceNodeExtensionForEnvPath = false,\r\n } = options\r\n // Default ke cwd kalau runtimeDir tidak disediakan\r\n const runtimeDir = options.runtimeDir || process.cwd()\r\n const candidates: string[] = []\r\n\r\n for (const envVar of envVarNames) {\r\n const envPath = process.env[envVar]\r\n if (envPath) {\r\n candidates.push(enforceNodeExtensionForEnvPath && !envPath.endsWith(\".node\") ? envPath + \".node\" : envPath)\r\n }\r\n }\r\n\r\n if (!includeDefaultCandidates) return candidates\r\n\r\n if (fs.existsSync(runtimeDir)) {\r\n try {\r\n for (const entry of fs.readdirSync(runtimeDir)) {\r\n if (entry.endsWith(\".node\")) candidates.push(entry)\r\n }\r\n } catch { /* ignore read errors */ }\r\n }\r\n\r\n const BINARY_NAMES = [\"tailwind-styled-native\", \"tailwind_styled_parser\"]\r\n const napiPlatform = process.platform === \"linux\" && process.arch === \"x64\" ? \"linux-x64-gnu\"\r\n : process.platform === \"linux\" && process.arch === \"arm64\" ? \"linux-arm64-gnu\"\r\n : `${process.platform}-${process.arch}`\r\n\r\n for (const bin of BINARY_NAMES) {\r\n candidates.push(path.resolve(runtimeDir, `${bin}.node`))\r\n candidates.push(path.resolve(runtimeDir, `${bin}.${napiPlatform}.node`))\r\n // 1 level: dist/ → package-root/native/ (published npm package)\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"native\", `${bin}.node`))\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"native\", `${bin}.${napiPlatform}.node`))\r\n // cwd fallback (user project root)\r\n candidates.push(path.resolve(process.cwd(), \"native\", `${bin}.node`))\r\n candidates.push(path.resolve(process.cwd(), \"native\", `${bin}.${napiPlatform}.node`))\r\n // 4 level: dist/ → package/ → domain/ → packages/ → repo-root/ (monorepo dev)\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"..\", \"..\", \"..\", \"native\", `${bin}.node`))\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"..\", \"..\", \"..\", \"native\", `${bin}.${napiPlatform}.node`))\r\n // 3 level fallback\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"..\", \"..\", \"native\", `${bin}.node`))\r\n }\r\n\r\n return Array.from(new Set(candidates))\r\n}\r\n\r\nexport function resolveRuntimeDir(dir: string | undefined, importMetaUrl: string): string {\r\n if (dir) return path.resolve(dir)\r\n try {\r\n return path.dirname(fileURLToPath(importMetaUrl))\r\n } catch {\r\n return process.cwd()\r\n }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Hashing\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport function hashContent(content: string, algorithm: string = \"md5\", length?: number): string {\r\n const hash = createHash(algorithm).update(content).digest(\"hex\")\r\n return length ? hash.slice(0, length) : hash\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Error formatting\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport function formatErrorMessage(error: unknown): string {\r\n if (error instanceof TwError) return error.toString()\r\n if (error instanceof Error) return error.message\r\n return String(error)\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// LRU Cache\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport class LRUCache<K, V> {\r\n private capacity: number\r\n private cache: Map<K, V>\r\n\r\n constructor(capacity: number) {\r\n this.capacity = capacity\r\n this.cache = new Map()\r\n }\r\n\r\n get(key: K): V | undefined {\r\n if (!this.cache.has(key)) return undefined\r\n const value = this.cache.get(key)!\r\n this.cache.delete(key)\r\n this.cache.set(key, value)\r\n return value\r\n }\r\n\r\n set(key: K, value: V): void {\r\n if (this.cache.has(key)) {\r\n this.cache.delete(key)\r\n } else if (this.cache.size >= this.capacity) {\r\n const firstKey = this.cache.keys().next().value\r\n if (firstKey !== undefined) {\r\n this.cache.delete(firstKey)\r\n }\r\n }\r\n this.cache.set(key, value)\r\n }\r\n\r\n delete(key: K): boolean {\r\n return this.cache.delete(key)\r\n }\r\n\r\n has(key: K): boolean {\r\n return this.cache.has(key)\r\n }\r\n\r\n clear(): void {\r\n this.cache.clear()\r\n }\r\n\r\n entries(): IterableIterator<[K, V]> {\r\n return this.cache.entries()\r\n }\r\n\r\n get size(): number {\r\n return this.cache.size\r\n }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Trace Utilities\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type { TraceSnapshot, TraceSummary } from \"./trace\"\r\nexport {\r\n getHealthColor,\r\n getModeColor,\r\n formatMemory,\r\n formatDuration,\r\n calculateHealth,\r\n getBuildTimeColor,\r\n getMemoryColor,\r\n createTraceSnapshot,\r\n getPipelinePercentages,\r\n} from \"./trace\"\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Performance Telemetry\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\n\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Error Codes\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type { ErrorCode } from \"./error-codes\"\r\nexport { ERROR_CODES, getSuggestion, formatErrorCode } from \"./error-codes\"\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Tailwind Compatibility\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type { TailwindInfo } from \"./compatibility\"\r\nexport { detectTailwind, assertTailwindV4, getTailwindVersion, isTailwindV4 } from \"./compatibility\"\r\n\r\n// ── Native binding schemas (Zod boundary validation)\r\nexport {\r\n NativeScanFileSchema, NativeScanResultSchema,\r\n NativeAnalyzerReportSchema, NativeTransformResultSchema,\r\n NativeCssCompileResultSchema, NativeWatchResultSchema,\r\n NativeCacheEntrySchema, NativeCacheReadResultSchema,\r\n safeParseNative, parseNative,\r\n} from './native-schemas'\r\n\r\n// ── ESM-safe runtime helpers ──────────────────────────────────────────────\r\nexport {\r\n createEsmRequire,\r\n getDirname,\r\n getFilename,\r\n resolveFromRoot,\r\n tryRequire,\r\n resolveNativeNodePath,\r\n} from \"./esmHelpers\"\r\n\r\n// ── Performance telemetry ────────────────────────────────────────────────────\r\nexport {\r\n TelemetryCollector,\r\n getGlobalTelemetry,\r\n resetGlobalTelemetry,\r\n createBuildTimer,\r\n type BuildTelemetry,\r\n type TelemetrySummary,\r\n type BuildPhases,\r\n} from \"./telemetry\"\r\n\r\n// ── Config/JSON schema validation ─────────────────────────────────────────────\r\nexport {\r\n ScanCacheSchema,\r\n ScanCacheClassEntrySchema,\r\n TailwindConfigSchema,\r\n RegistryPluginEntrySchema,\r\n RegistryFileSchema,\r\n PackageJsonSchema,\r\n parseJsonWithSchema,\r\n parseJsonFileWithSchema,\r\n type ScanCache,\r\n type ScanCacheClassEntry,\r\n type TailwindConfig,\r\n type RegistryPluginEntry,\r\n type RegistryFile,\r\n type PackageJson,\r\n} from \"./configSchemas\"\r\n\r\n// ── Worker/bootstrap path resolution ─────────────────────────────────────────\r\nexport {\r\n resolveWorkerPath,\r\n resolveLoaderPath,\r\n type WorkerPathOptions,\r\n type WorkerPathResult,\r\n} from \"./workerResolver\"\r\n\r\n// ── Codegen helpers ───────────────────────────────────────────────────────────\r\nexport {\r\n generateComponentCode,\r\n generateStorybookStory,\r\n generateClassRenameCodemod,\r\n generateBarrelFile,\r\n type ComponentCodegenOptions,\r\n} from \"./codegen\"\r\n\r\n// ── Native binary resolution (QA #1) ─────────────────────────────────────────\r\nexport {\r\n resolveNativeBinary,\r\n formatNativeNotFoundError,\r\n type NativeResolutionResult,\r\n} from \"./native-resolution\"\r\n\r\n// ── Shared observability contract ────────────────────────────────────────────\r\nexport {\r\n createObservabilityClient,\r\n type ClassInspection,\r\n type ClassProperty,\r\n type ClassUsageLocation,\r\n type BuildTrace,\r\n type BuildPhaseTrace,\r\n type DashboardMetrics,\r\n type DashboardSummary,\r\n type ObservabilityClient,\r\n} from \"./observability\"","import { z } from \"zod\"\r\nimport { TwError } from \"@tailwind-styled/shared\"\r\n\r\nconst formatIssuePath = (path: readonly PropertyKey[]): string =>\r\n path.length > 0\r\n ? path\r\n .map((segment) =>\r\n typeof segment === \"symbol\" ? segment.description ?? segment.toString() : String(segment)\r\n )\r\n .join(\".\")\r\n : \"<root>\"\r\n\r\nconst formatIssues = (error: z.ZodError): string =>\r\n error.issues\r\n .map((issue) => {\r\n const p = formatIssuePath(issue.path)\r\n return `${p}: ${issue.message}`\r\n })\r\n .join(\"; \")\r\n\r\nconst parseWithSchema = <T>(schema: z.ZodType<T>, data: unknown, label: string): T => {\r\n const parsed = schema.safeParse(data)\r\n if (parsed.success) return parsed.data\r\n const details = formatIssues(parsed.error)\r\n throw new TwError(\r\n \"validation\",\r\n \"SCHEMA_VALIDATION_FAILED\",\r\n details ? `${label}: ${details}` : label,\r\n parsed.error\r\n )\r\n}\r\n\r\nexport const RspackPluginOptionsSchema = z.object({\r\n include: z.instanceof(RegExp).optional(),\r\n exclude: z.instanceof(RegExp).optional(),\r\n addDataAttr: z.boolean().optional(),\r\n analyze: z.boolean().optional(),\r\n cssEntry: z.string().optional(),\r\n})\r\n\r\nexport type RspackPluginOptionsInput = z.infer<typeof RspackPluginOptionsSchema>\r\n\r\nexport const parseRspackPluginOptions = (options: unknown) =>\r\n parseWithSchema(RspackPluginOptionsSchema, options ?? {}, \"rspack plugin options are invalid\")\r\n","/**\r\n * tailwind-styled-v4 - Rspack Plugin v5 (stable)\r\n *\r\n * Usage:\r\n * import { tailwindStyledRspackPlugin } from \"@tailwind-styled/rspack\"\r\n *\r\n * export default defineConfig({\r\n * plugins: [tailwindStyledRspackPlugin()],\r\n * })\r\n *\r\n * v5:\r\n * - Simplified API\r\n * - Mode always zero-runtime\r\n */\r\n\r\nimport fs from \"node:fs\"\r\nimport path from \"node:path\"\r\nimport { getDirname as getEsmDirname } from \"@tailwind-styled/shared\"\r\n\r\nimport { parseRspackPluginOptions } from \"./schemas\"\r\n\r\nfunction getDirname(): string {\r\n if (typeof __dirname !== \"undefined\") {\r\n return __dirname\r\n }\r\n if (typeof import.meta !== \"undefined\" && import.meta.url) {\r\n return getEsmDirname(import.meta.url)\r\n }\r\n return process.cwd()\r\n}\r\n\r\nfunction resolveLoaderPath(basename: string): string {\r\n const runtimeDir = getDirname()\r\n const preferredExtensions =\r\n typeof __dirname !== \"undefined\" && __dirname.length > 0 ? [\".cjs\", \".js\"] : [\".js\", \".cjs\"]\r\n\r\n for (const ext of preferredExtensions) {\r\n const candidate = path.resolve(runtimeDir, `${basename}${ext}`)\r\n if (fs.existsSync(candidate)) return candidate\r\n }\r\n\r\n return path.resolve(runtimeDir, `${basename}.js`)\r\n}\r\n\r\ninterface RspackRule {\r\n _tailwindStyledRspackMarker?: boolean\r\n test?: RegExp\r\n exclude?: RegExp\r\n use?: Array<{\r\n loader: string\r\n options: {\r\n mode: \"zero-runtime\"\r\n addDataAttr: boolean\r\n preserveImports: boolean\r\n }\r\n }>\r\n}\r\n\r\ninterface RspackCompiler {\r\n options: {\r\n mode?: string\r\n module?: {\r\n rules?: RspackRule[]\r\n }\r\n }\r\n}\r\n\r\nexport interface RspackPluginOptions {\r\n /** File patterns to include. Default: /\\.[jt]sx?$/ */\r\n include?: RegExp\r\n /** File patterns to exclude. Default: /node_modules/ */\r\n exclude?: RegExp\r\n /** Add data-tw debug attributes in dev. Default: true in dev */\r\n addDataAttr?: boolean\r\n /** Enable analyzer. Default: false */\r\n analyze?: boolean\r\n}\r\n\r\nexport class TailwindStyledRspackPlugin {\r\n private opts: RspackPluginOptions\r\n\r\n constructor(opts: RspackPluginOptions = {}) {\r\n this.opts = parseRspackPluginOptions(opts)\r\n }\r\n\r\n apply(compiler: RspackCompiler): void {\r\n const isDev = compiler.options.mode !== \"production\"\r\n const loaderPath = resolveLoaderPath(\"loader\")\r\n const existing = compiler.options.module?.rules ?? []\r\n const alreadyRegistered = existing.some(\r\n (rule) =>\r\n typeof rule === \"object\" && rule !== null && rule._tailwindStyledRspackMarker === true\r\n )\r\n\r\n if (alreadyRegistered) return\r\n\r\n const rule: RspackRule = {\r\n _tailwindStyledRspackMarker: true,\r\n test: this.opts.include ?? /\\.[jt]sx?$/,\r\n exclude: this.opts.exclude ?? /node_modules/,\r\n use: [\r\n {\r\n loader: loaderPath,\r\n options: {\r\n mode: \"zero-runtime\",\r\n addDataAttr: this.opts.addDataAttr ?? isDev,\r\n preserveImports: true,\r\n },\r\n },\r\n ],\r\n }\r\n\r\n compiler.options.module = {\r\n ...(compiler.options.module ?? {}),\r\n rules: [rule, ...existing],\r\n }\r\n }\r\n}\r\n\r\nexport function tailwindStyledRspackPlugin(\r\n opts: RspackPluginOptions = {}\r\n): TailwindStyledRspackPlugin {\r\n return new TailwindStyledRspackPlugin(opts)\r\n}\r\n\r\nexport default tailwindStyledRspackPlugin\r\n\r\nexport {\r\n parseRspackPluginOptions,\r\n type RspackPluginOptionsInput,\r\n RspackPluginOptionsSchema,\r\n} from \"./schemas\"\r\n"]}
1
+ {"version":3,"sources":["../packages/domain/shared/src/esmHelpers.ts","../packages/domain/shared/src/index.ts","../packages/presentation/rspack/src/index.ts","../packages/presentation/rspack/src/schemas.ts"],"names":["path","formatIssuePath","getDirname","fs","rule"],"mappings":"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","file":"rspack.mjs","sourcesContent":["/**\r\n * ESM-safe runtime helpers untuk monorepo.\r\n *\r\n * Menggantikan pola fragile seperti:\r\n * - `createRequire(import.meta.url)` → gunakan `createEsmRequire()`\r\n * - `__dirname` → gunakan `getDirname(import.meta.url)`\r\n * - `__filename` → gunakan `getFilename(import.meta.url)`\r\n *\r\n * Semua helper ini bekerja di ESM dan CJS.\r\n *\r\n * @module @tailwind-styled/shared/esmHelpers\r\n */\r\n\r\nconst isBrowser = typeof window !== \"undefined\" || typeof document !== \"undefined\"\r\n\r\n// Safe check for require availability - works in both CJS and ESM\r\nlet nodeModuleRef: typeof import(\"node:module\") | null = null\r\nfunction getNodeModuleRef(): typeof import(\"node:module\") | null {\r\n if (isBrowser) return null\r\n if (nodeModuleRef !== null) return nodeModuleRef\r\n try {\r\n // Test if require actually works\r\n const test = typeof require === 'function' ? (require('node:module') as typeof import(\"node:module\")) : null\r\n nodeModuleRef = test\r\n return test\r\n } catch {\r\n nodeModuleRef = null\r\n return null\r\n }\r\n}\r\n\r\nlet _nodePath: typeof import(\"node:path\") | null = null\r\nlet _nodeUrl: typeof import(\"node:url\") | null = null\r\nlet _nodeFs: typeof import(\"node:fs\") | null = null\r\nlet _nodeCrypto: typeof import(\"node:crypto\") | null = null\r\nlet _nodeOs: typeof import(\"node:os\") | null = null\r\n\r\nfunction getNodePath(): typeof import(\"node:path\") {\r\n if (isBrowser) throw new Error(\"node:path not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodePath) _nodePath = nodeRequire.createRequire(import.meta.url)(\"node:path\") as typeof import(\"node:path\")\r\n return _nodePath!\r\n}\r\nfunction getNodeUrl(): typeof import(\"node:url\") {\r\n if (isBrowser) throw new Error(\"node:url not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeUrl) _nodeUrl = nodeRequire.createRequire(import.meta.url)(\"node:url\") as typeof import(\"node:url\")\r\n return _nodeUrl!\r\n}\r\nfunction getNodeFs(): typeof import(\"node:fs\") {\r\n if (isBrowser) throw new Error(\"node:fs not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeFs) _nodeFs = nodeRequire.createRequire(import.meta.url)(\"node:fs\") as typeof import(\"node:fs\")\r\n return _nodeFs!\r\n}\r\nfunction getNodeCrypto(): typeof import(\"node:crypto\") {\r\n if (isBrowser) throw new Error(\"node:crypto not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeCrypto) _nodeCrypto = nodeRequire.createRequire(import.meta.url)(\"node:crypto\") as typeof import(\"node:crypto\")\r\n return _nodeCrypto!\r\n}\r\nfunction getNodeOs(): typeof import(\"node:os\") {\r\n if (isBrowser) throw new Error(\"node:os not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeOs) _nodeOs = nodeRequire.createRequire(import.meta.url)(\"node:os\") as typeof import(\"node:os\")\r\n return _nodeOs!\r\n}\r\n\r\n/**\r\n * Buat `require()` function yang relative terhadap sebuah ESM module.\r\n *\r\n * @example\r\n * // Ganti: createRequire(import.meta.url)(\"some-pkg\")\r\n * const req = createEsmRequire(import.meta.url)\r\n * const mod = req(\"some-pkg\")\r\n */\r\nexport function createEsmRequire(importMetaUrl: string): NodeRequire {\r\n if (isBrowser) throw new Error(\"require not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n return nodeRequire.createRequire(importMetaUrl)\r\n}\r\n\r\n/**\r\n * Dapat `__dirname` dari `import.meta.url`.\r\n *\r\n * @example\r\n * // Ganti: const __dirname = ...\r\n * const dir = getDirname(import.meta.url)\r\n */\r\nexport function getDirname(importMetaUrl: string): string {\r\n if (isBrowser) return \"\"\r\n const nodePath = getNodePath()\r\n const nodeUrl = getNodeUrl()\r\n return nodePath.dirname(nodeUrl.fileURLToPath(importMetaUrl))\r\n}\r\n\r\n/**\r\n * Dapat `__filename` dari `import.meta.url`.\r\n */\r\nexport function getFilename(importMetaUrl: string): string {\r\n if (isBrowser) return \"\"\r\n return getNodeUrl().fileURLToPath(importMetaUrl)\r\n}\r\n\r\n/**\r\n * Resolve path dari root monorepo (bukan CWD).\r\n * Berguna untuk scripts dan tools yang dipanggil dari lokasi berbeda.\r\n *\r\n * @example\r\n * const root = resolveFromRoot(\"packages/domain/shared/src\")\r\n */\r\nexport function resolveFromRoot(...segments: string[]): string {\r\n if (isBrowser) return segments.join(\"/\")\r\n\r\n const nodePath = getNodePath()\r\n const nodeFs = getNodeFs()\r\n \r\n let dir = getDirname(import.meta.url)\r\n for (let i = 0; i < 10; i++) {\r\n const pkgPath = nodePath.join(dir, \"package.json\")\r\n try {\r\n const pkg = JSON.parse(nodeFs.readFileSync(pkgPath, \"utf-8\"))\r\n if (pkg.workspaces) {\r\n return nodePath.resolve(dir, ...segments)\r\n }\r\n } catch { /* intentionally silent */ }\r\n dir = nodePath.dirname(dir)\r\n }\r\n return nodePath.resolve(process.cwd(), ...segments)\r\n}\r\n\r\n/**\r\n * Require sebuah module dengan fallback ke null jika tidak tersedia.\r\n * Berguna untuk optional dependencies.\r\n *\r\n * @example\r\n * const oxc = tryRequire(\"oxc-parser\", import.meta.url)\r\n * if (!oxc) console.warn(\"oxc-parser not installed\")\r\n */\r\nexport function tryRequire<T = unknown>(\r\n moduleName: string,\r\n importMetaUrl: string\r\n): T | null {\r\n if (isBrowser) return null\r\n try {\r\n return createEsmRequire(importMetaUrl)(moduleName) as T\r\n } catch { /* intentionally silent — optional dep */ }\r\n return null\r\n}\r\n\r\n/**\r\n * Resolve .node binary path yang cross-platform dan ESM-safe.\r\n * Menggantikan pola `path.resolve(__dirname, \"../native.node\")`.\r\n */\r\nexport function resolveNativeNodePath(\r\n importMetaUrl: string,\r\n ...relativeSegments: string[]\r\n): string {\r\n if (isBrowser) return relativeSegments.join(\"/\")\r\n return getNodePath().resolve(getDirname(importMetaUrl), ...relativeSegments)\r\n}","import { createHash } from \"node:crypto\"\r\nimport fs from \"node:fs\"\r\nimport path from \"node:path\"\r\nimport { fileURLToPath } from \"node:url\"\r\nimport { createRequire } from \"node:module\"\r\n\r\n// Native-only: Node.js is always available. No browser fallback.\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Types\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type TokenMap = Record<string, string>\r\n\r\nexport type VariantValue = string | number | boolean | undefined\r\n\r\nexport type VariantProps = Record<string, VariantValue>\r\n\r\nexport type HtmlTagName = keyof HTMLElementTagNameMap\r\n\r\nexport type CompoundCondition = Record<string, string | number | boolean>\r\n\r\nexport type VariantMatrix = Record<string, Array<string | number | boolean>>\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Logging\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport interface Logger {\r\n warn(...args: unknown[]): void\r\n debug(...args: unknown[]): void\r\n error(...args: unknown[]): void\r\n log(...args: unknown[]): void\r\n}\r\n\r\nexport function createLogger(namespace: string): Logger {\r\n const prefix = `[${namespace}]`\r\n return {\r\n warn(...args: unknown[]) {\r\n process.stderr.write(`${prefix} ${args.map(a => typeof a === \"string\" ? a : String(a)).join(\" \")}\\n`)\r\n },\r\n debug(...args: unknown[]) {\r\n process.stderr.write(`${prefix} ${args.map(a => typeof a === \"string\" ? a : String(a)).join(\" \")}\\n`)\r\n },\r\n error(...args: unknown[]) {\r\n process.stderr.write(`${prefix} ${args.map(a => typeof a === \"string\" ? a : String(a)).join(\" \")}\\n`)\r\n },\r\n log(...args: unknown[]) {\r\n process.stderr.write(`${prefix} ${args.map(a => typeof a === \"string\" ? a : String(a)).join(\" \")}\\n`)\r\n },\r\n }\r\n}\r\n\r\nexport function createDebugLogger(namespace: string, label?: string): (msg: string) => void {\r\n const prefix = label ? `[${namespace}:${label}]` : `[${namespace}]`\r\n return (msg: string) => {\r\n if (process.env.DEBUG?.includes(namespace) || process.env.TW_DEBUG) {\r\n console.debug(prefix, msg)\r\n }\r\n }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Error handling\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type ErrorSource = \"rust\" | \"validation\" | \"compile\" | \"io\" | \"config\" | \"unknown\"\r\n\r\ntype ZodLikeIssue = {\r\n path?: readonly PropertyKey[]\r\n message?: string\r\n}\r\n\r\nfunction formatIssuePath(path?: readonly PropertyKey[]): string {\r\n if (!path || path.length === 0) return \"(root)\"\r\n return path\r\n .map((segment) =>\r\n typeof segment === \"symbol\" ? segment.description ?? segment.toString() : String(segment)\r\n )\r\n .join(\".\")\r\n}\r\n\r\nexport class TwError extends Error {\r\n /** @deprecated Gunakan source */\r\n public readonly domain: string\r\n public readonly source: ErrorSource\r\n public readonly code: string\r\n public readonly originalCause?: unknown\r\n\r\n constructor(domainOrSource: string, code: string, message: string, cause?: unknown) {\r\n super(message)\r\n this.name = \"TwError\"\r\n this.domain = domainOrSource\r\n this.source = domainOrSource as ErrorSource\r\n this.code = code\r\n this.originalCause = cause\r\n if (Error.captureStackTrace) Error.captureStackTrace(this, TwError)\r\n }\r\n\r\n static fromIo(code: string, message: string): TwError {\r\n return new TwError(\"io\", code, message)\r\n }\r\n\r\n static fromCompile(code: string, message: string): TwError {\r\n return new TwError(\"compile\", code, message)\r\n }\r\n\r\n static fromRust(err: { code?: string; message?: string } | Error | unknown): TwError {\r\n if (err instanceof TwError) return err\r\n if (err instanceof Error) return new TwError(\"rust\", \"RUST_ERROR\", err.message, err)\r\n if (err && typeof err === \"object\") {\r\n const e = err as { code?: string; message?: string }\r\n return new TwError(\"rust\", e.code ?? \"RUST_ERROR\", e.message ?? String(err), err)\r\n }\r\n return new TwError(\"rust\", \"RUST_ERROR\", String(err), err)\r\n }\r\n\r\n /** Buat TwError dari ZodError — dukung shape Zod v3 (`errors`) dan v4 (`issues`). */\r\n static fromZod(err: { issues?: ZodLikeIssue[]; errors?: ZodLikeIssue[] }): TwError {\r\n const first = err.issues?.[0] ?? err.errors?.[0]\r\n const path = formatIssuePath(first?.path)\r\n const message = first ? `${path}: ${first.message}` : \"Schema validation failed\"\r\n return new TwError(\"validation\", \"SCHEMA_VALIDATION_FAILED\", message, err)\r\n }\r\n\r\n static wrap(source: string, code: string, err: unknown): TwError {\r\n if (err instanceof TwError) return err\r\n if (err instanceof Error) return new TwError(source, code, err.message, err)\r\n return new TwError(source, code, String(err), err)\r\n }\r\n\r\n override toString(): string {\r\n return `TwError [${this.source}:${this.code}] ${this.message}`\r\n }\r\n\r\n toJSON(): { name: string; source: string; code: string; message: string } {\r\n return { name: this.name, source: this.source, code: this.code, message: this.message }\r\n }\r\n\r\n toCliMessage(): string {\r\n return `[${this.source.toUpperCase()}:${this.code}] ${this.message}`\r\n }\r\n}\r\n\r\nexport function wrapUnknownError(domain: string, code: string, error: unknown): TwError {\r\n return TwError.wrap(domain, code, error)\r\n}\r\n\r\nexport function isTwError(err: unknown): err is TwError {\r\n return err instanceof TwError\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Native binding resolution\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport interface LoadNativeBindingOptions<T> {\r\n runtimeDir: string\r\n candidates: string[]\r\n isValid: (module: unknown) => module is T\r\n invalidExportMessage: string\r\n}\r\n\r\nexport interface LoadNativeBindingResult<T> {\r\n binding: T | null\r\n loadErrors: Array<{ path: string; message: string }>\r\n loadedPath?: string\r\n}\r\n\r\nexport function loadNativeBinding<T>(options: LoadNativeBindingOptions<T>): LoadNativeBindingResult<T> {\r\n const { runtimeDir, candidates, isValid } = options\r\n const loadErrors: Array<{ path: string; message: string }> = []\r\n\r\n for (const candidate of candidates) {\r\n const candidatePath = path.resolve(runtimeDir, candidate)\r\n try {\r\n if (!fs.existsSync(candidatePath) && !fs.existsSync(candidatePath + \".node\")) {\r\n continue\r\n }\r\n const mod = requireNativeModule(candidatePath)\r\n if (mod && isValid(mod)) {\r\n return { binding: mod, loadErrors, loadedPath: candidatePath }\r\n }\r\n loadErrors.push({ path: candidatePath, message: options.invalidExportMessage })\r\n } catch (e) {\r\n loadErrors.push({ path: candidatePath, message: e instanceof Error ? e.message : String(e) })\r\n }\r\n }\r\n\r\n return { binding: null, loadErrors }\r\n}\r\n\r\nconst _require = createRequire(import.meta.url)\r\n\r\nfunction requireNativeModule(p: string): unknown {\r\n return _require(p)\r\n}\r\n\r\nexport interface ResolveCandidatesOptions {\r\n runtimeDir?: string\r\n envVarNames?: string[]\r\n includeDefaultCandidates?: boolean\r\n enforceNodeExtensionForEnvPath?: boolean\r\n /** @deprecated — ignored, kept for backward compat */\r\n packageName?: string\r\n}\r\n\r\nexport function resolveNativeBindingCandidates(options: ResolveCandidatesOptions): string[] {\r\n const {\r\n envVarNames = [\"TW_NATIVE_PATH\", \"TWS_NATIVE_PATH\"],\r\n includeDefaultCandidates = true,\r\n enforceNodeExtensionForEnvPath = false,\r\n } = options\r\n // Default ke cwd kalau runtimeDir tidak disediakan\r\n const runtimeDir = options.runtimeDir || process.cwd()\r\n const candidates: string[] = []\r\n\r\n for (const envVar of envVarNames) {\r\n const envPath = process.env[envVar]\r\n if (envPath) {\r\n candidates.push(enforceNodeExtensionForEnvPath && !envPath.endsWith(\".node\") ? envPath + \".node\" : envPath)\r\n }\r\n }\r\n\r\n if (!includeDefaultCandidates) return candidates\r\n\r\n if (fs.existsSync(runtimeDir)) {\r\n try {\r\n for (const entry of fs.readdirSync(runtimeDir)) {\r\n if (entry.endsWith(\".node\")) candidates.push(entry)\r\n }\r\n } catch { /* ignore read errors */ }\r\n }\r\n\r\n const BINARY_NAMES = [\"tailwind-styled-native\", \"tailwind_styled_parser\"]\r\n const napiPlatform = process.platform === \"linux\" && process.arch === \"x64\" ? \"linux-x64-gnu\"\r\n : process.platform === \"linux\" && process.arch === \"arm64\" ? \"linux-arm64-gnu\"\r\n : `${process.platform}-${process.arch}`\r\n\r\n for (const bin of BINARY_NAMES) {\r\n candidates.push(path.resolve(runtimeDir, `${bin}.node`))\r\n candidates.push(path.resolve(runtimeDir, `${bin}.${napiPlatform}.node`))\r\n // 1 level: dist/ → package-root/native/ (published npm package)\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"native\", `${bin}.node`))\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"native\", `${bin}.${napiPlatform}.node`))\r\n // cwd fallback (user project root)\r\n candidates.push(path.resolve(process.cwd(), \"native\", `${bin}.node`))\r\n candidates.push(path.resolve(process.cwd(), \"native\", `${bin}.${napiPlatform}.node`))\r\n // 4 level: dist/ → package/ → domain/ → packages/ → repo-root/ (monorepo dev)\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"..\", \"..\", \"..\", \"native\", `${bin}.node`))\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"..\", \"..\", \"..\", \"native\", `${bin}.${napiPlatform}.node`))\r\n // 3 level fallback\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"..\", \"..\", \"native\", `${bin}.node`))\r\n }\r\n\r\n return Array.from(new Set(candidates))\r\n}\r\n\r\nexport function resolveRuntimeDir(dir: string | undefined, importMetaUrl: string): string {\r\n if (dir) return path.resolve(dir)\r\n try {\r\n return path.dirname(fileURLToPath(importMetaUrl))\r\n } catch {\r\n return process.cwd()\r\n }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Hashing\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport function hashContent(content: string, algorithm: string = \"md5\", length?: number): string {\r\n const hash = createHash(algorithm).update(content).digest(\"hex\")\r\n return length ? hash.slice(0, length) : hash\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Error formatting\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport function formatErrorMessage(error: unknown): string {\r\n if (error instanceof TwError) return error.toString()\r\n if (error instanceof Error) return error.message\r\n return String(error)\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// LRU Cache\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport class LRUCache<K, V> {\r\n private capacity: number\r\n private cache: Map<K, V>\r\n\r\n constructor(capacity: number) {\r\n this.capacity = capacity\r\n this.cache = new Map()\r\n }\r\n\r\n get(key: K): V | undefined {\r\n if (!this.cache.has(key)) return undefined\r\n const value = this.cache.get(key)!\r\n this.cache.delete(key)\r\n this.cache.set(key, value)\r\n return value\r\n }\r\n\r\n set(key: K, value: V): void {\r\n if (this.cache.has(key)) {\r\n this.cache.delete(key)\r\n } else if (this.cache.size >= this.capacity) {\r\n const firstKey = this.cache.keys().next().value\r\n if (firstKey !== undefined) {\r\n this.cache.delete(firstKey)\r\n }\r\n }\r\n this.cache.set(key, value)\r\n }\r\n\r\n delete(key: K): boolean {\r\n return this.cache.delete(key)\r\n }\r\n\r\n has(key: K): boolean {\r\n return this.cache.has(key)\r\n }\r\n\r\n clear(): void {\r\n this.cache.clear()\r\n }\r\n\r\n entries(): IterableIterator<[K, V]> {\r\n return this.cache.entries()\r\n }\r\n\r\n get size(): number {\r\n return this.cache.size\r\n }\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Trace Utilities\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type { TraceSnapshot, TraceSummary } from \"./trace\"\r\nexport {\r\n getHealthColor,\r\n getModeColor,\r\n formatMemory,\r\n formatDuration,\r\n calculateHealth,\r\n getBuildTimeColor,\r\n getMemoryColor,\r\n createTraceSnapshot,\r\n getPipelinePercentages,\r\n} from \"./trace\"\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Performance Telemetry\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\n\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Error Codes\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type { ErrorCode } from \"./error-codes\"\r\nexport { ERROR_CODES, getSuggestion, formatErrorCode } from \"./error-codes\"\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Tailwind Compatibility\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\nexport type { TailwindInfo } from \"./compatibility\"\r\nexport { detectTailwind, assertTailwindV4, getTailwindVersion, isTailwindV4 } from \"./compatibility\"\r\n\r\n// ── Native binding schemas (Zod boundary validation)\r\nexport {\r\n NativeScanFileSchema, NativeScanResultSchema,\r\n NativeAnalyzerReportSchema, NativeTransformResultSchema,\r\n NativeCssCompileResultSchema, NativeWatchResultSchema,\r\n NativeCacheEntrySchema, NativeCacheReadResultSchema,\r\n safeParseNative, parseNative,\r\n} from './native-schemas'\r\n\r\n// ── ESM-safe runtime helpers ──────────────────────────────────────────────\r\nexport {\r\n createEsmRequire,\r\n getDirname,\r\n getFilename,\r\n resolveFromRoot,\r\n tryRequire,\r\n resolveNativeNodePath,\r\n} from \"./esmHelpers\"\r\n\r\n// ── Performance telemetry ────────────────────────────────────────────────────\r\nexport {\r\n TelemetryCollector,\r\n getGlobalTelemetry,\r\n resetGlobalTelemetry,\r\n createBuildTimer,\r\n type BuildTelemetry,\r\n type TelemetrySummary,\r\n type BuildPhases,\r\n} from \"./telemetry\"\r\n\r\n// ── Config/JSON schema validation ─────────────────────────────────────────────\r\nexport {\r\n ScanCacheSchema,\r\n ScanCacheClassEntrySchema,\r\n TailwindConfigSchema,\r\n RegistryPluginEntrySchema,\r\n RegistryFileSchema,\r\n PackageJsonSchema,\r\n parseJsonWithSchema,\r\n parseJsonFileWithSchema,\r\n type ScanCache,\r\n type ScanCacheClassEntry,\r\n type TailwindConfig,\r\n type RegistryPluginEntry,\r\n type RegistryFile,\r\n type PackageJson,\r\n} from \"./configSchemas\"\r\n\r\n// ── Worker/bootstrap path resolution ─────────────────────────────────────────\r\nexport {\r\n resolveWorkerPath,\r\n resolveLoaderPath,\r\n type WorkerPathOptions,\r\n type WorkerPathResult,\r\n} from \"./workerResolver\"\r\n\r\n// ── Codegen helpers ───────────────────────────────────────────────────────────\r\nexport {\r\n generateComponentCode,\r\n generateStorybookStory,\r\n generateClassRenameCodemod,\r\n generateBarrelFile,\r\n type ComponentCodegenOptions,\r\n} from \"./codegen\"\r\n\r\n// ── Native binary resolution (QA #1) ─────────────────────────────────────────\r\nexport {\r\n resolveNativeBinary,\r\n formatNativeNotFoundError,\r\n type NativeResolutionResult,\r\n} from \"./native-resolution\"\r\n\r\n// ── Shared observability contract ────────────────────────────────────────────\r\nexport {\r\n createObservabilityClient,\r\n type ClassInspection,\r\n type ClassProperty,\r\n type ClassUsageLocation,\r\n type BuildTrace,\r\n type BuildPhaseTrace,\r\n type DashboardMetrics,\r\n type DashboardSummary,\r\n type ObservabilityClient,\r\n} from \"./observability\"\r\n\r\nexport {\r\n TW_STATE_STATIC_FILENAME,\r\n extractStaticStateCss,\r\n appendStaticStateCssToSafelist,\r\n type TwStateConfigEntry,\r\n type StaticStateCssInput,\r\n type GeneratedStateRule,\r\n type StaticStateExtractionResult,\r\n} from \"./staticStateExtractor\"\r\nexport { setGlobalLogFile } from \"./logger\"","/**\r\n * tailwind-styled-v4 - Rspack Plugin v5 (stable)\r\n *\r\n * Usage:\r\n * import { tailwindStyledRspackPlugin } from \"@tailwind-styled/rspack\"\r\n *\r\n * export default defineConfig({\r\n * plugins: [tailwindStyledRspackPlugin()],\r\n * })\r\n *\r\n * v5:\r\n * - Simplified API\r\n * - Mode always zero-runtime\r\n */\r\n\r\nimport fs from \"node:fs\"\r\nimport path from \"node:path\"\r\nimport { getDirname as getEsmDirname } from \"@tailwind-styled/shared\"\r\n\r\nimport { parseRspackPluginOptions } from \"./schemas\"\r\n\r\nfunction getDirname(): string {\r\n if (typeof __dirname !== \"undefined\") {\r\n return __dirname\r\n }\r\n if (typeof import.meta !== \"undefined\" && import.meta.url) {\r\n return getEsmDirname(import.meta.url)\r\n }\r\n return process.cwd()\r\n}\r\n\r\nfunction resolveLoaderPath(basename: string): string {\r\n const runtimeDir = getDirname()\r\n const preferredExtensions =\r\n typeof __dirname !== \"undefined\" && __dirname.length > 0 ? [\".cjs\", \".js\"] : [\".js\", \".cjs\"]\r\n\r\n for (const ext of preferredExtensions) {\r\n const candidate = path.resolve(runtimeDir, `${basename}${ext}`)\r\n if (fs.existsSync(candidate)) return candidate\r\n }\r\n\r\n return path.resolve(runtimeDir, `${basename}.js`)\r\n}\r\n\r\ninterface RspackRule {\r\n _tailwindStyledRspackMarker?: boolean\r\n test?: RegExp\r\n exclude?: RegExp\r\n use?: Array<{\r\n loader: string\r\n options: {\r\n mode: \"zero-runtime\"\r\n addDataAttr: boolean\r\n preserveImports: boolean\r\n safelistPath?: string\r\n }\r\n }>\r\n}\r\n\r\ninterface RspackCompiler {\r\n options: {\r\n mode?: string\r\n module?: {\r\n rules?: RspackRule[]\r\n }\r\n }\r\n}\r\n\r\nexport interface RspackPluginOptions {\r\n /** File patterns to include. Default: /\\.[jt]sx?$/ */\r\n include?: RegExp\r\n /** File patterns to exclude. Default: /node_modules/ */\r\n exclude?: RegExp\r\n /** Add data-tw debug attributes in dev. Default: true in dev */\r\n addDataAttr?: boolean\r\n /** Enable analyzer. Default: false */\r\n analyze?: boolean\r\n /**\r\n * Path ke safelist CSS file.\r\n * `_tw-state-static.css` ditulis di direktori yang sama.\r\n * Default: `<cwd>/__tw_safelist.css`\r\n */\r\n safelistPath?: string\r\n}\r\n\r\nexport class TailwindStyledRspackPlugin {\r\n private opts: RspackPluginOptions\r\n\r\n constructor(opts: RspackPluginOptions = {}) {\r\n this.opts = parseRspackPluginOptions(opts)\r\n }\r\n\r\n apply(compiler: RspackCompiler): void {\r\n const isDev = compiler.options.mode !== \"production\"\r\n const loaderPath = resolveLoaderPath(\"loader\")\r\n const existing = compiler.options.module?.rules ?? []\r\n const alreadyRegistered = existing.some(\r\n (rule) =>\r\n typeof rule === \"object\" && rule !== null && rule._tailwindStyledRspackMarker === true\r\n )\r\n\r\n if (alreadyRegistered) return\r\n\r\n const safelistPath =\r\n this.opts.safelistPath ?? path.join(process.cwd(), \"__tw_safelist.css\")\r\n\r\n // Tulis placeholder agar @import di CSS entry tidak error saat cold start\r\n const stateStaticPath = path.join(path.dirname(safelistPath), \"_tw-state-static.css\")\r\n if (!fs.existsSync(stateStaticPath)) {\r\n try {\r\n fs.mkdirSync(path.dirname(stateStaticPath), { recursive: true })\r\n fs.writeFileSync(\r\n stateStaticPath,\r\n `/* _tw-state-static.css — Auto-generated by tailwind-styled-v4. DO NOT EDIT.\\n` +\r\n ` * Import di CSS entry: @import \"./_tw-state-static.css\";\\n` +\r\n ` */\\n`,\r\n \"utf-8\"\r\n )\r\n } catch { /* non-fatal */ }\r\n }\r\n\r\n const rule: RspackRule = {\r\n _tailwindStyledRspackMarker: true,\r\n test: this.opts.include ?? /\\.[jt]sx?$/,\r\n exclude: this.opts.exclude ?? /node_modules/,\r\n use: [\r\n {\r\n loader: loaderPath,\r\n options: {\r\n mode: \"zero-runtime\",\r\n addDataAttr: this.opts.addDataAttr ?? isDev,\r\n preserveImports: true,\r\n safelistPath,\r\n },\r\n },\r\n ],\r\n }\r\n\r\n compiler.options.module = {\r\n ...(compiler.options.module ?? {}),\r\n rules: [rule, ...existing],\r\n }\r\n }\r\n}\r\n\r\nexport function tailwindStyledRspackPlugin(\r\n opts: RspackPluginOptions = {}\r\n): TailwindStyledRspackPlugin {\r\n return new TailwindStyledRspackPlugin(opts)\r\n}\r\n\r\nexport default tailwindStyledRspackPlugin\r\n\r\nexport {\r\n parseRspackPluginOptions,\r\n type RspackPluginOptionsInput,\r\n RspackPluginOptionsSchema,\r\n} from \"./schemas\"\r\n","import { z } from \"zod\"\r\nimport { TwError } from \"@tailwind-styled/shared\"\r\n\r\nconst formatIssuePath = (path: readonly PropertyKey[]): string =>\r\n path.length > 0\r\n ? path\r\n .map((segment) =>\r\n typeof segment === \"symbol\" ? segment.description ?? segment.toString() : String(segment)\r\n )\r\n .join(\".\")\r\n : \"<root>\"\r\n\r\nconst formatIssues = (error: z.ZodError): string =>\r\n error.issues\r\n .map((issue) => {\r\n const p = formatIssuePath(issue.path)\r\n return `${p}: ${issue.message}`\r\n })\r\n .join(\"; \")\r\n\r\nconst parseWithSchema = <T>(schema: z.ZodType<T>, data: unknown, label: string): T => {\r\n const parsed = schema.safeParse(data)\r\n if (parsed.success) return parsed.data\r\n const details = formatIssues(parsed.error)\r\n throw new TwError(\r\n \"validation\",\r\n \"SCHEMA_VALIDATION_FAILED\",\r\n details ? `${label}: ${details}` : label,\r\n parsed.error\r\n )\r\n}\r\n\r\nexport const RspackPluginOptionsSchema = z.object({\r\n include: z.instanceof(RegExp).optional(),\r\n exclude: z.instanceof(RegExp).optional(),\r\n addDataAttr: z.boolean().optional(),\r\n analyze: z.boolean().optional(),\r\n cssEntry: z.string().optional(),\r\n /** Path ke safelist CSS file. Default: <cwd>/__tw_safelist.css */\r\n safelistPath: z.string().optional(),\r\n})\r\n\r\nexport type RspackPluginOptionsInput = z.infer<typeof RspackPluginOptionsSchema>\r\n\r\nexport const parseRspackPluginOptions = (options: unknown) =>\r\n parseWithSchema(RspackPluginOptionsSchema, options ?? {}, \"rspack plugin options are invalid\")\r\n"]}
@@ -4,17 +4,25 @@ import React from 'react';
4
4
  * Queue a CSS rule for batched injection.
5
5
  * Multiple rules accumulated during one event loop tick are flushed together
6
6
  * in one requestAnimationFrame → one style recalculation.
7
+ *
8
+ * Rules diinjeksi via insertRule() — zero flicker, truly additive.
7
9
  */
8
10
  declare function batchedInject(cssRule: string): void;
9
11
  /**
10
12
  * Immediately flush all pending CSS rules to the DOM.
11
13
  * Called automatically by RAF each frame. Can also be called manually
12
14
  * after synchronous component setup where RAF timing is too late.
15
+ *
16
+ * Setiap rule diinjeksi secara individual via insertRule() — tidak ada
17
+ * window dimana existing rules hilang.
13
18
  */
14
19
  declare function flushBatchedCss(): void;
15
20
  /**
16
21
  * Synchronous inject — skips batching.
17
22
  * Use for SSR / critical path where RAF is not available.
23
+ *
24
+ * Menggunakan insertRule() — tidak ada flicker meskipun dipanggil
25
+ * di tengah render cycle.
18
26
  */
19
27
  declare function syncInject(cssRule: string): void;
20
28
  /**
@@ -4,17 +4,25 @@ import React from 'react';
4
4
  * Queue a CSS rule for batched injection.
5
5
  * Multiple rules accumulated during one event loop tick are flushed together
6
6
  * in one requestAnimationFrame → one style recalculation.
7
+ *
8
+ * Rules diinjeksi via insertRule() — zero flicker, truly additive.
7
9
  */
8
10
  declare function batchedInject(cssRule: string): void;
9
11
  /**
10
12
  * Immediately flush all pending CSS rules to the DOM.
11
13
  * Called automatically by RAF each frame. Can also be called manually
12
14
  * after synchronous component setup where RAF timing is too late.
15
+ *
16
+ * Setiap rule diinjeksi secara individual via insertRule() — tidak ada
17
+ * window dimana existing rules hilang.
13
18
  */
14
19
  declare function flushBatchedCss(): void;
15
20
  /**
16
21
  * Synchronous inject — skips batching.
17
22
  * Use for SSR / critical path where RAF is not available.
23
+ *
24
+ * Menggunakan insertRule() — tidak ada flicker meskipun dipanggil
25
+ * di tengah render cycle.
18
26
  */
19
27
  declare function syncInject(cssRule: string): void;
20
28
  /**
@@ -23,6 +23,24 @@ function getStyleElement() {
23
23
  document.head.appendChild(_state.styleEl);
24
24
  return _state.styleEl;
25
25
  }
26
+ function insertRuleToSheet(cssRule) {
27
+ const trimmed = cssRule.trim();
28
+ if (!trimmed) return;
29
+ const el = getStyleElement();
30
+ const sheet = el.sheet;
31
+ if (sheet) {
32
+ try {
33
+ sheet.insertRule(trimmed, sheet.cssRules.length);
34
+ return;
35
+ } catch {
36
+ if (process.env.NODE_ENV === "development") {
37
+ console.warn("[tw] insertRule failed, falling back to textContent append for rule:", trimmed.slice(0, 80));
38
+ }
39
+ }
40
+ }
41
+ el.textContent = (el.textContent ?? "") + `
42
+ ${trimmed}`;
43
+ }
26
44
  function batchedInject(cssRule) {
27
45
  if (typeof window === "undefined") return;
28
46
  if (!cssRule || injected.has(cssRule)) return;
@@ -35,18 +53,16 @@ function batchedInject(cssRule) {
35
53
  function flushBatchedCss() {
36
54
  _state.rafHandle = null;
37
55
  if (pending.length === 0 || typeof document === "undefined") return;
38
- const el = getStyleElement();
39
- const css = pending.join("\n");
40
- pending.length = 0;
41
- el.textContent += `
42
- ${css}`;
56
+ const rules = pending.splice(0);
57
+ for (const rule of rules) {
58
+ insertRuleToSheet(rule);
59
+ }
43
60
  }
44
61
  function syncInject(cssRule) {
45
62
  if (typeof document === "undefined") return;
46
63
  if (!cssRule || injected.has(cssRule)) return;
47
64
  injected.add(cssRule);
48
- getStyleElement().textContent += `
49
- ${cssRule}`;
65
+ insertRuleToSheet(cssRule);
50
66
  }
51
67
  function isInjected(cssRule) {
52
68
  return injected.has(cssRule);
@@ -1 +1 @@
1
- {"version":3,"sources":["../packages/domain/runtime-css/src/batchedInjector.ts","../packages/domain/runtime-css/src/CssInjector.tsx"],"names":["React"],"mappings":"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","file":"runtime-css.js","sourcesContent":["\"use client\"\r\n\r\n/**\r\n * tailwind-styled-v5 — Batched CSS Injector (Client Runtime)\r\n *\r\n * Menggantikan pattern inject-per-komponen yang menyebabkan banyak\r\n * style recalculation saat banyak komponen mount bersamaan.\r\n *\r\n * Cara kerja:\r\n * - Semua CSS rules dari render cycle yang sama dikumpulkan\r\n * - Satu requestAnimationFrame = satu DOM style update\r\n * - Deduplication via Set<string> — rule yang sama tidak diinjeksi dua kali\r\n * - Fallback synchronous untuk SSR / server context\r\n *\r\n * Usage (internal, dipakai oleh stateEngine dan containerQuery):\r\n * import { batchedInject, flushBatchedCss } from \"./batchedInjector\"\r\n *\r\n * // Queue a rule\r\n * batchedInject(\".tw-s-abc123[data-active=\\\"true\\\"]{opacity:0.5}\")\r\n *\r\n * // Force flush (biasanya tidak perlu — RAF melakukan ini otomatis)\r\n * flushBatchedCss()\r\n */\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Singleton state\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\n/** All injected rules (deduplication registry) */\r\nconst injected = new Set<string>()\r\n\r\n/** Pending rules for current RAF batch */\r\nconst pending: string[] = []\r\n\r\n/** RAF handle and style element state */\r\nconst _state = {\r\n rafHandle: null as ReturnType<typeof requestAnimationFrame> | null,\r\n styleEl: null as HTMLStyleElement | null,\r\n}\r\n\r\nfunction getStyleElement(): HTMLStyleElement {\r\n if (_state.styleEl && document.head.contains(_state.styleEl)) return _state.styleEl\r\n\r\n _state.styleEl = document.createElement(\"style\")\r\n _state.styleEl.id = \"__tw-runtime-css\"\r\n _state.styleEl.setAttribute(\"data-tw-batched\", \"true\")\r\n document.head.appendChild(_state.styleEl)\r\n return _state.styleEl\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Core API\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\n/**\r\n * Queue a CSS rule for batched injection.\r\n * Multiple rules accumulated during one event loop tick are flushed together\r\n * in one requestAnimationFrame → one style recalculation.\r\n */\r\nexport function batchedInject(cssRule: string): void {\r\n if (typeof window === \"undefined\") return // SSR — no-op\r\n if (!cssRule || injected.has(cssRule)) return\r\n\r\n injected.add(cssRule)\r\n pending.push(cssRule)\r\n\r\n if (_state.rafHandle === null) {\r\n _state.rafHandle = requestAnimationFrame(flushBatchedCss)\r\n }\r\n}\r\n\r\n/**\r\n * Immediately flush all pending CSS rules to the DOM.\r\n * Called automatically by RAF each frame. Can also be called manually\r\n * after synchronous component setup where RAF timing is too late.\r\n */\r\nexport function flushBatchedCss(): void {\r\n _state.rafHandle = null\r\n\r\n if (pending.length === 0 || typeof document === \"undefined\") return\r\n\r\n const el = getStyleElement()\r\n const css = pending.join(\"\\n\")\r\n pending.length = 0\r\n\r\n // Append rather than replace — preserves previously injected rules\r\n el.textContent += `\\n${css}`\r\n}\r\n\r\n/**\r\n * Synchronous inject — skips batching.\r\n * Use for SSR / critical path where RAF is not available.\r\n */\r\nexport function syncInject(cssRule: string): void {\r\n if (typeof document === \"undefined\") return\r\n if (!cssRule || injected.has(cssRule)) return\r\n\r\n injected.add(cssRule)\r\n getStyleElement().textContent += `\\n${cssRule}`\r\n}\r\n\r\n/**\r\n * Check if a rule has already been injected (deduplication check).\r\n */\r\nexport function isInjected(cssRule: string): boolean {\r\n return injected.has(cssRule)\r\n}\r\n\r\n/**\r\n * Clear all injected rules and remove the style element.\r\n * Useful for testing / SSR resets. Not for production use.\r\n */\r\nexport function resetBatchedCss(): void {\r\n injected.clear()\r\n pending.length = 0\r\n\r\n if (_state.rafHandle !== null) {\r\n cancelAnimationFrame(_state.rafHandle)\r\n _state.rafHandle = null\r\n }\r\n\r\n // Guard: document tidak tersedia di SSR / Node test environment\r\n if (typeof document !== \"undefined\" && _state.styleEl && document.head.contains(_state.styleEl)) {\r\n document.head.removeChild(_state.styleEl)\r\n _state.styleEl = null\r\n } else {\r\n _state.styleEl = null\r\n }\r\n}\r\n\r\n/**\r\n * Get stats about the current injection state (for devtools).\r\n */\r\nexport function getBatchedCssStats(): {\r\n totalInjected: number\r\n pendingCount: number\r\n hasBatchScheduled: boolean\r\n} {\r\n return {\r\n totalInjected: injected.size,\r\n pendingCount: pending.length,\r\n hasBatchScheduled: _state.rafHandle !== null,\r\n }\r\n}","/**\r\n * tailwind-styled-v4 — TwCssInjector\r\n *\r\n * React Server Component — inject route-specific CSS ke <head>.\r\n * Zero client JS, no hydration overhead, streaming-friendly.\r\n *\r\n * Pipeline:\r\n * 1. withTailwindStyled webpack plugin emit CSS manifest ke .next/static/css/tw/\r\n * 2. TwCssInjector baca manifest → inject <style> inline per route\r\n *\r\n * Usage:\r\n * // app/layout.tsx\r\n * import { TwCssInjector } from \"tailwind-styled-v4/runtime-css\"\r\n *\r\n * export default function Layout({ children }) {\r\n * return (\r\n * <html>\r\n * <head><TwCssInjector /></head>\r\n * <body>{children}</body>\r\n * </html>\r\n * )\r\n * }\r\n */\r\n\r\nimport React from \"react\"\r\n\r\ninterface CssInjectorProps {\r\n /** Route spesifik. Default: auto-detect */\r\n route?: string\r\n /** Inject global CSS juga. Default: true */\r\n includeGlobal?: boolean\r\n /** Minify inline CSS. Default: true */\r\n minify?: boolean\r\n /** CSS directory. Default: .next/static/css/tw */\r\n cssDir?: string\r\n}\r\n\r\n/**\r\n * Server Component — inject CSS per route ke <head>.\r\n * Baca dari manifest yang di-emit oleh TwCssManifestPlugin.\r\n */\r\nexport async function TwCssInjector(props: CssInjectorProps = {}): Promise<React.ReactElement> {\r\n const { route, includeGlobal = true, minify = true, cssDir } = props\r\n\r\n // Dynamic import fs — hanya jalan di server\r\n let fs: typeof import(\"node:fs\") | null = null\r\n let path: typeof import(\"node:path\") | null = null\r\n try {\r\n fs = await import(\"node:fs\")\r\n path = await import(\"node:path\")\r\n } catch {\r\n return React.createElement(React.Fragment, null)\r\n }\r\n\r\n const resolvedDir = cssDir\r\n ?? path.join(process.cwd(), \".next\", \"static\", \"css\", \"tw\")\r\n\r\n const manifestPath = path.join(resolvedDir, \"css-manifest.json\")\r\n\r\n // Baca manifest\r\n let manifest: { routes?: Record<string, string> } = {}\r\n try {\r\n if (fs.existsSync(manifestPath)) {\r\n manifest = JSON.parse(fs.readFileSync(manifestPath, \"utf-8\"))\r\n }\r\n } catch {\r\n // Manifest tidak ada — mungkin belum build atau native binding belum ready\r\n return React.createElement(React.Fragment, null)\r\n }\r\n\r\n const cssChunks: string[] = []\r\n\r\n // Global CSS (_global.css)\r\n if (includeGlobal && manifest.routes?.[\"__global\"]) {\r\n const globalPath = path.join(resolvedDir, manifest.routes[\"__global\"])\r\n const css = readFile(fs, globalPath)\r\n if (css) cssChunks.push(css)\r\n }\r\n\r\n // Route-specific CSS\r\n const targetRoute = route ?? \"/\"\r\n if (manifest.routes?.[targetRoute]) {\r\n const routePath = path.join(resolvedDir, manifest.routes[targetRoute])\r\n const css = readFile(fs, routePath)\r\n if (css) cssChunks.push(css)\r\n }\r\n\r\n if (cssChunks.length === 0) return React.createElement(React.Fragment, null)\r\n\r\n const combined = cssChunks.join(\"\\n\")\r\n const final = minify ? minifyCss(combined) : combined\r\n\r\n return React.createElement(\"style\", {\r\n dangerouslySetInnerHTML: { __html: final },\r\n \"data-tw-route\": targetRoute,\r\n \"data-tw-injector\": \"true\",\r\n })\r\n}\r\n\r\n/**\r\n * Hook untuk client components — CSS sudah di-handle TwCssInjector di server.\r\n */\r\nexport function useTwClasses(classes: string): string {\r\n return classes\r\n}\r\n\r\n// Helpers\r\nfunction readFile(fs: typeof import(\"node:fs\"), filepath: string): string | null {\r\n try {\r\n if (fs.existsSync(filepath)) return fs.readFileSync(filepath, \"utf-8\")\r\n } catch {}\r\n return null\r\n}\r\n\r\nfunction minifyCss(css: string): string {\r\n return css\r\n .replace(/\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\//g, \"\")\r\n .replace(/\\s+/g, \" \")\r\n .replace(/\\s*{\\s*/g, \"{\")\r\n .replace(/\\s*}\\s*/g, \"}\")\r\n .replace(/\\s*;\\s*/g, \";\")\r\n .trim()\r\n}"]}
1
+ {"version":3,"sources":["../packages/domain/runtime-css/src/batchedInjector.ts","../packages/domain/runtime-css/src/CssInjector.tsx"],"names":["React"],"mappings":"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","file":"runtime-css.js","sourcesContent":["\"use client\"\r\n\r\n/**\r\n * tailwind-styled-v5 — Batched CSS Injector (Client Runtime)\r\n *\r\n * Menggantikan pattern inject-per-komponen yang menyebabkan banyak\r\n * style recalculation saat banyak komponen mount bersamaan.\r\n *\r\n * Cara kerja:\r\n * - Semua CSS rules dari render cycle yang sama dikumpulkan\r\n * - Satu requestAnimationFrame = satu DOM style update\r\n * - Deduplication via Set<string> — rule yang sama tidak diinjeksi dua kali\r\n * - Injection via CSSStyleSheet.insertRule() — TIDAK menghapus rules yang ada\r\n * - Fallback ke textContent += jika CSSOM API tidak tersedia\r\n *\r\n * PENTING — Kenapa insertRule() bukan textContent +=:\r\n * `el.textContent += css` terlihat additive tapi sebenarnya:\r\n * 1. Browser baca semua textContent yang ada\r\n * 2. HAPUS semua rules dari stylesheet\r\n * 3. Concat string baru\r\n * 4. Parse ulang dan re-add semua rules\r\n * Di step 2-3, ada window singkat dimana SEMUA styles hilang → FLICKER.\r\n *\r\n * `sheet.insertRule()` benar-benar additive — hanya menambah rule baru\r\n * tanpa menyentuh rules yang sudah ada. Zero flicker.\r\n *\r\n * Usage (internal, dipakai oleh stateEngine dan containerQuery):\r\n * import { batchedInject, flushBatchedCss } from \"./batchedInjector\"\r\n *\r\n * // Queue a rule\r\n * batchedInject(\".tw-s-abc123[data-active=\\\"true\\\"]{opacity:0.5}\")\r\n *\r\n * // Force flush (biasanya tidak perlu — RAF melakukan ini otomatis)\r\n * flushBatchedCss()\r\n */\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Singleton state\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\n/** All injected rules (deduplication registry) */\r\nconst injected = new Set<string>()\r\n\r\n/** Pending rules for current RAF batch */\r\nconst pending: string[] = []\r\n\r\n/** RAF handle and style element state */\r\nconst _state = {\r\n rafHandle: null as ReturnType<typeof requestAnimationFrame> | null,\r\n styleEl: null as HTMLStyleElement | null,\r\n}\r\n\r\nfunction getStyleElement(): HTMLStyleElement {\r\n if (_state.styleEl && document.head.contains(_state.styleEl)) return _state.styleEl\r\n\r\n _state.styleEl = document.createElement(\"style\")\r\n _state.styleEl.id = \"__tw-runtime-css\"\r\n _state.styleEl.setAttribute(\"data-tw-batched\", \"true\")\r\n // Harus diappend ke DOM sebelum .sheet bisa diakses\r\n document.head.appendChild(_state.styleEl)\r\n return _state.styleEl\r\n}\r\n\r\n/**\r\n * Inject satu CSS rule via CSSStyleSheet.insertRule().\r\n *\r\n * Ini benar-benar additive — tidak menyentuh rules yang sudah ada.\r\n * Fallback ke textContent append jika sheet belum siap (edge case).\r\n *\r\n * @internal\r\n */\r\nfunction insertRuleToSheet(cssRule: string): void {\r\n const trimmed = cssRule.trim()\r\n if (!trimmed) return\r\n\r\n const el = getStyleElement()\r\n const sheet = el.sheet\r\n\r\n if (sheet) {\r\n try {\r\n // insertRule() di akhir — urutan tidak kritis untuk utility CSS\r\n sheet.insertRule(trimmed, sheet.cssRules.length)\r\n return\r\n } catch {\r\n // insertRule() bisa throw jika:\r\n // 1. Rule syntax tidak valid\r\n // 2. Multi-rule string (insertRule() hanya terima satu rule)\r\n // Fallback ke textContent append untuk kasus ini.\r\n if (process.env.NODE_ENV === \"development\") {\r\n console.warn(\"[tw] insertRule failed, falling back to textContent append for rule:\", trimmed.slice(0, 80))\r\n }\r\n }\r\n }\r\n\r\n // Fallback: textContent append.\r\n // Lebih jarang terjadi sekarang karena stateEngine sudah loop per-rule,\r\n // tapi tetap perlu sebagai safety net.\r\n el.textContent = (el.textContent ?? \"\") + `\\n${trimmed}`\r\n}\r\n\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n// Core API\r\n// ─────────────────────────────────────────────────────────────────────────────\r\n\r\n/**\r\n * Queue a CSS rule for batched injection.\r\n * Multiple rules accumulated during one event loop tick are flushed together\r\n * in one requestAnimationFrame → one style recalculation.\r\n *\r\n * Rules diinjeksi via insertRule() — zero flicker, truly additive.\r\n */\r\nexport function batchedInject(cssRule: string): void {\r\n if (typeof window === \"undefined\") return // SSR — no-op\r\n if (!cssRule || injected.has(cssRule)) return\r\n\r\n injected.add(cssRule)\r\n pending.push(cssRule)\r\n\r\n if (_state.rafHandle === null) {\r\n _state.rafHandle = requestAnimationFrame(flushBatchedCss)\r\n }\r\n}\r\n\r\n/**\r\n * Immediately flush all pending CSS rules to the DOM.\r\n * Called automatically by RAF each frame. Can also be called manually\r\n * after synchronous component setup where RAF timing is too late.\r\n *\r\n * Setiap rule diinjeksi secara individual via insertRule() — tidak ada\r\n * window dimana existing rules hilang.\r\n */\r\nexport function flushBatchedCss(): void {\r\n _state.rafHandle = null\r\n\r\n if (pending.length === 0 || typeof document === \"undefined\") return\r\n\r\n // Flush semua rules sekaligus — satu per satu via insertRule()\r\n // insertRule() atomic per-rule: rule lama tidak pernah dihapus\r\n const rules = pending.splice(0)\r\n for (const rule of rules) {\r\n insertRuleToSheet(rule)\r\n }\r\n}\r\n\r\n/**\r\n * Synchronous inject — skips batching.\r\n * Use for SSR / critical path where RAF is not available.\r\n *\r\n * Menggunakan insertRule() — tidak ada flicker meskipun dipanggil\r\n * di tengah render cycle.\r\n */\r\nexport function syncInject(cssRule: string): void {\r\n if (typeof document === \"undefined\") return\r\n if (!cssRule || injected.has(cssRule)) return\r\n\r\n injected.add(cssRule)\r\n insertRuleToSheet(cssRule)\r\n}\r\n\r\n/**\r\n * Check if a rule has already been injected (deduplication check).\r\n */\r\nexport function isInjected(cssRule: string): boolean {\r\n return injected.has(cssRule)\r\n}\r\n\r\n/**\r\n * Clear all injected rules and remove the style element.\r\n * Useful for testing / SSR resets. Not for production use.\r\n */\r\nexport function resetBatchedCss(): void {\r\n injected.clear()\r\n pending.length = 0\r\n\r\n if (_state.rafHandle !== null) {\r\n cancelAnimationFrame(_state.rafHandle)\r\n _state.rafHandle = null\r\n }\r\n\r\n // Guard: document tidak tersedia di SSR / Node test environment\r\n if (typeof document !== \"undefined\" && _state.styleEl && document.head.contains(_state.styleEl)) {\r\n document.head.removeChild(_state.styleEl)\r\n _state.styleEl = null\r\n } else {\r\n _state.styleEl = null\r\n }\r\n}\r\n\r\n/**\r\n * Get stats about the current injection state (for devtools).\r\n */\r\nexport function getBatchedCssStats(): {\r\n totalInjected: number\r\n pendingCount: number\r\n hasBatchScheduled: boolean\r\n} {\r\n return {\r\n totalInjected: injected.size,\r\n pendingCount: pending.length,\r\n hasBatchScheduled: _state.rafHandle !== null,\r\n }\r\n}","/**\r\n * tailwind-styled-v4 — TwCssInjector\r\n *\r\n * React Server Component — inject route-specific CSS ke <head>.\r\n * Zero client JS, no hydration overhead, streaming-friendly.\r\n *\r\n * Pipeline:\r\n * 1. withTailwindStyled webpack plugin emit CSS manifest ke .next/static/css/tw/\r\n * 2. TwCssInjector baca manifest → inject <style> inline per route\r\n *\r\n * Usage:\r\n * // app/layout.tsx\r\n * import { TwCssInjector } from \"tailwind-styled-v4/runtime-css\"\r\n *\r\n * export default function Layout({ children }) {\r\n * return (\r\n * <html>\r\n * <head><TwCssInjector /></head>\r\n * <body>{children}</body>\r\n * </html>\r\n * )\r\n * }\r\n */\r\n\r\nimport React from \"react\"\r\n\r\ninterface CssInjectorProps {\r\n /** Route spesifik. Default: auto-detect */\r\n route?: string\r\n /** Inject global CSS juga. Default: true */\r\n includeGlobal?: boolean\r\n /** Minify inline CSS. Default: true */\r\n minify?: boolean\r\n /** CSS directory. Default: .next/static/css/tw */\r\n cssDir?: string\r\n}\r\n\r\n/**\r\n * Server Component — inject CSS per route ke <head>.\r\n * Baca dari manifest yang di-emit oleh TwCssManifestPlugin.\r\n */\r\nexport async function TwCssInjector(props: CssInjectorProps = {}): Promise<React.ReactElement> {\r\n const { route, includeGlobal = true, minify = true, cssDir } = props\r\n\r\n // Dynamic import fs — hanya jalan di server\r\n let fs: typeof import(\"node:fs\") | null = null\r\n let path: typeof import(\"node:path\") | null = null\r\n try {\r\n fs = await import(\"node:fs\")\r\n path = await import(\"node:path\")\r\n } catch {\r\n return React.createElement(React.Fragment, null)\r\n }\r\n\r\n const resolvedDir = cssDir\r\n ?? path.join(process.cwd(), \".next\", \"static\", \"css\", \"tw\")\r\n\r\n const manifestPath = path.join(resolvedDir, \"css-manifest.json\")\r\n\r\n // Baca manifest\r\n let manifest: { routes?: Record<string, string> } = {}\r\n try {\r\n if (fs.existsSync(manifestPath)) {\r\n manifest = JSON.parse(fs.readFileSync(manifestPath, \"utf-8\"))\r\n }\r\n } catch {\r\n // Manifest tidak ada — mungkin belum build atau native binding belum ready\r\n return React.createElement(React.Fragment, null)\r\n }\r\n\r\n const cssChunks: string[] = []\r\n\r\n // Global CSS (_global.css)\r\n if (includeGlobal && manifest.routes?.[\"__global\"]) {\r\n const globalPath = path.join(resolvedDir, manifest.routes[\"__global\"])\r\n const css = readFile(fs, globalPath)\r\n if (css) cssChunks.push(css)\r\n }\r\n\r\n // Route-specific CSS\r\n const targetRoute = route ?? \"/\"\r\n if (manifest.routes?.[targetRoute]) {\r\n const routePath = path.join(resolvedDir, manifest.routes[targetRoute])\r\n const css = readFile(fs, routePath)\r\n if (css) cssChunks.push(css)\r\n }\r\n\r\n if (cssChunks.length === 0) return React.createElement(React.Fragment, null)\r\n\r\n const combined = cssChunks.join(\"\\n\")\r\n const final = minify ? minifyCss(combined) : combined\r\n\r\n return React.createElement(\"style\", {\r\n dangerouslySetInnerHTML: { __html: final },\r\n \"data-tw-route\": targetRoute,\r\n \"data-tw-injector\": \"true\",\r\n })\r\n}\r\n\r\n/**\r\n * Hook untuk client components — CSS sudah di-handle TwCssInjector di server.\r\n */\r\nexport function useTwClasses(classes: string): string {\r\n return classes\r\n}\r\n\r\n// Helpers\r\nfunction readFile(fs: typeof import(\"node:fs\"), filepath: string): string | null {\r\n try {\r\n if (fs.existsSync(filepath)) return fs.readFileSync(filepath, \"utf-8\")\r\n } catch {}\r\n return null\r\n}\r\n\r\nfunction minifyCss(css: string): string {\r\n return css\r\n .replace(/\\/\\*[^*]*\\*+([^/*][^*]*\\*+)*\\//g, \"\")\r\n .replace(/\\s+/g, \" \")\r\n .replace(/\\s*{\\s*/g, \"{\")\r\n .replace(/\\s*}\\s*/g, \"}\")\r\n .replace(/\\s*;\\s*/g, \";\")\r\n .trim()\r\n}"]}