Skip to content

Commit

Permalink
Polish matchVariant API (#9313)
Browse files Browse the repository at this point in the history
* convert the `matchVariant` to look more like `addVariant`

With the biggest difference that the `matchVariant` will have a callback
function that receives the current value of the variant.

* use object as argument for `matchVariant` callback

This will allow us to add more properties in the future if needed
without breaking changes.

- This is a breaking change: `(value) => ...` -> `({ value, other }) => ...`
- This is **not** a breaking change: `({ value }) => ...` -> `({ value, other }) => ...`

* add types for `matchVariant`
  • Loading branch information
RobinMalfait authored Sep 16, 2022
1 parent be429b7 commit 4fddd2d
Show file tree
Hide file tree
Showing 3 changed files with 28 additions and 45 deletions.
20 changes: 9 additions & 11 deletions src/lib/setupContextUtils.js
Original file line number Diff line number Diff line change
Expand Up @@ -500,18 +500,16 @@ function buildPluginApi(tailwindConfig, context, { variantList, variantMap, offs
}

if (flagEnabled(tailwindConfig, 'matchVariant')) {
api.matchVariant = function (variants, options) {
for (let variant in variants) {
for (let [k, v] of Object.entries(options?.values ?? {})) {
api.addVariant(`${variant}-${k}`, variants[variant](v))
}

api.addVariant(
variant,
Object.assign(({ args }) => variants[variant](args), { [MATCH_VARIANT]: true }),
options
)
api.matchVariant = function (variant, variantFn, options) {
for (let [key, value] of Object.entries(options?.values ?? {})) {
api.addVariant(`${variant}-${key}`, variantFn({ value }))
}

api.addVariant(
variant,
Object.assign(({ args }) => variantFn({ value: args }), { [MATCH_VARIANT]: true }),
options
)
}
}

Expand Down
52 changes: 18 additions & 34 deletions tests/match-variants.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,7 @@ test('partial arbitrary variants', () => {
corePlugins: { preflight: false },
plugins: [
({ matchVariant }) => {
matchVariant({
potato: (flavor) => `.potato-${flavor} &`,
})
matchVariant('potato', ({ value: flavor }) => `.potato-${flavor} &`)
},
],
}
Expand Down Expand Up @@ -47,9 +45,7 @@ test('partial arbitrary variants with at-rules', () => {
corePlugins: { preflight: false },
plugins: [
({ matchVariant }) => {
matchVariant({
potato: (flavor) => `@media (potato: ${flavor})`,
})
matchVariant('potato', ({ value: flavor }) => `@media (potato: ${flavor})`)
},
],
}
Expand Down Expand Up @@ -86,9 +82,7 @@ test('partial arbitrary variants with at-rules and placeholder', () => {
corePlugins: { preflight: false },
plugins: [
({ matchVariant }) => {
matchVariant({
potato: (flavor) => `@media (potato: ${flavor}) { &:potato }`,
})
matchVariant('potato', ({ value: flavor }) => `@media (potato: ${flavor}) { &:potato }`)
},
],
}
Expand Down Expand Up @@ -125,17 +119,12 @@ test('partial arbitrary variants with default values', () => {
corePlugins: { preflight: false },
plugins: [
({ matchVariant }) => {
matchVariant(
{
tooltip: (side) => `&${side}`,
matchVariant('tooltip', ({ value: side }) => `&${side}`, {
values: {
bottom: '[data-location="bottom"]',
top: '[data-location="top"]',
},
{
values: {
bottom: '[data-location="bottom"]',
top: '[data-location="top"]',
},
}
)
})
},
],
}
Expand Down Expand Up @@ -170,19 +159,14 @@ test('matched variant values maintain the sort order they are registered in', ()
corePlugins: { preflight: false },
plugins: [
({ matchVariant }) => {
matchVariant(
{
alphabet: (side) => `&${side}`,
matchVariant('alphabet', ({ value: side }) => `&${side}`, {
values: {
a: '[data-value="a"]',
b: '[data-value="b"]',
c: '[data-value="c"]',
d: '[data-value="d"]',
},
{
values: {
a: '[data-value="a"]',
b: '[data-value="b"]',
c: '[data-value="c"]',
d: '[data-value="d"]',
},
}
)
})
},
],
}
Expand Down Expand Up @@ -223,9 +207,9 @@ test('matchVariant can return an array of format strings from the function', ()
corePlugins: { preflight: false },
plugins: [
({ matchVariant }) => {
matchVariant({
test: (selector) => selector.split(',').map((selector) => `&.${selector} > *`),
})
matchVariant('test', ({ value: selector }) =>
selector.split(',').map((selector) => `&.${selector} > *`)
)
},
],
}
Expand Down
1 change: 1 addition & 0 deletions types/config.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -291,6 +291,7 @@ export interface PluginAPI {
addBase(base: CSSRuleObject | CSSRuleObject[]): void
// for registering custom variants
addVariant(name: string, definition: string | string[] | (() => string) | (() => string)[]): void
matchVariant(name: string, cb: (options: { value: string }) => string | string[]): void
// for looking up values in the user’s theme configuration
theme: <TDefaultValue = Config['theme']>(
path?: string,
Expand Down

0 comments on commit 4fddd2d

Please sign in to comment.