tailwindcss 0.0.0-oxide-insiders.9ebaaac → 0.0.0-oxide.2

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 (286) hide show
  1. package/dist/chunk-VA4PAOBV.mjs +5017 -0
  2. package/dist/cli.d.mts +2 -0
  3. package/dist/cli.d.ts +2 -0
  4. package/dist/cli.js +5446 -0
  5. package/dist/cli.mjs +438 -0
  6. package/dist/lib.d.mts +244 -0
  7. package/dist/lib.d.ts +244 -0
  8. package/dist/lib.js +4947 -0
  9. package/dist/lib.mjs +1 -0
  10. package/index.css +4 -4
  11. package/package.json +36 -106
  12. package/preflight.css +404 -0
  13. package/theme.css +468 -0
  14. package/LICENSE +0 -21
  15. package/README.md +0 -41
  16. package/base.css +0 -1
  17. package/colors.d.ts +0 -3
  18. package/colors.js +0 -2
  19. package/components.css +0 -1
  20. package/defaultConfig.d.ts +0 -3
  21. package/defaultConfig.js +0 -2
  22. package/defaultTheme.d.ts +0 -4
  23. package/defaultTheme.js +0 -2
  24. package/lib/cli/build/deps.js +0 -62
  25. package/lib/cli/build/index.js +0 -54
  26. package/lib/cli/build/plugin.js +0 -383
  27. package/lib/cli/build/utils.js +0 -88
  28. package/lib/cli/build/watching.js +0 -182
  29. package/lib/cli/help/index.js +0 -73
  30. package/lib/cli/index.js +0 -230
  31. package/lib/cli/init/index.js +0 -67
  32. package/lib/cli-peer-dependencies.js +0 -36
  33. package/lib/cli.js +0 -7
  34. package/lib/corePluginList.js +0 -187
  35. package/lib/corePlugins.js +0 -4173
  36. package/lib/css/LICENSE +0 -25
  37. package/lib/css/preflight.css +0 -375
  38. package/lib/featureFlags.js +0 -83
  39. package/lib/index.js +0 -2
  40. package/lib/lib/cacheInvalidation.js +0 -92
  41. package/lib/lib/collapseAdjacentRules.js +0 -61
  42. package/lib/lib/collapseDuplicateDeclarations.js +0 -85
  43. package/lib/lib/content.js +0 -202
  44. package/lib/lib/defaultExtractor.js +0 -243
  45. package/lib/lib/detectNesting.js +0 -45
  46. package/lib/lib/evaluateTailwindFunctions.js +0 -238
  47. package/lib/lib/expandApplyAtRules.js +0 -534
  48. package/lib/lib/expandTailwindAtRules.js +0 -274
  49. package/lib/lib/findAtConfigPath.js +0 -46
  50. package/lib/lib/generateRules.js +0 -882
  51. package/lib/lib/getModuleDependencies.js +0 -99
  52. package/lib/lib/handleImportAtRules.js +0 -49
  53. package/lib/lib/load-config.js +0 -42
  54. package/lib/lib/normalizeTailwindDirectives.js +0 -91
  55. package/lib/lib/offsets.js +0 -306
  56. package/lib/lib/partitionApplyAtRules.js +0 -58
  57. package/lib/lib/regex.js +0 -74
  58. package/lib/lib/remap-bitfield.js +0 -89
  59. package/lib/lib/resolveDefaultsAtRules.js +0 -165
  60. package/lib/lib/setupContextUtils.js +0 -1255
  61. package/lib/lib/setupTrackingContext.js +0 -165
  62. package/lib/lib/sharedState.js +0 -87
  63. package/lib/lib/substituteScreenAtRules.js +0 -31
  64. package/lib/oxide/cli/build/deps.js +0 -89
  65. package/lib/oxide/cli/build/index.js +0 -53
  66. package/lib/oxide/cli/build/plugin.js +0 -354
  67. package/lib/oxide/cli/build/utils.js +0 -87
  68. package/lib/oxide/cli/build/watching.js +0 -179
  69. package/lib/oxide/cli/help/index.js +0 -72
  70. package/lib/oxide/cli/index.js +0 -214
  71. package/lib/oxide/cli/init/index.js +0 -56
  72. package/lib/oxide/cli.js +0 -5
  73. package/lib/oxide/postcss-plugin.js +0 -2
  74. package/lib/plugin.js +0 -100
  75. package/lib/postcss-plugins/nesting/README.md +0 -42
  76. package/lib/postcss-plugins/nesting/index.js +0 -21
  77. package/lib/postcss-plugins/nesting/plugin.js +0 -89
  78. package/lib/processTailwindFeatures.js +0 -64
  79. package/lib/public/colors.js +0 -355
  80. package/lib/public/create-plugin.js +0 -17
  81. package/lib/public/default-config.js +0 -18
  82. package/lib/public/default-theme.js +0 -18
  83. package/lib/public/load-config.js +0 -12
  84. package/lib/public/resolve-config.js +0 -24
  85. package/lib/util/applyImportantSelector.js +0 -36
  86. package/lib/util/bigSign.js +0 -13
  87. package/lib/util/buildMediaQuery.js +0 -27
  88. package/lib/util/cloneDeep.js +0 -22
  89. package/lib/util/cloneNodes.js +0 -34
  90. package/lib/util/color.js +0 -116
  91. package/lib/util/colorNames.js +0 -752
  92. package/lib/util/configurePlugins.js +0 -23
  93. package/lib/util/createPlugin.js +0 -32
  94. package/lib/util/createUtilityPlugin.js +0 -53
  95. package/lib/util/dataTypes.js +0 -304
  96. package/lib/util/defaults.js +0 -27
  97. package/lib/util/escapeClassName.js +0 -24
  98. package/lib/util/escapeCommas.js +0 -13
  99. package/lib/util/flattenColorPalette.js +0 -18
  100. package/lib/util/formatVariantSelector.js +0 -263
  101. package/lib/util/getAllConfigs.js +0 -52
  102. package/lib/util/hashConfig.js +0 -21
  103. package/lib/util/isKeyframeRule.js +0 -13
  104. package/lib/util/isPlainObject.js +0 -17
  105. package/lib/util/isSyntacticallyValidPropertyValue.js +0 -74
  106. package/lib/util/log.js +0 -61
  107. package/lib/util/nameClass.js +0 -49
  108. package/lib/util/negateValue.js +0 -36
  109. package/lib/util/normalizeConfig.js +0 -304
  110. package/lib/util/normalizeScreens.js +0 -178
  111. package/lib/util/parseAnimationValue.js +0 -93
  112. package/lib/util/parseBoxShadowValue.js +0 -88
  113. package/lib/util/parseDependency.js +0 -47
  114. package/lib/util/parseGlob.js +0 -36
  115. package/lib/util/parseObjectStyles.js +0 -36
  116. package/lib/util/pluginUtils.js +0 -276
  117. package/lib/util/prefixSelector.js +0 -39
  118. package/lib/util/pseudoElements.js +0 -229
  119. package/lib/util/removeAlphaVariables.js +0 -31
  120. package/lib/util/resolveConfig.js +0 -256
  121. package/lib/util/resolveConfigPath.js +0 -70
  122. package/lib/util/responsive.js +0 -24
  123. package/lib/util/splitAtTopLevelOnly.js +0 -51
  124. package/lib/util/tap.js +0 -14
  125. package/lib/util/toColorValue.js +0 -13
  126. package/lib/util/toPath.js +0 -32
  127. package/lib/util/transformThemeValue.js +0 -73
  128. package/lib/util/validateConfig.js +0 -43
  129. package/lib/util/validateFormalSyntax.js +0 -26
  130. package/lib/util/withAlphaVariable.js +0 -79
  131. package/lib/value-parser/LICENSE +0 -22
  132. package/lib/value-parser/README.md +0 -3
  133. package/lib/value-parser/index.d.js +0 -2
  134. package/lib/value-parser/index.js +0 -22
  135. package/lib/value-parser/parse.js +0 -259
  136. package/lib/value-parser/stringify.js +0 -38
  137. package/lib/value-parser/unit.js +0 -86
  138. package/lib/value-parser/walk.js +0 -16
  139. package/loadConfig.d.ts +0 -4
  140. package/loadConfig.js +0 -2
  141. package/nesting/index.js +0 -2
  142. package/peers/index.js +0 -96294
  143. package/plugin.d.ts +0 -11
  144. package/plugin.js +0 -2
  145. package/prettier.config.js +0 -19
  146. package/resolveConfig.d.ts +0 -12
  147. package/resolveConfig.js +0 -2
  148. package/screens.css +0 -1
  149. package/scripts/create-plugin-list.js +0 -10
  150. package/scripts/generate-types.js +0 -105
  151. package/scripts/release-channel.js +0 -18
  152. package/scripts/release-notes.js +0 -21
  153. package/scripts/swap-engines.js +0 -40
  154. package/scripts/type-utils.js +0 -27
  155. package/src/cli/build/deps.js +0 -56
  156. package/src/cli/build/index.js +0 -49
  157. package/src/cli/build/plugin.js +0 -451
  158. package/src/cli/build/utils.js +0 -76
  159. package/src/cli/build/watching.js +0 -229
  160. package/src/cli/help/index.js +0 -70
  161. package/src/cli/index.js +0 -216
  162. package/src/cli/init/index.js +0 -84
  163. package/src/cli-peer-dependencies.js +0 -15
  164. package/src/cli.js +0 -7
  165. package/src/corePluginList.js +0 -1
  166. package/src/corePlugins.js +0 -2849
  167. package/src/css/LICENSE +0 -25
  168. package/src/css/preflight.css +0 -375
  169. package/src/featureFlags.js +0 -70
  170. package/src/index.js +0 -1
  171. package/src/lib/cacheInvalidation.js +0 -52
  172. package/src/lib/collapseAdjacentRules.js +0 -58
  173. package/src/lib/collapseDuplicateDeclarations.js +0 -93
  174. package/src/lib/content.js +0 -235
  175. package/src/lib/defaultExtractor.js +0 -217
  176. package/src/lib/detectNesting.js +0 -47
  177. package/src/lib/evaluateTailwindFunctions.js +0 -272
  178. package/src/lib/expandApplyAtRules.js +0 -613
  179. package/src/lib/expandTailwindAtRules.js +0 -283
  180. package/src/lib/findAtConfigPath.js +0 -48
  181. package/src/lib/generateRules.js +0 -927
  182. package/src/lib/getModuleDependencies.js +0 -79
  183. package/src/lib/handleImportAtRules.js +0 -33
  184. package/src/lib/load-config.ts +0 -31
  185. package/src/lib/normalizeTailwindDirectives.js +0 -86
  186. package/src/lib/offsets.js +0 -373
  187. package/src/lib/partitionApplyAtRules.js +0 -52
  188. package/src/lib/regex.js +0 -74
  189. package/src/lib/remap-bitfield.js +0 -82
  190. package/src/lib/resolveDefaultsAtRules.js +0 -163
  191. package/src/lib/setupContextUtils.js +0 -1327
  192. package/src/lib/setupTrackingContext.js +0 -171
  193. package/src/lib/sharedState.js +0 -61
  194. package/src/lib/substituteScreenAtRules.js +0 -19
  195. package/src/oxide/cli/build/deps.ts +0 -91
  196. package/src/oxide/cli/build/index.ts +0 -47
  197. package/src/oxide/cli/build/plugin.ts +0 -419
  198. package/src/oxide/cli/build/utils.ts +0 -74
  199. package/src/oxide/cli/build/watching.ts +0 -225
  200. package/src/oxide/cli/help/index.ts +0 -69
  201. package/src/oxide/cli/index.ts +0 -204
  202. package/src/oxide/cli/init/index.ts +0 -64
  203. package/src/oxide/cli.ts +0 -1
  204. package/src/oxide/postcss-plugin.ts +0 -1
  205. package/src/plugin.js +0 -109
  206. package/src/postcss-plugins/nesting/README.md +0 -42
  207. package/src/postcss-plugins/nesting/index.js +0 -13
  208. package/src/postcss-plugins/nesting/plugin.js +0 -80
  209. package/src/processTailwindFeatures.js +0 -58
  210. package/src/public/colors.js +0 -322
  211. package/src/public/create-plugin.js +0 -2
  212. package/src/public/default-config.js +0 -4
  213. package/src/public/default-theme.js +0 -4
  214. package/src/public/load-config.js +0 -2
  215. package/src/public/resolve-config.js +0 -7
  216. package/src/util/applyImportantSelector.js +0 -27
  217. package/src/util/bigSign.js +0 -3
  218. package/src/util/buildMediaQuery.js +0 -22
  219. package/src/util/cloneDeep.js +0 -11
  220. package/src/util/cloneNodes.js +0 -28
  221. package/src/util/color.js +0 -88
  222. package/src/util/colorNames.js +0 -150
  223. package/src/util/configurePlugins.js +0 -23
  224. package/src/util/createPlugin.js +0 -27
  225. package/src/util/createUtilityPlugin.js +0 -37
  226. package/src/util/dataTypes.js +0 -292
  227. package/src/util/defaults.js +0 -17
  228. package/src/util/escapeClassName.js +0 -8
  229. package/src/util/escapeCommas.js +0 -3
  230. package/src/util/flattenColorPalette.js +0 -13
  231. package/src/util/formatVariantSelector.js +0 -316
  232. package/src/util/getAllConfigs.js +0 -45
  233. package/src/util/hashConfig.js +0 -5
  234. package/src/util/isKeyframeRule.js +0 -3
  235. package/src/util/isPlainObject.js +0 -8
  236. package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
  237. package/src/util/log.js +0 -29
  238. package/src/util/nameClass.js +0 -30
  239. package/src/util/negateValue.js +0 -24
  240. package/src/util/normalizeConfig.js +0 -335
  241. package/src/util/normalizeScreens.js +0 -140
  242. package/src/util/parseAnimationValue.js +0 -68
  243. package/src/util/parseBoxShadowValue.js +0 -72
  244. package/src/util/parseDependency.js +0 -44
  245. package/src/util/parseGlob.js +0 -24
  246. package/src/util/parseObjectStyles.js +0 -19
  247. package/src/util/pluginUtils.js +0 -291
  248. package/src/util/prefixSelector.js +0 -32
  249. package/src/util/pseudoElements.js +0 -170
  250. package/src/util/removeAlphaVariables.js +0 -24
  251. package/src/util/resolveConfig.js +0 -277
  252. package/src/util/resolveConfigPath.js +0 -66
  253. package/src/util/responsive.js +0 -10
  254. package/src/util/splitAtTopLevelOnly.js +0 -52
  255. package/src/util/tap.js +0 -4
  256. package/src/util/toColorValue.js +0 -3
  257. package/src/util/toPath.js +0 -26
  258. package/src/util/transformThemeValue.js +0 -62
  259. package/src/util/validateConfig.js +0 -33
  260. package/src/util/validateFormalSyntax.js +0 -34
  261. package/src/util/withAlphaVariable.js +0 -49
  262. package/src/value-parser/LICENSE +0 -22
  263. package/src/value-parser/README.md +0 -3
  264. package/src/value-parser/index.d.ts +0 -177
  265. package/src/value-parser/index.js +0 -28
  266. package/src/value-parser/parse.js +0 -303
  267. package/src/value-parser/stringify.js +0 -41
  268. package/src/value-parser/unit.js +0 -118
  269. package/src/value-parser/walk.js +0 -18
  270. package/stubs/.gitignore +0 -1
  271. package/stubs/.prettierrc.json +0 -6
  272. package/stubs/config.full.js +0 -991
  273. package/stubs/config.simple.js +0 -7
  274. package/stubs/postcss.config.cjs +0 -6
  275. package/stubs/postcss.config.js +0 -6
  276. package/stubs/tailwind.config.cjs +0 -2
  277. package/stubs/tailwind.config.js +0 -2
  278. package/stubs/tailwind.config.ts +0 -3
  279. package/tailwind.css +0 -5
  280. package/types/config.d.ts +0 -368
  281. package/types/generated/.gitkeep +0 -0
  282. package/types/generated/colors.d.ts +0 -298
  283. package/types/generated/corePluginList.d.ts +0 -1
  284. package/types/generated/default-theme.d.ts +0 -372
  285. package/types/index.d.ts +0 -7
  286. package/variants.css +0 -1
@@ -1,225 +0,0 @@
1
- import chokidar from 'chokidar'
2
- import fs from 'fs'
3
- import micromatch from 'micromatch'
4
- import normalizePath from 'normalize-path'
5
- import path from 'path'
6
-
7
- import { readFileWithRetries } from './utils'
8
-
9
- /**
10
- * The core idea of this watcher is:
11
- * 1. Whenever a file is added, changed, or renamed we queue a rebuild
12
- * 2. Perform as few rebuilds as possible by batching them together
13
- * 3. Coalesce events that happen in quick succession to avoid unnecessary rebuilds
14
- * 4. Ensure another rebuild happens _if_ changed while a rebuild is in progress
15
- */
16
-
17
- /**
18
- *
19
- * @param {*} args
20
- * @param {{ state, rebuild(changedFiles: any[]): Promise<any> }} param1
21
- * @returns {{
22
- * fswatcher: import('chokidar').FSWatcher,
23
- * refreshWatchedFiles(): void,
24
- * }}
25
- */
26
- export function createWatcher(args, { state, rebuild }) {
27
- let shouldPoll = args['--poll']
28
- let shouldCoalesceWriteEvents = shouldPoll || process.platform === 'win32'
29
-
30
- // Polling interval in milliseconds
31
- // Used only when polling or coalescing add/change events on Windows
32
- let pollInterval = 10
33
-
34
- let watcher = chokidar.watch([], {
35
- // Force checking for atomic writes in all situations
36
- // This causes chokidar to wait up to 100ms for a file to re-added after it's been unlinked
37
- // This only works when watching directories though
38
- atomic: true,
39
-
40
- usePolling: shouldPoll,
41
- interval: shouldPoll ? pollInterval : undefined,
42
- ignoreInitial: true,
43
- awaitWriteFinish: shouldCoalesceWriteEvents
44
- ? {
45
- stabilityThreshold: 50,
46
- pollInterval: pollInterval,
47
- }
48
- : false,
49
- })
50
-
51
- // A queue of rebuilds, file reads, etc… to run
52
- let chain = Promise.resolve()
53
-
54
- /**
55
- * A list of files that have been changed since the last rebuild
56
- *
57
- * @type {{file: string, content: () => Promise<string>, extension: string}[]}
58
- */
59
- let changedContent = []
60
-
61
- /**
62
- * A list of files for which a rebuild has already been queued.
63
- * This is used to prevent duplicate rebuilds when multiple events are fired for the same file.
64
- * The rebuilt file is cleared from this list when it's associated rebuild has _started_
65
- * This is because if the file is changed during a rebuild it won't trigger a new rebuild which it should
66
- **/
67
- let pendingRebuilds = new Set()
68
-
69
- let _timer
70
- let _reject
71
-
72
- /**
73
- * Rebuilds the changed files and resolves when the rebuild is
74
- * complete regardless of whether it was successful or not
75
- */
76
- async function rebuildAndContinue() {
77
- let changes = changedContent.splice(0)
78
-
79
- // There are no changes to rebuild so we can just do nothing
80
- if (changes.length === 0) {
81
- return Promise.resolve()
82
- }
83
-
84
- // Clear all pending rebuilds for the about-to-be-built files
85
- changes.forEach((change) => pendingRebuilds.delete(change.file))
86
-
87
- // Resolve the promise even when the rebuild fails
88
- return rebuild(changes).then(
89
- () => {},
90
- () => {}
91
- )
92
- }
93
-
94
- /**
95
- *
96
- * @param {*} file
97
- * @param {(() => Promise<string>) | null} content
98
- * @param {boolean} skipPendingCheck
99
- * @returns {Promise<void>}
100
- */
101
- function recordChangedFile(file, content = null, skipPendingCheck = false) {
102
- file = path.resolve(file)
103
-
104
- // Applications like Vim/Neovim fire both rename and change events in succession for atomic writes
105
- // In that case rebuild has already been queued by rename, so can be skipped in change
106
- if (pendingRebuilds.has(file) && !skipPendingCheck) {
107
- return Promise.resolve()
108
- }
109
-
110
- // Mark that a rebuild of this file is going to happen
111
- // It MUST happen synchronously before the rebuild is queued for this to be effective
112
- pendingRebuilds.add(file)
113
-
114
- changedContent.push({
115
- file,
116
- content: content ?? (() => fs.promises.readFile(file, 'utf8')),
117
- extension: path.extname(file).slice(1),
118
- })
119
-
120
- if (_timer) {
121
- clearTimeout(_timer)
122
- _reject()
123
- }
124
-
125
- // If a rebuild is already in progress we don't want to start another one until the 10ms timer has expired
126
- chain = chain.then(
127
- () =>
128
- new Promise((resolve, reject) => {
129
- _timer = setTimeout(resolve, 10)
130
- _reject = reject
131
- })
132
- )
133
-
134
- // Resolves once this file has been rebuilt (or the rebuild for this file has failed)
135
- // This queues as many rebuilds as there are changed files
136
- // But those rebuilds happen after some delay
137
- // And will immediately resolve if there are no changes
138
- chain = chain.then(rebuildAndContinue, rebuildAndContinue)
139
-
140
- return chain
141
- }
142
-
143
- watcher.on('change', (file) => recordChangedFile(file))
144
- watcher.on('add', (file) => recordChangedFile(file))
145
-
146
- // Restore watching any files that are "removed"
147
- // This can happen when a file is pseudo-atomically replaced (a copy is created, overwritten, the old one is unlinked, and the new one is renamed)
148
- // TODO: An an optimization we should allow removal when the config changes
149
- watcher.on('unlink', (file) => {
150
- file = normalizePath(file)
151
-
152
- // Only re-add the file if it's not covered by a dynamic pattern
153
- if (!micromatch.some([file], state.contentPatterns.dynamic)) {
154
- watcher.add(file)
155
- }
156
- })
157
-
158
- // Some applications such as Visual Studio (but not VS Code)
159
- // will only fire a rename event for atomic writes and not a change event
160
- // This is very likely a chokidar bug but it's one we need to work around
161
- // We treat this as a change event and rebuild the CSS
162
- watcher.on('raw', (evt, filePath, meta) => {
163
- if (evt !== 'rename') {
164
- return
165
- }
166
-
167
- let watchedPath = meta.watchedPath
168
-
169
- // Watched path might be the file itself
170
- // Or the directory it is in
171
- filePath = watchedPath.endsWith(filePath) ? watchedPath : path.join(watchedPath, filePath)
172
-
173
- // Skip this event since the files it is for does not match any of the registered content globs
174
- if (!micromatch.some([filePath], state.contentPatterns.all)) {
175
- return
176
- }
177
-
178
- // Skip since we've already queued a rebuild for this file that hasn't happened yet
179
- if (pendingRebuilds.has(filePath)) {
180
- return
181
- }
182
-
183
- // We'll go ahead and add the file to the pending rebuilds list here
184
- // It'll be removed when the rebuild starts unless the read fails
185
- // which will be taken care of as well
186
- pendingRebuilds.add(filePath)
187
-
188
- async function enqueue() {
189
- try {
190
- // We need to read the file as early as possible outside of the chain
191
- // because it may be gone by the time we get to it. doing the read
192
- // immediately increases the chance that the file is still there
193
- let content = await readFileWithRetries(path.resolve(filePath))
194
-
195
- if (content === undefined) {
196
- return
197
- }
198
-
199
- // This will push the rebuild onto the chain
200
- // We MUST skip the rebuild check here otherwise the rebuild will never happen on Linux
201
- // This is because the order of events and timing is different on Linux
202
- // @ts-ignore: TypeScript isn't picking up that content is a string here
203
- await recordChangedFile(filePath, () => content, true)
204
- } catch {
205
- // If reading the file fails, it's was probably a deleted temporary file
206
- // So we can ignore it and no rebuild is needed
207
- }
208
- }
209
-
210
- enqueue().then(() => {
211
- // If the file read fails we still need to make sure the file isn't stuck in the pending rebuilds list
212
- pendingRebuilds.delete(filePath)
213
- })
214
- })
215
-
216
- return {
217
- fswatcher: watcher,
218
-
219
- refreshWatchedFiles() {
220
- watcher.add(Array.from(state.contextDependencies))
221
- watcher.add(Array.from(state.configBag.dependencies))
222
- watcher.add(state.contentPatterns.all)
223
- },
224
- }
225
- }
@@ -1,69 +0,0 @@
1
- import packageJson from '../../../../package.json'
2
-
3
- export function help({ message, usage, commands, options }) {
4
- let indent = 2
5
-
6
- // Render header
7
- console.log()
8
- console.log(`${packageJson.name} v${packageJson.version}`)
9
-
10
- // Render message
11
- if (message) {
12
- console.log()
13
- for (let msg of message.split('\n')) {
14
- console.log(msg)
15
- }
16
- }
17
-
18
- // Render usage
19
- if (usage && usage.length > 0) {
20
- console.log()
21
- console.log('Usage:')
22
- for (let example of usage) {
23
- console.log(' '.repeat(indent), example)
24
- }
25
- }
26
-
27
- // Render commands
28
- if (commands && commands.length > 0) {
29
- console.log()
30
- console.log('Commands:')
31
- for (let command of commands) {
32
- console.log(' '.repeat(indent), command)
33
- }
34
- }
35
-
36
- // Render options
37
- if (options) {
38
- let groupedOptions = {}
39
- for (let [key, value] of Object.entries(options)) {
40
- if (typeof value === 'object') {
41
- groupedOptions[key] = { ...value, flags: [key] }
42
- } else {
43
- groupedOptions[value].flags.push(key)
44
- }
45
- }
46
-
47
- console.log()
48
- console.log('Options:')
49
- for (let { flags, description, deprecated } of Object.values(groupedOptions)) {
50
- if (deprecated) continue
51
-
52
- if (flags.length === 1) {
53
- console.log(
54
- ' '.repeat(indent + 4 /* 4 = "-i, ".length */),
55
- flags.slice().reverse().join(', ').padEnd(20, ' '),
56
- description
57
- )
58
- } else {
59
- console.log(
60
- ' '.repeat(indent),
61
- flags.slice().reverse().join(', ').padEnd(24, ' '),
62
- description
63
- )
64
- }
65
- }
66
- }
67
-
68
- console.log()
69
- }
@@ -1,204 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- import path from 'path'
4
- import arg from 'arg'
5
- import fs from 'fs'
6
-
7
- import { build } from './build'
8
- import { help } from './help'
9
- import { init } from './init'
10
-
11
- // ---
12
-
13
- function oneOf(...options) {
14
- return Object.assign(
15
- (value = true) => {
16
- for (let option of options) {
17
- let parsed = option(value)
18
- if (parsed === value) {
19
- return parsed
20
- }
21
- }
22
-
23
- throw new Error('...')
24
- },
25
- { manualParsing: true }
26
- )
27
- }
28
-
29
- let commands = {
30
- init: {
31
- run: init,
32
- args: {
33
- '--esm': { type: Boolean, description: `Initialize configuration file as ESM` },
34
- '--ts': { type: Boolean, description: `Initialize configuration file as TypeScript` },
35
- '--full': {
36
- type: Boolean,
37
- description: `Include the default values for all options in the generated configuration file`,
38
- },
39
- '-f': '--full',
40
- },
41
- },
42
- build: {
43
- run: build,
44
- args: {
45
- '--input': { type: String, description: 'Input file' },
46
- '--output': { type: String, description: 'Output file' },
47
- '--watch': {
48
- type: oneOf(String, Boolean),
49
- description: 'Watch for changes and rebuild as needed',
50
- },
51
- '--poll': {
52
- type: Boolean,
53
- description: 'Use polling instead of filesystem events when watching',
54
- },
55
- '--content': {
56
- type: String,
57
- description: 'Content paths to use for removing unused classes',
58
- },
59
- '--minify': { type: Boolean, description: 'Minify the output' },
60
- '--config': {
61
- type: String,
62
- description: 'Path to a custom config file',
63
- },
64
- '-c': '--config',
65
- '-i': '--input',
66
- '-o': '--output',
67
- '-m': '--minify',
68
- '-w': '--watch',
69
- '-p': '--poll',
70
- },
71
- },
72
- }
73
-
74
- let sharedFlags = {
75
- '--help': { type: Boolean, description: 'Display usage information' },
76
- '-h': '--help',
77
- }
78
-
79
- if (
80
- process.stdout.isTTY /* Detect redirecting output to a file */ &&
81
- (process.argv[2] === undefined ||
82
- process.argv.slice(2).every((flag) => sharedFlags[flag] !== undefined))
83
- ) {
84
- help({
85
- usage: [
86
- 'tailwindcss [--input input.css] [--output output.css] [--watch] [options...]',
87
- 'tailwindcss init [--full] [options...]',
88
- ],
89
- commands: Object.keys(commands)
90
- .filter((command) => command !== 'build')
91
- .map((command) => `${command} [options]`),
92
- options: { ...commands.build.args, ...sharedFlags },
93
- })
94
- process.exit(0)
95
- }
96
-
97
- let command = ((arg = '') => (arg.startsWith('-') ? undefined : arg))(process.argv[2]) || 'build'
98
-
99
- if (commands[command] === undefined) {
100
- if (fs.existsSync(path.resolve(command))) {
101
- // TODO: Deprecate this in future versions
102
- // Check if non-existing command, might be a file.
103
- command = 'build'
104
- } else {
105
- help({
106
- message: `Invalid command: ${command}`,
107
- usage: ['tailwindcss <command> [options]'],
108
- commands: Object.keys(commands)
109
- .filter((command) => command !== 'build')
110
- .map((command) => `${command} [options]`),
111
- options: sharedFlags,
112
- })
113
- process.exit(1)
114
- }
115
- }
116
-
117
- // Execute command
118
- let { args: flags, run } = commands[command]
119
- let args = (() => {
120
- try {
121
- let result = arg(
122
- Object.fromEntries(
123
- Object.entries({ ...flags, ...sharedFlags })
124
- .filter(([_key, value]) => !value?.type?.manualParsing)
125
- .map(([key, value]) => [key, typeof value === 'object' ? value.type : value])
126
- ),
127
- { permissive: true }
128
- )
129
-
130
- // Manual parsing of flags to allow for special flags like oneOf(Boolean, String)
131
- for (let i = result['_'].length - 1; i >= 0; --i) {
132
- let flag = result['_'][i]
133
- if (!flag.startsWith('-')) continue
134
-
135
- let [flagName, flagValue] = flag.split('=')
136
- let handler = flags[flagName]
137
-
138
- // Resolve flagName & handler
139
- while (typeof handler === 'string') {
140
- flagName = handler
141
- handler = flags[handler]
142
- }
143
-
144
- if (!handler) continue
145
-
146
- let args = []
147
- let offset = i + 1
148
-
149
- // --flag value syntax was used so we need to pull `value` from `args`
150
- if (flagValue === undefined) {
151
- // Parse args for current flag
152
- while (result['_'][offset] && !result['_'][offset].startsWith('-')) {
153
- args.push(result['_'][offset++])
154
- }
155
-
156
- // Cleanup manually parsed flags + args
157
- result['_'].splice(i, 1 + args.length)
158
-
159
- // No args were provided, use default value defined in handler
160
- // One arg was provided, use that directly
161
- // Multiple args were provided so pass them all in an array
162
- flagValue = args.length === 0 ? undefined : args.length === 1 ? args[0] : args
163
- } else {
164
- // Remove the whole flag from the args array
165
- result['_'].splice(i, 1)
166
- }
167
-
168
- // Set the resolved value in the `result` object
169
- result[flagName] = handler.type(flagValue, flagName)
170
- }
171
-
172
- // Ensure that the `command` is always the first argument in the `args`.
173
- // This is important so that we don't have to check if a default command
174
- // (build) was used or not from within each plugin.
175
- //
176
- // E.g.: tailwindcss input.css -> _: ['build', 'input.css']
177
- // E.g.: tailwindcss build input.css -> _: ['build', 'input.css']
178
- if (result['_'][0] !== command) {
179
- result['_'].unshift(command)
180
- }
181
-
182
- return result
183
- } catch (err) {
184
- if (err.code === 'ARG_UNKNOWN_OPTION') {
185
- help({
186
- message: err.message,
187
- usage: ['tailwindcss <command> [options]'],
188
- options: sharedFlags,
189
- })
190
- process.exit(1)
191
- }
192
- throw err
193
- }
194
- })()
195
-
196
- if (args['--help']) {
197
- help({
198
- options: { ...flags, ...sharedFlags },
199
- usage: [`tailwindcss ${command} [options]`],
200
- })
201
- process.exit(0)
202
- }
203
-
204
- run(args)
@@ -1,64 +0,0 @@
1
- import fs from 'fs'
2
- import path from 'path'
3
-
4
- function isESM() {
5
- const pkgPath = path.resolve('./package.json')
6
-
7
- try {
8
- let pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf8'))
9
- return pkg.type && pkg.type === 'module'
10
- } catch (err) {
11
- return false
12
- }
13
- }
14
-
15
- export function init(args) {
16
- let messages: string[] = []
17
-
18
- let isProjectESM = args['--ts'] || args['--esm'] || isESM()
19
- let syntax = args['--ts'] ? 'ts' : isProjectESM ? 'js' : 'cjs'
20
- let extension = args['--ts'] ? 'ts' : 'js'
21
-
22
- let tailwindConfigLocation = path.resolve(args['_'][1] ?? `./tailwind.config.${extension}`)
23
-
24
- if (fs.existsSync(tailwindConfigLocation)) {
25
- messages.push(`${path.basename(tailwindConfigLocation)} already exists.`)
26
- } else {
27
- let stubContentsFile = fs.readFileSync(
28
- args['--full']
29
- ? path.resolve(__dirname, '../../../../stubs/config.full.js')
30
- : path.resolve(__dirname, '../../../../stubs/config.simple.js'),
31
- 'utf8'
32
- )
33
-
34
- let stubFile = fs.readFileSync(
35
- path.resolve(__dirname, `../../../../stubs/tailwind.config.${syntax}`),
36
- 'utf8'
37
- )
38
-
39
- // Drop `content` in the oxide engine to promote auto content
40
- if (__OXIDE__) {
41
- stubContentsFile = stubContentsFile.replace(/ *content: \[\],\n/, '')
42
- }
43
-
44
- // Change colors import
45
- stubContentsFile = stubContentsFile.replace('../colors', 'tailwindcss/colors')
46
-
47
- // Replace contents of {ts,js,cjs} file with the stub {simple,full}.
48
- stubFile =
49
- stubFile
50
- .replace('__CONFIG__', stubContentsFile.replace('module.exports =', '').trim())
51
- .trim() + '\n\n'
52
-
53
- fs.writeFileSync(tailwindConfigLocation, stubFile, 'utf8')
54
-
55
- messages.push(`Created Tailwind CSS config file: ${path.basename(tailwindConfigLocation)}`)
56
- }
57
-
58
- if (messages.length > 0) {
59
- console.log()
60
- for (let message of messages) {
61
- console.log(message)
62
- }
63
- }
64
- }
package/src/oxide/cli.ts DELETED
@@ -1 +0,0 @@
1
- import './cli/index'
@@ -1 +0,0 @@
1
- module.exports = require('../plugin.js')
package/src/plugin.js DELETED
@@ -1,109 +0,0 @@
1
- import setupTrackingContext from './lib/setupTrackingContext'
2
- import processTailwindFeatures from './processTailwindFeatures'
3
- import { env } from './lib/sharedState'
4
- import { findAtConfigPath } from './lib/findAtConfigPath'
5
- import { handleImportAtRules } from './lib/handleImportAtRules'
6
-
7
- module.exports = function tailwindcss(configOrPath) {
8
- return {
9
- postcssPlugin: 'tailwindcss',
10
- plugins: [
11
- env.DEBUG &&
12
- function (root) {
13
- console.log('\n')
14
- console.time('JIT TOTAL')
15
- return root
16
- },
17
- ...(__OXIDE__ ? handleImportAtRules() : []),
18
- function (root, result) {
19
- // Use the path for the `@config` directive if it exists, otherwise use the
20
- // path for the file being processed
21
- configOrPath = findAtConfigPath(root, result) ?? configOrPath
22
-
23
- let context = setupTrackingContext(configOrPath)
24
-
25
- if (root.type === 'document') {
26
- let roots = root.nodes.filter((node) => node.type === 'root')
27
-
28
- for (const root of roots) {
29
- if (root.type === 'root') {
30
- processTailwindFeatures(context)(root, result)
31
- }
32
- }
33
-
34
- return
35
- }
36
-
37
- processTailwindFeatures(context)(root, result)
38
- },
39
- __OXIDE__ &&
40
- function lightningCssPlugin(_root, result) {
41
- let postcss = require('postcss')
42
- let lightningcss = require('lightningcss')
43
- let browserslist = require('browserslist')
44
-
45
- try {
46
- let transformed = lightningcss.transform({
47
- filename: result.opts.from,
48
- code: Buffer.from(result.root.toString()),
49
- minify: false,
50
- sourceMap: !!result.map,
51
- inputSourceMap: result.map ? result.map.toString() : undefined,
52
- targets:
53
- typeof process !== 'undefined' && process.env.JEST_WORKER_ID
54
- ? { chrome: 106 << 16 }
55
- : lightningcss.browserslistToTargets(
56
- browserslist(require('../package.json').browserslist)
57
- ),
58
-
59
- drafts: {
60
- nesting: true,
61
- customMedia: true,
62
- },
63
- })
64
-
65
- result.map = Object.assign(result.map ?? {}, {
66
- toJSON() {
67
- return transformed.map.toJSON()
68
- },
69
- toString() {
70
- return transformed.map.toString()
71
- },
72
- })
73
-
74
- result.root = postcss.parse(transformed.code.toString('utf8'))
75
- } catch (err) {
76
- if (typeof process !== 'undefined' && process.env.JEST_WORKER_ID) {
77
- let lines = err.source.split('\n')
78
- err = new Error(
79
- [
80
- 'Error formatting using Lightning CSS:',
81
- '',
82
- ...[
83
- '```css',
84
- ...lines.slice(Math.max(err.loc.line - 3, 0), err.loc.line),
85
- ' '.repeat(err.loc.column - 1) + '^-- ' + err.toString(),
86
- ...lines.slice(err.loc.line, err.loc.line + 2),
87
- '```',
88
- ],
89
- ].join('\n')
90
- )
91
- }
92
-
93
- if (Error.captureStackTrace) {
94
- Error.captureStackTrace(err, lightningCssPlugin)
95
- }
96
- throw err
97
- }
98
- },
99
- env.DEBUG &&
100
- function (root) {
101
- console.timeEnd('JIT TOTAL')
102
- console.log('\n')
103
- return root
104
- },
105
- ].filter(Boolean),
106
- }
107
- }
108
-
109
- module.exports.postcss = true