Home / File/ migrate-theme-to-var.test.ts — tailwindcss Source File

migrate-theme-to-var.test.ts — tailwindcss Source File

Architecture documentation for migrate-theme-to-var.test.ts, a typescript file in the tailwindcss codebase. 10 imports, 0 dependents.

File typescript UpgradeToolkit Codemods 10 imports 1 functions

Entity Profile

Dependency Diagram

graph LR
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612["migrate-theme-to-var.test.ts"]
  e7639b6d_2132_7e05_9498_c732c7517772["format-nodes.ts"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> e7639b6d_2132_7e05_9498_c732c7517772
  729a086c_18ec_2750_83e5_bdd730f8fa5e["formatNodes"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> 729a086c_18ec_2750_83e5_bdd730f8fa5e
  c550fc21_73bc_6946_0379_6439db07d05a["migrate-theme-to-var.ts"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> c550fc21_73bc_6946_0379_6439db07d05a
  36a33041_3344_f866_1e23_f035f7e8756f["migrateThemeToVar"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> 36a33041_3344_f866_1e23_f035f7e8756f
  ecf9faa2_4ccf_f16c_bb10_222be63faed0["sort-buckets.ts"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> ecf9faa2_4ccf_f16c_bb10_222be63faed0
  92a12a9f_b36d_4c66_d885_e04224081f21["sortBuckets"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> 92a12a9f_b36d_4c66_d885_e04224081f21
  92f2d961_72a4_d195_92d7_2e66972f8894["node"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> 92f2d961_72a4_d195_92d7_2e66972f8894
  211db6bb_9759_d0cf_acda_36d7f5733ce2["dedent"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> 211db6bb_9759_d0cf_acda_36d7f5733ce2
  ba54c7c3_7b1e_9984_bfef_a693a3df2d84["postcss"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> ba54c7c3_7b1e_9984_bfef_a693a3df2d84
  696bd648_5f24_1b59_8e8b_7a97a692869e["vitest"]
  0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 --> 696bd648_5f24_1b59_8e8b_7a97a692869e
  style 0c13c6dd_2cb9_954d_8cc6_359b1ce5d612 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import { __unstable__loadDesignSystem } from '@tailwindcss/node'
import dedent from 'dedent'
import postcss from 'postcss'
import { expect, it } from 'vitest'
import { formatNodes } from './format-nodes'
import { migrateThemeToVar } from './migrate-theme-to-var'
import { sortBuckets } from './sort-buckets'

const css = dedent

async function migrate(input: string) {
  return postcss()
    .use(
      migrateThemeToVar({
        designSystem: await __unstable__loadDesignSystem(`@import 'tailwindcss';`, {
          base: __dirname,
        }),
      }),
    )
    .use(sortBuckets())
    .use(formatNodes())
    .process(input, { from: expect.getState().testPath })
    .then((result) => result.css)
}

it('should migrate `theme(…)` to `var(…)`', async () => {
  expect(
    await migrate(css`
      @media theme(screens.sm) {
        .foo {
          background-color: theme(colors.red.900);
          color: theme(colors.red.900 / 75%);
          border-color: theme(colors.red.200/75%);
        }
      }
    `),
  ).toMatchInlineSnapshot(`
    "@media --theme(--breakpoint-sm) {
      .foo {
        background-color: var(--color-red-900);
        color: --theme(--color-red-900 / 75%);
        border-color: --theme(--color-red-200 / 75%);
      }
    }"
  `)
})

Subdomains

Functions

Frequently Asked Questions

What does migrate-theme-to-var.test.ts do?
migrate-theme-to-var.test.ts is a source file in the tailwindcss codebase, written in typescript. It belongs to the UpgradeToolkit domain, Codemods subdomain.
What functions are defined in migrate-theme-to-var.test.ts?
migrate-theme-to-var.test.ts defines 1 function(s): migrate.
What does migrate-theme-to-var.test.ts depend on?
migrate-theme-to-var.test.ts imports 10 module(s): dedent, format-nodes.ts, formatNodes, migrate-theme-to-var.ts, migrateThemeToVar, node, postcss, sort-buckets.ts, and 2 more.
Where is migrate-theme-to-var.test.ts in the architecture?
migrate-theme-to-var.test.ts is located at packages/@tailwindcss-upgrade/src/codemods/css/migrate-theme-to-var.test.ts (domain: UpgradeToolkit, subdomain: Codemods, directory: packages/@tailwindcss-upgrade/src/codemods/css).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free