weapp-tailwindcss 5.0.0-next.2 → 5.0.0-next.20

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 (220) hide show
  1. package/README.md +6 -7
  2. package/bin/weapp-tailwindcss.js +1 -21
  3. package/dist/bundle-state-BlXvU4jl.js +530 -0
  4. package/dist/bundle-state-PO6MysTJ.mjs +414 -0
  5. package/dist/bundlers/shared/cache.d.ts +6 -6
  6. package/dist/bundlers/shared/css-cleanup/at-rules.d.ts +2 -0
  7. package/dist/bundlers/shared/css-cleanup/color-gamut.d.ts +3 -0
  8. package/dist/bundlers/shared/css-cleanup/root-cleanups.d.ts +5 -0
  9. package/dist/bundlers/shared/css-cleanup/selectors.d.ts +8 -0
  10. package/dist/bundlers/shared/css-cleanup.d.ts +7 -3
  11. package/dist/bundlers/shared/css-imports.d.ts +3 -3
  12. package/dist/bundlers/shared/generated-css-marker.d.ts +3 -0
  13. package/dist/bundlers/shared/generator-css/config-directive.d.ts +2 -0
  14. package/dist/bundlers/shared/generator-css/directives.d.ts +20 -0
  15. package/dist/bundlers/shared/generator-css/legacy-compat.d.ts +7 -0
  16. package/dist/bundlers/shared/generator-css/legacy-selectors.d.ts +5 -0
  17. package/dist/bundlers/shared/generator-css/legacy-units.d.ts +1 -0
  18. package/dist/bundlers/shared/generator-css/markers.d.ts +28 -0
  19. package/dist/bundlers/shared/generator-css/source-files.d.ts +14 -0
  20. package/dist/bundlers/shared/generator-css/source-resolver.d.ts +24 -0
  21. package/dist/bundlers/shared/generator-css.d.ts +16 -22
  22. package/dist/bundlers/shared/hmr-timing.d.ts +22 -0
  23. package/dist/bundlers/shared/style-requests.d.ts +2 -0
  24. package/dist/bundlers/vite/bundle-state.d.ts +1 -0
  25. package/dist/bundlers/vite/css-finalizer.d.ts +7 -1
  26. package/dist/bundlers/vite/generate-bundle/candidates.d.ts +2 -0
  27. package/dist/bundlers/vite/generate-bundle/css-handler-options.d.ts +24 -0
  28. package/dist/bundlers/vite/generate-bundle/css-share-scope.d.ts +4 -0
  29. package/dist/bundlers/vite/generate-bundle/dirty-state.d.ts +1 -0
  30. package/dist/bundlers/vite/generate-bundle/js-entries.d.ts +2 -0
  31. package/dist/bundlers/vite/generate-bundle/js-handler-options.d.ts +8 -0
  32. package/dist/bundlers/vite/generate-bundle/js-linking.d.ts +13 -0
  33. package/dist/bundlers/vite/generate-bundle/metrics.d.ts +17 -0
  34. package/dist/bundlers/vite/generate-bundle/process-plan.d.ts +9 -0
  35. package/dist/bundlers/vite/generate-bundle/rollup-assets.d.ts +7 -0
  36. package/dist/bundlers/vite/generate-bundle/signatures.d.ts +8 -0
  37. package/dist/bundlers/vite/generate-bundle.d.ts +14 -2
  38. package/dist/bundlers/vite/incremental-runtime-class-set.d.ts +5 -1
  39. package/dist/bundlers/vite/index.d.ts +1 -1
  40. package/dist/bundlers/vite/official-tailwind-plugins.d.ts +5 -0
  41. package/dist/bundlers/vite/postcss-config.d.ts +6 -0
  42. package/dist/bundlers/vite/processed-css-assets.d.ts +32 -0
  43. package/dist/bundlers/vite/rewrite-css-imports.d.ts +8 -3
  44. package/dist/bundlers/vite/runtime-class-set.d.ts +25 -0
  45. package/dist/bundlers/vite/source-candidates.d.ts +16 -1
  46. package/dist/bundlers/vite/source-scan.d.ts +26 -0
  47. package/dist/bundlers/vite/static-config-content.d.ts +5 -0
  48. package/dist/bundlers/vite/tailwind-basedir.d.ts +1 -0
  49. package/dist/bundlers/webpack/BaseUnifiedPlugin/shared.d.ts +6 -0
  50. package/dist/bundlers/webpack/BaseUnifiedPlugin/v5-assets.d.ts +6 -2
  51. package/dist/bundlers/webpack/BaseUnifiedPlugin/v5-loaders.d.ts +9 -3
  52. package/dist/bundlers/webpack/BaseUnifiedPlugin/v5.d.ts +1 -0
  53. package/dist/bundlers/webpack/loaders/runtime-registry.d.ts +31 -0
  54. package/dist/bundlers/webpack/loaders/weapp-tw-css-import-rewrite-loader.d.ts +2 -6
  55. package/dist/bundlers/webpack/loaders/weapp-tw-runtime-classset-loader.d.ts +3 -7
  56. package/dist/cache/index.d.ts +6 -6
  57. package/dist/cli/context.d.ts +1 -14
  58. package/dist/cli/doctor/types.d.ts +11 -11
  59. package/dist/cli/helpers.d.ts +1 -2
  60. package/dist/cli/mount-options.d.ts +2 -0
  61. package/dist/cli/types.d.ts +0 -2
  62. package/dist/cli/vscode-entry.d.ts +3 -3
  63. package/dist/cli.js +605 -611
  64. package/dist/cli.mjs +614 -620
  65. package/dist/constants.d.ts +1 -2
  66. package/dist/core.js +13 -20
  67. package/dist/core.mjs +8 -14
  68. package/dist/css-macro/postcss.js +3 -2
  69. package/dist/css-macro/postcss.mjs +3 -2
  70. package/dist/css-macro.d.ts +1 -0
  71. package/dist/css-macro.js +2 -2
  72. package/dist/css-macro.mjs +2 -2
  73. package/dist/defaults-B1igPF_e.mjs +150 -0
  74. package/dist/defaults-IHhYxNeU.js +193 -0
  75. package/dist/defaults.d.ts +15 -1
  76. package/dist/defaults.js +6 -131
  77. package/dist/defaults.mjs +2 -129
  78. package/dist/escape.js +10 -2
  79. package/dist/escape.mjs +10 -2
  80. package/dist/generator/index.d.ts +1 -1
  81. package/dist/generator/options.d.ts +9 -8
  82. package/dist/generator/types.d.ts +3 -3
  83. package/dist/generator-DIuglJub.mjs +32 -0
  84. package/dist/generator-N4jy1HCk.js +55 -0
  85. package/dist/generator.js +12 -11
  86. package/dist/generator.mjs +2 -1
  87. package/dist/gulp.js +185 -47
  88. package/dist/gulp.mjs +179 -41
  89. package/dist/incremental-runtime-class-set-CJ0Pnsw2.js +2348 -0
  90. package/dist/incremental-runtime-class-set-hF-uiw6W.mjs +2285 -0
  91. package/dist/index.d.ts +1 -1
  92. package/dist/index.js +6 -6
  93. package/dist/index.mjs +5 -5
  94. package/dist/js/babel/cache-options.d.ts +3 -0
  95. package/dist/js/babel/parse.d.ts +7 -4
  96. package/dist/js/index.d.ts +1 -0
  97. package/dist/js/literal-transform.d.ts +2 -0
  98. package/dist/js/precheck.d.ts +2 -2
  99. package/dist/lightningcss/style-handler/selector-transform.d.ts +1 -1
  100. package/dist/lightningcss/style-handler.d.ts +3 -3
  101. package/dist/logger-CZUxvJJD.mjs +2 -0
  102. package/dist/logger-EVNB9z7i.js +1 -0
  103. package/dist/postcss/config-directive.d.ts +1 -0
  104. package/dist/postcss/context.d.ts +9 -0
  105. package/dist/postcss/source-files.d.ts +8 -0
  106. package/dist/postcss/tailwind-version.d.ts +3 -0
  107. package/dist/postcss-D4UdbBQ6.mjs +228 -0
  108. package/dist/postcss-DlY-YRvA.js +237 -0
  109. package/dist/postcss.d.ts +2 -2
  110. package/dist/postcss.js +3 -276
  111. package/dist/postcss.mjs +1 -269
  112. package/dist/{recorder-gYSNLfOP.js → precheck-BjEbVEpX.js} +218 -314
  113. package/dist/{recorder-zsgatmkB.mjs → precheck-tbk626YL.mjs} +186 -281
  114. package/dist/presets.js +13 -11
  115. package/dist/presets.mjs +11 -9
  116. package/dist/reset.d.ts +1 -0
  117. package/dist/runtime-registry-D5qnaSpo.js +5516 -0
  118. package/dist/shared/mpx.d.ts +1 -0
  119. package/dist/source-candidates-BrvneDDd.mjs +209 -0
  120. package/dist/source-candidates-gxijpPI3.js +222 -0
  121. package/dist/tailwindcss/miniprogram.d.ts +5 -1
  122. package/dist/tailwindcss/patcher-options.d.ts +3 -51
  123. package/dist/tailwindcss/patcher.d.ts +1 -2
  124. package/dist/tailwindcss/runtime/cache.d.ts +4 -3
  125. package/dist/tailwindcss/runtime-patch.d.ts +5 -0
  126. package/dist/tailwindcss/runtime.d.ts +11 -12
  127. package/dist/tailwindcss/source-scan.d.ts +35 -0
  128. package/dist/tailwindcss/targets.d.ts +1 -5
  129. package/dist/tailwindcss/v3-engine/types.d.ts +17 -14
  130. package/dist/tailwindcss/v4/css-entries.d.ts +2 -2
  131. package/dist/tailwindcss/v4/css-sources.d.ts +5 -0
  132. package/dist/tailwindcss/v4/patcher-options.d.ts +1 -23
  133. package/dist/tailwindcss/v4/patcher.d.ts +1 -0
  134. package/dist/tailwindcss/v4-engine/source.d.ts +2 -2
  135. package/dist/tailwindcss/v4-engine/types.d.ts +17 -5
  136. package/dist/tailwindcss/version.d.ts +4 -0
  137. package/dist/tailwindcss-BhG7BtB-.js +651 -0
  138. package/dist/tailwindcss-c6ROlNNW.mjs +600 -0
  139. package/dist/typedoc.export.d.ts +0 -2
  140. package/dist/types/index.d.ts +51 -48
  141. package/dist/types/shared.d.ts +3 -0
  142. package/dist/types/user-defined-options/general.d.ts +23 -23
  143. package/dist/types/user-defined-options/important.d.ts +31 -28
  144. package/dist/types/user-defined-options/lifecycle.d.ts +4 -4
  145. package/dist/types/user-defined-options/matcher.d.ts +6 -6
  146. package/dist/uni-app-x/vite.d.ts +1 -1
  147. package/dist/utils/disabled.d.ts +2 -3
  148. package/dist/utils/object.d.ts +9 -0
  149. package/dist/{utils-DmC9_In3.js → utils-4ODFyoqD.js} +1 -1
  150. package/dist/{utils-7DUGTFED.mjs → utils-CGBVVNm6.mjs} +1 -1
  151. package/dist/v3-engine-5LoZUH-4.js +3695 -0
  152. package/dist/v3-engine-DIXDEDmL.mjs +3406 -0
  153. package/dist/{vite-CrlzCNqz.mjs → vite-B5faZcbE.mjs} +1256 -1088
  154. package/dist/vite-MyXBNux0.js +2368 -0
  155. package/dist/vite.d.ts +1 -2
  156. package/dist/vite.js +3 -4
  157. package/dist/vite.mjs +2 -2
  158. package/dist/weapp-tw-css-import-rewrite-loader.js +5157 -16
  159. package/dist/weapp-tw-runtime-classset-loader.js +32 -7
  160. package/dist/webpack-BnVyDmsD.mjs +836 -0
  161. package/dist/webpack-Mz1V0A9p.js +846 -0
  162. package/dist/webpack.js +1 -1
  163. package/dist/webpack.mjs +1 -1
  164. package/package.json +27 -37
  165. package/dist/bundlers/shared/generator-candidates.d.ts +0 -5
  166. package/dist/bundlers/webpack/BaseUnifiedPlugin/v4-assets.d.ts +0 -14
  167. package/dist/bundlers/webpack/BaseUnifiedPlugin/v4-loaders.d.ts +0 -15
  168. package/dist/bundlers/webpack/BaseUnifiedPlugin/v4.d.ts +0 -9
  169. package/dist/bundlers/webpack/shared/css-imports.d.ts +0 -6
  170. package/dist/cli/config.d.ts +0 -5
  171. package/dist/cli/helpers/patch-cwd.d.ts +0 -1
  172. package/dist/cli/mount-options/patch-status.d.ts +0 -2
  173. package/dist/cli/patch-options.d.ts +0 -6
  174. package/dist/cli/tokens.d.ts +0 -4
  175. package/dist/cli/workspace/package-dirs.d.ts +0 -3
  176. package/dist/cli/workspace/patch-package.d.ts +0 -3
  177. package/dist/cli/workspace/patch-utils.d.ts +0 -3
  178. package/dist/cli/workspace/types.d.ts +0 -11
  179. package/dist/cli/workspace/workspace-globs.d.ts +0 -2
  180. package/dist/cli/workspace/workspace-io.d.ts +0 -1
  181. package/dist/cli/workspace/workspace-lock.d.ts +0 -1
  182. package/dist/cli/workspace.d.ts +0 -2
  183. package/dist/css-imports-BbrbluP9.js +0 -177
  184. package/dist/css-imports-CSdPq_Sc.mjs +0 -128
  185. package/dist/experimental/index.d.ts +0 -2
  186. package/dist/experimental/oxc/ast-utils.d.ts +0 -30
  187. package/dist/experimental/oxc/index.d.ts +0 -2
  188. package/dist/experimental/oxc/module-specifiers.d.ts +0 -2
  189. package/dist/experimental/shared/cache.d.ts +0 -3
  190. package/dist/experimental/shared/transform.d.ts +0 -3
  191. package/dist/experimental/shared.d.ts +0 -8
  192. package/dist/experimental/swc/ast-utils.d.ts +0 -30
  193. package/dist/experimental/swc/index.d.ts +0 -2
  194. package/dist/experimental/swc/module-specifiers.d.ts +0 -2
  195. package/dist/generator-Y-Ikv4Fu.mjs +0 -1177
  196. package/dist/generator-css-B5ejWUMv.mjs +0 -1098
  197. package/dist/generator-css-D3OdPRiS.js +0 -1125
  198. package/dist/generator-mmhXzZnv.js +0 -1276
  199. package/dist/js/syntax.d.ts +0 -10
  200. package/dist/loader-anchors-CNkWT8hx.js +0 -273
  201. package/dist/loader-anchors-TrU7EUr7.mjs +0 -205
  202. package/dist/logger-BZ45DZJT.js +0 -1003
  203. package/dist/logger-BoVx1Dbt.mjs +0 -935
  204. package/dist/patcher-options-6gJN2EXy.js +0 -115
  205. package/dist/patcher-options-DQfR5xxT.mjs +0 -92
  206. package/dist/tailwindcss/recorder.d.ts +0 -13
  207. package/dist/tailwindcss/targets/paths.d.ts +0 -13
  208. package/dist/tailwindcss/targets/record-io.d.ts +0 -5
  209. package/dist/tailwindcss/targets/recorder.d.ts +0 -3
  210. package/dist/tailwindcss/targets/types.d.ts +0 -35
  211. package/dist/types/disabled-options.d.ts +0 -4
  212. package/dist/vite-BC9U7ahn.js +0 -2199
  213. package/dist/webpack-Bu6M-Hbw.mjs +0 -441
  214. package/dist/webpack-DD7A6V0u.js +0 -456
  215. package/dist/webpack4.d.ts +0 -4
  216. package/dist/webpack4.js +0 -387
  217. package/dist/webpack4.mjs +0 -379
  218. package/scripts/postinstall.mjs +0 -59
  219. /package/dist/{constants-B-_T5UnW.mjs → constants-BG12WAKw.mjs} +0 -0
  220. /package/dist/{constants-p1dyh1x1.js → constants-BeeyfJ9k.js} +0 -0
@@ -1,441 +0,0 @@
1
- import { r as resolveTailwindcssOptions } from "./patcher-options-DQfR5xxT.mjs";
2
- import { g as ensureRuntimeClassSet, n as shouldSkipJsTransform, p as pluginName, r as getCompilerContext, t as setupPatchRecorder, v as createDebug } from "./recorder-zsgatmkB.mjs";
3
- import { r as getGroupedEntries } from "./utils-7DUGTFED.mjs";
4
- import { d as getRuntimeClassSetSignature } from "./logger-BoVx1Dbt.mjs";
5
- import { i as processCachedTask, t as generateCssByGenerator } from "./generator-css-B5ejWUMv.mjs";
6
- import { a as resolveDisabledOptions, c as toAbsoluteOutputPath, i as resolvePackageDir, r as pushConcurrentTaskFactories, s as resolveOutputSpecifier } from "./css-imports-CSdPq_Sc.mjs";
7
- import { a as hasLoaderEntry, c as applyTailwindcssCssImportRewrite, d as isMpx, f as patchMpxLoaderResolve, i as getCacheKey, l as ensureMpxTailwindcssAliases, n as __dirname, o as hasWatchChanges, p as setupMpxTailwindcssRedirect, r as createAssetHashByChunkMap, s as isCssLikeModuleResource, t as createLoaderAnchorFinders, u as injectMpxCssRewritePreRules } from "./loader-anchors-TrU7EUr7.mjs";
8
- import path from "node:path";
9
- import process from "node:process";
10
- import fs from "node:fs";
11
- //#region src/bundlers/webpack/BaseUnifiedPlugin/v5-assets.ts
12
- function resolveWebpackStaleClassNameFallback(option, _compiler) {
13
- if (typeof option === "boolean") return option;
14
- return false;
15
- }
16
- function setupWebpackV5ProcessAssetsHook(options) {
17
- const { compiler, options: compilerOptions, appType, runtimeState, getRuntimeRefreshRequirement, refreshRuntimeMetadata, consumeRuntimeRefreshRequirement, debug } = options;
18
- const { Compilation, sources } = compiler.webpack;
19
- const { ConcatSource } = sources;
20
- const cssHandlerOptionsCache = /* @__PURE__ */ new Map();
21
- const cssUserHandlerOptionsCache = /* @__PURE__ */ new Map();
22
- compiler.hooks.compilation.tap(pluginName, (compilation) => {
23
- compilation.hooks.processAssets.tapPromise({
24
- name: pluginName,
25
- stage: Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE
26
- }, async (assets) => {
27
- compilerOptions.onStart();
28
- debug("start");
29
- await runtimeState.patchPromise;
30
- for (const chunk of compilation.chunks) if (chunk.id && chunk.hash) compilerOptions.cache.calcHashValueChanged(chunk.id, chunk.hash);
31
- const assetHashByChunk = createAssetHashByChunkMap(compilation.chunks);
32
- const entries = Object.entries(assets);
33
- const compilerOutputPath = compilation.compiler?.outputPath ?? compiler.outputPath;
34
- const outputDir = compilerOutputPath ? path.resolve(compilerOutputPath) : compilation.outputOptions?.path ?? process.cwd();
35
- const jsAssets = /* @__PURE__ */ new Map();
36
- for (const [file] of entries) if (compilerOptions.jsMatcher(file) || compilerOptions.wxsMatcher(file)) {
37
- const absolute = toAbsoluteOutputPath(file, outputDir);
38
- jsAssets.set(absolute, file);
39
- }
40
- const moduleGraphOptions = {
41
- resolve(specifier, importer) {
42
- return resolveOutputSpecifier(specifier, importer, outputDir, (candidate) => jsAssets.has(candidate));
43
- },
44
- load: (id) => {
45
- const assetName = jsAssets.get(id);
46
- if (!assetName) return;
47
- const asset = compilation.getAsset(assetName);
48
- if (!asset) return;
49
- const source = asset.source.source();
50
- return typeof source === "string" ? source : source.toString();
51
- },
52
- filter(id) {
53
- return jsAssets.has(id);
54
- }
55
- };
56
- const applyLinkedResults = (linked) => {
57
- if (!linked) return;
58
- for (const [id, { code }] of Object.entries(linked)) {
59
- const assetName = jsAssets.get(id);
60
- if (!assetName) continue;
61
- const asset = compilation.getAsset(assetName);
62
- if (!asset) continue;
63
- const previousSource = asset.source.source();
64
- const previous = typeof previousSource === "string" ? previousSource : previousSource.toString();
65
- if (previous === code) continue;
66
- const source = new ConcatSource(code);
67
- compilation.updateAsset(assetName, source);
68
- compilerOptions.onUpdate(assetName, previous, code);
69
- debug("js linked handle: %s", assetName);
70
- }
71
- };
72
- const groupedEntries = getGroupedEntries(entries, compilerOptions);
73
- const getCssHandlerOptions = (file) => {
74
- const majorVersion = runtimeState.twPatcher.majorVersion;
75
- const isMainChunk = compilerOptions.mainCssChunkMatcher(file, appType);
76
- const cacheKey = `${majorVersion ?? "unknown"}:${isMainChunk ? "1" : "0"}:${file}`;
77
- const cached = cssHandlerOptionsCache.get(cacheKey);
78
- if (cached) return cached;
79
- const created = {
80
- isMainChunk,
81
- postcssOptions: { options: { from: file } },
82
- majorVersion
83
- };
84
- cssHandlerOptionsCache.set(cacheKey, created);
85
- return created;
86
- };
87
- const getCssUserHandlerOptions = (file) => {
88
- const cacheKey = `${runtimeState.twPatcher.majorVersion ?? "unknown"}:${file}`;
89
- const cached = cssUserHandlerOptionsCache.get(cacheKey);
90
- if (cached) return cached;
91
- const created = {
92
- ...getCssHandlerOptions(file),
93
- isMainChunk: false
94
- };
95
- cssUserHandlerOptionsCache.set(cacheKey, created);
96
- return created;
97
- };
98
- const staleClassNameFallback = resolveWebpackStaleClassNameFallback(compilerOptions.staleClassNameFallback, compiler);
99
- const forceRuntimeRefresh = getRuntimeRefreshRequirement();
100
- debug("processAssets ensure runtime set forceRefresh=%s major=%s", forceRuntimeRefresh, runtimeState.twPatcher.majorVersion ?? "unknown");
101
- const runtimeSet = await ensureRuntimeClassSet(runtimeState, {
102
- forceRefresh: forceRuntimeRefresh,
103
- forceCollect: true,
104
- clearCache: forceRuntimeRefresh,
105
- allowEmpty: false
106
- });
107
- await refreshRuntimeMetadata(forceRuntimeRefresh);
108
- consumeRuntimeRefreshRequirement();
109
- const defaultTemplateHandlerOptions = { runtimeSet };
110
- debug("get runtimeSet, class count: %d", runtimeSet.size);
111
- const tasks = [];
112
- if (Array.isArray(groupedEntries.html)) for (const element of groupedEntries.html) {
113
- const [file, originalSource] = element;
114
- const rawSource = originalSource.source().toString();
115
- const cacheKey = file;
116
- const chunkHash = assetHashByChunk.get(file);
117
- tasks.push(processCachedTask({
118
- cache: compilerOptions.cache,
119
- cacheKey,
120
- hashKey: `${file}:asset`,
121
- rawSource,
122
- hash: chunkHash,
123
- applyResult(source) {
124
- compilation.updateAsset(file, source);
125
- },
126
- onCacheHit() {
127
- debug("html cache hit: %s", file);
128
- },
129
- transform: async () => {
130
- const wxml = await compilerOptions.templateHandler(rawSource, defaultTemplateHandlerOptions);
131
- const source = new ConcatSource(wxml);
132
- compilerOptions.onUpdate(file, rawSource, wxml);
133
- debug("html handle: %s", file);
134
- return { result: source };
135
- }
136
- }));
137
- }
138
- const jsTaskFactories = [];
139
- if (Array.isArray(groupedEntries.js)) for (const [file] of groupedEntries.js) {
140
- const cacheKey = getCacheKey(file);
141
- const asset = compilation.getAsset(file);
142
- if (!asset) continue;
143
- const absoluteFile = toAbsoluteOutputPath(file, outputDir);
144
- const initialSource = asset.source.source();
145
- const initialRawSource = typeof initialSource === "string" ? initialSource : initialSource.toString();
146
- const chunkHash = assetHashByChunk.get(file);
147
- jsTaskFactories.push(async () => {
148
- await processCachedTask({
149
- cache: compilerOptions.cache,
150
- cacheKey,
151
- hashKey: `${file}:asset`,
152
- rawSource: initialRawSource,
153
- hash: chunkHash,
154
- applyResult(source) {
155
- compilation.updateAsset(file, source);
156
- },
157
- onCacheHit() {
158
- debug("js cache hit: %s", file);
159
- },
160
- transform: async () => {
161
- const currentSourceValue = compilation.getAsset(file)?.source.source();
162
- const currentSource = typeof currentSourceValue === "string" ? currentSourceValue : currentSourceValue?.toString() ?? "";
163
- const handlerOptions = {
164
- staleClassNameFallback,
165
- tailwindcssMajorVersion: runtimeState.twPatcher.majorVersion,
166
- filename: absoluteFile,
167
- moduleGraph: moduleGraphOptions,
168
- babelParserOptions: { sourceFilename: absoluteFile }
169
- };
170
- if (shouldSkipJsTransform(currentSource, handlerOptions)) return { result: new ConcatSource(currentSource) };
171
- const { code, linked } = await compilerOptions.jsHandler(currentSource, runtimeSet, handlerOptions);
172
- const source = new ConcatSource(code);
173
- compilerOptions.onUpdate(file, currentSource, code);
174
- debug("js handle: %s", file);
175
- applyLinkedResults(linked);
176
- return { result: source };
177
- }
178
- });
179
- });
180
- }
181
- if (Array.isArray(groupedEntries.css)) for (const element of groupedEntries.css) {
182
- const [file, originalSource] = element;
183
- const rawSource = originalSource.source().toString();
184
- const cacheKey = file;
185
- const chunkHash = assetHashByChunk.get(file);
186
- tasks.push(processCachedTask({
187
- cache: compilerOptions.cache,
188
- cacheKey,
189
- hashKey: `${file}:asset`,
190
- rawSource,
191
- hash: chunkHash,
192
- applyResult(source) {
193
- compilation.updateAsset(file, source);
194
- },
195
- onCacheHit() {
196
- debug("css cache hit: %s", file);
197
- },
198
- transform: async () => {
199
- await runtimeState.patchPromise;
200
- const cssHandlerOptions = getCssHandlerOptions(file);
201
- const generated = await generateCssByGenerator({
202
- opts: compilerOptions,
203
- runtimeState,
204
- runtime: runtimeSet,
205
- rawSource,
206
- file,
207
- cssHandlerOptions,
208
- cssUserHandlerOptions: getCssUserHandlerOptions(file),
209
- styleHandler: compilerOptions.styleHandler,
210
- debug
211
- });
212
- const css = generated?.css ?? (await compilerOptions.styleHandler(rawSource, cssHandlerOptions)).css;
213
- const source = new ConcatSource(css);
214
- compilerOptions.onUpdate(file, rawSource, css);
215
- if (generated) debug("css handle via tailwind v%s engine(%s): %s", runtimeState.twPatcher.majorVersion, generated.target, file);
216
- else debug("css handle: %s", file);
217
- return { result: source };
218
- }
219
- }));
220
- }
221
- pushConcurrentTaskFactories(tasks, jsTaskFactories);
222
- await Promise.all(tasks);
223
- debug("end");
224
- compilerOptions.onEnd();
225
- });
226
- });
227
- }
228
- //#endregion
229
- //#region src/bundlers/webpack/BaseUnifiedPlugin/v5-loaders.ts
230
- function setupWebpackV5Loaders(options) {
231
- const { compiler, options: compilerOptions, appType, weappTailwindcssPackageDir, shouldRewriteCssImports, runtimeLoaderPath, runtimeCssImportRewriteLoaderPath, getClassSetInLoader, getRuntimeWatchDependencies, debug } = options;
232
- const isMpxApp = isMpx(appType);
233
- if (shouldRewriteCssImports && isMpxApp) ensureMpxTailwindcssAliases(compiler, weappTailwindcssPackageDir);
234
- const runtimeClassSetLoader = runtimeLoaderPath ?? path.resolve(__dirname, "./weapp-tw-runtime-classset-loader.js");
235
- const runtimeCssImportRewriteLoader = shouldRewriteCssImports ? runtimeCssImportRewriteLoaderPath ?? path.resolve(__dirname, "./weapp-tw-css-import-rewrite-loader.js") : void 0;
236
- const runtimeClassSetLoaderExists = fs.existsSync(runtimeClassSetLoader);
237
- const runtimeCssImportRewriteLoaderExists = runtimeCssImportRewriteLoader ? fs.existsSync(runtimeCssImportRewriteLoader) : false;
238
- const runtimeLoaderRewriteOptions = shouldRewriteCssImports ? {
239
- pkgDir: weappTailwindcssPackageDir,
240
- appType
241
- } : void 0;
242
- const classSetLoaderOptions = {
243
- getClassSet: getClassSetInLoader,
244
- getWatchDependencies: getRuntimeWatchDependencies
245
- };
246
- const { findRewriteAnchor, findClassSetAnchor } = createLoaderAnchorFinders(appType);
247
- const cssImportRewriteLoaderOptions = runtimeLoaderRewriteOptions ? { rewriteCssImports: runtimeLoaderRewriteOptions } : void 0;
248
- if (runtimeCssImportRewriteLoader && shouldRewriteCssImports && cssImportRewriteLoaderOptions && isMpxApp) injectMpxCssRewritePreRules(compiler, runtimeCssImportRewriteLoader, cssImportRewriteLoaderOptions);
249
- const createRuntimeClassSetLoaderEntry = () => ({
250
- loader: runtimeClassSetLoader,
251
- options: classSetLoaderOptions,
252
- ident: null,
253
- type: null
254
- });
255
- const createCssImportRewriteLoaderEntry = () => {
256
- if (!runtimeCssImportRewriteLoader) return null;
257
- return {
258
- loader: runtimeCssImportRewriteLoader,
259
- options: cssImportRewriteLoaderOptions,
260
- ident: null,
261
- type: null
262
- };
263
- };
264
- const { NormalModule } = compiler.webpack;
265
- compiler.hooks.compilation.tap(pluginName, (compilation) => {
266
- NormalModule.getCompilationHooks(compilation).loader.tap(pluginName, (_loaderContext, module) => {
267
- if (!(runtimeClassSetLoaderExists || runtimeCssImportRewriteLoaderExists)) return;
268
- patchMpxLoaderResolve(_loaderContext, weappTailwindcssPackageDir, shouldRewriteCssImports && isMpxApp);
269
- const loaderEntries = module.loaders || [];
270
- let rewriteAnchorIdx = findRewriteAnchor(loaderEntries);
271
- const classSetAnchorIdx = findClassSetAnchor(loaderEntries);
272
- const isCssModule = isCssLikeModuleResource(module.resource, compilerOptions.cssMatcher, appType);
273
- if (process.env.WEAPP_TW_LOADER_DEBUG && isCssModule) debug("loader hook css module: %s loaders=%o anchors=%o", module.resource, loaderEntries.map((x) => x.loader), {
274
- rewriteAnchorIdx,
275
- classSetAnchorIdx
276
- });
277
- if (process.env.WEAPP_TW_LOADER_DEBUG && typeof module.resource === "string" && module.resource.includes("app.css")) debug("app.css module loaders=%o anchors=%o", loaderEntries.map((x) => x.loader), {
278
- rewriteAnchorIdx,
279
- classSetAnchorIdx
280
- });
281
- else if (process.env.WEAPP_TW_LOADER_DEBUG && typeof module.resource === "string" && module.resource.endsWith(".css")) debug("css module seen: %s loaders=%o anchors=%o", module.resource, loaderEntries.map((x) => x.loader), {
282
- rewriteAnchorIdx,
283
- classSetAnchorIdx
284
- });
285
- if (rewriteAnchorIdx === -1 && classSetAnchorIdx === -1 && !isCssModule) return;
286
- const anchorlessInsert = (entry, position) => {
287
- if (position === "after") loaderEntries.push(entry);
288
- else loaderEntries.unshift(entry);
289
- };
290
- if (cssImportRewriteLoaderOptions && runtimeCssImportRewriteLoaderExists && runtimeCssImportRewriteLoader) {
291
- const existingIndex = loaderEntries.findIndex((entry) => entry.loader?.includes?.(runtimeCssImportRewriteLoader));
292
- const rewriteLoaderEntry = existingIndex !== -1 ? loaderEntries.splice(existingIndex, 1)[0] : createCssImportRewriteLoaderEntry();
293
- if (rewriteLoaderEntry) {
294
- const anchorIndex = findRewriteAnchor(loaderEntries);
295
- if (anchorIndex === -1) anchorlessInsert(rewriteLoaderEntry, "after");
296
- else loaderEntries.splice(anchorIndex + 1, 0, rewriteLoaderEntry);
297
- rewriteAnchorIdx = findRewriteAnchor(loaderEntries);
298
- }
299
- }
300
- if (runtimeClassSetLoaderExists && !hasLoaderEntry(loaderEntries, runtimeClassSetLoader)) {
301
- const classSetLoaderEntry = createRuntimeClassSetLoaderEntry();
302
- const anchorIndex = findClassSetAnchor(loaderEntries);
303
- if (anchorIndex === -1) anchorlessInsert(classSetLoaderEntry, "before");
304
- else {
305
- const insertIndex = anchorIndex === -1 ? rewriteAnchorIdx : anchorIndex;
306
- loaderEntries.splice(insertIndex, 0, classSetLoaderEntry);
307
- }
308
- }
309
- });
310
- });
311
- }
312
- //#endregion
313
- //#region src/bundlers/webpack/BaseUnifiedPlugin/v5.ts
314
- const debug = createDebug();
315
- const weappTailwindcssPackageDir = resolvePackageDir("weapp-tailwindcss");
316
- /**
317
- * @name UnifiedWebpackPluginV5
318
- * @description webpack5 核心转义插件
319
- * @link https://tw.icebreaker.top/docs/intro
320
- */
321
- var UnifiedWebpackPluginV5 = class {
322
- constructor(options = {}) {
323
- this.options = getCompilerContext(options);
324
- this.appType = this.options.appType;
325
- }
326
- apply(compiler) {
327
- compiler.options = compiler.options || {};
328
- const { disabled, onLoad, runtimeLoaderPath, runtimeCssImportRewriteLoaderPath, twPatcher: initialTwPatcher, refreshTailwindcssPatcher } = this.options;
329
- const disabledOptions = resolveDisabledOptions(disabled);
330
- const shouldRewriteCssImports = (initialTwPatcher.majorVersion ?? 0) >= 4 && this.options.rewriteCssImports !== false && !disabledOptions.rewriteCssImports;
331
- const isMpxApp = isMpx(this.appType);
332
- if (shouldRewriteCssImports) {
333
- applyTailwindcssCssImportRewrite(compiler, {
334
- pkgDir: weappTailwindcssPackageDir,
335
- enabled: true,
336
- appType: this.appType
337
- });
338
- setupMpxTailwindcssRedirect(weappTailwindcssPackageDir, isMpxApp);
339
- }
340
- if (disabledOptions.plugin) return;
341
- const patchRecorderState = setupPatchRecorder(initialTwPatcher, this.options.tailwindcssBasedir, {
342
- source: "runtime",
343
- cwd: this.options.tailwindcssBasedir ?? process.cwd()
344
- });
345
- const runtimeState = {
346
- twPatcher: initialTwPatcher,
347
- patchPromise: patchRecorderState.patchPromise,
348
- refreshTailwindcssPatcher,
349
- onPatchCompleted: patchRecorderState.onPatchCompleted
350
- };
351
- let runtimeSetPrepared = false;
352
- let runtimeSetSignature;
353
- let runtimeRefreshRequiredForCompilation = false;
354
- const runtimeWatchDependencyFiles = /* @__PURE__ */ new Set();
355
- const runtimeWatchDependencyContexts = /* @__PURE__ */ new Set();
356
- let runtimeMetadataPrepared = false;
357
- const updateRuntimeWatchDependencies = async () => {
358
- runtimeWatchDependencyFiles.clear();
359
- runtimeWatchDependencyContexts.clear();
360
- const tailwindOptions = resolveTailwindcssOptions(runtimeState.twPatcher.options);
361
- if (tailwindOptions?.config) runtimeWatchDependencyFiles.add(tailwindOptions.config);
362
- for (const entry of tailwindOptions?.v4?.cssEntries ?? []) runtimeWatchDependencyFiles.add(entry);
363
- for (const source of tailwindOptions?.v4?.sources ?? []) if (source?.base) runtimeWatchDependencyContexts.add(source.base);
364
- if (typeof runtimeState.twPatcher.collectContentTokens !== "function") return;
365
- try {
366
- const report = await runtimeState.twPatcher.collectContentTokens();
367
- for (const entry of report.entries ?? []) if (entry.file) runtimeWatchDependencyFiles.add(entry.file);
368
- for (const source of report.sources ?? []) if (source?.base) runtimeWatchDependencyContexts.add(source.base);
369
- } catch (error) {
370
- debug("collect runtime watch dependencies failed: %O", error);
371
- }
372
- };
373
- const ensureRuntimeMetadata = async (force = false) => {
374
- if (runtimeMetadataPrepared && !force) return;
375
- await updateRuntimeWatchDependencies();
376
- runtimeMetadataPrepared = true;
377
- };
378
- const syncRuntimeRefreshRequirement = () => {
379
- runtimeRefreshRequiredForCompilation = runtimeRefreshRequiredForCompilation || hasWatchChanges(compiler);
380
- };
381
- const resetRuntimePreparation = () => {
382
- runtimeSetPrepared = false;
383
- runtimeMetadataPrepared = false;
384
- syncRuntimeRefreshRequirement();
385
- };
386
- compiler.hooks.invalid?.tap?.(pluginName, () => {
387
- runtimeRefreshRequiredForCompilation = true;
388
- });
389
- compiler.hooks.watchRun?.tap?.(pluginName, syncRuntimeRefreshRequirement);
390
- if (compiler.hooks.thisCompilation?.tap) compiler.hooks.thisCompilation.tap(pluginName, resetRuntimePreparation);
391
- else if (compiler.hooks.compilation?.tap) compiler.hooks.compilation.tap(pluginName, resetRuntimePreparation);
392
- async function getClassSetInLoader() {
393
- if (runtimeSetPrepared) return;
394
- const signature = getRuntimeClassSetSignature(runtimeState.twPatcher);
395
- const forceRefresh = runtimeRefreshRequiredForCompilation || signature !== runtimeSetSignature;
396
- debug("runtime loader ensure class set forceRefresh=%s watchDirty=%s signatureChanged=%s", forceRefresh, runtimeRefreshRequiredForCompilation, signature !== runtimeSetSignature);
397
- runtimeSetPrepared = true;
398
- await ensureRuntimeClassSet(runtimeState, {
399
- forceRefresh,
400
- forceCollect: true,
401
- clearCache: forceRefresh,
402
- allowEmpty: true
403
- });
404
- await ensureRuntimeMetadata(forceRefresh);
405
- runtimeSetSignature = signature;
406
- runtimeRefreshRequiredForCompilation = false;
407
- }
408
- onLoad();
409
- setupWebpackV5Loaders({
410
- compiler,
411
- options: this.options,
412
- appType: this.appType,
413
- weappTailwindcssPackageDir,
414
- shouldRewriteCssImports,
415
- runtimeLoaderPath,
416
- runtimeCssImportRewriteLoaderPath,
417
- getClassSetInLoader,
418
- getRuntimeWatchDependencies() {
419
- return {
420
- files: runtimeWatchDependencyFiles,
421
- contexts: runtimeWatchDependencyContexts
422
- };
423
- },
424
- debug
425
- });
426
- setupWebpackV5ProcessAssetsHook({
427
- compiler,
428
- options: this.options,
429
- appType: this.appType,
430
- runtimeState,
431
- getRuntimeRefreshRequirement: () => runtimeRefreshRequiredForCompilation,
432
- refreshRuntimeMetadata: ensureRuntimeMetadata,
433
- consumeRuntimeRefreshRequirement() {
434
- runtimeRefreshRequiredForCompilation = false;
435
- },
436
- debug
437
- });
438
- }
439
- };
440
- //#endregion
441
- export { weappTailwindcssPackageDir as n, UnifiedWebpackPluginV5 as t };