smart-registry 1.4.0 → 1.6.0

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/README.md CHANGED
@@ -1,5 +1,9 @@
1
1
  # Smart Registry
2
2
 
3
+ Drop-in replacement for `shadcn build`, generate non-error prone registry with automatic detection of dependencies and files.
4
+
5
+ [![GitHub](https://img.shields.io/github/license/nrjdalal/smart-registry?color=blue)](
6
+
3
7
  [![Twitter](https://img.shields.io/twitter/follow/nrjdalal_com?label=%40nrjdalal_com)](https://twitter.com/nrjdalal_com)
4
8
  [![npm](https://img.shields.io/npm/v/smart-registry?color=red&logo=npm)](https://www.npmjs.com/package/smart-registry)
5
9
  [![npm](https://img.shields.io/npm/dt/smart-registry?color=red&logo=npm)](https://www.npmjs.com/package/smart-registry)
@@ -144,7 +148,8 @@ Codemods:
144
148
  --codemod-radix migrate to unify "@radix-ui/react-*" imports to "radix-ui"
145
149
 
146
150
  Cleanup:
147
- --remove-prefix remove given prefix from the registry item name (default: none)
151
+ --no-utils remove @/lib/utils from the registry items (default: false)
152
+ --remove-prefix remove given prefix from the registry item names (default: none)
148
153
 
149
154
  Author:
150
155
  Neeraj Dalal <admin@nrjdalal.com> (https://nrjdalal.com)
package/dist/bin/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  #!/usr/bin/env node
2
2
  var pe=Object.defineProperty,ce=Object.defineProperties;var me=Object.getOwnPropertyDescriptors;var H=Object.getOwnPropertySymbols;var ge=Object.prototype.hasOwnProperty,de=Object.prototype.propertyIsEnumerable;var K=(r,t,s)=>t in r?pe(r,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[t]=s,$=(r,t)=>{for(var s in t||(t={}))ge.call(t,s)&&K(r,s,t[s]);if(H)for(var s of H(t))de.call(t,s)&&K(r,s,t[s]);return r},C=(r,t)=>ce(r,me(t));import G from"node:fs";import v from"node:path";import{parseArgs as Se}from"node:util";import A,{existsSync as X}from"node:fs";import{readFile as ue}from"node:fs/promises";import V from"node:path";import{detect as fe}from"@antfu/ni";async function Q(r,{withFallback:t}={withFallback:!1}){let s=await fe({programmatic:!0,cwd:r});if(s==="yarn@berry")return"yarn";if(s==="pnpm@6")return"pnpm";if(s==="bun")return"bun";if(s==="deno")return"deno";if(!t)return s!=null?s:"npm";let o=process.env.npm_config_user_agent||"";return o.startsWith("yarn")?"yarn":o.startsWith("pnpm")?"pnpm":o.startsWith("bun")?"bun":"npm"}import{execa as Y}from"execa";import{glob as ye}from"tinyglobby";var Z=async({cwd:r})=>{let t=V.resolve(r,".gitignore"),s=X(t)?(await ue(t,"utf8")).split(`
3
- `).filter(n=>n.trim()&&!n.startsWith("#")).map(n=>n.replace(/^\//,"").replace(/^/,"**/")):[],o=await ye(["**/*.ts","**/*.tsx","**/*.js","**/*.jsx"],{cwd:r,ignore:s}),e=new Set,i=o.map(async n=>{let m=V.resolve(r,n),l=await A.promises.readFile(m,"utf-8"),d=l.replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(u,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(l)&&(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")),A.promises.writeFile(m,d,"utf-8")});await Promise.all(i);let a=V.resolve(r,"registry.json");if(X(a)){let n=await A.promises.readFile(a,"utf-8"),m=JSON.parse(n),l=u=>{for(let h in u)h==="dependencies"||h==="devDependencies"?u[h]=Array.from(new Set(u[h].map(b=>e.has(b)?"radix-ui":b))):typeof u[h]=="object"&&u[h]!==null&&l(u[h])};l(m);let d=JSON.stringify(m,null,2);await A.promises.writeFile(a,d,"utf-8")}let c=await Q(r);e.size&&await Y(c,[c==="npm"?"uninstall":"remove",...Array.from(e)],{cwd:r}),await Y(c,[c==="npm"?"install":"add","radix-ui"],{cwd:r}),console.log(`
4
- Codemod ran successfully. Please run the command again without the --codemod-radix flag to generate the registry.`)};var ee=["registry/**","src/registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],W={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 T from"node:path";import he from"strip-json-comments";var te=async r=>{let t={},s=["tsconfig.json","jsconfig.json"].find(o=>B.existsSync(T.resolve(r,o)));if(s){let o=await B.promises.readFile(T.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(he(o,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((i,[a,[c]])=>(a.endsWith("*")&&c.endsWith("*")&&(i[a.replace(/\*$/,"")]=c.replace(/\*$/,"")),i),{}))}return t["@/"]||(t["@/"]=B.existsSync(T.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([o],[e])=>e.length-o.length).reduce((o,[e,i])=>(o[e]=i,o),{}),t};import E from"node:fs";import j from"node:path";import ve from"node:path";var w=({cwd:r,aliases:t,filepath:s})=>{var a;let o=s;for(let c in t)s=s.replace(t[c].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(c,n)=>`blocks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(c,n)=>`charts/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(c,n)=>`${n?n+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(c,n)=>`components/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(c,n)=>`hooks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(c,n)=>`lib/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(c,n)=>`components/ui/${n?n+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):s.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),i=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,"-");return{type:e.endsWith("page.tsx")?"registry:page":((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",name:i,import:"@/"+e.replace(r+ve.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:o.split("/").length>1?e:`~/${e}`,path:s}};var se=async({cwd:r,aliases:t,registryFiles:s})=>{let o=j.resolve(r,"registry.json"),e={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};E.existsSync(o)&&(e=$({},JSON.parse(await E.promises.readFile(o,"utf8"))));let i=[];for(let m of s)w({cwd:r,aliases:t,filepath:m}).type==="registry:ui"&&i.push({type:"registry:ui",path:m});let a=null,c=null,n=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(n){let m=await E.promises.readFile(n,"utf8"),l=m.match(/:root\s*{([^}]*)}/);a=l?l[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(u=>u.trim()).filter(u=>u.length).map(u=>{let[h,b]=u.split(":").map(R=>R.trim());return{name:h.replace(/^--/,""),value:b}}):null;let d=m.match(/\.dark\s*{([^}]*)}/);c=d?d[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(u=>u.trim()).filter(u=>u.length).map(u=>{let[h,b]=u.split(":").map(R=>R.trim());return{name:h.replace(/^--/,""),value:b}}):null}return a&&c&&e.items.push({name:"style",type:"registry:style",cssVars:{light:Object.fromEntries(a.map(m=>[m.name,m.value])),dark:Object.fromEntries(c.map(m=>[m.name,m.value]))}}),i.length&&e.items.push({name:"ui",type:"registry:ui",files:i}),e};import be from"node:fs";import xe from"node:path";import{glob as we}from"tinyglobby";var F=async({cwd:r,patterns:t=["**",".**"],ignore:s=[]})=>{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),s=typeof s=="string"?s.split(",").map(e=>e.trim()):s,s=s.filter(Boolean);let o=await we(t,{cwd:r,ignore:s.filter(e=>!t.includes(e))});for(let e of t)if(!o.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let i=xe.resolve(r,e);(await be.promises.stat(i)).isFile()&&o.push(e)}catch(i){continue}return[...new Set(o)]};var re=async({cwd:r,patterns:t,ignore:s,patternsOnly:o})=>{let e=[];if(!o){for(let i of ee)if(e=await F({cwd:r,patterns:i,ignore:s}),e.length)break}if(t.length&&(e=e.concat(await F({cwd:r,patterns:t,ignore:s}))),!e.length)throw new Error("No files/directories found to build the registry from!");return e=e.sort((i,a)=>i.localeCompare(a,void 0,{numeric:!0,sensitivity:"base"})),e};import ie from"node:fs";import ne from"node:path";var _={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:s,resolved:o})=>{o=o!=null?o:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let i of s){if(o.has(i))continue;o.add(i),e.files.push(i),e.content[i]||(e.content[i]=await ie.promises.readFile(ne.resolve(r,i),"utf8"));let{dependencies:a,devDependencies:c,files:n,transformations:m}=await z({cwd:r,aliases:t,filepath:i,content:e.content[i]});n.forEach(l=>e.files.push(l)),a.forEach(l=>e.dependencies.push(l)),c.forEach(l=>e.devDependencies.push(l))}for(let i of e.files){let{dependencies:a,devDependencies:c,files:n,content:m}=await q({cwd:r,aliases:t,filepaths:[i],resolved:o});e.content[i]||(e.content[i]=m[i]||await ie.promises.readFile(ne.resolve(r,i),"utf8")),n.forEach(l=>e.files.push(l)),a.forEach(l=>e.dependencies.push(l)),c.forEach(l=>e.devDependencies.push(l))}e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort();for(let i of e.files){let{transformations:a}=await z({cwd:r,aliases:t,filepath:i,content:e.content[i]});e.content[i]=e.content[i].replace(_.imports,c=>{let n=c.match(/['"](.*)['"]/);return n&&a[n[1]]?c.replace(n[1],a[n[1]].import):c})}return e};import oe from"node:fs";import J from"node:path";var ke=async({cwd:r,current:t,aliases:s})=>{t=t.replace(new RegExp(`^${Object.keys(s).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))}`),s[Object.keys(s).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))]),t=t.replace(/^\.\//g,"");let o=await F({cwd:r,patterns:t});return t=o.find(e=>e.startsWith(t+"."))||o.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},$e=async({cwd:r,filepath:t,current:s})=>{s=J.relative(r,J.resolve(r,J.dirname(t),s));let o=await F({cwd:r,patterns:s});return s=o.find(e=>e.startsWith(s+"."))||o.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},z=async({cwd:r,aliases:t,filepath:s,content:o})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},i=o.match(_.imports)||[];if(!i.length)return e;i=i.map(a=>{var c;return(c=a.match(/['"](.*)['"]/))==null?void 0:c[1].replace(/\/\//g,"/")});for(let a of i){let c=a;if(Object.keys(t).some(m=>a.startsWith(m.replace(/\.\//g,"").replace(/\.\.\//g,""))))a=await ke({cwd:r,aliases:t,current:a}),e.transformations[c]=w({cwd:r,aliases:t,filepath:a}),e.files.push(a);else if(a.startsWith("."))a=await $e({cwd:r,filepath:s,current:a}),e.transformations[c]=w({cwd:r,aliases:t,filepath:a}),e.files.push(a);else{let m=J.resolve(r,"package.json"),l={};if(oe.existsSync(m)){let d=JSON.parse(await oe.promises.readFile(m,"utf8"));l=$({},d.devDependencies)}if(a.startsWith("@")){let d=a.split("/").slice(0,2).join("/");l[d]?e.devDependencies.push(d):e.dependencies.push(d)}else{let d=a.split("/")[0];l[d]?e.devDependencies.push(d):e.dependencies.push(d)}}}return e};import{green as je}from"yoctocolors";var M="smart-registry",U="1.4.0";var I={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var ae=`Version:
3
+ `).filter(n=>n.trim()&&!n.startsWith("#")).map(n=>n.replace(/^\//,"").replace(/^/,"**/")):[],o=await ye(["**/*.ts","**/*.tsx","**/*.js","**/*.jsx"],{cwd:r,ignore:s}),e=new Set,i=o.map(async n=>{let c=V.resolve(r,n),l=await A.promises.readFile(c,"utf-8"),d=l.replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(u,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(l)&&(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")),A.promises.writeFile(c,d,"utf-8")});await Promise.all(i);let a=V.resolve(r,"registry.json");if(X(a)){let n=await A.promises.readFile(a,"utf-8"),c=JSON.parse(n),l=u=>{for(let h in u)h==="dependencies"||h==="devDependencies"?u[h]=Array.from(new Set(u[h].map(b=>e.has(b)?"radix-ui":b))):typeof u[h]=="object"&&u[h]!==null&&l(u[h])};l(c);let d=JSON.stringify(c,null,2);await A.promises.writeFile(a,d,"utf-8")}let m=await Q(r);e.size&&await Y(m,[m==="npm"?"uninstall":"remove",...Array.from(e)],{cwd:r}),await Y(m,[m==="npm"?"install":"add","radix-ui"],{cwd:r}),console.log(`
4
+ Codemod ran successfully. Please run the command again without the --codemod-radix flag to generate the registry.`)};var ee=["registry/**","src/registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],W={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 T from"node:path";import he from"strip-json-comments";var te=async r=>{let t={},s=["tsconfig.json","jsconfig.json"].find(o=>B.existsSync(T.resolve(r,o)));if(s){let o=await B.promises.readFile(T.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(he(o,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((i,[a,[m]])=>(a.endsWith("*")&&m.endsWith("*")&&(i[a.replace(/\*$/,"")]=m.replace(/\*$/,"")),i),{}))}return t["@/"]||(t["@/"]=B.existsSync(T.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([o],[e])=>e.length-o.length).reduce((o,[e,i])=>(o[e]=i,o),{}),t};import E from"node:fs";import j from"node:path";import ve from"node:path";var w=({cwd:r,aliases:t,filepath:s})=>{var a;let o=s;for(let m in t)s=s.replace(t[m].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(m,n)=>`blocks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(m,n)=>`charts/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(m,n)=>`${n?n+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(m,n)=>`components/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(m,n)=>`hooks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(m,n)=>`lib/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(m,n)=>`components/ui/${n?n+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):s.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),i=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,"-");return{type:e.endsWith("page.tsx")?"registry:page":((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",name:i,import:"@/"+e.replace(r+ve.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:o.split("/").length>1?e:`~/${e}`,path:s}};var se=async({cwd:r,aliases:t,registryFiles:s})=>{let o=j.resolve(r,"registry.json"),e={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};E.existsSync(o)&&(e=$({},JSON.parse(await E.promises.readFile(o,"utf8"))));let i=[];for(let c of s)w({cwd:r,aliases:t,filepath:c}).type==="registry:ui"&&i.push({type:"registry:ui",path:c});let a=null,m=null,n=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(n){let c=await E.promises.readFile(n,"utf8"),l=c.match(/:root\s*{([^}]*)}/);a=l?l[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(u=>u.trim()).filter(u=>u.length).map(u=>{let[h,b]=u.split(":").map(R=>R.trim());return{name:h.replace(/^--/,""),value:b}}):null;let d=c.match(/\.dark\s*{([^}]*)}/);m=d?d[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(u=>u.trim()).filter(u=>u.length).map(u=>{let[h,b]=u.split(":").map(R=>R.trim());return{name:h.replace(/^--/,""),value:b}}):null}return a&&m&&e.items.push({name:"style",type:"registry:style",cssVars:{light:Object.fromEntries(a.map(c=>[c.name,c.value])),dark:Object.fromEntries(m.map(c=>[c.name,c.value]))}}),i.length&&e.items.push({name:"ui",type:"registry:ui",files:i}),e};import be from"node:fs";import xe from"node:path";import{glob as we}from"tinyglobby";var F=async({cwd:r,patterns:t=["**",".**"],ignore:s=[]})=>{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),s=typeof s=="string"?s.split(",").map(e=>e.trim()):s,s=s.filter(Boolean);let o=await we(t,{cwd:r,ignore:s.filter(e=>!t.includes(e))});for(let e of t)if(!o.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let i=xe.resolve(r,e);(await be.promises.stat(i)).isFile()&&o.push(e)}catch(i){continue}return[...new Set(o)]};var re=async({cwd:r,patterns:t,ignore:s,patternsOnly:o})=>{let e=[];if(!o){for(let i of ee)if(e=await F({cwd:r,patterns:i,ignore:s}),e.length)break}if(t.length&&(e=e.concat(await F({cwd:r,patterns:t,ignore:s}))),!e.length)throw new Error("No files/directories found to build the registry from!");return e=e.sort((i,a)=>i.localeCompare(a,void 0,{numeric:!0,sensitivity:"base"})),e};import ie from"node:fs";import ne from"node:path";var _={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:s,resolved:o})=>{o=o!=null?o:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let i of s){if(o.has(i))continue;o.add(i),e.files.push(i),e.content[i]||(e.content[i]=await ie.promises.readFile(ne.resolve(r,i),"utf8"));let{dependencies:a,devDependencies:m,files:n,transformations:c}=await z({cwd:r,aliases:t,filepath:i,content:e.content[i]});n.forEach(l=>e.files.push(l)),a.forEach(l=>e.dependencies.push(l)),m.forEach(l=>e.devDependencies.push(l))}for(let i of e.files){let{dependencies:a,devDependencies:m,files:n,content:c}=await q({cwd:r,aliases:t,filepaths:[i],resolved:o});e.content[i]||(e.content[i]=c[i]||await ie.promises.readFile(ne.resolve(r,i),"utf8")),n.forEach(l=>e.files.push(l)),a.forEach(l=>e.dependencies.push(l)),m.forEach(l=>e.devDependencies.push(l))}e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort();for(let i of e.files){let{transformations:a}=await z({cwd:r,aliases:t,filepath:i,content:e.content[i]});e.content[i]=e.content[i].replace(_.imports,m=>{let n=m.match(/['"](.*)['"]/);return n&&a[n[1]]?m.replace(n[1],a[n[1]].import):m})}return e};import oe from"node:fs";import J from"node:path";var ke=async({cwd:r,current:t,aliases:s})=>{t=t.replace(new RegExp(`^${Object.keys(s).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))}`),s[Object.keys(s).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))]),t=t.replace(/^\.\//g,"");let o=await F({cwd:r,patterns:t});return t=o.find(e=>e.startsWith(t+"."))||o.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},$e=async({cwd:r,filepath:t,current:s})=>{s=J.relative(r,J.resolve(r,J.dirname(t),s));let o=await F({cwd:r,patterns:s});return s=o.find(e=>e.startsWith(s+"."))||o.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},z=async({cwd:r,aliases:t,filepath:s,content:o})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},i=o.match(_.imports)||[];if(!i.length)return e;i=i.map(a=>{var m;return(m=a.match(/['"](.*)['"]/))==null?void 0:m[1].replace(/\/\//g,"/")});for(let a of i){let m=a;if(Object.keys(t).some(c=>a.startsWith(c.replace(/\.\//g,"").replace(/\.\.\//g,""))))a=await ke({cwd:r,aliases:t,current:a}),e.transformations[m]=w({cwd:r,aliases:t,filepath:a}),e.files.push(a);else if(a.startsWith("."))a=await $e({cwd:r,filepath:s,current:a}),e.transformations[m]=w({cwd:r,aliases:t,filepath:a}),e.files.push(a);else{let c=J.resolve(r,"package.json"),l={};if(oe.existsSync(c)){let d=JSON.parse(await oe.promises.readFile(c,"utf8"));l=$({},d.devDependencies)}if(a.startsWith("@")){let d=a.split("/").slice(0,2).join("/");l[d]?e.devDependencies.push(d):e.dependencies.push(d)}else{let d=a.split("/")[0];l[d]?e.devDependencies.push(d):e.dependencies.push(d)}}}return e};import{green as je}from"yoctocolors";var M="smart-registry",U="1.6.0";var I={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var ae=`Version:
5
5
  ${M}@${U}
6
6
 
7
7
  Usage:
@@ -25,12 +25,13 @@ Codemods:
25
25
  --codemod-radix migrate to unify "@radix-ui/react-*" imports to "radix-ui"
26
26
 
27
27
  Cleanup:
28
- --remove-prefix remove given prefix from the registry item name (default: none)
28
+ --no-utils remove @/lib/utils from the registry items (default: false)
29
+ --remove-prefix remove given prefix from the registry item names (default: none)
29
30
 
30
31
  Author:
31
- ${I.name} <${I.email}> (${I.url})`,Re=r=>{try{return Se(r)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},Oe=async()=>{var r,t,s,o,e,i,a,c;try{let{positionals:n,values:m}=Re({allowPositionals:!0,options:{output:{type:"string",short:"o",default:"public/r"},cwd:{type:"string",short:"c"},ignore:{type:"string",short:"i",default:""},"patterns-only":{type:"boolean",short:"p",default:!1},"registry-only":{type:"boolean",short:"r",default:!1},"codemod-radix":{type:"boolean"},"remove-prefix":{type:"string",default:""},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});n.length||(m.version&&(console.log(`${M}@${U}`),process.exit(0)),m.help&&(console.log(ae),process.exit(0)));let l=v.resolve((r=m.cwd)!=null?r:process.cwd());m["codemod-radix"]&&(await Z({cwd:l}),process.exit(0));let d=await te(l),u=m["registry-only"]?[]:await re({cwd:l,patterns:n,ignore:m.ignore,patternsOnly:m["patterns-only"]}),h=await se({cwd:l,aliases:d,registryFiles:u}),b=[],R=((t=h.items)==null?void 0:t.map(g=>g.name))||[],O=C($({},h),{items:[]});for(let g of[...u,...R])try{if((s=O.items)!=null&&s.find(p=>p.name===g||p.name===w({cwd:l,aliases:d,filepath:g}).name))continue;let f=((o=h.items)==null?void 0:o.find(p=>p.name===g||p.name===w({cwd:l,aliases:d,filepath:g}).name))||{},S=await q({cwd:l,aliases:d,filepaths:[...R.includes(g)?[]:[g],...((e=f==null?void 0:f.files)==null?void 0:e.map(p=>p.path))||[]]}),D={dependencies:[...new Set([...S.dependencies,...(f==null?void 0:f.dependencies)||[]])].filter((p,k,x)=>!x.some(P=>P!==p&&P.startsWith(p+"@"))).sort(),devDependencies:[...new Set([...S.devDependencies,...(f==null?void 0:f.devDependencies)||[]])].filter((p,k,x)=>!x.some(P=>P!==p&&P.startsWith(p+"@"))).sort(),registryDependencies:[...new Set([...(f==null?void 0:f.registryDependencies)||[]])].sort()},y=$(C($($($({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:w({cwd:l,aliases:d,filepath:g}).name.replace(new RegExp(`^${m["remove-prefix"]||""}-?`),""),type:f.type||w({cwd:l,aliases:d,filepath:g}).type||"registry:file"},D.dependencies.length&&{dependencies:D.dependencies}),D.devDependencies.length&&{devDependencies:D.devDependencies}),D.registryDependencies.length&&{registryDependencies:D.registryDependencies}),{files:S.files.map(p=>({type:w({cwd:l,aliases:d,filepath:p}).type||"registry:file",target:w({cwd:l,aliases:d,filepath:p}).target||p,content:S.content[p],path:p}))}),Object.fromEntries(Object.entries(f).filter(([p])=>!["$schema","name","type","dependencies","devDependencies","registryDependencies","files"].includes(p))));y.files.length?y.files.some(p=>p.path===g)?y.files=y.files.sort((p,k)=>{if(p.path===g)return-1;if(k.path===g)return 1;let x=W.items.files.type.default;return x.indexOf(p.type)-x.indexOf(k.type)}):y.files=[y.files[0],...y.files.slice(1).sort((p,k)=>{let x=W.items.files.type.default;return x.indexOf(p.type)-x.indexOf(k.type)})]:delete y.files,y.cssVars&&Object.keys(y.cssVars).length===0&&delete y.cssVars,y=Object.keys(y).sort((p,k)=>{let x=W.items.default;return x.indexOf(p)-x.indexOf(k)}).reduce((p,k)=>(p[k]=y[k],p),{});let N=v.resolve(l,m.output,y.name+".json");console.log(`${g==="ui"||g==="style"?`- \u{1F525} 'registry:${g}' pack`.padEnd(Math.max(...u.map(p=>v.relative(process.cwd(),v.resolve(l,p)).length))+4," "):"- "+v.relative(process.cwd(),v.resolve(l,g)).padEnd(Math.max(...u.map(p=>v.relative(process.cwd(),v.resolve(l,p)).length))+2," ")} ${(i=S.dependencies)!=null&&i.length?"\u{1F4E6}"+String(S.dependencies.length).padEnd(2," "):" "} ${((a=y.files)==null?void 0:a.length)-1?"\u{1F4C4}"+String(y.files.length).padEnd(2," "):" "} ${v.relative(process.cwd(),N)}`),await G.promises.mkdir(v.dirname(N),{recursive:!0}),await G.promises.writeFile(N,JSON.stringify(y,null,2)+`
32
- `),(c=y.files)==null||c.forEach(p=>{delete p.content}),delete y.$schema,O.items.push(y)}catch(f){b.push(g+": "+f.message);continue}O.items.sort((g,f)=>g.name.localeCompare(f.name,void 0,{numeric:!0,sensitivity:"base"})).sort((g,f)=>{let S=W.items.type.default;return S.indexOf(g.type)-S.indexOf(f.type)}),await G.promises.writeFile(v.resolve(l,m.output,"registry.json"),JSON.stringify(O,null,2)+`
32
+ ${I.name} <${I.email}> (${I.url})`,Re=r=>{try{return Se(r)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},Oe=async()=>{var r,t,s,o,e,i,a,m;try{let{positionals:n,values:c}=Re({allowPositionals:!0,options:{output:{type:"string",short:"o",default:"public/r"},cwd:{type:"string",short:"c"},ignore:{type:"string",short:"i",default:""},"patterns-only":{type:"boolean",short:"p",default:!1},"registry-only":{type:"boolean",short:"r",default:!1},"codemod-radix":{type:"boolean"},"remove-prefix":{type:"string",default:""},"no-utils":{type:"boolean",default:!1},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});n.length||(c.version&&(console.log(`${M}@${U}`),process.exit(0)),c.help&&(console.log(ae),process.exit(0)));let l=v.resolve((r=c.cwd)!=null?r:process.cwd());c["codemod-radix"]&&(await Z({cwd:l}),process.exit(0));let d=await te(l),u=c["registry-only"]?[]:await re({cwd:l,patterns:n,ignore:c.ignore,patternsOnly:c["patterns-only"]}),h=await se({cwd:l,aliases:d,registryFiles:u}),b=[],R=((t=h.items)==null?void 0:t.map(g=>g.name))||[],O=C($({},h),{items:[]});for(let g of[...u,...R])try{if((s=O.items)!=null&&s.find(p=>p.name===g||p.name===w({cwd:l,aliases:d,filepath:g}).name))continue;let f=((o=h.items)==null?void 0:o.find(p=>p.name===g||p.name===w({cwd:l,aliases:d,filepath:g}).name))||{},S=await q({cwd:l,aliases:d,filepaths:[...R.includes(g)?[]:[g],...((e=f==null?void 0:f.files)==null?void 0:e.map(p=>p.path))||[]]}),D={dependencies:[...new Set([...S.dependencies,...(f==null?void 0:f.dependencies)||[]])].filter((p,k,x)=>!x.some(P=>P!==p&&P.startsWith(p+"@"))).sort(),devDependencies:[...new Set([...S.devDependencies,...(f==null?void 0:f.devDependencies)||[]])].filter((p,k,x)=>!x.some(P=>P!==p&&P.startsWith(p+"@"))).sort(),registryDependencies:[...new Set([...(f==null?void 0:f.registryDependencies)||[]])].sort()},y=$(C($($($({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:w({cwd:l,aliases:d,filepath:g}).name.replace(new RegExp(`^${c["remove-prefix"]||""}-?`),""),type:f.type||w({cwd:l,aliases:d,filepath:g}).type||"registry:file"},D.dependencies.length&&{dependencies:D.dependencies}),D.devDependencies.length&&{devDependencies:D.devDependencies}),D.registryDependencies.length&&{registryDependencies:D.registryDependencies}),{files:S.files.map(p=>({type:w({cwd:l,aliases:d,filepath:p}).type||"registry:file",target:w({cwd:l,aliases:d,filepath:p}).target||p,content:S.content[p],path:p}))}),Object.fromEntries(Object.entries(f).filter(([p])=>!["$schema","name","type","dependencies","devDependencies","registryDependencies","files"].includes(p))));y.files.length?(y.files.length>1&&c["no-utils"]&&(y.files=y.files.filter(p=>p.target!=="lib/utils.ts")),y.files.some(p=>p.path===g)?y.files=y.files.sort((p,k)=>{if(p.path===g)return-1;if(k.path===g)return 1;let x=W.items.files.type.default;return x.indexOf(p.type)-x.indexOf(k.type)}):y.files=[y.files[0],...y.files.slice(1).sort((p,k)=>{let x=W.items.files.type.default;return x.indexOf(p.type)-x.indexOf(k.type)})]):delete y.files,y.cssVars&&Object.keys(y.cssVars).length===0&&delete y.cssVars,y=Object.keys(y).sort((p,k)=>{let x=W.items.default;return x.indexOf(p)-x.indexOf(k)}).reduce((p,k)=>(p[k]=y[k],p),{});let N=v.resolve(l,c.output,y.name+".json");console.log(`${g==="ui"||g==="style"?`- \u{1F525} 'registry:${g}' pack`.padEnd(Math.max(...u.map(p=>v.relative(process.cwd(),v.resolve(l,p)).length))+4," "):"- "+v.relative(process.cwd(),v.resolve(l,g)).padEnd(Math.max(...u.map(p=>v.relative(process.cwd(),v.resolve(l,p)).length))+2," ")} ${(i=S.dependencies)!=null&&i.length?"\u{1F4E6}"+String(S.dependencies.length).padEnd(2," "):" "} ${((a=y.files)==null?void 0:a.length)-1?"\u{1F4C4}"+String(y.files.length).padEnd(2," "):" "} ${v.relative(process.cwd(),N)}`),await G.promises.mkdir(v.dirname(N),{recursive:!0}),await G.promises.writeFile(N,JSON.stringify(y,null,2)+`
33
+ `),(m=y.files)==null||m.forEach(p=>{delete p.content}),delete y.$schema,O.items.push(y)}catch(f){b.push(g+": "+f.message);continue}O.items.sort((g,f)=>g.name.localeCompare(f.name,void 0,{numeric:!0,sensitivity:"base"})).sort((g,f)=>{let S=W.items.type.default;return S.indexOf(g.type)-S.indexOf(f.type)}),await G.promises.writeFile(v.resolve(l,c.output,"registry.json"),JSON.stringify(O,null,2)+`
33
34
  `);let le=O.items.reduce((g,f)=>(g[f.type]=(g[f.type]||0)+1,g),{});console.log(),console.table(Object.entries(le).map(([g,f])=>({Type:g,Items:f}))),console.log(`
34
- - Master (shadcn-compatible) "registry.json" file created at: ${je(v.relative(process.cwd(),v.resolve(l,m.output,"registry.json")))} with ${O.items.length} items`),b.length&&(console.log(),b.forEach(g=>console.error(`\x1B[31m- ${g}\x1B[0m`))),process.exit(0)}catch(n){console.error(ae),console.error(`
35
+ - Master (shadcn-compatible) "registry.json" file created at: ${je(v.relative(process.cwd(),v.resolve(l,c.output,"registry.json")))} with ${O.items.length} items`),b.length&&(console.log(),b.forEach(g=>console.error(`\x1B[31m- ${g}\x1B[0m`))),process.exit(0)}catch(n){console.error(ae),console.error(`
35
36
  ${n.message}
36
37
  `),process.exit(1)}};Oe();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "smart-registry",
3
- "version": "1.4.0",
3
+ "version": "1.6.0",
4
4
  "description": "A zero-configuration (no registry.json required), shadcn add / open in v0 compatible registry builder.",
5
5
  "keywords": [
6
6
  "shadcn",