Skip to content

Commit

Permalink
fix(shadcn): Support single quote formatted registry files (#4870)
Browse files Browse the repository at this point in the history
  • Loading branch information
bcorbold committed Sep 17, 2024
1 parent 0610830 commit ff442e6
Show file tree
Hide file tree
Showing 5 changed files with 45 additions and 9 deletions.
5 changes: 5 additions & 0 deletions .changeset/wise-cheetahs-report.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
---
"shadcn": patch
---

support tw prefixes for registry files with single quote formatting
16 changes: 8 additions & 8 deletions packages/shadcn/src/utils/transformers/transform-tw-prefix.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ export const transformTwPrefixes: Transformer = async ({
if (defaultClassNames) {
defaultClassNames.replaceWithText(
`"${applyPrefix(
defaultClassNames.getText()?.replace(/"/g, ""),
defaultClassNames.getText()?.replace(/"|'/g, ""),
config.tailwind.prefix
)}"`
)
Expand All @@ -46,7 +46,7 @@ export const transformTwPrefixes: Transformer = async ({
if (classNames) {
classNames?.replaceWithText(
`"${applyPrefix(
classNames.getText()?.replace(/"/g, ""),
classNames.getText()?.replace(/"|'/g, ""),
config.tailwind.prefix
)}"`
)
Expand All @@ -65,7 +65,7 @@ export const transformTwPrefixes: Transformer = async ({
if (value) {
value.replaceWithText(
`"${applyPrefix(
value.getText()?.replace(/"/g, ""),
value.getText()?.replace(/"|'/g, ""),
config.tailwind.prefix
)}"`
)
Expand All @@ -91,7 +91,7 @@ export const transformTwPrefixes: Transformer = async ({
.forEach((node) => {
node.replaceWithText(
`"${applyPrefix(
node.getText()?.replace(/"/g, ""),
node.getText()?.replace(/"|'/g, ""),
config.tailwind.prefix
)}"`
)
Expand All @@ -101,7 +101,7 @@ export const transformTwPrefixes: Transformer = async ({
if (node.isKind(SyntaxKind.StringLiteral)) {
node.replaceWithText(
`"${applyPrefix(
node.getText()?.replace(/"/g, ""),
node.getText()?.replace(/"|'/g, ""),
config.tailwind.prefix
)}"`
)
Expand Down Expand Up @@ -130,7 +130,7 @@ export const transformTwPrefixes: Transformer = async ({
.forEach((node) => {
node.replaceWithText(
`"${applyPrefix(
node.getText()?.replace(/"/g, ""),
node.getText()?.replace(/"|'/g, ""),
config.tailwind.prefix
)}"`
)
Expand All @@ -140,7 +140,7 @@ export const transformTwPrefixes: Transformer = async ({
if (arg.isKind(SyntaxKind.StringLiteral)) {
arg.replaceWithText(
`"${applyPrefix(
arg.getText()?.replace(/"/g, ""),
arg.getText()?.replace(/"|'/g, ""),
config.tailwind.prefix
)}"`
)
Expand All @@ -155,7 +155,7 @@ export const transformTwPrefixes: Transformer = async ({
if (classNames) {
classNames.replaceWithText(
`"${applyPrefix(
classNames.getText()?.replace(/"/g, ""),
classNames.getText()?.replace(/"|'/g, ""),
config.tailwind.prefix
)}"`
)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,14 @@ export function Foo() {
`;

exports[`transform tailwind prefix 4`] = `
"import * as React from "react"
export function Foo() {
return <div className={cn("tw-bg-background hover:tw-bg-muted", true && "tw-text-primary-foreground sm:focus:tw-text-accent-foreground")}>foo</div>
}
"
`;

exports[`transform tailwind prefix 5`] = `
"@tailwind base;
@tailwind components;
@tailwind utilities;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -251,7 +251,7 @@ const Input = React.forwardRef<HTMLInputElement, InputProps>(
<input
type={type}
className={cn(
"flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",
"flex h-10 w-full rounded-md border border-input bg-background px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium file:text-foreground placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50",
className
)}
ref={ref}
Expand Down
23 changes: 23 additions & 0 deletions packages/shadcn/test/utils/transform-tw-prefix.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,29 @@ export function Foo() {
})
).toMatchSnapshot()

expect(
await transform({
filename: "test.ts",
raw: `import * as React from "react"
export function Foo() {
return <div className={cn('bg-background hover:bg-muted', true && 'text-primary-foreground sm:focus:text-accent-foreground')}>foo</div>
}
`,
config: {
tailwind: {
baseColor: "stone",
cssVariables: false,
prefix: "tw-",
},
aliases: {
components: "@/components",
utils: "@/lib/utils",
},
},
baseColor: stone,
})
).toMatchSnapshot()

expect(
applyPrefixesCss(
"@tailwind base;\n@tailwind components;\n@tailwind utilities;\n \n@layer base {\n :root {\n --background: 0 0% 100%;\n --foreground: 224 71.4% 4.1%;\n \n --muted: 220 14.3% 95.9%;\n --muted-foreground: 220 8.9% 46.1%;\n \n --popover: 0 0% 100%;\n --popover-foreground: 224 71.4% 4.1%;\n \n --card: 0 0% 100%;\n --card-foreground: 224 71.4% 4.1%;\n \n --border: 220 13% 91%;\n --input: 220 13% 91%;\n \n --primary: 220.9 39.3% 11%;\n --primary-foreground: 210 20% 98%;\n \n --secondary: 220 14.3% 95.9%;\n --secondary-foreground: 220.9 39.3% 11%;\n \n --accent: 220 14.3% 95.9%;\n --accent-foreground: 220.9 39.3% 11%;\n \n --destructive: 0 84.2% 60.2%;\n --destructive-foreground: 210 20% 98%;\n \n --ring: 217.9 10.6% 64.9%;\n \n --radius: 0.5rem;\n }\n \n .dark {\n --background: 224 71.4% 4.1%;\n --foreground: 210 20% 98%;\n \n --muted: 215 27.9% 16.9%;\n --muted-foreground: 217.9 10.6% 64.9%;\n \n --popover: 224 71.4% 4.1%;\n --popover-foreground: 210 20% 98%;\n \n --card: 224 71.4% 4.1%;\n --card-foreground: 210 20% 98%;\n \n --border: 215 27.9% 16.9%;\n --input: 215 27.9% 16.9%;\n \n --primary: 210 20% 98%;\n --primary-foreground: 220.9 39.3% 11%;\n \n --secondary: 215 27.9% 16.9%;\n --secondary-foreground: 210 20% 98%;\n \n --accent: 215 27.9% 16.9%;\n --accent-foreground: 210 20% 98%;\n \n --destructive: 0 62.8% 30.6%;\n --destructive-foreground: 0 85.7% 97.3%;\n \n --ring: 215 27.9% 16.9%;\n }\n}\n \n@layer base {\n * {\n @apply border-border;\n }\n body {\n @apply bg-background text-foreground;\n }\n}",
Expand Down

0 comments on commit ff442e6

Please sign in to comment.