mirror of
https://github.com/tailwindlabs/tailwindcss.git
synced 2025-12-08 21:36:08 +00:00
2268 lines
68 KiB
JavaScript
2268 lines
68 KiB
JavaScript
import fs from 'fs'
|
|
import postcss from 'postcss'
|
|
import createUtilityPlugin from './util/createUtilityPlugin'
|
|
import buildMediaQuery from './util/buildMediaQuery'
|
|
import prefixSelector from './util/prefixSelector'
|
|
import parseAnimationValue from './util/parseAnimationValue'
|
|
import flattenColorPalette from './util/flattenColorPalette'
|
|
import withAlphaVariable, { withAlphaValue } from './util/withAlphaVariable'
|
|
import toColorValue from './util/toColorValue'
|
|
import isPlainObject from './util/isPlainObject'
|
|
import transformThemeValue from './util/transformThemeValue'
|
|
import {
|
|
applyStateToMarker,
|
|
updateLastClasses,
|
|
updateAllClasses,
|
|
transformAllSelectors,
|
|
transformAllClasses,
|
|
transformLastClasses,
|
|
} from './util/pluginUtils'
|
|
import { version as tailwindVersion } from '../package.json'
|
|
import log from './util/log'
|
|
|
|
export default {
|
|
// Variant plugins
|
|
pseudoElementVariants: ({ config, addVariant }) => {
|
|
addVariant(
|
|
'first-letter',
|
|
transformAllSelectors((selector) => {
|
|
return updateAllClasses(selector, (className, { withPseudo }) => {
|
|
return withPseudo(`first-letter${config('separator')}${className}`, '::first-letter')
|
|
})
|
|
})
|
|
)
|
|
|
|
addVariant(
|
|
'first-line',
|
|
transformAllSelectors((selector) => {
|
|
return updateAllClasses(selector, (className, { withPseudo }) => {
|
|
return withPseudo(`first-line${config('separator')}${className}`, '::first-line')
|
|
})
|
|
})
|
|
)
|
|
|
|
addVariant('marker', [
|
|
transformAllSelectors((selector) => {
|
|
let variantSelector = updateAllClasses(selector, (className) => {
|
|
return `marker${config('separator')}${className}`
|
|
})
|
|
|
|
return `${variantSelector} *::marker`
|
|
}),
|
|
transformAllSelectors((selector) => {
|
|
return updateAllClasses(selector, (className, { withPseudo }) => {
|
|
return withPseudo(`marker${config('separator')}${className}`, '::marker')
|
|
})
|
|
}),
|
|
])
|
|
|
|
addVariant('selection', [
|
|
transformAllSelectors((selector) => {
|
|
let variantSelector = updateAllClasses(selector, (className) => {
|
|
return `selection${config('separator')}${className}`
|
|
})
|
|
|
|
return `${variantSelector} *::selection`
|
|
}),
|
|
transformAllSelectors((selector) => {
|
|
return updateAllClasses(selector, (className, { withPseudo }) => {
|
|
return withPseudo(`selection${config('separator')}${className}`, '::selection')
|
|
})
|
|
}),
|
|
])
|
|
|
|
addVariant(
|
|
'file',
|
|
transformAllSelectors((selector) => {
|
|
return updateAllClasses(selector, (className, { withPseudo }) => {
|
|
return withPseudo(`file${config('separator')}${className}`, '::file-selector-button')
|
|
})
|
|
})
|
|
)
|
|
|
|
addVariant(
|
|
'before',
|
|
transformAllSelectors(
|
|
(selector) => {
|
|
return updateAllClasses(selector, (className, { withPseudo }) => {
|
|
return withPseudo(`before${config('separator')}${className}`, '::before')
|
|
})
|
|
},
|
|
{
|
|
withRule: (rule) => {
|
|
let foundContent = false
|
|
rule.walkDecls('content', () => {
|
|
foundContent = true
|
|
})
|
|
if (!foundContent) {
|
|
rule.prepend(postcss.decl({ prop: 'content', value: '""' }))
|
|
}
|
|
},
|
|
}
|
|
)
|
|
)
|
|
|
|
addVariant(
|
|
'after',
|
|
transformAllSelectors(
|
|
(selector) => {
|
|
return updateAllClasses(selector, (className, { withPseudo }) => {
|
|
return withPseudo(`after${config('separator')}${className}`, '::after')
|
|
})
|
|
},
|
|
{
|
|
withRule: (rule) => {
|
|
let foundContent = false
|
|
rule.walkDecls('content', () => {
|
|
foundContent = true
|
|
})
|
|
if (!foundContent) {
|
|
rule.prepend(postcss.decl({ prop: 'content', value: '""' }))
|
|
}
|
|
},
|
|
}
|
|
)
|
|
)
|
|
},
|
|
|
|
pseudoClassVariants: ({ config, addVariant }) => {
|
|
let pseudoVariants = [
|
|
// Positional
|
|
['first', ':first-child'],
|
|
['last', ':last-child'],
|
|
['only', ':only-child'],
|
|
['odd', ':nth-child(odd)'],
|
|
['even', ':nth-child(even)'],
|
|
'first-of-type',
|
|
'last-of-type',
|
|
'only-of-type',
|
|
|
|
// State
|
|
'visited',
|
|
'target',
|
|
['open', '[open]'],
|
|
|
|
// Forms
|
|
'default',
|
|
'checked',
|
|
'indeterminate',
|
|
'placeholder-shown',
|
|
'autofill',
|
|
'required',
|
|
'valid',
|
|
'invalid',
|
|
'in-range',
|
|
'out-of-range',
|
|
'read-only',
|
|
|
|
// Content
|
|
'empty',
|
|
|
|
// Interactive
|
|
'focus-within',
|
|
'hover',
|
|
'focus',
|
|
'focus-visible',
|
|
'active',
|
|
'disabled',
|
|
]
|
|
|
|
for (let variant of pseudoVariants) {
|
|
let [variantName, state] = Array.isArray(variant) ? variant : [variant, `:${variant}`]
|
|
|
|
addVariant(
|
|
variantName,
|
|
transformAllClasses((className, { withAttr, withPseudo }) => {
|
|
if (state.startsWith(':')) {
|
|
return withPseudo(`${variantName}${config('separator')}${className}`, state)
|
|
} else if (state.startsWith('[')) {
|
|
return withAttr(`${variantName}${config('separator')}${className}`, state)
|
|
}
|
|
})
|
|
)
|
|
}
|
|
|
|
let groupMarker = prefixSelector(config('prefix'), '.group')
|
|
for (let variant of pseudoVariants) {
|
|
let [variantName, state] = Array.isArray(variant) ? variant : [variant, `:${variant}`]
|
|
let groupVariantName = `group-${variantName}`
|
|
|
|
addVariant(
|
|
groupVariantName,
|
|
transformAllSelectors((selector) => {
|
|
let variantSelector = updateAllClasses(selector, (className) => {
|
|
if (`.${className}` === groupMarker) return className
|
|
return `${groupVariantName}${config('separator')}${className}`
|
|
})
|
|
|
|
if (variantSelector === selector) {
|
|
return null
|
|
}
|
|
|
|
return applyStateToMarker(
|
|
variantSelector,
|
|
groupMarker,
|
|
state,
|
|
(marker, selector) => `${marker} ${selector}`
|
|
)
|
|
})
|
|
)
|
|
}
|
|
|
|
let peerMarker = prefixSelector(config('prefix'), '.peer')
|
|
for (let variant of pseudoVariants) {
|
|
let [variantName, state] = Array.isArray(variant) ? variant : [variant, `:${variant}`]
|
|
let peerVariantName = `peer-${variantName}`
|
|
|
|
addVariant(
|
|
peerVariantName,
|
|
transformAllSelectors((selector) => {
|
|
let variantSelector = updateAllClasses(selector, (className) => {
|
|
if (`.${className}` === peerMarker) return className
|
|
return `${peerVariantName}${config('separator')}${className}`
|
|
})
|
|
|
|
if (variantSelector === selector) {
|
|
return null
|
|
}
|
|
|
|
return applyStateToMarker(variantSelector, peerMarker, state, (marker, selector) =>
|
|
selector.trim().startsWith('~') ? `${marker}${selector}` : `${marker} ~ ${selector}`
|
|
)
|
|
})
|
|
)
|
|
}
|
|
},
|
|
|
|
directionVariants: ({ config, addVariant }) => {
|
|
addVariant(
|
|
'ltr',
|
|
transformAllSelectors(
|
|
(selector) =>
|
|
`[dir="ltr"] ${updateAllClasses(
|
|
selector,
|
|
(className) => `ltr${config('separator')}${className}`
|
|
)}`
|
|
)
|
|
)
|
|
|
|
addVariant(
|
|
'rtl',
|
|
transformAllSelectors(
|
|
(selector) =>
|
|
`[dir="rtl"] ${updateAllClasses(
|
|
selector,
|
|
(className) => `rtl${config('separator')}${className}`
|
|
)}`
|
|
)
|
|
)
|
|
},
|
|
|
|
reducedMotionVariants: ({ config, addVariant }) => {
|
|
addVariant(
|
|
'motion-safe',
|
|
transformLastClasses(
|
|
(className) => {
|
|
return `motion-safe${config('separator')}${className}`
|
|
},
|
|
{
|
|
wrap: () =>
|
|
postcss.atRule({
|
|
name: 'media',
|
|
params: '(prefers-reduced-motion: no-preference)',
|
|
}),
|
|
}
|
|
)
|
|
)
|
|
|
|
addVariant(
|
|
'motion-reduce',
|
|
transformLastClasses(
|
|
(className) => {
|
|
return `motion-reduce${config('separator')}${className}`
|
|
},
|
|
{
|
|
wrap: () =>
|
|
postcss.atRule({
|
|
name: 'media',
|
|
params: '(prefers-reduced-motion: reduce)',
|
|
}),
|
|
}
|
|
)
|
|
)
|
|
},
|
|
|
|
darkVariants: ({ config, addVariant }) => {
|
|
let mode = config('darkMode', 'media')
|
|
if (mode === false) {
|
|
mode = 'media'
|
|
log.warn([
|
|
'`darkMode` is set to `false` in your config.',
|
|
'This will behave just like the `media` value.',
|
|
])
|
|
}
|
|
|
|
if (mode === 'class') {
|
|
addVariant(
|
|
'dark',
|
|
transformAllSelectors((selector) => {
|
|
let variantSelector = updateLastClasses(selector, (className) => {
|
|
return `dark${config('separator')}${className}`
|
|
})
|
|
|
|
if (variantSelector === selector) {
|
|
return null
|
|
}
|
|
|
|
let darkSelector = prefixSelector(config('prefix'), `.dark`)
|
|
|
|
return `${darkSelector} ${variantSelector}`
|
|
})
|
|
)
|
|
} else if (mode === 'media') {
|
|
addVariant(
|
|
'dark',
|
|
transformLastClasses(
|
|
(className) => {
|
|
return `dark${config('separator')}${className}`
|
|
},
|
|
{
|
|
wrap: () =>
|
|
postcss.atRule({
|
|
name: 'media',
|
|
params: '(prefers-color-scheme: dark)',
|
|
}),
|
|
}
|
|
)
|
|
)
|
|
}
|
|
},
|
|
|
|
screenVariants: ({ config, theme, addVariant }) => {
|
|
for (let screen in theme('screens')) {
|
|
let size = theme('screens')[screen]
|
|
let query = buildMediaQuery(size)
|
|
|
|
addVariant(
|
|
screen,
|
|
transformLastClasses(
|
|
(className) => {
|
|
return `${screen}${config('separator')}${className}`
|
|
},
|
|
{ wrap: () => postcss.atRule({ name: 'media', params: query }) }
|
|
)
|
|
)
|
|
}
|
|
},
|
|
|
|
// Actual plugins
|
|
preflight: ({ addBase }) => {
|
|
let preflightStyles = postcss.parse(fs.readFileSync(`${__dirname}/css/preflight.css`, 'utf8'))
|
|
|
|
addBase([
|
|
postcss.comment({
|
|
text: `! tailwindcss v${tailwindVersion} | MIT License | https://tailwindcss.com`,
|
|
}),
|
|
...preflightStyles.nodes,
|
|
])
|
|
},
|
|
|
|
container: (() => {
|
|
function extractMinWidths(breakpoints) {
|
|
return Object.values(breakpoints ?? {}).flatMap((breakpoints) => {
|
|
if (typeof breakpoints === 'string') {
|
|
breakpoints = { min: breakpoints }
|
|
}
|
|
|
|
if (!Array.isArray(breakpoints)) {
|
|
breakpoints = [breakpoints]
|
|
}
|
|
|
|
return breakpoints
|
|
.filter((breakpoint) => {
|
|
return breakpoint?.hasOwnProperty?.('min') || breakpoint?.hasOwnProperty('min-width')
|
|
})
|
|
.map((breakpoint) => {
|
|
return breakpoint['min-width'] ?? breakpoint.min
|
|
})
|
|
})
|
|
}
|
|
|
|
function mapMinWidthsToPadding(minWidths, screens, paddings) {
|
|
if (typeof paddings === 'undefined') {
|
|
return []
|
|
}
|
|
|
|
if (!(typeof paddings === 'object' && paddings !== null)) {
|
|
return [
|
|
{
|
|
screen: 'DEFAULT',
|
|
minWidth: 0,
|
|
padding: paddings,
|
|
},
|
|
]
|
|
}
|
|
|
|
let mapping = []
|
|
|
|
if (paddings.DEFAULT) {
|
|
mapping.push({
|
|
screen: 'DEFAULT',
|
|
minWidth: 0,
|
|
padding: paddings.DEFAULT,
|
|
})
|
|
}
|
|
|
|
for (let minWidth of minWidths) {
|
|
for (let [screen, value] of Object.entries(screens)) {
|
|
let screenMinWidth =
|
|
typeof value === 'object' && value !== null ? value.min || value['min-width'] : value
|
|
|
|
if (`${screenMinWidth}` === `${minWidth}`) {
|
|
mapping.push({
|
|
screen,
|
|
minWidth,
|
|
padding: paddings[screen],
|
|
})
|
|
}
|
|
}
|
|
}
|
|
|
|
return mapping
|
|
}
|
|
|
|
return function ({ addComponents, theme }) {
|
|
let screens = theme('container.screens', theme('screens'))
|
|
let minWidths = extractMinWidths(screens)
|
|
let paddings = mapMinWidthsToPadding(minWidths, screens, theme('container.padding'))
|
|
|
|
let generatePaddingFor = (minWidth) => {
|
|
let paddingConfig = paddings.find((padding) => `${padding.minWidth}` === `${minWidth}`)
|
|
|
|
if (!paddingConfig) {
|
|
return {}
|
|
}
|
|
|
|
return {
|
|
paddingRight: paddingConfig.padding,
|
|
paddingLeft: paddingConfig.padding,
|
|
}
|
|
}
|
|
|
|
let atRules = Array.from(
|
|
new Set(minWidths.slice().sort((a, z) => parseInt(a) - parseInt(z)))
|
|
).map((minWidth) => ({
|
|
[`@media (min-width: ${minWidth})`]: {
|
|
'.container': {
|
|
'max-width': minWidth,
|
|
...generatePaddingFor(minWidth),
|
|
},
|
|
},
|
|
}))
|
|
|
|
addComponents([
|
|
{
|
|
'.container': Object.assign(
|
|
{ width: '100%' },
|
|
theme('container.center', false) ? { marginRight: 'auto', marginLeft: 'auto' } : {},
|
|
generatePaddingFor(0)
|
|
),
|
|
},
|
|
...atRules,
|
|
])
|
|
}
|
|
})(),
|
|
|
|
accessibility: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.sr-only': {
|
|
position: 'absolute',
|
|
width: '1px',
|
|
height: '1px',
|
|
padding: '0',
|
|
margin: '-1px',
|
|
overflow: 'hidden',
|
|
clip: 'rect(0, 0, 0, 0)',
|
|
whiteSpace: 'nowrap',
|
|
borderWidth: '0',
|
|
},
|
|
'.not-sr-only': {
|
|
position: 'static',
|
|
width: 'auto',
|
|
height: 'auto',
|
|
padding: '0',
|
|
margin: '0',
|
|
overflow: 'visible',
|
|
clip: 'auto',
|
|
whiteSpace: 'normal',
|
|
},
|
|
})
|
|
},
|
|
|
|
pointerEvents: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.pointer-events-none': { 'pointer-events': 'none' },
|
|
'.pointer-events-auto': { 'pointer-events': 'auto' },
|
|
})
|
|
},
|
|
|
|
visibility: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.visible': { visibility: 'visible' },
|
|
'.invisible': { visibility: 'hidden' },
|
|
})
|
|
},
|
|
|
|
position: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.static': { position: 'static' },
|
|
'.fixed': { position: 'fixed' },
|
|
'.absolute': { position: 'absolute' },
|
|
'.relative': { position: 'relative' },
|
|
'.sticky': { position: 'sticky' },
|
|
})
|
|
},
|
|
|
|
inset: createUtilityPlugin('inset', [
|
|
['inset', ['top', 'right', 'bottom', 'left']],
|
|
[
|
|
['inset-x', ['left', 'right']],
|
|
['inset-y', ['top', 'bottom']],
|
|
],
|
|
[
|
|
['top', ['top']],
|
|
['right', ['right']],
|
|
['bottom', ['bottom']],
|
|
['left', ['left']],
|
|
],
|
|
]),
|
|
|
|
isolation: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.isolate': { isolation: 'isolate' },
|
|
'.isolation-auto': { isolation: 'auto' },
|
|
})
|
|
},
|
|
|
|
zIndex: createUtilityPlugin('zIndex', [['z', ['zIndex']]]),
|
|
order: createUtilityPlugin('order'),
|
|
gridColumn: createUtilityPlugin('gridColumn', [['col', ['gridColumn']]]),
|
|
gridColumnStart: createUtilityPlugin('gridColumnStart', [['col-start', ['gridColumnStart']]]),
|
|
gridColumnEnd: createUtilityPlugin('gridColumnEnd', [['col-end', ['gridColumnEnd']]]),
|
|
gridRow: createUtilityPlugin('gridRow', [['row', ['gridRow']]]),
|
|
gridRowStart: createUtilityPlugin('gridRowStart', [['row-start', ['gridRowStart']]]),
|
|
gridRowEnd: createUtilityPlugin('gridRowEnd', [['row-end', ['gridRowEnd']]]),
|
|
|
|
float: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.float-right': { float: 'right' },
|
|
'.float-left': { float: 'left' },
|
|
'.float-none': { float: 'none' },
|
|
})
|
|
},
|
|
|
|
clear: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.clear-left': { clear: 'left' },
|
|
'.clear-right': { clear: 'right' },
|
|
'.clear-both': { clear: 'both' },
|
|
'.clear-none': { clear: 'none' },
|
|
})
|
|
},
|
|
|
|
margin: createUtilityPlugin('margin', [
|
|
['m', ['margin']],
|
|
[
|
|
['mx', ['margin-left', 'margin-right']],
|
|
['my', ['margin-top', 'margin-bottom']],
|
|
],
|
|
[
|
|
['mt', ['margin-top']],
|
|
['mr', ['margin-right']],
|
|
['mb', ['margin-bottom']],
|
|
['ml', ['margin-left']],
|
|
],
|
|
]),
|
|
|
|
boxSizing: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.box-border': { 'box-sizing': 'border-box' },
|
|
'.box-content': { 'box-sizing': 'content-box' },
|
|
})
|
|
},
|
|
|
|
display: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.block': { display: 'block' },
|
|
'.inline-block': { display: 'inline-block' },
|
|
'.inline': { display: 'inline' },
|
|
'.flex': { display: 'flex' },
|
|
'.inline-flex': { display: 'inline-flex' },
|
|
'.table': { display: 'table' },
|
|
'.inline-table': { display: 'inline-table' },
|
|
'.table-caption': { display: 'table-caption' },
|
|
'.table-cell': { display: 'table-cell' },
|
|
'.table-column': { display: 'table-column' },
|
|
'.table-column-group': { display: 'table-column-group' },
|
|
'.table-footer-group': { display: 'table-footer-group' },
|
|
'.table-header-group': { display: 'table-header-group' },
|
|
'.table-row-group': { display: 'table-row-group' },
|
|
'.table-row': { display: 'table-row' },
|
|
'.flow-root': { display: 'flow-root' },
|
|
'.grid': { display: 'grid' },
|
|
'.inline-grid': { display: 'inline-grid' },
|
|
'.contents': { display: 'contents' },
|
|
'.list-item': { display: 'list-item' },
|
|
'.hidden': { display: 'none' },
|
|
})
|
|
},
|
|
|
|
aspectRatio: createUtilityPlugin('aspectRatio', [['aspect', ['aspect-ratio']]]),
|
|
|
|
height: createUtilityPlugin('height', [['h', ['height']]]),
|
|
maxHeight: createUtilityPlugin('maxHeight', [['max-h', ['maxHeight']]]),
|
|
minHeight: createUtilityPlugin('minHeight', [['min-h', ['minHeight']]]),
|
|
|
|
width: createUtilityPlugin('width', [['w', ['width']]]),
|
|
minWidth: createUtilityPlugin('minWidth', [['min-w', ['minWidth']]]),
|
|
maxWidth: createUtilityPlugin('maxWidth', [['max-w', ['maxWidth']]]),
|
|
|
|
flex: createUtilityPlugin('flex'),
|
|
flexShrink: createUtilityPlugin('flexShrink', [['flex-shrink', ['flex-shrink']]]),
|
|
flexGrow: createUtilityPlugin('flexGrow', [['flex-grow', ['flex-grow']]]),
|
|
|
|
tableLayout: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.table-auto': { 'table-layout': 'auto' },
|
|
'.table-fixed': { 'table-layout': 'fixed' },
|
|
})
|
|
},
|
|
|
|
borderCollapse: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.border-collapse': { 'border-collapse': 'collapse' },
|
|
'.border-separate': { 'border-collapse': 'separate' },
|
|
})
|
|
},
|
|
|
|
transformOrigin: createUtilityPlugin('transformOrigin', [['origin', ['transformOrigin']]]),
|
|
translate: createUtilityPlugin('translate', [
|
|
[
|
|
[
|
|
'translate-x',
|
|
[['@defaults transform', {}], '--tw-translate-x', ['transform', 'var(--tw-transform)']],
|
|
],
|
|
[
|
|
'translate-y',
|
|
[['@defaults transform', {}], '--tw-translate-y', ['transform', 'var(--tw-transform)']],
|
|
],
|
|
],
|
|
]),
|
|
rotate: createUtilityPlugin('rotate', [
|
|
['rotate', [['@defaults transform', {}], '--tw-rotate', ['transform', 'var(--tw-transform)']]],
|
|
]),
|
|
skew: createUtilityPlugin('skew', [
|
|
[
|
|
[
|
|
'skew-x',
|
|
[['@defaults transform', {}], '--tw-skew-x', ['transform', 'var(--tw-transform)']],
|
|
],
|
|
[
|
|
'skew-y',
|
|
[['@defaults transform', {}], '--tw-skew-y', ['transform', 'var(--tw-transform)']],
|
|
],
|
|
],
|
|
]),
|
|
scale: createUtilityPlugin('scale', [
|
|
[
|
|
'scale',
|
|
[
|
|
['@defaults transform', {}],
|
|
'--tw-scale-x',
|
|
'--tw-scale-y',
|
|
['transform', 'var(--tw-transform)'],
|
|
],
|
|
],
|
|
[
|
|
[
|
|
'scale-x',
|
|
[['@defaults transform', {}], '--tw-scale-x', ['transform', 'var(--tw-transform)']],
|
|
],
|
|
[
|
|
'scale-y',
|
|
[['@defaults transform', {}], '--tw-scale-y', ['transform', 'var(--tw-transform)']],
|
|
],
|
|
],
|
|
]),
|
|
|
|
transform: ({ addBase, addUtilities }) => {
|
|
addBase({
|
|
'@defaults transform': {
|
|
'--tw-translate-x': '0',
|
|
'--tw-translate-y': '0',
|
|
'--tw-rotate': '0',
|
|
'--tw-skew-x': '0',
|
|
'--tw-skew-y': '0',
|
|
'--tw-scale-x': '1',
|
|
'--tw-scale-y': '1',
|
|
'--tw-transform': [
|
|
'translateX(var(--tw-translate-x))',
|
|
'translateY(var(--tw-translate-y))',
|
|
'rotate(var(--tw-rotate))',
|
|
'skewX(var(--tw-skew-x))',
|
|
'skewY(var(--tw-skew-y))',
|
|
'scaleX(var(--tw-scale-x))',
|
|
'scaleY(var(--tw-scale-y))',
|
|
].join(' '),
|
|
},
|
|
})
|
|
addUtilities({
|
|
'.transform': { '@defaults transform': {}, transform: 'var(--tw-transform)' },
|
|
'.transform-cpu': {
|
|
'--tw-transform': [
|
|
'translateX(var(--tw-translate-x))',
|
|
'translateY(var(--tw-translate-y))',
|
|
'rotate(var(--tw-rotate))',
|
|
'skewX(var(--tw-skew-x))',
|
|
'skewY(var(--tw-skew-y))',
|
|
'scaleX(var(--tw-scale-x))',
|
|
'scaleY(var(--tw-scale-y))',
|
|
].join(' '),
|
|
},
|
|
'.transform-gpu': {
|
|
'--tw-transform': [
|
|
'translate3d(var(--tw-translate-x), var(--tw-translate-y), 0)',
|
|
'rotate(var(--tw-rotate))',
|
|
'skewX(var(--tw-skew-x))',
|
|
'skewY(var(--tw-skew-y))',
|
|
'scaleX(var(--tw-scale-x))',
|
|
'scaleY(var(--tw-scale-y))',
|
|
].join(' '),
|
|
},
|
|
'.transform-none': { transform: 'none' },
|
|
})
|
|
},
|
|
|
|
animation: ({ matchUtilities, theme, prefix }) => {
|
|
let prefixName = (name) => prefix(`.${name}`).slice(1)
|
|
let keyframes = Object.fromEntries(
|
|
Object.entries(theme('keyframes') ?? {}).map(([key, value]) => {
|
|
return [key, [{ [`@keyframes ${prefixName(key)}`]: value }]]
|
|
})
|
|
)
|
|
|
|
matchUtilities(
|
|
{
|
|
animate: (value, { includeRules }) => {
|
|
let animations = parseAnimationValue(value)
|
|
|
|
for (let { name } of animations) {
|
|
if (keyframes[name] !== undefined) {
|
|
includeRules(keyframes[name], { respectImportant: false })
|
|
}
|
|
}
|
|
|
|
return {
|
|
animation: animations
|
|
.map(({ name, value }) => {
|
|
if (name === undefined || keyframes[name] === undefined) {
|
|
return value
|
|
}
|
|
return value.replace(name, prefixName(name))
|
|
})
|
|
.join(', '),
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('animation') }
|
|
)
|
|
},
|
|
|
|
cursor: createUtilityPlugin('cursor'),
|
|
|
|
touchAction: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.touch-auto': { 'touch-action': 'auto' },
|
|
'.touch-none': { 'touch-action': 'none' },
|
|
'.touch-pan-x': { 'touch-action': 'pan-x' },
|
|
'.touch-pan-left': { 'touch-action': 'pan-left' },
|
|
'.touch-pan-right': { 'touch-action': 'pan-right' },
|
|
'.touch-pan-y': { 'touch-action': 'pan-y' },
|
|
'.touch-pan-up': { 'touch-action': 'pan-up' },
|
|
'.touch-pan-down': { 'touch-action': 'pan-down' },
|
|
'.touch-pinch-zoom': { 'touch-action': 'pinch-zoom' },
|
|
'.touch-manipulation': { 'touch-action': 'manipulation' },
|
|
})
|
|
},
|
|
|
|
userSelect: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.select-none': { 'user-select': 'none' },
|
|
'.select-text': { 'user-select': 'text' },
|
|
'.select-all': { 'user-select': 'all' },
|
|
'.select-auto': { 'user-select': 'auto' },
|
|
})
|
|
},
|
|
|
|
resize: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.resize-none': { resize: 'none' },
|
|
'.resize-y': { resize: 'vertical' },
|
|
'.resize-x': { resize: 'horizontal' },
|
|
'.resize': { resize: 'both' },
|
|
})
|
|
},
|
|
|
|
listStylePosition: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.list-inside': { 'list-style-position': 'inside' },
|
|
'.list-outside': { 'list-style-position': 'outside' },
|
|
})
|
|
},
|
|
|
|
listStyleType: createUtilityPlugin('listStyleType', [['list', ['listStyleType']]]),
|
|
|
|
appearance: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.appearance-none': { appearance: 'none' },
|
|
})
|
|
},
|
|
|
|
columns: createUtilityPlugin('columns', [['columns', ['columns']]]),
|
|
|
|
breakBefore: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.break-before-auto': { 'break-before': 'auto' },
|
|
'.break-before-avoid': { 'break-before': 'avoid' },
|
|
'.break-before-all': { 'break-before': 'all' },
|
|
'.break-before-avoid-page': { 'break-before': 'avoid-page' },
|
|
'.break-before-page': { 'break-before': 'page' },
|
|
'.break-before-left': { 'break-before': 'left' },
|
|
'.break-before-right': { 'break-before': 'right' },
|
|
'.break-before-column': { 'break-before': 'column' },
|
|
})
|
|
},
|
|
|
|
breakInside: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.break-inside-auto': { 'break-inside': 'auto' },
|
|
'.break-inside-avoid': { 'break-inside': 'avoid' },
|
|
'.break-inside-avoid-page': { 'break-inside': 'avoid-page' },
|
|
'.break-inside-avoid-column': { 'break-inside': 'avoid-column' },
|
|
})
|
|
},
|
|
|
|
breakAfter: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.break-after-auto': { 'break-after': 'auto' },
|
|
'.break-after-avoid': { 'break-after': 'avoid' },
|
|
'.break-after-all': { 'break-after': 'all' },
|
|
'.break-after-avoid-page': { 'break-after': 'avoid-page' },
|
|
'.break-after-page': { 'break-after': 'page' },
|
|
'.break-after-left': { 'break-after': 'left' },
|
|
'.break-after-right': { 'break-after': 'right' },
|
|
'.break-after-column': { 'break-after': 'column' },
|
|
})
|
|
},
|
|
|
|
gridAutoColumns: createUtilityPlugin('gridAutoColumns', [['auto-cols', ['gridAutoColumns']]]),
|
|
|
|
gridAutoFlow: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.grid-flow-row': { gridAutoFlow: 'row' },
|
|
'.grid-flow-col': { gridAutoFlow: 'column' },
|
|
'.grid-flow-row-dense': { gridAutoFlow: 'row dense' },
|
|
'.grid-flow-col-dense': { gridAutoFlow: 'column dense' },
|
|
})
|
|
},
|
|
|
|
gridAutoRows: createUtilityPlugin('gridAutoRows', [['auto-rows', ['gridAutoRows']]]),
|
|
gridTemplateColumns: createUtilityPlugin('gridTemplateColumns', [
|
|
['grid-cols', ['gridTemplateColumns']],
|
|
]),
|
|
gridTemplateRows: createUtilityPlugin('gridTemplateRows', [['grid-rows', ['gridTemplateRows']]]),
|
|
|
|
flexDirection: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.flex-row': { 'flex-direction': 'row' },
|
|
'.flex-row-reverse': { 'flex-direction': 'row-reverse' },
|
|
'.flex-col': { 'flex-direction': 'column' },
|
|
'.flex-col-reverse': { 'flex-direction': 'column-reverse' },
|
|
})
|
|
},
|
|
|
|
flexWrap: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.flex-wrap': { 'flex-wrap': 'wrap' },
|
|
'.flex-wrap-reverse': { 'flex-wrap': 'wrap-reverse' },
|
|
'.flex-nowrap': { 'flex-wrap': 'nowrap' },
|
|
})
|
|
},
|
|
|
|
placeContent: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.place-content-center': { 'place-content': 'center' },
|
|
'.place-content-start': { 'place-content': 'start' },
|
|
'.place-content-end': { 'place-content': 'end' },
|
|
'.place-content-between': { 'place-content': 'space-between' },
|
|
'.place-content-around': { 'place-content': 'space-around' },
|
|
'.place-content-evenly': { 'place-content': 'space-evenly' },
|
|
'.place-content-stretch': { 'place-content': 'stretch' },
|
|
})
|
|
},
|
|
|
|
placeItems: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.place-items-start': { 'place-items': 'start' },
|
|
'.place-items-end': { 'place-items': 'end' },
|
|
'.place-items-center': { 'place-items': 'center' },
|
|
'.place-items-stretch': { 'place-items': 'stretch' },
|
|
})
|
|
},
|
|
|
|
alignContent: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.content-center': { 'align-content': 'center' },
|
|
'.content-start': { 'align-content': 'flex-start' },
|
|
'.content-end': { 'align-content': 'flex-end' },
|
|
'.content-between': { 'align-content': 'space-between' },
|
|
'.content-around': { 'align-content': 'space-around' },
|
|
'.content-evenly': { 'align-content': 'space-evenly' },
|
|
})
|
|
},
|
|
|
|
alignItems: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.items-start': { 'align-items': 'flex-start' },
|
|
'.items-end': { 'align-items': 'flex-end' },
|
|
'.items-center': { 'align-items': 'center' },
|
|
'.items-baseline': { 'align-items': 'baseline' },
|
|
'.items-stretch': { 'align-items': 'stretch' },
|
|
})
|
|
},
|
|
|
|
justifyContent: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.justify-start': { 'justify-content': 'flex-start' },
|
|
'.justify-end': { 'justify-content': 'flex-end' },
|
|
'.justify-center': { 'justify-content': 'center' },
|
|
'.justify-between': { 'justify-content': 'space-between' },
|
|
'.justify-around': { 'justify-content': 'space-around' },
|
|
'.justify-evenly': { 'justify-content': 'space-evenly' },
|
|
})
|
|
},
|
|
|
|
justifyItems: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.justify-items-start': { 'justify-items': 'start' },
|
|
'.justify-items-end': { 'justify-items': 'end' },
|
|
'.justify-items-center': { 'justify-items': 'center' },
|
|
'.justify-items-stretch': { 'justify-items': 'stretch' },
|
|
})
|
|
},
|
|
|
|
gap: createUtilityPlugin('gap', [
|
|
['gap', ['gap']],
|
|
[
|
|
['gap-x', ['columnGap']],
|
|
['gap-y', ['rowGap']],
|
|
],
|
|
]),
|
|
|
|
space: ({ matchUtilities, addUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'space-x': (value) => {
|
|
value = value === '0' ? '0px' : value
|
|
|
|
return {
|
|
'& > :not([hidden]) ~ :not([hidden])': {
|
|
'--tw-space-x-reverse': '0',
|
|
'margin-right': `calc(${value} * var(--tw-space-x-reverse))`,
|
|
'margin-left': `calc(${value} * calc(1 - var(--tw-space-x-reverse)))`,
|
|
},
|
|
}
|
|
},
|
|
'space-y': (value) => {
|
|
value = value === '0' ? '0px' : value
|
|
|
|
return {
|
|
'& > :not([hidden]) ~ :not([hidden])': {
|
|
'--tw-space-y-reverse': '0',
|
|
'margin-top': `calc(${value} * calc(1 - var(--tw-space-y-reverse)))`,
|
|
'margin-bottom': `calc(${value} * var(--tw-space-y-reverse))`,
|
|
},
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('space') }
|
|
)
|
|
|
|
addUtilities({
|
|
'.space-y-reverse > :not([hidden]) ~ :not([hidden])': { '--tw-space-y-reverse': '1' },
|
|
'.space-x-reverse > :not([hidden]) ~ :not([hidden])': { '--tw-space-x-reverse': '1' },
|
|
})
|
|
},
|
|
|
|
divideWidth: ({ matchUtilities, addUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'divide-x': (value) => {
|
|
value = value === '0' ? '0px' : value
|
|
|
|
return {
|
|
'& > :not([hidden]) ~ :not([hidden])': {
|
|
'@defaults border-width': {},
|
|
'--tw-divide-x-reverse': '0',
|
|
'border-right-width': `calc(${value} * var(--tw-divide-x-reverse))`,
|
|
'border-left-width': `calc(${value} * calc(1 - var(--tw-divide-x-reverse)))`,
|
|
},
|
|
}
|
|
},
|
|
'divide-y': (value) => {
|
|
value = value === '0' ? '0px' : value
|
|
|
|
return {
|
|
'& > :not([hidden]) ~ :not([hidden])': {
|
|
'@defaults border-width': {},
|
|
'--tw-divide-y-reverse': '0',
|
|
'border-top-width': `calc(${value} * calc(1 - var(--tw-divide-y-reverse)))`,
|
|
'border-bottom-width': `calc(${value} * var(--tw-divide-y-reverse))`,
|
|
},
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('divideWidth'), type: ['line-width', 'length'] }
|
|
)
|
|
|
|
addUtilities({
|
|
'.divide-y-reverse > :not([hidden]) ~ :not([hidden])': {
|
|
'@defaults border-width': {},
|
|
'--tw-divide-y-reverse': '1',
|
|
},
|
|
'.divide-x-reverse > :not([hidden]) ~ :not([hidden])': {
|
|
'@defaults border-width': {},
|
|
'--tw-divide-x-reverse': '1',
|
|
},
|
|
})
|
|
},
|
|
|
|
divideStyle: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.divide-solid > :not([hidden]) ~ :not([hidden])': { 'border-style': 'solid' },
|
|
'.divide-dashed > :not([hidden]) ~ :not([hidden])': { 'border-style': 'dashed' },
|
|
'.divide-dotted > :not([hidden]) ~ :not([hidden])': { 'border-style': 'dotted' },
|
|
'.divide-double > :not([hidden]) ~ :not([hidden])': { 'border-style': 'double' },
|
|
'.divide-none > :not([hidden]) ~ :not([hidden])': { 'border-style': 'none' },
|
|
})
|
|
},
|
|
|
|
divideColor: ({ matchUtilities, theme, corePlugins }) => {
|
|
matchUtilities(
|
|
{
|
|
divide: (value) => {
|
|
if (!corePlugins('divideOpacity')) {
|
|
return {
|
|
['& > :not([hidden]) ~ :not([hidden])']: {
|
|
'border-color': toColorValue(value),
|
|
},
|
|
}
|
|
}
|
|
|
|
return {
|
|
['& > :not([hidden]) ~ :not([hidden])']: withAlphaVariable({
|
|
color: value,
|
|
property: 'border-color',
|
|
variable: '--tw-divide-opacity',
|
|
}),
|
|
}
|
|
},
|
|
},
|
|
{
|
|
values: (({ DEFAULT: _, ...colors }) => colors)(flattenColorPalette(theme('divideColor'))),
|
|
type: 'color',
|
|
}
|
|
)
|
|
},
|
|
|
|
divideOpacity: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'divide-opacity': (value) => {
|
|
return { [`& > :not([hidden]) ~ :not([hidden])`]: { '--tw-divide-opacity': value } }
|
|
},
|
|
},
|
|
{ values: theme('divideOpacity') }
|
|
)
|
|
},
|
|
|
|
placeSelf: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.place-self-auto': { 'place-self': 'auto' },
|
|
'.place-self-start': { 'place-self': 'start' },
|
|
'.place-self-end': { 'place-self': 'end' },
|
|
'.place-self-center': { 'place-self': 'center' },
|
|
'.place-self-stretch': { 'place-self': 'stretch' },
|
|
})
|
|
},
|
|
|
|
alignSelf: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.self-auto': { 'align-self': 'auto' },
|
|
'.self-start': { 'align-self': 'flex-start' },
|
|
'.self-end': { 'align-self': 'flex-end' },
|
|
'.self-center': { 'align-self': 'center' },
|
|
'.self-stretch': { 'align-self': 'stretch' },
|
|
'.self-baseline': { 'align-self': 'baseline' },
|
|
})
|
|
},
|
|
|
|
justifySelf: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.justify-self-auto': { 'justify-self': 'auto' },
|
|
'.justify-self-start': { 'justify-self': 'start' },
|
|
'.justify-self-end': { 'justify-self': 'end' },
|
|
'.justify-self-center': { 'justify-self': 'center' },
|
|
'.justify-self-stretch': { 'justify-self': 'stretch' },
|
|
})
|
|
},
|
|
|
|
overflow: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.overflow-auto': { overflow: 'auto' },
|
|
'.overflow-hidden': { overflow: 'hidden' },
|
|
'.overflow-visible': { overflow: 'visible' },
|
|
'.overflow-scroll': { overflow: 'scroll' },
|
|
'.overflow-x-auto': { 'overflow-x': 'auto' },
|
|
'.overflow-y-auto': { 'overflow-y': 'auto' },
|
|
'.overflow-x-hidden': { 'overflow-x': 'hidden' },
|
|
'.overflow-y-hidden': { 'overflow-y': 'hidden' },
|
|
'.overflow-x-visible': { 'overflow-x': 'visible' },
|
|
'.overflow-y-visible': { 'overflow-y': 'visible' },
|
|
'.overflow-x-scroll': { 'overflow-x': 'scroll' },
|
|
'.overflow-y-scroll': { 'overflow-y': 'scroll' },
|
|
})
|
|
},
|
|
|
|
overscrollBehavior: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.overscroll-auto': { 'overscroll-behavior': 'auto' },
|
|
'.overscroll-contain': { 'overscroll-behavior': 'contain' },
|
|
'.overscroll-none': { 'overscroll-behavior': 'none' },
|
|
'.overscroll-y-auto': { 'overscroll-behavior-y': 'auto' },
|
|
'.overscroll-y-contain': { 'overscroll-behavior-y': 'contain' },
|
|
'.overscroll-y-none': { 'overscroll-behavior-y': 'none' },
|
|
'.overscroll-x-auto': { 'overscroll-behavior-x': 'auto' },
|
|
'.overscroll-x-contain': { 'overscroll-behavior-x': 'contain' },
|
|
'.overscroll-x-none': { 'overscroll-behavior-x': 'none' },
|
|
})
|
|
},
|
|
|
|
scrollBehavior: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.scroll-auto': { 'scroll-behavior': 'auto' },
|
|
'.scroll-smooth': { 'scroll-behavior': 'smooth' },
|
|
})
|
|
},
|
|
|
|
textOverflow: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.truncate': { overflow: 'hidden', 'text-overflow': 'ellipsis', 'white-space': 'nowrap' },
|
|
'.overflow-ellipsis': { 'text-overflow': 'ellipsis' },
|
|
'.overflow-clip': { 'text-overflow': 'clip' },
|
|
})
|
|
},
|
|
|
|
whitespace: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.whitespace-normal': { 'white-space': 'normal' },
|
|
'.whitespace-nowrap': { 'white-space': 'nowrap' },
|
|
'.whitespace-pre': { 'white-space': 'pre' },
|
|
'.whitespace-pre-line': { 'white-space': 'pre-line' },
|
|
'.whitespace-pre-wrap': { 'white-space': 'pre-wrap' },
|
|
})
|
|
},
|
|
|
|
wordBreak: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.break-normal': { 'overflow-wrap': 'normal', 'word-break': 'normal' },
|
|
'.break-words': { 'overflow-wrap': 'break-word' },
|
|
'.break-all': { 'word-break': 'break-all' },
|
|
})
|
|
},
|
|
|
|
borderRadius: createUtilityPlugin('borderRadius', [
|
|
['rounded', ['border-radius']],
|
|
[
|
|
['rounded-t', ['border-top-left-radius', 'border-top-right-radius']],
|
|
['rounded-r', ['border-top-right-radius', 'border-bottom-right-radius']],
|
|
['rounded-b', ['border-bottom-right-radius', 'border-bottom-left-radius']],
|
|
['rounded-l', ['border-top-left-radius', 'border-bottom-left-radius']],
|
|
],
|
|
[
|
|
['rounded-tl', ['border-top-left-radius']],
|
|
['rounded-tr', ['border-top-right-radius']],
|
|
['rounded-br', ['border-bottom-right-radius']],
|
|
['rounded-bl', ['border-bottom-left-radius']],
|
|
],
|
|
]),
|
|
|
|
borderWidth: createUtilityPlugin(
|
|
'borderWidth',
|
|
[
|
|
['border', [['@defaults border-width', {}], 'border-width']],
|
|
[
|
|
['border-t', [['@defaults border-width', {}], 'border-top-width']],
|
|
['border-r', [['@defaults border-width', {}], 'border-right-width']],
|
|
['border-b', [['@defaults border-width', {}], 'border-bottom-width']],
|
|
['border-l', [['@defaults border-width', {}], 'border-left-width']],
|
|
],
|
|
],
|
|
{ type: ['line-width', 'length'] }
|
|
),
|
|
|
|
borderStyle: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.border-solid': { 'border-style': 'solid' },
|
|
'.border-dashed': { 'border-style': 'dashed' },
|
|
'.border-dotted': { 'border-style': 'dotted' },
|
|
'.border-double': { 'border-style': 'double' },
|
|
'.border-hidden': { 'border-style': 'hidden' },
|
|
'.border-none': { 'border-style': 'none' },
|
|
})
|
|
},
|
|
|
|
borderColor: ({ addBase, matchUtilities, theme, corePlugins }) => {
|
|
if (!corePlugins('borderOpacity')) {
|
|
let value = theme('borderColor.DEFAULT', 'currentColor')
|
|
addBase({
|
|
'@defaults border-width': {
|
|
'border-color': toColorValue(value),
|
|
},
|
|
})
|
|
} else {
|
|
addBase({
|
|
'@defaults border-width': withAlphaVariable({
|
|
color: theme('borderColor.DEFAULT', 'currentColor'),
|
|
property: 'border-color',
|
|
variable: '--tw-border-opacity',
|
|
}),
|
|
})
|
|
}
|
|
|
|
matchUtilities(
|
|
{
|
|
border: (value) => {
|
|
if (!corePlugins('borderOpacity')) {
|
|
return {
|
|
'border-color': toColorValue(value),
|
|
}
|
|
}
|
|
|
|
return withAlphaVariable({
|
|
color: value,
|
|
property: 'border-color',
|
|
variable: '--tw-border-opacity',
|
|
})
|
|
},
|
|
},
|
|
{
|
|
values: (({ DEFAULT: _, ...colors }) => colors)(flattenColorPalette(theme('borderColor'))),
|
|
type: ['color'],
|
|
}
|
|
)
|
|
|
|
matchUtilities(
|
|
{
|
|
'border-t': (value) => {
|
|
if (!corePlugins('borderOpacity')) {
|
|
return {
|
|
'border-top-color': toColorValue(value),
|
|
}
|
|
}
|
|
|
|
return withAlphaVariable({
|
|
color: value,
|
|
property: 'border-top-color',
|
|
variable: '--tw-border-opacity',
|
|
})
|
|
},
|
|
'border-r': (value) => {
|
|
if (!corePlugins('borderOpacity')) {
|
|
return {
|
|
'border-right-color': toColorValue(value),
|
|
}
|
|
}
|
|
|
|
return withAlphaVariable({
|
|
color: value,
|
|
property: 'border-right-color',
|
|
variable: '--tw-border-opacity',
|
|
})
|
|
},
|
|
'border-b': (value) => {
|
|
if (!corePlugins('borderOpacity')) {
|
|
return {
|
|
'border-bottom-color': toColorValue(value),
|
|
}
|
|
}
|
|
|
|
return withAlphaVariable({
|
|
color: value,
|
|
property: 'border-bottom-color',
|
|
variable: '--tw-border-opacity',
|
|
})
|
|
},
|
|
'border-l': (value) => {
|
|
if (!corePlugins('borderOpacity')) {
|
|
return {
|
|
'border-left-color': toColorValue(value),
|
|
}
|
|
}
|
|
|
|
return withAlphaVariable({
|
|
color: value,
|
|
property: 'border-left-color',
|
|
variable: '--tw-border-opacity',
|
|
})
|
|
},
|
|
},
|
|
{
|
|
values: (({ DEFAULT: _, ...colors }) => colors)(flattenColorPalette(theme('borderColor'))),
|
|
type: 'color',
|
|
}
|
|
)
|
|
},
|
|
|
|
borderOpacity: createUtilityPlugin('borderOpacity', [
|
|
['border-opacity', ['--tw-border-opacity']],
|
|
]),
|
|
|
|
backgroundColor: ({ matchUtilities, theme, corePlugins }) => {
|
|
matchUtilities(
|
|
{
|
|
bg: (value) => {
|
|
if (!corePlugins('backgroundOpacity')) {
|
|
return {
|
|
'background-color': toColorValue(value),
|
|
}
|
|
}
|
|
|
|
return withAlphaVariable({
|
|
color: value,
|
|
property: 'background-color',
|
|
variable: '--tw-bg-opacity',
|
|
})
|
|
},
|
|
},
|
|
{ values: flattenColorPalette(theme('backgroundColor')), type: 'color' }
|
|
)
|
|
},
|
|
|
|
backgroundOpacity: createUtilityPlugin('backgroundOpacity', [
|
|
['bg-opacity', ['--tw-bg-opacity']],
|
|
]),
|
|
backgroundImage: createUtilityPlugin('backgroundImage', [['bg', ['background-image']]], {
|
|
type: ['lookup', 'image', 'url'],
|
|
}),
|
|
gradientColorStops: (() => {
|
|
function transparentTo(value) {
|
|
return withAlphaValue(value, 0, 'rgb(255 255 255 / 0)')
|
|
}
|
|
|
|
return function ({ matchUtilities, theme }) {
|
|
let options = {
|
|
values: flattenColorPalette(theme('gradientColorStops')),
|
|
type: ['color', 'any'],
|
|
}
|
|
|
|
matchUtilities(
|
|
{
|
|
from: (value) => {
|
|
let transparentToValue = transparentTo(value)
|
|
|
|
return {
|
|
'--tw-gradient-from': toColorValue(value, 'from'),
|
|
'--tw-gradient-stops': `var(--tw-gradient-from), var(--tw-gradient-to, ${transparentToValue})`,
|
|
}
|
|
},
|
|
},
|
|
options
|
|
)
|
|
matchUtilities(
|
|
{
|
|
via: (value) => {
|
|
let transparentToValue = transparentTo(value)
|
|
|
|
return {
|
|
'--tw-gradient-stops': `var(--tw-gradient-from), ${toColorValue(
|
|
value,
|
|
'via'
|
|
)}, var(--tw-gradient-to, ${transparentToValue})`,
|
|
}
|
|
},
|
|
},
|
|
options
|
|
)
|
|
matchUtilities(
|
|
{ to: (value) => ({ '--tw-gradient-to': toColorValue(value, 'to') }) },
|
|
options
|
|
)
|
|
}
|
|
})(),
|
|
|
|
boxDecorationBreak: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.decoration-slice': { 'box-decoration-break': 'slice' },
|
|
'.decoration-clone': { 'box-decoration-break': 'clone' },
|
|
})
|
|
},
|
|
|
|
backgroundSize: createUtilityPlugin('backgroundSize', [['bg', ['background-size']]], {
|
|
type: ['lookup', 'length', 'percentage'],
|
|
}),
|
|
|
|
backgroundAttachment: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.bg-fixed': { 'background-attachment': 'fixed' },
|
|
'.bg-local': { 'background-attachment': 'local' },
|
|
'.bg-scroll': { 'background-attachment': 'scroll' },
|
|
})
|
|
},
|
|
|
|
backgroundClip: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.bg-clip-border': { 'background-clip': 'border-box' },
|
|
'.bg-clip-padding': { 'background-clip': 'padding-box' },
|
|
'.bg-clip-content': { 'background-clip': 'content-box' },
|
|
'.bg-clip-text': { 'background-clip': 'text' },
|
|
})
|
|
},
|
|
|
|
backgroundPosition: createUtilityPlugin('backgroundPosition', [['bg', ['background-position']]], {
|
|
type: ['lookup', 'position'],
|
|
}),
|
|
|
|
backgroundRepeat: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.bg-repeat': { 'background-repeat': 'repeat' },
|
|
'.bg-no-repeat': { 'background-repeat': 'no-repeat' },
|
|
'.bg-repeat-x': { 'background-repeat': 'repeat-x' },
|
|
'.bg-repeat-y': { 'background-repeat': 'repeat-y' },
|
|
'.bg-repeat-round': { 'background-repeat': 'round' },
|
|
'.bg-repeat-space': { 'background-repeat': 'space' },
|
|
})
|
|
},
|
|
|
|
backgroundOrigin: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.bg-origin-border': { 'background-origin': 'border-box' },
|
|
'.bg-origin-padding': { 'background-origin': 'padding-box' },
|
|
'.bg-origin-content': { 'background-origin': 'content-box' },
|
|
})
|
|
},
|
|
|
|
fill: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
fill: (value) => {
|
|
return { fill: toColorValue(value) }
|
|
},
|
|
},
|
|
{ values: flattenColorPalette(theme('fill')), type: ['color', 'any'] }
|
|
)
|
|
},
|
|
|
|
stroke: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
stroke: (value) => {
|
|
return { stroke: toColorValue(value) }
|
|
},
|
|
},
|
|
{ values: flattenColorPalette(theme('stroke')), type: ['color', 'url'] }
|
|
)
|
|
},
|
|
|
|
strokeWidth: createUtilityPlugin('strokeWidth', [['stroke', ['stroke-width']]], {
|
|
type: ['length', 'number', 'percentage'],
|
|
}),
|
|
|
|
objectFit: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.object-contain': { 'object-fit': 'contain' },
|
|
'.object-cover': { 'object-fit': 'cover' },
|
|
'.object-fill': { 'object-fit': 'fill' },
|
|
'.object-none': { 'object-fit': 'none' },
|
|
'.object-scale-down': { 'object-fit': 'scale-down' },
|
|
})
|
|
},
|
|
objectPosition: createUtilityPlugin('objectPosition', [['object', ['object-position']]]),
|
|
|
|
padding: createUtilityPlugin('padding', [
|
|
['p', ['padding']],
|
|
[
|
|
['px', ['padding-left', 'padding-right']],
|
|
['py', ['padding-top', 'padding-bottom']],
|
|
],
|
|
[
|
|
['pt', ['padding-top']],
|
|
['pr', ['padding-right']],
|
|
['pb', ['padding-bottom']],
|
|
['pl', ['padding-left']],
|
|
],
|
|
]),
|
|
|
|
textAlign: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.text-left': { 'text-align': 'left' },
|
|
'.text-center': { 'text-align': 'center' },
|
|
'.text-right': { 'text-align': 'right' },
|
|
'.text-justify': { 'text-align': 'justify' },
|
|
})
|
|
},
|
|
|
|
textIndent: createUtilityPlugin('textIndent', [['indent', ['text-indent']]]),
|
|
|
|
verticalAlign: ({ addUtilities, matchUtilities }) => {
|
|
addUtilities({
|
|
'.align-baseline': { 'vertical-align': 'baseline' },
|
|
'.align-top': { 'vertical-align': 'top' },
|
|
'.align-middle': { 'vertical-align': 'middle' },
|
|
'.align-bottom': { 'vertical-align': 'bottom' },
|
|
'.align-text-top': { 'vertical-align': 'text-top' },
|
|
'.align-text-bottom': { 'vertical-align': 'text-bottom' },
|
|
'.align-sub': { 'vertical-align': 'sub' },
|
|
'.align-super': { 'vertical-align': 'super' },
|
|
})
|
|
|
|
matchUtilities({ align: (value) => ({ 'vertical-align': value }) })
|
|
},
|
|
|
|
fontFamily: createUtilityPlugin('fontFamily', [['font', ['fontFamily']]], {
|
|
type: ['lookup', 'generic-name', 'family-name'],
|
|
}),
|
|
|
|
fontSize: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
text: (value) => {
|
|
let [fontSize, options] = Array.isArray(value) ? value : [value]
|
|
let { lineHeight, letterSpacing } = isPlainObject(options)
|
|
? options
|
|
: { lineHeight: options }
|
|
|
|
return {
|
|
'font-size': fontSize,
|
|
...(lineHeight === undefined ? {} : { 'line-height': lineHeight }),
|
|
...(letterSpacing === undefined ? {} : { 'letter-spacing': letterSpacing }),
|
|
}
|
|
},
|
|
},
|
|
{
|
|
values: theme('fontSize'),
|
|
type: ['absolute-size', 'relative-size', 'length', 'percentage'],
|
|
}
|
|
)
|
|
},
|
|
|
|
fontWeight: createUtilityPlugin('fontWeight', [['font', ['fontWeight']]], {
|
|
type: ['lookup', 'number'],
|
|
}),
|
|
|
|
textTransform: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.uppercase': { 'text-transform': 'uppercase' },
|
|
'.lowercase': { 'text-transform': 'lowercase' },
|
|
'.capitalize': { 'text-transform': 'capitalize' },
|
|
'.normal-case': { 'text-transform': 'none' },
|
|
})
|
|
},
|
|
|
|
fontStyle: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.italic': { 'font-style': 'italic' },
|
|
'.not-italic': { 'font-style': 'normal' },
|
|
})
|
|
},
|
|
|
|
fontVariantNumeric: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.ordinal, .slashed-zero, .lining-nums, .oldstyle-nums, .proportional-nums, .tabular-nums, .diagonal-fractions, .stacked-fractions':
|
|
{
|
|
'--tw-ordinal': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-slashed-zero': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-numeric-figure': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-numeric-spacing': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-numeric-fraction': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'font-variant-numeric':
|
|
'var(--tw-ordinal) var(--tw-slashed-zero) var(--tw-numeric-figure) var(--tw-numeric-spacing) var(--tw-numeric-fraction)',
|
|
},
|
|
'.normal-nums': { 'font-variant-numeric': 'normal' },
|
|
'.ordinal': { '--tw-ordinal': 'ordinal' },
|
|
'.slashed-zero': { '--tw-slashed-zero': 'slashed-zero' },
|
|
'.lining-nums': { '--tw-numeric-figure': 'lining-nums' },
|
|
'.oldstyle-nums': { '--tw-numeric-figure': 'oldstyle-nums' },
|
|
'.proportional-nums': { '--tw-numeric-spacing': 'proportional-nums' },
|
|
'.tabular-nums': { '--tw-numeric-spacing': 'tabular-nums' },
|
|
'.diagonal-fractions': { '--tw-numeric-fraction': 'diagonal-fractions' },
|
|
'.stacked-fractions': { '--tw-numeric-fraction': 'stacked-fractions' },
|
|
})
|
|
},
|
|
|
|
lineHeight: createUtilityPlugin('lineHeight', [['leading', ['lineHeight']]]),
|
|
letterSpacing: createUtilityPlugin('letterSpacing', [['tracking', ['letterSpacing']]]),
|
|
|
|
textColor: ({ matchUtilities, theme, corePlugins }) => {
|
|
matchUtilities(
|
|
{
|
|
text: (value) => {
|
|
if (!corePlugins('textOpacity')) {
|
|
return { color: toColorValue(value) }
|
|
}
|
|
|
|
return withAlphaVariable({
|
|
color: value,
|
|
property: 'color',
|
|
variable: '--tw-text-opacity',
|
|
})
|
|
},
|
|
},
|
|
{ values: flattenColorPalette(theme('textColor')), type: 'color' }
|
|
)
|
|
},
|
|
|
|
textOpacity: createUtilityPlugin('textOpacity', [['text-opacity', ['--tw-text-opacity']]]),
|
|
|
|
textDecoration: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.underline': { 'text-decoration': 'underline' },
|
|
'.line-through': { 'text-decoration': 'line-through' },
|
|
'.no-underline': { 'text-decoration': 'none' },
|
|
})
|
|
},
|
|
|
|
fontSmoothing: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.antialiased': {
|
|
'-webkit-font-smoothing': 'antialiased',
|
|
'-moz-osx-font-smoothing': 'grayscale',
|
|
},
|
|
'.subpixel-antialiased': {
|
|
'-webkit-font-smoothing': 'auto',
|
|
'-moz-osx-font-smoothing': 'auto',
|
|
},
|
|
})
|
|
},
|
|
|
|
placeholderColor: ({ matchUtilities, theme, corePlugins }) => {
|
|
matchUtilities(
|
|
{
|
|
placeholder: (value) => {
|
|
if (!corePlugins('placeholderOpacity')) {
|
|
return {
|
|
'&::placeholder': {
|
|
color: toColorValue(value),
|
|
},
|
|
}
|
|
}
|
|
|
|
return {
|
|
'&::placeholder': withAlphaVariable({
|
|
color: value,
|
|
property: 'color',
|
|
variable: '--tw-placeholder-opacity',
|
|
}),
|
|
}
|
|
},
|
|
},
|
|
{ values: flattenColorPalette(theme('placeholderColor')), type: ['color', 'any'] }
|
|
)
|
|
},
|
|
|
|
placeholderOpacity: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'placeholder-opacity': (value) => {
|
|
return { ['&::placeholder']: { '--tw-placeholder-opacity': value } }
|
|
},
|
|
},
|
|
{ values: theme('placeholderOpacity') }
|
|
)
|
|
},
|
|
|
|
caretColor: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
caret: (value) => {
|
|
return { 'caret-color': toColorValue(value) }
|
|
},
|
|
},
|
|
{ values: flattenColorPalette(theme('caretColor')), type: ['color', 'any'] }
|
|
)
|
|
},
|
|
|
|
accentColor: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
accent: (value) => {
|
|
return { 'accent-color': toColorValue(value) }
|
|
},
|
|
},
|
|
{ values: flattenColorPalette(theme('accentColor')), type: ['color', 'any'] }
|
|
)
|
|
},
|
|
|
|
opacity: createUtilityPlugin('opacity', [['opacity', ['opacity']]]),
|
|
|
|
backgroundBlendMode: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.bg-blend-normal': { 'background-blend-mode': 'normal' },
|
|
'.bg-blend-multiply': { 'background-blend-mode': 'multiply' },
|
|
'.bg-blend-screen': { 'background-blend-mode': 'screen' },
|
|
'.bg-blend-overlay': { 'background-blend-mode': 'overlay' },
|
|
'.bg-blend-darken': { 'background-blend-mode': 'darken' },
|
|
'.bg-blend-lighten': { 'background-blend-mode': 'lighten' },
|
|
'.bg-blend-color-dodge': { 'background-blend-mode': 'color-dodge' },
|
|
'.bg-blend-color-burn': { 'background-blend-mode': 'color-burn' },
|
|
'.bg-blend-hard-light': { 'background-blend-mode': 'hard-light' },
|
|
'.bg-blend-soft-light': { 'background-blend-mode': 'soft-light' },
|
|
'.bg-blend-difference': { 'background-blend-mode': 'difference' },
|
|
'.bg-blend-exclusion': { 'background-blend-mode': 'exclusion' },
|
|
'.bg-blend-hue': { 'background-blend-mode': 'hue' },
|
|
'.bg-blend-saturation': { 'background-blend-mode': 'saturation' },
|
|
'.bg-blend-color': { 'background-blend-mode': 'color' },
|
|
'.bg-blend-luminosity': { 'background-blend-mode': 'luminosity' },
|
|
})
|
|
},
|
|
|
|
mixBlendMode: ({ addUtilities }) => {
|
|
addUtilities({
|
|
'.mix-blend-normal': { 'mix-blend-mode': 'normal' },
|
|
'.mix-blend-multiply': { 'mix-blend-mode': 'multiply' },
|
|
'.mix-blend-screen': { 'mix-blend-mode': 'screen' },
|
|
'.mix-blend-overlay': { 'mix-blend-mode': 'overlay' },
|
|
'.mix-blend-darken': { 'mix-blend-mode': 'darken' },
|
|
'.mix-blend-lighten': { 'mix-blend-mode': 'lighten' },
|
|
'.mix-blend-color-dodge': { 'mix-blend-mode': 'color-dodge' },
|
|
'.mix-blend-color-burn': { 'mix-blend-mode': 'color-burn' },
|
|
'.mix-blend-hard-light': { 'mix-blend-mode': 'hard-light' },
|
|
'.mix-blend-soft-light': { 'mix-blend-mode': 'soft-light' },
|
|
'.mix-blend-difference': { 'mix-blend-mode': 'difference' },
|
|
'.mix-blend-exclusion': { 'mix-blend-mode': 'exclusion' },
|
|
'.mix-blend-hue': { 'mix-blend-mode': 'hue' },
|
|
'.mix-blend-saturation': { 'mix-blend-mode': 'saturation' },
|
|
'.mix-blend-color': { 'mix-blend-mode': 'color' },
|
|
'.mix-blend-luminosity': { 'mix-blend-mode': 'luminosity' },
|
|
})
|
|
},
|
|
|
|
boxShadow: (() => {
|
|
let transformValue = transformThemeValue('boxShadow')
|
|
let defaultBoxShadow = [
|
|
`var(--tw-ring-offset-shadow, 0 0 #0000)`,
|
|
`var(--tw-ring-shadow, 0 0 #0000)`,
|
|
`var(--tw-shadow)`,
|
|
].join(', ')
|
|
|
|
return function ({ matchUtilities, addBase, theme }) {
|
|
addBase({
|
|
'@defaults box-shadow': {
|
|
'--tw-ring-offset-shadow': '0 0 #0000',
|
|
'--tw-ring-shadow': '0 0 #0000',
|
|
'--tw-shadow': '0 0 #0000',
|
|
},
|
|
})
|
|
|
|
matchUtilities(
|
|
{
|
|
shadow: (value) => {
|
|
value = transformValue(value)
|
|
|
|
return {
|
|
'@defaults box-shadow': {},
|
|
'--tw-shadow': value === 'none' ? '0 0 #0000' : value,
|
|
'box-shadow': defaultBoxShadow,
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('boxShadow') }
|
|
)
|
|
}
|
|
})(),
|
|
|
|
outline: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
outline: (value) => {
|
|
value = Array.isArray(value) ? value : value.split(',')
|
|
let [outline, outlineOffset = '0'] = Array.isArray(value) ? value : [value]
|
|
|
|
return { outline, 'outline-offset': outlineOffset }
|
|
},
|
|
},
|
|
{ values: theme('outline') }
|
|
)
|
|
},
|
|
|
|
ringWidth: ({ matchUtilities, addBase, addUtilities, theme }) => {
|
|
let ringOpacityDefault = theme('ringOpacity.DEFAULT', '0.5')
|
|
let ringColorDefault = withAlphaValue(
|
|
theme('ringColor.DEFAULT'),
|
|
ringOpacityDefault,
|
|
`rgb(147 197 253 / ${ringOpacityDefault})`
|
|
)
|
|
|
|
addBase({
|
|
'@defaults ring-width': {
|
|
'--tw-ring-inset': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-ring-offset-width': theme('ringOffsetWidth.DEFAULT', '0px'),
|
|
'--tw-ring-offset-color': theme('ringOffsetColor.DEFAULT', '#fff'),
|
|
'--tw-ring-color': ringColorDefault,
|
|
'--tw-ring-offset-shadow': '0 0 #0000',
|
|
'--tw-ring-shadow': '0 0 #0000',
|
|
'--tw-shadow': '0 0 #0000',
|
|
},
|
|
})
|
|
|
|
matchUtilities(
|
|
{
|
|
ring: (value) => {
|
|
return {
|
|
'@defaults ring-width': {},
|
|
'--tw-ring-offset-shadow': `var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)`,
|
|
'--tw-ring-shadow': `var(--tw-ring-inset) 0 0 0 calc(${value} + var(--tw-ring-offset-width)) var(--tw-ring-color)`,
|
|
'box-shadow': [
|
|
`var(--tw-ring-offset-shadow)`,
|
|
`var(--tw-ring-shadow)`,
|
|
`var(--tw-shadow, 0 0 #0000)`,
|
|
].join(', '),
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('ringWidth'), type: 'length' }
|
|
)
|
|
|
|
addUtilities({
|
|
'.ring-inset': { '@defaults ring-width': {}, '--tw-ring-inset': 'inset' },
|
|
})
|
|
},
|
|
|
|
ringColor: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
ring: (value) => {
|
|
return withAlphaVariable({
|
|
color: value,
|
|
property: '--tw-ring-color',
|
|
variable: '--tw-ring-opacity',
|
|
})
|
|
},
|
|
},
|
|
{
|
|
values: Object.fromEntries(
|
|
Object.entries(flattenColorPalette(theme('ringColor'))).filter(
|
|
([modifier]) => modifier !== 'DEFAULT'
|
|
)
|
|
),
|
|
type: 'color',
|
|
}
|
|
)
|
|
},
|
|
|
|
ringOpacity: createUtilityPlugin('ringOpacity', [['ring-opacity', ['--tw-ring-opacity']]], {
|
|
filterDefault: true,
|
|
}),
|
|
ringOffsetWidth: createUtilityPlugin(
|
|
'ringOffsetWidth',
|
|
[['ring-offset', ['--tw-ring-offset-width']]],
|
|
{ type: 'length' }
|
|
),
|
|
|
|
ringOffsetColor: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'ring-offset': (value) => {
|
|
return {
|
|
'--tw-ring-offset-color': toColorValue(value),
|
|
}
|
|
},
|
|
},
|
|
{ values: flattenColorPalette(theme('ringOffsetColor')), type: 'color' }
|
|
)
|
|
},
|
|
|
|
blur: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
blur: (value) => {
|
|
return {
|
|
'--tw-blur': `blur(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('blur') }
|
|
)
|
|
},
|
|
|
|
brightness: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
brightness: (value) => {
|
|
return {
|
|
'--tw-brightness': `brightness(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('brightness') }
|
|
)
|
|
},
|
|
|
|
contrast: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
contrast: (value) => {
|
|
return {
|
|
'--tw-contrast': `contrast(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('contrast') }
|
|
)
|
|
},
|
|
|
|
dropShadow: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'drop-shadow': (value) => {
|
|
return {
|
|
'--tw-drop-shadow': Array.isArray(value)
|
|
? value.map((v) => `drop-shadow(${v})`).join(' ')
|
|
: `drop-shadow(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('dropShadow') }
|
|
)
|
|
},
|
|
|
|
grayscale: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
grayscale: (value) => {
|
|
return {
|
|
'--tw-grayscale': `grayscale(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('grayscale') }
|
|
)
|
|
},
|
|
|
|
hueRotate: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'hue-rotate': (value) => {
|
|
return {
|
|
'--tw-hue-rotate': `hue-rotate(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('hueRotate') }
|
|
)
|
|
},
|
|
|
|
invert: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
invert: (value) => {
|
|
return {
|
|
'--tw-invert': `invert(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('invert') }
|
|
)
|
|
},
|
|
|
|
saturate: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
saturate: (value) => {
|
|
return {
|
|
'--tw-saturate': `saturate(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('saturate') }
|
|
)
|
|
},
|
|
|
|
sepia: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
sepia: (value) => {
|
|
return {
|
|
'--tw-sepia': `sepia(${value})`,
|
|
'@defaults filter': {},
|
|
filter: 'var(--tw-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('sepia') }
|
|
)
|
|
},
|
|
|
|
filter: ({ addBase, addUtilities }) => {
|
|
addBase({
|
|
'@defaults filter': {
|
|
'--tw-blur': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-brightness': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-contrast': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-grayscale': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-hue-rotate': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-invert': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-saturate': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-sepia': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-drop-shadow': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-filter': [
|
|
'var(--tw-blur)',
|
|
'var(--tw-brightness)',
|
|
'var(--tw-contrast)',
|
|
'var(--tw-grayscale)',
|
|
'var(--tw-hue-rotate)',
|
|
'var(--tw-invert)',
|
|
'var(--tw-saturate)',
|
|
'var(--tw-sepia)',
|
|
'var(--tw-drop-shadow)',
|
|
].join(' '),
|
|
},
|
|
})
|
|
addUtilities({
|
|
'.filter': { '@defaults filter': {}, filter: 'var(--tw-filter)' },
|
|
'.filter-none': { filter: 'none' },
|
|
})
|
|
},
|
|
|
|
backdropBlur: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-blur': (value) => {
|
|
return {
|
|
'--tw-backdrop-blur': `blur(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropBlur') }
|
|
)
|
|
},
|
|
|
|
backdropBrightness: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-brightness': (value) => {
|
|
return {
|
|
'--tw-backdrop-brightness': `brightness(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropBrightness') }
|
|
)
|
|
},
|
|
|
|
backdropContrast: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-contrast': (value) => {
|
|
return {
|
|
'--tw-backdrop-contrast': `contrast(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropContrast') }
|
|
)
|
|
},
|
|
|
|
backdropGrayscale: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-grayscale': (value) => {
|
|
return {
|
|
'--tw-backdrop-grayscale': `grayscale(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropGrayscale') }
|
|
)
|
|
},
|
|
|
|
backdropHueRotate: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-hue-rotate': (value) => {
|
|
return {
|
|
'--tw-backdrop-hue-rotate': `hue-rotate(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropHueRotate') }
|
|
)
|
|
},
|
|
|
|
backdropInvert: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-invert': (value) => {
|
|
return {
|
|
'--tw-backdrop-invert': `invert(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropInvert') }
|
|
)
|
|
},
|
|
|
|
backdropOpacity: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-opacity': (value) => {
|
|
return {
|
|
'--tw-backdrop-opacity': `opacity(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropOpacity') }
|
|
)
|
|
},
|
|
|
|
backdropSaturate: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-saturate': (value) => {
|
|
return {
|
|
'--tw-backdrop-saturate': `saturate(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropSaturate') }
|
|
)
|
|
},
|
|
|
|
backdropSepia: ({ matchUtilities, theme }) => {
|
|
matchUtilities(
|
|
{
|
|
'backdrop-sepia': (value) => {
|
|
return {
|
|
'--tw-backdrop-sepia': `sepia(${value})`,
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('backdropSepia') }
|
|
)
|
|
},
|
|
|
|
backdropFilter: ({ addBase, addUtilities }) => {
|
|
addBase({
|
|
'@defaults backdrop-filter': {
|
|
'--tw-backdrop-blur': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-brightness': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-contrast': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-grayscale': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-hue-rotate': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-invert': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-opacity': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-saturate': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-sepia': 'var(--tw-empty,/*!*/ /*!*/)',
|
|
'--tw-backdrop-filter': [
|
|
'var(--tw-backdrop-blur)',
|
|
'var(--tw-backdrop-brightness)',
|
|
'var(--tw-backdrop-contrast)',
|
|
'var(--tw-backdrop-grayscale)',
|
|
'var(--tw-backdrop-hue-rotate)',
|
|
'var(--tw-backdrop-invert)',
|
|
'var(--tw-backdrop-opacity)',
|
|
'var(--tw-backdrop-saturate)',
|
|
'var(--tw-backdrop-sepia)',
|
|
].join(' '),
|
|
},
|
|
})
|
|
addUtilities({
|
|
'.backdrop-filter': {
|
|
'@defaults backdrop-filter': {},
|
|
'backdrop-filter': 'var(--tw-backdrop-filter)',
|
|
},
|
|
'.backdrop-filter-none': { 'backdrop-filter': 'none' },
|
|
})
|
|
},
|
|
|
|
transitionProperty: ({ matchUtilities, theme }) => {
|
|
let defaultTimingFunction = theme('transitionTimingFunction.DEFAULT')
|
|
let defaultDuration = theme('transitionDuration.DEFAULT')
|
|
|
|
matchUtilities(
|
|
{
|
|
transition: (value) => {
|
|
return {
|
|
'transition-property': value,
|
|
...(value === 'none'
|
|
? {}
|
|
: {
|
|
'transition-timing-function': defaultTimingFunction,
|
|
'transition-duration': defaultDuration,
|
|
}),
|
|
}
|
|
},
|
|
},
|
|
{ values: theme('transitionProperty') }
|
|
)
|
|
},
|
|
|
|
transitionDelay: createUtilityPlugin('transitionDelay', [['delay', ['transitionDelay']]]),
|
|
transitionDuration: createUtilityPlugin(
|
|
'transitionDuration',
|
|
[['duration', ['transitionDuration']]],
|
|
{ filterDefault: true }
|
|
),
|
|
transitionTimingFunction: createUtilityPlugin(
|
|
'transitionTimingFunction',
|
|
[['ease', ['transitionTimingFunction']]],
|
|
{ filterDefault: true }
|
|
),
|
|
willChange: createUtilityPlugin('willChange', [['will-change', ['will-change']]]),
|
|
content: createUtilityPlugin('content'),
|
|
}
|