smart-registry 1.17.0-canary.13 → 1.17.0-canary.14

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