smart-registry 0.33.0 → 0.35.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.
Files changed (2) hide show
  1. package/dist/bin/index.js +10 -10
  2. package/package.json +1 -1
package/dist/bin/index.js CHANGED
@@ -1,11 +1,11 @@
1
1
  #!/usr/bin/env node
2
- var le=Object.defineProperty,pe=Object.defineProperties;var ce=Object.getOwnPropertyDescriptors;var T=Object.getOwnPropertySymbols;var me=Object.prototype.hasOwnProperty,ge=Object.prototype.propertyIsEnumerable;var U=(r,t,s)=>t in r?le(r,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[t]=s,S=(r,t)=>{for(var s in t||(t={}))me.call(t,s)&&U(r,s,t[s]);if(T)for(var s of T(t))ge.call(t,s)&&U(r,s,t[s]);return r},N=(r,t)=>pe(r,ce(t));import L from"node:fs";import $ from"node:path";import{parseArgs as we}from"node:util";import W,{existsSync as H}from"node:fs";import{readFile as fe}from"node:fs/promises";import I from"node:path";import{detect as de}from"@antfu/ni";async function G(r,{withFallback:t}={withFallback:!1}){let s=await de({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 K}from"execa";import{glob as ue}from"tinyglobby";var Q=async({cwd:r})=>{let t=I.resolve(r,".gitignore"),s=H(t)?(await fe(t,"utf8")).split(`
3
- `).filter(i=>i.trim()&&!i.startsWith("#")).map(i=>i.replace(/^\//,"").replace(/^/,"**/")):[],o=await ue(["**/*.ts","**/*.tsx","**/*.js","**/*.jsx"],{cwd:r,ignore:s}),e=new Set,a=o.map(async i=>{let p=I.resolve(r,i),m=await W.promises.readFile(p,"utf-8"),d=m.replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(f,y,v)=>(e.add(`@radix-ui/react-${v}`),`import { ${y.replace("Primitive","")} as ${y} } 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(m)&&(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")),W.promises.writeFile(p,d,"utf-8")});await Promise.all(a);let n=I.resolve(r,"registry.json");if(H(n)){let i=await W.promises.readFile(n,"utf-8"),p=JSON.parse(i),m=f=>{for(let y in f)y==="dependencies"||y==="devDependencies"?f[y]=Array.from(new Set(f[y].map(v=>e.has(v)?"radix-ui":v))):typeof f[y]=="object"&&f[y]!==null&&m(f[y])};m(p);let d=JSON.stringify(p,null,2);await W.promises.writeFile(n,d,"utf-8")}let l=await G(r);e.size&&await K(l,[l==="npm"?"uninstall":"remove",...Array.from(e)],{cwd:r}),await K(l,[l==="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 X=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],F={default:["$schema","name","homepage","items"],items:{default:["$schema","name","type","description","title","author","dependencies","devDependencies","registryDependencies","files","tailwind","cssVars","meta","docs","categories"],type:{default:["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"]}}}};import V from"node:fs";import C from"node:path";import he from"strip-json-comments";var Y=async r=>{let t={},s=["tsconfig.json","jsconfig.json"].find(o=>V.existsSync(C.resolve(r,o)));if(s){let o=await V.promises.readFile(C.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(he(o,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((a,[n,[l]])=>(n.endsWith("*")&&l.endsWith("*")&&(a[n.replace(/\*$/,"")]=l.replace(/\*$/,"")),a),{}))}return t["@/"]||(t["@/"]=V.existsSync(C.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([o],[e])=>e.length-o.length).reduce((o,[e,a])=>(o[e]=a,o),{}),t};import P from"node:fs";import j from"node:path";import ye from"node:path";var x=({cwd:r,aliases:t,filepath:s})=>{var n;let o=s;for(let l in t)s=s.replace(t[l].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(l,i)=>`blocks/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(l,i)=>`charts/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(l,i)=>`${i?i+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(l,i)=>`components/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(l,i)=>`hooks/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(l,i)=>`lib/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(l,i)=>`components/ui/${i?i+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):s.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),a=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":((n=e.match(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:n[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:a,import:"@/"+e.replace(r+ye.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:o.split("/").length>1?e:`~/${e}`,path:s}};var Z=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:[]};P.existsSync(o)&&(e=S({},JSON.parse(await P.promises.readFile(o,"utf8"))));let a=[];for(let p of s)x({cwd:r,aliases:t,filepath:p}).type==="registry:ui"&&a.push({type:"registry:ui",path:p});let n=null,l=null,i=P.existsSync(j.relative(process.cwd(),j.resolve(r,"app/globals.css")))?j.relative(process.cwd(),j.resolve(r,"app/globals.css")):P.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(i){let p=await P.promises.readFile(i,"utf8"),m=p.match(/:root\s*{([^}]*)}/);n=m?m[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(f=>f.trim()).filter(f=>f.length).map(f=>{let[y,v]=f.split(":").map(g=>g.trim());return{name:y.replace(/^--/,""),value:v}}):null;let d=p.match(/\.dark\s*{([^}]*)}/);l=d?d[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(f=>f.trim()).filter(f=>f.length).map(f=>{let[y,v]=f.split(":").map(g=>g.trim());return{name:y.replace(/^--/,""),value:v}}):null}return n&&l&&e.items.push({name:"style",type:"registry:style",cssVars:{light:Object.fromEntries(n.map(p=>[p.name,p.value])),dark:Object.fromEntries(l.map(p=>[p.name,p.value]))}}),a.length&&e.items.push(S({name:"ui",type:"registry:ui",files:a},n&&l?{cssVars:{light:Object.fromEntries(n.map(p=>[p.name,p.value])),dark:Object.fromEntries(l.map(p=>[p.name,p.value]))}}:{})),e};import ee from"node:fs";import te from"node:path";import{glob as ve}from"tinyglobby";var O=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 ve(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 a=te.resolve(r,e),n=await ee.promises.stat(a);if(n.isDirectory()){let l=(await ee.promises.readdir(a)).map(i=>te.resolve(e,i));o.push(...l)}else n.isFile()&&o.push(e)}catch(a){continue}return[...new Set(o)]};var se=async({cwd:r,patterns:t,ignore:s,patternsOnly:o})=>{let e=[];if(!o){for(let a of X)if(e=await O({cwd:r,patterns:a,ignore:s}),e.length)break}if(t.length&&(e=e.concat(await O({cwd:r,patterns:t,ignore:s}))),!e.length)throw new Error("No files/directories found to build the registry from!");return e=e.sort((a,n)=>a.localeCompare(n,void 0,{numeric:!0,sensitivity:"base"})),e};import re from"node:fs";import ie from"node:path";var E={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var z=async({cwd:r,aliases:t,filepaths:s,resolved:o})=>{o=o!=null?o:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let a of s){if(o.has(a))continue;o.add(a),e.files.push(a),e.content[a]||(e.content[a]=await re.promises.readFile(ie.resolve(r,a),"utf8"));let{dependencies:n,devDependencies:l,files:i,transformations:p}=await ne({cwd:r,aliases:t,filepath:a,content:e.content[a]});e.content[a]=e.content[a].replace(E.imports,m=>{let d=m.match(/['"](.*)['"]/);return d&&p[d[1]]?m.replace(d[1],p[d[1]].import):m}),i.forEach(m=>e.files.push(m)),n.forEach(m=>e.dependencies.push(m)),l.forEach(m=>e.devDependencies.push(m))}for(let a of e.files){let{dependencies:n,devDependencies:l,files:i,content:p}=await z({cwd:r,aliases:t,filepaths:[a],resolved:o});e.content[a]||(e.content[a]=p[a]||await re.promises.readFile(ie.resolve(r,a),"utf8")),i.forEach(m=>e.files.push(m)),n.forEach(m=>e.dependencies.push(m)),l.forEach(m=>e.devDependencies.push(m))}return e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort(),e};import oe from"node:fs";import A from"node:path";var be=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 O({cwd:r,patterns:t});return t=o.find(e=>e.startsWith(t+"."))||o.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},xe=async({cwd:r,filepath:t,current:s})=>{s=A.relative(r,A.resolve(r,A.dirname(t),s));let o=await O({cwd:r,patterns:s});return s=o.find(e=>e.startsWith(s+"."))||o.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},ne=async({cwd:r,aliases:t,filepath:s,content:o})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},a=o.match(E.imports)||[];if(!a.length)return e;a=a.map(n=>{var l;return(l=n.match(/['"](.*)['"]/))==null?void 0:l[1].replace(/\/\//g,"/")});for(let n of a){let l=n;if(Object.keys(t).some(p=>n.startsWith(p.replace(/\.\//g,"").replace(/\.\.\//g,""))))n=await be({cwd:r,aliases:t,current:n}),e.transformations[l]=x({cwd:r,aliases:t,filepath:n}),e.files.push(n);else if(n.startsWith("."))n=await xe({cwd:r,filepath:s,current:n}),e.transformations[l]=x({cwd:r,aliases:t,filepath:n}),e.files.push(n);else{let p=A.resolve(r,"package.json"),m={};if(oe.existsSync(p)){let d=JSON.parse(await oe.promises.readFile(p,"utf8"));m=S({},d.devDependencies)}if(n.startsWith("@")){let d=n.split("/").slice(0,2).join("/");m[d]?e.devDependencies.push(d):e.dependencies.push(d)}else{let d=n.split("/")[0];m[d]?e.devDependencies.push(d):e.dependencies.push(d)}}}return e};var _="smart-registry",q="0.33.0";var J={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var ae=`Version:
5
- ${_}@${q}
2
+ var fe=Object.defineProperty,ue=Object.defineProperties;var he=Object.getOwnPropertyDescriptors;var X=Object.getOwnPropertySymbols;var ye=Object.prototype.hasOwnProperty,ve=Object.prototype.propertyIsEnumerable;var Y=(r,t,s)=>t in r?fe(r,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[t]=s,S=(r,t)=>{for(var s in t||(t={}))ye.call(t,s)&&Y(r,s,t[s]);if(X)for(var s of X(t))ve.call(t,s)&&Y(r,s,t[s]);return r},B=(r,t)=>ue(r,he(t));import K from"node:fs";import $ from"node:path";import{parseArgs as Oe}from"node:util";import _,{existsSync as ee}from"node:fs";import{readFile as xe}from"node:fs/promises";import q from"node:path";import{detect as be}from"@antfu/ni";async function Z(r,{withFallback:t}={withFallback:!1}){let s=await be({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 i=process.env.npm_config_user_agent||"";return i.startsWith("yarn")?"yarn":i.startsWith("pnpm")?"pnpm":i.startsWith("bun")?"bun":"npm"}import{execa as te}from"execa";import{glob as we}from"tinyglobby";var se=async({cwd:r})=>{let t=q.resolve(r,".gitignore"),s=ee(t)?(await xe(t,"utf8")).split(`
3
+ `).filter(a=>a.trim()&&!a.startsWith("#")).map(a=>a.replace(/^\//,"").replace(/^/,"**/")):[],i=await we(["**/*.ts","**/*.tsx","**/*.js","**/*.jsx"],{cwd:r,ignore:s}),e=new Set,n=i.map(async a=>{let c=q.resolve(r,a),m=await _.promises.readFile(c,"utf-8"),g=m.replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(f,u,d)=>(e.add(`@radix-ui/react-${d}`),`import { ${u.replace("Primitive","")} as ${u} } from "radix-ui"`)).replace(/Sheet\s+as\s+SheetPrimitive/g,"Dialog as SheetPrimitive");return/import\s+\{\s+Slot\s+\}\s+from\s+"@radix-ui\/react-slot"/.test(m)&&(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")),_.promises.writeFile(c,g,"utf-8")});await Promise.all(n);let o=q.resolve(r,"registry.json");if(ee(o)){let a=await _.promises.readFile(o,"utf-8"),c=JSON.parse(a),m=f=>{for(let u in f)u==="dependencies"||u==="devDependencies"?f[u]=Array.from(new Set(f[u].map(d=>e.has(d)?"radix-ui":d))):typeof f[u]=="object"&&f[u]!==null&&m(f[u])};m(c);let g=JSON.stringify(c,null,2);await _.promises.writeFile(o,g,"utf-8")}let p=await Z(r);e.size&&await te(p,[p==="npm"?"uninstall":"remove",...Array.from(e)],{cwd:r}),await te(p,[p==="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 re=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],P={default:["$schema","name","homepage","items"],items:{default:["$schema","name","type","description","title","author","dependencies","devDependencies","registryDependencies","files","tailwind","cssVars","meta","docs","categories"],type:{default:["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"]}}}};import L from"node:fs";import T from"node:path";import ke from"strip-json-comments";var ie=async r=>{let t={},s=["tsconfig.json","jsconfig.json"].find(i=>L.existsSync(T.resolve(r,i)));if(s){let i=await L.promises.readFile(T.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(ke(i,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((n,[o,[p]])=>(o.endsWith("*")&&p.endsWith("*")&&(n[o.replace(/\*$/,"")]=p.replace(/\*$/,"")),n),{}))}return t["@/"]||(t["@/"]=L.existsSync(T.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([i],[e])=>e.length-i.length).reduce((i,[e,n])=>(i[e]=n,i),{}),t};import W from"node:fs";import j from"node:path";import Se from"node:path";var w=({cwd:r,aliases:t,filepath:s})=>{var o;let i=s;for(let p in t)s=s.replace(t[p].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(p,a)=>`blocks/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(p,a)=>`charts/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(p,a)=>`${a?a+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(p,a)=>`components/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(p,a)=>`hooks/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(p,a)=>`lib/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(p,a)=>`components/ui/${a?a+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):s.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),n=e.toLowerCase().replace(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)\//,"").replace(/\/(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)\//,"/").replace(/\.[^\/.]+$/,"").replace(/\/index$/,"").replace(/\/page$/,"").replace(/\/route$/,"").replace(/\/\[.*\]$/,"").replace(/(\b\w+)\b\/\1\b/g,"$1").replace(/\//g,"-");return{type:e.endsWith("page.tsx")?"registry:page":((o=e.match(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:o[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:n,import:"@/"+e.replace(r+Se.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:i.split("/").length>1?e:`~/${e}`,path:s}};var ne=async({cwd:r,aliases:t,registryFiles:s})=>{let i=j.resolve(r,"registry.json"),e={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};W.existsSync(i)&&(e=S({},JSON.parse(await W.promises.readFile(i,"utf8"))));let n=[];for(let c of s)w({cwd:r,aliases:t,filepath:c}).type==="registry:ui"&&n.push({type:"registry:ui",path:c});let o=null,p=null,a=W.existsSync(j.relative(process.cwd(),j.resolve(r,"app/globals.css")))?j.relative(process.cwd(),j.resolve(r,"app/globals.css")):W.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(a){let c=await W.promises.readFile(a,"utf8"),m=c.match(/:root\s*{([^}]*)}/);o=m?m[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(f=>f.trim()).filter(f=>f.length).map(f=>{let[u,d]=f.split(":").map(b=>b.trim());return{name:u.replace(/^--/,""),value:d}}):null;let g=c.match(/\.dark\s*{([^}]*)}/);p=g?g[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(f=>f.trim()).filter(f=>f.length).map(f=>{let[u,d]=f.split(":").map(b=>b.trim());return{name:u.replace(/^--/,""),value:d}}):null}return o&&p&&e.items.push({name:"style",type:"registry:style",cssVars:{light:Object.fromEntries(o.map(c=>[c.name,c.value])),dark:Object.fromEntries(p.map(c=>[c.name,c.value]))}}),n.length&&e.items.push(S({name:"ui",type:"registry:ui",files:n},o&&p?{cssVars:{light:Object.fromEntries(o.map(c=>[c.name,c.value])),dark:Object.fromEntries(p.map(c=>[c.name,c.value]))}}:{})),e};import oe from"node:fs";import ae from"node:path";import{glob as $e}from"tinyglobby";var D=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 i=await $e(t,{cwd:r,ignore:s.filter(e=>!t.includes(e))});for(let e of t)if(!i.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let n=ae.resolve(r,e),o=await oe.promises.stat(n);if(o.isDirectory()){let p=(await oe.promises.readdir(n)).map(a=>ae.resolve(e,a));i.push(...p)}else o.isFile()&&i.push(e)}catch(n){continue}return[...new Set(i)]};var le=async({cwd:r,patterns:t,ignore:s,patternsOnly:i})=>{let e=[];if(!i){for(let n of re)if(e=await D({cwd:r,patterns:n,ignore:s}),e.length)break}if(t.length&&(e=e.concat(await D({cwd:r,patterns:t,ignore:s}))),!e.length)throw new Error("No files/directories found to build the registry from!");return e=e.sort((n,o)=>n.localeCompare(o,void 0,{numeric:!0,sensitivity:"base"})),e};import pe from"node:fs";import ce 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:s,resolved:i})=>{i=i!=null?i:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let n of s){if(i.has(n))continue;i.add(n),e.files.push(n),e.content[n]||(e.content[n]=await pe.promises.readFile(ce.resolve(r,n),"utf8"));let{dependencies:o,devDependencies:p,files:a,transformations:c}=await me({cwd:r,aliases:t,filepath:n,content:e.content[n]});e.content[n]=e.content[n].replace(J.imports,m=>{let g=m.match(/['"](.*)['"]/);return g&&c[g[1]]?m.replace(g[1],c[g[1]].import):m}),a.forEach(m=>e.files.push(m)),o.forEach(m=>e.dependencies.push(m)),p.forEach(m=>e.devDependencies.push(m))}for(let n of e.files){let{dependencies:o,devDependencies:p,files:a,content:c}=await U({cwd:r,aliases:t,filepaths:[n],resolved:i});e.content[n]||(e.content[n]=c[n]||await pe.promises.readFile(ce.resolve(r,n),"utf8")),a.forEach(m=>e.files.push(m)),o.forEach(m=>e.dependencies.push(m)),p.forEach(m=>e.devDependencies.push(m))}return e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort(),e};import ge from"node:fs";import M from"node:path";var je=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 i=await D({cwd:r,patterns:t});return t=i.find(e=>e.startsWith(t+"."))||i.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},Re=async({cwd:r,filepath:t,current:s})=>{s=M.relative(r,M.resolve(r,M.dirname(t),s));let i=await D({cwd:r,patterns:s});return s=i.find(e=>e.startsWith(s+"."))||i.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},me=async({cwd:r,aliases:t,filepath:s,content:i})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},n=i.match(J.imports)||[];if(!n.length)return e;n=n.map(o=>{var p;return(p=o.match(/['"](.*)['"]/))==null?void 0:p[1].replace(/\/\//g,"/")});for(let o of n){let p=o;if(Object.keys(t).some(c=>o.startsWith(c.replace(/\.\//g,"").replace(/\.\.\//g,""))))o=await je({cwd:r,aliases:t,current:o}),e.transformations[p]=w({cwd:r,aliases:t,filepath:o}),e.files.push(o);else if(o.startsWith("."))o=await Re({cwd:r,filepath:s,current:o}),e.transformations[p]=w({cwd:r,aliases:t,filepath:o}),e.files.push(o);else{let c=M.resolve(r,"package.json"),m={};if(ge.existsSync(c)){let g=JSON.parse(await ge.promises.readFile(c,"utf8"));m=S({},g.devDependencies)}if(o.startsWith("@")){let g=o.split("/").slice(0,2).join("/");m[g]?e.devDependencies.push(g):e.dependencies.push(g)}else{let g=o.split("/")[0];m[g]?e.devDependencies.push(g):e.dependencies.push(g)}}}return e};var N="smart-registry",H="0.35.0";var I={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var de=`Version:
5
+ ${N}@${H}
6
6
 
7
7
  Usage:
8
- $ ${_} [files/directories] ... [options]
8
+ $ ${N} [files/directories] ... [options]
9
9
 
10
10
  Arguments:
11
11
  files/directories files or directories to extend the registry (optional)
@@ -25,8 +25,8 @@ Codemods:
25
25
  --codemod-radix migrate to unify "@radix-ui/react-*" imports to "radix-ui"
26
26
 
27
27
  Author:
28
- ${J.name} <${J.email}> (${J.url})`,ke=r=>{try{return we(r)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},Se=async()=>{var r,t,s,o,e,a;try{let{positionals:n,values:l}=ke({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"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});n.length||(l.version&&(console.log(`${_}@${q}`),process.exit(0)),l.help&&(console.log(ae),process.exit(0)));let i=$.resolve((r=l.cwd)!=null?r:process.cwd());l["codemod-radix"]&&(await Q({cwd:i}),process.exit(0));let p=await Y(i),m=l["registry-only"]?[]:await se({cwd:i,patterns:n,ignore:l.ignore,patternsOnly:l["patterns-only"]}),d=await Z({cwd:i,aliases:p,registryFiles:m}),f=[],y=((t=d.items)==null?void 0:t.map(g=>g.name))||[],v=N(S({},d),{items:[]});for(let g of[...m,...y])try{if((s=v.items)!=null&&s.find(c=>c.name===g||c.name===x({cwd:i,aliases:p,filepath:g}).name))continue;let u=((o=d.items)==null?void 0:o.find(c=>c.name===g||c.name===x({cwd:i,aliases:p,filepath:g}).name))||{},w=await z({cwd:i,aliases:p,filepaths:[...y.includes(g)?[]:[g],...((e=u==null?void 0:u.files)==null?void 0:e.map(c=>c.path))||[]]}),R={dependencies:[...new Set([...w.dependencies,...(u==null?void 0:u.dependencies)||[]])].filter((c,k,b)=>!b.some(D=>D!==c&&D.startsWith(c+"@"))).sort(),devDependencies:[...new Set([...w.devDependencies,...(u==null?void 0:u.devDependencies)||[]])].filter((c,k,b)=>!b.some(D=>D!==c&&D.startsWith(c+"@"))).sort(),registryDependencies:[...new Set([...(u==null?void 0:u.registryDependencies)||[]])].sort()},h=S(N(S(S(S({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:x({cwd:i,aliases:p,filepath:g}).name,type:u.type||x({cwd:i,aliases:p,filepath:g}).type||"registry:file"},R.dependencies.length&&{dependencies:R.dependencies}),R.devDependencies.length&&{devDependencies:R.devDependencies}),R.registryDependencies.length&&{registryDependencies:R.registryDependencies}),{files:w.files.map(c=>({type:x({cwd:i,aliases:p,filepath:c}).type||"registry:file",target:x({cwd:i,aliases:p,filepath:c}).target||c,content:w.content[c],path:c}))}),Object.fromEntries(Object.entries(u).filter(([c])=>!["$schema","name","type","dependencies","devDependencies","registryDependencies","files"].includes(c))));h.files.length?h.files.some(c=>c.path===g)?h.files=h.files.sort((c,k)=>{if(c.path===g)return-1;if(k.path===g)return 1;let b=F.items.files.type.default;return b.indexOf(c.type)-b.indexOf(k.type)}):h.files=[h.files[0],...h.files.slice(1).sort((c,k)=>{let b=F.items.files.type.default;return b.indexOf(c.type)-b.indexOf(k.type)})]:delete h.files,h.cssVars&&Object.keys(h.cssVars).length===0&&delete h.cssVars,h=Object.keys(h).sort((c,k)=>{let b=F.items.default;return b.indexOf(c)-b.indexOf(k)}).reduce((c,k)=>(c[k]=h[k],c),{});let M=$.resolve(i,l.output,h.name+".json");console.log(`${g==="ui"||g==="style"?`- \u{1F525} 'registry:${g}' pack`.padEnd(Math.max(...m.map(c=>$.relative(process.cwd(),$.resolve(i,c)).length))+4," "):"- "+$.relative(process.cwd(),$.resolve(i,g)).padEnd(Math.max(...m.map(c=>$.relative(process.cwd(),$.resolve(i,c)).length))+2," ")} ${w.dependencies.length?"\u{1F4E6}"+String(w.dependencies.length).padEnd(2," "):" "} ${w.files.length-1?"\u{1F4C4}"+String(w.files.length).padEnd(2," "):" "} ${$.relative(process.cwd(),M)}`),await L.promises.mkdir($.dirname(M),{recursive:!0}),await L.promises.writeFile(M,JSON.stringify(h,null,2)+`
29
- `),(a=h.files)==null||a.forEach(c=>delete c.content),v.items.push(h)}catch(u){f.push(g+": "+u.message);continue}v.items.sort((g,u)=>g.name.localeCompare(u.name)).sort((g,u)=>{let w=F.items.type.default;return w.indexOf(g.type)-w.indexOf(u.type)}),await L.promises.writeFile($.resolve(i,l.output,"registry.json"),JSON.stringify(v,null,2)+`
30
- `),f.length&&(console.log(),f.forEach(g=>console.error(`\x1B[31m- ${g}\x1B[0m`))),process.exit(0)}catch(n){console.error(ae),console.error(`
31
- ${n.message}
32
- `),process.exit(1)}};Se();
28
+ ${I.name} <${I.email}> (${I.url})`,De=r=>{try{return Oe(r)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},Fe=async()=>{var r,t,s,i,e,n,o,p,a,c,m,g;try{let{positionals:f,values:u}=De({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"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});f.length||(u.version&&(console.log(`${N}@${H}`),process.exit(0)),u.help&&(console.log(de),process.exit(0)));let d=$.resolve((r=u.cwd)!=null?r:process.cwd());u["codemod-radix"]&&(await se({cwd:d}),process.exit(0));let b=await ie(d),E=u["registry-only"]?[]:await le({cwd:d,patterns:f,ignore:u.ignore,patternsOnly:u["patterns-only"]}),V=await ne({cwd:d,aliases:b,registryFiles:E}),C=[],Q=((t=V.items)==null?void 0:t.map(h=>h.name))||[],A=B(S({},V),{items:[]});for(let h of[...E,...Q])try{if((s=A.items)!=null&&s.find(l=>l.name===h||l.name===w({cwd:d,aliases:b,filepath:h}).name))continue;let v=((i=V.items)==null?void 0:i.find(l=>l.name===h||l.name===w({cwd:d,aliases:b,filepath:h}).name))||{},R=await U({cwd:d,aliases:b,filepaths:[...Q.includes(h)?[]:[h],...((e=v==null?void 0:v.files)==null?void 0:e.map(l=>l.path))||[]]}),O={dependencies:[...new Set([...R.dependencies,...(v==null?void 0:v.dependencies)||[]])].filter((l,k,x)=>!x.some(F=>F!==l&&F.startsWith(l+"@"))).sort(),devDependencies:[...new Set([...R.devDependencies,...(v==null?void 0:v.devDependencies)||[]])].filter((l,k,x)=>!x.some(F=>F!==l&&F.startsWith(l+"@"))).sort(),registryDependencies:[...new Set([...(v==null?void 0:v.registryDependencies)||[]])].sort()},y=S(B(S(S(S({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:w({cwd:d,aliases:b,filepath:h}).name,type:v.type||w({cwd:d,aliases:b,filepath:h}).type||"registry:file"},O.dependencies.length&&{dependencies:O.dependencies}),O.devDependencies.length&&{devDependencies:O.devDependencies}),O.registryDependencies.length&&{registryDependencies:O.registryDependencies}),{files:R.files.map(l=>({type:w({cwd:d,aliases:b,filepath:l}).type||"registry:file",target:w({cwd:d,aliases:b,filepath:l}).target||l,content:R.content[l],path:l}))}),Object.fromEntries(Object.entries(v).filter(([l])=>!["$schema","name","type","dependencies","devDependencies","registryDependencies","files"].includes(l))));y.files.length?y.files.some(l=>l.path===h)?y.files=y.files.sort((l,k)=>{if(l.path===h)return-1;if(k.path===h)return 1;let x=P.items.files.type.default;return x.indexOf(l.type)-x.indexOf(k.type)}):y.files=[y.files[0],...y.files.slice(1).sort((l,k)=>{let x=P.items.files.type.default;return x.indexOf(l.type)-x.indexOf(k.type)})]:delete y.files,y.cssVars&&Object.keys(y.cssVars).length===0&&delete y.cssVars,y=Object.keys(y).sort((l,k)=>{let x=P.items.default;return x.indexOf(l)-x.indexOf(k)}).reduce((l,k)=>(l[k]=y[k],l),{});let z=$.resolve(d,u.output,y.name+".json");console.log(`${h==="ui"||h==="style"?`- \u{1F525} 'registry:${h}' pack`.padEnd(Math.max(...E.map(l=>$.relative(process.cwd(),$.resolve(d,l)).length))+4," "):"- "+$.relative(process.cwd(),$.resolve(d,h)).padEnd(Math.max(...E.map(l=>$.relative(process.cwd(),$.resolve(d,l)).length))+2," ")} ${((n=y.dependencies)==null?void 0:n.length)+((o=y.devDependencies)==null?void 0:o.length)?"\u{1F4E6}"+String(((p=y.dependencies)==null?void 0:p.length)+((a=y.devDependencies)==null?void 0:a.length)).padEnd(2," "):" "} ${((c=y.files)==null?void 0:c.length)-1?"\u{1F4C4}"+String((m=y.files)==null?void 0:m.length).padEnd(2," "):" "} ${$.relative(process.cwd(),z)}`),await K.promises.mkdir($.dirname(z),{recursive:!0}),await K.promises.writeFile(z,JSON.stringify(y,null,2)+`
29
+ `),(g=y.files)==null||g.forEach(l=>delete l.content),A.items.push(y)}catch(v){C.push(h+": "+v.message);continue}A.items.sort((h,v)=>h.name.localeCompare(v.name)).sort((h,v)=>{let R=P.items.type.default;return R.indexOf(h.type)-R.indexOf(v.type)}),await K.promises.writeFile($.resolve(d,u.output,"registry.json"),JSON.stringify(A,null,2)+`
30
+ `),C.length&&(console.log(),C.forEach(h=>console.error(`\x1B[31m- ${h}\x1B[0m`))),process.exit(0)}catch(f){console.error(de),console.error(`
31
+ ${f.message}
32
+ `),process.exit(1)}};Fe();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "smart-registry",
3
- "version": "0.33.0",
3
+ "version": "0.35.0",
4
4
  "description": "A zero-configuration (no registry.json required), shadcn add / open in v0 compatible registry builder.",
5
5
  "keywords": [
6
6
  "components",