hghcn 3.6.17 → 3.6.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -1,67 +1,67 @@
1
1
  #!/usr/bin/env node
2
- import {b as b$1,a as a$1}from'./chunk-SSXFFJQN.js';import {a,O,n,R,_ as _$1,s,d,Y,P,p,i,q,j as j$1,t,b,ca,ea,g,h,e,f,r,N,c as c$1,ba,K,ka,M,la,ha,fa,ia,J as J$1,L,Q,ma,ja,S as S$1,k,da,o as o$1,F,W as W$1,z as z$2,X,m,T,l,U,G,I,H as H$1,V}from'./chunk-I3JXSMK6.js';export{ha as fetchTree,ia as getItemTargetPath,la as getPreset,ka as getPresets,aa as getRegistriesConfig,ja as getRegistriesIndex,Z as getRegistry,fa as getRegistryBaseColor,ea as getRegistryBaseColors,da as getRegistryIcons,_ as getRegistryItems,ca as getRegistryStyles,ba as getShadcnRegistryIndex,$ as resolveRegistryItems,ga as resolveTree}from'./chunk-I3JXSMK6.js';import {c,o,n as n$1}from'./chunk-WKG3W635.js';import'./chunk-PMFK2ZSQ.js';import'./chunk-BFNVF2P5.js';import*as j from'path';import j__default,{join}from'path';import S from'fs-extra';import {existsSync,promises}from'fs';import x from'postcss';import Zr from'postcss/lib/at-rule';import lt,{z as z$1}from'zod';import {execa}from'execa';import Te from'prompts';import {SyntaxKind,Project,ScriptKind,VariableDeclarationKind}from'ts-morph';import Ze,{tmpdir}from'os';import {Command}from'commander';import lr from'deepmerge';import*as J from'fs/promises';import st from'dedent';import br from'open';import {diffLines}from'diff';import {StdioServerTransport}from'@modelcontextprotocol/sdk/server/stdio.js';import {randomBytes}from'crypto';import $n from'fast-glob';async function Jt(e){let t$1={};if(!S.existsSync(e.cwd)||!S.existsSync(j__default.resolve(e.cwd,"package.json")))return t$1["1"]=true,{errors:t$1,projectInfo:null};let r=t("Preflight checks.",{silent:e.silent}).start();S.existsSync(j__default.resolve(e.cwd,"components.json"))&&!e.force&&(r?.fail(),s.break(),s.error(`A ${d.info("components.json")} file already exists at ${d.info(e.cwd)}.
2
+ import {b as b$1,a as a$1}from'./chunk-SSXFFJQN.js';import {a,O,n,R,_,s,d,Y,P,p,i,q,j as j$1,t,b,ca,ea,g,h,e,f,r,N,c as c$1,ba,K,ka,M as M$1,la,ha,fa,ia,J as J$1,L,Q,ma,ja,S,k,da,o as o$1,F,W as W$1,z as z$1,X,m,T,l,U,G,I,H as H$1,V}from'./chunk-I3JXSMK6.js';export{ha as fetchTree,ia as getItemTargetPath,la as getPreset,ka as getPresets,aa as getRegistriesConfig,ja as getRegistriesIndex,Z as getRegistry,fa as getRegistryBaseColor,ea as getRegistryBaseColors,da as getRegistryIcons,_ as getRegistryItems,ca as getRegistryStyles,ba as getShadcnRegistryIndex,$ as resolveRegistryItems,ga as resolveTree}from'./chunk-I3JXSMK6.js';import {c,o,n as n$1}from'./chunk-WKG3W635.js';import'./chunk-PMFK2ZSQ.js';import'./chunk-BFNVF2P5.js';import*as j from'path';import j__default,{join}from'path';import v from'fs-extra';import {existsSync,promises}from'fs';import x from'postcss';import Qr from'postcss/lib/at-rule';import at,{z}from'zod';import {execa}from'execa';import Oe from'prompts';import {SyntaxKind,Project,ScriptKind,VariableDeclarationKind}from'ts-morph';import Qe,{tmpdir}from'os';import {Command}from'commander';import cr from'deepmerge';import*as J from'fs/promises';import nt from'dedent';import wr from'open';import {diffLines}from'diff';import {StdioServerTransport}from'@modelcontextprotocol/sdk/server/stdio.js';import {randomBytes}from'crypto';import $n from'fast-glob';async function Ut(e){let t$1={};if(!v.existsSync(e.cwd)||!v.existsSync(j__default.resolve(e.cwd,"package.json")))return t$1["1"]=true,{errors:t$1,projectInfo:null};let r=t("Preflight checks.",{silent:e.silent}).start();v.existsSync(j__default.resolve(e.cwd,"components.json"))&&!e.force&&(r?.fail(),s.break(),s.error(`A ${d.info("components.json")} file already exists at ${d.info(e.cwd)}.
3
3
  To start over, remove the ${d.info("components.json")} file and run ${d.info("init")} again.`),s.break(),process.exit(1)),r?.succeed();let i=t("Verifying framework.",{silent:e.silent}).start(),n=await p(e.cwd);return (!n||n?.framework.name==="manual")&&(t$1["7"]=true,i?.fail(),s.break(),n?.framework.links.installation&&s.error(`We could not detect a supported framework at ${d.info(e.cwd)}.
4
4
  Visit ${d.info(n?.framework.links.installation)} to manually configure your project.
5
- Once configured, you can use the cli to add components.`),s.break(),process.exit(1)),i?.succeed(`Verifying framework. Found ${d.info(n.framework.label)}.`),{errors:t$1,projectInfo:n}}function Yt(e,t){if(e.includes("\0"))return false;let r;try{r=e;let u="";for(;r!==u&&r.includes("%");)u=r,r=decodeURIComponent(r);}catch{return false}let i=j__default.normalize(r.replace(/\\/g,"/")),n=j__default.normalize(t),o=u=>u.replace(/\[\.\.\..*?\]/g,"").includes("..");if(o(i)||o(r)||o(e))return false;let a=u=>u.replace(/\[\.\.\..*?\]/g,""),s=a(e),c=a(r);if([/\.\.[\/\\]/,/[\/\\]\.\./,/\.\./,/\.\.%/,/\x00/,/[\x01-\x1f]/].some(u=>u.test(s)||u.test(c))||(e.includes("~")||r.includes("~"))&&(e.includes("../")||r.includes("../")))return false;if(/^[a-zA-Z]:[\/\\]/.test(r))return process.platform==="win32"?r.toLowerCase().startsWith(t.toLowerCase()):false;if(j__default.isAbsolute(i))return i.startsWith(n+j__default.sep);let p=j__default.resolve(n,i);return p.startsWith(n+j__default.sep)||p===n}async function Ye(e,t$1,r){if(!t$1.resolvedPaths.tailwindCss||!e||Object.keys(e).length===0)return;r={silent:false,...r};let i=t$1.resolvedPaths.tailwindCss,n=j__default.relative(t$1.resolvedPaths.cwd,i),o=t(`Updating ${d.info(n)}`,{silent:r.silent}).start(),a=await promises.readFile(i,"utf8"),s=await Hr(a,e);await promises.writeFile(i,s,"utf8"),o.succeed();}async function Hr(e,t){let r=[Xr(t)],i=await x(r).process(e,{from:void 0}),n=i.css,o=i.root;if(o.nodes&&o.nodes.length>0){let a=o.nodes[o.nodes.length-1];a.type==="atrule"&&!a.nodes&&!n.trimEnd().endsWith(";")&&(n=n.trimEnd()+";");}return n=n.replace(/\/\* ---break--- \*\//g,""),n=n.replace(/(\n\s*\n)+/g,`
5
+ Once configured, you can use the cli to add components.`),s.break(),process.exit(1)),i?.succeed(`Verifying framework. Found ${d.info(n.framework.label)}.`),{errors:t$1,projectInfo:n}}function Gt(e,t){if(e.includes("\0"))return false;let r;try{r=e;let u="";for(;r!==u&&r.includes("%");)u=r,r=decodeURIComponent(r);}catch{return false}let i=j__default.normalize(r.replace(/\\/g,"/")),n=j__default.normalize(t),o=u=>u.replace(/\[\.\.\..*?\]/g,"").includes("..");if(o(i)||o(r)||o(e))return false;let a=u=>u.replace(/\[\.\.\..*?\]/g,""),s=a(e),c=a(r);if([/\.\.[\/\\]/,/[\/\\]\.\./,/\.\./,/\.\.%/,/\x00/,/[\x01-\x1f]/].some(u=>u.test(s)||u.test(c))||(e.includes("~")||r.includes("~"))&&(e.includes("../")||r.includes("../")))return false;if(/^[a-zA-Z]:[\/\\]/.test(r))return process.platform==="win32"?r.toLowerCase().startsWith(t.toLowerCase()):false;if(j__default.isAbsolute(i))return i.startsWith(n+j__default.sep);let p=j__default.resolve(n,i);return p.startsWith(n+j__default.sep)||p===n}async function Je(e,t$1,r){if(!t$1.resolvedPaths.tailwindCss||!e||Object.keys(e).length===0)return;r={silent:false,...r};let i=t$1.resolvedPaths.tailwindCss,n=j__default.relative(t$1.resolvedPaths.cwd,i),o=t(`Updating ${d.info(n)}`,{silent:r.silent}).start(),a=await promises.readFile(i,"utf8"),s=await qr(a,e);await promises.writeFile(i,s,"utf8"),o.succeed();}async function qr(e,t){let r=[Hr(t)],i=await x(r).process(e,{from:void 0}),n=i.css,o=i.root;if(o.nodes&&o.nodes.length>0){let a=o.nodes[o.nodes.length-1];a.type==="atrule"&&!a.nodes&&!n.trimEnd().endsWith(";")&&(n=n.trimEnd()+";");}return n=n.replace(/\/\* ---break--- \*\//g,""),n=n.replace(/(\n\s*\n)+/g,`
6
6
 
7
- `),n=n.trimEnd(),n}function Xr(e){return {postcssPlugin:"update-css",Once(t){for(let[r,i]of Object.entries(e))if(r.startsWith("@")){let n=r.match(/@([a-zA-Z-]+)\s*(.*)/);if(!n)continue;let[,o,a]=n;if(o==="import"){if(!t.nodes?.find(c=>c.type==="atrule"&&c.name==="import"&&c.params===a)){let c=x.atRule({name:"import",params:a,raws:{semicolon:true}}),m=t.nodes?.filter(l=>l.type==="atrule"&&l.name==="import");if(m&&m.length>0){let l=m[m.length-1];c.raws.before=`
7
+ `),n=n.trimEnd(),n}function Hr(e){return {postcssPlugin:"update-css",Once(t){for(let[r,i]of Object.entries(e))if(r.startsWith("@")){let n=r.match(/@([a-zA-Z-]+)\s*(.*)/);if(!n)continue;let[,o,a]=n;if(o==="import"){if(!t.nodes?.find(c=>c.type==="atrule"&&c.name==="import"&&c.params===a)){let c=x.atRule({name:"import",params:a,raws:{semicolon:true}}),m=t.nodes?.filter(l=>l.type==="atrule"&&l.name==="import");if(m&&m.length>0){let l=m[m.length-1];c.raws.before=`
8
8
  `,t.insertAfter(l,c);}else !t.nodes||t.nodes.length,c.raws.before="",t.prepend(c);}}else if(o==="plugin"){let s=a;a&&!a.startsWith('"')&&!a.startsWith("'")&&(s=`"${a}"`);let c=l=>l.startsWith('"')&&l.endsWith('"')||l.startsWith("'")&&l.endsWith("'")?l.slice(1,-1):l;if(!t.nodes?.find(l=>l.type!=="atrule"||l.name!=="plugin"?false:c(l.params)===c(a))){let l=x.atRule({name:"plugin",params:s,raws:{semicolon:true,before:`
9
- `}}),p=t.nodes?.filter(h=>h.type==="atrule"&&h.name==="import"),u=t.nodes?.filter(h=>h.type==="atrule"&&h.name==="plugin");if(u&&u.length>0){let h=u[u.length-1];t.insertAfter(h,l);}else if(p&&p.length>0){let h=p[p.length-1];t.insertAfter(h,l),t.insertBefore(l,x.comment({text:"---break---"})),t.insertAfter(l,x.comment({text:"---break---"}));}else t.prepend(l),t.insertBefore(l,x.comment({text:"---break---"})),t.insertAfter(l,x.comment({text:"---break---"}));}}else if(typeof i=="object"&&Object.keys(i).length===0){if(!t.nodes?.find(c=>c.type==="atrule"&&c.name===o&&c.params===a)){let c=x.atRule({name:o,params:a,raws:{semicolon:true}});t.append(c),t.insertBefore(c,x.comment({text:"---break---"}));}}else if(o==="keyframes"){let s=t.nodes?.find(l=>l.type==="atrule"&&l.name==="theme"&&l.params==="inline");s||(s=x.atRule({name:"theme",params:"inline",raws:{semicolon:true,between:" ",before:`
9
+ `}}),p=t.nodes?.filter(g=>g.type==="atrule"&&g.name==="import"),u=t.nodes?.filter(g=>g.type==="atrule"&&g.name==="plugin");if(u&&u.length>0){let g=u[u.length-1];t.insertAfter(g,l);}else if(p&&p.length>0){let g=p[p.length-1];t.insertAfter(g,l),t.insertBefore(l,x.comment({text:"---break---"})),t.insertAfter(l,x.comment({text:"---break---"}));}else t.prepend(l),t.insertBefore(l,x.comment({text:"---break---"})),t.insertAfter(l,x.comment({text:"---break---"}));}}else if(typeof i=="object"&&Object.keys(i).length===0){if(!t.nodes?.find(c=>c.type==="atrule"&&c.name===o&&c.params===a)){let c=x.atRule({name:o,params:a,raws:{semicolon:true}});t.append(c),t.insertBefore(c,x.comment({text:"---break---"}));}}else if(o==="keyframes"){let s=t.nodes?.find(l=>l.type==="atrule"&&l.name==="theme"&&l.params==="inline");s||(s=x.atRule({name:"theme",params:"inline",raws:{semicolon:true,between:" ",before:`
10
10
  `}}),t.append(s),t.insertBefore(s,x.comment({text:"---break---"})));let c=s.nodes?.find(l=>l.type==="atrule"&&l.name==="keyframes"&&l.params===a),m;if(c?(m=x.atRule({name:"keyframes",params:a,raws:{semicolon:true,between:" ",before:`
11
11
  `}}),c.replaceWith(m)):(m=x.atRule({name:"keyframes",params:a,raws:{semicolon:true,between:" ",before:`
12
12
  `}}),s.append(m)),typeof i=="object")for(let[l,p]of Object.entries(i))te(m,l,p);}else if(o==="utility"){let s=t.nodes?.find(c=>c.type==="atrule"&&c.name===o&&c.params===a);if(s){if(typeof i=="object")for(let[c,m]of Object.entries(i))if(typeof m=="string"){let l=s.nodes?.find(u=>u.type==="decl"&&u.prop===c),p=x.decl({prop:c,value:m,raws:{semicolon:true,before:`
13
13
  `}});l?l.replaceWith(p):s.append(p);}else typeof m=="object"&&te(s,c,m);}else {let c=x.atRule({name:o,params:a,raws:{semicolon:true,between:" ",before:`
14
14
  `}});if(t.append(c),t.insertBefore(c,x.comment({text:"---break---"})),typeof i=="object")for(let[m,l]of Object.entries(i))if(typeof l=="string"){let p=x.decl({prop:m,value:l,raws:{semicolon:true,before:`
15
- `}});c.append(p);}else typeof l=="object"&&te(c,m,l);}}else o==="property"?te(t,r,i):qt(t,o,a,i);}else te(t,r,i);}}}function qt(e,t,r,i){let n=e.nodes?.find(o=>o.type==="atrule"&&o.name===t&&o.params===r);if(n||(n=x.atRule({name:t,params:r,raws:{semicolon:true,between:" ",before:`
16
- `}}),e.append(n),e.insertBefore(n,x.comment({text:"---break---"}))),typeof i=="object")for(let[o,a]of Object.entries(i))if(o.startsWith("@")){let s=o.match(/@([a-zA-Z-]+)\s*(.*)/);if(s){let[,c,m]=s;qt(n,c,m,a);}}else te(n,o,a);else if(typeof i=="string")try{let a=x.parse(`.temp{${i}}`).first;if(a&&a.nodes){let s=x.rule({selector:"temp",raws:{semicolon:!0,between:" ",before:`
15
+ `}});c.append(p);}else typeof l=="object"&&te(c,m,l);}}else o==="property"?te(t,r,i):Kt(t,o,a,i);}else te(t,r,i);}}}function Kt(e,t,r,i){let n=e.nodes?.find(o=>o.type==="atrule"&&o.name===t&&o.params===r);if(n||(n=x.atRule({name:t,params:r,raws:{semicolon:true,between:" ",before:`
16
+ `}}),e.append(n),e.insertBefore(n,x.comment({text:"---break---"}))),typeof i=="object")for(let[o,a]of Object.entries(i))if(o.startsWith("@")){let s=o.match(/@([a-zA-Z-]+)\s*(.*)/);if(s){let[,c,m]=s;Kt(n,c,m,a);}}else te(n,o,a);else if(typeof i=="string")try{let a=x.parse(`.temp{${i}}`).first;if(a&&a.nodes){let s=x.rule({selector:"temp",raws:{semicolon:!0,between:" ",before:`
17
17
  `}});a.nodes.forEach(c=>{if(c.type==="decl"){let m=c.clone();m.raws.before=`
18
18
  `,s.append(m);}}),s.nodes?.length&&n.append(s);}}catch(o){throw console.error("Error parsing at-rule content:",i,o),o}}function te(e,t,r){let i=e.nodes?.find(n=>n.type==="rule"&&n.selector===t);if(i||(i=x.rule({selector:t,raws:{semicolon:true,between:" ",before:`
19
19
  `}}),e.append(i)),typeof r=="object"){for(let[n,o]of Object.entries(r))if(n.startsWith("@")&&typeof o=="object"&&o!==null&&Object.keys(o).length===0){let a=n.match(/@([a-zA-Z-]+)\s*(.*)/);if(a){let[,s,c]=a,m=x.atRule({name:s,params:c,raws:{semicolon:true,before:`
20
20
  `}});i.append(m);}}else if(typeof o=="string"){let a=x.decl({prop:n,value:o,raws:{semicolon:true,before:`
21
21
  `}}),s=i.nodes?.find(c=>c.type==="decl"&&c.prop===n);s?s.replaceWith(a):i.append(a);}else if(typeof o=="object"){let a=n.startsWith("&")?t.replace(/^([^:]+)/,`$1${n.substring(1)}`):n;te(e,a,o);}}else if(typeof r=="string")try{let o=x.parse(`.temp{${r}}`).first;o&&o.nodes&&o.nodes.forEach(a=>{if(a.type==="decl"){let s=a.clone();s.raws.before=`
22
- `,i?.append(s);}});}catch(n){throw console.error("Error parsing rule content:",t,r,n),n}}async function Ke(e,t$1,r){if(!t$1.resolvedPaths.tailwindCss||!Object.keys(e??{}).length)return;r={cleanupDefaultNextStyles:false,silent:false,tailwindVersion:"v3",overwriteCssVars:false,initIndex:true,...r};let i=t$1.resolvedPaths.tailwindCss,n=j__default.relative(t$1.resolvedPaths.cwd,i),o=t(`Updating CSS variables in ${d.info(n)}`,{silent:r.silent}).start(),a=await promises.readFile(i,"utf8"),s=await ei(a,e??{},t$1,{cleanupDefaultNextStyles:r.cleanupDefaultNextStyles,tailwindVersion:r.tailwindVersion,tailwindConfig:r.tailwindConfig,overwriteCssVars:r.overwriteCssVars,initIndex:r.initIndex});await promises.writeFile(i,s,"utf8"),o.succeed();}async function ei(e,t,r,i={cleanupDefaultNextStyles:false,tailwindVersion:"v3",tailwindConfig:void 0,overwriteCssVars:false,initIndex:false}){i={cleanupDefaultNextStyles:false,tailwindVersion:"v3",tailwindConfig:void 0,overwriteCssVars:false,initIndex:false,...i};let n=[ri(t)];if(i.cleanupDefaultNextStyles&&n.push(Qt()),i.tailwindVersion==="v4"){if(n=[],r.resolvedPaths?.cwd){let s=o$1(r.resolvedPaths.cwd);!s?.dependencies?.["tailwindcss-animate"]&&!s?.devDependencies?.["tailwindcss-animate"]&&i.initIndex&&n.push(ai({params:"tw-animate-css"}));}n.push(si({params:"dark (&:is(.dark *))"})),i.cleanupDefaultNextStyles&&n.push(Qt()),n.push(ni(t,{overwriteCssVars:i.overwriteCssVars})),n.push(oi(t)),i.tailwindConfig&&(n.push(ci(i.tailwindConfig)),n.push(mi(i.tailwindConfig)),n.push(li(i.tailwindConfig)));}r.tailwind.cssVariables&&i.initIndex&&n.push(ti({tailwindVersion:i.tailwindVersion}));let a=(await x(n).process(e,{from:void 0})).css;return a=a.replace(/\/\* ---break--- \*\//g,""),i.tailwindVersion==="v4"&&(a=a.replace(/(\n\s*\n)+/g,`
22
+ `,i?.append(s);}});}catch(n){throw console.error("Error parsing rule content:",t,r,n),n}}async function Ke(e,t$1,r){if(!t$1.resolvedPaths.tailwindCss||!Object.keys(e??{}).length)return;r={cleanupDefaultNextStyles:false,silent:false,tailwindVersion:"v3",overwriteCssVars:false,initIndex:true,...r};let i=t$1.resolvedPaths.tailwindCss,n=j__default.relative(t$1.resolvedPaths.cwd,i),o=t(`Updating CSS variables in ${d.info(n)}`,{silent:r.silent}).start(),a=await promises.readFile(i,"utf8"),s=await Zr(a,e??{},t$1,{cleanupDefaultNextStyles:r.cleanupDefaultNextStyles,tailwindVersion:r.tailwindVersion,tailwindConfig:r.tailwindConfig,overwriteCssVars:r.overwriteCssVars,initIndex:r.initIndex});await promises.writeFile(i,s,"utf8"),o.succeed();}async function Zr(e,t,r,i={cleanupDefaultNextStyles:false,tailwindVersion:"v3",tailwindConfig:void 0,overwriteCssVars:false,initIndex:false}){i={cleanupDefaultNextStyles:false,tailwindVersion:"v3",tailwindConfig:void 0,overwriteCssVars:false,initIndex:false,...i};let n=[ti(t)];if(i.cleanupDefaultNextStyles&&n.push(Ht()),i.tailwindVersion==="v4"){if(n=[],r.resolvedPaths?.cwd){let s=o$1(r.resolvedPaths.cwd);!s?.dependencies?.["tailwindcss-animate"]&&!s?.devDependencies?.["tailwindcss-animate"]&&i.initIndex&&n.push(si({params:"tw-animate-css"}));}n.push(oi({params:"dark (&:is(.dark *))"})),i.cleanupDefaultNextStyles&&n.push(Ht()),n.push(ii(t,{overwriteCssVars:i.overwriteCssVars})),n.push(ni(t)),i.tailwindConfig&&(n.push(ai(i.tailwindConfig)),n.push(li(i.tailwindConfig)),n.push(ci(i.tailwindConfig)));}r.tailwind.cssVariables&&i.initIndex&&n.push(ei({tailwindVersion:i.tailwindVersion}));let a=(await x(n).process(e,{from:void 0})).css;return a=a.replace(/\/\* ---break--- \*\//g,""),i.tailwindVersion==="v4"&&(a=a.replace(/(\n\s*\n)+/g,`
23
23
 
24
- `)),a}function ti({tailwindVersion:e}){return {postcssPlugin:"update-base-layer",Once(t){let r=[{selector:"*",apply:e==="v4"?"border-border outline-ring/50":"border-border"},{selector:"body",apply:"bg-background text-foreground"}],i=t.nodes.find(n=>n.type==="atrule"&&n.name==="layer"&&n.params==="base"&&r.every(({selector:o,apply:a})=>n.nodes?.some(s=>s.type==="rule"&&s.selector===o&&s.nodes.some(c=>c.type==="atrule"&&c.name==="apply"&&c.params===a))));i||(i=x.atRule({name:"layer",params:"base",raws:{semicolon:true,between:" ",before:`
24
+ `)),a}function ei({tailwindVersion:e}){return {postcssPlugin:"update-base-layer",Once(t){let r=[{selector:"*",apply:e==="v4"?"border-border outline-ring/50":"border-border"},{selector:"body",apply:"bg-background text-foreground"}],i=t.nodes.find(n=>n.type==="atrule"&&n.name==="layer"&&n.params==="base"&&r.every(({selector:o,apply:a})=>n.nodes?.some(s=>s.type==="rule"&&s.selector===o&&s.nodes.some(c=>c.type==="atrule"&&c.name==="apply"&&c.params===a))));i||(i=x.atRule({name:"layer",params:"base",raws:{semicolon:true,between:" ",before:`
25
25
  `}}),t.append(i),t.insertBefore(i,x.comment({text:"---break---"}))),r.forEach(({selector:n,apply:o})=>{i?.nodes?.find(s=>s.type==="rule"&&s.selector===n)||i?.append(x.rule({selector:n,nodes:[x.atRule({name:"apply",params:o,raws:{semicolon:true,before:`
26
26
  `}})],raws:{semicolon:true,between:" ",before:`
27
- `}}));});}}}function ri(e){return {postcssPlugin:"update-css-vars",Once(t){let r=t.nodes.find(i=>i.type==="atrule"&&i.name==="layer"&&i.params==="base");r instanceof Zr||(r=x.atRule({name:"layer",params:"base",nodes:[],raws:{semicolon:true,before:`
28
- `,between:" "}}),t.append(r),t.insertBefore(r,x.comment({text:"---break---"}))),r!==void 0&&Object.entries(e).forEach(([i,n])=>{let o=i==="light"?":root":`.${i}`;ii(r,o,n);});}}}function Xt(e){let t=e.nodes.find(r=>r.type==="rule"&&r.selector===":root");if(t){let r=["--background","--foreground"];t.nodes.filter(i=>i.type==="decl"&&r.includes(i.prop)).forEach(i=>i.remove()),t.nodes.length===0&&t.remove();}}function Qt(){return {postcssPlugin:"cleanup-default-next-styles",Once(e){let t=e.nodes.find(i=>i.type==="rule"&&i.selector==="body");t&&(t.nodes.find(i=>i.type==="decl"&&i.prop==="color"&&["rgb(var(--foreground-rgb))","var(--foreground)"].includes(i.value))?.remove(),t.nodes.find(i=>i.type==="decl"&&i.prop==="background"&&(i.value.startsWith("linear-gradient")||i.value==="var(--background)"))?.remove(),t.nodes.find(i=>i.type==="decl"&&i.prop==="font-family"&&i.value==="Arial, Helvetica, sans-serif")?.remove(),t.nodes.length===0&&t.remove()),Xt(e);let r=e.nodes.find(i=>i.type==="atrule"&&i.params==="(prefers-color-scheme: dark)");r&&(Xt(r),r.nodes.length===0&&r.remove());}}}function ii(e,t,r){let i=e.nodes?.find(n=>n.type==="rule"&&n.selector===t);i||Object.keys(r).length>0&&(i=x.rule({selector:t,raws:{between:" ",before:`
29
- `}}),e.append(i)),Object.entries(r).forEach(([n,o])=>{let a=`--${n.replace(/^--/,"")}`,s=x.decl({prop:a,value:o,raws:{semicolon:true}}),c=i?.nodes.find(m=>m.type==="decl"&&m.prop===a);c?c.replaceWith(s):i?.append(s);});}function ni(e,t){return {postcssPlugin:"update-css-vars-v4",Once(r){Object.entries(e).forEach(([i,n])=>{let o=i==="light"?":root":`.${i}`;if(i==="theme"){o="@theme";let s=Pe(r);Object.entries(n).forEach(([c,m])=>{let l=`--${c.replace(/^--/,"")}`,p=x.decl({prop:l,value:m,raws:{semicolon:true}}),u=s?.nodes?.find(h=>h.type==="decl"&&h.prop===l);t.overwriteCssVars?u?u.replaceWith(p):s?.append(p):u||s?.append(p);});return}let a=r.nodes?.find(s=>s.type==="rule"&&s.selector===o);!a&&Object.keys(n).length>0&&(a=x.rule({selector:o,nodes:[],raws:{semicolon:true,between:" ",before:`
30
- `}}),r.append(a),r.insertBefore(a,x.comment({text:"---break---"}))),Object.entries(n).forEach(([s,c])=>{let m=`--${s.replace(/^--/,"")}`;m==="--sidebar-background"&&(m="--sidebar"),Zt(c)&&(c=`hsl(${c})`);let l=x.decl({prop:m,value:c,raws:{semicolon:true}}),p=a?.nodes.find(u=>u.type==="decl"&&u.prop===m);t.overwriteCssVars?p?p.replaceWith(l):a?.append(l):p||a?.append(l);});});}}}function oi(e){return {postcssPlugin:"update-theme",Once(t){let r=Array.from(new Set(Object.keys(e).flatMap(o=>Object.keys(e[o]||{}))));if(!r.length)return;let i=Pe(t),n=i.nodes?.filter(o=>o.type==="decl"&&o.prop.startsWith("--"));for(let o of r){let a=Object.values(e).find(p=>p[o])?.[o];if(!a)continue;if(o==="radius"){let p={sm:"calc(var(--radius) - 4px)",md:"calc(var(--radius) - 2px)",lg:"var(--radius)",xl:"calc(var(--radius) + 4px)","2xl":"calc(var(--radius) + 8px)","3xl":"calc(var(--radius) + 12px)","4xl":"calc(var(--radius) + 16px)"};for(let[u,h]of Object.entries(p)){let g=x.decl({prop:`--radius-${u}`,value:h,raws:{semicolon:true}});i?.nodes?.find(w=>w.type==="decl"&&w.prop===g.prop)||i?.append(g);}continue}let s=Zt(a)||pi(a)?`--color-${o.replace(/^--/,"")}`:`--${o.replace(/^--/,"")}`;s==="--color-sidebar-background"&&(s="--color-sidebar");let c=`var(--${o})`;s==="--color-sidebar"&&(c="var(--sidebar)");let m=x.decl({prop:s,value:c,raws:{semicolon:true}});i?.nodes?.find(p=>p.type==="decl"&&p.prop===m.prop)||(n?.length?i?.insertAfter(n[n.length-1],m):i?.append(m));}}}}function Pe(e){let t=e.nodes.find(r=>r.type==="atrule"&&r.name==="theme"&&r.params==="inline");return t||(t=x.atRule({name:"theme",params:"inline",nodes:[],raws:{semicolon:true,between:" ",before:`
31
- `}}),e.append(t),e.insertBefore(t,x.comment({text:"---break---"}))),t}function si({params:e}){return {postcssPlugin:"add-custom-variant",Once(t){if(!t.nodes.find(i=>i.type==="atrule"&&i.name==="custom-variant")){let i=t.nodes.filter(o=>o.type==="atrule"&&o.name==="import"),n=x.atRule({name:"custom-variant",params:e,raws:{semicolon:true,before:`
32
- `}});if(i.length>0){let o=i[i.length-1];t.insertAfter(o,n);}else t.insertAfter(t.nodes[0],n);t.insertBefore(n,x.comment({text:"---break---"}));}}}}function ai({params:e}){return {postcssPlugin:"add-custom-import",Once(t){let r=t.nodes.filter(o=>o.type==="atrule"&&o.name==="import"),i=t.nodes.find(o=>o.type==="atrule"&&o.name==="custom-variant");if(!r.some(o=>o.params.replace(/["']/g,"")===e)){let o=x.atRule({name:"import",params:`"${e}"`,raws:{semicolon:true,before:`
33
- `}});if(r.length>0){let a=r[r.length-1];t.insertAfter(a,o);}else i?(t.insertBefore(i,o),t.insertBefore(i,x.comment({text:"---break---"}))):(t.prepend(o),t.insertAfter(o,x.comment({text:"---break---"})));}}}}function ci(e){return {postcssPlugin:"update-tailwind-config",Once(t){if(!e?.plugins)return;let i=fi(t)==="single"?"'":'"',n=t.nodes.filter(a=>a.type==="atrule"&&a.name==="plugin"),o=n[n.length-1]||t.nodes[0];for(let a of e.plugins){let s=a.replace(/^require\(["']|["']\)$/g,"");if(n.some(m=>m.params.replace(/["']/g,"")===s))continue;let c=x.atRule({name:"plugin",params:`${i}${s}${i}`,raws:{semicolon:true,before:`
34
- `}});t.insertAfter(o,c),t.insertBefore(c,x.comment({text:"---break---"}));}}}}function li(e){return {postcssPlugin:"update-tailwind-config-keyframes",Once(t){if(!e?.theme?.extend?.keyframes)return;let r=Pe(t),i=r.nodes?.filter(o=>o.type==="atrule"&&o.name==="keyframes"),n=z$1.record(z$1.string(),z$1.record(z$1.string(),z$1.string()));for(let[o,a]of Object.entries(e.theme.extend.keyframes)){if(typeof o!="string")continue;let s=n.safeParse(a);if(!s.success||i?.find(m=>m.type==="atrule"&&m.name==="keyframes"&&m.params===o))continue;let c=x.atRule({name:"keyframes",params:o,nodes:[],raws:{semicolon:true,between:" ",before:`
35
- `}});for(let[m,l]of Object.entries(s.data)){let p=x.rule({selector:m,nodes:Object.entries(l).map(([u,h])=>x.decl({prop:u,value:h,raws:{semicolon:true,before:`
27
+ `}}));});}}}function ti(e){return {postcssPlugin:"update-css-vars",Once(t){let r=t.nodes.find(i=>i.type==="atrule"&&i.name==="layer"&&i.params==="base");r instanceof Qr||(r=x.atRule({name:"layer",params:"base",nodes:[],raws:{semicolon:true,before:`
28
+ `,between:" "}}),t.append(r),t.insertBefore(r,x.comment({text:"---break---"}))),r!==void 0&&Object.entries(e).forEach(([i,n])=>{let o=i==="light"?":root":`.${i}`;ri(r,o,n);});}}}function qt(e){let t=e.nodes.find(r=>r.type==="rule"&&r.selector===":root");if(t){let r=["--background","--foreground"];t.nodes.filter(i=>i.type==="decl"&&r.includes(i.prop)).forEach(i=>i.remove()),t.nodes.length===0&&t.remove();}}function Ht(){return {postcssPlugin:"cleanup-default-next-styles",Once(e){let t=e.nodes.find(i=>i.type==="rule"&&i.selector==="body");t&&(t.nodes.find(i=>i.type==="decl"&&i.prop==="color"&&["rgb(var(--foreground-rgb))","var(--foreground)"].includes(i.value))?.remove(),t.nodes.find(i=>i.type==="decl"&&i.prop==="background"&&(i.value.startsWith("linear-gradient")||i.value==="var(--background)"))?.remove(),t.nodes.find(i=>i.type==="decl"&&i.prop==="font-family"&&i.value==="Arial, Helvetica, sans-serif")?.remove(),t.nodes.length===0&&t.remove()),qt(e);let r=e.nodes.find(i=>i.type==="atrule"&&i.params==="(prefers-color-scheme: dark)");r&&(qt(r),r.nodes.length===0&&r.remove());}}}function ri(e,t,r){let i=e.nodes?.find(n=>n.type==="rule"&&n.selector===t);i||Object.keys(r).length>0&&(i=x.rule({selector:t,raws:{between:" ",before:`
29
+ `}}),e.append(i)),Object.entries(r).forEach(([n,o])=>{let a=`--${n.replace(/^--/,"")}`,s=x.decl({prop:a,value:o,raws:{semicolon:true}}),c=i?.nodes.find(m=>m.type==="decl"&&m.prop===a);c?c.replaceWith(s):i?.append(s);});}function ii(e,t){return {postcssPlugin:"update-css-vars-v4",Once(r){Object.entries(e).forEach(([i,n])=>{let o=i==="light"?":root":`.${i}`;if(i==="theme"){o="@theme";let s=Pe(r);Object.entries(n).forEach(([c,m])=>{let l=`--${c.replace(/^--/,"")}`,p=x.decl({prop:l,value:m,raws:{semicolon:true}}),u=s?.nodes?.find(g=>g.type==="decl"&&g.prop===l);t.overwriteCssVars?u?u.replaceWith(p):s?.append(p):u||s?.append(p);});return}let a=r.nodes?.find(s=>s.type==="rule"&&s.selector===o);!a&&Object.keys(n).length>0&&(a=x.rule({selector:o,nodes:[],raws:{semicolon:true,between:" ",before:`
30
+ `}}),r.append(a),r.insertBefore(a,x.comment({text:"---break---"}))),Object.entries(n).forEach(([s,c])=>{let m=`--${s.replace(/^--/,"")}`;m==="--sidebar-background"&&(m="--sidebar"),Xt(c)&&(c=`hsl(${c})`);let l=x.decl({prop:m,value:c,raws:{semicolon:true}}),p=a?.nodes.find(u=>u.type==="decl"&&u.prop===m);t.overwriteCssVars?p?p.replaceWith(l):a?.append(l):p||a?.append(l);});});}}}function ni(e){return {postcssPlugin:"update-theme",Once(t){let r=Array.from(new Set(Object.keys(e).flatMap(o=>Object.keys(e[o]||{}))));if(!r.length)return;let i=Pe(t),n=i.nodes?.filter(o=>o.type==="decl"&&o.prop.startsWith("--"));for(let o of r){let a=Object.values(e).find(p=>p[o])?.[o];if(!a)continue;if(o==="radius"){let p={sm:"calc(var(--radius) - 4px)",md:"calc(var(--radius) - 2px)",lg:"var(--radius)",xl:"calc(var(--radius) + 4px)","2xl":"calc(var(--radius) + 8px)","3xl":"calc(var(--radius) + 12px)","4xl":"calc(var(--radius) + 16px)"};for(let[u,g]of Object.entries(p)){let h=x.decl({prop:`--radius-${u}`,value:g,raws:{semicolon:true}});i?.nodes?.find(y=>y.type==="decl"&&y.prop===h.prop)||i?.append(h);}continue}let s=Xt(a)||fi(a)?`--color-${o.replace(/^--/,"")}`:`--${o.replace(/^--/,"")}`;s==="--color-sidebar-background"&&(s="--color-sidebar");let c=`var(--${o})`;s==="--color-sidebar"&&(c="var(--sidebar)");let m=x.decl({prop:s,value:c,raws:{semicolon:true}});i?.nodes?.find(p=>p.type==="decl"&&p.prop===m.prop)||(n?.length?i?.insertAfter(n[n.length-1],m):i?.append(m));}}}}function Pe(e){let t=e.nodes.find(r=>r.type==="atrule"&&r.name==="theme"&&r.params==="inline");return t||(t=x.atRule({name:"theme",params:"inline",nodes:[],raws:{semicolon:true,between:" ",before:`
31
+ `}}),e.append(t),e.insertBefore(t,x.comment({text:"---break---"}))),t}function oi({params:e}){return {postcssPlugin:"add-custom-variant",Once(t){if(!t.nodes.find(i=>i.type==="atrule"&&i.name==="custom-variant")){let i=t.nodes.filter(o=>o.type==="atrule"&&o.name==="import"),n=x.atRule({name:"custom-variant",params:e,raws:{semicolon:true,before:`
32
+ `}});if(i.length>0){let o=i[i.length-1];t.insertAfter(o,n);}else t.insertAfter(t.nodes[0],n);t.insertBefore(n,x.comment({text:"---break---"}));}}}}function si({params:e}){return {postcssPlugin:"add-custom-import",Once(t){let r=t.nodes.filter(o=>o.type==="atrule"&&o.name==="import"),i=t.nodes.find(o=>o.type==="atrule"&&o.name==="custom-variant");if(!r.some(o=>o.params.replace(/["']/g,"")===e)){let o=x.atRule({name:"import",params:`"${e}"`,raws:{semicolon:true,before:`
33
+ `}});if(r.length>0){let a=r[r.length-1];t.insertAfter(a,o);}else i?(t.insertBefore(i,o),t.insertBefore(i,x.comment({text:"---break---"}))):(t.prepend(o),t.insertAfter(o,x.comment({text:"---break---"})));}}}}function ai(e){return {postcssPlugin:"update-tailwind-config",Once(t){if(!e?.plugins)return;let i=mi(t)==="single"?"'":'"',n=t.nodes.filter(a=>a.type==="atrule"&&a.name==="plugin"),o=n[n.length-1]||t.nodes[0];for(let a of e.plugins){let s=a.replace(/^require\(["']|["']\)$/g,"");if(n.some(m=>m.params.replace(/["']/g,"")===s))continue;let c=x.atRule({name:"plugin",params:`${i}${s}${i}`,raws:{semicolon:true,before:`
34
+ `}});t.insertAfter(o,c),t.insertBefore(c,x.comment({text:"---break---"}));}}}}function ci(e){return {postcssPlugin:"update-tailwind-config-keyframes",Once(t){if(!e?.theme?.extend?.keyframes)return;let r=Pe(t),i=r.nodes?.filter(o=>o.type==="atrule"&&o.name==="keyframes"),n=z.record(z.string(),z.record(z.string(),z.string()));for(let[o,a]of Object.entries(e.theme.extend.keyframes)){if(typeof o!="string")continue;let s=n.safeParse(a);if(!s.success||i?.find(m=>m.type==="atrule"&&m.name==="keyframes"&&m.params===o))continue;let c=x.atRule({name:"keyframes",params:o,nodes:[],raws:{semicolon:true,between:" ",before:`
35
+ `}});for(let[m,l]of Object.entries(s.data)){let p=x.rule({selector:m,nodes:Object.entries(l).map(([u,g])=>x.decl({prop:u,value:g,raws:{semicolon:true,before:`
36
36
  `,between:": "}})),raws:{semicolon:true,between:" ",before:`
37
- `}});c.append(p);}r.append(c),r.insertBefore(c,x.comment({text:"---break---"}));}}}}function mi(e){return {postcssPlugin:"update-tailwind-config-animation",Once(t){if(!e?.theme?.extend?.animation)return;let r=Pe(t),i=r.nodes?.filter(o=>o.type==="decl"&&o.prop.startsWith("--animate-")),n=z$1.record(z$1.string(),z$1.string()).safeParse(e.theme.extend.animation);if(n.success)for(let[o,a]of Object.entries(n.data)){let s=`--animate-${o}`;if(i?.find(m=>m.prop===s))continue;let c=x.decl({prop:s,value:a,raws:{semicolon:true,between:": ",before:`
38
- `}});r.append(c);}}}}function fi(e){return e.nodes[0].toString().includes("'")?"single":"double"}function Zt(e){if(e.startsWith("hsl")||e.startsWith("rgb")||e.startsWith("#")||e.startsWith("oklch"))return false;let t=e.split(" ");return t.length===3&&t.slice(1,3).every(r=>r.includes("%"))}function pi(e){return e.startsWith("hsl")||e.startsWith("rgb")||e.startsWith("#")||e.startsWith("oklch")||e.includes("--color-")}async function W(e,t$1,r,i){if(e=Array.from(new Set(e)),t$1=Array.from(new Set(t$1)),!e?.length&&!t$1?.length)return;i={silent:false,...i};let n=t("Installing dependencies.",{silent:i.silent})?.start(),o=await gi(r),a="";if(ui(r)&&o==="npm")if(i.silent)a="force";else {n.stopAndPersist(),s.warn(`
37
+ `}});c.append(p);}r.append(c),r.insertBefore(c,x.comment({text:"---break---"}));}}}}function li(e){return {postcssPlugin:"update-tailwind-config-animation",Once(t){if(!e?.theme?.extend?.animation)return;let r=Pe(t),i=r.nodes?.filter(o=>o.type==="decl"&&o.prop.startsWith("--animate-")),n=z.record(z.string(),z.string()).safeParse(e.theme.extend.animation);if(n.success)for(let[o,a]of Object.entries(n.data)){let s=`--animate-${o}`;if(i?.find(m=>m.prop===s))continue;let c=x.decl({prop:s,value:a,raws:{semicolon:true,between:": ",before:`
38
+ `}});r.append(c);}}}}function mi(e){return e.nodes[0].toString().includes("'")?"single":"double"}function Xt(e){if(e.startsWith("hsl")||e.startsWith("rgb")||e.startsWith("#")||e.startsWith("oklch"))return false;let t=e.split(" ");return t.length===3&&t.slice(1,3).every(r=>r.includes("%"))}function fi(e){return e.startsWith("hsl")||e.startsWith("rgb")||e.startsWith("#")||e.startsWith("oklch")||e.includes("--color-")}async function W(e,t$1,r,i){if(e=Array.from(new Set(e)),t$1=Array.from(new Set(t$1)),!e?.length&&!t$1?.length)return;i={silent:false,...i};let n=t("Installing dependencies.",{silent:i.silent})?.start(),o=await ui(r),a="";if(di(r)&&o==="npm")if(i.silent)a="force";else {n.stopAndPersist(),s.warn(`
39
39
  It looks like you are using React 19.
40
40
  Some packages may fail to install due to peer dependency issues in npm (see https://ui.shadcn.com/react-19).
41
- `);let s$1=await Te([{type:"select",name:"flag",message:"How would you like to proceed?",choices:[{title:"Use --force",value:"force"},{title:"Use --legacy-peer-deps",value:"legacy-peer-deps"}]}]);s$1&&(a=s$1.flag);}n?.start(),await hi(o,e,t$1,r.resolvedPaths.cwd,a),n?.succeed();}function ui(e){let t=o$1(e.resolvedPaths.cwd,false);if(!t?.dependencies?.react)return false;let r=/^(?:\^|~)?19(?:\.\d+)*(?:-.*)?$/.test(t.dependencies.react),i=t.dependencies["react-day-picker"]?.startsWith("8");return r&&i}async function gi(e){return o$1(e.resolvedPaths.cwd,false)?.dependencies?.expo?"expo":a$1(e.resolvedPaths.cwd)}async function hi(e,t,r,i,n){if(e==="npm")return wi(t,r,i,n);if(e==="deno")return yi(t,r,i);if(e==="expo")return bi(t,r,i);t?.length&&await execa(e,["add",...t],{cwd:i}),r?.length&&await execa(e,["add","-D",...r],{cwd:i});}async function wi(e,t,r,i){e.length&&await execa("npm",["install",...i?[`--${i}`]:[],...e],{cwd:r}),t.length&&await execa("npm",["install",...i?[`--${i}`]:[],"-D",...t],{cwd:r});}async function yi(e,t,r){e?.length&&await execa("deno",["add",...e.map(i=>`npm:${i}`)],{cwd:r}),t?.length&&await execa("deno",["add","-D",...t.map(i=>`npm:${i}`)],{cwd:r});}async function bi(e,t,r){e.length&&await execa("npx",["expo","install",...e],{cwd:r}),t.length&&await execa("npx",["expo","install","-- -D",...t],{cwd:r});}async function He(e,t$1,r){if(!e||Object.keys(e).length===0)return {envVarsAdded:[],envFileUpdated:null,envFileCreated:null};r={silent:false,...r};let i=t("Adding environment variables.",{silent:r.silent})?.start(),n=t$1.resolvedPaths.cwd,o=j__default.join(n,".env.local"),a=G(n);a&&(o=a);let s$1=existsSync(o),c=j__default.basename(o),m=Object.entries(e).map(([h,g])=>`${h}=${g}`).join(`
42
- `),l=[],p=null,u=null;if(s$1){let h=await promises.readFile(o,"utf-8"),g=I(h,m);if(l=H$1(h,m),l.length>0){if(await promises.writeFile(o,g,"utf-8"),p=j__default.relative(n,o),i?.succeed(`Added the following variables to ${d.info(c)}:`),!r.silent)for(let w of l)s.log(` ${d.success("+")} ${w}`);}else i?.stop();}else if(await promises.writeFile(o,m+`
43
- `,"utf-8"),u=j__default.relative(n,o),l=Object.keys(e),i?.succeed(`Added the following variables to ${d.info(c)}:`),!r.silent)for(let h of l)s.log(` ${d.success("+")} ${h}`);return !r.silent&&l.length>0&&s.break(),{envVarsAdded:l,envFileUpdated:p,envFileCreated:u}}async function tr(e,t){if(!e.fonts?.length)return e;let r=await p(t.resolvedPaths.cwd);if(!r)return e;let[i]=e.fonts;if(e.cssVars??={},e.cssVars.theme??={},r.framework.name==="next-app"||r.framework.name==="next-pages")return e.cssVars.theme[i.font.variable]=`var(${i.font.variable})`,e;let o=`@fontsource-variable/${i.name.replace("font-","")}`;return e.dependencies??=[],e.dependencies.push(o),e.css??={},e.css[`@import "${o}"`]={},e.css["@layer base"]??={},e.css["@layer base"].html={"@apply font-sans":{}},e.css["@layer base"].body={"@apply font-sans bg-background text-foreground":{}},e.cssVars.theme[i.font.variable]=i.font.family,e}async function Xe(e,t$1,r){if(!e?.length)return;let i=await p(t$1.resolvedPaths.cwd);if(!i||i.framework.name!=="next-app"&&i.framework.name!=="next-pages")return;let n=t("Updating fonts.",{silent:r.silent})?.start();try{await ki(e,t$1,i),n?.succeed("Updating fonts.");}catch(o){throw n?.fail("Failed to update fonts."),o}}async function ki(e,t,r){let i=await Pi(t,r);if(!i)return;let n=await promises.readFile(i,"utf-8"),o=await ji(n,e);o!==n&&await promises.writeFile(i,o,"utf-8");}async function Pi(e,t){let r=e.resolvedPaths.cwd,i=t.isSrcDir,o=t.isTsx?"tsx":"jsx",a=i?[`src/app/layout.${o}`,`app/layout.${o}`]:[`app/layout.${o}`];for(let s of a){let c=j__default.join(r,s);if(existsSync(c))return c}return null}async function ji(e,t,r){let n=new Project({compilerOptions:{}}).createSourceFile("layout.tsx",e,{scriptKind:ScriptKind.TSX}),o=t.filter(s=>s.font.provider==="google"),a=[];for(let s of o){let c=s.font.import;if(!c)continue;let m=$i(c),l=n.getImportDeclaration(h=>h.getModuleSpecifierValue()==="next/font/google"),p=Ei(s);l?l.getNamedImports().some(w=>w.getName()===c)||l.addNamedImport(c):n.addImportDeclaration({moduleSpecifier:"next/font/google",namedImports:[c]});let u=Ni(n,s.font.variable);if(u)u.setInitializer(`${c}(${p})`),u.getName()!==m&&u.rename(m);else {let h=Oi(n);n.insertVariableStatement(h,{declarationKind:VariableDeclarationKind.Const,declarations:[{name:m,initializer:`${c}(${p})`}]}).appendWhitespace(`
44
- `);}a.push(m);}return a.length>0&&Ti(n,a),n.getFullText()}function Ei(e){let t={};return e.font.subsets?.length&&(t.subsets=e.font.subsets),e.font.weight?.length&&(t.weight=e.font.weight),t.variable=e.font.variable,JSON.stringify(t).replace(/"([^"]+)":/g,"$1:").replace(/"/g,"'")}function $i(e){return e.split("_").map((t,r)=>r===0?t.toLowerCase():t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function Ni(e,t){let r=e.getVariableStatements();for(let i of r)for(let n of i.getDeclarations()){let o=n.getInitializer();if(!o||o.getKind()!==SyntaxKind.CallExpression)continue;let s=o.getArguments();if(s.length===0)continue;let c=s[0].getText();if(c.includes("variable:")&&c.includes(t))return n}return null}function Oi(e){let t=e.getImportDeclarations();return t.length>0?t[t.length-1].getChildIndex()+1:0}function Ti(e,t){let r=e.getDescendantsOfKind(SyntaxKind.JsxOpeningElement);for(let i of r){if(i.getTagNameNode().getText()!=="html")continue;let o=i.getAttribute("className");if(!o){let m=t.map(l=>`${l}.variable`).join(", ");t.length===1?i.addAttribute({name:"className",initializer:`{${m}}`}):(ge(e),i.addAttribute({name:"className",initializer:`{cn(${m})}`}));return}if(o.getKind()!==SyntaxKind.JsxAttribute)return;let a=o.asKindOrThrow(SyntaxKind.JsxAttribute),s=a.getInitializer();if(!s)return;let c=t.map(m=>`${m}.variable`);if(s.getKind()===SyntaxKind.StringLiteral){let m=s.getText().slice(1,-1);ge(e),a.setInitializer(`{cn("${m}", ${c.join(", ")})}`);}else if(s.getKind()===SyntaxKind.JsxExpression){let m=s.asKindOrThrow(SyntaxKind.JsxExpression),l=m.getExpression();if(!l)return;let p=l.getText();if(p.startsWith("cn(")){if(c.every(w=>p.includes(w)))continue;let h=Ai(p),g=Di(h,c);m.replaceWithText(`{${g}}`);}else if(/^\w+\.variable$/.test(p)){if(c.includes(p))continue;c.length===1?m.replaceWithText(`{${c[0]}}`):(ge(e),m.replaceWithText(`{cn(${c.join(", ")})}`));}else if(p.startsWith("`")&&p.endsWith("`")){let u=Fi(p);ge(e),m.replaceWithText(`{cn(${[...u,...c].join(", ")})}`);}else ge(e),m.replaceWithText(`{cn(${p}, ${c.join(", ")})}`);}}}function ge(e){if(!e.getImportDeclaration(r=>r.getNamedImports().some(n=>n.getName()==="cn"))){let r=e.getImportDeclaration(i=>i.getModuleSpecifierValue().includes("/lib/utils"));r?r.getNamedImports().some(n=>n.getName()==="cn")||r.addNamedImport("cn"):e.addImportDeclaration({moduleSpecifier:"@/lib/utils",namedImports:["cn"]});}}function Fi(e){let t=[],r=[],n=e.slice(1,-1).split(/(\$\{[^}]+\})/);for(let o of n)if(o)if(o.startsWith("${")&&o.endsWith("}")){let a=o.slice(2,-1).trim();a&&r.push(a);}else {let a=o.trim().split(/\s+/).filter(Boolean);for(let s of a)t.push(`"${s}"`);}return [...t,...r]}function Ai(e){return e.replace(/,?\s*\w+\.variable/g,"").replace(/cn\(\s*,/,"cn(")}function Di(e,t){let r=t.join(", ");return e.replace(/\)$/,`, ${r})`)}async function se(e,t,r){r={overwrite:false,silent:false,isNewProject:false,baseStyle:true,...r};let i=await k(t);return i&&i.ui&&i.ui.resolvedPaths.cwd!==t.resolvedPaths.cwd?await Vi(e,t,i,{...r,isRemote:e?.length===1&&!!e[0].match(/\/chat\/b\//)}):await Li(e,t,r)}async function Li(e,t$1,r$1){if(!r$1.baseStyle&&!e.length)return;let i=t("Checking registry.",{silent:r$1.silent})?.start(),n=await X(e,O(t$1));if(!n)return i?.fail(),Y(new Error("Failed to fetch components from registry."));try{ir(n.files??[],t$1.resolvedPaths.cwd);}catch(s){return i?.fail(),Y(s)}i?.succeed();let o=await r(t$1);n=await tr(n,t$1),await T(n.tailwind?.config,t$1,{silent:r$1.silent,tailwindVersion:o});let a=await rr(e,t$1);await Ke(n.cssVars,t$1,{cleanupDefaultNextStyles:r$1.isNewProject,silent:r$1.silent,tailwindVersion:o,tailwindConfig:n.tailwind?.config,overwriteCssVars:a,initIndex:r$1.baseStyle}),await Ye(n.css,t$1,{silent:r$1.silent}),await He(n.envVars,t$1,{silent:r$1.silent}),await W(n.dependencies,n.devDependencies,t$1,{silent:r$1.silent}),await Xe(n.fonts,t$1,{silent:r$1.silent}),await K(n.files,t$1,{overwrite:r$1.overwrite,silent:r$1.silent,path:r$1.path}),n.docs&&s.info(n.docs);}async function Vi(e,t$1,r$1,i){if(!i.baseStyle&&!e.length)return;let n=t("Checking registry.",{silent:i.silent})?.start(),o=await X(e,O(t$1));if(!o)return n?.fail(),Y(new Error("Failed to fetch components from registry."));try{ir(o.files??[],t$1.resolvedPaths.cwd);}catch(w){return n?.fail(),Y(w)}n?.succeed();let a=[],s$1=[],c=[],m$1=t("Installing components.")?.start(),l$1=r$1.ui,p=await r(l$1),u=m(t$1.resolvedPaths.cwd,l$1.resolvedPaths.ui);if(o.tailwind?.config&&(await T(o.tailwind?.config,l$1,{silent:true,tailwindVersion:p}),s$1.push(j__default.relative(u,l$1.resolvedPaths.tailwindConfig))),o.cssVars){let w=await rr(e,t$1);await Ke(o.cssVars,l$1,{silent:true,tailwindVersion:p,tailwindConfig:o.tailwind?.config,overwriteCssVars:w}),s$1.push(j__default.relative(u,l$1.resolvedPaths.tailwindCss));}o.css&&(await Ye(o.css,l$1,{silent:true}),s$1.push(j__default.relative(u,l$1.resolvedPaths.tailwindCss))),o.envVars&&await He(o.envVars,l$1,{silent:true}),await W(o.dependencies,o.devDependencies,l$1,{silent:true}),await Xe(o.fonts,l$1,{silent:true});let h=new Map;for(let w of o.files??[]){let C=w.type||"registry:ui";h.has(C)||h.set(C,[]),h.get(C).push(w);}for(let w of Array.from(h.keys())){let C=h.get(w),v=w==="registry:ui"?r$1.ui:t$1,Y=m(t$1.resolvedPaths.cwd,v.resolvedPaths.ui||v.resolvedPaths.cwd),O=await l(Y,v.resolvedPaths.cwd)??v.resolvedPaths.cwd,X=await K(C,v,{overwrite:i.overwrite,silent:true,rootSpinner:m$1,isRemote:i.isRemote,isWorkspace:true,path:i.path});a.push(...X.filesCreated.map(T=>j__default.relative(Y,j__default.join(O,T)))),s$1.push(...X.filesUpdated.map(T=>j__default.relative(Y,j__default.join(O,T)))),c.push(...X.filesSkipped.map(T=>j__default.relative(Y,j__default.join(O,T))));}if(m$1?.succeed(),a.sort(),s$1.sort(),c.sort(),!(a.length||s$1.length)&&!c.length&&t("No files updated.",{silent:i.silent})?.info(),a.length){t(`Created ${a.length} ${a.length===1?"file":"files"}:`,{silent:i.silent})?.succeed();for(let w of a)s.log(` - ${w}`);}if(s$1.length){t(`Updated ${s$1.length} ${s$1.length===1?"file":"files"}:`,{silent:i.silent})?.info();for(let w of s$1)s.log(` - ${w}`);}if(c.length){t(`Skipped ${c.length} ${s$1.length===1?"file":"files"}: (use --overwrite to overwrite)`,{silent:i.silent})?.info();for(let w of c)s.log(` - ${w}`);}o.docs&&s.info(o.docs);}async function rr(e,t){let r=await _$1(e,{config:t});return z$1.array(n$1).parse(r).some(n=>n.type==="registry:theme"||n.type==="registry:style"||n.type==="registry:font"||n.type==="registry:base")}function ir(e,t){for(let r of e)if(r?.target&&!Yt(r.target,t))throw new Error(`We found an unsafe file path "${r.target} in the registry item. Installation aborted.`)}var et="https://codeload.github.com/shadcn-ui/ui/tar.gz/main",D={next:"next","next-monorepo":"next-monorepo",vite:"vite",start:"start"};async function Ee(e){e={srcDir:false,...e};let t=e.template&&D[e.template]?e.template:"next",r=e.name??(t===D.next||t===D.vite||t===D.start?"my-app":"my-monorepo"),i="latest",n=e.components?.length===1&&!!e.components[0].match(/\/chat\/b\//);if(e.components&&n)try{let[s]=await S$1(e.components),{meta:c}=z$1.object({meta:z$1.object({nextVersion:z$1.string()})}).parse(s);i=c.nextVersion,t=D.next;}catch(s$1){s.break(),Y(s$1);}if(!e.force){let{type:s,name:c}=await Te([{type:e.template||n?null:"select",name:"type",message:`The path ${d.info(e.cwd)} does not contain a package.json file.
45
- Would you like to start a new project?`,choices:[{title:"Next.js",value:"next"},{title:"Next.js (Monorepo)",value:"next-monorepo"},{title:"Vite",value:"vite"},{title:"TanStack Start",value:"start"}],initial:0},{type:e.name?null:"text",name:"name",message:"What is your project named?",initial:r,format:m=>m.trim(),validate:m=>m.length>128?"Name should be less than 128 characters.":true}]);t=s??t,r=c??r;}let o=await a$1(e.cwd,{withFallback:true}),a=`${e.cwd}/${r}`;try{await S.access(e.cwd,S.constants.W_OK);}catch{s.break(),s.error(`The path ${d.info(e.cwd)} is not writable.`),s.error(`It is likely you do not have write permissions for this folder or the path ${d.info(e.cwd)} does not exist.`),s.break(),process.exit(1);}return S.existsSync(j__default.resolve(e.cwd,r,"package.json"))&&(s.break(),s.error(`A project with the name ${d.info(r)} already exists.`),s.error("Please choose a different name and try again."),s.break(),process.exit(1)),t===D.next&&await Wi(a,{version:i,cwd:e.cwd,packageManager:o,srcDir:!!e.srcDir}),t===D["next-monorepo"]&&await zi(a,{packageManager:o}),t===D.vite&&await Bi(a,{packageManager:o}),t===D.start&&await Ui(a,{packageManager:o}),{projectPath:a,projectName:r,template:t}}async function Wi(e,t$1){let r=t("Creating a new Next.js project. This may take a few minutes.").start(),i=["--tailwind","--eslint","--typescript","--app",t$1.srcDir?"--src-dir":"--no-src-dir","--no-import-alias",`--use-${t$1.packageManager}`];(t$1.version.startsWith("15")||t$1.version.startsWith("latest")||t$1.version.startsWith("canary"))&&i.push("--turbopack"),(t$1.version.startsWith("latest")||t$1.version.startsWith("canary"))&&i.push("--no-react-compiler");try{await execa("npx",[`create-next-app@${t$1.version}`,e,"--silent",...i],{cwd:t$1.cwd});}catch{s.break(),s.error("Something went wrong creating a new Next.js project. Please try again."),process.exit(1);}r?.succeed("Creating a new Next.js project.");}async function zi(e,t$1){let r=t("Creating a new Next.js monorepo. This may take a few minutes.").start();try{let i=j__default.join(Ze.tmpdir(),`shadcn-template-${Date.now()}`);await S.ensureDir(i);let n=await fetch(et);if(!n.ok)throw new Error(`Failed to download template: ${n.statusText}`);let o=j__default.resolve(i,"template.tar.gz");await S.writeFile(o,Buffer.from(await n.arrayBuffer())),await execa("tar",["-xzf",o,"-C",i,"--strip-components=2","ui-main/templates/monorepo-next"]);let a=j__default.resolve(i,"monorepo-next");await S.move(a,e),await S.remove(i),await execa(t$1.packageManager,["install"],{cwd:e});let s=j__default.join(e,"package.json");if(S.existsSync(s)){let m=await S.readFile(s,"utf8"),l=JSON.parse(m);l.name=e.split("/").pop(),await S.writeFile(s,JSON.stringify(l,null,2));}let c=process.cwd();await execa("git",["--version"],{cwd:e}),await execa("git",["init"],{cwd:e}),await execa("git",["add","-A"],{cwd:e}),await execa("git",["commit","-m","Initial commit"],{cwd:e}),r?.succeed("Creating a new Next.js monorepo.");}catch(i){r?.fail("Something went wrong creating a new Next.js monorepo."),Y(i);}}async function Bi(e,t$1){let r=t("Creating a new Vite project. This may take a few minutes.").start();try{let i=j__default.join(Ze.tmpdir(),`shadcn-template-${Date.now()}`);await S.ensureDir(i);let n=await fetch(et);if(!n.ok)throw new Error(`Failed to download template: ${n.statusText}`);let o=j__default.resolve(i,"template.tar.gz");await S.writeFile(o,Buffer.from(await n.arrayBuffer())),await execa("tar",["-xzf",o,"-C",i,"--strip-components=2","ui-main/templates/vite-app"]);let a=j__default.resolve(i,"vite-app");if(await S.move(a,e),await S.remove(i),t$1.packageManager!=="pnpm"){let c=j__default.join(e,"pnpm-lock.yaml");S.existsSync(c)&&await S.remove(c);}await execa(t$1.packageManager,["install"],{cwd:e});let s=j__default.join(e,"package.json");if(S.existsSync(s)){let c=await S.readFile(s,"utf8"),m=JSON.parse(c);m.name=e.split("/").pop(),await S.writeFile(s,JSON.stringify(m,null,2));}await execa("git",["--version"],{cwd:e}),await execa("git",["init"],{cwd:e}),await execa("git",["add","-A"],{cwd:e}),await execa("git",["commit","-m","Initial commit"],{cwd:e}),r?.succeed("Creating a new Vite project.");}catch(i){r?.fail("Something went wrong creating a new Vite project."),Y(i);}}async function Ui(e,t$1){let r=t("Creating a new TanStack Start project. This may take a few minutes.").start();try{let i=j__default.join(Ze.tmpdir(),`shadcn-template-${Date.now()}`);await S.ensureDir(i);let n=await fetch(et);if(!n.ok)throw new Error(`Failed to download template: ${n.statusText}`);let o=j__default.resolve(i,"template.tar.gz");await S.writeFile(o,Buffer.from(await n.arrayBuffer())),await execa("tar",["-xzf",o,"-C",i,"--strip-components=2","ui-main/templates/start-app"]);let a=j__default.resolve(i,"start-app");if(await S.move(a,e),await S.remove(i),t$1.packageManager!=="pnpm"){let c=j__default.join(e,"pnpm-lock.yaml");S.existsSync(c)&&await S.remove(c);}await execa(t$1.packageManager,["install"],{cwd:e});let s=j__default.join(e,"package.json");if(S.existsSync(s)){let c=await S.readFile(s,"utf8"),m=JSON.parse(c);m.name=e.split("/").pop(),await S.writeFile(s,JSON.stringify(m,null,2));}await execa("git",["--version"],{cwd:e}),await execa("git",["init"],{cwd:e}),await execa("git",["add","-A"],{cwd:e}),await execa("git",["commit","-m","Initial commit"],{cwd:e}),r?.succeed("Creating a new TanStack Start project.");}catch(i){r?.fail("Something went wrong creating a new TanStack Start project."),Y(i);}}async function z(e=process.cwd()){try{let{config:t}=await import('@dotenvx/dotenvx'),r=[".env.local",".env.development.local",".env.development",".env"];for(let i of r){let n=join(e,i);existsSync(n)&&t({path:n,overload:!1,quiet:!0});}}catch(t){s.warn("Failed to load env files:",t);}}var he=".bak";function nr(e){if(!S.existsSync(e))return null;let t=`${e}${he}`;try{return S.renameSync(e,t),t}catch(r){return console.error(`Failed to create backup of ${e}: ${r}`),null}}function or(e){let t=`${e}${he}`;if(!S.existsSync(t))return false;try{return S.renameSync(t,e),!0}catch(r){return console.error(`Warning: Could not restore backup file ${t}: ${r}`),false}}function tt(e){let t=`${e}${he}`;if(!S.existsSync(t))return false;try{return S.unlinkSync(t),!0}catch{return false}}async function sr(e,t){let r=new Set,i=new Set,n=[...e];for(;n.length>0;){let o=n.shift();if(i.has(o))continue;i.add(o);let{registry:a}=F(o);a&&!b[a]&&r.add(a);try{let[s]=await W$1([o],t,{useCache:!0});if(s?.registryDependencies)for(let c of s.registryDependencies){let{registry:m}=F(c);m&&!b[m]&&r.add(m),i.has(c)||n.push(c);}}catch(s){if(s instanceof z$2){let{registry:c}=F(o);c&&!b[c]&&r.add(c);continue}continue}}return Array.from(r)}async function _(e,t$1,r={}){r={silent:false,writeFile:true,...r};let n=(await sr(e,t$1)).filter(m=>!t$1.registries?.[m]&&!Object.keys(b).includes(m));if(n.length===0)return {config:t$1,newRegistries:[]};let o=await ja({useCache:process.env.NODE_ENV!=="development"});if(!o)return {config:t$1,newRegistries:[]};let a={};for(let m of n)o[m]&&(a[m]=o[m]);if(Object.keys(a).length===0)return {config:t$1,newRegistries:[]};let s=Object.fromEntries(Object.entries(t$1.registries||{}).filter(([m])=>!Object.keys(b).includes(m))),c$1={...t$1,registries:{...s,...a}};if(r.writeFile){let{resolvedPaths:m,...l}=c$1,p=t("Updating components.json.",{silent:r.silent}).start(),u=c.parse(l);await S.writeFile(j__default.resolve(t$1.resolvedPaths.cwd,"components.json"),JSON.stringify(u,null,2)+`
46
- `,"utf-8"),p.succeed();}return {config:c$1,newRegistries:Object.keys(a)}}async function cr(e,t$1,r){if(!e)return;r={silent:false,...r};let i=j__default.relative(t$1.resolvedPaths.cwd,t$1.resolvedPaths.tailwindConfig),n=t(`Updating ${d.info(i)}`,{silent:r.silent}).start(),o=await promises.readFile(t$1.resolvedPaths.tailwindConfig,"utf8"),a=await Hi(o,e,t$1);await promises.writeFile(t$1.resolvedPaths.tailwindConfig,a,"utf8"),n?.succeed();}async function Hi(e,t,r){let i=await U(e,r),n=i.getDescendantsOfKind(SyntaxKind.ObjectLiteralExpression).find(o=>o.getProperties().some(a=>a.isKind(SyntaxKind.PropertyAssignment)&&a.getName()==="content"));return n?(Xi(n,t),i.getFullText()):e}async function Xi(e,t){let r=V(e),i=e.getProperty("content");if(!i){let n={name:"content",initializer:`[${r}${t.join(`${r}, ${r}`)}${r}]`};return e.addPropertyAssignment(n),e}if(i.isKind(SyntaxKind.PropertyAssignment)){let n=i.getInitializer();if(n?.isKind(SyntaxKind.ArrayLiteralExpression))for(let o of t){let a=`${r}${o}${r}`;n.getElements().map(s=>s.getText()).includes(a)||n.addElement(a);}return e}return e}process.on("exit",e=>{let t=j__default.resolve(process.cwd(),"components.json");return e===0?tt(t):or(t)});var it=z$1.object({cwd:z$1.string(),name:z$1.string().optional(),components:z$1.array(z$1.string()).optional(),yes:z$1.boolean(),defaults:z$1.boolean(),force:z$1.boolean(),silent:z$1.boolean(),isNewProject:z$1.boolean(),srcDir:z$1.boolean().optional(),cssVariables:z$1.boolean(),template:z$1.string().optional().refine(e=>e?D[e]:true,{message:"Invalid template. Please use 'next', 'vite', 'start' or 'next-monorepo'."}),baseColor:z$1.string().optional().refine(e=>e?a.find(t=>t.name===e):true,{message:`Invalid base color. Please use '${a.map(e=>e.name).join("', '")}'`}),baseStyle:z$1.boolean(),registryBaseConfig:c.deepPartial().optional()}),mr=new Command().name("init").description("initialize your project and install dependencies").argument("[components...]","names, url or local path to component").option("-t, --template <template>","the template to use. (next, start, vite, next-monorepo)").option("-b, --base-color <base-color>","the base color to use. (neutral, gray, zinc, stone, slate)",void 0).option("-y, --yes","skip confirmation prompt.",true).option("-d, --defaults,","use default configuration.",false).option("-f, --force","force overwrite of existing configuration.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-s, --silent","mute output.",false).option("--src-dir","use the src directory when creating a new project.",false).option("--no-src-dir","do not use the src directory when creating a new project.").option("--css-variables","use css variables for theming.",true).option("--no-css-variables","do not use css variables for theming.").option("--no-base-style","do not install the base shadcn style.").action(async(e,t)=>{try{t.defaults&&(t.template=t.template||"next",t.baseColor=t.baseColor||"neutral");let r=it.parse({cwd:j__default.resolve(t.cwd),isNewProject:!1,components:e,...t});if(await z(r.cwd),e.length>0){let i=O(n({resolvedPaths:{cwd:r.cwd}})),n$1=j__default.resolve(r.cwd,"components.json");if(S.existsSync(n$1)){let s=await S.readJson(n$1),c$1=c.partial().parse(s),m=n({resolvedPaths:{cwd:r.cwd}});i=O({...c$1,resolvedPaths:{...m.resolvedPaths,cwd:r.cwd}}),nr(n$1);}let{config:o}=await _(e,i,{silent:!0,writeFile:!1});i=o,R(e[0],i);let[a]=await _$1([e[0]],{config:i});a?.type==="registry:base"&&(a.config&&(i=O(lr(i,a.config)),r.registryBaseConfig=a.config),r.baseStyle=a.extends==="none"?!1:r.baseStyle),a?.type==="registry:style"&&(r.baseColor="neutral",r.baseStyle=a.extends==="none"?!1:r.baseStyle);}r.baseStyle||(r.baseColor="neutral"),await le(r),s.log(`${d.success("Success!")} Project initialization completed.
47
- You may now add components.`),tt(j__default.resolve(r.cwd,"components.json")),s.break();}catch(r){s.break(),Y(r);}finally{P();}});async function le(e){let t$1,r;if(e.skipPreflight)t$1=await p(e.cwd);else {let h=await Jt(e);if(h.errors["1"]){let{projectPath:g,template:w}=await Ee(e);g||process.exit(1),e.cwd=g,e.isNewProject=true,r=w,t$1=await p(e.cwd);}else t$1=h.projectInfo;}if(r==="next-monorepo")return e.cwd=j__default.resolve(e.cwd,"apps/web"),await i(e.cwd);let i$1=await q(e.cwd,t$1),n=i$1?await en(i$1,e):await Zi(await i(e.cwd));if(!e.yes){let{proceed:h}=await Te({type:"confirm",name:"proceed",message:`Write configuration to ${d.info("components.json")}. Proceed?`,initial:true});h||process.exit(0);}let o=[...e.baseStyle?["index"]:[],...e.components??[]],a=await j$1(e.cwd,n),{config:s}=await _(o,a,{silent:true});s.registries&&(n.registries=s.registries);let c=t("Writing components.json.").start(),l=`${j__default.resolve(e.cwd,"components.json")}${he}`,p$1=(h,g)=>{let{registries:w,...C}=lr(h,g);return {...C,registries:w}};if(!e.force&&S.existsSync(l)){let h=await S.readJson(l);n=p$1(h,n);}e.registryBaseConfig&&(n=p$1(n,e.registryBaseConfig)),n.registries=Object.fromEntries(Object.entries(n.registries||{}).filter(([h])=>!Object.keys(b).includes(h))),c.succeed();let u=await j$1(e.cwd,n);return await se(o,u,{overwrite:true,silent:e.silent,baseStyle:e.baseStyle,isNewProject:e.isNewProject||t$1?.framework.name==="next-app"}),e.isNewProject&&e.srcDir&&await cr(["./src/**/*.{js,ts,jsx,tsx,mdx}"],u,{silent:e.silent}),u}async function Zi(e$1=null){let[t,r]=await Promise.all([ca(),ea()]);s.info("");let i=await Te([{type:"toggle",name:"typescript",message:`Would you like to use ${d.info("TypeScript")} (recommended)?`,initial:e$1?.tsx??true,active:"yes",inactive:"no"},{type:"select",name:"style",message:`Which ${d.info("style")} would you like to use?`,choices:t.map(n=>({title:n.label,value:n.name}))},{type:"select",name:"tailwindBaseColor",message:`Which color would you like to use as the ${d.info("base color")}?`,choices:r.map(n=>({title:n.label,value:n.name}))},{type:"text",name:"tailwindCss",message:`Where is your ${d.info("global CSS")} file?`,initial:e$1?.tailwind.css??g},{type:"toggle",name:"tailwindCssVariables",message:`Would you like to use ${d.info("CSS variables")} for theming?`,initial:e$1?.tailwind.cssVariables??true,active:"yes",inactive:"no"},{type:"text",name:"tailwindPrefix",message:`Are you using a custom ${d.info("tailwind prefix eg. tw-")}? (Leave blank if not)`,initial:""},{type:"text",name:"tailwindConfig",message:`Where is your ${d.info("tailwind.config.js")} located?`,initial:e$1?.tailwind.config??h},{type:"text",name:"components",message:`Configure the import alias for ${d.info("components")}:`,initial:e$1?.aliases.components??e},{type:"text",name:"utils",message:`Configure the import alias for ${d.info("utils")}:`,initial:e$1?.aliases.utils??f},{type:"toggle",name:"rsc",message:`Are you using ${d.info("React Server Components")}?`,initial:e$1?.rsc??true,active:"yes",inactive:"no"}]);return c.parse({$schema:"https://ui.shadcn.com/schema.json",style:i.style,tailwind:{config:i.tailwindConfig,css:i.tailwindCss,baseColor:i.tailwindBaseColor,cssVariables:i.tailwindCssVariables,prefix:i.tailwindPrefix},rsc:i.rsc,tsx:i.typescript,aliases:{utils:i.utils,components:i.components,lib:i.components.replace(/\/components$/,"lib"),hooks:i.components.replace(/\/components$/,"hooks")}})}async function en(e,t){let r$1=e.style,i=t.baseColor,n=e.tailwind.cssVariables,o=e.iconLibrary??"lucide";if(!t.defaults){let[a,s,c]=await Promise.all([ca(),ea(),r(e)]),m=await Te([{type:c==="v4"||r$1?null:"select",name:"style",message:`Which ${d.info("style")} would you like to use?`,choices:a.map(l=>({title:l.name==="new-york"?"New York (Recommended)":l.label,value:l.name})),initial:0},{type:t.baseColor?null:"select",name:"tailwindBaseColor",message:`Which color would you like to use as the ${d.info("base color")}?`,choices:s.map(l=>({title:l.label,value:l.name}))}]);r$1=m.style??r$1??"new-york",i=m.tailwindBaseColor??i,n=t.cssVariables;}return c.parse({$schema:e?.$schema,style:r$1,tailwind:{...e?.tailwind,baseColor:i,cssVariables:n},rsc:e?.rsc,tsx:e?.tsx,iconLibrary:o,aliases:e?.aliases})}async function pr(e){let t={};if(!S.existsSync(e.cwd)||!S.existsSync(j__default.resolve(e.cwd,"package.json")))return t["1"]=true,{errors:t,config:null};if(!S.existsSync(j__default.resolve(e.cwd,"components.json")))return t["3"]=true,{errors:t,config:null};try{let r=await i(e.cwd);return {errors:t,config:r}}catch{s.break(),s.error(`An invalid ${d.info("components.json")} file was found at ${d.info(e.cwd)}.
48
- Before you can add components, you must create a valid ${d.info("components.json")} file by running the ${d.info("init")} command.`),s.error(`Learn more at ${d.info("https://ui.shadcn.com/docs/components-json")}.`),s.break(),process.exit(1);}}var rn=z$1.object({components:z$1.array(z$1.string()).optional(),yes:z$1.boolean(),overwrite:z$1.boolean(),cwd:z$1.string(),all:z$1.boolean(),path:z$1.string().optional(),silent:z$1.boolean(),srcDir:z$1.boolean().optional(),cssVariables:z$1.boolean()}),ur=new Command().name("add").description("add a component to your project").argument("[components...]","names, url or local path to component").option("-y, --yes","skip confirmation prompt.",false).option("-o, --overwrite","overwrite existing files.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-a, --all","add all available components",false).option("-p, --path <path>","the path to add the component to.").option("-s, --silent","mute output.",false).option("--src-dir","use the src directory when creating a new project.",false).option("--no-src-dir","do not use the src directory when creating a new project.").option("--css-variables","use css variables for theming.",true).option("--no-css-variables","do not use css variables for theming.").action(async(e,t)=>{try{let r=rn.parse({components:e,cwd:j__default.resolve(t.cwd),...t});await z(r.cwd);let i$1=await i(r.cwd);i$1||(i$1=n({style:"new-york",resolvedPaths:{cwd:r.cwd}}));let n$1=["sidebar-","login-","signup-","otp-","calendar-"],o=["base-","radix-"];if(e.length>0&&i$1?.style&&o.some(w=>i$1?.style.startsWith(w))){let w=e.filter(C=>n$1.some(v=>C.startsWith(v)));w.length&&(s.warn(`The ${d.info(w.map(C=>C).join(", "))} component(s) are not available for the ${d.info(i$1.style)} style yet. They are coming soon.`),s.warn("In the meantime, you can visit the blocks page on https://ui.shadcn.com/blocks and copy the code."),s.break(),process.exit(1));}let a=!1;if(e.length>0){let{config:g,newRegistries:w}=await _(e,i$1,{silent:r.silent,writeFile:!1});i$1=g,a=w.length>0;}let s$1,c=!0;if(e.length>0){let[g]=await _$1([e[0]],{config:i$1});if(s$1=g?.type,c=s$1!=="registry:theme"&&s$1!=="registry:style",N(g)){await se(e,i$1,{...r,baseStyle:c});return}if(!r.yes&&(s$1==="registry:style"||s$1==="registry:theme")){s.break();let{confirm:w}=await Te({type:"confirm",name:"confirm",message:d.warn(`You are about to install a new ${s$1.replace("registry:","")}.
49
- Existing CSS variables and components will be overwritten. Continue?`)});w||(s.break(),s.log("Installation cancelled."),s.break(),process.exit(1));}}if(r.components?.length||(r.components=await nn(r)),(await p(r.cwd))?.tailwindVersion==="v4"){let g=c$1.filter(w=>r.components?.includes(w.name));g?.length&&(s.break(),g.forEach(w=>{s.warn(d.warn(w.message));}),s.break(),process.exit(1));}let{errors:l,config:p$1}=await pr(r),u=!1;if(l["3"]){let{proceed:g}=await Te({type:"confirm",name:"proceed",message:`You need to create a ${d.info("components.json")} file to add components. Proceed?`,initial:!0});g||(s.break(),process.exit(1)),p$1=await le({cwd:r.cwd,yes:!0,force:!0,defaults:!1,skipPreflight:!1,silent:r.silent&&!a,isNewProject:!1,srcDir:r.srcDir,cssVariables:r.cssVariables,baseStyle:c,baseColor:c?void 0:"neutral",components:r.components}),u=!0;}let h=!1;if(l["1"]){let{projectPath:g,template:w}=await Ee({cwd:r.cwd,force:r.overwrite,srcDir:r.srcDir,components:r.components});g||(s.break(),process.exit(1)),r.cwd=g,w==="next-monorepo"?(r.cwd=j__default.resolve(r.cwd,"apps/web"),p$1=await i(r.cwd)):(p$1=await le({cwd:r.cwd,yes:!0,force:!0,defaults:!1,skipPreflight:!0,silent:!a&&r.silent,isNewProject:!0,srcDir:r.srcDir,cssVariables:r.cssVariables,baseStyle:c,baseColor:c?void 0:"neutral",components:r.components}),u=!0,h=r.components?.length===1&&!!r.components[0].match(/\/chat\/b\//));}}catch(r){console.log("add error"),s.break(),Y(r);}finally{P();}});async function nn(e){let t=await ba();if(!t)return s.break(),Y(new Error("Failed to fetch registry index.")),[];if(e.all)return t.map(n=>n.name).filter(n=>!c$1.some(o=>o.name===n));if(e.components?.length)return e.components;let{components:r}=await Te({type:"multiselect",name:"components",message:"Which components would you like to add?",hint:"Space to select. A to toggle all. Enter to submit.",instructions:false,choices:t.filter(n=>n.type==="registry:ui"&&!c$1.some(o=>o.name===n.name)).map(n=>({title:n.name,value:n.name,selected:e.all?true:e.components?.includes(n.name)}))});r?.length||(s.warn("No components selected. Exiting."),s.info(""),process.exit(1));let i=z$1.array(z$1.string()).safeParse(r);return i.success?i.data:(s.error(""),Y(new Error("Something went wrong. Please try again.")),[])}async function wr(e){let t={},r={cwd:e.cwd,registryFile:j__default.resolve(e.cwd,e.registryFile),outputDir:j__default.resolve(e.cwd,e.outputDir)};return S.existsSync(r.registryFile)||(t["13"]=true),await S.mkdir(r.outputDir,{recursive:true}),Object.keys(t).length>0&&(t["13"]&&(s.break(),s.error(`The path ${d.info(r.registryFile)} does not exist.`)),s.break(),process.exit(1)),{errors:t,resolvePaths:r}}var sn=z$1.object({cwd:z$1.string(),registryFile:z$1.string(),outputDir:z$1.string()}),yr=new Command().name("build").description("build components for a shadcn registry").argument("[registry]","path to registry.json file","./registry.json").option("-o, --output <path>","destination directory for json files","./public/r").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t$1)=>{try{let r=sn.parse({cwd:j.resolve(t$1.cwd),registryFile:e,outputDir:t$1.output}),{resolvePaths:i}=await wr(r),n=await J.readFile(i.registryFile,"utf-8"),o$1=o.safeParse(JSON.parse(n));o$1.success||(s.error(`Invalid registry file found at ${d.info(i.registryFile)}.`),process.exit(1));let a=t("Building registry...");for(let s$1 of o$1.data.items){a.start(`Building ${s$1.name}...`),s$1.$schema="https://ui.shadcn.com/schema/registry-item.json";for(let m of s$1.files??[])m.content=await J.readFile(j.resolve(i.cwd,m.path),"utf-8");let c=n$1.safeParse(s$1);if(!c.success){s.error(`Invalid registry item found for ${d.info(s$1.name)}.`);continue}await J.writeFile(j.resolve(i.outputDir,`${c.data.name}.json`),JSON.stringify(c.data,null,2));}await J.copyFile(i.registryFile,j.resolve(i.outputDir,"registry.json")),a.succeed("Building registry.");}catch(r){s.break(),Y(r);}});var xr="https://ui.shadcn.com",ln={next:"Next.js",vite:"Vite",start:"TanStack Start"},vr=new Command().name("create").description("create a new project with shadcn/ui").argument("[name]","the name of your project").option("-t, --template <template>","the template to use. e.g. next, start or vite").option("-p, --preset [name]","use a preset configuration").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("--src-dir","use the src directory when creating a new project.",false).option("--no-src-dir","do not use the src directory when creating a new project.").option("-y, --yes","skip confirmation prompt.",true).action(async(e,t)=>{try{if(!e&&!t.template&&!t.preset){let g=Sr();s.log("Build your own shadcn/ui."),s.log(`You will be taken to ${d.info(g)} to build your custom design system.`),s.break();let{proceed:w}=await Te({type:"confirm",name:"proceed",message:"Open in browser?",initial:!0});w&&await br(g),process.exit(0);}let i=e;if(!i){let{enteredName:g}=await Te({type:"text",name:"enteredName",message:"What is your project named?",initial:t.template?`${t.template}-app`:"my-app",format:w=>w.trim(),validate:w=>w.length>128?"Name should be less than 128 characters.":!0});g||process.exit(0),i=g;}let n=t.template;if(!n){let{selectedTemplate:g}=await Te({type:"select",name:"selectedTemplate",message:`Which ${d.info("template")} would you like to use?`,choices:Object.entries(ln).map(([w,C])=>({title:C,value:w}))});g||process.exit(0),n=g;}let o=await fn(t.preset??!0);o||process.exit(0);let a,s$1;"_isUrl"in o?(a=o.url,s$1=new URL(o.url).searchParams.get("baseColor")??"neutral"):(a=mn(o),s$1=o.baseColor);let c=O({}),{config:m}=await _([a],c,{silent:!0});c=m;let[l]=await _$1([a],{config:c}),p;l?.type==="registry:base"&&l.config&&(p=l.config);let u=it.parse({cwd:j__default.resolve(t.cwd),name:i,components:[a],yes:t.yes,defaults:!1,force:!1,silent:!1,isNewProject:!0,srcDir:t.srcDir,cssVariables:!0,template:n,baseColor:s$1,baseStyle:!1,registryBaseConfig:p,skipPreflight:!1}),h=await le(u);if(h){await se(["component-example"],h,{baseStyle:!1,silent:!0,overwrite:!0});let g=pn(n);g.length>0&&await K(g,h,{overwrite:!0,silent:!0});}s.log(`${d.success("Success!")} Project initialization completed.
50
- You may now add components.`),s.break();}catch(r){s.break(),Y(r);}finally{P();}});function mn(e){let t=new URLSearchParams({base:e.base,style:e.style,baseColor:e.baseColor,theme:e.theme,iconLibrary:e.iconLibrary,font:e.font,menuAccent:e.menuAccent,menuColor:e.menuColor,radius:e.radius});return `${dn()}?${t.toString()}`}async function fn(e){if(e===true){let t=await ka(),{selectedPreset:r}=await Te({type:"select",name:"selectedPreset",message:`Which ${d.info("preset")} would you like to use?`,choices:[...t.map(i=>({title:i.title,description:i.description,value:i.name})),{title:"Custom",description:"Build your own on https://ui.shadcn.com",value:"custom"}]});if(!r)return null;if(r==="custom"){let i=Sr();return s.info(`
41
+ `);let s$1=await Oe([{type:"select",name:"flag",message:"How would you like to proceed?",choices:[{title:"Use --force",value:"force"},{title:"Use --legacy-peer-deps",value:"legacy-peer-deps"}]}]);s$1&&(a=s$1.flag);}n?.start(),await gi(o,e,t$1,r.resolvedPaths.cwd,a),n?.succeed();}function di(e){let t=o$1(e.resolvedPaths.cwd,false);if(!t?.dependencies?.react)return false;let r=/^(?:\^|~)?19(?:\.\d+)*(?:-.*)?$/.test(t.dependencies.react),i=t.dependencies["react-day-picker"]?.startsWith("8");return r&&i}async function ui(e){return o$1(e.resolvedPaths.cwd,false)?.dependencies?.expo?"expo":a$1(e.resolvedPaths.cwd)}async function gi(e,t,r,i,n){if(e==="npm")return hi(t,r,i,n);if(e==="deno")return yi(t,r,i);if(e==="expo")return wi(t,r,i);t?.length&&await execa(e,["add",...t],{cwd:i}),r?.length&&await execa(e,["add","-D",...r],{cwd:i});}async function hi(e,t,r,i){e.length&&await execa("npm",["install",...i?[`--${i}`]:[],...e],{cwd:r}),t.length&&await execa("npm",["install",...i?[`--${i}`]:[],"-D",...t],{cwd:r});}async function yi(e,t,r){e?.length&&await execa("deno",["add",...e.map(i=>`npm:${i}`)],{cwd:r}),t?.length&&await execa("deno",["add","-D",...t.map(i=>`npm:${i}`)],{cwd:r});}async function wi(e,t,r){e.length&&await execa("npx",["expo","install",...e],{cwd:r}),t.length&&await execa("npx",["expo","install","-- -D",...t],{cwd:r});}async function qe(e,t$1,r){if(!e||Object.keys(e).length===0)return {envVarsAdded:[],envFileUpdated:null,envFileCreated:null};r={silent:false,...r};let i=t("Adding environment variables.",{silent:r.silent})?.start(),n=t$1.resolvedPaths.cwd,o=j__default.join(n,".env.local"),a=G(n);a&&(o=a);let s$1=existsSync(o),c=j__default.basename(o),m=Object.entries(e).map(([g,h])=>`${g}=${h}`).join(`
42
+ `),l=[],p=null,u=null;if(s$1){let g=await promises.readFile(o,"utf-8"),h=I(g,m);if(l=H$1(g,m),l.length>0){if(await promises.writeFile(o,h,"utf-8"),p=j__default.relative(n,o),i?.succeed(`Added the following variables to ${d.info(c)}:`),!r.silent)for(let y of l)s.log(` ${d.success("+")} ${y}`);}else i?.stop();}else if(await promises.writeFile(o,m+`
43
+ `,"utf-8"),u=j__default.relative(n,o),l=Object.keys(e),i?.succeed(`Added the following variables to ${d.info(c)}:`),!r.silent)for(let g of l)s.log(` ${d.success("+")} ${g}`);return !r.silent&&l.length>0&&s.break(),{envVarsAdded:l,envFileUpdated:p,envFileCreated:u}}async function Zt(e,t){if(!e.fonts?.length)return e;let r=await p(t.resolvedPaths.cwd);if(!r)return e;let[i]=e.fonts;if(e.cssVars??={},e.cssVars.theme??={},r.framework.name==="next-app"||r.framework.name==="next-pages")return e.cssVars.theme[i.font.variable]=`var(${i.font.variable})`,e;let o=`@fontsource-variable/${i.name.replace("font-","")}`;return e.dependencies??=[],e.dependencies.push(o),e.css??={},e.css[`@import "${o}"`]={},e.css["@layer base"]??={},e.css["@layer base"].html={"@apply font-sans":{}},e.css["@layer base"].body={"@apply font-sans bg-background text-foreground":{}},e.cssVars.theme[i.font.variable]=i.font.family,e}async function He(e,t$1,r){if(!e?.length)return;let i=await p(t$1.resolvedPaths.cwd);if(!i||i.framework.name!=="next-app"&&i.framework.name!=="next-pages")return;let n=t("Updating fonts.",{silent:r.silent})?.start();try{await Ii(e,t$1,i),n?.succeed("Updating fonts.");}catch(o){throw n?.fail("Failed to update fonts."),o}}async function Ii(e,t,r){let i=await ki(t,r);if(!i)return;let n=await promises.readFile(i,"utf-8"),o=await Pi(n,e);o!==n&&await promises.writeFile(i,o,"utf-8");}async function ki(e,t){let r=e.resolvedPaths.cwd,i=t.isSrcDir,o=t.isTsx?"tsx":"jsx",a=i?[`src/app/layout.${o}`,`app/layout.${o}`]:[`app/layout.${o}`];for(let s of a){let c=j__default.join(r,s);if(existsSync(c))return c}return null}async function Pi(e,t,r){let n=new Project({compilerOptions:{}}).createSourceFile("layout.tsx",e,{scriptKind:ScriptKind.TSX}),o=t.filter(s=>s.font.provider==="google"),a=[];for(let s of o){let c=s.font.import;if(!c)continue;let m=Ei(c),l=n.getImportDeclaration(g=>g.getModuleSpecifierValue()==="next/font/google"),p=ji(s);l?l.getNamedImports().some(y=>y.getName()===c)||l.addNamedImport(c):n.addImportDeclaration({moduleSpecifier:"next/font/google",namedImports:[c]});let u=$i(n,s.font.variable);if(u)u.setInitializer(`${c}(${p})`),u.getName()!==m&&u.rename(m);else {let g=Ni(n);n.insertVariableStatement(g,{declarationKind:VariableDeclarationKind.Const,declarations:[{name:m,initializer:`${c}(${p})`}]}).appendWhitespace(`
44
+ `);}a.push(m);}return a.length>0&&Oi(n,a),n.getFullText()}function ji(e){let t={};return e.font.subsets?.length&&(t.subsets=e.font.subsets),e.font.weight?.length&&(t.weight=e.font.weight),t.variable=e.font.variable,JSON.stringify(t).replace(/"([^"]+)":/g,"$1:").replace(/"/g,"'")}function Ei(e){return e.split("_").map((t,r)=>r===0?t.toLowerCase():t.charAt(0).toUpperCase()+t.slice(1).toLowerCase()).join("")}function $i(e,t){let r=e.getVariableStatements();for(let i of r)for(let n of i.getDeclarations()){let o=n.getInitializer();if(!o||o.getKind()!==SyntaxKind.CallExpression)continue;let s=o.getArguments();if(s.length===0)continue;let c=s[0].getText();if(c.includes("variable:")&&c.includes(t))return n}return null}function Ni(e){let t=e.getImportDeclarations();return t.length>0?t[t.length-1].getChildIndex()+1:0}function Oi(e,t){let r=e.getDescendantsOfKind(SyntaxKind.JsxOpeningElement);for(let i of r){if(i.getTagNameNode().getText()!=="html")continue;let o=i.getAttribute("className");if(!o){let m=t.map(l=>`${l}.variable`).join(", ");t.length===1?i.addAttribute({name:"className",initializer:`{${m}}`}):(ue(e),i.addAttribute({name:"className",initializer:`{cn(${m})}`}));return}if(o.getKind()!==SyntaxKind.JsxAttribute)return;let a=o.asKindOrThrow(SyntaxKind.JsxAttribute),s=a.getInitializer();if(!s)return;let c=t.map(m=>`${m}.variable`);if(s.getKind()===SyntaxKind.StringLiteral){let m=s.getText().slice(1,-1);ue(e),a.setInitializer(`{cn("${m}", ${c.join(", ")})}`);}else if(s.getKind()===SyntaxKind.JsxExpression){let m=s.asKindOrThrow(SyntaxKind.JsxExpression),l=m.getExpression();if(!l)return;let p=l.getText();if(p.startsWith("cn(")){if(c.every(y=>p.includes(y)))continue;let g=Fi(p),h=Ai(g,c);m.replaceWithText(`{${h}}`);}else if(/^\w+\.variable$/.test(p)){if(c.includes(p))continue;c.length===1?m.replaceWithText(`{${c[0]}}`):(ue(e),m.replaceWithText(`{cn(${c.join(", ")})}`));}else if(p.startsWith("`")&&p.endsWith("`")){let u=Ti(p);ue(e),m.replaceWithText(`{cn(${[...u,...c].join(", ")})}`);}else ue(e),m.replaceWithText(`{cn(${p}, ${c.join(", ")})}`);}}}function ue(e){if(!e.getImportDeclaration(r=>r.getNamedImports().some(n=>n.getName()==="cn"))){let r=e.getImportDeclaration(i=>i.getModuleSpecifierValue().includes("/lib/utils"));r?r.getNamedImports().some(n=>n.getName()==="cn")||r.addNamedImport("cn"):e.addImportDeclaration({moduleSpecifier:"@/lib/utils",namedImports:["cn"]});}}function Ti(e){let t=[],r=[],n=e.slice(1,-1).split(/(\$\{[^}]+\})/);for(let o of n)if(o)if(o.startsWith("${")&&o.endsWith("}")){let a=o.slice(2,-1).trim();a&&r.push(a);}else {let a=o.trim().split(/\s+/).filter(Boolean);for(let s of a)t.push(`"${s}"`);}return [...t,...r]}function Fi(e){return e.replace(/,?\s*\w+\.variable/g,"").replace(/cn\(\s*,/,"cn(")}function Ai(e,t){let r=t.join(", ");return e.replace(/\)$/,`, ${r})`)}async function se(e,t,r){r={overwrite:false,silent:false,isNewProject:false,baseStyle:true,...r};let i=await k(t);return i&&i.ui&&i.ui.resolvedPaths.cwd!==t.resolvedPaths.cwd?await Li(e,t,i,{...r,isRemote:e?.length===1&&!!e[0].match(/\/chat\/b\//)}):await _i(e,t,r)}async function _i(e,t$1,r$1){if(!r$1.baseStyle&&!e.length)return;let i=t("Checking registry.",{silent:r$1.silent})?.start(),n=await X(e,O(t$1));if(!n)return i?.fail(),Y(new Error("Failed to fetch components from registry."));try{tr(n.files??[],t$1.resolvedPaths.cwd);}catch(s){return i?.fail(),Y(s)}i?.succeed();let o=await r(t$1);n=await Zt(n,t$1),await T(n.tailwind?.config,t$1,{silent:r$1.silent,tailwindVersion:o});let a=await er(e,t$1);await Ke(n.cssVars,t$1,{cleanupDefaultNextStyles:r$1.isNewProject,silent:r$1.silent,tailwindVersion:o,tailwindConfig:n.tailwind?.config,overwriteCssVars:a,initIndex:r$1.baseStyle}),await Je(n.css,t$1,{silent:r$1.silent}),await qe(n.envVars,t$1,{silent:r$1.silent}),await W(n.dependencies,n.devDependencies,t$1,{silent:r$1.silent}),await He(n.fonts,t$1,{silent:r$1.silent}),await K(n.files,t$1,{overwrite:r$1.overwrite,silent:r$1.silent,path:r$1.path}),n.docs&&s.info(n.docs);}async function Li(e,t$1,r$1,i){if(!i.baseStyle&&!e.length)return;let n=t("Checking registry.",{silent:i.silent})?.start(),o=await X(e,O(t$1));if(!o)return n?.fail(),Y(new Error("Failed to fetch components from registry."));try{tr(o.files??[],t$1.resolvedPaths.cwd);}catch(y){return n?.fail(),Y(y)}n?.succeed();let a=[],s$1=[],c=[],m$1=t("Installing components.")?.start(),l$1=r$1.ui,p=await r(l$1),u=m(t$1.resolvedPaths.cwd,l$1.resolvedPaths.ui);if(o.tailwind?.config&&(await T(o.tailwind?.config,l$1,{silent:true,tailwindVersion:p}),s$1.push(j__default.relative(u,l$1.resolvedPaths.tailwindConfig))),o.cssVars){let y=await er(e,t$1);await Ke(o.cssVars,l$1,{silent:true,tailwindVersion:p,tailwindConfig:o.tailwind?.config,overwriteCssVars:y}),s$1.push(j__default.relative(u,l$1.resolvedPaths.tailwindCss));}o.css&&(await Je(o.css,l$1,{silent:true}),s$1.push(j__default.relative(u,l$1.resolvedPaths.tailwindCss))),o.envVars&&await qe(o.envVars,l$1,{silent:true}),await W(o.dependencies,o.devDependencies,l$1,{silent:true}),await He(o.fonts,l$1,{silent:true});let g=new Map;for(let y of o.files??[]){let C=y.type||"registry:ui";g.has(C)||g.set(C,[]),g.get(C).push(y);}for(let y of Array.from(g.keys())){let C=g.get(y),S=y==="registry:ui"?r$1.ui:t$1,K$1=m(t$1.resolvedPaths.cwd,S.resolvedPaths.ui||S.resolvedPaths.cwd),O=await l(K$1,S.resolvedPaths.cwd)??S.resolvedPaths.cwd,X=await K(C,S,{overwrite:i.overwrite,silent:true,rootSpinner:m$1,isRemote:i.isRemote,isWorkspace:true,path:i.path});a.push(...X.filesCreated.map(T=>j__default.relative(K$1,j__default.join(O,T)))),s$1.push(...X.filesUpdated.map(T=>j__default.relative(K$1,j__default.join(O,T)))),c.push(...X.filesSkipped.map(T=>j__default.relative(K$1,j__default.join(O,T))));}if(m$1?.succeed(),a.sort(),s$1.sort(),c.sort(),!(a.length||s$1.length)&&!c.length&&t("No files updated.",{silent:i.silent})?.info(),a.length){t(`Created ${a.length} ${a.length===1?"file":"files"}:`,{silent:i.silent})?.succeed();for(let y of a)s.log(` - ${y}`);}if(s$1.length){t(`Updated ${s$1.length} ${s$1.length===1?"file":"files"}:`,{silent:i.silent})?.info();for(let y of s$1)s.log(` - ${y}`);}if(c.length){t(`Skipped ${c.length} ${s$1.length===1?"file":"files"}: (use --overwrite to overwrite)`,{silent:i.silent})?.info();for(let y of c)s.log(` - ${y}`);}o.docs&&s.info(o.docs);}async function er(e,t){let r=await _(e,{config:t});return z.array(n$1).parse(r).some(n=>n.type==="registry:theme"||n.type==="registry:style"||n.type==="registry:font"||n.type==="registry:base")}function tr(e,t){for(let r of e)if(r?.target&&!Gt(r.target,t))throw new Error(`We found an unsafe file path "${r.target} in the registry item. Installation aborted.`)}var Ze="https://codeload.github.com/shadcn-ui/ui/tar.gz/main",A={next:"next","next-monorepo":"next-monorepo",vite:"vite",start:"start"};async function rr(e){e={srcDir:false,...e};let t=e.template&&A[e.template]?e.template:"next",r=e.name??(t===A.next||t===A.vite||t===A.start?"my-app":"my-monorepo"),i="latest",n=e.components?.length===1&&!!e.components[0].match(/\/chat\/b\//);if(e.components&&n)try{let[s]=await S(e.components),{meta:c}=z.object({meta:z.object({nextVersion:z.string()})}).parse(s);i=c.nextVersion,t=A.next;}catch(s$1){s.break(),Y(s$1);}if(!e.force){let{type:s,name:c}=await Oe([{type:e.template||n?null:"select",name:"type",message:`The path ${d.info(e.cwd)} does not contain a package.json file.
45
+ Would you like to start a new project?`,choices:[{title:"Next.js",value:"next"},{title:"Next.js (Monorepo)",value:"next-monorepo"},{title:"Vite",value:"vite"},{title:"TanStack Start",value:"start"}],initial:0},{type:e.name?null:"text",name:"name",message:"What is your project named?",initial:r,format:m=>m.trim(),validate:m=>m.length>128?"Name should be less than 128 characters.":true}]);t=s??t,r=c??r;}let o=await a$1(e.cwd,{withFallback:true}),a=`${e.cwd}/${r}`;try{await v.access(e.cwd,v.constants.W_OK);}catch{s.break(),s.error(`The path ${d.info(e.cwd)} is not writable.`),s.error(`It is likely you do not have write permissions for this folder or the path ${d.info(e.cwd)} does not exist.`),s.break(),process.exit(1);}return v.existsSync(j__default.resolve(e.cwd,r,"package.json"))&&(s.break(),s.error(`A project with the name ${d.info(r)} already exists.`),s.error("Please choose a different name and try again."),s.break(),process.exit(1)),t===A.next&&await Wi(a,{version:i,cwd:e.cwd,packageManager:o,srcDir:!!e.srcDir}),t===A["next-monorepo"]&&await Mi(a,{packageManager:o}),t===A.vite&&await zi(a,{packageManager:o}),t===A.start&&await Bi(a,{packageManager:o}),{projectPath:a,projectName:r,template:t}}async function Wi(e,t$1){let r=t("Creating a new Next.js project. This may take a few minutes.").start(),i=["--tailwind","--eslint","--typescript","--app",t$1.srcDir?"--src-dir":"--no-src-dir","--no-import-alias",`--use-${t$1.packageManager}`];(t$1.version.startsWith("15")||t$1.version.startsWith("latest")||t$1.version.startsWith("canary"))&&i.push("--turbopack"),(t$1.version.startsWith("latest")||t$1.version.startsWith("canary"))&&i.push("--no-react-compiler");try{await execa("npx",[`create-next-app@${t$1.version}`,e,"--silent",...i],{cwd:t$1.cwd});}catch{s.break(),s.error("Something went wrong creating a new Next.js project. Please try again."),process.exit(1);}r?.succeed("Creating a new Next.js project.");}async function Mi(e,t$1){let r=t("Creating a new Next.js monorepo. This may take a few minutes.").start();try{let i=j__default.join(Qe.tmpdir(),`shadcn-template-${Date.now()}`);await v.ensureDir(i);let n=await fetch(Ze);if(!n.ok)throw new Error(`Failed to download template: ${n.statusText}`);let o=j__default.resolve(i,"template.tar.gz");await v.writeFile(o,Buffer.from(await n.arrayBuffer())),await execa("tar",["-xzf",o,"-C",i,"--strip-components=2","ui-main/templates/monorepo-next"]);let a=j__default.resolve(i,"monorepo-next");await v.move(a,e),await v.remove(i),await execa(t$1.packageManager,["install"],{cwd:e});let s=j__default.join(e,"package.json");if(v.existsSync(s)){let m=await v.readFile(s,"utf8"),l=JSON.parse(m);l.name=e.split("/").pop(),await v.writeFile(s,JSON.stringify(l,null,2));}let c=process.cwd();await execa("git",["--version"],{cwd:e}),await execa("git",["init"],{cwd:e}),await execa("git",["add","-A"],{cwd:e}),await execa("git",["commit","-m","Initial commit"],{cwd:e}),r?.succeed("Creating a new Next.js monorepo.");}catch(i){r?.fail("Something went wrong creating a new Next.js monorepo."),Y(i);}}async function zi(e,t$1){let r=t("Creating a new Vite project. This may take a few minutes.").start();try{let i=j__default.join(Qe.tmpdir(),`shadcn-template-${Date.now()}`);await v.ensureDir(i);let n=await fetch(Ze);if(!n.ok)throw new Error(`Failed to download template: ${n.statusText}`);let o=j__default.resolve(i,"template.tar.gz");await v.writeFile(o,Buffer.from(await n.arrayBuffer())),await execa("tar",["-xzf",o,"-C",i,"--strip-components=2","ui-main/templates/vite-app"]);let a=j__default.resolve(i,"vite-app");if(await v.move(a,e),await v.remove(i),t$1.packageManager!=="pnpm"){let c=j__default.join(e,"pnpm-lock.yaml");v.existsSync(c)&&await v.remove(c);}await execa(t$1.packageManager,["install"],{cwd:e});let s=j__default.join(e,"package.json");if(v.existsSync(s)){let c=await v.readFile(s,"utf8"),m=JSON.parse(c);m.name=e.split("/").pop(),await v.writeFile(s,JSON.stringify(m,null,2));}await execa("git",["--version"],{cwd:e}),await execa("git",["init"],{cwd:e}),await execa("git",["add","-A"],{cwd:e}),await execa("git",["commit","-m","Initial commit"],{cwd:e}),r?.succeed("Creating a new Vite project.");}catch(i){r?.fail("Something went wrong creating a new Vite project."),Y(i);}}async function Bi(e,t$1){let r=t("Creating a new TanStack Start project. This may take a few minutes.").start();try{let i=j__default.join(Qe.tmpdir(),`shadcn-template-${Date.now()}`);await v.ensureDir(i);let n=await fetch(Ze);if(!n.ok)throw new Error(`Failed to download template: ${n.statusText}`);let o=j__default.resolve(i,"template.tar.gz");await v.writeFile(o,Buffer.from(await n.arrayBuffer())),await execa("tar",["-xzf",o,"-C",i,"--strip-components=2","ui-main/templates/start-app"]);let a=j__default.resolve(i,"start-app");if(await v.move(a,e),await v.remove(i),t$1.packageManager!=="pnpm"){let c=j__default.join(e,"pnpm-lock.yaml");v.existsSync(c)&&await v.remove(c);}await execa(t$1.packageManager,["install"],{cwd:e});let s=j__default.join(e,"package.json");if(v.existsSync(s)){let c=await v.readFile(s,"utf8"),m=JSON.parse(c);m.name=e.split("/").pop(),await v.writeFile(s,JSON.stringify(m,null,2));}await execa("git",["--version"],{cwd:e}),await execa("git",["init"],{cwd:e}),await execa("git",["add","-A"],{cwd:e}),await execa("git",["commit","-m","Initial commit"],{cwd:e}),r?.succeed("Creating a new TanStack Start project.");}catch(i){r?.fail("Something went wrong creating a new TanStack Start project."),Y(i);}}async function M(e=process.cwd()){try{let{config:t}=await import('@dotenvx/dotenvx'),r=[".env.local",".env.development.local",".env.development",".env"];for(let i of r){let n=join(e,i);existsSync(n)&&t({path:n,overload:!1,quiet:!0});}}catch(t){s.warn("Failed to load env files:",t);}}var ge=".bak";function ir(e){if(!v.existsSync(e))return null;let t=`${e}${ge}`;try{return v.renameSync(e,t),t}catch(r){return console.error(`Failed to create backup of ${e}: ${r}`),null}}function nr(e){let t=`${e}${ge}`;if(!v.existsSync(t))return false;try{return v.renameSync(t,e),!0}catch(r){return console.error(`Warning: Could not restore backup file ${t}: ${r}`),false}}function et(e){let t=`${e}${ge}`;if(!v.existsSync(t))return false;try{return v.unlinkSync(t),!0}catch{return false}}async function or(e,t){let r=new Set,i=new Set,n=[...e];for(;n.length>0;){let o=n.shift();if(i.has(o))continue;i.add(o);let{registry:a}=F(o);a&&!b[a]&&r.add(a);try{let[s]=await W$1([o],t,{useCache:!0});if(s?.registryDependencies)for(let c of s.registryDependencies){let{registry:m}=F(c);m&&!b[m]&&r.add(m),i.has(c)||n.push(c);}}catch(s){if(s instanceof z$1){let{registry:c}=F(o);c&&!b[c]&&r.add(c);continue}continue}}return Array.from(r)}async function D(e,t$1,r={}){r={silent:false,writeFile:true,...r};let n=(await or(e,t$1)).filter(m=>!t$1.registries?.[m]&&!Object.keys(b).includes(m));if(n.length===0)return {config:t$1,newRegistries:[]};let o=await ja({useCache:process.env.NODE_ENV!=="development"});if(!o)return {config:t$1,newRegistries:[]};let a={};for(let m of n)o[m]&&(a[m]=o[m]);if(Object.keys(a).length===0)return {config:t$1,newRegistries:[]};let s=Object.fromEntries(Object.entries(t$1.registries||{}).filter(([m])=>!Object.keys(b).includes(m))),c$1={...t$1,registries:{...s,...a}};if(r.writeFile){let{resolvedPaths:m,...l}=c$1,p=t("Updating components.json.",{silent:r.silent}).start(),u=c.parse(l);await v.writeFile(j__default.resolve(t$1.resolvedPaths.cwd,"components.json"),JSON.stringify(u,null,2)+`
46
+ `,"utf-8"),p.succeed();}return {config:c$1,newRegistries:Object.keys(a)}}async function ar(e,t$1,r){if(!e)return;r={silent:false,...r};let i=j__default.relative(t$1.resolvedPaths.cwd,t$1.resolvedPaths.tailwindConfig),n=t(`Updating ${d.info(i)}`,{silent:r.silent}).start(),o=await promises.readFile(t$1.resolvedPaths.tailwindConfig,"utf8"),a=await qi(o,e,t$1);await promises.writeFile(t$1.resolvedPaths.tailwindConfig,a,"utf8"),n?.succeed();}async function qi(e,t,r){let i=await U(e,r),n=i.getDescendantsOfKind(SyntaxKind.ObjectLiteralExpression).find(o=>o.getProperties().some(a=>a.isKind(SyntaxKind.PropertyAssignment)&&a.getName()==="content"));return n?(Hi(n,t),i.getFullText()):e}async function Hi(e,t){let r=V(e),i=e.getProperty("content");if(!i){let n={name:"content",initializer:`[${r}${t.join(`${r}, ${r}`)}${r}]`};return e.addPropertyAssignment(n),e}if(i.isKind(SyntaxKind.PropertyAssignment)){let n=i.getInitializer();if(n?.isKind(SyntaxKind.ArrayLiteralExpression))for(let o of t){let a=`${r}${o}${r}`;n.getElements().map(s=>s.getText()).includes(a)||n.addElement(a);}return e}return e}process.on("exit",e=>{let t=j__default.resolve(process.cwd(),"components.json");return e===0?et(t):nr(t)});var rt=z.object({cwd:z.string(),name:z.string().optional(),components:z.array(z.string()).optional(),yes:z.boolean(),defaults:z.boolean(),force:z.boolean(),silent:z.boolean(),isNewProject:z.boolean(),srcDir:z.boolean().optional(),cssVariables:z.boolean(),template:z.string().optional().refine(e=>e?A[e]:true,{message:"Invalid template. Please use 'next', 'vite', 'start' or 'next-monorepo'."}),baseColor:z.string().optional().refine(e=>e?a.find(t=>t.name===e):true,{message:`Invalid base color. Please use '${a.map(e=>e.name).join("', '")}'`}),baseStyle:z.boolean(),registryBaseConfig:c.deepPartial().optional()}),lr=new Command().name("init").description("initialize your project and install dependencies").argument("[components...]","names, url or local path to component").option("-t, --template <template>","the template to use. (next, start, vite, next-monorepo)").option("-b, --base-color <base-color>","the base color to use. (neutral, gray, zinc, stone, slate)",void 0).option("-y, --yes","skip confirmation prompt.",true).option("-d, --defaults,","use default configuration.",false).option("-f, --force","force overwrite of existing configuration.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-s, --silent","mute output.",false).option("--src-dir","use the src directory when creating a new project.",false).option("--no-src-dir","do not use the src directory when creating a new project.").option("--css-variables","use css variables for theming.",true).option("--no-css-variables","do not use css variables for theming.").option("--no-base-style","do not install the base shadcn style.").action(async(e,t)=>{try{t.defaults&&(t.template=t.template||"next",t.baseColor=t.baseColor||"neutral");let r=rt.parse({cwd:j__default.resolve(t.cwd),isNewProject:!1,components:e,...t});if(await M(r.cwd),e.length>0){let i=O(n({resolvedPaths:{cwd:r.cwd}})),n$1=j__default.resolve(r.cwd,"components.json");if(v.existsSync(n$1)){let s=await v.readJson(n$1),c$1=c.partial().parse(s),m=n({resolvedPaths:{cwd:r.cwd}});i=O({...c$1,resolvedPaths:{...m.resolvedPaths,cwd:r.cwd}}),ir(n$1);}let{config:o}=await D(e,i,{silent:!0,writeFile:!1});i=o,R(e[0],i);let[a]=await _([e[0]],{config:i});a?.type==="registry:base"&&(a.config&&(i=O(cr(i,a.config)),r.registryBaseConfig=a.config),r.baseStyle=a.extends==="none"?!1:r.baseStyle),a?.type==="registry:style"&&(r.baseColor="neutral",r.baseStyle=a.extends==="none"?!1:r.baseStyle);}r.baseStyle||(r.baseColor="neutral"),await he(r),s.log(`${d.success("Success!")} Project initialization completed.
47
+ You may now add components.`),et(j__default.resolve(r.cwd,"components.json")),s.break();}catch(r){s.break(),Y(r);}finally{P();}});async function he(e){let t$1,r;if(e.skipPreflight)t$1=await p(e.cwd);else {let g=await Ut(e);if(g.errors["1"]){let{projectPath:h,template:y}=await rr(e);h||process.exit(1),e.cwd=h,e.isNewProject=true,r=y,t$1=await p(e.cwd);}else t$1=g.projectInfo;}if(r==="next-monorepo")return e.cwd=j__default.resolve(e.cwd,"apps/web"),await i(e.cwd);let i$1=await q(e.cwd,t$1),n=i$1?await Zi(i$1,e):await Qi(await i(e.cwd));if(!e.yes){let{proceed:g}=await Oe({type:"confirm",name:"proceed",message:`Write configuration to ${d.info("components.json")}. Proceed?`,initial:true});g||process.exit(0);}let o=[...e.baseStyle?["index"]:[],...e.components??[]],a=await j$1(e.cwd,n),{config:s}=await D(o,a,{silent:true});s.registries&&(n.registries=s.registries);let c=t("Writing components.json.").start(),l=`${j__default.resolve(e.cwd,"components.json")}${ge}`,p$1=(g,h)=>{let{registries:y,...C}=cr(g,h);return {...C,registries:y}};if(!e.force&&v.existsSync(l)){let g=await v.readJson(l);n=p$1(g,n);}e.registryBaseConfig&&(n=p$1(n,e.registryBaseConfig)),n.registries=Object.fromEntries(Object.entries(n.registries||{}).filter(([g])=>!Object.keys(b).includes(g))),c.succeed();let u=await j$1(e.cwd,n);return await se(o,u,{overwrite:true,silent:e.silent,baseStyle:e.baseStyle,isNewProject:e.isNewProject||t$1?.framework.name==="next-app"}),e.isNewProject&&e.srcDir&&await ar(["./src/**/*.{js,ts,jsx,tsx,mdx}"],u,{silent:e.silent}),u}async function Qi(e$1=null){let[t,r]=await Promise.all([ca(),ea()]);s.info("");let i=await Oe([{type:"toggle",name:"typescript",message:`Would you like to use ${d.info("TypeScript")} (recommended)?`,initial:e$1?.tsx??true,active:"yes",inactive:"no"},{type:"select",name:"style",message:`Which ${d.info("style")} would you like to use?`,choices:t.map(n=>({title:n.label,value:n.name}))},{type:"select",name:"tailwindBaseColor",message:`Which color would you like to use as the ${d.info("base color")}?`,choices:r.map(n=>({title:n.label,value:n.name}))},{type:"text",name:"tailwindCss",message:`Where is your ${d.info("global CSS")} file?`,initial:e$1?.tailwind.css??g},{type:"toggle",name:"tailwindCssVariables",message:`Would you like to use ${d.info("CSS variables")} for theming?`,initial:e$1?.tailwind.cssVariables??true,active:"yes",inactive:"no"},{type:"text",name:"tailwindPrefix",message:`Are you using a custom ${d.info("tailwind prefix eg. tw-")}? (Leave blank if not)`,initial:""},{type:"text",name:"tailwindConfig",message:`Where is your ${d.info("tailwind.config.js")} located?`,initial:e$1?.tailwind.config??h},{type:"text",name:"components",message:`Configure the import alias for ${d.info("components")}:`,initial:e$1?.aliases.components??e},{type:"text",name:"utils",message:`Configure the import alias for ${d.info("utils")}:`,initial:e$1?.aliases.utils??f},{type:"toggle",name:"rsc",message:`Are you using ${d.info("React Server Components")}?`,initial:e$1?.rsc??true,active:"yes",inactive:"no"}]);return c.parse({$schema:"https://ui.shadcn.com/schema.json",style:i.style,tailwind:{config:i.tailwindConfig,css:i.tailwindCss,baseColor:i.tailwindBaseColor,cssVariables:i.tailwindCssVariables,prefix:i.tailwindPrefix},rsc:i.rsc,tsx:i.typescript,aliases:{utils:i.utils,components:i.components,lib:i.components.replace(/\/components$/,"lib"),hooks:i.components.replace(/\/components$/,"hooks")}})}async function Zi(e,t){let r$1=e.style,i=t.baseColor,n=e.tailwind.cssVariables,o=e.iconLibrary??"lucide";if(!t.defaults){let[a,s,c]=await Promise.all([ca(),ea(),r(e)]),m=await Oe([{type:c==="v4"||r$1?null:"select",name:"style",message:`Which ${d.info("style")} would you like to use?`,choices:a.map(l=>({title:l.name==="new-york"?"New York (Recommended)":l.label,value:l.name})),initial:0},{type:t.baseColor?null:"select",name:"tailwindBaseColor",message:`Which color would you like to use as the ${d.info("base color")}?`,choices:s.map(l=>({title:l.label,value:l.name}))}]);r$1=m.style??r$1??"new-york",i=m.tailwindBaseColor??i,n=t.cssVariables;}return c.parse({$schema:e?.$schema,style:r$1,tailwind:{...e?.tailwind,baseColor:i,cssVariables:n},rsc:e?.rsc,tsx:e?.tsx,iconLibrary:o,aliases:e?.aliases})}async function fr(e){let t={};if(!v.existsSync(e.cwd)||!v.existsSync(j__default.resolve(e.cwd,"package.json")))return t["1"]=true,{errors:t,config:null};if(!v.existsSync(j__default.resolve(e.cwd,"components.json")))return t["3"]=true,{errors:t,config:null};try{let r=await i(e.cwd);return {errors:t,config:r}}catch{s.break(),s.error(`An invalid ${d.info("components.json")} file was found at ${d.info(e.cwd)}.
48
+ Before you can add components, you must create a valid ${d.info("components.json")} file by running the ${d.info("init")} command.`),s.error(`Learn more at ${d.info("https://ui.shadcn.com/docs/components-json")}.`),s.break(),process.exit(1);}}var rn=z.object({components:z.array(z.string()).optional(),yes:z.boolean(),overwrite:z.boolean(),cwd:z.string(),all:z.boolean(),path:z.string().optional(),silent:z.boolean(),srcDir:z.boolean().optional(),cssVariables:z.boolean()}),dr=new Command().name("add").description("add a component to your project").argument("[components...]","names, url or local path to component").option("-y, --yes","skip confirmation prompt.",false).option("-o, --overwrite","overwrite existing files.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-a, --all","add all available components",false).option("-p, --path <path>","the path to add the component to.").option("-s, --silent","mute output.",false).option("--src-dir","use the src directory when creating a new project.",false).option("--no-src-dir","do not use the src directory when creating a new project.").option("--css-variables","use css variables for theming.",true).option("--no-css-variables","do not use css variables for theming.").action(async(e,t)=>{try{let r=rn.parse({components:e,cwd:j__default.resolve(t.cwd),...t});await M(r.cwd);let i$1=await i(r.cwd);i$1||(i$1=n({style:"new-york",resolvedPaths:{cwd:r.cwd}}));let n$1=["sidebar-","login-","signup-","otp-","calendar-"],o=["base-","radix-"];if(e.length>0&&i$1?.style&&o.some(h=>i$1?.style.startsWith(h))){let h=e.filter(y=>n$1.some(C=>y.startsWith(C)));h.length&&(s.warn(`The ${d.info(h.map(y=>y).join(", "))} component(s) are not available for the ${d.info(i$1.style)} style yet. They are coming soon.`),s.warn("In the meantime, you can visit the blocks page on https://ui.shadcn.com/blocks and copy the code."),s.break(),process.exit(1));}let a=!1;if(e.length>0){let{config:g,newRegistries:h}=await D(e,i$1,{silent:r.silent,writeFile:!1});i$1=g,a=h.length>0;}let s$1,c=!0;if(e.length>0){let[g]=await _([e[0]],{config:i$1});if(s$1=g?.type,c=s$1!=="registry:theme"&&s$1!=="registry:style",N(g)){await se(e,i$1,{...r,baseStyle:c});return}if(!r.yes&&(s$1==="registry:style"||s$1==="registry:theme")){s.break();let{confirm:h}=await Oe({type:"confirm",name:"confirm",message:d.warn(`You are about to install a new ${s$1.replace("registry:","")}.
49
+ Existing CSS variables and components will be overwritten. Continue?`)});h||(s.break(),s.log("Installation cancelled."),s.break(),process.exit(1));}}if(r.components?.length||(r.components=await nn(r)),(await p(r.cwd))?.tailwindVersion==="v4"){let g=c$1.filter(h=>r.components?.includes(h.name));g?.length&&(s.break(),g.forEach(h=>{s.warn(d.warn(h.message));}),s.break(),process.exit(1));}let{errors:l,config:p$1}=await fr(r);console.log({errors:l,config:p$1});let u=!1;l["3"]&&(p$1=await he({cwd:r.cwd,yes:!0,force:!0,defaults:!1,skipPreflight:!1,silent:r.silent&&!a,isNewProject:!1,srcDir:r.srcDir,cssVariables:r.cssVariables,baseStyle:c,baseColor:c?void 0:"neutral",components:r.components}),u=!0);}catch(r){console.log("add error"),s.break(),Y(r);}finally{P();}});async function nn(e){let t=await ba();if(!t)return s.break(),Y(new Error("Failed to fetch registry index.")),[];if(e.all)return t.map(n=>n.name).filter(n=>!c$1.some(o=>o.name===n));if(e.components?.length)return e.components;let{components:r}=await Oe({type:"multiselect",name:"components",message:"Which components would you like to add?",hint:"Space to select. A to toggle all. Enter to submit.",instructions:false,choices:t.filter(n=>n.type==="registry:ui"&&!c$1.some(o=>o.name===n.name)).map(n=>({title:n.name,value:n.name,selected:e.all?true:e.components?.includes(n.name)}))});r?.length||(s.warn("No components selected. Exiting."),s.info(""),process.exit(1));let i=z.array(z.string()).safeParse(r);return i.success?i.data:(s.error(""),Y(new Error("Something went wrong. Please try again.")),[])}async function hr(e){let t={},r={cwd:e.cwd,registryFile:j__default.resolve(e.cwd,e.registryFile),outputDir:j__default.resolve(e.cwd,e.outputDir)};return v.existsSync(r.registryFile)||(t["13"]=true),await v.mkdir(r.outputDir,{recursive:true}),Object.keys(t).length>0&&(t["13"]&&(s.break(),s.error(`The path ${d.info(r.registryFile)} does not exist.`)),s.break(),process.exit(1)),{errors:t,resolvePaths:r}}var sn=z.object({cwd:z.string(),registryFile:z.string(),outputDir:z.string()}),yr=new Command().name("build").description("build components for a shadcn registry").argument("[registry]","path to registry.json file","./registry.json").option("-o, --output <path>","destination directory for json files","./public/r").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t$1)=>{try{let r=sn.parse({cwd:j.resolve(t$1.cwd),registryFile:e,outputDir:t$1.output}),{resolvePaths:i}=await hr(r),n=await J.readFile(i.registryFile,"utf-8"),o$1=o.safeParse(JSON.parse(n));o$1.success||(s.error(`Invalid registry file found at ${d.info(i.registryFile)}.`),process.exit(1));let a=t("Building registry...");for(let s$1 of o$1.data.items){a.start(`Building ${s$1.name}...`),s$1.$schema="https://ui.shadcn.com/schema/registry-item.json";for(let m of s$1.files??[])m.content=await J.readFile(j.resolve(i.cwd,m.path),"utf-8");let c=n$1.safeParse(s$1);if(!c.success){s.error(`Invalid registry item found for ${d.info(s$1.name)}.`);continue}await J.writeFile(j.resolve(i.outputDir,`${c.data.name}.json`),JSON.stringify(c.data,null,2));}await J.copyFile(i.registryFile,j.resolve(i.outputDir,"registry.json")),a.succeed("Building registry.");}catch(r){s.break(),Y(r);}});var br="https://ui.shadcn.com",ln={next:"Next.js",vite:"Vite",start:"TanStack Start"},xr=new Command().name("create").description("create a new project with shadcn/ui").argument("[name]","the name of your project").option("-t, --template <template>","the template to use. e.g. next, start or vite").option("-p, --preset [name]","use a preset configuration").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("--src-dir","use the src directory when creating a new project.",false).option("--no-src-dir","do not use the src directory when creating a new project.").option("-y, --yes","skip confirmation prompt.",true).action(async(e,t)=>{try{if(!e&&!t.template&&!t.preset){let h=vr();s.log("Build your own shadcn/ui."),s.log(`You will be taken to ${d.info(h)} to build your custom design system.`),s.break();let{proceed:y}=await Oe({type:"confirm",name:"proceed",message:"Open in browser?",initial:!0});y&&await wr(h),process.exit(0);}let i=e;if(!i){let{enteredName:h}=await Oe({type:"text",name:"enteredName",message:"What is your project named?",initial:t.template?`${t.template}-app`:"my-app",format:y=>y.trim(),validate:y=>y.length>128?"Name should be less than 128 characters.":!0});h||process.exit(0),i=h;}let n=t.template;if(!n){let{selectedTemplate:h}=await Oe({type:"select",name:"selectedTemplate",message:`Which ${d.info("template")} would you like to use?`,choices:Object.entries(ln).map(([y,C])=>({title:C,value:y}))});h||process.exit(0),n=h;}let o=await fn(t.preset??!0);o||process.exit(0);let a,s$1;"_isUrl"in o?(a=o.url,s$1=new URL(o.url).searchParams.get("baseColor")??"neutral"):(a=mn(o),s$1=o.baseColor);let c=O({}),{config:m}=await D([a],c,{silent:!0});c=m;let[l]=await _([a],{config:c}),p;l?.type==="registry:base"&&l.config&&(p=l.config);let u=rt.parse({cwd:j__default.resolve(t.cwd),name:i,components:[a],yes:t.yes,defaults:!1,force:!1,silent:!1,isNewProject:!0,srcDir:t.srcDir,cssVariables:!0,template:n,baseColor:s$1,baseStyle:!1,registryBaseConfig:p,skipPreflight:!1}),g=await he(u);if(g){await se(["component-example"],g,{baseStyle:!1,silent:!0,overwrite:!0});let h=pn(n);h.length>0&&await K(h,g,{overwrite:!0,silent:!0});}s.log(`${d.success("Success!")} Project initialization completed.
50
+ You may now add components.`),s.break();}catch(r){s.break(),Y(r);}finally{P();}});function mn(e){let t=new URLSearchParams({base:e.base,style:e.style,baseColor:e.baseColor,theme:e.theme,iconLibrary:e.iconLibrary,font:e.font,menuAccent:e.menuAccent,menuColor:e.menuColor,radius:e.radius});return `${dn()}?${t.toString()}`}async function fn(e){if(e===true){let t=await ka(),{selectedPreset:r}=await Oe({type:"select",name:"selectedPreset",message:`Which ${d.info("preset")} would you like to use?`,choices:[...t.map(i=>({title:i.title,description:i.description,value:i.name})),{title:"Custom",description:"Build your own on https://ui.shadcn.com",value:"custom"}]});if(!r)return null;if(r==="custom"){let i=vr();return s.info(`
51
51
  Opening ${d.info(i)} in your browser...
52
- `),await br(i),null}return t.find(i=>i.name===r)??null}if(typeof e=="string"){if(M(e))return {_isUrl:true,url:e};let t=await la(e);if(!t){let i=(await ka()).map(n=>n.name).join(", ");s.error(`Preset "${e}" not found. Available presets: ${i}`),process.exit(1);}return t}return null}function pn(e){switch(e){case "vite":return [{type:"registry:file",path:"src/App.tsx",target:"src/App.tsx",content:st`import { ComponentExample } from "@/components/component-example";
52
+ `),await wr(i),null}return t.find(i=>i.name===r)??null}if(typeof e=="string"){if(M$1(e))return {_isUrl:true,url:e};let t=await la(e);if(!t){let i=(await ka()).map(n=>n.name).join(", ");s.error(`Preset "${e}" not found. Available presets: ${i}`),process.exit(1);}return t}return null}function pn(e){switch(e){case "vite":return [{type:"registry:file",path:"src/App.tsx",target:"src/App.tsx",content:nt`import { ComponentExample } from "@/components/component-example";
53
53
 
54
54
  export function App() {
55
55
  return <ComponentExample />;
56
56
  }
57
57
 
58
58
  export default App;
59
- `}];case "next":return [{type:"registry:page",path:"app/page.tsx",target:"app/page.tsx",content:st`import { ComponentExample } from "@/components/component-example";
59
+ `}];case "next":return [{type:"registry:page",path:"app/page.tsx",target:"app/page.tsx",content:nt`import { ComponentExample } from "@/components/component-example";
60
60
 
61
61
  export default function Page() {
62
62
  return <ComponentExample />;
63
63
  }
64
- `}];case "start":return [{type:"registry:file",path:"src/routes/index.tsx",target:"src/routes/index.tsx",content:st`import { createFileRoute } from "@tanstack/react-router";
64
+ `}];case "start":return [{type:"registry:file",path:"src/routes/index.tsx",target:"src/routes/index.tsx",content:nt`import { createFileRoute } from "@tanstack/react-router";
65
65
  import { ComponentExample } from "@/components/component-example";
66
66
 
67
67
  export const Route = createFileRoute("/")({ component: App });
@@ -71,18 +71,18 @@ function App() {
71
71
  <ComponentExample />
72
72
  );
73
73
  }
74
- `}];default:return []}}function Sr(){return `${xr}/create`}function dn(){return `${xr}/init`}var wn=z$1.object({component:z$1.string().optional(),yes:z$1.boolean(),cwd:z$1.string(),path:z$1.string().optional()}),Cr=new Command().name("diff").description("check for updates against the registry").argument("[component]","the component name").option("-y, --yes","skip confirmation prompt.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{try{let r=wn.parse({component:e,...t}),i$1=j__default.resolve(r.cwd);existsSync(i$1)||(s.error(`The path ${i$1} does not exist. Please try again.`),process.exit(1));let n=await i(i$1);n||(s.warn(`Configuration is missing. Please run ${d.success("init")} to create a components.json file.`),process.exit(1));let o=await ba();if(o||(Y(new Error("Failed to fetch registry index.")),process.exit(1)),!r.component){let c=n.resolvedPaths.components,m=o.filter(p=>{for(let u of p.files??[]){let h=j__default.resolve(c,typeof u=="string"?u:u.path);if(existsSync(h))return !0}return !1}),l=[];for(let p of m){let u=await Rr(p,n);u.length&&l.push({name:p.name,changes:u});}l.length||(s.info("No updates found."),process.exit(0)),s.info("The following components have updates available:");for(let p of l){s.info(`- ${p.name}`);for(let u of p.changes)s.info(` - ${u.filePath}`);}s.break(),s.info(`Run ${d.success("diff <component>")} to see the changes.`),process.exit(0);}let a=o.find(c=>c.name===r.component);a||(s.error(`The component ${d.success(r.component)} does not exist.`),process.exit(1));let s$1=await Rr(a,n);s$1.length||(s.info(`No updates found for ${r.component}.`),process.exit(0));for(let c of s$1)s.info(`- ${c.filePath}`),await yn(c.patch),s.info("");}catch(r){Y(r);}});async function Rr(e,t){let r=await ha(t.style,[e]),i=await fa(t.tailwind.baseColor);if(!r)return [];let n=[];for(let o of r){let a=await ia(t,o);if(a)for(let s of o.files??[]){let c=j__default.resolve(a,typeof s=="string"?s:s.path);if(!existsSync(c))continue;let m=await promises.readFile(c,"utf8");if(typeof s=="string"||!s.content)continue;let l=await J$1({filename:s.path,raw:s.content,config:t,baseColor:i}),p=diffLines(l,m);p.length>1&&n.push({filePath:c,patch:p});}}return n}async function yn(e){e.forEach(t=>{if(t)return t.added?process.stdout.write(d.success(t.value)):t.removed?process.stdout.write(d.error(t.value)):process.stdout.write(t.value)});}var Ir=new Command().name("info").description("get information about your project").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{try{s.info("> project info"),console.log(await p(e.cwd)),s.break(),s.info("> components.json"),console.log(await i(e.cwd));}catch(t){Y(t);}});var fe="latest",Ae=[{name:"claude",label:"Claude Code",configPath:".mcp.json",config:{mcpServers:{shadcn:{command:"npx",args:[`shadcn@${fe}`,"mcp"]}}}},{name:"cursor",label:"Cursor",configPath:".cursor/mcp.json",config:{mcpServers:{shadcn:{command:"npx",args:[`shadcn@${fe}`,"mcp"]}}}},{name:"vscode",label:"VS Code",configPath:".vscode/mcp.json",config:{servers:{shadcn:{command:"npx",args:[`shadcn@${fe}`,"mcp"]}}}},{name:"codex",label:"Codex",configPath:".codex/config.toml",config:`[mcp_servers.shadcn]
74
+ `}];default:return []}}function vr(){return `${br}/create`}function dn(){return `${br}/init`}var yn=z.object({component:z.string().optional(),yes:z.boolean(),cwd:z.string(),path:z.string().optional()}),Rr=new Command().name("diff").description("check for updates against the registry").argument("[component]","the component name").option("-y, --yes","skip confirmation prompt.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{try{let r=yn.parse({component:e,...t}),i$1=j__default.resolve(r.cwd);existsSync(i$1)||(s.error(`The path ${i$1} does not exist. Please try again.`),process.exit(1));let n=await i(i$1);n||(s.warn(`Configuration is missing. Please run ${d.success("init")} to create a components.json file.`),process.exit(1));let o=await ba();if(o||(Y(new Error("Failed to fetch registry index.")),process.exit(1)),!r.component){let c=n.resolvedPaths.components,m=o.filter(p=>{for(let u of p.files??[]){let g=j__default.resolve(c,typeof u=="string"?u:u.path);if(existsSync(g))return !0}return !1}),l=[];for(let p of m){let u=await Sr(p,n);u.length&&l.push({name:p.name,changes:u});}l.length||(s.info("No updates found."),process.exit(0)),s.info("The following components have updates available:");for(let p of l){s.info(`- ${p.name}`);for(let u of p.changes)s.info(` - ${u.filePath}`);}s.break(),s.info(`Run ${d.success("diff <component>")} to see the changes.`),process.exit(0);}let a=o.find(c=>c.name===r.component);a||(s.error(`The component ${d.success(r.component)} does not exist.`),process.exit(1));let s$1=await Sr(a,n);s$1.length||(s.info(`No updates found for ${r.component}.`),process.exit(0));for(let c of s$1)s.info(`- ${c.filePath}`),await wn(c.patch),s.info("");}catch(r){Y(r);}});async function Sr(e,t){let r=await ha(t.style,[e]),i=await fa(t.tailwind.baseColor);if(!r)return [];let n=[];for(let o of r){let a=await ia(t,o);if(a)for(let s of o.files??[]){let c=j__default.resolve(a,typeof s=="string"?s:s.path);if(!existsSync(c))continue;let m=await promises.readFile(c,"utf8");if(typeof s=="string"||!s.content)continue;let l=await J$1({filename:s.path,raw:s.content,config:t,baseColor:i}),p=diffLines(l,m);p.length>1&&n.push({filePath:c,patch:p});}}return n}async function wn(e){e.forEach(t=>{if(t)return t.added?process.stdout.write(d.success(t.value)):t.removed?process.stdout.write(d.error(t.value)):process.stdout.write(t.value)});}var Cr=new Command().name("info").description("get information about your project").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{try{s.info("> project info"),console.log(await p(e.cwd)),s.break(),s.info("> components.json"),console.log(await i(e.cwd));}catch(t){Y(t);}});var me="latest",Fe=[{name:"claude",label:"Claude Code",configPath:".mcp.json",config:{mcpServers:{shadcn:{command:"npx",args:[`shadcn@${me}`,"mcp"]}}}},{name:"cursor",label:"Cursor",configPath:".cursor/mcp.json",config:{mcpServers:{shadcn:{command:"npx",args:[`shadcn@${me}`,"mcp"]}}}},{name:"vscode",label:"VS Code",configPath:".vscode/mcp.json",config:{servers:{shadcn:{command:"npx",args:[`shadcn@${me}`,"mcp"]}}}},{name:"codex",label:"Codex",configPath:".codex/config.toml",config:`[mcp_servers.shadcn]
75
75
  command = "npx"
76
- args = ["shadcn@${fe}", "mcp"]
77
- `}],Fe=[`shadcn@${fe}`],mt=new Command().name("mcp").description("MCP server and configuration commands").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{try{await z(e.cwd);let t=new StdioServerTransport;await b$1.connect(t);}catch(t){s.break(),Y(t);}}),In=lt.object({client:lt.enum(["claude","cursor","vscode","codex"]),cwd:lt.string()});mt.command("init").description("Initialize MCP configuration for your client").option("--client <client>",`MCP client (${Ae.map(e=>e.name).join(", ")})`).action(async(e,t$1)=>{try{let i$1=(t$1.parent?.opts()||{}).cwd||process.cwd(),n=e.client;if(!n){let m=await Te({type:"select",name:"client",message:"Which MCP client are you using?",choices:Ae.map(l=>({title:l.label,value:l.name}))});m.client||(s.break(),process.exit(1)),n=m.client;}let o=In.parse({client:n,cwd:i$1}),a=await i(o.cwd);if(o.client==="codex"){if(a)await W([],Fe,a,{silent:!1});else {let m=await a$1(o.cwd),l=m==="npm"?"install":"add",p=m==="npm"?"--save-dev":"-D",u=t("Installing dependencies...").start();await execa(m,[l,p,...Fe],{cwd:o.cwd}),u.succeed("Installing dependencies.");}s.break(),s.log("To configure the shadcn MCP server in Codex:"),s.break(),s.log(`1. Open or create the file ${d.info("~/.codex/config.toml")}`),s.log("2. Add the following configuration:"),s.log(),s.info(`[mcp_servers.shadcn]
76
+ args = ["shadcn@${me}", "mcp"]
77
+ `}],Te=[`shadcn@${me}`],ct=new Command().name("mcp").description("MCP server and configuration commands").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{try{await M(e.cwd);let t=new StdioServerTransport;await b$1.connect(t);}catch(t){s.break(),Y(t);}}),In=at.object({client:at.enum(["claude","cursor","vscode","codex"]),cwd:at.string()});ct.command("init").description("Initialize MCP configuration for your client").option("--client <client>",`MCP client (${Fe.map(e=>e.name).join(", ")})`).action(async(e,t$1)=>{try{let i$1=(t$1.parent?.opts()||{}).cwd||process.cwd(),n=e.client;if(!n){let m=await Oe({type:"select",name:"client",message:"Which MCP client are you using?",choices:Fe.map(l=>({title:l.label,value:l.name}))});m.client||(s.break(),process.exit(1)),n=m.client;}let o=In.parse({client:n,cwd:i$1}),a=await i(o.cwd);if(o.client==="codex"){if(a)await W([],Te,a,{silent:!1});else {let m=await a$1(o.cwd),l=m==="npm"?"install":"add",p=m==="npm"?"--save-dev":"-D",u=t("Installing dependencies...").start();await execa(m,[l,p,...Te],{cwd:o.cwd}),u.succeed("Installing dependencies.");}s.break(),s.log("To configure the shadcn MCP server in Codex:"),s.break(),s.log(`1. Open or create the file ${d.info("~/.codex/config.toml")}`),s.log("2. Add the following configuration:"),s.log(),s.info(`[mcp_servers.shadcn]
78
78
  command = "npx"
79
- args = ["shadcn@${fe}", "mcp"]`),s.break(),s.info("3. Restart Codex to load the MCP server"),s.break(),process.exit(0);}let s$1=t("Configuring MCP server...").start(),c=await Pn(o);if(s$1.succeed("Configuring MCP server."),a)await W([],Fe,a,{silent:!1});else {let m=await a$1(o.cwd),l=m==="npm"?"install":"add",p=m==="npm"?"--save-dev":"-D",u=t("Installing dependencies...").start();await execa(m,[l,p,...Fe],{cwd:o.cwd}),u.succeed("Installing dependencies.");}s.break(),s.success(`Configuration saved to ${c}.`),s.break();}catch(r){Y(r);}});var kn=(e,t)=>t;async function Pn(e){let{client:t,cwd:r}=e,i=Ae.find(c=>c.name===t);if(!i)throw new Error(`Unknown client: ${t}. Available clients: ${Ae.map(c=>c.name).join(", ")}`);let n=j__default.join(r,i.configPath),o=j__default.dirname(n);await S.ensureDir(o);let a={};try{let c=await promises.readFile(n,"utf-8");a=JSON.parse(c);}catch{}let s=lr(a,i.config,{arrayMerge:kn});return await promises.writeFile(n,JSON.stringify(s,null,2)+`
80
- `,"utf-8"),i.configPath}var H={lucide:{name:"lucide-react",package:"lucide-react",import:"lucide-react"},radix:{name:"@radix-ui/react-icons",package:"@radix-ui/react-icons",import:"@radix-ui/react-icons"}};async function $r(e){if(!e.resolvedPaths.ui)throw new Error("We could not find a valid `ui` path in your `components.json` file. Please ensure you have a valid `ui` path in your `components.json` file.");let t$1=e.resolvedPaths.ui,[r,i]=await Promise.all([$n("**/*.{js,ts,jsx,tsx}",{cwd:t$1}),da()]);if(Object.keys(i).length===0)throw new Error("Something went wrong fetching the registry icons.");let n=Object.entries(H).map(([l,p])=>({title:p.name,value:l})),o=await Te([{type:"select",name:"sourceLibrary",message:`Which icon library would you like to ${d.info("migrate from")}?`,choices:n},{type:"select",name:"targetLibrary",message:`Which icon library would you like to ${d.info("migrate to")}?`,choices:n}]);if(o.sourceLibrary===o.targetLibrary)throw new Error("You cannot migrate to the same icon library. Please choose a different icon library.");if(!(o.sourceLibrary in H&&o.targetLibrary in H))throw new Error("Invalid icon library. Please choose a valid icon library.");let a=H[o.sourceLibrary],s$1=H[o.targetLibrary],{confirm:c}=await Te({type:"confirm",name:"confirm",initial:true,message:`We will migrate ${d.info(r.length)} files in ${d.info(`./${j__default.relative(e.resolvedPaths.cwd,t$1)}`)} from ${d.info(a.name)} to ${d.info(s$1.name)}. Continue?`});c||(s.info("Migration cancelled."),process.exit(0)),s$1.package&&await W([s$1.package],[],e,{silent:false});let m=t("Migrating icons...")?.start();await Promise.all(r.map(async l=>{m.text=`Migrating ${l}...`;let p=j__default.join(t$1,l),u=await promises.readFile(p,"utf-8"),h=await Fn(u,o.sourceLibrary,o.targetLibrary,i);await promises.writeFile(p,h);})),m.succeed("Migration complete.");}async function Fn(e,t,r,i){let n=H[t]?.import,o=H[r]?.import,a=await promises.mkdtemp(j__default.join(tmpdir(),"shadcn-")),s=new Project({compilerOptions:{}}),c=j__default.join(a,`shadcn-icons-${randomBytes(4).toString("hex")}.tsx`),m=s.createSourceFile(c,e,{scriptKind:ScriptKind.TSX}),l=[];for(let p of m.getImportDeclarations()??[])if(p.getModuleSpecifier()?.getText()===`"${n}"`){for(let u of p.getNamedImports()??[]){let h=u.getName(),g=Object.values(i).find(w=>w[t]===h)?.[r];!g||l.includes(g)||(l.push(g),u.remove(),m.getDescendantsOfKind(SyntaxKind.JsxSelfClosingElement).filter(w=>w.getTagNameNode()?.getText()===h).forEach(w=>w.getTagNameNode()?.replaceWithText(g)));}p.getNamedImports()?.length===0&&p.remove();}return l.length>0&&m.addImportDeclaration({moduleSpecifier:o,namedImports:l.map(p=>({name:p}))}),await m.getText()}function _n(e){return e.split("-").map(t=>t.charAt(0).toUpperCase()+t.slice(1)).join("")}function Ln(e,t,r,i){let o=e.replace(/\/\/.*$/gm,"").replace(/\/\*[\s\S]*?\*\//g,"").replace(/\s+/g," ").trim().split(",").map(a=>a.trim()).filter(Boolean);for(let a of o){let s=a.match(/^type\s+(\w+)(?:\s+as\s+(\w+))?$/),c=a.match(/^(\w+)\s+as\s+(\w+)$/);if(s){let m=s[1],l=s[2];i==="slot"&&m==="Slot"&&!l?r.push({name:"Slot",alias:"SlotPrimitive",isType:true}):r.push({name:m,alias:l,isType:true});}else if(c){let m=c[1],l=c[2];i==="slot"&&m==="Slot"&&l==="Slot"?r.push({name:"Slot",alias:"SlotPrimitive",isType:t}):r.push({name:m,alias:l,isType:t});}else i==="slot"&&a==="Slot"?r.push({name:"Slot",alias:"SlotPrimitive",isType:t}):r.push({name:a,isType:t});}}async function Nr(e,t$1={}){if(!e.resolvedPaths.ui)throw new Error("We could not find a valid `ui` path in your `components.json` file. Please ensure you have a valid `ui` path in your `components.json` file.");let r=e.resolvedPaths.ui,i=await $n("**/*.{js,ts,jsx,tsx}",{cwd:r});if(!t$1.yes){let{confirm:s$1}=await Te({type:"confirm",name:"confirm",initial:true,message:`We will migrate ${d.info(i.length)} files in ${d.info(`./${j__default.relative(e.resolvedPaths.cwd,r)}`)} to ${d.info("radix-ui")}. Continue?`});s$1||(s.info("Migration cancelled."),process.exit(0));}let n=t("Migrating imports...")?.start(),o=new Set;await Promise.all(i.map(async s=>{n.text=`Migrating ${s}...`;let c=j__default.join(r,s),m=await promises.readFile(c,"utf-8"),{content:l,replacedPackages:p}=await Vn(m);p.forEach(u=>o.add(u)),await promises.writeFile(c,l);})),n.succeed("Migrating imports.");let a=t("Updating package.json...")?.start();try{let s$1=o$1(e.resolvedPaths.cwd,!1);if(!s$1){a.fail("Could not read package.json"),s.warn("Could not update package.json. You may need to manually replace @radix-ui/react-* packages with radix-ui");return}let c=Array.from(o),m=["dependencies","devDependencies"];for(let l of m)if(s$1[l])for(let p of c)s$1[l][p]&&delete s$1[l][p];if(c.length>0){s$1.dependencies||(s$1.dependencies={}),s$1.dependencies["radix-ui"]="latest";let l=j__default.join(e.resolvedPaths.cwd,"package.json");await promises.writeFile(l,JSON.stringify(s$1,null,2)+`
81
- `),a.succeed("Updated package.json."),await W(["radix-ui"],[],e,{silent:!1});}else a.succeed("No packages found in source files.");}catch{a.fail("Failed to update package.json"),s.warn("You may need to manually replace @radix-ui/react-* packages with radix-ui");}}async function Vn(e){let t=/import\s+(?:(type)\s+)?(?:\*\s+as\s+(\w+)|{([^}]+)})\s+from\s+(["'])@radix-ui\/react-([^"']+)\4(;?)/g,r=[],i=[],n=[],o='"',a=false,s=e,c;for(;(c=t.exec(e))!==null;){let[g,w,C,v,Y,O,X]=c;if(O==="icons"||O.startsWith("icons/"))continue;i.push(g),i.length===1&&(o=Y,a=X===";"),n.push(`@radix-ui/react-${O}`);let T=!!w;if(C){let _e=_n(O);r.push({name:_e,alias:C,isType:T});}else v&&Ln(v,T,r,O);}if(r.length===0)return {content:e,replacedPackages:[]};let m=r.filter((g,w,C)=>w===C.findIndex(v=>v.name===g.name&&v.alias===g.alias&&v.isType===g.isType)),p=`import { ${m.map(g=>{let w=g.isType?"type ":"";return g.alias?`${w}${g.name} as ${g.alias}`:`${w}${g.name}`}).join(", ")} } from ${o}radix-ui${o}${a?";":""}`;s=i.reduce((g,w,C)=>g.replace(w,C===0?p:""),s),s=s.replace(/\n\s*\n\s*\n/g,`
79
+ args = ["shadcn@${me}", "mcp"]`),s.break(),s.info("3. Restart Codex to load the MCP server"),s.break(),process.exit(0);}let s$1=t("Configuring MCP server...").start(),c=await Pn(o);if(s$1.succeed("Configuring MCP server."),a)await W([],Te,a,{silent:!1});else {let m=await a$1(o.cwd),l=m==="npm"?"install":"add",p=m==="npm"?"--save-dev":"-D",u=t("Installing dependencies...").start();await execa(m,[l,p,...Te],{cwd:o.cwd}),u.succeed("Installing dependencies.");}s.break(),s.success(`Configuration saved to ${c}.`),s.break();}catch(r){Y(r);}});var kn=(e,t)=>t;async function Pn(e){let{client:t,cwd:r}=e,i=Fe.find(c=>c.name===t);if(!i)throw new Error(`Unknown client: ${t}. Available clients: ${Fe.map(c=>c.name).join(", ")}`);let n=j__default.join(r,i.configPath),o=j__default.dirname(n);await v.ensureDir(o);let a={};try{let c=await promises.readFile(n,"utf-8");a=JSON.parse(c);}catch{}let s=cr(a,i.config,{arrayMerge:kn});return await promises.writeFile(n,JSON.stringify(s,null,2)+`
80
+ `,"utf-8"),i.configPath}var H={lucide:{name:"lucide-react",package:"lucide-react",import:"lucide-react"},radix:{name:"@radix-ui/react-icons",package:"@radix-ui/react-icons",import:"@radix-ui/react-icons"}};async function Er(e){if(!e.resolvedPaths.ui)throw new Error("We could not find a valid `ui` path in your `components.json` file. Please ensure you have a valid `ui` path in your `components.json` file.");let t$1=e.resolvedPaths.ui,[r,i]=await Promise.all([$n("**/*.{js,ts,jsx,tsx}",{cwd:t$1}),da()]);if(Object.keys(i).length===0)throw new Error("Something went wrong fetching the registry icons.");let n=Object.entries(H).map(([l,p])=>({title:p.name,value:l})),o=await Oe([{type:"select",name:"sourceLibrary",message:`Which icon library would you like to ${d.info("migrate from")}?`,choices:n},{type:"select",name:"targetLibrary",message:`Which icon library would you like to ${d.info("migrate to")}?`,choices:n}]);if(o.sourceLibrary===o.targetLibrary)throw new Error("You cannot migrate to the same icon library. Please choose a different icon library.");if(!(o.sourceLibrary in H&&o.targetLibrary in H))throw new Error("Invalid icon library. Please choose a valid icon library.");let a=H[o.sourceLibrary],s$1=H[o.targetLibrary],{confirm:c}=await Oe({type:"confirm",name:"confirm",initial:true,message:`We will migrate ${d.info(r.length)} files in ${d.info(`./${j__default.relative(e.resolvedPaths.cwd,t$1)}`)} from ${d.info(a.name)} to ${d.info(s$1.name)}. Continue?`});c||(s.info("Migration cancelled."),process.exit(0)),s$1.package&&await W([s$1.package],[],e,{silent:false});let m=t("Migrating icons...")?.start();await Promise.all(r.map(async l=>{m.text=`Migrating ${l}...`;let p=j__default.join(t$1,l),u=await promises.readFile(p,"utf-8"),g=await Fn(u,o.sourceLibrary,o.targetLibrary,i);await promises.writeFile(p,g);})),m.succeed("Migration complete.");}async function Fn(e,t,r,i){let n=H[t]?.import,o=H[r]?.import,a=await promises.mkdtemp(j__default.join(tmpdir(),"shadcn-")),s=new Project({compilerOptions:{}}),c=j__default.join(a,`shadcn-icons-${randomBytes(4).toString("hex")}.tsx`),m=s.createSourceFile(c,e,{scriptKind:ScriptKind.TSX}),l=[];for(let p of m.getImportDeclarations()??[])if(p.getModuleSpecifier()?.getText()===`"${n}"`){for(let u of p.getNamedImports()??[]){let g=u.getName(),h=Object.values(i).find(y=>y[t]===g)?.[r];!h||l.includes(h)||(l.push(h),u.remove(),m.getDescendantsOfKind(SyntaxKind.JsxSelfClosingElement).filter(y=>y.getTagNameNode()?.getText()===g).forEach(y=>y.getTagNameNode()?.replaceWithText(h)));}p.getNamedImports()?.length===0&&p.remove();}return l.length>0&&m.addImportDeclaration({moduleSpecifier:o,namedImports:l.map(p=>({name:p}))}),await m.getText()}function _n(e){return e.split("-").map(t=>t.charAt(0).toUpperCase()+t.slice(1)).join("")}function Ln(e,t,r,i){let o=e.replace(/\/\/.*$/gm,"").replace(/\/\*[\s\S]*?\*\//g,"").replace(/\s+/g," ").trim().split(",").map(a=>a.trim()).filter(Boolean);for(let a of o){let s=a.match(/^type\s+(\w+)(?:\s+as\s+(\w+))?$/),c=a.match(/^(\w+)\s+as\s+(\w+)$/);if(s){let m=s[1],l=s[2];i==="slot"&&m==="Slot"&&!l?r.push({name:"Slot",alias:"SlotPrimitive",isType:true}):r.push({name:m,alias:l,isType:true});}else if(c){let m=c[1],l=c[2];i==="slot"&&m==="Slot"&&l==="Slot"?r.push({name:"Slot",alias:"SlotPrimitive",isType:t}):r.push({name:m,alias:l,isType:t});}else i==="slot"&&a==="Slot"?r.push({name:"Slot",alias:"SlotPrimitive",isType:t}):r.push({name:a,isType:t});}}async function $r(e,t$1={}){if(!e.resolvedPaths.ui)throw new Error("We could not find a valid `ui` path in your `components.json` file. Please ensure you have a valid `ui` path in your `components.json` file.");let r=e.resolvedPaths.ui,i=await $n("**/*.{js,ts,jsx,tsx}",{cwd:r});if(!t$1.yes){let{confirm:s$1}=await Oe({type:"confirm",name:"confirm",initial:true,message:`We will migrate ${d.info(i.length)} files in ${d.info(`./${j__default.relative(e.resolvedPaths.cwd,r)}`)} to ${d.info("radix-ui")}. Continue?`});s$1||(s.info("Migration cancelled."),process.exit(0));}let n=t("Migrating imports...")?.start(),o=new Set;await Promise.all(i.map(async s=>{n.text=`Migrating ${s}...`;let c=j__default.join(r,s),m=await promises.readFile(c,"utf-8"),{content:l,replacedPackages:p}=await Vn(m);p.forEach(u=>o.add(u)),await promises.writeFile(c,l);})),n.succeed("Migrating imports.");let a=t("Updating package.json...")?.start();try{let s$1=o$1(e.resolvedPaths.cwd,!1);if(!s$1){a.fail("Could not read package.json"),s.warn("Could not update package.json. You may need to manually replace @radix-ui/react-* packages with radix-ui");return}let c=Array.from(o),m=["dependencies","devDependencies"];for(let l of m)if(s$1[l])for(let p of c)s$1[l][p]&&delete s$1[l][p];if(c.length>0){s$1.dependencies||(s$1.dependencies={}),s$1.dependencies["radix-ui"]="latest";let l=j__default.join(e.resolvedPaths.cwd,"package.json");await promises.writeFile(l,JSON.stringify(s$1,null,2)+`
81
+ `),a.succeed("Updated package.json."),await W(["radix-ui"],[],e,{silent:!1});}else a.succeed("No packages found in source files.");}catch{a.fail("Failed to update package.json"),s.warn("You may need to manually replace @radix-ui/react-* packages with radix-ui");}}async function Vn(e){let t=/import\s+(?:(type)\s+)?(?:\*\s+as\s+(\w+)|{([^}]+)})\s+from\s+(["'])@radix-ui\/react-([^"']+)\4(;?)/g,r=[],i=[],n=[],o='"',a=false,s=e,c;for(;(c=t.exec(e))!==null;){let[h,y,C,S,K,O,X]=c;if(O==="icons"||O.startsWith("icons/"))continue;i.push(h),i.length===1&&(o=K,a=X===";"),n.push(`@radix-ui/react-${O}`);let T=!!y;if(C){let De=_n(O);r.push({name:De,alias:C,isType:T});}else S&&Ln(S,T,r,O);}if(r.length===0)return {content:e,replacedPackages:[]};let m=r.filter((h,y,C)=>y===C.findIndex(S=>S.name===h.name&&S.alias===h.alias&&S.isType===h.isType)),p=`import { ${m.map(h=>{let y=h.isType?"type ":"";return h.alias?`${y}${h.name} as ${h.alias}`:`${y}${h.name}`}).join(", ")} } from ${o}radix-ui${o}${a?";":""}`;s=i.reduce((h,y,C)=>h.replace(y,C===0?p:""),s),s=s.replace(/\n\s*\n\s*\n/g,`
82
82
 
83
- `),m.some(g=>g.name==="Slot"&&g.alias==="SlotPrimitive")&&(s=s.split(`
84
- `).map(C=>{if(C.trim().startsWith("import "))return C;let v=C;return v=v.replace(/\b(asChild\s*\?\s*)Slot(\s*:)/g,"$1__SLOT_PLACEHOLDER__$2"),v=v.replace(/\bReact\.ComponentProps<typeof\s+Slot>/g,"React.ComponentProps<typeof __SLOT_PLACEHOLDER__>"),v=v.replace(/\bComponentProps<typeof\s+Slot>/g,"ComponentProps<typeof __SLOT_PLACEHOLDER__>"),v=v.replace(/(<\/?)Slot(\s*\/?>)/g,"$1__SLOT_PLACEHOLDER__$2"),v=v.replace(/\bSlot\b/g,(Y,O,X)=>{let T=X.substring(0,O),_e=(T.match(/"/g)||[]).length,Yr=(T.match(/'/g)||[]).length;return _e%2!==0||Yr%2!==0?Y:"__SLOT_PLACEHOLDER__"}),v=v.replace(/__SLOT_PLACEHOLDER__/g,"SlotPrimitive.Slot"),v}).join(`
85
- `));let h=Array.from(new Set(n));return {content:s,replacedPackages:h}}async function Tr(e){let t={};if(!S.existsSync(e.cwd)||!S.existsSync(j__default.resolve(e.cwd,"package.json")))return t["1"]=true,{errors:t,config:null};if(!S.existsSync(j__default.resolve(e.cwd,"components.json")))return t["3"]=true,{errors:t,config:null};try{let r=await i(e.cwd);return {errors:t,config:r}}catch{s.break(),s.error(`An invalid ${d.info("components.json")} file was found at ${d.info(e.cwd)}.
86
- Before you can run a migration, you must create a valid ${d.info("components.json")} file by running the ${d.info("init")} command.`),s.error(`Learn more at ${d.info("https://ui.shadcn.com/docs/components-json")}.`),s.break(),process.exit(1);}}var Fr=[{name:"icons",description:"migrate your ui components to a different icon library."},{name:"radix",description:"migrate to radix-ui."}],zn=z$1.object({cwd:z$1.string(),list:z$1.boolean(),yes:z$1.boolean(),migration:z$1.string().refine(e=>e&&Fr.some(t=>t.name===e),{message:"You must specify a valid migration. Run `shadcn migrate --list` to see available migrations."}).optional()}),Ar=new Command().name("migrate").description("run a migration.").argument("[migration]","the migration to run.").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-l, --list","list all migrations.",false).option("-y, --yes","skip confirmation prompt.",false).action(async(e,t)=>{try{let r=zn.parse({cwd:j__default.resolve(t.cwd),migration:e,list:t.list,yes:t.yes});if(r.list||!r.migration){s.info("Available migrations:");for(let o of Fr)s.info(`- ${o.name}: ${o.description}`);return}if(!r.migration)throw new Error("You must specify a migration. Run `shadcn migrate --list` to see available migrations.");let{errors:i,config:n}=await Tr(r);if(i["1"]||i["3"])throw new Error("No `components.json` file found. Ensure you are at the root of your project.");if(!n)throw new Error("Something went wrong reading your `components.json` file. Please ensure you have a valid `components.json` file.");r.migration==="icons"&&await $r(n),r.migration==="radix"&&await Nr(n,{yes:r.yes});}catch(r){s.break(),Y(r);}});async function Dr(e){let t={},r={cwd:e.cwd,registryFile:j__default.resolve(e.cwd,e.registryFile),outputDir:j__default.resolve(e.cwd,e.outputDir)};if(!S.existsSync(r.registryFile))return t["13"]=true,{errors:t,resolvePaths:null,config:null};if(!S.existsSync(j__default.resolve(e.cwd,"components.json")))return t["3"]=true,{errors:t,resolvePaths:null,config:null};await S.mkdir(r.outputDir,{recursive:true});try{let i$1=await i(e.cwd);return {errors:t,config:i$1,resolvePaths:r}}catch{s.break(),s.error(`An invalid ${d.info("components.json")} file was found at ${d.info(e.cwd)}.
87
- Before you can build the registry, you must create a valid ${d.info("components.json")} file by running the ${d.info("init")} command.`),s.break(),process.exit(1);}}var Un=z$1.object({cwd:z$1.string(),registryFile:z$1.string(),outputDir:z$1.string(),verbose:z$1.boolean().optional().default(false)}),_r=new Command().name("registry:build").description("builds the registry [EXPERIMENTAL]").argument("[registry]","path to registry.json file","./registry.json").option("-o, --output <path>","destination directory for json files","./public/r").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-v, --verbose","verbose output").action(async(e,t)=>{await Gn({cwd:j.resolve(t.cwd),registryFile:e,outputDir:t.output,verbose:t.verbose});});async function Gn(e){try{let t$1=Un.parse(e),[{errors:r,resolvePaths:i,config:n},o$1]=await Promise.all([Dr(t$1),p(t$1.cwd)]);(r["3"]||!n||!o$1)&&(s.error(`A ${d.info("components.json")} file is required to build the registry. Run ${d.info("shadcn init")} to create one.`),s.break(),process.exit(1)),(r["13"]||!i)&&(s.error(`We could not find a registry file at ${d.info(j.resolve(t$1.cwd,t$1.registryFile))}.`),s.break(),process.exit(1));let a=await J.readFile(i.registryFile,"utf-8"),s$1=o.safeParse(JSON.parse(a));s$1.success||(s.error(`Invalid registry file found at ${d.info(i.registryFile)}.`),s.break(),process.exit(1));let c=t("Building registry..."),m=await Jn(s$1.data,n,o$1);for(let l of m.items)l.files=l.files?.filter((p,u,h)=>u===h.findIndex(g=>g.path===p.path)),l.dependencies&&(l.dependencies=l.dependencies.filter((p,u,h)=>u===h.findIndex(g=>g===p)));for(let l of m.items){if(!l.files)continue;c.start(`Building ${l.name}...`),l.$schema="https://ui.shadcn.com/schema/registry-item.json";for(let u of l.files){let h=j.resolve(i.cwd,u.path);try{if(!(await J.stat(h)).isFile())continue;u.content=await J.readFile(h,"utf-8");}catch(g){console.error("Error reading file in registry build:",h,g);continue}}let p=n$1.safeParse(l);if(!p.success){s.error(`Invalid registry item found for ${d.info(l.name)}.`);continue}await J.writeFile(j.resolve(i.outputDir,`${p.data.name}.json`),JSON.stringify(p.data,null,2));}if(await J.copyFile(i.registryFile,j.resolve(i.outputDir,"registry.json")),c.succeed("Building registry."),t$1.verbose){t(`The registry has ${d.info(m.items.length.toString())} items:`).succeed();for(let l of m.items){s.log(` - ${l.name} (${d.info(l.type)})`);for(let p of l.files??[])s.log(` - ${p.path}`);}}}catch(t){s.break(),Y(t);}}async function Jn(e,t,r){for(let i of e.items)if(i.files?.length)for(let n of i.files){let o=await L(n.path,t,r);o.files=o.files?.filter(a=>a.path!==n.path),o.files&&i.files.push(...o.files),o.dependencies&&(i.dependencies=i.dependencies?i.dependencies.concat(o.dependencies):o.dependencies);}return e}var Lr=new Command().name("registry:mcp").description("starts the registry MCP server [DEPRECATED]").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async()=>{s.warn(`The ${d.info("shadcn registry:mcp")} command is deprecated. Use the ${d.info("shadcn mcp")} command instead.`),s.break();});var qn=z$1.object({cwd:z$1.string(),query:z$1.string().optional(),limit:z$1.number().optional(),offset:z$1.number().optional()}),Wr=new Command().name("search").alias("list").description("search items from registries").argument("<registries...>","the registry names or urls to search items from. Names must be prefixed with @.").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-q, --query <query>","query string").option("-l, --limit <number>","maximum number of items to display per registry","100").option("-o, --offset <number>","number of items to skip","0").action(async(e,t)=>{try{let r=qn.parse({cwd:j__default.resolve(t.cwd),query:t.query,limit:t.limit?parseInt(t.limit,10):void 0,offset:t.offset?parseInt(t.offset,10):void 0});await z(r.cwd);let i$1=n({style:"new-york",resolvedPaths:{cwd:r.cwd}}),n$1=O(i$1),o=j__default.resolve(r.cwd,"components.json");if(S.existsSync(o)){let l=await S.readJson(o),p=c.partial().parse(l);n$1=O({...i$1,...p});}let a=n$1;try{let l=await i(r.cwd);l&&(a=O(l));}catch{}let{config:s,newRegistries:c$1}=await _(e.map(l=>`${l}/registry`),a,{silent:!0,writeFile:!1});c$1.length>0&&(a.registries=s.registries),Q(e,a);let m=await ma(e,{query:r.query,limit:r.limit,offset:r.offset,config:a});console.log(JSON.stringify(m,null,2)),process.exit(0);}catch(r){Y(r);}finally{P();}});var Xn=z$1.object({cwd:z$1.string()}),Gr=new Command().name("view").description("view items from the registry").argument("<items...>","the item names or URLs to view").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{try{let r=Xn.parse({cwd:j__default.resolve(t.cwd)});await z(r.cwd);let i$1=O({}),n=j__default.resolve(r.cwd,"components.json");if(S.existsSync(n)){let m=await S.readJson(n),l=c.partial().parse(m);i$1=O(l);}let o=i$1;try{let m=await i(r.cwd);m&&(o=O(m));}catch{}let{config:a,newRegistries:s}=await _(e,o,{silent:!0,writeFile:!1});s.length>0&&(o.registries=a.registries),Q(e,o);let c$1=await _$1(e,{config:o});console.log(JSON.stringify(c$1,null,2)),process.exit(0);}catch(r){Y(r);}finally{P();}});var Jr={version:"3.6.16"};process.on("SIGINT",()=>process.exit(0));process.on("SIGTERM",()=>process.exit(0));async function eo(){let e=new Command().name("shadcn").description("add items from registries to your project").version(Jr.version,"-v, --version","display the version number");e.addCommand(mr).addCommand(vr).addCommand(ur).addCommand(Cr).addCommand(Gr).addCommand(Wr).addCommand(Ar).addCommand(Ir).addCommand(yr).addCommand(mt),e.addCommand(_r).addCommand(Lr),e.parse();}eo();//# sourceMappingURL=index.js.map
83
+ `),m.some(h=>h.name==="Slot"&&h.alias==="SlotPrimitive")&&(s=s.split(`
84
+ `).map(C=>{if(C.trim().startsWith("import "))return C;let S=C;return S=S.replace(/\b(asChild\s*\?\s*)Slot(\s*:)/g,"$1__SLOT_PLACEHOLDER__$2"),S=S.replace(/\bReact\.ComponentProps<typeof\s+Slot>/g,"React.ComponentProps<typeof __SLOT_PLACEHOLDER__>"),S=S.replace(/\bComponentProps<typeof\s+Slot>/g,"ComponentProps<typeof __SLOT_PLACEHOLDER__>"),S=S.replace(/(<\/?)Slot(\s*\/?>)/g,"$1__SLOT_PLACEHOLDER__$2"),S=S.replace(/\bSlot\b/g,(K,O,X)=>{let T=X.substring(0,O),De=(T.match(/"/g)||[]).length,Jr=(T.match(/'/g)||[]).length;return De%2!==0||Jr%2!==0?K:"__SLOT_PLACEHOLDER__"}),S=S.replace(/__SLOT_PLACEHOLDER__/g,"SlotPrimitive.Slot"),S}).join(`
85
+ `));let g=Array.from(new Set(n));return {content:s,replacedPackages:g}}async function Or(e){let t={};if(!v.existsSync(e.cwd)||!v.existsSync(j__default.resolve(e.cwd,"package.json")))return t["1"]=true,{errors:t,config:null};if(!v.existsSync(j__default.resolve(e.cwd,"components.json")))return t["3"]=true,{errors:t,config:null};try{let r=await i(e.cwd);return {errors:t,config:r}}catch{s.break(),s.error(`An invalid ${d.info("components.json")} file was found at ${d.info(e.cwd)}.
86
+ Before you can run a migration, you must create a valid ${d.info("components.json")} file by running the ${d.info("init")} command.`),s.error(`Learn more at ${d.info("https://ui.shadcn.com/docs/components-json")}.`),s.break(),process.exit(1);}}var Tr=[{name:"icons",description:"migrate your ui components to a different icon library."},{name:"radix",description:"migrate to radix-ui."}],zn=z.object({cwd:z.string(),list:z.boolean(),yes:z.boolean(),migration:z.string().refine(e=>e&&Tr.some(t=>t.name===e),{message:"You must specify a valid migration. Run `shadcn migrate --list` to see available migrations."}).optional()}),Fr=new Command().name("migrate").description("run a migration.").argument("[migration]","the migration to run.").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-l, --list","list all migrations.",false).option("-y, --yes","skip confirmation prompt.",false).action(async(e,t)=>{try{let r=zn.parse({cwd:j__default.resolve(t.cwd),migration:e,list:t.list,yes:t.yes});if(r.list||!r.migration){s.info("Available migrations:");for(let o of Tr)s.info(`- ${o.name}: ${o.description}`);return}if(!r.migration)throw new Error("You must specify a migration. Run `shadcn migrate --list` to see available migrations.");let{errors:i,config:n}=await Or(r);if(i["1"]||i["3"])throw new Error("No `components.json` file found. Ensure you are at the root of your project.");if(!n)throw new Error("Something went wrong reading your `components.json` file. Please ensure you have a valid `components.json` file.");r.migration==="icons"&&await Er(n),r.migration==="radix"&&await $r(n,{yes:r.yes});}catch(r){s.break(),Y(r);}});async function Ar(e){let t={},r={cwd:e.cwd,registryFile:j__default.resolve(e.cwd,e.registryFile),outputDir:j__default.resolve(e.cwd,e.outputDir)};if(!v.existsSync(r.registryFile))return t["13"]=true,{errors:t,resolvePaths:null,config:null};if(!v.existsSync(j__default.resolve(e.cwd,"components.json")))return t["3"]=true,{errors:t,resolvePaths:null,config:null};await v.mkdir(r.outputDir,{recursive:true});try{let i$1=await i(e.cwd);return {errors:t,config:i$1,resolvePaths:r}}catch{s.break(),s.error(`An invalid ${d.info("components.json")} file was found at ${d.info(e.cwd)}.
87
+ Before you can build the registry, you must create a valid ${d.info("components.json")} file by running the ${d.info("init")} command.`),s.break(),process.exit(1);}}var Un=z.object({cwd:z.string(),registryFile:z.string(),outputDir:z.string(),verbose:z.boolean().optional().default(false)}),Dr=new Command().name("registry:build").description("builds the registry [EXPERIMENTAL]").argument("[registry]","path to registry.json file","./registry.json").option("-o, --output <path>","destination directory for json files","./public/r").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-v, --verbose","verbose output").action(async(e,t)=>{await Gn({cwd:j.resolve(t.cwd),registryFile:e,outputDir:t.output,verbose:t.verbose});});async function Gn(e){try{let t$1=Un.parse(e),[{errors:r,resolvePaths:i,config:n},o$1]=await Promise.all([Ar(t$1),p(t$1.cwd)]);(r["3"]||!n||!o$1)&&(s.error(`A ${d.info("components.json")} file is required to build the registry. Run ${d.info("shadcn init")} to create one.`),s.break(),process.exit(1)),(r["13"]||!i)&&(s.error(`We could not find a registry file at ${d.info(j.resolve(t$1.cwd,t$1.registryFile))}.`),s.break(),process.exit(1));let a=await J.readFile(i.registryFile,"utf-8"),s$1=o.safeParse(JSON.parse(a));s$1.success||(s.error(`Invalid registry file found at ${d.info(i.registryFile)}.`),s.break(),process.exit(1));let c=t("Building registry..."),m=await Jn(s$1.data,n,o$1);for(let l of m.items)l.files=l.files?.filter((p,u,g)=>u===g.findIndex(h=>h.path===p.path)),l.dependencies&&(l.dependencies=l.dependencies.filter((p,u,g)=>u===g.findIndex(h=>h===p)));for(let l of m.items){if(!l.files)continue;c.start(`Building ${l.name}...`),l.$schema="https://ui.shadcn.com/schema/registry-item.json";for(let u of l.files){let g=j.resolve(i.cwd,u.path);try{if(!(await J.stat(g)).isFile())continue;u.content=await J.readFile(g,"utf-8");}catch(h){console.error("Error reading file in registry build:",g,h);continue}}let p=n$1.safeParse(l);if(!p.success){s.error(`Invalid registry item found for ${d.info(l.name)}.`);continue}await J.writeFile(j.resolve(i.outputDir,`${p.data.name}.json`),JSON.stringify(p.data,null,2));}if(await J.copyFile(i.registryFile,j.resolve(i.outputDir,"registry.json")),c.succeed("Building registry."),t$1.verbose){t(`The registry has ${d.info(m.items.length.toString())} items:`).succeed();for(let l of m.items){s.log(` - ${l.name} (${d.info(l.type)})`);for(let p of l.files??[])s.log(` - ${p.path}`);}}}catch(t){s.break(),Y(t);}}async function Jn(e,t,r){for(let i of e.items)if(i.files?.length)for(let n of i.files){let o=await L(n.path,t,r);o.files=o.files?.filter(a=>a.path!==n.path),o.files&&i.files.push(...o.files),o.dependencies&&(i.dependencies=i.dependencies?i.dependencies.concat(o.dependencies):o.dependencies);}return e}var _r=new Command().name("registry:mcp").description("starts the registry MCP server [DEPRECATED]").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async()=>{s.warn(`The ${d.info("shadcn registry:mcp")} command is deprecated. Use the ${d.info("shadcn mcp")} command instead.`),s.break();});var qn=z.object({cwd:z.string(),query:z.string().optional(),limit:z.number().optional(),offset:z.number().optional()}),Wr=new Command().name("search").alias("list").description("search items from registries").argument("<registries...>","the registry names or urls to search items from. Names must be prefixed with @.").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-q, --query <query>","query string").option("-l, --limit <number>","maximum number of items to display per registry","100").option("-o, --offset <number>","number of items to skip","0").action(async(e,t)=>{try{let r=qn.parse({cwd:j__default.resolve(t.cwd),query:t.query,limit:t.limit?parseInt(t.limit,10):void 0,offset:t.offset?parseInt(t.offset,10):void 0});await M(r.cwd);let i$1=n({style:"new-york",resolvedPaths:{cwd:r.cwd}}),n$1=O(i$1),o=j__default.resolve(r.cwd,"components.json");if(v.existsSync(o)){let l=await v.readJson(o),p=c.partial().parse(l);n$1=O({...i$1,...p});}let a=n$1;try{let l=await i(r.cwd);l&&(a=O(l));}catch{}let{config:s,newRegistries:c$1}=await D(e.map(l=>`${l}/registry`),a,{silent:!0,writeFile:!1});c$1.length>0&&(a.registries=s.registries),Q(e,a);let m=await ma(e,{query:r.query,limit:r.limit,offset:r.offset,config:a});console.log(JSON.stringify(m,null,2)),process.exit(0);}catch(r){Y(r);}finally{P();}});var Xn=z.object({cwd:z.string()}),Ur=new Command().name("view").description("view items from the registry").argument("<items...>","the item names or URLs to view").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{try{let r=Xn.parse({cwd:j__default.resolve(t.cwd)});await M(r.cwd);let i$1=O({}),n=j__default.resolve(r.cwd,"components.json");if(v.existsSync(n)){let m=await v.readJson(n),l=c.partial().parse(m);i$1=O(l);}let o=i$1;try{let m=await i(r.cwd);m&&(o=O(m));}catch{}let{config:a,newRegistries:s}=await D(e,o,{silent:!0,writeFile:!1});s.length>0&&(o.registries=a.registries),Q(e,o);let c$1=await _(e,{config:o});console.log(JSON.stringify(c$1,null,2)),process.exit(0);}catch(r){Y(r);}finally{P();}});var Gr={version:"3.6.18"};process.on("SIGINT",()=>process.exit(0));process.on("SIGTERM",()=>process.exit(0));async function eo(){let e=new Command().name("shadcn").description("add items from registries to your project").version(Gr.version,"-v, --version","display the version number");e.addCommand(lr).addCommand(xr).addCommand(dr).addCommand(Rr).addCommand(Ur).addCommand(Wr).addCommand(Fr).addCommand(Cr).addCommand(yr).addCommand(ct),e.addCommand(Dr).addCommand(_r),e.parse();}eo();//# sourceMappingURL=index.js.map
88
88
  //# sourceMappingURL=index.js.map