tailwindcss 0.0.0-insiders.eb8d929 → 0.0.0-insiders.ec0049a

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 (277) hide show
  1. package/README.md +5 -6
  2. package/dist/chunk-AZANAYY2.mjs +1 -0
  3. package/dist/chunk-CH45MXZF.mjs +10 -0
  4. package/dist/chunk-V2K3XTS4.mjs +1 -0
  5. package/dist/colors-b_6i0Oi7.d.ts +295 -0
  6. package/dist/colors.d.mts +295 -0
  7. package/dist/colors.d.ts +5 -0
  8. package/dist/colors.js +1 -0
  9. package/dist/colors.mjs +1 -0
  10. package/dist/default-theme.d.mts +1147 -0
  11. package/dist/default-theme.d.ts +1147 -0
  12. package/dist/default-theme.js +1 -0
  13. package/dist/default-theme.mjs +1 -0
  14. package/dist/flatten-color-palette.d.mts +6 -0
  15. package/dist/flatten-color-palette.d.ts +6 -0
  16. package/dist/flatten-color-palette.js +1 -0
  17. package/dist/flatten-color-palette.mjs +1 -0
  18. package/dist/lib.d.mts +260 -0
  19. package/dist/lib.d.ts +3 -0
  20. package/dist/lib.js +33 -0
  21. package/dist/lib.mjs +24 -0
  22. package/dist/plugin.d.mts +11 -0
  23. package/dist/plugin.d.ts +104 -0
  24. package/dist/plugin.js +1 -0
  25. package/dist/plugin.mjs +1 -0
  26. package/dist/resolve-config-BIFUA2FY.d.ts +29 -0
  27. package/dist/resolve-config-QUZ9b-Gn.d.mts +190 -0
  28. package/dist/types-B254mqw1.d.mts +98 -0
  29. package/index.css +863 -3
  30. package/package.json +73 -102
  31. package/preflight.css +383 -0
  32. package/theme.css +453 -0
  33. package/base.css +0 -1
  34. package/colors.d.ts +0 -3
  35. package/colors.js +0 -2
  36. package/components.css +0 -1
  37. package/defaultConfig.d.ts +0 -3
  38. package/defaultConfig.js +0 -2
  39. package/defaultTheme.d.ts +0 -4
  40. package/defaultTheme.js +0 -2
  41. package/lib/cli/build/index.js +0 -57
  42. package/lib/cli/build/plugin.js +0 -381
  43. package/lib/cli/build/utils.js +0 -88
  44. package/lib/cli/build/watching.js +0 -182
  45. package/lib/cli/help/index.js +0 -73
  46. package/lib/cli/index.js +0 -231
  47. package/lib/cli/init/index.js +0 -63
  48. package/lib/cli.js +0 -3
  49. package/lib/corePluginList.js +0 -188
  50. package/lib/corePlugins.js +0 -4197
  51. package/lib/css/LICENSE +0 -25
  52. package/lib/css/preflight.css +0 -375
  53. package/lib/featureFlags.js +0 -84
  54. package/lib/index.js +0 -2
  55. package/lib/lib/cacheInvalidation.js +0 -92
  56. package/lib/lib/collapseAdjacentRules.js +0 -61
  57. package/lib/lib/collapseDuplicateDeclarations.js +0 -85
  58. package/lib/lib/content.js +0 -207
  59. package/lib/lib/defaultExtractor.js +0 -243
  60. package/lib/lib/detectNesting.js +0 -45
  61. package/lib/lib/evaluateTailwindFunctions.js +0 -238
  62. package/lib/lib/expandApplyAtRules.js +0 -534
  63. package/lib/lib/expandTailwindAtRules.js +0 -314
  64. package/lib/lib/findAtConfigPath.js +0 -46
  65. package/lib/lib/generateRules.js +0 -879
  66. package/lib/lib/getModuleDependencies.js +0 -99
  67. package/lib/lib/handleImportAtRules.js +0 -50
  68. package/lib/lib/load-config.js +0 -42
  69. package/lib/lib/normalizeTailwindDirectives.js +0 -74
  70. package/lib/lib/offsets.js +0 -306
  71. package/lib/lib/partitionApplyAtRules.js +0 -58
  72. package/lib/lib/regex.js +0 -74
  73. package/lib/lib/remap-bitfield.js +0 -89
  74. package/lib/lib/resolveDefaultsAtRules.js +0 -165
  75. package/lib/lib/setupContextUtils.js +0 -1245
  76. package/lib/lib/setupTrackingContext.js +0 -166
  77. package/lib/lib/sharedState.js +0 -79
  78. package/lib/lib/substituteScreenAtRules.js +0 -31
  79. package/lib/plugin.js +0 -116
  80. package/lib/postcss-plugins/nesting/README.md +0 -42
  81. package/lib/postcss-plugins/nesting/index.js +0 -21
  82. package/lib/postcss-plugins/nesting/plugin.js +0 -89
  83. package/lib/processTailwindFeatures.js +0 -64
  84. package/lib/public/colors.js +0 -355
  85. package/lib/public/create-plugin.js +0 -17
  86. package/lib/public/default-config.js +0 -18
  87. package/lib/public/default-theme.js +0 -18
  88. package/lib/public/load-config.js +0 -12
  89. package/lib/public/resolve-config.js +0 -24
  90. package/lib/util/applyImportantSelector.js +0 -36
  91. package/lib/util/bigSign.js +0 -13
  92. package/lib/util/buildMediaQuery.js +0 -27
  93. package/lib/util/cloneDeep.js +0 -22
  94. package/lib/util/cloneNodes.js +0 -34
  95. package/lib/util/color.js +0 -116
  96. package/lib/util/colorNames.js +0 -752
  97. package/lib/util/configurePlugins.js +0 -23
  98. package/lib/util/createPlugin.js +0 -32
  99. package/lib/util/createUtilityPlugin.js +0 -53
  100. package/lib/util/dataTypes.js +0 -304
  101. package/lib/util/defaults.js +0 -27
  102. package/lib/util/escapeClassName.js +0 -24
  103. package/lib/util/escapeCommas.js +0 -13
  104. package/lib/util/flattenColorPalette.js +0 -18
  105. package/lib/util/formatVariantSelector.js +0 -263
  106. package/lib/util/getAllConfigs.js +0 -50
  107. package/lib/util/hashConfig.js +0 -21
  108. package/lib/util/isKeyframeRule.js +0 -13
  109. package/lib/util/isPlainObject.js +0 -17
  110. package/lib/util/isSyntacticallyValidPropertyValue.js +0 -74
  111. package/lib/util/log.js +0 -78
  112. package/lib/util/nameClass.js +0 -49
  113. package/lib/util/negateValue.js +0 -36
  114. package/lib/util/normalizeConfig.js +0 -308
  115. package/lib/util/normalizeScreens.js +0 -178
  116. package/lib/util/parseAnimationValue.js +0 -93
  117. package/lib/util/parseBoxShadowValue.js +0 -88
  118. package/lib/util/parseDependency.js +0 -47
  119. package/lib/util/parseGlob.js +0 -36
  120. package/lib/util/parseObjectStyles.js +0 -36
  121. package/lib/util/pluginUtils.js +0 -274
  122. package/lib/util/prefixSelector.js +0 -39
  123. package/lib/util/pseudoElements.js +0 -229
  124. package/lib/util/removeAlphaVariables.js +0 -31
  125. package/lib/util/resolveConfig.js +0 -256
  126. package/lib/util/resolveConfigPath.js +0 -70
  127. package/lib/util/responsive.js +0 -24
  128. package/lib/util/splitAtTopLevelOnly.js +0 -51
  129. package/lib/util/tap.js +0 -14
  130. package/lib/util/toColorValue.js +0 -13
  131. package/lib/util/toPath.js +0 -32
  132. package/lib/util/transformThemeValue.js +0 -73
  133. package/lib/util/validateConfig.js +0 -48
  134. package/lib/util/validateFormalSyntax.js +0 -26
  135. package/lib/util/withAlphaVariable.js +0 -79
  136. package/lib/value-parser/LICENSE +0 -22
  137. package/lib/value-parser/README.md +0 -3
  138. package/lib/value-parser/index.d.js +0 -2
  139. package/lib/value-parser/index.js +0 -22
  140. package/lib/value-parser/parse.js +0 -259
  141. package/lib/value-parser/stringify.js +0 -38
  142. package/lib/value-parser/unit.js +0 -86
  143. package/lib/value-parser/walk.js +0 -16
  144. package/loadConfig.d.ts +0 -4
  145. package/loadConfig.js +0 -2
  146. package/nesting/index.js +0 -2
  147. package/plugin.d.ts +0 -11
  148. package/plugin.js +0 -2
  149. package/prettier.config.js +0 -19
  150. package/resolveConfig.d.ts +0 -12
  151. package/resolveConfig.js +0 -2
  152. package/screens.css +0 -1
  153. package/scripts/create-plugin-list.js +0 -10
  154. package/scripts/generate-types.js +0 -105
  155. package/scripts/release-channel.js +0 -18
  156. package/scripts/release-notes.js +0 -21
  157. package/scripts/type-utils.js +0 -27
  158. package/src/cli/build/index.js +0 -53
  159. package/src/cli/build/plugin.js +0 -457
  160. package/src/cli/build/utils.js +0 -76
  161. package/src/cli/build/watching.js +0 -229
  162. package/src/cli/help/index.js +0 -70
  163. package/src/cli/index.js +0 -217
  164. package/src/cli/init/index.js +0 -79
  165. package/src/cli.js +0 -3
  166. package/src/corePluginList.js +0 -1
  167. package/src/corePlugins.js +0 -2877
  168. package/src/css/LICENSE +0 -25
  169. package/src/css/preflight.css +0 -375
  170. package/src/featureFlags.js +0 -68
  171. package/src/index.js +0 -1
  172. package/src/lib/cacheInvalidation.js +0 -52
  173. package/src/lib/collapseAdjacentRules.js +0 -58
  174. package/src/lib/collapseDuplicateDeclarations.js +0 -93
  175. package/src/lib/content.js +0 -240
  176. package/src/lib/defaultExtractor.js +0 -217
  177. package/src/lib/detectNesting.js +0 -47
  178. package/src/lib/evaluateTailwindFunctions.js +0 -272
  179. package/src/lib/expandApplyAtRules.js +0 -613
  180. package/src/lib/expandTailwindAtRules.js +0 -315
  181. package/src/lib/findAtConfigPath.js +0 -48
  182. package/src/lib/generateRules.js +0 -923
  183. package/src/lib/getModuleDependencies.js +0 -79
  184. package/src/lib/handleImportAtRules.js +0 -34
  185. package/src/lib/load-config.ts +0 -31
  186. package/src/lib/normalizeTailwindDirectives.js +0 -57
  187. package/src/lib/offsets.js +0 -373
  188. package/src/lib/partitionApplyAtRules.js +0 -52
  189. package/src/lib/regex.js +0 -74
  190. package/src/lib/remap-bitfield.js +0 -82
  191. package/src/lib/resolveDefaultsAtRules.js +0 -163
  192. package/src/lib/setupContextUtils.js +0 -1318
  193. package/src/lib/setupTrackingContext.js +0 -169
  194. package/src/lib/sharedState.js +0 -57
  195. package/src/lib/substituteScreenAtRules.js +0 -19
  196. package/src/plugin.js +0 -124
  197. package/src/postcss-plugins/nesting/README.md +0 -42
  198. package/src/postcss-plugins/nesting/index.js +0 -13
  199. package/src/postcss-plugins/nesting/plugin.js +0 -80
  200. package/src/processTailwindFeatures.js +0 -58
  201. package/src/public/colors.js +0 -322
  202. package/src/public/create-plugin.js +0 -2
  203. package/src/public/default-config.js +0 -4
  204. package/src/public/default-theme.js +0 -4
  205. package/src/public/load-config.js +0 -2
  206. package/src/public/resolve-config.js +0 -7
  207. package/src/util/applyImportantSelector.js +0 -27
  208. package/src/util/bigSign.js +0 -3
  209. package/src/util/buildMediaQuery.js +0 -22
  210. package/src/util/cloneDeep.js +0 -11
  211. package/src/util/cloneNodes.js +0 -28
  212. package/src/util/color.js +0 -88
  213. package/src/util/colorNames.js +0 -150
  214. package/src/util/configurePlugins.js +0 -23
  215. package/src/util/createPlugin.js +0 -27
  216. package/src/util/createUtilityPlugin.js +0 -37
  217. package/src/util/dataTypes.js +0 -292
  218. package/src/util/defaults.js +0 -17
  219. package/src/util/escapeClassName.js +0 -8
  220. package/src/util/escapeCommas.js +0 -3
  221. package/src/util/flattenColorPalette.js +0 -13
  222. package/src/util/formatVariantSelector.js +0 -316
  223. package/src/util/getAllConfigs.js +0 -38
  224. package/src/util/hashConfig.js +0 -5
  225. package/src/util/isKeyframeRule.js +0 -3
  226. package/src/util/isPlainObject.js +0 -8
  227. package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
  228. package/src/util/log.js +0 -53
  229. package/src/util/nameClass.js +0 -30
  230. package/src/util/negateValue.js +0 -24
  231. package/src/util/normalizeConfig.js +0 -328
  232. package/src/util/normalizeScreens.js +0 -140
  233. package/src/util/parseAnimationValue.js +0 -68
  234. package/src/util/parseBoxShadowValue.js +0 -72
  235. package/src/util/parseDependency.js +0 -44
  236. package/src/util/parseGlob.js +0 -24
  237. package/src/util/parseObjectStyles.js +0 -19
  238. package/src/util/pluginUtils.js +0 -287
  239. package/src/util/prefixSelector.js +0 -32
  240. package/src/util/pseudoElements.js +0 -170
  241. package/src/util/removeAlphaVariables.js +0 -24
  242. package/src/util/resolveConfig.js +0 -277
  243. package/src/util/resolveConfigPath.js +0 -66
  244. package/src/util/responsive.js +0 -10
  245. package/src/util/splitAtTopLevelOnly.js +0 -52
  246. package/src/util/tap.js +0 -4
  247. package/src/util/toColorValue.js +0 -3
  248. package/src/util/toPath.js +0 -26
  249. package/src/util/transformThemeValue.js +0 -62
  250. package/src/util/validateConfig.js +0 -36
  251. package/src/util/validateFormalSyntax.js +0 -34
  252. package/src/util/withAlphaVariable.js +0 -49
  253. package/src/value-parser/LICENSE +0 -22
  254. package/src/value-parser/README.md +0 -3
  255. package/src/value-parser/index.d.ts +0 -177
  256. package/src/value-parser/index.js +0 -28
  257. package/src/value-parser/parse.js +0 -303
  258. package/src/value-parser/stringify.js +0 -41
  259. package/src/value-parser/unit.js +0 -118
  260. package/src/value-parser/walk.js +0 -18
  261. package/stubs/.gitignore +0 -1
  262. package/stubs/.prettierrc.json +0 -6
  263. package/stubs/config.full.js +0 -1003
  264. package/stubs/config.simple.js +0 -7
  265. package/stubs/postcss.config.cjs +0 -5
  266. package/stubs/postcss.config.js +0 -5
  267. package/stubs/tailwind.config.cjs +0 -2
  268. package/stubs/tailwind.config.js +0 -2
  269. package/stubs/tailwind.config.ts +0 -3
  270. package/tailwind.css +0 -5
  271. package/types/config.d.ts +0 -369
  272. package/types/generated/.gitkeep +0 -0
  273. package/types/generated/colors.d.ts +0 -298
  274. package/types/generated/corePluginList.d.ts +0 -1
  275. package/types/generated/default-theme.d.ts +0 -372
  276. package/types/index.d.ts +0 -7
  277. package/variants.css +0 -1
@@ -1,229 +0,0 @@
1
- // @ts-check
2
-
3
- import chokidar from 'chokidar'
4
- import fs from 'fs'
5
- import micromatch from 'micromatch'
6
- import normalizePath from 'normalize-path'
7
- import path from 'path'
8
-
9
- import { readFileWithRetries } from './utils.js'
10
-
11
- /**
12
- * The core idea of this watcher is:
13
- * 1. Whenever a file is added, changed, or renamed we queue a rebuild
14
- * 2. Perform as few rebuilds as possible by batching them together
15
- * 3. Coalesce events that happen in quick succession to avoid unnecessary rebuilds
16
- * 4. Ensure another rebuild happens _if_ changed while a rebuild is in progress
17
- */
18
-
19
- /**
20
- *
21
- * @param {*} args
22
- * @param {{ state, rebuild(changedFiles: any[]): Promise<any> }} param1
23
- * @returns {{
24
- * fswatcher: import('chokidar').FSWatcher,
25
- * refreshWatchedFiles(): void,
26
- * }}
27
- */
28
- export function createWatcher(args, { state, rebuild }) {
29
- let shouldPoll = args['--poll']
30
- let shouldCoalesceWriteEvents = shouldPoll || process.platform === 'win32'
31
-
32
- // Polling interval in milliseconds
33
- // Used only when polling or coalescing add/change events on Windows
34
- let pollInterval = 10
35
-
36
- let watcher = chokidar.watch([], {
37
- // Force checking for atomic writes in all situations
38
- // This causes chokidar to wait up to 100ms for a file to re-added after it's been unlinked
39
- // This only works when watching directories though
40
- atomic: true,
41
-
42
- usePolling: shouldPoll,
43
- interval: shouldPoll ? pollInterval : undefined,
44
- ignoreInitial: true,
45
- awaitWriteFinish: shouldCoalesceWriteEvents
46
- ? {
47
- stabilityThreshold: 50,
48
- pollInterval: pollInterval,
49
- }
50
- : false,
51
- })
52
-
53
- // A queue of rebuilds, file reads, etc… to run
54
- let chain = Promise.resolve()
55
-
56
- /**
57
- * A list of files that have been changed since the last rebuild
58
- *
59
- * @type {{file: string, content: () => Promise<string>, extension: string}[]}
60
- */
61
- let changedContent = []
62
-
63
- /**
64
- * A list of files for which a rebuild has already been queued.
65
- * This is used to prevent duplicate rebuilds when multiple events are fired for the same file.
66
- * The rebuilt file is cleared from this list when it's associated rebuild has _started_
67
- * This is because if the file is changed during a rebuild it won't trigger a new rebuild which it should
68
- **/
69
- let pendingRebuilds = new Set()
70
-
71
- let _timer
72
- let _reject
73
-
74
- /**
75
- * Rebuilds the changed files and resolves when the rebuild is
76
- * complete regardless of whether it was successful or not
77
- */
78
- async function rebuildAndContinue() {
79
- let changes = changedContent.splice(0)
80
-
81
- // There are no changes to rebuild so we can just do nothing
82
- if (changes.length === 0) {
83
- return Promise.resolve()
84
- }
85
-
86
- // Clear all pending rebuilds for the about-to-be-built files
87
- changes.forEach((change) => pendingRebuilds.delete(change.file))
88
-
89
- // Resolve the promise even when the rebuild fails
90
- return rebuild(changes).then(
91
- () => {},
92
- (e) => {
93
- console.error(e.toString())
94
- }
95
- )
96
- }
97
-
98
- /**
99
- *
100
- * @param {*} file
101
- * @param {(() => Promise<string>) | null} content
102
- * @param {boolean} skipPendingCheck
103
- * @returns {Promise<void>}
104
- */
105
- function recordChangedFile(file, content = null, skipPendingCheck = false) {
106
- file = path.resolve(file)
107
-
108
- // Applications like Vim/Neovim fire both rename and change events in succession for atomic writes
109
- // In that case rebuild has already been queued by rename, so can be skipped in change
110
- if (pendingRebuilds.has(file) && !skipPendingCheck) {
111
- return Promise.resolve()
112
- }
113
-
114
- // Mark that a rebuild of this file is going to happen
115
- // It MUST happen synchronously before the rebuild is queued for this to be effective
116
- pendingRebuilds.add(file)
117
-
118
- changedContent.push({
119
- file,
120
- content: content ?? (() => fs.promises.readFile(file, 'utf8')),
121
- extension: path.extname(file).slice(1),
122
- })
123
-
124
- if (_timer) {
125
- clearTimeout(_timer)
126
- _reject()
127
- }
128
-
129
- // If a rebuild is already in progress we don't want to start another one until the 10ms timer has expired
130
- chain = chain.then(
131
- () =>
132
- new Promise((resolve, reject) => {
133
- _timer = setTimeout(resolve, 10)
134
- _reject = reject
135
- })
136
- )
137
-
138
- // Resolves once this file has been rebuilt (or the rebuild for this file has failed)
139
- // This queues as many rebuilds as there are changed files
140
- // But those rebuilds happen after some delay
141
- // And will immediately resolve if there are no changes
142
- chain = chain.then(rebuildAndContinue, rebuildAndContinue)
143
-
144
- return chain
145
- }
146
-
147
- watcher.on('change', (file) => recordChangedFile(file))
148
- watcher.on('add', (file) => recordChangedFile(file))
149
-
150
- // Restore watching any files that are "removed"
151
- // 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)
152
- // TODO: An an optimization we should allow removal when the config changes
153
- watcher.on('unlink', (file) => {
154
- file = normalizePath(file)
155
-
156
- // Only re-add the file if it's not covered by a dynamic pattern
157
- if (!micromatch.some([file], state.contentPatterns.dynamic)) {
158
- watcher.add(file)
159
- }
160
- })
161
-
162
- // Some applications such as Visual Studio (but not VS Code)
163
- // will only fire a rename event for atomic writes and not a change event
164
- // This is very likely a chokidar bug but it's one we need to work around
165
- // We treat this as a change event and rebuild the CSS
166
- watcher.on('raw', (evt, filePath, meta) => {
167
- if (evt !== 'rename') {
168
- return
169
- }
170
-
171
- let watchedPath = meta.watchedPath
172
-
173
- // Watched path might be the file itself
174
- // Or the directory it is in
175
- filePath = watchedPath.endsWith(filePath) ? watchedPath : path.join(watchedPath, filePath)
176
-
177
- // Skip this event since the files it is for does not match any of the registered content globs
178
- if (!micromatch.some([filePath], state.contentPatterns.all)) {
179
- return
180
- }
181
-
182
- // Skip since we've already queued a rebuild for this file that hasn't happened yet
183
- if (pendingRebuilds.has(filePath)) {
184
- return
185
- }
186
-
187
- // We'll go ahead and add the file to the pending rebuilds list here
188
- // It'll be removed when the rebuild starts unless the read fails
189
- // which will be taken care of as well
190
- pendingRebuilds.add(filePath)
191
-
192
- async function enqueue() {
193
- try {
194
- // We need to read the file as early as possible outside of the chain
195
- // because it may be gone by the time we get to it. doing the read
196
- // immediately increases the chance that the file is still there
197
- let content = await readFileWithRetries(path.resolve(filePath))
198
-
199
- if (content === undefined) {
200
- return
201
- }
202
-
203
- // This will push the rebuild onto the chain
204
- // We MUST skip the rebuild check here otherwise the rebuild will never happen on Linux
205
- // This is because the order of events and timing is different on Linux
206
- // @ts-ignore: TypeScript isn't picking up that content is a string here
207
- await recordChangedFile(filePath, () => content, true)
208
- } catch {
209
- // If reading the file fails, it's was probably a deleted temporary file
210
- // So we can ignore it and no rebuild is needed
211
- }
212
- }
213
-
214
- enqueue().then(() => {
215
- // If the file read fails we still need to make sure the file isn't stuck in the pending rebuilds list
216
- pendingRebuilds.delete(filePath)
217
- })
218
- })
219
-
220
- return {
221
- fswatcher: watcher,
222
-
223
- refreshWatchedFiles() {
224
- watcher.add(Array.from(state.contextDependencies))
225
- watcher.add(Array.from(state.configBag.dependencies))
226
- watcher.add(state.contentPatterns.all)
227
- },
228
- }
229
- }
@@ -1,70 +0,0 @@
1
- // @ts-check
2
- import packageJson from '../../../package.json'
3
-
4
- export function help({ message, usage, commands, options }) {
5
- let indent = 2
6
-
7
- // Render header
8
- console.log()
9
- console.log(`${packageJson.name} v${packageJson.version}`)
10
-
11
- // Render message
12
- if (message) {
13
- console.log()
14
- for (let msg of message.split('\n')) {
15
- console.log(msg)
16
- }
17
- }
18
-
19
- // Render usage
20
- if (usage && usage.length > 0) {
21
- console.log()
22
- console.log('Usage:')
23
- for (let example of usage) {
24
- console.log(' '.repeat(indent), example)
25
- }
26
- }
27
-
28
- // Render commands
29
- if (commands && commands.length > 0) {
30
- console.log()
31
- console.log('Commands:')
32
- for (let command of commands) {
33
- console.log(' '.repeat(indent), command)
34
- }
35
- }
36
-
37
- // Render options
38
- if (options) {
39
- let groupedOptions = {}
40
- for (let [key, value] of Object.entries(options)) {
41
- if (typeof value === 'object') {
42
- groupedOptions[key] = { ...value, flags: [key] }
43
- } else {
44
- groupedOptions[value].flags.push(key)
45
- }
46
- }
47
-
48
- console.log()
49
- console.log('Options:')
50
- for (let { flags, description, deprecated } of Object.values(groupedOptions)) {
51
- if (deprecated) continue
52
-
53
- if (flags.length === 1) {
54
- console.log(
55
- ' '.repeat(indent + 4 /* 4 = "-i, ".length */),
56
- flags.slice().reverse().join(', ').padEnd(20, ' '),
57
- description
58
- )
59
- } else {
60
- console.log(
61
- ' '.repeat(indent),
62
- flags.slice().reverse().join(', ').padEnd(24, ' '),
63
- description
64
- )
65
- }
66
- }
67
- }
68
-
69
- console.log()
70
- }
package/src/cli/index.js DELETED
@@ -1,217 +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
- function oneOf(...options) {
12
- return Object.assign(
13
- (value = true) => {
14
- for (let option of options) {
15
- let parsed = option(value)
16
- if (parsed === value) {
17
- return parsed
18
- }
19
- }
20
-
21
- throw new Error('...')
22
- },
23
- { manualParsing: true }
24
- )
25
- }
26
-
27
- let commands = {
28
- init: {
29
- run: init,
30
- args: {
31
- '--esm': { type: Boolean, description: `Initialize configuration file as ESM` },
32
- '--ts': { type: Boolean, description: `Initialize configuration file as TypeScript` },
33
- '--postcss': { type: Boolean, description: `Initialize a \`postcss.config.js\` file` },
34
- '--full': {
35
- type: Boolean,
36
- description: `Include the default values for all options in the generated configuration file`,
37
- },
38
- '-f': '--full',
39
- '-p': '--postcss',
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
- '--purge': {
60
- type: String,
61
- deprecated: true,
62
- },
63
- '--postcss': {
64
- type: oneOf(String, Boolean),
65
- description: 'Load custom PostCSS configuration',
66
- },
67
- '--minify': { type: Boolean, description: 'Minify the output' },
68
- '--config': {
69
- type: String,
70
- description: 'Path to a custom config file',
71
- },
72
- '--no-autoprefixer': {
73
- deprecated: true,
74
- type: Boolean,
75
- description: 'Disable autoprefixer',
76
- },
77
- '-c': '--config',
78
- '-i': '--input',
79
- '-o': '--output',
80
- '-m': '--minify',
81
- '-w': '--watch',
82
- '-p': '--poll',
83
- },
84
- },
85
- }
86
-
87
- let sharedFlags = {
88
- '--help': { type: Boolean, description: 'Display usage information' },
89
- '-h': '--help',
90
- }
91
-
92
- if (
93
- process.stdout.isTTY /* Detect redirecting output to a file */ &&
94
- (process.argv[2] === undefined ||
95
- process.argv.slice(2).every((flag) => sharedFlags[flag] !== undefined))
96
- ) {
97
- help({
98
- usage: [
99
- 'tailwindcss [--input input.css] [--output output.css] [--watch] [options...]',
100
- 'tailwindcss init [--full] [--postcss] [options...]',
101
- ],
102
- commands: Object.keys(commands)
103
- .filter((command) => command !== 'build')
104
- .map((command) => `${command} [options]`),
105
- options: { ...commands.build.args, ...sharedFlags },
106
- })
107
- process.exit(0)
108
- }
109
-
110
- let command = ((arg = '') => (arg.startsWith('-') ? undefined : arg))(process.argv[2]) || 'build'
111
-
112
- if (commands[command] === undefined) {
113
- if (fs.existsSync(path.resolve(command))) {
114
- // TODO: Deprecate this in future versions
115
- // Check if non-existing command, might be a file.
116
- command = 'build'
117
- } else {
118
- help({
119
- message: `Invalid command: ${command}`,
120
- usage: ['tailwindcss <command> [options]'],
121
- commands: Object.keys(commands)
122
- .filter((command) => command !== 'build')
123
- .map((command) => `${command} [options]`),
124
- options: sharedFlags,
125
- })
126
- process.exit(1)
127
- }
128
- }
129
-
130
- // Execute command
131
- let { args: flags, run } = commands[command]
132
- let args = (() => {
133
- try {
134
- let result = arg(
135
- Object.fromEntries(
136
- Object.entries({ ...flags, ...sharedFlags })
137
- .filter(([_key, value]) => !value?.type?.manualParsing)
138
- .map(([key, value]) => [key, typeof value === 'object' ? value.type : value])
139
- ),
140
- { permissive: true }
141
- )
142
-
143
- // Manual parsing of flags to allow for special flags like oneOf(Boolean, String)
144
- for (let i = result['_'].length - 1; i >= 0; --i) {
145
- let flag = result['_'][i]
146
- if (!flag.startsWith('-')) continue
147
-
148
- let [flagName, flagValue] = flag.split('=')
149
- let handler = flags[flagName]
150
-
151
- // Resolve flagName & handler
152
- while (typeof handler === 'string') {
153
- flagName = handler
154
- handler = flags[handler]
155
- }
156
-
157
- if (!handler) continue
158
-
159
- let args = []
160
- let offset = i + 1
161
-
162
- // --flag value syntax was used so we need to pull `value` from `args`
163
- if (flagValue === undefined) {
164
- // Parse args for current flag
165
- while (result['_'][offset] && !result['_'][offset].startsWith('-')) {
166
- args.push(result['_'][offset++])
167
- }
168
-
169
- // Cleanup manually parsed flags + args
170
- result['_'].splice(i, 1 + args.length)
171
-
172
- // No args were provided, use default value defined in handler
173
- // One arg was provided, use that directly
174
- // Multiple args were provided so pass them all in an array
175
- flagValue = args.length === 0 ? undefined : args.length === 1 ? args[0] : args
176
- } else {
177
- // Remove the whole flag from the args array
178
- result['_'].splice(i, 1)
179
- }
180
-
181
- // Set the resolved value in the `result` object
182
- result[flagName] = handler.type(flagValue, flagName)
183
- }
184
-
185
- // Ensure that the `command` is always the first argument in the `args`.
186
- // This is important so that we don't have to check if a default command
187
- // (build) was used or not from within each plugin.
188
- //
189
- // E.g.: tailwindcss input.css -> _: ['build', 'input.css']
190
- // E.g.: tailwindcss build input.css -> _: ['build', 'input.css']
191
- if (result['_'][0] !== command) {
192
- result['_'].unshift(command)
193
- }
194
-
195
- return result
196
- } catch (err) {
197
- if (err.code === 'ARG_UNKNOWN_OPTION') {
198
- help({
199
- message: err.message,
200
- usage: ['tailwindcss <command> [options]'],
201
- options: sharedFlags,
202
- })
203
- process.exit(1)
204
- }
205
- throw err
206
- }
207
- })()
208
-
209
- if (args['--help']) {
210
- help({
211
- options: { ...flags, ...sharedFlags },
212
- usage: [`tailwindcss ${command} [options]`],
213
- })
214
- process.exit(0)
215
- }
216
-
217
- run(args)
@@ -1,79 +0,0 @@
1
- // @ts-check
2
-
3
- import fs from 'fs'
4
- import path from 'path'
5
-
6
- function isESM() {
7
- const pkgPath = path.resolve('./package.json')
8
-
9
- try {
10
- let pkg = JSON.parse(fs.readFileSync(pkgPath, 'utf8'))
11
- return pkg.type && pkg.type === 'module'
12
- } catch (err) {
13
- return false
14
- }
15
- }
16
-
17
- export function init(args) {
18
- let messages = []
19
-
20
- let isProjectESM = args['--ts'] || args['--esm'] || isESM()
21
- let syntax = args['--ts'] ? 'ts' : isProjectESM ? 'js' : 'cjs'
22
- let extension = args['--ts'] ? 'ts' : 'js'
23
-
24
- let tailwindConfigLocation = path.resolve(args['_'][1] ?? `./tailwind.config.${extension}`)
25
-
26
- if (fs.existsSync(tailwindConfigLocation)) {
27
- messages.push(`${path.basename(tailwindConfigLocation)} already exists.`)
28
- } else {
29
- let stubContentsFile = fs.readFileSync(
30
- args['--full']
31
- ? path.resolve(__dirname, '../../../stubs/config.full.js')
32
- : path.resolve(__dirname, '../../../stubs/config.simple.js'),
33
- 'utf8'
34
- )
35
-
36
- let stubFile = fs.readFileSync(
37
- path.resolve(__dirname, `../../../stubs/tailwind.config.${syntax}`),
38
- 'utf8'
39
- )
40
-
41
- // Change colors import
42
- stubContentsFile = stubContentsFile.replace('../colors', 'tailwindcss/colors')
43
-
44
- // Replace contents of {ts,js,cjs} file with the stub {simple,full}.
45
- stubFile =
46
- stubFile
47
- .replace('__CONFIG__', stubContentsFile.replace('module.exports =', '').trim())
48
- .trim() + '\n\n'
49
-
50
- fs.writeFileSync(tailwindConfigLocation, stubFile, 'utf8')
51
-
52
- messages.push(`Created Tailwind CSS config file: ${path.basename(tailwindConfigLocation)}`)
53
- }
54
-
55
- if (args['--postcss']) {
56
- let postcssConfigLocation = path.resolve('./postcss.config.js')
57
- if (fs.existsSync(postcssConfigLocation)) {
58
- messages.push(`${path.basename(postcssConfigLocation)} already exists.`)
59
- } else {
60
- let stubFile = fs.readFileSync(
61
- isProjectESM
62
- ? path.resolve(__dirname, '../../../stubs/postcss.config.js')
63
- : path.resolve(__dirname, '../../../stubs/postcss.config.cjs'),
64
- 'utf8'
65
- )
66
-
67
- fs.writeFileSync(postcssConfigLocation, stubFile, 'utf8')
68
-
69
- messages.push(`Created PostCSS config file: ${path.basename(postcssConfigLocation)}`)
70
- }
71
- }
72
-
73
- if (messages.length > 0) {
74
- console.log()
75
- for (let message of messages) {
76
- console.log(message)
77
- }
78
- }
79
- }
package/src/cli.js DELETED
@@ -1,3 +0,0 @@
1
- #!/usr/bin/env node
2
-
3
- module.exports = require('./cli/index')
@@ -1 +0,0 @@
1
- export default ["preflight","container","accessibility","pointerEvents","visibility","position","inset","isolation","zIndex","order","gridColumn","gridColumnStart","gridColumnEnd","gridRow","gridRowStart","gridRowEnd","float","clear","margin","boxSizing","lineClamp","display","aspectRatio","height","maxHeight","minHeight","width","minWidth","maxWidth","flex","flexShrink","flexGrow","flexBasis","tableLayout","captionSide","borderCollapse","borderSpacing","transformOrigin","translate","rotate","skew","scale","transform","animation","cursor","touchAction","userSelect","resize","scrollSnapType","scrollSnapAlign","scrollSnapStop","scrollMargin","scrollPadding","listStylePosition","listStyleType","listStyleImage","appearance","columns","breakBefore","breakInside","breakAfter","gridAutoColumns","gridAutoFlow","gridAutoRows","gridTemplateColumns","gridTemplateRows","flexDirection","flexWrap","placeContent","placeItems","alignContent","alignItems","justifyContent","justifyItems","gap","space","divideWidth","divideStyle","divideColor","divideOpacity","placeSelf","alignSelf","justifySelf","overflow","overscrollBehavior","scrollBehavior","textOverflow","hyphens","whitespace","textWrap","wordBreak","borderRadius","borderWidth","borderStyle","borderColor","borderOpacity","backgroundColor","backgroundOpacity","backgroundImage","gradientColorStops","boxDecorationBreak","backgroundSize","backgroundAttachment","backgroundClip","backgroundPosition","backgroundRepeat","backgroundOrigin","fill","stroke","strokeWidth","objectFit","objectPosition","padding","textAlign","textIndent","verticalAlign","fontFamily","fontSize","fontWeight","textTransform","fontStyle","fontVariantNumeric","lineHeight","letterSpacing","textColor","textOpacity","textDecoration","textDecorationColor","textDecorationStyle","textDecorationThickness","textUnderlineOffset","fontSmoothing","placeholderColor","placeholderOpacity","caretColor","accentColor","opacity","backgroundBlendMode","mixBlendMode","boxShadow","boxShadowColor","outlineStyle","outlineWidth","outlineOffset","outlineColor","ringWidth","ringColor","ringOpacity","ringOffsetWidth","ringOffsetColor","blur","brightness","contrast","dropShadow","grayscale","hueRotate","invert","saturate","sepia","filter","backdropBlur","backdropBrightness","backdropContrast","backdropGrayscale","backdropHueRotate","backdropInvert","backdropOpacity","backdropSaturate","backdropSepia","backdropFilter","transitionProperty","transitionDelay","transitionDuration","transitionTimingFunction","willChange","content"]