smart-registry 1.17.0-canary.2 → 1.17.0-canary.3

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/bin/index.js CHANGED
@@ -1,8 +1,8 @@
1
1
  #!/usr/bin/env node
2
- var fe=Object.defineProperty,ue=Object.defineProperties;var ye=Object.getOwnPropertyDescriptors;var Q=Object.getOwnPropertySymbols;var he=Object.prototype.hasOwnProperty,be=Object.prototype.propertyIsEnumerable;var X=(r,t,i)=>t in r?fe(r,t,{enumerable:!0,configurable:!0,writable:!0,value:i}):r[t]=i,k=(r,t)=>{for(var i in t||(t={}))he.call(t,i)&&X(r,i,t[i]);if(Q)for(var i of Q(t))be.call(t,i)&&X(r,i,t[i]);return r},T=(r,t)=>ue(r,ye(t));import H from"node:fs";import v from"node:path";import{parseArgs as Pe}from"node:util";import{execSync as z}from"node:child_process";import D,{existsSync as ve}from"node:fs";import{readFile as xe}from"node:fs/promises";import F from"node:path";import{glob as Y}from"tinyglobby";var ee=async({cwd:r})=>{function t(a,o){let s=a.toLowerCase(),c=o.toLowerCase(),d=s===c&&a!==o;try{if(d){let g=`${a}.tmp-case-rename`;z(`git mv "${a}" "${g}"`,{stdio:"pipe"}),z(`git mv "${g}" "${o}"`,{stdio:"pipe"})}else z(`git mv "${a}" "${o}"`,{stdio:"pipe"})}catch(g){if(d){let u=`${a}.tmp-case-rename`;D.renameSync(a,u),D.renameSync(u,o)}else D.renameSync(a,o)}}let i=F.resolve(r,".gitignore"),p=ve(i)?(await xe(i,"utf8")).split(`
3
- `).filter(a=>a.trim()&&!a.startsWith("#")).map(a=>a.replace(/^\//,"").replace(/^/,"**/")):[];p.push("tailwind.config.js","tailwind.config.ts");let e=await Y(["**/*"],{cwd:r,ignore:p});for(let a of e){let o=F.resolve(r,a),d=a.split("/").map(g=>{let u=F.extname(g);return`${F.basename(g,u).replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}${u}`}).join("/");if(d!==a){let g=F.resolve(r,d);await D.promises.mkdir(F.dirname(g),{recursive:!0}),t(o,g)}}function n(a){return a.split("/").map((o,s)=>o==="."||o===".."||s===0&&o.startsWith("@")?o:o.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()).join("/")}let m=await Y(["**/*.{js,jsx,ts,tsx,css,scss}"],{cwd:r,ignore:p});for(let a of m){let o=F.resolve(r,a),s=await D.promises.readFile(o,"utf8");s=s.replace(/(from\s+['"`])([^'"`]+)(['"`])/g,(c,d,g,u)=>`${d}${n(g)}${u}`),s=s.replace(/(vi\.(?:mock|importActual)\(\s*['"`])([^'"`]+)(['"`])/g,(c,d,g,u)=>`${d}${n(g)}${u}`),s=s.replace(/(url\(\s*['"`]?)([^)'"`]+)(['"`]?\s*\))/g,(c,d,g,u)=>`${d}${n(g)}${u}`),await D.promises.writeFile(o,s,"utf8")}console.log("\u2705 Filenames, import paths, and CSS url() assets converted to kebab-case via git mv (with case-only fallback).")};import C,{existsSync as se}from"node:fs";import{readFile as $e}from"node:fs/promises";import V from"node:path";import{detect as we}from"@antfu/ni";async function te(r,{withFallback:t}={withFallback:!1}){let i=await we({programmatic:!0,cwd:r});if(i==="yarn@berry")return"yarn";if(i==="pnpm@6")return"pnpm";if(i==="bun")return"bun";if(i==="deno")return"deno";if(!t)return i!=null?i:"npm";let p=process.env.npm_config_user_agent||"";return p.startsWith("yarn")?"yarn":p.startsWith("pnpm")?"pnpm":p.startsWith("bun")?"bun":"npm"}import{execa as re}from"execa";import{glob as ke}from"tinyglobby";var ie=async({cwd:r})=>{let t=V.resolve(r,".gitignore"),i=se(t)?(await $e(t,"utf8")).split(`
4
- `).filter(o=>o.trim()&&!o.startsWith("#")).map(o=>o.replace(/^\//,"").replace(/^/,"**/")):[],p=await ke(["**/*.ts","**/*.tsx","**/*.js","**/*.jsx"],{cwd:r,ignore:i}),e=new Set,n=p.map(async o=>{let s=V.resolve(r,o),c=await C.promises.readFile(s,"utf-8"),d=c.replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(g,u,b)=>(e.add(`@radix-ui/react-${b}`),`import { ${u.replace("Primitive","")} as ${u} } from "radix-ui"`)).replace(/Sheet\s+as\s+SheetPrimitive/g,"Dialog as SheetPrimitive");return/import\s+\{\s+Slot\s+\}\s+from\s+"@radix-ui\/react-slot"/.test(c)&&(d=d.replace(/import\s+\{\s+Slot\s+\}\s+from\s+"@radix-ui\/react-slot"/,()=>(e.add("@radix-ui/react-slot"),"import { Slot as SlotPrimitive } from 'radix-ui'")).replace(/typeof\s+Slot\b/g,"typeof SlotPrimitive.Slot").replace(/\?\s+Slot\s+:/g,"? SlotPrimitive.Slot :").replace(/<Slot\b/g,"<SlotPrimitive.Slot")),C.promises.writeFile(s,d,"utf-8")});await Promise.all(n);let m=V.resolve(r,"registry.json");if(se(m)){let o=await C.promises.readFile(m,"utf-8"),s=JSON.parse(o),c=g=>{for(let u in g)u==="dependencies"||u==="devDependencies"?g[u]=Array.from(new Set(g[u].map(b=>e.has(b)?"radix-ui":b))):typeof g[u]=="object"&&g[u]!==null&&c(g[u])};c(s);let d=JSON.stringify(s,null,2);await C.promises.writeFile(m,d,"utf-8")}let a=await te(r);e.size&&await re(a,[a==="npm"?"uninstall":"remove",...Array.from(e)],{cwd:r}),await re(a,[a==="npm"?"install":"add","radix-ui"],{cwd:r}),console.log(`
5
- Codemod ran successfully. Please run the command again without the --codemod-radix flag to generate the registry.`)};var ne=["registry/**","src/registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],E={default:["$schema","name","homepage","items"],items:{default:["$schema","name","type","title","description","author","dependencies","devDependencies","registryDependencies","files","tailwind","cssVars","meta","docs","categories"],type:{default:["registry:style","registry:ui","registry:hook","registry:lib","registry:theme","registry:page","registry:file","registry:component","registry:block"]},files:{default:["type","target","content","path"],type:{default:["registry:block","registry:component","registry:file","registry:page","registry:theme","registry:lib","registry:hook","registry:ui","registry:style"]}}}};import B from"node:fs";import K from"node:path";import Se from"strip-json-comments";var oe=async r=>{let t={},i=["tsconfig.json","jsconfig.json"].find(p=>B.existsSync(K.resolve(r,p)));if(i){let p=await B.promises.readFile(K.resolve(r,i),"utf8"),{compilerOptions:e}=JSON.parse(Se(p,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((n,[m,[a]])=>(m.endsWith("*")&&a.endsWith("*")&&(n[m.replace(/\*$/,"")]=a.replace(/\*$/,"")),n),{}))}return t["@/"]||(t["@/"]=B.existsSync(K.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([p],[e])=>e.length-p.length).reduce((p,[e,n])=>(p[e]=n,p),{}),t};import _ from"node:fs";import j from"node:path";import je from"node:path";var w=({cwd:r,aliases:t,filepath:i})=>{var a;let p=i;for(let o in t)i=i.replace(t[o].replaceAll("./","").replaceAll("../",""),"");let e=i.startsWith("registry/")?i.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(o,s)=>`blocks/${s?s+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(o,s)=>`charts/${s?s+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(o,s)=>`${s?s+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(o,s)=>`components/${s?s+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(o,s)=>`hooks/${s?s+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(o,s)=>`lib/${s?s+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(o,s)=>`components/ui/${s?s+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):i.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),n=e.toLowerCase().replace(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)\//,"").replace(/\/(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)\//,"/").replace(/\.[^\/.]+$/,"").replace(/\/index$/,"").replace(/\/page$/,"").replace(/\/route$/,"").replace(/\/\[.*\]$/,"").replace(/(\b\w+)\b\/\1\b/g,"$1").replace(/\//g,"-");e=e.startsWith("blocks/")&&e.includes("components/")?e.replace(/^blocks\//,"").replace(/(?:([^\/]*)\/)?components\//,(o,s)=>`components/${s?s+"/":""}`).replace(/.*?(components\/)/,"$1"):e;let m=e.endsWith("page.tsx")?"registry:page":e.endsWith(".css")?"registry:style":((a=e.match(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:a[1].replace("blocks","registry:block").replace("components/charts","registry:component").replace("components/ui","registry:ui").replace("components","registry:component").replace("hooks","registry:hook").replace("lib","registry:lib").replace("utils","registry:lib").replace("helpers","registry:lib"))||"registry:file";return e=e.startsWith("blocks/")&&e.endsWith("page.tsx")?e.replace(/^blocks\//,"app/"):e,{type:m,name:n,import:"@/"+e.replace(r+je.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:p.split("/").length>1?e:`~/${e}`,path:i}};var ae=async({cwd:r,aliases:t,registryFiles:i})=>{let p=j.resolve(r,"registry.json"),e={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};_.existsSync(p)&&(e=k({},JSON.parse(await _.promises.readFile(p,"utf8"))));let n=[];for(let s of i)w({cwd:r,aliases:t,filepath:s}).type==="registry:ui"&&n.push({type:"registry:ui",path:s});let m=null,a=null,o=_.existsSync(j.relative(process.cwd(),j.resolve(r,"app/globals.css")))?j.relative(process.cwd(),j.resolve(r,"app/globals.css")):_.existsSync(j.relative(process.cwd(),j.resolve(r,"src/app/globals.css")))?j.relative(process.cwd(),j.resolve(r,"src/app/globals.css")):null;if(o){let s=await _.promises.readFile(o,"utf8"),c=s.match(/:root\s*{([^}]*)}/);m=c?c[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(g=>g.trim()).filter(g=>g.length).map(g=>{let[u,b]=g.split(":").map(R=>R.trim());return{name:u.replace(/^--/,""),value:b}}):null;let d=s.match(/\.dark\s*{([^}]*)}/);a=d?d[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(g=>g.trim()).filter(g=>g.length).map(g=>{let[u,b]=g.split(":").map(R=>R.trim());return{name:u.replace(/^--/,""),value:b}}):null}return m&&a&&e.items.push({name:"style",type:"registry:style",cssVars:{light:Object.fromEntries(m.map(s=>[s.name,s.value])),dark:Object.fromEntries(a.map(s=>[s.name,s.value]))}}),n.length&&e.items.push({name:"ui",type:"registry:ui",files:n}),e};import Re from"node:fs";import Fe from"node:path";import{glob as Oe}from"tinyglobby";var P=async({cwd:r,patterns:t=["**",".**"],ignore:i=[]})=>{t=Array.isArray(t)?t:[t],t=t.map(e=>e.replace(/^'|'$/g,"").replace(/^"|"$/g,"").trim()),t=[...t,...t.flatMap(e=>e.includes("*")?[]:[e+".**",e+"**"])],t=t.filter(Boolean),i=typeof i=="string"?i.split(",").map(e=>e.trim()):i,i=i.filter(Boolean);let p=await Oe(t,{cwd:r,ignore:i.filter(e=>!t.includes(e))});for(let e of t)if(!p.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let n=Fe.resolve(r,e);(await Re.promises.stat(n)).isFile()&&p.push(e)}catch(n){continue}return[...new Set(p)]};var le=async({cwd:r,patterns:t,ignore:i,patternsOnly:p})=>{let e=[];if(!p){for(let n of ne)if(e=await P({cwd:r,patterns:n,ignore:i}),e.length)break}if(t.length&&(e=e.concat(await P({cwd:r,patterns:t,ignore:i}))),!e.length)throw new Error("No files/directories found to build the registry from!");return e=e.sort((n,m)=>n.localeCompare(m,void 0,{numeric:!0,sensitivity:"base"})).filter(n=>!n.startsWith("registry/registry")&&!n.startsWith("registry/index")&&!n.startsWith("src/registry/registry")&&!n.startsWith("src/registry/index")),e};import ce from"node:fs";import pe from"node:path";var M={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var q=async({cwd:r,aliases:t,filepaths:i,resolved:p})=>{p=p!=null?p:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let n of i){if(p.has(n))continue;p.add(n),e.files.push(n),e.content[n]||(e.content[n]=await ce.promises.readFile(pe.resolve(r,n),"utf8"));let{dependencies:m,devDependencies:a,files:o,transformations:s}=await Z({cwd:r,aliases:t,filepath:n,content:e.content[n]});o.forEach(c=>e.files.push(c)),m.forEach(c=>e.dependencies.push(c)),a.forEach(c=>e.devDependencies.push(c))}for(let n of e.files){let{dependencies:m,devDependencies:a,files:o,content:s}=await q({cwd:r,aliases:t,filepaths:[n],resolved:p});e.content[n]||(e.content[n]=s[n]||await ce.promises.readFile(pe.resolve(r,n),"utf8")),o.forEach(c=>e.files.push(c)),m.forEach(c=>e.dependencies.push(c)),a.forEach(c=>e.devDependencies.push(c))}e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort();for(let n of e.files){let{transformations:m}=await Z({cwd:r,aliases:t,filepath:n,content:e.content[n]});e.content[n]=e.content[n].replace(M.imports,a=>{let o=a.match(/['"](.*)['"]/);return o&&m[o[1]]?a.replace(o[1],m[o[1]].import):a})}return e};import me from"node:fs";import J from"node:path";var We=async({cwd:r,current:t,aliases:i})=>{t=t.replace(new RegExp(`^${Object.keys(i).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))}`),i[Object.keys(i).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))]),t=t.replace(/^\.\//g,"");let p=await P({cwd:r,patterns:t});return t=p.find(e=>e.startsWith(t+"."))||p.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},De=async({cwd:r,filepath:t,current:i})=>{i=J.relative(r,J.resolve(r,J.dirname(t),i));let p=await P({cwd:r,patterns:i});return i=p.find(e=>e.startsWith(i+"."))||p.find(e=>e.startsWith(i+"/index"))||i,i.replace(r+"/","")},Z=async({cwd:r,aliases:t,filepath:i,content:p})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},n=p.match(M.imports)||[];if(!n.length)return e;n=n.map(m=>{var a;return(a=m.match(/['"](.*)['"]/))==null?void 0:a[1].replace(/\/\//g,"/")});for(let m of n){let a=m;if(Object.keys(t).some(s=>m.startsWith(s.replace(/\.\//g,"").replace(/\.\.\//g,""))))m=await We({cwd:r,aliases:t,current:m}),e.transformations[a]=w({cwd:r,aliases:t,filepath:m}),e.files.push(m);else if(m.startsWith("."))m=await De({cwd:r,filepath:i,current:m}),e.transformations[a]=w({cwd:r,aliases:t,filepath:m}),e.files.push(m);else{let s=J.resolve(r,"package.json"),c={};if(me.existsSync(s)){let d=JSON.parse(await me.promises.readFile(s,"utf8"));c=k({},d.devDependencies)}if(m.startsWith("@")){let d=m.split("/").slice(0,2).join("/");c[d]?e.devDependencies.push(d):e.dependencies.push(d)}else{let d=m.split("/")[0];c[d]?e.devDependencies.push(d):e.dependencies.push(d)}}}return e};import{green as Ae}from"yoctocolors";var I="smart-registry",G="1.17.0-canary.2";var N={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var ge=`Version:
2
+ var fe=Object.defineProperty,ue=Object.defineProperties;var ye=Object.getOwnPropertyDescriptors;var Q=Object.getOwnPropertySymbols;var he=Object.prototype.hasOwnProperty,be=Object.prototype.propertyIsEnumerable;var X=(r,s,i)=>s in r?fe(r,s,{enumerable:!0,configurable:!0,writable:!0,value:i}):r[s]=i,k=(r,s)=>{for(var i in s||(s={}))he.call(s,i)&&X(r,i,s[i]);if(Q)for(var i of Q(s))be.call(s,i)&&X(r,i,s[i]);return r},T=(r,s)=>ue(r,ye(s));import H from"node:fs";import v from"node:path";import{parseArgs as Ae}from"node:util";import{execSync as z}from"node:child_process";import D,{existsSync as ve}from"node:fs";import{readFile as xe}from"node:fs/promises";import F from"node:path";import{glob as Y}from"tinyglobby";var ee=async({cwd:r})=>{function s(a,o){let t=a.toLowerCase(),p=o.toLowerCase(),d=t===p&&a!==o;try{if(d){let m=`${a}.tmp-case-rename`;z(`git mv "${a}" "${m}"`,{stdio:"pipe"}),z(`git mv "${m}" "${o}"`,{stdio:"pipe"})}else z(`git mv "${a}" "${o}"`,{stdio:"pipe"})}catch(m){if(d){let f=`${a}.tmp-case-rename`;D.renameSync(a,f),D.renameSync(f,o)}else D.renameSync(a,o)}}let i=F.resolve(r,".gitignore"),c=ve(i)?(await xe(i,"utf8")).split(`
3
+ `).filter(a=>a.trim()&&!a.startsWith("#")).map(a=>a.replace(/^\//,"").replace(/^/,"**/")):[];c.push("tailwind.config.js","tailwind.config.ts");let e=await Y(["**/*"],{cwd:r,ignore:c});for(let a of e){let o=F.resolve(r,a),d=a.split("/").map(m=>{let f=F.extname(m),b=F.basename(m,f);return/^[A-Z0-9_]+$/.test(b)?m:`${b.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}${f}`}).join("/");if(d!==a){let m=F.resolve(r,d);await D.promises.mkdir(F.dirname(m),{recursive:!0}),s(o,m)}}function n(a){return a.split("/").map((o,t)=>o==="."||o===".."||t===0&&o.startsWith("@")||/^[A-Z0-9_]+$/.test(o)?o:o.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()).join("/")}let g=await Y(["**/*.{js,jsx,ts,tsx,css,scss}"],{cwd:r,ignore:c});for(let a of g){let o=F.resolve(r,a),t=await D.promises.readFile(o,"utf8");t=t.replace(/(from\s+['"`])([^'"`]+)(['"`])/g,(p,d,m,f)=>`${d}${n(m)}${f}`),t=t.replace(/(import\s+['"`])([^'"`]+)(['"`])/g,(p,d,m,f)=>`${d}${n(m)}${f}`),t=t.replace(/((?:import|require)\s*\(\s*['"`])([^'"`]+)(['"`]\s*\))/g,(p,d,m,f)=>`${d}${n(m)}${f}`),t=t.replace(/((?:vi|jest)\.(?:mock|importActual|requireActual)\(\s*['"`])([^'"`]+)(['"`])/g,(p,d,m,f)=>`${d}${n(m)}${f}`),t=t.replace(/(url\(\s*['"`]?)([^)'"`]+)(['"`]?\s*\))/g,(p,d,m,f)=>`${d}${n(m)}${f}`),await D.promises.writeFile(o,t,"utf8")}console.log("\u2705 Filenames, import paths, and CSS url() assets converted to kebab-case via git mv (with case-only fallback).")};import C,{existsSync as se}from"node:fs";import{readFile as $e}from"node:fs/promises";import V from"node:path";import{detect as we}from"@antfu/ni";async function te(r,{withFallback:s}={withFallback:!1}){let i=await we({programmatic:!0,cwd:r});if(i==="yarn@berry")return"yarn";if(i==="pnpm@6")return"pnpm";if(i==="bun")return"bun";if(i==="deno")return"deno";if(!s)return i!=null?i:"npm";let c=process.env.npm_config_user_agent||"";return c.startsWith("yarn")?"yarn":c.startsWith("pnpm")?"pnpm":c.startsWith("bun")?"bun":"npm"}import{execa as re}from"execa";import{glob as ke}from"tinyglobby";var ie=async({cwd:r})=>{let s=V.resolve(r,".gitignore"),i=se(s)?(await $e(s,"utf8")).split(`
4
+ `).filter(o=>o.trim()&&!o.startsWith("#")).map(o=>o.replace(/^\//,"").replace(/^/,"**/")):[],c=await ke(["**/*.ts","**/*.tsx","**/*.js","**/*.jsx"],{cwd:r,ignore:i}),e=new Set,n=c.map(async o=>{let t=V.resolve(r,o),p=await C.promises.readFile(t,"utf-8"),d=p.replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(m,f,b)=>(e.add(`@radix-ui/react-${b}`),`import { ${f.replace("Primitive","")} as ${f} } from "radix-ui"`)).replace(/Sheet\s+as\s+SheetPrimitive/g,"Dialog as SheetPrimitive");return/import\s+\{\s+Slot\s+\}\s+from\s+"@radix-ui\/react-slot"/.test(p)&&(d=d.replace(/import\s+\{\s+Slot\s+\}\s+from\s+"@radix-ui\/react-slot"/,()=>(e.add("@radix-ui/react-slot"),"import { Slot as SlotPrimitive } from 'radix-ui'")).replace(/typeof\s+Slot\b/g,"typeof SlotPrimitive.Slot").replace(/\?\s+Slot\s+:/g,"? SlotPrimitive.Slot :").replace(/<Slot\b/g,"<SlotPrimitive.Slot")),C.promises.writeFile(t,d,"utf-8")});await Promise.all(n);let g=V.resolve(r,"registry.json");if(se(g)){let o=await C.promises.readFile(g,"utf-8"),t=JSON.parse(o),p=m=>{for(let f in m)f==="dependencies"||f==="devDependencies"?m[f]=Array.from(new Set(m[f].map(b=>e.has(b)?"radix-ui":b))):typeof m[f]=="object"&&m[f]!==null&&p(m[f])};p(t);let d=JSON.stringify(t,null,2);await C.promises.writeFile(g,d,"utf-8")}let a=await te(r);e.size&&await re(a,[a==="npm"?"uninstall":"remove",...Array.from(e)],{cwd:r}),await re(a,[a==="npm"?"install":"add","radix-ui"],{cwd:r}),console.log(`
5
+ Codemod ran successfully. Please run the command again without the --codemod-radix flag to generate the registry.`)};var ne=["registry/**","src/registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],_={default:["$schema","name","homepage","items"],items:{default:["$schema","name","type","title","description","author","dependencies","devDependencies","registryDependencies","files","tailwind","cssVars","meta","docs","categories"],type:{default:["registry:style","registry:ui","registry:hook","registry:lib","registry:theme","registry:page","registry:file","registry:component","registry:block"]},files:{default:["type","target","content","path"],type:{default:["registry:block","registry:component","registry:file","registry:page","registry:theme","registry:lib","registry:hook","registry:ui","registry:style"]}}}};import Z from"node:fs";import q from"node:path";import Se from"strip-json-comments";var oe=async r=>{let s={},i=["tsconfig.json","jsconfig.json"].find(c=>Z.existsSync(q.resolve(r,c)));if(i){let c=await Z.promises.readFile(q.resolve(r,i),"utf8"),{compilerOptions:e}=JSON.parse(Se(c,{trailingCommas:!0}));e.paths&&(s=Object.entries(e.paths).reduce((n,[g,[a]])=>(g.endsWith("*")&&a.endsWith("*")&&(n[g.replace(/\*$/,"")]=a.replace(/\*$/,"")),n),{}))}return s["@/"]||(s["@/"]=Z.existsSync(q.resolve(r,"src"))?"./src/":"./"),s=Object.entries(s).sort(([c],[e])=>e.length-c.length).reduce((c,[e,n])=>(c[e]=n,c),{}),s};import E from"node:fs";import j from"node:path";import je from"node:path";var w=({cwd:r,aliases:s,filepath:i})=>{var a;let c=i;for(let o in s)i=i.replace(s[o].replaceAll("./","").replaceAll("../",""),"");let e=i.startsWith("registry/")?i.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(o,t)=>`blocks/${t?t+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(o,t)=>`charts/${t?t+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(o,t)=>`${t?t+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(o,t)=>`components/${t?t+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(o,t)=>`hooks/${t?t+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(o,t)=>`lib/${t?t+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(o,t)=>`components/ui/${t?t+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):i.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),n=e.toLowerCase().replace(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)\//,"").replace(/\/(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)\//,"/").replace(/\.[^\/.]+$/,"").replace(/\/index$/,"").replace(/\/page$/,"").replace(/\/route$/,"").replace(/\/\[.*\]$/,"").replace(/(\b\w+)\b\/\1\b/g,"$1").replace(/\//g,"-");e=e.startsWith("blocks/")&&e.includes("components/")?e.replace(/^blocks\//,"").replace(/(?:([^\/]*)\/)?components\//,(o,t)=>`components/${t?t+"/":""}`).replace(/.*?(components\/)/,"$1"):e;let g=e.endsWith("page.tsx")?"registry:page":e.endsWith(".css")?"registry:style":((a=e.match(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:a[1].replace("blocks","registry:block").replace("components/charts","registry:component").replace("components/ui","registry:ui").replace("components","registry:component").replace("hooks","registry:hook").replace("lib","registry:lib").replace("utils","registry:lib").replace("helpers","registry:lib"))||"registry:file";return e=e.startsWith("blocks/")&&e.endsWith("page.tsx")?e.replace(/^blocks\//,"app/"):e,{type:g,name:n,import:"@/"+e.replace(r+je.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:c.split("/").length>1?e:`~/${e}`,path:i}};var ae=async({cwd:r,aliases:s,registryFiles:i})=>{let c=j.resolve(r,"registry.json"),e={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};E.existsSync(c)&&(e=k({},JSON.parse(await E.promises.readFile(c,"utf8"))));let n=[];for(let t of i)w({cwd:r,aliases:s,filepath:t}).type==="registry:ui"&&n.push({type:"registry:ui",path:t});let g=null,a=null,o=E.existsSync(j.relative(process.cwd(),j.resolve(r,"app/globals.css")))?j.relative(process.cwd(),j.resolve(r,"app/globals.css")):E.existsSync(j.relative(process.cwd(),j.resolve(r,"src/app/globals.css")))?j.relative(process.cwd(),j.resolve(r,"src/app/globals.css")):null;if(o){let t=await E.promises.readFile(o,"utf8"),p=t.match(/:root\s*{([^}]*)}/);g=p?p[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(m=>m.trim()).filter(m=>m.length).map(m=>{let[f,b]=m.split(":").map(R=>R.trim());return{name:f.replace(/^--/,""),value:b}}):null;let d=t.match(/\.dark\s*{([^}]*)}/);a=d?d[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(m=>m.trim()).filter(m=>m.length).map(m=>{let[f,b]=m.split(":").map(R=>R.trim());return{name:f.replace(/^--/,""),value:b}}):null}return g&&a&&e.items.push({name:"style",type:"registry:style",cssVars:{light:Object.fromEntries(g.map(t=>[t.name,t.value])),dark:Object.fromEntries(a.map(t=>[t.name,t.value]))}}),n.length&&e.items.push({name:"ui",type:"registry:ui",files:n}),e};import Re from"node:fs";import Fe from"node:path";import{glob as Oe}from"tinyglobby";var A=async({cwd:r,patterns:s=["**",".**"],ignore:i=[]})=>{s=Array.isArray(s)?s:[s],s=s.map(e=>e.replace(/^'|'$/g,"").replace(/^"|"$/g,"").trim()),s=[...s,...s.flatMap(e=>e.includes("*")?[]:[e+".**",e+"**"])],s=s.filter(Boolean),i=typeof i=="string"?i.split(",").map(e=>e.trim()):i,i=i.filter(Boolean);let c=await Oe(s,{cwd:r,ignore:i.filter(e=>!s.includes(e))});for(let e of s)if(!c.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let n=Fe.resolve(r,e);(await Re.promises.stat(n)).isFile()&&c.push(e)}catch(n){continue}return[...new Set(c)]};var le=async({cwd:r,patterns:s,ignore:i,patternsOnly:c})=>{let e=[];if(!c){for(let n of ne)if(e=await A({cwd:r,patterns:n,ignore:i}),e.length)break}if(s.length&&(e=e.concat(await A({cwd:r,patterns:s,ignore:i}))),!e.length)throw new Error("No files/directories found to build the registry from!");return e=e.sort((n,g)=>n.localeCompare(g,void 0,{numeric:!0,sensitivity:"base"})).filter(n=>!n.startsWith("registry/registry")&&!n.startsWith("registry/index")&&!n.startsWith("src/registry/registry")&&!n.startsWith("src/registry/index")),e};import pe from"node:fs";import ce from"node:path";var M={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var K=async({cwd:r,aliases:s,filepaths:i,resolved:c})=>{c=c!=null?c:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let n of i){if(c.has(n))continue;c.add(n),e.files.push(n),e.content[n]||(e.content[n]=await pe.promises.readFile(ce.resolve(r,n),"utf8"));let{dependencies:g,devDependencies:a,files:o,transformations:t}=await B({cwd:r,aliases:s,filepath:n,content:e.content[n]});o.forEach(p=>e.files.push(p)),g.forEach(p=>e.dependencies.push(p)),a.forEach(p=>e.devDependencies.push(p))}for(let n of e.files){let{dependencies:g,devDependencies:a,files:o,content:t}=await K({cwd:r,aliases:s,filepaths:[n],resolved:c});e.content[n]||(e.content[n]=t[n]||await pe.promises.readFile(ce.resolve(r,n),"utf8")),o.forEach(p=>e.files.push(p)),g.forEach(p=>e.dependencies.push(p)),a.forEach(p=>e.devDependencies.push(p))}e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort();for(let n of e.files){let{transformations:g}=await B({cwd:r,aliases:s,filepath:n,content:e.content[n]});e.content[n]=e.content[n].replace(M.imports,a=>{let o=a.match(/['"](.*)['"]/);return o&&g[o[1]]?a.replace(o[1],g[o[1]].import):a})}return e};import me from"node:fs";import J from"node:path";var We=async({cwd:r,current:s,aliases:i})=>{s=s.replace(new RegExp(`^${Object.keys(i).find(e=>s.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))}`),i[Object.keys(i).find(e=>s.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))]),s=s.replace(/^\.\//g,"");let c=await A({cwd:r,patterns:s});return s=c.find(e=>e.startsWith(s+"."))||c.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},De=async({cwd:r,filepath:s,current:i})=>{i=J.relative(r,J.resolve(r,J.dirname(s),i));let c=await A({cwd:r,patterns:i});return i=c.find(e=>e.startsWith(i+"."))||c.find(e=>e.startsWith(i+"/index"))||i,i.replace(r+"/","")},B=async({cwd:r,aliases:s,filepath:i,content:c})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},n=c.match(M.imports)||[];if(!n.length)return e;n=n.map(g=>{var a;return(a=g.match(/['"](.*)['"]/))==null?void 0:a[1].replace(/\/\//g,"/")});for(let g of n){let a=g;if(Object.keys(s).some(t=>g.startsWith(t.replace(/\.\//g,"").replace(/\.\.\//g,""))))g=await We({cwd:r,aliases:s,current:g}),e.transformations[a]=w({cwd:r,aliases:s,filepath:g}),e.files.push(g);else if(g.startsWith("."))g=await De({cwd:r,filepath:i,current:g}),e.transformations[a]=w({cwd:r,aliases:s,filepath:g}),e.files.push(g);else{let t=J.resolve(r,"package.json"),p={};if(me.existsSync(t)){let d=JSON.parse(await me.promises.readFile(t,"utf8"));p=k({},d.devDependencies)}if(g.startsWith("@")){let d=g.split("/").slice(0,2).join("/");p[d]?e.devDependencies.push(d):e.dependencies.push(d)}else{let d=g.split("/")[0];p[d]?e.devDependencies.push(d):e.dependencies.push(d)}}}return e};import{green as Pe}from"yoctocolors";var I="smart-registry",G="1.17.0-canary.3";var N={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var ge=`Version:
6
6
  ${I}@${G}
7
7
 
8
8
  Usage:
@@ -31,9 +31,9 @@ Cleanup:
31
31
  --remove-prefix remove given prefix from the registry item names (default: none)
32
32
 
33
33
  Author:
34
- ${N.name} <${N.email}> (${N.url})`,Ee=r=>{try{return Pe(r)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},_e=async()=>{var r,t,i,p,e,n,m,a;try{let{positionals:o,values:s}=Ee({allowPositionals:!0,options:{output:{type:"string",short:"o",default:"public/r"},cwd:{type:"string",short:"c"},ignore:{type:"string",short:"i",default:""},"with-utils":{type:"boolean",short:"u",default:!1},"patterns-only":{type:"boolean",short:"p",default:!1},"registry-only":{type:"boolean",short:"r",default:!1},"codemod-radix":{type:"boolean"},"codemod-camel-to-kebab":{type:"boolean"},"remove-prefix":{type:"string",default:""},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});o.length||(s.version&&(console.log(`${I}@${G}`),process.exit(0)),s.help&&(console.log(ge),process.exit(0)));let c=v.resolve((r=s.cwd)!=null?r:process.cwd());s["codemod-radix"]&&(await ie({cwd:c}),process.exit(0)),s["codemod-camel-to-kebab"]&&(await ee({cwd:c}),process.exit(0));let d=await oe(c),g=s["registry-only"]?[]:await le({cwd:c,patterns:o,ignore:s.ignore,patternsOnly:s["patterns-only"]}),u=await ae({cwd:c,aliases:d,registryFiles:g}),b=[],R=((t=u.items)==null?void 0:t.map(y=>y.name))||[],O=T(k({},u),{items:[]});for(let y of[...g,...R])try{if((i=O.items)!=null&&i.find(l=>l.name===y||l.name===w({cwd:c,aliases:d,filepath:y}).name))continue;let h=((p=u.items)==null?void 0:p.find(l=>l.name===y||l.name===w({cwd:c,aliases:d,filepath:y}).name))||{},S=await q({cwd:c,aliases:d,filepaths:[...R.includes(y)?[]:[y],...((e=h==null?void 0:h.files)==null?void 0:e.map(l=>l.path))||[]]}),W={dependencies:[...new Set([...S.dependencies,...(h==null?void 0:h.dependencies)||[]])].filter((l,$,x)=>!x.some(A=>A!==l&&A.startsWith(l+"@"))).sort(),devDependencies:[...new Set([...S.devDependencies,...(h==null?void 0:h.devDependencies)||[]])].filter((l,$,x)=>!x.some(A=>A!==l&&A.startsWith(l+"@"))).sort(),registryDependencies:[...new Set([...(h==null?void 0:h.registryDependencies)||[]])].sort()},f=k(T(k(k(k({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:w({cwd:c,aliases:d,filepath:y}).name.replace(new RegExp(`^${s["remove-prefix"]||""}-?`),""),type:h.type||w({cwd:c,aliases:d,filepath:y}).type||"registry:file"},W.dependencies.length&&{dependencies:W.dependencies}),W.devDependencies.length&&{devDependencies:W.devDependencies}),W.registryDependencies.length&&{registryDependencies:W.registryDependencies}),{files:S.files.map(l=>({type:l.endsWith(".css")?"registry:theme":w({cwd:c,aliases:d,filepath:l}).type||"registry:file",target:w({cwd:c,aliases:d,filepath:l}).target||l,content:S.content[l],path:l}))}),Object.fromEntries(Object.entries(h).filter(([l])=>!["$schema","name","type","dependencies","devDependencies","registryDependencies","files"].includes(l))));f.files.length&&(f.files.length>1&&!s["with-utils"]&&(f.files=f.files.filter(l=>l.target!=="lib/utils.ts"),f.dependencies=f.dependencies.filter(l=>!["clsx","tailwind-merge"].includes(l))),f.files.some(l=>l.path===y)?f.files=f.files.sort((l,$)=>{if(l.path===y)return-1;if($.path===y)return 1;let x=E.items.files.type.default;return x.indexOf(l.type)-x.indexOf($.type)}):f.files=[f.files[0],...f.files.slice(1).sort((l,$)=>{let x=E.items.files.type.default;return x.indexOf(l.type)-x.indexOf($.type)})]),f.dependencies&&(f.dependencies=f.dependencies.filter(l=>l!=="react"));for(let l in f)(Array.isArray(f[l])&&f[l].length===0||typeof f[l]=="object"&&f[l]!==null&&Object.keys(f[l]).length===0)&&delete f[l];f=Object.keys(f).sort((l,$)=>{let x=E.items.default;return x.indexOf(l)-x.indexOf($)}).reduce((l,$)=>(l[$]=f[$],l),{});let L=v.resolve(c,s.output,f.name+".json");console.log(`${y==="ui"||y==="style"?`- \u{1F525} 'registry:${y}' pack`.padEnd(Math.max(...g.map(l=>v.relative(process.cwd(),v.resolve(c,l)).length))+4," "):"- "+v.relative(process.cwd(),v.resolve(c,y)).padEnd(Math.max(...g.map(l=>v.relative(process.cwd(),v.resolve(c,l)).length))+2," ")} ${(n=S.dependencies)!=null&&n.length?"\u{1F4E6}"+String(S.dependencies.length).padEnd(2," "):" "} ${((m=f.files)==null?void 0:m.length)-1?"\u{1F4C4}"+String(f.files.length).padEnd(2," "):" "} ${v.relative(process.cwd(),L)}`),await H.promises.mkdir(v.dirname(L),{recursive:!0}),await H.promises.writeFile(L,JSON.stringify(f,null,2)+`
35
- `),(a=f.files)==null||a.forEach(l=>{delete l.content}),delete f.$schema,O.items.push(f)}catch(h){b.push(y+": "+h.message);continue}O.items.sort((y,h)=>y.name.localeCompare(h.name,void 0,{numeric:!0,sensitivity:"base"})).sort((y,h)=>{let S=E.items.type.default;return S.indexOf(y.type)-S.indexOf(h.type)}),await H.promises.writeFile(v.resolve(c,s.output,"registry.json"),JSON.stringify(O,null,2)+`
34
+ ${N.name} <${N.email}> (${N.url})`,_e=r=>{try{return Ae(r)}catch(s){throw new Error(`Error parsing arguments: ${s.message}`)}},Ee=async()=>{var r,s,i,c,e,n,g,a;try{let{positionals:o,values:t}=_e({allowPositionals:!0,options:{output:{type:"string",short:"o",default:"public/r"},cwd:{type:"string",short:"c"},ignore:{type:"string",short:"i",default:""},"with-utils":{type:"boolean",short:"u",default:!1},"patterns-only":{type:"boolean",short:"p",default:!1},"registry-only":{type:"boolean",short:"r",default:!1},"codemod-radix":{type:"boolean"},"codemod-camel-to-kebab":{type:"boolean"},"remove-prefix":{type:"string",default:""},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});o.length||(t.version&&(console.log(`${I}@${G}`),process.exit(0)),t.help&&(console.log(ge),process.exit(0)));let p=v.resolve((r=t.cwd)!=null?r:process.cwd());t["codemod-radix"]&&(await ie({cwd:p}),process.exit(0)),t["codemod-camel-to-kebab"]&&(await ee({cwd:p}),process.exit(0));let d=await oe(p),m=t["registry-only"]?[]:await le({cwd:p,patterns:o,ignore:t.ignore,patternsOnly:t["patterns-only"]}),f=await ae({cwd:p,aliases:d,registryFiles:m}),b=[],R=((s=f.items)==null?void 0:s.map(y=>y.name))||[],O=T(k({},f),{items:[]});for(let y of[...m,...R])try{if((i=O.items)!=null&&i.find(l=>l.name===y||l.name===w({cwd:p,aliases:d,filepath:y}).name))continue;let h=((c=f.items)==null?void 0:c.find(l=>l.name===y||l.name===w({cwd:p,aliases:d,filepath:y}).name))||{},S=await K({cwd:p,aliases:d,filepaths:[...R.includes(y)?[]:[y],...((e=h==null?void 0:h.files)==null?void 0:e.map(l=>l.path))||[]]}),W={dependencies:[...new Set([...S.dependencies,...(h==null?void 0:h.dependencies)||[]])].filter((l,$,x)=>!x.some(P=>P!==l&&P.startsWith(l+"@"))).sort(),devDependencies:[...new Set([...S.devDependencies,...(h==null?void 0:h.devDependencies)||[]])].filter((l,$,x)=>!x.some(P=>P!==l&&P.startsWith(l+"@"))).sort(),registryDependencies:[...new Set([...(h==null?void 0:h.registryDependencies)||[]])].sort()},u=k(T(k(k(k({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:w({cwd:p,aliases:d,filepath:y}).name.replace(new RegExp(`^${t["remove-prefix"]||""}-?`),""),type:h.type||w({cwd:p,aliases:d,filepath:y}).type||"registry:file"},W.dependencies.length&&{dependencies:W.dependencies}),W.devDependencies.length&&{devDependencies:W.devDependencies}),W.registryDependencies.length&&{registryDependencies:W.registryDependencies}),{files:S.files.map(l=>({type:l.endsWith(".css")?"registry:theme":w({cwd:p,aliases:d,filepath:l}).type||"registry:file",target:w({cwd:p,aliases:d,filepath:l}).target||l,content:S.content[l],path:l}))}),Object.fromEntries(Object.entries(h).filter(([l])=>!["$schema","name","type","dependencies","devDependencies","registryDependencies","files"].includes(l))));u.files.length&&(u.files.length>1&&!t["with-utils"]&&(u.files=u.files.filter(l=>l.target!=="lib/utils.ts"),u.dependencies=u.dependencies.filter(l=>!["clsx","tailwind-merge"].includes(l))),u.files.some(l=>l.path===y)?u.files=u.files.sort((l,$)=>{if(l.path===y)return-1;if($.path===y)return 1;let x=_.items.files.type.default;return x.indexOf(l.type)-x.indexOf($.type)}):u.files=[u.files[0],...u.files.slice(1).sort((l,$)=>{let x=_.items.files.type.default;return x.indexOf(l.type)-x.indexOf($.type)})]),u.dependencies&&(u.dependencies=u.dependencies.filter(l=>l!=="react"));for(let l in u)(Array.isArray(u[l])&&u[l].length===0||typeof u[l]=="object"&&u[l]!==null&&Object.keys(u[l]).length===0)&&delete u[l];u=Object.keys(u).sort((l,$)=>{let x=_.items.default;return x.indexOf(l)-x.indexOf($)}).reduce((l,$)=>(l[$]=u[$],l),{});let L=v.resolve(p,t.output,u.name+".json");console.log(`${y==="ui"||y==="style"?`- \u{1F525} 'registry:${y}' pack`.padEnd(Math.max(...m.map(l=>v.relative(process.cwd(),v.resolve(p,l)).length))+4," "):"- "+v.relative(process.cwd(),v.resolve(p,y)).padEnd(Math.max(...m.map(l=>v.relative(process.cwd(),v.resolve(p,l)).length))+2," ")} ${(n=S.dependencies)!=null&&n.length?"\u{1F4E6}"+String(S.dependencies.length).padEnd(2," "):" "} ${((g=u.files)==null?void 0:g.length)-1?"\u{1F4C4}"+String(u.files.length).padEnd(2," "):" "} ${v.relative(process.cwd(),L)}`),await H.promises.mkdir(v.dirname(L),{recursive:!0}),await H.promises.writeFile(L,JSON.stringify(u,null,2)+`
35
+ `),(a=u.files)==null||a.forEach(l=>{delete l.content}),delete u.$schema,O.items.push(u)}catch(h){b.push(y+": "+h.message);continue}O.items.sort((y,h)=>y.name.localeCompare(h.name,void 0,{numeric:!0,sensitivity:"base"})).sort((y,h)=>{let S=_.items.type.default;return S.indexOf(y.type)-S.indexOf(h.type)}),await H.promises.writeFile(v.resolve(p,t.output,"registry.json"),JSON.stringify(O,null,2)+`
36
36
  `);let de=O.items.reduce((y,h)=>(y[h.type]=(y[h.type]||0)+1,y),{});console.log(),console.table(Object.entries(de).map(([y,h])=>({Type:y,Items:h}))),console.log(`
37
- - Master (shadcn-compatible) "registry.json" file created at: ${Ae(v.relative(process.cwd(),v.resolve(c,s.output,"registry.json")))} with ${O.items.length} items`),b.length&&(console.log(),b.forEach(y=>console.error(`\x1B[31m- ${y}\x1B[0m`))),process.exit(0)}catch(o){console.error(ge),console.error(`
37
+ - Master (shadcn-compatible) "registry.json" file created at: ${Pe(v.relative(process.cwd(),v.resolve(p,t.output,"registry.json")))} with ${O.items.length} items`),b.length&&(console.log(),b.forEach(y=>console.error(`\x1B[31m- ${y}\x1B[0m`))),process.exit(0)}catch(o){console.error(ge),console.error(`
38
38
  ${o.message}
39
- `),process.exit(1)}};_e();
39
+ `),process.exit(1)}};Ee();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "smart-registry",
3
- "version": "1.17.0-canary.2",
3
+ "version": "1.17.0-canary.3",
4
4
  "description": "A zero-configuration (no registry.json required), shadcn add / open in v0 compatible registry builder.",
5
5
  "keywords": [
6
6
  "shadcn",