Don't remove keyframe stops when using important utilities (#12639)

* Don't remove keyframe stops when using important utilities

* Fix test

* fix linting
This commit is contained in:
Jordan Pittman 2023-12-21 12:17:12 -05:00
parent f33d6a5d75
commit 88907757c1
2 changed files with 40 additions and 0 deletions

View File

@ -119,10 +119,20 @@ function applyImportant(matches, classCandidate) {
let result = []
function isInKeyframes(rule) {
return rule.parent && rule.parent.type === 'atrule' && rule.parent.name === 'keyframes'
}
for (let [meta, rule] of matches) {
let container = postcss.root({ nodes: [rule.clone()] })
container.walkRules((r) => {
// Declarations inside keyframes cannot be marked as important
// They will be ignored by the browser
if (isInKeyframes(r)) {
return
}
let ast = selectorParser().astSync(r.selector)
// Remove extraneous selectors that do not include the base candidate

View File

@ -150,4 +150,34 @@ crosscheck(() => {
`)
})
})
test('the important modifier does not break keyframes', () => {
let config = {
content: [
{
raw: html` <div class="!animate-pulse"></div> `,
},
],
corePlugins: { preflight: false },
}
let input = css`
@tailwind utilities;
`
return run(input, config).then((result) => {
expect(result.css).toMatchFormattedCss(css`
@keyframes pulse {
50% {
opacity: 0.5;
}
}
.\!animate-pulse {
animation: 2s cubic-bezier(0.4, 0, 0.6, 1) infinite pulse !important;
}
`)
})
})
})