mirror of
https://github.com/tailwindlabs/tailwindcss.git
synced 2025-12-08 21:36:08 +00:00
* Extend opacity scale to include all steps of 5 * Update changelog --------- Co-authored-by: Adam Wathan <4323180+adamwathan@users.noreply.github.com>
235 lines
6.4 KiB
JavaScript
235 lines
6.4 KiB
JavaScript
import resolveConfig from '../src/public/resolve-config'
|
|
import plugin from '../src/public/create-plugin'
|
|
import { createContext } from '../src/lib/setupContextUtils'
|
|
import { crosscheck } from './util/run'
|
|
|
|
crosscheck(() => {
|
|
it('should generate every possible class, without variants', () => {
|
|
let config = {}
|
|
|
|
let context = createContext(resolveConfig(config))
|
|
let classes = context.getClassList()
|
|
expect(classes).toBeInstanceOf(Array)
|
|
|
|
// Verify we have a `container` for the 'components' section.
|
|
expect(classes).toContain('container')
|
|
|
|
// Verify we handle the DEFAULT case correctly
|
|
expect(classes).toContain('border')
|
|
|
|
// Verify we handle negative values correctly
|
|
expect(classes).toContain('-inset-1/4')
|
|
expect(classes).toContain('-m-0')
|
|
expect(classes).not.toContain('-uppercase')
|
|
expect(classes).not.toContain('-opacity-50')
|
|
|
|
config = { theme: { extend: { margin: { DEFAULT: '5px' } } } }
|
|
context = createContext(resolveConfig(config))
|
|
classes = context.getClassList()
|
|
|
|
expect(classes).not.toContain('-m-DEFAULT')
|
|
})
|
|
|
|
it('should generate every possible class while handling negatives and prefixes', () => {
|
|
let config = { prefix: 'tw-' }
|
|
let context = createContext(resolveConfig(config))
|
|
let classes = context.getClassList()
|
|
expect(classes).toBeInstanceOf(Array)
|
|
|
|
// Verify we have a `container` for the 'components' section.
|
|
expect(classes).toContain('tw-container')
|
|
|
|
// Verify we handle the DEFAULT case correctly
|
|
expect(classes).toContain('tw-border')
|
|
|
|
// Verify we handle negative values correctly
|
|
expect(classes).toContain('-tw-inset-1/4')
|
|
expect(classes).toContain('-tw-m-0')
|
|
expect(classes).not.toContain('-tw-uppercase')
|
|
expect(classes).not.toContain('-tw-opacity-50')
|
|
|
|
// These utilities do work but there's no reason to generate
|
|
// them alongside the `-{prefix}-{utility}` versions
|
|
expect(classes).not.toContain('tw--inset-1/4')
|
|
expect(classes).not.toContain('tw--m-0')
|
|
|
|
config = {
|
|
prefix: 'tw-',
|
|
theme: { extend: { margin: { DEFAULT: '5px' } } },
|
|
}
|
|
context = createContext(resolveConfig(config))
|
|
classes = context.getClassList()
|
|
|
|
expect(classes).not.toContain('-tw-m-DEFAULT')
|
|
})
|
|
|
|
it('should not generate utilities with opacity by default', () => {
|
|
let config = {}
|
|
let context = createContext(resolveConfig(config))
|
|
let classes = context.getClassList()
|
|
|
|
expect(classes).not.toContain('bg-red-500/50')
|
|
})
|
|
|
|
it('should not include metadata by default', () => {
|
|
let config = {}
|
|
let context = createContext(resolveConfig(config))
|
|
let classes = context.getClassList()
|
|
|
|
expect(classes.every((cls) => typeof cls === 'string')).toEqual(true)
|
|
|
|
expect(classes).toContain('bg-red-500')
|
|
expect(classes).toContain('text-2xl')
|
|
})
|
|
|
|
it('should generate utilities with modifier data when requested', () => {
|
|
let config = {}
|
|
let context = createContext(resolveConfig(config))
|
|
let classes = context.getClassList({ includeMetadata: true })
|
|
|
|
expect(classes).not.toContain('bg-red-500')
|
|
expect(classes).not.toContain('text-2xl')
|
|
|
|
expect(classes).toContainEqual([
|
|
'bg-red-500',
|
|
{
|
|
modifiers: [
|
|
'0',
|
|
'5',
|
|
'10',
|
|
'15',
|
|
'20',
|
|
'25',
|
|
'30',
|
|
'35',
|
|
'40',
|
|
'45',
|
|
'50',
|
|
'55',
|
|
'60',
|
|
'65',
|
|
'70',
|
|
'75',
|
|
'80',
|
|
'85',
|
|
'90',
|
|
'95',
|
|
'100',
|
|
],
|
|
},
|
|
])
|
|
expect(classes).toContainEqual([
|
|
'text-2xl',
|
|
{
|
|
modifiers: [
|
|
'3',
|
|
'4',
|
|
'5',
|
|
'6',
|
|
'7',
|
|
'8',
|
|
'9',
|
|
'10',
|
|
'none',
|
|
'tight',
|
|
'snug',
|
|
'normal',
|
|
'relaxed',
|
|
'loose',
|
|
],
|
|
},
|
|
])
|
|
})
|
|
|
|
it('should generate plugin-defined utilities with modifier data when requested', () => {
|
|
let config = {
|
|
plugins: [
|
|
plugin(function ({ matchUtilities }) {
|
|
matchUtilities(
|
|
{
|
|
foo: (value) => {
|
|
return { margin: value }
|
|
},
|
|
},
|
|
{
|
|
values: { xl: '32px' },
|
|
modifiers: { bar: 'something' },
|
|
}
|
|
)
|
|
matchUtilities(
|
|
{
|
|
'foo-negative': (value) => {
|
|
return { margin: value }
|
|
},
|
|
},
|
|
{
|
|
values: { xl: '32px' },
|
|
modifiers: { bar: 'something' },
|
|
supportsNegativeValues: true,
|
|
}
|
|
)
|
|
}),
|
|
],
|
|
}
|
|
let context = createContext(resolveConfig(config))
|
|
let classes = context.getClassList({ includeMetadata: true })
|
|
|
|
expect(classes).toContainEqual(['foo-xl', { modifiers: ['bar'] }])
|
|
expect(classes).toContainEqual(['foo-negative-xl', { modifiers: ['bar'] }])
|
|
expect(classes).toContainEqual(['-foo-negative-xl', { modifiers: ['bar'] }])
|
|
expect(classes).not.toContain('foo-xl')
|
|
expect(classes).not.toContain('-foo-xl')
|
|
expect(classes).not.toContainEqual(['-foo-xl', { modifiers: ['bar'] }])
|
|
})
|
|
|
|
it('should not generate utilities with opacity even if safe-listed', () => {
|
|
let config = {
|
|
safelist: [
|
|
{
|
|
pattern: /^bg-red-(400|500)(\/(40|50))?$/,
|
|
},
|
|
],
|
|
}
|
|
|
|
let context = createContext(resolveConfig(config))
|
|
let classes = context.getClassList()
|
|
|
|
expect(classes).not.toContain('bg-red-500/50')
|
|
})
|
|
|
|
it('should not generate utilities that are set to undefined or null to so that they are removed', () => {
|
|
let config = {
|
|
theme: {
|
|
extend: {
|
|
colors: {
|
|
red: null,
|
|
green: undefined,
|
|
blue: {
|
|
100: null,
|
|
200: undefined,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
safelist: [
|
|
{
|
|
pattern: /^bg-(red|green|blue)-.*$/,
|
|
},
|
|
],
|
|
}
|
|
|
|
let context = createContext(resolveConfig(config))
|
|
let classes = context.getClassList()
|
|
|
|
expect(classes).not.toContain('bg-red-100') // Red is `null`
|
|
|
|
expect(classes).not.toContain('bg-green-100') // Green is `undefined`
|
|
|
|
expect(classes).not.toContain('bg-blue-100') // Blue.100 is `null`
|
|
expect(classes).not.toContain('bg-blue-200') // Blue.200 is `undefined`
|
|
|
|
expect(classes).toContain('bg-blue-50')
|
|
expect(classes).toContain('bg-blue-300')
|
|
})
|
|
})
|