From 32cf4af2a4f131438289984f26c38fa150b48226 Mon Sep 17 00:00:00 2001 From: Adam Wathan Date: Wed, 6 Nov 2024 10:51:34 -0500 Subject: [PATCH] Rename `--transition-timing-function-*` variables to `--ease-*` (#14886) This PR renames the `--transition-timing-function-*` theme variables to `--ease-*` to more closely match the utility names and be a bit more terse in general. ```diff @theme { - --transition-timing-function-in: cubic-bezier(0.4, 0, 1, 1); - --transition-timing-function-out: cubic-bezier(0, 0, 0.2, 1); - --transition-timing-function-in-out: cubic-bezier(0.4, 0, 0.2, 1); + --ease-in: cubic-bezier(0.4, 0, 1, 1); + --ease-out: cubic-bezier(0, 0, 0.2, 1); + --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1); } ``` This is part of a bigger set of changes where we're renaming other theme variables as well with the same goals, since many existing theme variables like `--shadow-*` and `--radius-*` are already not using the explicit CSS property name. --------- Co-authored-by: Adam Wathan <4323180+adamwathan@users.noreply.github.com> --- CHANGELOG.md | 1 + .../src/__snapshots__/index.test.ts.snap | 6 +++--- .../src/__snapshots__/index.test.ts.snap | 6 +++--- .../src/compat/apply-config-to-theme.test.ts | 5 +++++ .../src/compat/apply-config-to-theme.ts | 1 + packages/tailwindcss/src/css-functions.test.ts | 3 +-- packages/tailwindcss/src/utilities.test.ts | 16 ++++++++-------- packages/tailwindcss/src/utilities.ts | 2 +- packages/tailwindcss/theme.css | 6 +++--- 9 files changed, 26 insertions(+), 20 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ba224d8ab740..e39491b8aebf 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -43,6 +43,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Remove default `--spacing-*` scale in favor of `--spacing` multiplier ([#14857](https://github.com/tailwindlabs/tailwindcss/pull/14857)) - Remove `var(…)` fallbacks from theme values in utilities ([#14881](https://github.com/tailwindlabs/tailwindcss/pull/14881)) - Remove static `font-weight` utilities and add `--font-weight-*` values to the default theme ([#14883](https://github.com/tailwindlabs/tailwindcss/pull/14883)) +- Rename `--transition-timing-function-*` variables to `--ease-*` ([#14886](https://github.com/tailwindlabs/tailwindcss/pull/14886)) ## [4.0.0-alpha.31] - 2024-10-29 diff --git a/packages/@tailwindcss-postcss/src/__snapshots__/index.test.ts.snap b/packages/@tailwindcss-postcss/src/__snapshots__/index.test.ts.snap index a0bf3c3b7607..b60913a8bb1c 100644 --- a/packages/@tailwindcss-postcss/src/__snapshots__/index.test.ts.snap +++ b/packages/@tailwindcss-postcss/src/__snapshots__/index.test.ts.snap @@ -366,9 +366,9 @@ exports[`\`@import 'tailwindcss'\` is replaced with the generated CSS 1`] = ` --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; - --transition-timing-function-in: cubic-bezier(.4, 0, 1, 1); - --transition-timing-function-out: cubic-bezier(0, 0, .2, 1); - --transition-timing-function-in-out: cubic-bezier(.4, 0, .2, 1); + --ease-in: cubic-bezier(.4, 0, 1, 1); + --ease-out: cubic-bezier(0, 0, .2, 1); + --ease-in-out: cubic-bezier(.4, 0, .2, 1); } } diff --git a/packages/tailwindcss/src/__snapshots__/index.test.ts.snap b/packages/tailwindcss/src/__snapshots__/index.test.ts.snap index a42259ede29e..78e0ab7a831a 100644 --- a/packages/tailwindcss/src/__snapshots__/index.test.ts.snap +++ b/packages/tailwindcss/src/__snapshots__/index.test.ts.snap @@ -365,9 +365,9 @@ exports[`compiling CSS > \`@tailwind utilities\` is replaced by utilities using --perspective-normal: 500px; --perspective-midrange: 800px; --perspective-distant: 1200px; - --transition-timing-function-in: cubic-bezier(.4, 0, 1, 1); - --transition-timing-function-out: cubic-bezier(0, 0, .2, 1); - --transition-timing-function-in-out: cubic-bezier(.4, 0, .2, 1); + --ease-in: cubic-bezier(.4, 0, 1, 1); + --ease-out: cubic-bezier(0, 0, .2, 1); + --ease-in-out: cubic-bezier(.4, 0, .2, 1); } .w-4 { diff --git a/packages/tailwindcss/src/compat/apply-config-to-theme.test.ts b/packages/tailwindcss/src/compat/apply-config-to-theme.test.ts index df71357c3777..452e3e4fea4d 100644 --- a/packages/tailwindcss/src/compat/apply-config-to-theme.test.ts +++ b/packages/tailwindcss/src/compat/apply-config-to-theme.test.ts @@ -56,6 +56,10 @@ test('config values can be merged into the theme', () => { '0.5': '60%', '100%': '100%', }, + + transitionTimingFunction: { + fast: 'cubic-bezier(0, 0.55, 0.45, 1)', + }, }, }, base: '/root', @@ -83,6 +87,7 @@ test('config values can be merged into the theme', () => { expect(theme.resolve('1/2', ['--width'])).toEqual('60%') expect(theme.resolve('0.5', ['--width'])).toEqual('60%') expect(theme.resolve('100%', ['--width'])).toEqual('100%') + expect(theme.resolve('fast', ['--ease'])).toEqual('cubic-bezier(0, 0.55, 0.45, 1)') }) test('will reset default theme values with overwriting theme values', () => { diff --git a/packages/tailwindcss/src/compat/apply-config-to-theme.ts b/packages/tailwindcss/src/compat/apply-config-to-theme.ts index 88f6655dd0d2..b59404bb32da 100644 --- a/packages/tailwindcss/src/compat/apply-config-to-theme.ts +++ b/packages/tailwindcss/src/compat/apply-config-to-theme.ts @@ -133,6 +133,7 @@ export function keyPathToCssProperty(path: string[]) { if (path[0] === 'borderRadius') path[0] = 'radius' if (path[0] === 'boxShadow') path[0] = 'shadow' if (path[0] === 'animation') path[0] = 'animate' + if (path[0] === 'transitionTimingFunction') path[0] = 'ease' if (path[0] === 'fontFamily') path[0] = 'font' for (let part of path) { diff --git a/packages/tailwindcss/src/css-functions.test.ts b/packages/tailwindcss/src/css-functions.test.ts index cd7820b49aae..40f1d797fb92 100644 --- a/packages/tailwindcss/src/css-functions.test.ts +++ b/packages/tailwindcss/src/css-functions.test.ts @@ -618,11 +618,10 @@ describe('theme function', () => { 'ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji"', ], ['width.xs', '20rem'], - ['transition.timing.function.in.out', 'cubic-bezier(.4, 0, .2, 1)'], + ['transitionTimingFunction.in-out', 'cubic-bezier(.4, 0, .2, 1)'], ['backgroundColor.red.500', 'oklch(.637 .237 25.331)'], ])('theme(%s) → %s', async (value, result) => { let defaultTheme = await fs.readFile(path.join(__dirname, '..', 'theme.css'), 'utf8') - let compiled = await compileCss(css` ${defaultTheme} .custom { diff --git a/packages/tailwindcss/src/utilities.test.ts b/packages/tailwindcss/src/utilities.test.ts index e904549b976d..8187950dc0e0 100644 --- a/packages/tailwindcss/src/utilities.test.ts +++ b/packages/tailwindcss/src/utilities.test.ts @@ -13801,8 +13801,8 @@ test('ease', async () => { await compileCss( css` @theme { - --transition-timing-function-in: cubic-bezier(0.4, 0, 1, 1); - --transition-timing-function-out: cubic-bezier(0, 0, 0.2, 1); + --ease-in: cubic-bezier(0.4, 0, 1, 1); + --ease-out: cubic-bezier(0, 0, 0.2, 1); } @tailwind utilities; `, @@ -13810,8 +13810,8 @@ test('ease', async () => { ), ).toMatchInlineSnapshot(` ":root { - --transition-timing-function-in: cubic-bezier(.4, 0, 1, 1); - --transition-timing-function-out: cubic-bezier(0, 0, .2, 1); + --ease-in: cubic-bezier(.4, 0, 1, 1); + --ease-out: cubic-bezier(0, 0, .2, 1); } .ease-\\[var\\(--value\\)\\] { @@ -13820,13 +13820,13 @@ test('ease', async () => { } .ease-in { - --tw-ease: var(--transition-timing-function-in); - transition-timing-function: var(--transition-timing-function-in); + --tw-ease: var(--ease-in); + transition-timing-function: var(--ease-in); } .ease-out { - --tw-ease: var(--transition-timing-function-out); - transition-timing-function: var(--transition-timing-function-out); + --tw-ease: var(--ease-out); + transition-timing-function: var(--ease-out); } @supports (-moz-orient: inline) { diff --git a/packages/tailwindcss/src/utilities.ts b/packages/tailwindcss/src/utilities.ts index 384028365b57..63d1033d5079 100644 --- a/packages/tailwindcss/src/utilities.ts +++ b/packages/tailwindcss/src/utilities.ts @@ -3539,7 +3539,7 @@ export function createUtilities(theme: Theme) { ['transition-timing-function', 'linear'], ]) functionalUtility('ease', { - themeKeys: ['--transition-timing-function'], + themeKeys: ['--ease'], handle: (value) => [ transitionTimingFunctionProperty(), decl('--tw-ease', value), diff --git a/packages/tailwindcss/theme.css b/packages/tailwindcss/theme.css index 1f6219b0abdb..f1339f6a4b79 100644 --- a/packages/tailwindcss/theme.css +++ b/packages/tailwindcss/theme.css @@ -421,9 +421,9 @@ --perspective-distant: 1200px; /* Transition timing functions */ - --transition-timing-function-in: cubic-bezier(0.4, 0, 1, 1); - --transition-timing-function-out: cubic-bezier(0, 0, 0.2, 1); - --transition-timing-function-in-out: cubic-bezier(0.4, 0, 0.2, 1); + --ease-in: cubic-bezier(0.4, 0, 1, 1); + --ease-out: cubic-bezier(0, 0, 0.2, 1); + --ease-in-out: cubic-bezier(0.4, 0, 0.2, 1); @keyframes spin { to {