From 1e0099a8b24da8cae49c42082ad10e9ebf940655 Mon Sep 17 00:00:00 2001 From: Jordan Pittman Date: Sat, 7 May 2022 22:48:44 -0400 Subject: [PATCH] Add support for at rules --- src/lib/generateRules.js | 7 ++++++- tests/arbitrary-variants.test.js | 23 +++++++++++++++++++++++ 2 files changed, 29 insertions(+), 1 deletion(-) diff --git a/src/lib/generateRules.js b/src/lib/generateRules.js index 74754b85ecbc..535263cb4b15 100644 --- a/src/lib/generateRules.js +++ b/src/lib/generateRules.js @@ -9,6 +9,7 @@ import * as sharedState from './sharedState' import { formatVariantSelector, finalizeSelector } from '../util/formatVariantSelector' import { asClass } from '../util/nameClass' import { normalize } from '../util/dataTypes' +import { parseVariant } from './setupContextUtils' import isValidArbitraryValue from '../util/isValidArbitraryValue' let classNameParser = selectorParser((selectors) => { @@ -128,8 +129,12 @@ function applyVariant(variant, matches, context) { // Register arbitrary variants if (isArbitraryValue(variant) && !context.variantMap.has(variant)) { let selector = normalize(variant.slice(1, -1)) + + // TODO: Error recovery for @supports(what:ever) -- note the absence of a space + let fn = parseVariant(selector) + let sort = Array.from(context.variantOrder.values()).pop() << 1n - context.variantMap.set(variant, [[sort, () => selector]]) + context.variantMap.set(variant, [[sort, fn]]) context.variantOrder.set(variant, sort) } diff --git a/tests/arbitrary-variants.test.js b/tests/arbitrary-variants.test.js index 1d75cfe86b8f..4006c0731392 100644 --- a/tests/arbitrary-variants.test.js +++ b/tests/arbitrary-variants.test.js @@ -132,3 +132,26 @@ test('using the important modifier', () => { `) }) }) + +test('at-rules', () => { + let config = { + content: [{ raw: html`
` }], + corePlugins: { preflight: false }, + } + + let input = css` + @tailwind base; + @tailwind components; + @tailwind utilities; + ` + + return run(input, config).then((result) => { + expect(result.css).toMatchFormattedCss(css` + ${defaults} + + .\[\&\>\*\]\:\!underline > * { + text-decoration-line: underline !important; + } + `) + }) +})