tailwind-styled-v4 5.0.9 → 5.0.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +15 -1
- package/dist/{analyzeWorkspace-DuJKh7Ty.d.mts → analyzeWorkspace-BS5O4rhC.d.mts} +47 -2
- package/dist/{analyzeWorkspace-Ct_NTAWt.d.ts → analyzeWorkspace-DDOQdzzI.d.ts} +47 -2
- package/dist/analyzer.d.mts +5 -3
- package/dist/analyzer.d.ts +5 -3
- package/dist/analyzer.js +563 -468
- package/dist/analyzer.js.map +1 -1
- package/dist/analyzer.mjs +562 -467
- package/dist/analyzer.mjs.map +1 -1
- package/dist/animate.d.mts +4 -7
- package/dist/animate.d.ts +4 -7
- package/dist/animate.js +171 -265
- package/dist/animate.js.map +1 -1
- package/dist/animate.mjs +165 -264
- package/dist/animate.mjs.map +1 -1
- package/dist/atomic.d.mts +22 -1
- package/dist/atomic.d.ts +22 -1
- package/dist/atomic.js +221 -165
- package/dist/atomic.js.map +1 -1
- package/dist/atomic.mjs +200 -165
- package/dist/atomic.mjs.map +1 -1
- package/dist/cli.d.mts +60 -1
- package/dist/cli.d.ts +60 -1
- package/dist/cli.js +1261 -1517
- package/dist/cli.js.map +1 -1
- package/dist/cli.mjs +1238 -1513
- package/dist/cli.mjs.map +1 -1
- package/dist/compiler.d.mts +38 -7
- package/dist/compiler.d.ts +38 -7
- package/dist/compiler.js +174 -197
- package/dist/compiler.js.map +1 -1
- package/dist/compiler.mjs +151 -194
- package/dist/compiler.mjs.map +1 -1
- package/dist/devtools.js +7 -31
- package/dist/devtools.js.map +1 -1
- package/dist/devtools.mjs +7 -31
- package/dist/devtools.mjs.map +1 -1
- package/dist/engine.d.mts +134 -63
- package/dist/engine.d.ts +134 -63
- package/dist/engine.js +2863 -2482
- package/dist/engine.js.map +1 -1
- package/dist/engine.mjs +2852 -2485
- package/dist/engine.mjs.map +1 -1
- package/dist/{index-eWAocnD2.d.mts → index-NDINUhLN.d.mts} +3 -1
- package/dist/{index-eWAocnD2.d.ts → index-NDINUhLN.d.ts} +3 -1
- package/dist/index.d.mts +45 -32
- package/dist/index.d.ts +45 -32
- package/dist/index.js +271 -158
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +251 -158
- package/dist/index.mjs.map +1 -1
- package/dist/{liveTokenEngine-DSUk88P6.d.ts → liveTokenEngine-CN9ian1R.d.ts} +1 -1
- package/dist/{liveTokenEngine-CX5_0c4q.d.mts → liveTokenEngine-DKoWRtqH.d.mts} +1 -1
- package/dist/next.js +20 -39
- package/dist/next.js.map +1 -1
- package/dist/next.mjs +18 -37
- package/dist/next.mjs.map +1 -1
- package/dist/plugin-api.d.mts +8 -2
- package/dist/plugin-api.d.ts +8 -2
- package/dist/plugin-api.js +14 -2
- package/dist/plugin-api.js.map +1 -1
- package/dist/plugin-api.mjs +14 -3
- package/dist/plugin-api.mjs.map +1 -1
- package/dist/plugin-registry.js +51 -11
- package/dist/plugin-registry.js.map +1 -1
- package/dist/plugin-registry.mjs +51 -11
- package/dist/plugin-registry.mjs.map +1 -1
- package/dist/plugin.d.mts +5 -7
- package/dist/plugin.d.ts +5 -7
- package/dist/plugin.js +16 -15
- package/dist/plugin.js.map +1 -1
- package/dist/plugin.mjs +16 -16
- package/dist/plugin.mjs.map +1 -1
- package/dist/rspack.js +17 -38
- package/dist/rspack.js.map +1 -1
- package/dist/rspack.mjs +15 -36
- package/dist/rspack.mjs.map +1 -1
- package/dist/runtime.d.mts +2 -2
- package/dist/runtime.d.ts +2 -2
- package/dist/scanner.d.mts +10 -1
- package/dist/scanner.d.ts +10 -1
- package/dist/scanner.js +298 -124
- package/dist/scanner.js.map +1 -1
- package/dist/scanner.mjs +296 -124
- package/dist/scanner.mjs.map +1 -1
- package/dist/shared.d.mts +1 -1
- package/dist/shared.d.ts +1 -1
- package/dist/shared.js +104 -176
- package/dist/shared.js.map +1 -1
- package/dist/shared.mjs +85 -176
- package/dist/shared.mjs.map +1 -1
- package/dist/storybook-addon.d.mts +1 -1
- package/dist/storybook-addon.d.ts +1 -1
- package/dist/svelte.d.mts +1 -1
- package/dist/svelte.d.ts +1 -1
- package/dist/svelte.js +166 -3
- package/dist/svelte.js.map +1 -1
- package/dist/svelte.mjs +143 -1
- package/dist/svelte.mjs.map +1 -1
- package/dist/syntax.js +21 -21
- package/dist/syntax.js.map +1 -1
- package/dist/syntax.mjs +21 -21
- package/dist/syntax.mjs.map +1 -1
- package/dist/testing.js +9 -1
- package/dist/testing.js.map +1 -1
- package/dist/testing.mjs +9 -1
- package/dist/testing.mjs.map +1 -1
- package/dist/theme.d.mts +2 -2
- package/dist/theme.d.ts +2 -2
- package/dist/theme.js +40 -112
- package/dist/theme.js.map +1 -1
- package/dist/theme.mjs +37 -110
- package/dist/theme.mjs.map +1 -1
- package/dist/turbopackLoader.js +79 -124
- package/dist/turbopackLoader.js.map +1 -1
- package/dist/turbopackLoader.mjs +63 -122
- package/dist/turbopackLoader.mjs.map +1 -1
- package/dist/tw.js +1256 -1517
- package/dist/tw.js.map +1 -1
- package/dist/tw.mjs +1236 -1513
- package/dist/tw.mjs.map +1 -1
- package/dist/vite.js +1783 -823
- package/dist/vite.js.map +1 -1
- package/dist/vite.mjs +1767 -821
- package/dist/vite.mjs.map +1 -1
- package/dist/vue.d.mts +1 -1
- package/dist/vue.d.ts +1 -1
- package/dist/vue.js +165 -4
- package/dist/vue.js.map +1 -1
- package/dist/vue.mjs +141 -1
- package/dist/vue.mjs.map +1 -1
- package/dist/webpackLoader.js +65 -108
- package/dist/webpackLoader.js.map +1 -1
- package/dist/webpackLoader.mjs +45 -104
- package/dist/webpackLoader.mjs.map +1 -1
- package/native/tailwind-styled-native.node +0 -0
- package/package.json +22 -24
package/dist/next.js
CHANGED
|
@@ -1,15 +1,17 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var zod = require('zod');
|
|
4
|
-
var
|
|
4
|
+
var fs2 = require('fs');
|
|
5
5
|
var module$1 = require('module');
|
|
6
|
-
var
|
|
6
|
+
var path2 = require('path');
|
|
7
|
+
require('crypto');
|
|
8
|
+
require('url');
|
|
7
9
|
|
|
8
10
|
var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
|
|
9
11
|
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
10
12
|
|
|
11
|
-
var
|
|
12
|
-
var
|
|
13
|
+
var fs2__default = /*#__PURE__*/_interopDefault(fs2);
|
|
14
|
+
var path2__default = /*#__PURE__*/_interopDefault(path2);
|
|
13
15
|
|
|
14
16
|
/* tailwind-styled-v4 v5.0.4 | MIT | https://github.com/dictionar32/tailwind-styled-v4 */
|
|
15
17
|
var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
|
|
@@ -50,10 +52,13 @@ function getDirnameFromUrl(importMetaUrl) {
|
|
|
50
52
|
if (isBrowser) return "";
|
|
51
53
|
try {
|
|
52
54
|
const nodeUrl = __require(NODE_URL);
|
|
53
|
-
|
|
55
|
+
const nodePath = __require(NODE_PATH);
|
|
56
|
+
return nodePath.dirname(nodeUrl.fileURLToPath(importMetaUrl));
|
|
54
57
|
} catch {
|
|
55
58
|
if (importMetaUrl.startsWith("file://")) {
|
|
56
|
-
|
|
59
|
+
const filePath = importMetaUrl.slice(7);
|
|
60
|
+
const lastSlash = filePath.lastIndexOf("/");
|
|
61
|
+
return lastSlash >= 0 ? filePath.slice(0, lastSlash) : filePath;
|
|
57
62
|
}
|
|
58
63
|
return "";
|
|
59
64
|
}
|
|
@@ -67,11 +72,11 @@ function resolvePath(...segments) {
|
|
|
67
72
|
return segments.join("/").replace(/\/+/g, "/");
|
|
68
73
|
}
|
|
69
74
|
}
|
|
70
|
-
function existsSync(
|
|
75
|
+
function existsSync(path3) {
|
|
71
76
|
if (isBrowser) return false;
|
|
72
77
|
try {
|
|
73
78
|
const nodeFs = __require(NODE_FS);
|
|
74
|
-
return nodeFs.existsSync(
|
|
79
|
+
return nodeFs.existsSync(path3);
|
|
75
80
|
} catch {
|
|
76
81
|
return false;
|
|
77
82
|
}
|
|
@@ -123,31 +128,7 @@ function resolveLoaderPath(loaderBasename, importMetaUrl) {
|
|
|
123
128
|
}
|
|
124
129
|
|
|
125
130
|
// packages/domain/shared/src/index.ts
|
|
126
|
-
|
|
127
|
-
var nodeModuleRef = null;
|
|
128
|
-
function getNodeModuleRef() {
|
|
129
|
-
if (isBrowser2) return null;
|
|
130
|
-
if (nodeModuleRef !== null) return nodeModuleRef;
|
|
131
|
-
try {
|
|
132
|
-
const test = typeof __require === "function" ? __require("module") : null;
|
|
133
|
-
nodeModuleRef = test;
|
|
134
|
-
return test;
|
|
135
|
-
} catch {
|
|
136
|
-
nodeModuleRef = null;
|
|
137
|
-
return null;
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
function getRequire() {
|
|
141
|
-
if (isBrowser2) return (() => {
|
|
142
|
-
throw new Error("require not available in browser");
|
|
143
|
-
});
|
|
144
|
-
const nodeRequire = getNodeModuleRef();
|
|
145
|
-
if (!nodeRequire) return (() => {
|
|
146
|
-
throw new Error("require not available");
|
|
147
|
-
});
|
|
148
|
-
return nodeRequire.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('next.js', document.baseURI).href)));
|
|
149
|
-
}
|
|
150
|
-
getRequire();
|
|
131
|
+
module$1.createRequire((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('next.js', document.baseURI).href)));
|
|
151
132
|
|
|
152
133
|
// packages/presentation/next/src/withTailwindStyled.ts
|
|
153
134
|
function getDirnameFromUrl2(importMetaUrl) {
|
|
@@ -171,12 +152,12 @@ var resolveLoaderPath2 = (basename) => {
|
|
|
171
152
|
} catch {
|
|
172
153
|
const runtimeDir = resolveRuntimeDir();
|
|
173
154
|
const candidates = [
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
155
|
+
path2__default.default.resolve(runtimeDir, `${basename}.mjs`),
|
|
156
|
+
path2__default.default.resolve(runtimeDir, `${basename}.js`),
|
|
157
|
+
path2__default.default.resolve(runtimeDir, `${basename}.cjs`)
|
|
177
158
|
];
|
|
178
159
|
for (const candidate of candidates) {
|
|
179
|
-
if (
|
|
160
|
+
if (fs2__default.default.existsSync(candidate)) {
|
|
180
161
|
return candidate;
|
|
181
162
|
}
|
|
182
163
|
}
|
|
@@ -214,7 +195,7 @@ var createLoaderOptions = (options) => {
|
|
|
214
195
|
preserveImports: true
|
|
215
196
|
};
|
|
216
197
|
if (options.verbose !== void 0) opts.verbose = options.verbose;
|
|
217
|
-
opts.safelistPath = options.safelistPath ??
|
|
198
|
+
opts.safelistPath = options.safelistPath ?? path2__default.default.join(process.cwd(), "__tw_safelist.css");
|
|
218
199
|
return Object.freeze(opts);
|
|
219
200
|
};
|
|
220
201
|
var buildTurbopackRules = (loaderPath, loaderOptions) => {
|
|
@@ -226,7 +207,7 @@ var buildTurbopackRules = (loaderPath, loaderOptions) => {
|
|
|
226
207
|
])
|
|
227
208
|
);
|
|
228
209
|
};
|
|
229
|
-
var normalizeLoaderPath = (loaderPath) =>
|
|
210
|
+
var normalizeLoaderPath = (loaderPath) => path2__default.default.resolve(loaderPath);
|
|
230
211
|
var applyWebpackRule = (config, options, loaderPath) => {
|
|
231
212
|
const loaderOptions = createLoaderOptions(options);
|
|
232
213
|
const rules = config.module?.rules ?? [];
|
package/dist/next.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../packages/presentation/next/src/schemas.ts","../packages/domain/shared/src/workerResolver.ts","../packages/domain/shared/src/index.ts","../packages/presentation/next/src/withTailwindStyled.ts"],"names":["z","path","isBrowser","getDirnameFromUrl","lastSlash","require","createRequire","resolveLoaderPath","fs"],"mappings":"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","file":"next.js","sourcesContent":["import { z } from \"zod\"\r\n\r\nconst formatIssues = (error: z.ZodError): string =>\r\n error.issues\r\n .map((issue) => {\r\n const p = issue.path.length > 0 ? issue.path.join(\".\") : \"<root>\"\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 throw new TypeError(`${label}: ${formatIssues(parsed.error)}`)\r\n}\r\n\r\nexport const NextAdapterOptionsSchema = z.object({\r\n mode: z.literal(\"zero-runtime\").optional(),\r\n autoClientBoundary: z.boolean().optional(),\r\n addDataAttr: z.boolean().optional(),\r\n hoist: z.boolean().optional(),\r\n routeCss: z.boolean().optional(),\r\n incremental: z.boolean().optional(),\r\n verbose: z.boolean().optional(),\r\n include: z.instanceof(RegExp).optional(),\r\n exclude: z.instanceof(RegExp).optional(),\r\n})\r\n\r\nexport type NextAdapterOptionsInput = z.infer<typeof NextAdapterOptionsSchema>\r\n\r\nexport const parseNextAdapterOptions = (options: unknown) =>\r\n parseWithSchema(NextAdapterOptionsSchema, options ?? {}, \"next adapter options are invalid\")\r\n","/**\r\n * Worker/bootstrap path resolution untuk artifact release safety.\r\n * Dari monorepo checklist: \"Perkuat worker/bootstrap path agar artifact release aman\"\r\n *\r\n * Masalah: path ke worker/loader script bisa berbeda antara:\r\n * - Development (src/*.ts)\r\n * - Built dist (dist/*.js / dist/*.cjs)\r\n * - Packed npm artifact (dist/ saja, tanpa src/)\r\n *\r\n * Solusi: resolve path secara hierarchical dengan fallback yang eksplisit.\r\n */\r\n\r\nconst isBrowser = typeof window !== \"undefined\" || typeof document !== \"undefined\"\r\n\r\nconst NODE_URL = typeof window === \"undefined\" || typeof document === \"undefined\" ? \"node:url\" : null\r\nconst NODE_FS = typeof window === \"undefined\" || typeof document === \"undefined\" ? \"node:fs\" : null\r\nconst NODE_PATH = typeof window === \"undefined\" || typeof document === \"undefined\" ? \"node:path\" : null\r\n\r\nfunction getDirnameFromUrl(importMetaUrl: string): string {\r\n if (!importMetaUrl) return \"\"\r\n if (isBrowser) return \"\"\r\n\r\n try {\r\n const nodeUrl = require(NODE_URL!)\r\n return nodeUrl.fileURLToPath(importMetaUrl)\r\n } catch {\r\n if (importMetaUrl.startsWith(\"file://\")) {\r\n return importMetaUrl.slice(7)\r\n }\r\n return \"\"\r\n }\r\n}\r\n\r\nfunction resolvePath(...segments: string[]): string {\r\n if (isBrowser) return segments.join(\"/\").replace(/\\/+/g, \"/\")\r\n try {\r\n const nodePath = require(NODE_PATH!)\r\n return nodePath.resolve(...segments)\r\n } catch {\r\n return segments.join(\"/\").replace(/\\/+/g, \"/\")\r\n }\r\n}\r\n\r\nfunction existsSync(path: string): boolean {\r\n if (isBrowser) return false\r\n try {\r\n const nodeFs = require(NODE_FS!)\r\n return nodeFs.existsSync(path)\r\n } catch {\r\n return false\r\n }\r\n}\r\n\r\nexport interface WorkerPathOptions {\r\n /** Nama file worker tanpa extension */\r\n basename: string\r\n /** Import meta URL dari caller module */\r\n importMetaUrl: string\r\n /** Extensions yang dicoba secara urutan (default: [\".cjs\", \".js\", \".mjs\"]) */\r\n extensions?: string[]\r\n /** Sub-directories relatif dari runtimeDir yang dicoba */\r\n subdirs?: string[]\r\n /** Throw jika tidak ditemukan (default: true) */\r\n required?: boolean\r\n}\r\n\r\nexport interface WorkerPathResult {\r\n /** Absolute path ke worker file */\r\n path: string\r\n /** Extension yang ditemukan */\r\n extension: string\r\n /** Apakah ini dari CJS atau ESM artifact */\r\n format: \"cjs\" | \"esm\"\r\n}\r\n\r\n/**\r\n * Resolve worker/loader script path yang aman untuk release artifacts.\r\n *\r\n * Prioritas:\r\n * 1. CJS (.cjs) — untuk Node.js workers yang butuh require()\r\n * 2. JS (.js) — bundled output\r\n * 3. MJS (.mjs) — explicit ESM\r\n *\r\n * @example\r\n * const workerPath = resolveWorkerPath({\r\n * basename: \"scanner-worker\",\r\n * importMetaUrl: import.meta.url,\r\n * })\r\n * // → \"/path/to/dist/scanner-worker.cjs\"\r\n */\r\nexport function resolveWorkerPath(opts: WorkerPathOptions): WorkerPathResult {\r\n if (isBrowser) {\r\n throw new Error(\"Worker resolution not available in browser\")\r\n }\r\n\r\n const {\r\n basename,\r\n importMetaUrl,\r\n extensions = [\".cjs\", \".js\", \".mjs\"],\r\n subdirs = [\".\", \"workers\", \"lib\"],\r\n required = true,\r\n } = opts\r\n\r\n const runtimeDir = getDirnameFromUrl(importMetaUrl)\r\n\r\n // Try each subdir + extension combination\r\n for (const subdir of subdirs) {\r\n for (const ext of extensions) {\r\n const candidate = resolvePath(runtimeDir, subdir, `${basename}${ext}`)\r\n if (existsSync(candidate)) {\r\n return {\r\n path: candidate,\r\n extension: ext,\r\n format: ext === \".cjs\" ? \"cjs\" : \"esm\",\r\n }\r\n }\r\n }\r\n }\r\n\r\n if (required) {\r\n const tried = subdirs.flatMap(d =>\r\n extensions.map(e => resolvePath(runtimeDir, d, `${basename}${e}`))\r\n )\r\n throw new Error(\r\n `[worker-resolver] Could not find worker script \"${basename}\".\\n` +\r\n `Tried:\\n${tried.map(p => ` - ${p}`).join(\"\\n\")}\\n` +\r\n `Ensure the package is built: npm run build`\r\n )\r\n }\r\n\r\n return { path: \"\", extension: \"\", format: \"cjs\" }\r\n}\r\n\r\n/**\r\n * Resolve loader path (untuk webpack/rspack/vite loaders).\r\n * Same as resolveWorkerPath but dengan nama yang lebih eksplisit.\r\n */\r\nexport function resolveLoaderPath(\r\n loaderBasename: string,\r\n importMetaUrl: string\r\n): string {\r\n return resolveWorkerPath({\r\n basename: loaderBasename,\r\n importMetaUrl,\r\n extensions: [\".cjs\", \".js\", \".mjs\"],\r\n subdirs: [\".\", \"loaders\", \"lib\"],\r\n }).path\r\n}","const isBrowser = typeof window !== \"undefined\" || typeof document !== \"undefined\"\r\n\r\n// ESM-safe require detection\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 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 _nodeCrypto: any = null\r\nlet _nodeFs: any = null\r\nlet _nodeModule: any = null\r\nlet _nodePath: any = null\r\nlet _nodeUrl: any = null\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 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 getNodeModule() {\r\n if (isBrowser) throw new Error(\"node:module not available in browser\")\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) throw new Error(\"require not available\")\r\n if (!_nodeModule) _nodeModule = nodeRequire\r\n return _nodeModule!\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\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 if (isBrowser) {\r\n return { binding: null, loadErrors: [{ path: \"\", message: \"Native bindings not available in browser\" }] }\r\n }\r\n \r\n const { runtimeDir, candidates, isValid } = options\r\n const loadErrors: Array<{ path: string; message: string }> = []\r\n const path = getNodePath()\r\n const fs = getNodeFs()\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\nfunction getRequire(): NodeRequire {\r\n if (isBrowser) return (() => { throw new Error(\"require not available in browser\") }) as unknown as NodeRequire\r\n const nodeRequire = getNodeModuleRef()\r\n if (!nodeRequire) return (() => { throw new Error(\"require not available\") }) as unknown as NodeRequire\r\n return nodeRequire.createRequire(import.meta.url)\r\n}\r\n\r\nconst _require = getRequire()\r\n\r\nfunction requireNativeModule(path: string): unknown {\r\n return _require(path)\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}\r\n\r\nexport function resolveNativeBindingCandidates(options: ResolveCandidatesOptions): string[] {\r\n if (isBrowser) return []\r\n \r\n const { runtimeDir, envVarNames = [], includeDefaultCandidates = true, enforceNodeExtensionForEnvPath = false } = options\r\n const candidates: string[] = []\r\n const path = getNodePath()\r\n const fs = getNodeFs()\r\n\r\n for (const envVar of envVarNames) {\r\n const envPath = process.env[envVar]\r\n if (envPath) {\r\n if (enforceNodeExtensionForEnvPath && !envPath.endsWith(\".node\")) {\r\n candidates.push(envPath + \".node\")\r\n } else {\r\n candidates.push(envPath)\r\n }\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 const entries = fs.readdirSync(runtimeDir)\r\n for (const entry of entries) {\r\n if (entry.endsWith(\".node\")) {\r\n candidates.push(entry)\r\n }\r\n }\r\n } catch {\r\n // ignore read errors\r\n }\r\n }\r\n\r\n const platform = typeof process !== \"undefined\" ? process.platform : \"\"\r\n const ext = platform === \"win32\" ? \".dll\" : platform === \"darwin\" ? \".dylib\" : \".so\"\r\n const defaultBindingName = `tailwind_styled_parser${ext}`\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"..\", \"..\", \"native\", defaultBindingName))\r\n candidates.push(path.resolve(runtimeDir, \"..\", \"..\", \"..\", \"..\", \"native\", defaultBindingName))\r\n candidates.push(path.resolve(process.cwd(), \"native\", defaultBindingName))\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 (isBrowser) return \"\"\r\n \r\n if (dir) return getNodePath().resolve(dir)\r\n try {\r\n return getNodeUrl().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 if (isBrowser) {\r\n // Simple hash fallback for browser\r\n let hash = 0\r\n for (let i = 0; i < content.length; i++) {\r\n const char = content.charCodeAt(i)\r\n hash = ((hash << 5) - hash) + char\r\n hash = hash & hash\r\n }\r\n return Math.abs(hash).toString(16).slice(0, length ?? 8)\r\n }\r\n const hash = getNodeCrypto().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","import fs from \"node:fs\"\r\nimport { createRequire } from \"node:module\"\r\nimport path from \"node:path\"\r\n\r\nfunction getDirnameFromUrl(importMetaUrl: string): string {\r\n if (typeof importMetaUrl !== 'string') return ''\r\n // Simple URL parsing without Node.js modules\r\n if (importMetaUrl.startsWith('file://')) {\r\n let withoutFile = importMetaUrl.slice(7)\r\n // On Windows, file URLs can be like file:///C:/path\r\n if (withoutFile[0] === '/' && withoutFile[2] === ':') {\r\n withoutFile = withoutFile.slice(1) // Remove leading / from C:/\r\n }\r\n const lastSlash = Math.max(withoutFile.lastIndexOf('/'), withoutFile.lastIndexOf('\\\\'))\r\n return lastSlash > 0 ? withoutFile.slice(0, lastSlash) : '/'\r\n }\r\n // Fallback for other URL types\r\n const lastSlash = Math.max(importMetaUrl.lastIndexOf('/'), importMetaUrl.lastIndexOf('\\\\'))\r\n return lastSlash > 0 ? importMetaUrl.slice(0, lastSlash) : ''\r\n}\r\n\r\nimport { resolveLoaderPath as sharedResolveLoaderPath } from \"@tailwind-styled/shared\"\r\n\r\nimport { parseNextAdapterOptions } from \"./schemas\"\r\n\r\nconst require = createRequire(import.meta.url)\r\n\r\ninterface TailwindStyledLoaderOptions {\r\n /** @deprecated — handled by engine internally */\r\n mode?: \"zero-runtime\"\r\n /** @deprecated — handled by engine internally */\r\n autoClientBoundary?: boolean\r\n /** @deprecated — handled by engine internally */\r\n addDataAttr?: boolean\r\n /** @deprecated — handled by engine internally */\r\n hoist?: boolean\r\n /** @deprecated — handled by engine internally */\r\n routeCss?: boolean\r\n /** @deprecated — handled by engine internally */\r\n incremental?: boolean\r\n verbose?: boolean\r\n preserveImports?: boolean\r\n safelistPath?: string\r\n}\r\n\r\nexport interface TailwindStyledNextOptions {\r\n /** @deprecated — handled by engine internally */\r\n mode?: \"zero-runtime\"\r\n /** @deprecated — handled by engine internally */\r\n autoClientBoundary?: boolean\r\n /** @deprecated — handled by engine internally */\r\n addDataAttr?: boolean\r\n /** @deprecated — handled by engine internally */\r\n hoist?: boolean\r\n /** @deprecated — handled by engine internally */\r\n routeCss?: boolean\r\n /** @deprecated — handled by engine internally */\r\n incremental?: boolean\r\n /** Show detailed loader output */\r\n verbose?: boolean\r\n /** Path to generated safelist CSS file. Default: <cwd>/__tw_safelist.css */\r\n safelistPath?: string\r\n include?: RegExp\r\n exclude?: RegExp\r\n}\r\n\r\nimport type { NextConfig } from \"next\"\r\n\r\n// Derive webpack types directly from Next.js — always in sync with installed version\r\ntype NextWebpackFn = NonNullable<NextConfig[\"webpack\"]>\r\ntype NextWebpackConfig = Parameters<NextWebpackFn>[0]\r\ntype NextWebpackOptions = Parameters<NextWebpackFn>[1]\r\n\r\n// Derive turbopack rule types from NextConfig\r\ntype TurboRules = NonNullable<NonNullable<NextConfig[\"turbopack\"]>[\"rules\"]>\r\ntype TurbopackLoaderRule = TurboRules[string]\r\n\r\n// Derive webpack module rule type for safe iteration\r\ntype ModuleRule = NonNullable<NonNullable<NextWebpackConfig[\"module\"]>[\"rules\"]>[number]\r\ntype RuleUseEntry = { loader?: string; options?: unknown }\r\n\r\ninterface NextWebpackUseEntry {\r\n loader: string\r\n options?: TailwindStyledLoaderOptions\r\n}\r\n\r\ninterface NextWebpackRule {\r\n test?: RegExp\r\n exclude?: RegExp\r\n enforce?: \"pre\" | \"post\"\r\n use?: NextWebpackUseEntry[]\r\n}\r\n\r\n\r\nconst resolveRuntimeDir = (): string => getDirnameFromUrl(import.meta.url)\r\n\r\nconst resolveLoaderPath = (basename: string): string => {\r\n try {\r\n return sharedResolveLoaderPath(basename, import.meta.url)\r\n } catch {\r\n const runtimeDir = resolveRuntimeDir()\r\n const candidates = [\r\n path.resolve(runtimeDir, `${basename}.mjs`),\r\n path.resolve(runtimeDir, `${basename}.js`),\r\n path.resolve(runtimeDir, `${basename}.cjs`),\r\n ]\r\n\r\n for (const candidate of candidates) {\r\n if (fs.existsSync(candidate)) {\r\n return candidate\r\n }\r\n }\r\n\r\n throw new Error(\r\n `[tailwind-styled] Loader not found for '${basename}'. Checked: ${candidates.join(\", \")}`\r\n )\r\n }\r\n}\r\n\r\nfunction checkNextVersion(): void {\r\n try {\r\n const pkgPath = require.resolve(\"next/package.json\")\r\n const { version } = require(pkgPath)\r\n const major = Number.parseInt(version.split(\".\")[0], 10)\r\n if (major < 15) {\r\n console.warn(\r\n `[tailwind-styled] Next.js ${version} detected. Recommended: 15+ for full Turbopack support.`\r\n )\r\n }\r\n } catch {\r\n // next not resolvable — skip check\r\n }\r\n}\r\n\r\nconst DEFAULT_INCLUDE = /\\.[jt]sx?$/\r\nconst DEFAULT_EXCLUDE = /node_modules/\r\n\r\n/**\r\n * Next.js App Router entry-point files yang TIDAK boleh diproses oleh TW loader.\r\n *\r\n * Mengapa: file-file ini adalah RSC boundary points yang dikelola Next.js secara khusus.\r\n * Jika loader menginjeksi TRANSFORM_MARKER atau memodifikasi source-nya—bahkan ketika\r\n * `changed: false`—Next.js/React Compiler kehilangan sinyal bahwa file adalah pure RSC,\r\n * sehingga locale injection dari Accept-Language header (Next.js 16+) tidak konsisten\r\n * antara SSR pass (server: lang=\"id\") dan hydration pass (client: lang=\"en\").\r\n *\r\n * File yang dikecualikan: layout, page, loading, error, not-found, template, default\r\n * semuanya adalah Next.js segment conventions yang tidak boleh disentuh loader pihak ketiga.\r\n */\r\nconst NEXT_RSC_ENTRIES =\r\n /(?:^|[\\\\/])(?:layout|page|loading|error|not-found|template|default)\\.[jt]sx?$/\r\n\r\n/**\r\n * Gabungkan user-supplied exclude dengan NEXT_RSC_ENTRIES.\r\n * Menggunakan non-capturing group agar tidak interferensi dengan capture group lain.\r\n */\r\nconst buildExcludePattern = (userExclude?: RegExp): RegExp => {\r\n if (!userExclude) return new RegExp(`(?:${DEFAULT_EXCLUDE.source})|(?:${NEXT_RSC_ENTRIES.source})`)\r\n return new RegExp(`(?:${userExclude.source})|(?:${NEXT_RSC_ENTRIES.source})`)\r\n}\r\n\r\nconst createLoaderOptions = (options: TailwindStyledNextOptions): Readonly<TailwindStyledLoaderOptions> => {\r\n // Deprecated options — still passed for loader backward compat but engine ignores them\r\n const opts: TailwindStyledLoaderOptions = {\r\n mode: \"zero-runtime\", // only supported mode\r\n autoClientBoundary: true, // always on (engine handles it)\r\n preserveImports: true,\r\n }\r\n if (options.verbose !== undefined) opts.verbose = options.verbose\r\n opts.safelistPath = options.safelistPath ?? path.join(process.cwd(), \"__tw_safelist.css\")\r\n return Object.freeze(opts)\r\n}\r\n\r\nconst buildTurbopackRules = (\r\n loaderPath: string,\r\n loaderOptions: TailwindStyledLoaderOptions\r\n): TurboRules => {\r\n const extensions = [\"js\", \"jsx\", \"ts\", \"tsx\", \"mjs\", \"cjs\"]\r\n return Object.fromEntries(\r\n extensions.map((ext) => [\r\n `*.${ext}`,\r\n { loaders: [{ loader: loaderPath, options: loaderOptions }] },\r\n ])\r\n ) as TurboRules\r\n}\r\n\r\nconst normalizeLoaderPath = (loaderPath: string): string => path.resolve(loaderPath)\r\n\r\nconst applyWebpackRule = (\r\n config: NextWebpackConfig,\r\n options: TailwindStyledNextOptions,\r\n loaderPath: string\r\n): NextWebpackConfig => {\r\n const loaderOptions = createLoaderOptions(options)\r\n const rules = config.module?.rules ?? []\r\n const normalizedLoaderPath = normalizeLoaderPath(loaderPath)\r\n\r\n const alreadyRegistered = rules.some(\r\n (rule: ModuleRule) =>\r\n Array.isArray(rule?.use) &&\r\n (rule.use as RuleUseEntry[]).some(\r\n (entry: RuleUseEntry) =>\r\n typeof entry.loader === \"string\" &&\r\n normalizeLoaderPath(entry.loader) === normalizedLoaderPath\r\n )\r\n )\r\n\r\n if (alreadyRegistered) return config\r\n\r\n const tailwindStyledRule: NextWebpackRule = {\r\n test: options.include ?? DEFAULT_INCLUDE,\r\n // Selalu kecualikan Next.js RSC entry files (layout, page, dll) bahkan jika\r\n // user menyuplai exclude pattern sendiri — lihat buildExcludePattern.\r\n exclude: buildExcludePattern(options.exclude),\r\n enforce: \"pre\",\r\n use: [{ loader: loaderPath, options: loaderOptions }],\r\n }\r\n\r\n config.module = {\r\n ...(config.module ?? {}),\r\n rules: [...rules, tailwindStyledRule],\r\n }\r\n\r\n const externalPackages = [\r\n \"@tailwind-styled/shared\",\r\n \"@tailwind-styled/compiler\", \r\n \"@tailwind-styled/engine\",\r\n \"@tailwind-styled/plugin\",\r\n \"@tailwind-styled/core\",\r\n \"@tailwind-styled/runtime-css\",\r\n \"@tailwind-styled/runtime\",\r\n \"@tailwind-styled/scanner\",\r\n \"@tailwind-styled/analyzer\",\r\n \"@tailwind-styled/theme\",\r\n \"@tailwind-styled/preset\",\r\n ]\r\n\r\n type ExternalsArray = Extract<NonNullable<NextWebpackConfig[\"externals\"]>, readonly unknown[]>\r\n type ExternalItem = ExternalsArray[number]\r\n\r\n if (!config.externals) {\r\n config.externals = []\r\n }\r\n\r\n const ext = config.externals\r\n if (Array.isArray(ext)) {\r\n externalPackages.forEach((pkg) => {\r\n const found = (ext as ExternalItem[]).find((e: ExternalItem) =>\r\n (typeof e === \"string\" && e.includes(pkg)) ||\r\n (typeof e === \"object\" && e !== null && !Array.isArray(e) &&\r\n Object.keys(e as object).some((k) => k.includes(pkg)))\r\n )\r\n if (!found) {\r\n (ext as string[]).push(pkg)\r\n }\r\n })\r\n }\r\n\r\n return config\r\n}\r\n\r\nconst mergeTurbopackRules = (\r\n existingRules: TurboRules,\r\n nextRules: TurboRules\r\n): TurboRules => {\r\n const merged: TurboRules = { ...existingRules }\r\n\r\n for (const [pattern, incomingRule] of Object.entries(nextRules)) {\r\n const current = merged[pattern]\r\n if (current == null) {\r\n merged[pattern] = incomingRule\r\n continue\r\n }\r\n\r\n if (typeof current === \"object\" && current !== null && \"loaders\" in current) {\r\n const typedCurrent = current as { loaders?: unknown }\r\n if (Array.isArray(typedCurrent.loaders)) {\r\n const incomingLoaders = (incomingRule as { loaders?: unknown[] }).loaders ?? []\r\n merged[pattern] = {\r\n ...(current as TurbopackLoaderRule),\r\n loaders: [...typedCurrent.loaders, ...incomingLoaders],\r\n } as TurbopackLoaderRule\r\n console.warn(\r\n `[tailwind-styled] Turbopack rule '${pattern}' already exists. Appending tailwind-styled loader.`\r\n )\r\n continue\r\n }\r\n }\r\n\r\n merged[pattern] = incomingRule\r\n console.warn(\r\n `[tailwind-styled] Turbopack rule '${pattern}' has incompatible shape. Replacing with tailwind-styled rule.`\r\n )\r\n }\r\n\r\n return merged\r\n}\r\n\r\nexport function withTailwindStyled(options: TailwindStyledNextOptions = {}) {\r\n checkNextVersion()\r\n const normalizedOptions = parseNextAdapterOptions(options)\r\n const webpackLoaderPath = resolveLoaderPath(\"webpackLoader\")\r\n const turbopackLoaderPath = resolveLoaderPath(\"turbopackLoader\")\r\n\r\nreturn function wrap(nextConfig: NextConfig = {}): NextConfig {\r\n const previousWebpack = nextConfig.webpack\r\n const loaderOptions = createLoaderOptions(normalizedOptions)\r\n\r\n return {\r\n ...nextConfig,\r\n webpack(\r\n config: NextWebpackConfig,\r\n webpackOptions: NextWebpackOptions\r\n ): ReturnType<NextWebpackFn> {\r\n const apply = (resolvedConfig: NextWebpackConfig) => {\r\n const finalConfig = applyWebpackRule(resolvedConfig, normalizedOptions, webpackLoaderPath)\r\n if (!finalConfig.externals) {\r\n finalConfig.externals = []\r\n }\r\n const externals = finalConfig.externals\r\n if (Array.isArray(externals)) {\r\n externals.push({\r\n \"@tailwind-styled/shared\": \"commonjs2 @tailwind-styled/shared\",\r\n \"@tailwind-styled/compiler\": \"commonjs2 @tailwind-styled/compiler\",\r\n \"@tailwind-styled/engine\": \"commonjs2 @tailwind-styled/engine\",\r\n \"@tailwind-styled/plugin\": \"commonjs2 @tailwind-styled/plugin\",\r\n })\r\n }\r\n return finalConfig\r\n }\r\n\r\n if (typeof previousWebpack !== \"function\") {\r\n return apply(config)\r\n }\r\n\r\n try {\r\n const result = previousWebpack(config, webpackOptions)\r\n return result instanceof Promise ? result.then(apply) : apply(result)\r\n } catch (error) {\r\n throw new Error(\"[tailwind-styled] Failed while executing existing Next webpack config.\", {\r\n cause: error,\r\n })\r\n }\r\n },\r\n turbopack: {\r\n ...(nextConfig.turbopack ?? {}),\r\n rules: mergeTurbopackRules(\r\n (nextConfig.turbopack?.rules ?? {}) as TurboRules,\r\n buildTurbopackRules(turbopackLoaderPath, loaderOptions)\r\n ),\r\n },\r\n }\r\n }\r\n}"]}
|
|
1
|
+
{"version":3,"sources":["../packages/presentation/next/src/schemas.ts","../packages/domain/shared/src/workerResolver.ts","../packages/domain/shared/src/index.ts","../packages/presentation/next/src/withTailwindStyled.ts"],"names":["z","path","createRequire","getDirnameFromUrl","lastSlash","require","resolveLoaderPath","fs"],"mappings":"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","file":"next.js","sourcesContent":["import { z } from \"zod\"\r\n\r\nconst formatIssues = (error: z.ZodError): string =>\r\n error.issues\r\n .map((issue) => {\r\n const p = issue.path.length > 0 ? issue.path.join(\".\") : \"<root>\"\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 throw new TypeError(`${label}: ${formatIssues(parsed.error)}`)\r\n}\r\n\r\nexport const NextAdapterOptionsSchema = z.object({\r\n mode: z.literal(\"zero-runtime\").optional(),\r\n autoClientBoundary: z.boolean().optional(),\r\n addDataAttr: z.boolean().optional(),\r\n hoist: z.boolean().optional(),\r\n routeCss: z.boolean().optional(),\r\n incremental: z.boolean().optional(),\r\n verbose: z.boolean().optional(),\r\n include: z.instanceof(RegExp).optional(),\r\n exclude: z.instanceof(RegExp).optional(),\r\n})\r\n\r\nexport type NextAdapterOptionsInput = z.infer<typeof NextAdapterOptionsSchema>\r\n\r\nexport const parseNextAdapterOptions = (options: unknown) =>\r\n parseWithSchema(NextAdapterOptionsSchema, options ?? {}, \"next adapter options are invalid\")\r\n","/**\r\n * Worker/bootstrap path resolution untuk artifact release safety.\r\n * Dari monorepo checklist: \"Perkuat worker/bootstrap path agar artifact release aman\"\r\n *\r\n * Masalah: path ke worker/loader script bisa berbeda antara:\r\n * - Development (src/*.ts)\r\n * - Built dist (dist/*.js / dist/*.cjs)\r\n * - Packed npm artifact (dist/ saja, tanpa src/)\r\n *\r\n * Solusi: resolve path secara hierarchical dengan fallback yang eksplisit.\r\n */\r\n\r\nconst isBrowser = typeof window !== \"undefined\" || typeof document !== \"undefined\"\r\n\r\nconst NODE_URL = typeof window === \"undefined\" || typeof document === \"undefined\" ? \"node:url\" : null\r\nconst NODE_FS = typeof window === \"undefined\" || typeof document === \"undefined\" ? \"node:fs\" : null\r\nconst NODE_PATH = typeof window === \"undefined\" || typeof document === \"undefined\" ? \"node:path\" : null\r\n\r\nfunction getDirnameFromUrl(importMetaUrl: string): string {\r\n if (!importMetaUrl) return \"\"\r\n if (isBrowser) return \"\"\r\n\r\n try {\r\n const nodeUrl = require(NODE_URL!)\r\n const nodePath = require(NODE_PATH!)\r\n // fileURLToPath returns the file path — we need the directory\r\n return nodePath.dirname(nodeUrl.fileURLToPath(importMetaUrl))\r\n } catch {\r\n if (importMetaUrl.startsWith(\"file://\")) {\r\n const filePath = importMetaUrl.slice(7)\r\n // strip the filename to get the directory\r\n const lastSlash = filePath.lastIndexOf(\"/\")\r\n return lastSlash >= 0 ? filePath.slice(0, lastSlash) : filePath\r\n }\r\n return \"\"\r\n }\r\n}\r\n\r\nfunction resolvePath(...segments: string[]): string {\r\n if (isBrowser) return segments.join(\"/\").replace(/\\/+/g, \"/\")\r\n try {\r\n const nodePath = require(NODE_PATH!)\r\n return nodePath.resolve(...segments)\r\n } catch {\r\n return segments.join(\"/\").replace(/\\/+/g, \"/\")\r\n }\r\n}\r\n\r\nfunction existsSync(path: string): boolean {\r\n if (isBrowser) return false\r\n try {\r\n const nodeFs = require(NODE_FS!)\r\n return nodeFs.existsSync(path)\r\n } catch {\r\n return false\r\n }\r\n}\r\n\r\nexport interface WorkerPathOptions {\r\n /** Nama file worker tanpa extension */\r\n basename: string\r\n /** Import meta URL dari caller module */\r\n importMetaUrl: string\r\n /** Extensions yang dicoba secara urutan (default: [\".cjs\", \".js\", \".mjs\"]) */\r\n extensions?: string[]\r\n /** Sub-directories relatif dari runtimeDir yang dicoba */\r\n subdirs?: string[]\r\n /** Throw jika tidak ditemukan (default: true) */\r\n required?: boolean\r\n}\r\n\r\nexport interface WorkerPathResult {\r\n /** Absolute path ke worker file */\r\n path: string\r\n /** Extension yang ditemukan */\r\n extension: string\r\n /** Apakah ini dari CJS atau ESM artifact */\r\n format: \"cjs\" | \"esm\"\r\n}\r\n\r\n/**\r\n * Resolve worker/loader script path yang aman untuk release artifacts.\r\n *\r\n * Prioritas:\r\n * 1. CJS (.cjs) — untuk Node.js workers yang butuh require()\r\n * 2. JS (.js) — bundled output\r\n * 3. MJS (.mjs) — explicit ESM\r\n *\r\n * @example\r\n * const workerPath = resolveWorkerPath({\r\n * basename: \"scanner-worker\",\r\n * importMetaUrl: import.meta.url,\r\n * })\r\n * // → \"/path/to/dist/scanner-worker.cjs\"\r\n */\r\nexport function resolveWorkerPath(opts: WorkerPathOptions): WorkerPathResult {\r\n if (isBrowser) {\r\n throw new Error(\"Worker resolution not available in browser\")\r\n }\r\n\r\n const {\r\n basename,\r\n importMetaUrl,\r\n extensions = [\".cjs\", \".js\", \".mjs\"],\r\n subdirs = [\".\", \"workers\", \"lib\"],\r\n required = true,\r\n } = opts\r\n\r\n const runtimeDir = getDirnameFromUrl(importMetaUrl)\r\n\r\n // Try each subdir + extension combination\r\n for (const subdir of subdirs) {\r\n for (const ext of extensions) {\r\n const candidate = resolvePath(runtimeDir, subdir, `${basename}${ext}`)\r\n if (existsSync(candidate)) {\r\n return {\r\n path: candidate,\r\n extension: ext,\r\n format: ext === \".cjs\" ? \"cjs\" : \"esm\",\r\n }\r\n }\r\n }\r\n }\r\n\r\n if (required) {\r\n const tried = subdirs.flatMap(d =>\r\n extensions.map(e => resolvePath(runtimeDir, d, `${basename}${e}`))\r\n )\r\n throw new Error(\r\n `[worker-resolver] Could not find worker script \"${basename}\".\\n` +\r\n `Tried:\\n${tried.map(p => ` - ${p}`).join(\"\\n\")}\\n` +\r\n `Ensure the package is built: npm run build`\r\n )\r\n }\r\n\r\n return { path: \"\", extension: \"\", format: \"cjs\" }\r\n}\r\n\r\n/**\r\n * Resolve loader path (untuk webpack/rspack/vite loaders).\r\n * Same as resolveWorkerPath but dengan nama yang lebih eksplisit.\r\n */\r\nexport function resolveLoaderPath(\r\n loaderBasename: string,\r\n importMetaUrl: string\r\n): string {\r\n return resolveWorkerPath({\r\n basename: loaderBasename,\r\n importMetaUrl,\r\n extensions: [\".cjs\", \".js\", \".mjs\"],\r\n subdirs: [\".\", \"loaders\", \"lib\"],\r\n }).path\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 // 4 level: dist/ → package/ → domain/ → packages/ → repo-root/\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 candidates.push(path.resolve(process.cwd(), \"native\", `${bin}.node`))\r\n candidates.push(path.resolve(process.cwd(), \"native\", `${bin}.${napiPlatform}.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 fs from \"node:fs\"\r\nimport { createRequire } from \"node:module\"\r\nimport path from \"node:path\"\r\n\r\nfunction getDirnameFromUrl(importMetaUrl: string): string {\r\n if (typeof importMetaUrl !== 'string') return ''\r\n // Simple URL parsing without Node.js modules\r\n if (importMetaUrl.startsWith('file://')) {\r\n let withoutFile = importMetaUrl.slice(7)\r\n // On Windows, file URLs can be like file:///C:/path\r\n if (withoutFile[0] === '/' && withoutFile[2] === ':') {\r\n withoutFile = withoutFile.slice(1) // Remove leading / from C:/\r\n }\r\n const lastSlash = Math.max(withoutFile.lastIndexOf('/'), withoutFile.lastIndexOf('\\\\'))\r\n return lastSlash > 0 ? withoutFile.slice(0, lastSlash) : '/'\r\n }\r\n // Fallback for other URL types\r\n const lastSlash = Math.max(importMetaUrl.lastIndexOf('/'), importMetaUrl.lastIndexOf('\\\\'))\r\n return lastSlash > 0 ? importMetaUrl.slice(0, lastSlash) : ''\r\n}\r\n\r\nimport { resolveLoaderPath as sharedResolveLoaderPath } from \"@tailwind-styled/shared\"\r\n\r\nimport { parseNextAdapterOptions } from \"./schemas\"\r\n\r\nconst require = createRequire(import.meta.url)\r\n\r\ninterface TailwindStyledLoaderOptions {\r\n /** @deprecated — handled by engine internally */\r\n mode?: \"zero-runtime\"\r\n /** @deprecated — handled by engine internally */\r\n autoClientBoundary?: boolean\r\n /** @deprecated — handled by engine internally */\r\n addDataAttr?: boolean\r\n /** @deprecated — handled by engine internally */\r\n hoist?: boolean\r\n /** @deprecated — handled by engine internally */\r\n routeCss?: boolean\r\n /** @deprecated — handled by engine internally */\r\n incremental?: boolean\r\n verbose?: boolean\r\n preserveImports?: boolean\r\n safelistPath?: string\r\n}\r\n\r\nexport interface TailwindStyledNextOptions {\r\n /** @deprecated — handled by engine internally */\r\n mode?: \"zero-runtime\"\r\n /** @deprecated — handled by engine internally */\r\n autoClientBoundary?: boolean\r\n /** @deprecated — handled by engine internally */\r\n addDataAttr?: boolean\r\n /** @deprecated — handled by engine internally */\r\n hoist?: boolean\r\n /** @deprecated — handled by engine internally */\r\n routeCss?: boolean\r\n /** @deprecated — handled by engine internally */\r\n incremental?: boolean\r\n /** Show detailed loader output */\r\n verbose?: boolean\r\n /** Path to generated safelist CSS file. Default: <cwd>/__tw_safelist.css */\r\n safelistPath?: string\r\n include?: RegExp\r\n exclude?: RegExp\r\n}\r\n\r\nimport type { NextConfig } from \"next\"\r\n\r\n// Derive webpack types directly from Next.js — always in sync with installed version\r\ntype NextWebpackFn = NonNullable<NextConfig[\"webpack\"]>\r\ntype NextWebpackConfig = Parameters<NextWebpackFn>[0]\r\ntype NextWebpackOptions = Parameters<NextWebpackFn>[1]\r\n\r\n// Derive turbopack rule types from NextConfig\r\ntype TurboRules = NonNullable<NonNullable<NextConfig[\"turbopack\"]>[\"rules\"]>\r\ntype TurbopackLoaderRule = TurboRules[string]\r\n\r\n// Derive webpack module rule type for safe iteration\r\ntype ModuleRule = NonNullable<NonNullable<NextWebpackConfig[\"module\"]>[\"rules\"]>[number]\r\ntype RuleUseEntry = { loader?: string; options?: unknown }\r\n\r\ninterface NextWebpackUseEntry {\r\n loader: string\r\n options?: TailwindStyledLoaderOptions\r\n}\r\n\r\ninterface NextWebpackRule {\r\n test?: RegExp\r\n exclude?: RegExp\r\n enforce?: \"pre\" | \"post\"\r\n use?: NextWebpackUseEntry[]\r\n}\r\n\r\n\r\nconst resolveRuntimeDir = (): string => getDirnameFromUrl(import.meta.url)\r\n\r\nconst resolveLoaderPath = (basename: string): string => {\r\n try {\r\n return sharedResolveLoaderPath(basename, import.meta.url)\r\n } catch {\r\n const runtimeDir = resolveRuntimeDir()\r\n const candidates = [\r\n path.resolve(runtimeDir, `${basename}.mjs`),\r\n path.resolve(runtimeDir, `${basename}.js`),\r\n path.resolve(runtimeDir, `${basename}.cjs`),\r\n ]\r\n\r\n for (const candidate of candidates) {\r\n if (fs.existsSync(candidate)) {\r\n return candidate\r\n }\r\n }\r\n\r\n throw new Error(\r\n `[tailwind-styled] Loader not found for '${basename}'. Checked: ${candidates.join(\", \")}`\r\n )\r\n }\r\n}\r\n\r\nfunction checkNextVersion(): void {\r\n try {\r\n const pkgPath = require.resolve(\"next/package.json\")\r\n const { version } = require(pkgPath)\r\n const major = Number.parseInt(version.split(\".\")[0], 10)\r\n if (major < 15) {\r\n console.warn(\r\n `[tailwind-styled] Next.js ${version} detected. Recommended: 15+ for full Turbopack support.`\r\n )\r\n }\r\n } catch {\r\n // next not resolvable — skip check\r\n }\r\n}\r\n\r\nconst DEFAULT_INCLUDE = /\\.[jt]sx?$/\r\nconst DEFAULT_EXCLUDE = /node_modules/\r\n\r\n/**\r\n * Next.js App Router entry-point files yang TIDAK boleh diproses oleh TW loader.\r\n *\r\n * Mengapa: file-file ini adalah RSC boundary points yang dikelola Next.js secara khusus.\r\n * Jika loader menginjeksi TRANSFORM_MARKER atau memodifikasi source-nya—bahkan ketika\r\n * `changed: false`—Next.js/React Compiler kehilangan sinyal bahwa file adalah pure RSC,\r\n * sehingga locale injection dari Accept-Language header (Next.js 16+) tidak konsisten\r\n * antara SSR pass (server: lang=\"id\") dan hydration pass (client: lang=\"en\").\r\n *\r\n * File yang dikecualikan: layout, page, loading, error, not-found, template, default\r\n * semuanya adalah Next.js segment conventions yang tidak boleh disentuh loader pihak ketiga.\r\n */\r\nconst NEXT_RSC_ENTRIES =\r\n /(?:^|[\\\\/])(?:layout|page|loading|error|not-found|template|default)\\.[jt]sx?$/\r\n\r\n/**\r\n * Gabungkan user-supplied exclude dengan NEXT_RSC_ENTRIES.\r\n * Menggunakan non-capturing group agar tidak interferensi dengan capture group lain.\r\n */\r\nconst buildExcludePattern = (userExclude?: RegExp): RegExp => {\r\n if (!userExclude) return new RegExp(`(?:${DEFAULT_EXCLUDE.source})|(?:${NEXT_RSC_ENTRIES.source})`)\r\n return new RegExp(`(?:${userExclude.source})|(?:${NEXT_RSC_ENTRIES.source})`)\r\n}\r\n\r\nconst createLoaderOptions = (options: TailwindStyledNextOptions): Readonly<TailwindStyledLoaderOptions> => {\r\n // Deprecated options — still passed for loader backward compat but engine ignores them\r\n const opts: TailwindStyledLoaderOptions = {\r\n mode: \"zero-runtime\", // only supported mode\r\n autoClientBoundary: true, // always on (engine handles it)\r\n preserveImports: true,\r\n }\r\n if (options.verbose !== undefined) opts.verbose = options.verbose\r\n opts.safelistPath = options.safelistPath ?? path.join(process.cwd(), \"__tw_safelist.css\")\r\n return Object.freeze(opts)\r\n}\r\n\r\nconst buildTurbopackRules = (\r\n loaderPath: string,\r\n loaderOptions: TailwindStyledLoaderOptions\r\n): TurboRules => {\r\n const extensions = [\"js\", \"jsx\", \"ts\", \"tsx\", \"mjs\", \"cjs\"]\r\n return Object.fromEntries(\r\n extensions.map((ext) => [\r\n `*.${ext}`,\r\n { loaders: [{ loader: loaderPath, options: loaderOptions }] },\r\n ])\r\n ) as TurboRules\r\n}\r\n\r\nconst normalizeLoaderPath = (loaderPath: string): string => path.resolve(loaderPath)\r\n\r\nconst applyWebpackRule = (\r\n config: NextWebpackConfig,\r\n options: TailwindStyledNextOptions,\r\n loaderPath: string\r\n): NextWebpackConfig => {\r\n const loaderOptions = createLoaderOptions(options)\r\n const rules = config.module?.rules ?? []\r\n const normalizedLoaderPath = normalizeLoaderPath(loaderPath)\r\n\r\n const alreadyRegistered = rules.some(\r\n (rule: ModuleRule) =>\r\n Array.isArray(rule?.use) &&\r\n (rule.use as RuleUseEntry[]).some(\r\n (entry: RuleUseEntry) =>\r\n typeof entry.loader === \"string\" &&\r\n normalizeLoaderPath(entry.loader) === normalizedLoaderPath\r\n )\r\n )\r\n\r\n if (alreadyRegistered) return config\r\n\r\n const tailwindStyledRule: NextWebpackRule = {\r\n test: options.include ?? DEFAULT_INCLUDE,\r\n // Selalu kecualikan Next.js RSC entry files (layout, page, dll) bahkan jika\r\n // user menyuplai exclude pattern sendiri — lihat buildExcludePattern.\r\n exclude: buildExcludePattern(options.exclude),\r\n enforce: \"pre\",\r\n use: [{ loader: loaderPath, options: loaderOptions }],\r\n }\r\n\r\n config.module = {\r\n ...(config.module ?? {}),\r\n rules: [...rules, tailwindStyledRule],\r\n }\r\n\r\n const externalPackages = [\r\n \"@tailwind-styled/shared\",\r\n \"@tailwind-styled/compiler\", \r\n \"@tailwind-styled/engine\",\r\n \"@tailwind-styled/plugin\",\r\n \"@tailwind-styled/core\",\r\n \"@tailwind-styled/runtime-css\",\r\n \"@tailwind-styled/runtime\",\r\n \"@tailwind-styled/scanner\",\r\n \"@tailwind-styled/analyzer\",\r\n \"@tailwind-styled/theme\",\r\n \"@tailwind-styled/preset\",\r\n ]\r\n\r\n type ExternalsArray = Extract<NonNullable<NextWebpackConfig[\"externals\"]>, readonly unknown[]>\r\n type ExternalItem = ExternalsArray[number]\r\n\r\n if (!config.externals) {\r\n config.externals = []\r\n }\r\n\r\n const ext = config.externals\r\n if (Array.isArray(ext)) {\r\n externalPackages.forEach((pkg) => {\r\n const found = (ext as ExternalItem[]).find((e: ExternalItem) =>\r\n (typeof e === \"string\" && e.includes(pkg)) ||\r\n (typeof e === \"object\" && e !== null && !Array.isArray(e) &&\r\n Object.keys(e as object).some((k) => k.includes(pkg)))\r\n )\r\n if (!found) {\r\n (ext as string[]).push(pkg)\r\n }\r\n })\r\n }\r\n\r\n return config\r\n}\r\n\r\nconst mergeTurbopackRules = (\r\n existingRules: TurboRules,\r\n nextRules: TurboRules\r\n): TurboRules => {\r\n const merged: TurboRules = { ...existingRules }\r\n\r\n for (const [pattern, incomingRule] of Object.entries(nextRules)) {\r\n const current = merged[pattern]\r\n if (current == null) {\r\n merged[pattern] = incomingRule\r\n continue\r\n }\r\n\r\n if (typeof current === \"object\" && current !== null && \"loaders\" in current) {\r\n const typedCurrent = current as { loaders?: unknown }\r\n if (Array.isArray(typedCurrent.loaders)) {\r\n const incomingLoaders = (incomingRule as { loaders?: unknown[] }).loaders ?? []\r\n merged[pattern] = {\r\n ...(current as TurbopackLoaderRule),\r\n loaders: [...typedCurrent.loaders, ...incomingLoaders],\r\n } as TurbopackLoaderRule\r\n console.warn(\r\n `[tailwind-styled] Turbopack rule '${pattern}' already exists. Appending tailwind-styled loader.`\r\n )\r\n continue\r\n }\r\n }\r\n\r\n merged[pattern] = incomingRule\r\n console.warn(\r\n `[tailwind-styled] Turbopack rule '${pattern}' has incompatible shape. Replacing with tailwind-styled rule.`\r\n )\r\n }\r\n\r\n return merged\r\n}\r\n\r\nexport function withTailwindStyled(options: TailwindStyledNextOptions = {}) {\r\n checkNextVersion()\r\n const normalizedOptions = parseNextAdapterOptions(options)\r\n const webpackLoaderPath = resolveLoaderPath(\"webpackLoader\")\r\n const turbopackLoaderPath = resolveLoaderPath(\"turbopackLoader\")\r\n\r\nreturn function wrap(nextConfig: NextConfig = {}): NextConfig {\r\n const previousWebpack = nextConfig.webpack\r\n const loaderOptions = createLoaderOptions(normalizedOptions)\r\n\r\n return {\r\n ...nextConfig,\r\n webpack(\r\n config: NextWebpackConfig,\r\n webpackOptions: NextWebpackOptions\r\n ): ReturnType<NextWebpackFn> {\r\n const apply = (resolvedConfig: NextWebpackConfig) => {\r\n const finalConfig = applyWebpackRule(resolvedConfig, normalizedOptions, webpackLoaderPath)\r\n if (!finalConfig.externals) {\r\n finalConfig.externals = []\r\n }\r\n const externals = finalConfig.externals\r\n if (Array.isArray(externals)) {\r\n externals.push({\r\n \"@tailwind-styled/shared\": \"commonjs2 @tailwind-styled/shared\",\r\n \"@tailwind-styled/compiler\": \"commonjs2 @tailwind-styled/compiler\",\r\n \"@tailwind-styled/engine\": \"commonjs2 @tailwind-styled/engine\",\r\n \"@tailwind-styled/plugin\": \"commonjs2 @tailwind-styled/plugin\",\r\n })\r\n }\r\n return finalConfig\r\n }\r\n\r\n if (typeof previousWebpack !== \"function\") {\r\n return apply(config)\r\n }\r\n\r\n try {\r\n const result = previousWebpack(config, webpackOptions)\r\n return result instanceof Promise ? result.then(apply) : apply(result)\r\n } catch (error) {\r\n throw new Error(\"[tailwind-styled] Failed while executing existing Next webpack config.\", {\r\n cause: error,\r\n })\r\n }\r\n },\r\n turbopack: {\r\n ...(nextConfig.turbopack ?? {}),\r\n rules: mergeTurbopackRules(\r\n (nextConfig.turbopack?.rules ?? {}) as TurboRules,\r\n buildTurbopackRules(turbopackLoaderPath, loaderOptions)\r\n ),\r\n },\r\n }\r\n }\r\n}"]}
|
package/dist/next.mjs
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { z } from 'zod';
|
|
2
|
-
import
|
|
2
|
+
import fs2 from 'fs';
|
|
3
3
|
import { createRequire } from 'module';
|
|
4
|
-
import
|
|
4
|
+
import path2 from 'path';
|
|
5
|
+
import 'crypto';
|
|
6
|
+
import 'url';
|
|
5
7
|
|
|
6
8
|
/* tailwind-styled-v4 v5.0.4 | MIT | https://github.com/dictionar32/tailwind-styled-v4 */
|
|
7
9
|
var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
|
|
@@ -42,10 +44,13 @@ function getDirnameFromUrl(importMetaUrl) {
|
|
|
42
44
|
if (isBrowser) return "";
|
|
43
45
|
try {
|
|
44
46
|
const nodeUrl = __require(NODE_URL);
|
|
45
|
-
|
|
47
|
+
const nodePath = __require(NODE_PATH);
|
|
48
|
+
return nodePath.dirname(nodeUrl.fileURLToPath(importMetaUrl));
|
|
46
49
|
} catch {
|
|
47
50
|
if (importMetaUrl.startsWith("file://")) {
|
|
48
|
-
|
|
51
|
+
const filePath = importMetaUrl.slice(7);
|
|
52
|
+
const lastSlash = filePath.lastIndexOf("/");
|
|
53
|
+
return lastSlash >= 0 ? filePath.slice(0, lastSlash) : filePath;
|
|
49
54
|
}
|
|
50
55
|
return "";
|
|
51
56
|
}
|
|
@@ -59,11 +64,11 @@ function resolvePath(...segments) {
|
|
|
59
64
|
return segments.join("/").replace(/\/+/g, "/");
|
|
60
65
|
}
|
|
61
66
|
}
|
|
62
|
-
function existsSync(
|
|
67
|
+
function existsSync(path3) {
|
|
63
68
|
if (isBrowser) return false;
|
|
64
69
|
try {
|
|
65
70
|
const nodeFs = __require(NODE_FS);
|
|
66
|
-
return nodeFs.existsSync(
|
|
71
|
+
return nodeFs.existsSync(path3);
|
|
67
72
|
} catch {
|
|
68
73
|
return false;
|
|
69
74
|
}
|
|
@@ -115,31 +120,7 @@ function resolveLoaderPath(loaderBasename, importMetaUrl) {
|
|
|
115
120
|
}
|
|
116
121
|
|
|
117
122
|
// packages/domain/shared/src/index.ts
|
|
118
|
-
|
|
119
|
-
var nodeModuleRef = null;
|
|
120
|
-
function getNodeModuleRef() {
|
|
121
|
-
if (isBrowser2) return null;
|
|
122
|
-
if (nodeModuleRef !== null) return nodeModuleRef;
|
|
123
|
-
try {
|
|
124
|
-
const test = typeof __require === "function" ? __require("module") : null;
|
|
125
|
-
nodeModuleRef = test;
|
|
126
|
-
return test;
|
|
127
|
-
} catch {
|
|
128
|
-
nodeModuleRef = null;
|
|
129
|
-
return null;
|
|
130
|
-
}
|
|
131
|
-
}
|
|
132
|
-
function getRequire() {
|
|
133
|
-
if (isBrowser2) return (() => {
|
|
134
|
-
throw new Error("require not available in browser");
|
|
135
|
-
});
|
|
136
|
-
const nodeRequire = getNodeModuleRef();
|
|
137
|
-
if (!nodeRequire) return (() => {
|
|
138
|
-
throw new Error("require not available");
|
|
139
|
-
});
|
|
140
|
-
return nodeRequire.createRequire(import.meta.url);
|
|
141
|
-
}
|
|
142
|
-
getRequire();
|
|
123
|
+
createRequire(import.meta.url);
|
|
143
124
|
|
|
144
125
|
// packages/presentation/next/src/withTailwindStyled.ts
|
|
145
126
|
function getDirnameFromUrl2(importMetaUrl) {
|
|
@@ -163,12 +144,12 @@ var resolveLoaderPath2 = (basename) => {
|
|
|
163
144
|
} catch {
|
|
164
145
|
const runtimeDir = resolveRuntimeDir();
|
|
165
146
|
const candidates = [
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
147
|
+
path2.resolve(runtimeDir, `${basename}.mjs`),
|
|
148
|
+
path2.resolve(runtimeDir, `${basename}.js`),
|
|
149
|
+
path2.resolve(runtimeDir, `${basename}.cjs`)
|
|
169
150
|
];
|
|
170
151
|
for (const candidate of candidates) {
|
|
171
|
-
if (
|
|
152
|
+
if (fs2.existsSync(candidate)) {
|
|
172
153
|
return candidate;
|
|
173
154
|
}
|
|
174
155
|
}
|
|
@@ -206,7 +187,7 @@ var createLoaderOptions = (options) => {
|
|
|
206
187
|
preserveImports: true
|
|
207
188
|
};
|
|
208
189
|
if (options.verbose !== void 0) opts.verbose = options.verbose;
|
|
209
|
-
opts.safelistPath = options.safelistPath ??
|
|
190
|
+
opts.safelistPath = options.safelistPath ?? path2.join(process.cwd(), "__tw_safelist.css");
|
|
210
191
|
return Object.freeze(opts);
|
|
211
192
|
};
|
|
212
193
|
var buildTurbopackRules = (loaderPath, loaderOptions) => {
|
|
@@ -218,7 +199,7 @@ var buildTurbopackRules = (loaderPath, loaderOptions) => {
|
|
|
218
199
|
])
|
|
219
200
|
);
|
|
220
201
|
};
|
|
221
|
-
var normalizeLoaderPath = (loaderPath) =>
|
|
202
|
+
var normalizeLoaderPath = (loaderPath) => path2.resolve(loaderPath);
|
|
222
203
|
var applyWebpackRule = (config, options, loaderPath) => {
|
|
223
204
|
const loaderOptions = createLoaderOptions(options);
|
|
224
205
|
const rules = config.module?.rules ?? [];
|