tailwindcss 3.4.1 → 4.0.0-alpha.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.
- package/README.md +5 -6
- package/dist/lib.d.mts +324 -0
- package/dist/lib.d.ts +324 -0
- package/dist/lib.js +11 -0
- package/dist/lib.mjs +11 -0
- package/index.css +5 -0
- package/package.json +29 -107
- package/preflight.css +355 -0
- package/theme.css +465 -0
- package/CHANGELOG.md +0 -2571
- package/base.css +0 -1
- package/colors.d.ts +0 -3
- package/colors.js +0 -2
- package/components.css +0 -1
- package/defaultConfig.d.ts +0 -3
- package/defaultConfig.js +0 -2
- package/defaultTheme.d.ts +0 -4
- package/defaultTheme.js +0 -2
- package/lib/cli/build/deps.js +0 -62
- package/lib/cli/build/index.js +0 -54
- package/lib/cli/build/plugin.js +0 -378
- package/lib/cli/build/utils.js +0 -88
- package/lib/cli/build/watching.js +0 -182
- package/lib/cli/help/index.js +0 -73
- package/lib/cli/index.js +0 -230
- package/lib/cli/init/index.js +0 -63
- package/lib/cli-peer-dependencies.js +0 -36
- package/lib/cli.js +0 -7
- package/lib/corePluginList.js +0 -190
- package/lib/corePlugins.js +0 -4282
- package/lib/css/LICENSE +0 -25
- package/lib/css/preflight.css +0 -385
- package/lib/featureFlags.js +0 -83
- package/lib/index.js +0 -2
- package/lib/lib/cacheInvalidation.js +0 -92
- package/lib/lib/collapseAdjacentRules.js +0 -61
- package/lib/lib/collapseDuplicateDeclarations.js +0 -85
- package/lib/lib/content.js +0 -181
- package/lib/lib/defaultExtractor.js +0 -251
- package/lib/lib/detectNesting.js +0 -45
- package/lib/lib/evaluateTailwindFunctions.js +0 -238
- package/lib/lib/expandApplyAtRules.js +0 -540
- package/lib/lib/expandTailwindAtRules.js +0 -291
- package/lib/lib/findAtConfigPath.js +0 -46
- package/lib/lib/generateRules.js +0 -904
- package/lib/lib/getModuleDependencies.js +0 -99
- package/lib/lib/load-config.js +0 -53
- package/lib/lib/normalizeTailwindDirectives.js +0 -89
- package/lib/lib/offsets.js +0 -306
- package/lib/lib/partitionApplyAtRules.js +0 -58
- package/lib/lib/regex.js +0 -74
- package/lib/lib/remap-bitfield.js +0 -89
- package/lib/lib/resolveDefaultsAtRules.js +0 -165
- package/lib/lib/setupContextUtils.js +0 -1294
- package/lib/lib/setupTrackingContext.js +0 -166
- package/lib/lib/sharedState.js +0 -87
- package/lib/lib/substituteScreenAtRules.js +0 -31
- package/lib/oxide/cli/build/deps.js +0 -89
- package/lib/oxide/cli/build/index.js +0 -53
- package/lib/oxide/cli/build/plugin.js +0 -375
- package/lib/oxide/cli/build/utils.js +0 -87
- package/lib/oxide/cli/build/watching.js +0 -179
- package/lib/oxide/cli/help/index.js +0 -72
- package/lib/oxide/cli/index.js +0 -214
- package/lib/oxide/cli/init/index.js +0 -52
- package/lib/oxide/cli.js +0 -5
- package/lib/oxide/postcss-plugin.js +0 -2
- package/lib/plugin.js +0 -98
- package/lib/postcss-plugins/nesting/README.md +0 -42
- package/lib/postcss-plugins/nesting/index.js +0 -21
- package/lib/postcss-plugins/nesting/plugin.js +0 -89
- package/lib/processTailwindFeatures.js +0 -64
- package/lib/public/colors.js +0 -355
- package/lib/public/create-plugin.js +0 -17
- package/lib/public/default-config.js +0 -18
- package/lib/public/default-theme.js +0 -18
- package/lib/public/load-config.js +0 -12
- package/lib/public/resolve-config.js +0 -24
- package/lib/util/applyImportantSelector.js +0 -36
- package/lib/util/bigSign.js +0 -13
- package/lib/util/buildMediaQuery.js +0 -27
- package/lib/util/cloneDeep.js +0 -22
- package/lib/util/cloneNodes.js +0 -54
- package/lib/util/color.js +0 -116
- package/lib/util/colorNames.js +0 -752
- package/lib/util/configurePlugins.js +0 -23
- package/lib/util/createPlugin.js +0 -32
- package/lib/util/createUtilityPlugin.js +0 -53
- package/lib/util/dataTypes.js +0 -415
- package/lib/util/defaults.js +0 -27
- package/lib/util/escapeClassName.js +0 -24
- package/lib/util/escapeCommas.js +0 -13
- package/lib/util/flattenColorPalette.js +0 -18
- package/lib/util/formatVariantSelector.js +0 -270
- package/lib/util/getAllConfigs.js +0 -50
- package/lib/util/hashConfig.js +0 -21
- package/lib/util/isKeyframeRule.js +0 -13
- package/lib/util/isPlainObject.js +0 -17
- package/lib/util/isSyntacticallyValidPropertyValue.js +0 -74
- package/lib/util/log.js +0 -61
- package/lib/util/nameClass.js +0 -49
- package/lib/util/negateValue.js +0 -36
- package/lib/util/normalizeConfig.js +0 -282
- package/lib/util/normalizeScreens.js +0 -178
- package/lib/util/parseAnimationValue.js +0 -93
- package/lib/util/parseBoxShadowValue.js +0 -88
- package/lib/util/parseDependency.js +0 -47
- package/lib/util/parseGlob.js +0 -36
- package/lib/util/parseObjectStyles.js +0 -36
- package/lib/util/pluginUtils.js +0 -289
- package/lib/util/prefixSelector.js +0 -39
- package/lib/util/pseudoElements.js +0 -212
- package/lib/util/removeAlphaVariables.js +0 -31
- package/lib/util/resolveConfig.js +0 -256
- package/lib/util/resolveConfigPath.js +0 -70
- package/lib/util/responsive.js +0 -24
- package/lib/util/splitAtTopLevelOnly.js +0 -51
- package/lib/util/tap.js +0 -14
- package/lib/util/toColorValue.js +0 -13
- package/lib/util/toPath.js +0 -32
- package/lib/util/transformThemeValue.js +0 -73
- package/lib/util/validateConfig.js +0 -37
- package/lib/util/validateFormalSyntax.js +0 -26
- package/lib/util/withAlphaVariable.js +0 -79
- package/lib/value-parser/LICENSE +0 -22
- package/lib/value-parser/README.md +0 -3
- package/lib/value-parser/index.d.js +0 -2
- package/lib/value-parser/index.js +0 -22
- package/lib/value-parser/parse.js +0 -259
- package/lib/value-parser/stringify.js +0 -38
- package/lib/value-parser/unit.js +0 -86
- package/lib/value-parser/walk.js +0 -16
- package/loadConfig.d.ts +0 -4
- package/loadConfig.js +0 -2
- package/nesting/index.d.ts +0 -4
- package/nesting/index.js +0 -2
- package/peers/index.js +0 -96624
- package/plugin.d.ts +0 -11
- package/plugin.js +0 -2
- package/prettier.config.js +0 -19
- package/resolveConfig.d.ts +0 -31
- package/resolveConfig.js +0 -2
- package/screens.css +0 -1
- package/scripts/create-plugin-list.js +0 -10
- package/scripts/generate-types.js +0 -104
- package/scripts/release-channel.js +0 -18
- package/scripts/release-notes.js +0 -21
- package/scripts/swap-engines.js +0 -40
- package/scripts/type-utils.js +0 -27
- package/src/cli/build/deps.js +0 -56
- package/src/cli/build/index.js +0 -49
- package/src/cli/build/plugin.js +0 -444
- package/src/cli/build/utils.js +0 -76
- package/src/cli/build/watching.js +0 -229
- package/src/cli/help/index.js +0 -70
- package/src/cli/index.js +0 -216
- package/src/cli/init/index.js +0 -79
- package/src/cli-peer-dependencies.js +0 -15
- package/src/cli.js +0 -7
- package/src/corePluginList.js +0 -1
- package/src/corePlugins.js +0 -2943
- package/src/css/LICENSE +0 -25
- package/src/css/preflight.css +0 -385
- package/src/featureFlags.js +0 -66
- package/src/index.js +0 -1
- package/src/lib/cacheInvalidation.js +0 -52
- package/src/lib/collapseAdjacentRules.js +0 -58
- package/src/lib/collapseDuplicateDeclarations.js +0 -93
- package/src/lib/content.js +0 -208
- package/src/lib/defaultExtractor.js +0 -230
- package/src/lib/detectNesting.js +0 -47
- package/src/lib/evaluateTailwindFunctions.js +0 -272
- package/src/lib/expandApplyAtRules.js +0 -620
- package/src/lib/expandTailwindAtRules.js +0 -300
- package/src/lib/findAtConfigPath.js +0 -48
- package/src/lib/generateRules.js +0 -951
- package/src/lib/getModuleDependencies.js +0 -79
- package/src/lib/load-config.ts +0 -39
- package/src/lib/normalizeTailwindDirectives.js +0 -84
- package/src/lib/offsets.js +0 -373
- package/src/lib/partitionApplyAtRules.js +0 -52
- package/src/lib/regex.js +0 -74
- package/src/lib/remap-bitfield.js +0 -82
- package/src/lib/resolveDefaultsAtRules.js +0 -163
- package/src/lib/setupContextUtils.js +0 -1366
- package/src/lib/setupTrackingContext.js +0 -169
- package/src/lib/sharedState.js +0 -61
- package/src/lib/substituteScreenAtRules.js +0 -19
- package/src/oxide/cli/build/deps.ts +0 -91
- package/src/oxide/cli/build/index.ts +0 -47
- package/src/oxide/cli/build/plugin.ts +0 -442
- package/src/oxide/cli/build/utils.ts +0 -74
- package/src/oxide/cli/build/watching.ts +0 -225
- package/src/oxide/cli/help/index.ts +0 -69
- package/src/oxide/cli/index.ts +0 -204
- package/src/oxide/cli/init/index.ts +0 -59
- package/src/oxide/cli.ts +0 -1
- package/src/oxide/postcss-plugin.ts +0 -1
- package/src/plugin.js +0 -107
- package/src/postcss-plugins/nesting/README.md +0 -42
- package/src/postcss-plugins/nesting/index.js +0 -13
- package/src/postcss-plugins/nesting/plugin.js +0 -80
- package/src/processTailwindFeatures.js +0 -59
- package/src/public/colors.js +0 -322
- package/src/public/create-plugin.js +0 -2
- package/src/public/default-config.js +0 -4
- package/src/public/default-theme.js +0 -4
- package/src/public/load-config.js +0 -2
- package/src/public/resolve-config.js +0 -7
- package/src/util/applyImportantSelector.js +0 -27
- package/src/util/bigSign.js +0 -3
- package/src/util/buildMediaQuery.js +0 -22
- package/src/util/cloneDeep.js +0 -11
- package/src/util/cloneNodes.js +0 -49
- package/src/util/color.js +0 -88
- package/src/util/colorNames.js +0 -150
- package/src/util/configurePlugins.js +0 -23
- package/src/util/createPlugin.js +0 -27
- package/src/util/createUtilityPlugin.js +0 -37
- package/src/util/dataTypes.js +0 -406
- package/src/util/defaults.js +0 -17
- package/src/util/escapeClassName.js +0 -8
- package/src/util/escapeCommas.js +0 -3
- package/src/util/flattenColorPalette.js +0 -13
- package/src/util/formatVariantSelector.js +0 -324
- package/src/util/getAllConfigs.js +0 -38
- package/src/util/hashConfig.js +0 -5
- package/src/util/isKeyframeRule.js +0 -3
- package/src/util/isPlainObject.js +0 -8
- package/src/util/isSyntacticallyValidPropertyValue.js +0 -61
- package/src/util/log.js +0 -29
- package/src/util/nameClass.js +0 -30
- package/src/util/negateValue.js +0 -24
- package/src/util/normalizeConfig.js +0 -301
- package/src/util/normalizeScreens.js +0 -140
- package/src/util/parseAnimationValue.js +0 -68
- package/src/util/parseBoxShadowValue.js +0 -72
- package/src/util/parseDependency.js +0 -44
- package/src/util/parseGlob.js +0 -24
- package/src/util/parseObjectStyles.js +0 -19
- package/src/util/pluginUtils.js +0 -307
- package/src/util/prefixSelector.js +0 -33
- package/src/util/pseudoElements.js +0 -171
- package/src/util/removeAlphaVariables.js +0 -24
- package/src/util/resolveConfig.js +0 -277
- package/src/util/resolveConfigPath.js +0 -66
- package/src/util/responsive.js +0 -10
- package/src/util/splitAtTopLevelOnly.js +0 -52
- package/src/util/tap.js +0 -4
- package/src/util/toColorValue.js +0 -3
- package/src/util/toPath.js +0 -26
- package/src/util/transformThemeValue.js +0 -62
- package/src/util/validateConfig.js +0 -26
- package/src/util/validateFormalSyntax.js +0 -34
- package/src/util/withAlphaVariable.js +0 -49
- package/src/value-parser/LICENSE +0 -22
- package/src/value-parser/README.md +0 -3
- package/src/value-parser/index.d.ts +0 -177
- package/src/value-parser/index.js +0 -28
- package/src/value-parser/parse.js +0 -303
- package/src/value-parser/stringify.js +0 -41
- package/src/value-parser/unit.js +0 -118
- package/src/value-parser/walk.js +0 -18
- package/stubs/.gitignore +0 -1
- package/stubs/.prettierrc.json +0 -6
- package/stubs/config.full.js +0 -1062
- package/stubs/config.simple.js +0 -7
- package/stubs/postcss.config.cjs +0 -6
- package/stubs/postcss.config.js +0 -6
- package/stubs/tailwind.config.cjs +0 -2
- package/stubs/tailwind.config.js +0 -2
- package/stubs/tailwind.config.ts +0 -3
- package/tailwind.css +0 -5
- package/types/config.d.ts +0 -376
- package/types/generated/.gitkeep +0 -0
- package/types/generated/colors.d.ts +0 -298
- package/types/generated/corePluginList.d.ts +0 -1
- package/types/generated/default-theme.d.ts +0 -397
- package/types/index.d.ts +0 -11
- 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
|
-
}
|
package/src/oxide/cli/index.ts
DELETED
@@ -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,59 +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
|
-
// Change colors import
|
40
|
-
stubContentsFile = stubContentsFile.replace('../colors', 'tailwindcss/colors')
|
41
|
-
|
42
|
-
// Replace contents of {ts,js,cjs} file with the stub {simple,full}.
|
43
|
-
stubFile =
|
44
|
-
stubFile
|
45
|
-
.replace('__CONFIG__', stubContentsFile.replace('module.exports =', '').trim())
|
46
|
-
.trim() + '\n\n'
|
47
|
-
|
48
|
-
fs.writeFileSync(tailwindConfigLocation, stubFile, 'utf8')
|
49
|
-
|
50
|
-
messages.push(`Created Tailwind CSS config file: ${path.basename(tailwindConfigLocation)}`)
|
51
|
-
}
|
52
|
-
|
53
|
-
if (messages.length > 0) {
|
54
|
-
console.log()
|
55
|
-
for (let message of messages) {
|
56
|
-
console.log(message)
|
57
|
-
}
|
58
|
-
}
|
59
|
-
}
|
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,107 +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
|
-
|
6
|
-
module.exports = function tailwindcss(configOrPath) {
|
7
|
-
return {
|
8
|
-
postcssPlugin: 'tailwindcss',
|
9
|
-
plugins: [
|
10
|
-
env.DEBUG &&
|
11
|
-
function (root) {
|
12
|
-
console.log('\n')
|
13
|
-
console.time('JIT TOTAL')
|
14
|
-
return root
|
15
|
-
},
|
16
|
-
async function (root, result) {
|
17
|
-
// Use the path for the `@config` directive if it exists, otherwise use the
|
18
|
-
// path for the file being processed
|
19
|
-
configOrPath = findAtConfigPath(root, result) ?? configOrPath
|
20
|
-
|
21
|
-
let context = setupTrackingContext(configOrPath)
|
22
|
-
|
23
|
-
if (root.type === 'document') {
|
24
|
-
let roots = root.nodes.filter((node) => node.type === 'root')
|
25
|
-
|
26
|
-
for (const root of roots) {
|
27
|
-
if (root.type === 'root') {
|
28
|
-
await processTailwindFeatures(context)(root, result)
|
29
|
-
}
|
30
|
-
}
|
31
|
-
|
32
|
-
return
|
33
|
-
}
|
34
|
-
|
35
|
-
await processTailwindFeatures(context)(root, result)
|
36
|
-
},
|
37
|
-
__OXIDE__ &&
|
38
|
-
function lightningCssPlugin(_root, result) {
|
39
|
-
let postcss = require('postcss')
|
40
|
-
let lightningcss = require('lightningcss')
|
41
|
-
let browserslist = require('browserslist')
|
42
|
-
|
43
|
-
try {
|
44
|
-
let transformed = lightningcss.transform({
|
45
|
-
filename: result.opts.from,
|
46
|
-
code: Buffer.from(result.root.toString()),
|
47
|
-
minify: false,
|
48
|
-
sourceMap: !!result.map,
|
49
|
-
inputSourceMap: result.map ? result.map.toString() : undefined,
|
50
|
-
targets:
|
51
|
-
typeof process !== 'undefined' && process.env.JEST_WORKER_ID
|
52
|
-
? { chrome: 106 << 16 }
|
53
|
-
: lightningcss.browserslistToTargets(
|
54
|
-
browserslist(require('../package.json').browserslist)
|
55
|
-
),
|
56
|
-
|
57
|
-
drafts: {
|
58
|
-
nesting: true,
|
59
|
-
customMedia: true,
|
60
|
-
},
|
61
|
-
})
|
62
|
-
|
63
|
-
result.map = Object.assign(result.map ?? {}, {
|
64
|
-
toJSON() {
|
65
|
-
return transformed.map.toJSON()
|
66
|
-
},
|
67
|
-
toString() {
|
68
|
-
return transformed.map.toString()
|
69
|
-
},
|
70
|
-
})
|
71
|
-
|
72
|
-
result.root = postcss.parse(transformed.code.toString('utf8'))
|
73
|
-
} catch (err) {
|
74
|
-
if (typeof process !== 'undefined' && process.env.JEST_WORKER_ID) {
|
75
|
-
let lines = err.source.split('\n')
|
76
|
-
err = new Error(
|
77
|
-
[
|
78
|
-
'Error formatting using Lightning CSS:',
|
79
|
-
'',
|
80
|
-
...[
|
81
|
-
'```css',
|
82
|
-
...lines.slice(Math.max(err.loc.line - 3, 0), err.loc.line),
|
83
|
-
' '.repeat(err.loc.column - 1) + '^-- ' + err.toString(),
|
84
|
-
...lines.slice(err.loc.line, err.loc.line + 2),
|
85
|
-
'```',
|
86
|
-
],
|
87
|
-
].join('\n')
|
88
|
-
)
|
89
|
-
}
|
90
|
-
|
91
|
-
if (Error.captureStackTrace) {
|
92
|
-
Error.captureStackTrace(err, lightningCssPlugin)
|
93
|
-
}
|
94
|
-
throw err
|
95
|
-
}
|
96
|
-
},
|
97
|
-
env.DEBUG &&
|
98
|
-
function (root) {
|
99
|
-
console.timeEnd('JIT TOTAL')
|
100
|
-
console.log('\n')
|
101
|
-
return root
|
102
|
-
},
|
103
|
-
].filter(Boolean),
|
104
|
-
}
|
105
|
-
}
|
106
|
-
|
107
|
-
module.exports.postcss = true
|