smart-registry 1.17.0-canary.5 → 1.17.0-canary.7

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