smart-registry 0.5.4 → 0.5.6

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 +11 -9
  2. package/package.json +1 -1
package/dist/bin/index.js CHANGED
@@ -1,20 +1,22 @@
1
1
  #!/usr/bin/env node
2
- var z=Object.defineProperty,q=Object.defineProperties;var B=Object.getOwnPropertyDescriptors;var _=Object.getOwnPropertySymbols;var T=Object.prototype.hasOwnProperty,U=Object.prototype.propertyIsEnumerable;var J=(r,i,t)=>i in r?z(r,i,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[i]=t,$=(r,i)=>{for(var t in i||(i={}))T.call(i,t)&&J(r,t,i[t]);if(_)for(var t of _(i))U.call(i,t)&&J(r,t,i[t]);return r},E=(r,i)=>q(r,B(i));import v from"node:fs";import S from"node:path";import{parseArgs as K}from"node:util";import F from"node:fs";import Z from"strip-json-comments";var C=async()=>{let r={};if(F.existsSync("tsconfig.json")){let t=await F.promises.readFile("tsconfig.json","utf8"),{compilerOptions:n}=JSON.parse(Z(t,{trailingCommas:!0}));if(n.paths){if(r=Object.entries(n.paths).reduce((s,[e,[a]])=>(s[e.replace(/\*$/,"")]=a.replace(/^\.\//,"").replace(/\*$/,""),s),{}),!Object.keys(r).includes("@/"))throw new Error("No alias key '@/' found in compilerOptions.paths!");return r}}let i=["registry","components","src/components"];for(let t of i)if(F.existsSync(t))return r["@/"]=t==="src/components"?"src/":"",r;throw new Error("Could not resolve aliases!")};import j from"node:fs";import k from"node:path";import{glob as G}from"tinyglobby";var R=r=>{if(k.extname(r)!=="")return r;{let t=r.split(/\/|\\/).slice(0,-1).join(k.sep);if(!j.existsSync(t))return"";let n=j.readdirSync(t);n=n.map(e=>t+k.sep+e);let s=n.find(e=>e.startsWith(r+"."));return s=s==null?void 0:s.replace(process.cwd()+k.sep,""),s||""}},V=async({patterns:r=["**",".**"],ignore:i=[]}={})=>{if(r=Array.isArray(r)?r:[r],i=Array.isArray(i)?i:[i],j.existsSync(".gitignore")){let t=(await j.promises.readFile(".gitignore","utf8")).split(`
3
- `).map(n=>n.trim()).filter(n=>n&&!n.startsWith("#")).map(n=>n.replace(/^\//,""));i=i.concat(t)}return await G(r,{ignore:i.filter(t=>!r.includes(t))})};import M from"node:fs";import x from"node:path";import H from"node:path";var d=(r,i={})=>{var n;r=i.aliases?r.replace(i.aliases["@/"],""):r;let t=r.startsWith("registry/")?r.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(s,e)=>`blocks/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(s,e)=>`${e?e+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(s,e)=>`components/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(s,e)=>`hooks/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(s,e)=>`lib/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(s,e)=>`components/ui/${e?e+"/":""}`).replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,""):r.replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,"");return{type:t.endsWith("page.tsx")?"registry:page":((n=t.match(/^(blocks|components\/ui|components|hooks|lib|utils)/))==null?void 0:n[1].replace("blocks","registry:block").replace("components/ui","registry:ui").replace("components","registry:component").replace("hooks","registry:hook").replace("lib","registry:lib").replace("utils","registry:lib"))||"registry:file",name:t.replace(/^(blocks|components\/ui|components|hooks|lib|utils)\//,"").replace(/\.[^\/.]+$/,""),import:"@/"+t.replace(process.cwd()+H.sep,"").replace(/\.[^/.]+$/,""),target:t,path:r}};var w=(r,i)=>Object.entries(i).sort(([n],[s])=>s.length-n.length).reduce((n,[s,e])=>n.replace(s,e),r),N=async(r,i={})=>{let{aliases:t={},resolved:n=new Set}=i,s={dependencies:[],files:[],content:{}};for(let e of r){if(n.has(e))continue;n.add(e),s.files.push(e),s.content[e]=s.content[e]||await M.promises.readFile(e,"utf8");let a=s.content[e].match(/import\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]/g);if(!a)continue;let o=a.map(f=>{var h;return(h=f.match(/['"](.*)['"]/))==null?void 0:h[1]});for(let f of o)if(Object.keys(t).some(c=>f.startsWith(c))){let c=w(f,t);c=R(c),c&&!s.files.includes(c)&&s.files.push(c)}else if(f.startsWith(".")){let c=x.resolve(x.dirname(e),f);c=R(c),c&&!s.files.includes(c)&&s.files.push(c)}else{let c=["fs","path","util"],g=f.split("/").slice(0,2).join("/");g=g.startsWith("@")?g:g.split("/")[0],/^[a-zA-Z0-9@/-]+$/.test(g)&&!c.includes(g)&&!s.dependencies.includes(g)&&s.dependencies.push(g)}}for(let e of s.files){let a=await N([e],{aliases:t,resolved:n});a.dependencies.forEach(o=>{s.dependencies.includes(o)||s.dependencies.push(o)}),a.files.forEach(o=>{s.files.includes(o)||s.files.push(o)}),s.content[e]=a.content[e]||await M.promises.readFile(e,"utf8")}for(let e of s.files)s.content[e]=s.content[e].replace(/import\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]/g,a=>{var h,c,g;let o=(h=a.match(/['"](.*)['"]/))==null?void 0:h[1];if(Object.keys(t).some(u=>o.startsWith(u))){let u=w(o,t),y=(c=d(u,{aliases:t}))==null?void 0:c.import;return a.replace(o,y)}else if(o.startsWith(".")){let u=x.resolve(x.dirname(e),o),y=(g=d(u,{aliases:t}))==null?void 0:g.import;return a.replace(o,y)}else return a});return s.dependencies.sort(),s.files.sort((e,a)=>d(e,{aliases:t}).target.localeCompare(d(a,{aliases:t}).target)),s.files.sort((e,a)=>{let o=["registry:file","registry:block","registry:component","registry:ui","registry:hook","registry:lib"],f=d(e,{aliases:t}).type,h=d(a,{aliases:t}).type;return o.indexOf(f)-o.indexOf(h)}),s};var A="smart-registry",D="0.5.4";var O={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var I=`Version:
4
- ${A}@${D}
2
+ var q=Object.defineProperty,B=Object.defineProperties;var T=Object.getOwnPropertyDescriptors;var J=Object.getOwnPropertySymbols;var U=Object.prototype.hasOwnProperty,Z=Object.prototype.propertyIsEnumerable;var C=(r,i,t)=>i in r?q(r,i,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[i]=t,x=(r,i)=>{for(var t in i||(i={}))U.call(i,t)&&C(r,t,i[t]);if(J)for(var t of J(i))Z.call(i,t)&&C(r,t,i[t]);return r},R=(r,i)=>B(r,T(i));import v from"node:fs";import O from"node:path";import{parseArgs as L}from"node:util";import $ from"node:fs";import G from"strip-json-comments";var M=async()=>{let r={},i=["registry","components","src/components"];if($.existsSync("tsconfig.json")){let t=await $.promises.readFile("tsconfig.json","utf8"),{compilerOptions:o}=JSON.parse(G(t,{trailingCommas:!0}));if(o.paths){r=Object.entries(o.paths).reduce((s,[e,[n]])=>(s[e.replace(/\*$/,"")]=n.replace(/^\.\//,"").replace(/\*$/,""),s),{});for(let s of i)$.existsSync(s)&&(r["@/"]=s==="src/components"?"src/":"");if(!Object.keys(r).includes("@/"))throw new Error("No alias key '@/' found in compilerOptions.paths!");return r}}for(let t of i)if($.existsSync(t))return r["@/"]=t==="src/components"?"src/":"",r;throw new Error("Could not resolve aliases!")};import j from"node:fs";import k from"node:path";import{glob as H}from"tinyglobby";var W=r=>{if(k.extname(r)!=="")return r;{let t=r.split(/\/|\\/).slice(0,-1).join(k.sep);if(t=t.replace(/\/\//g,"/"),!j.existsSync(t))return"";let o=j.readdirSync(t);o=o.map(e=>t+k.sep+e);let s=o.find(e=>e.startsWith(r+"."));return s=s==null?void 0:s.replace(process.cwd()+k.sep,""),s||""}},V=async({patterns:r=["**",".**"],ignore:i=[]}={})=>{if(r=Array.isArray(r)?r:[r],i=Array.isArray(i)?i:[i],j.existsSync(".gitignore")){let t=(await j.promises.readFile(".gitignore","utf8")).split(`
3
+ `).map(o=>o.trim()).filter(o=>o&&!o.startsWith("#")).map(o=>o.replace(/^\//,""));i=i.concat(t)}return await H(r,{ignore:i.filter(t=>!r.includes(t))})};import I from"node:fs";import A from"node:path";import K from"node:path";var f=(r,i={})=>{var o;r=i.aliases?r.replace(i.aliases["@/"],""):r;let t=r.startsWith("registry/")?r.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(s,e)=>`blocks/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(s,e)=>`${e?e+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(s,e)=>`components/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(s,e)=>`hooks/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(s,e)=>`lib/${e?e+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(s,e)=>`components/ui/${e?e+"/":""}`).replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,""):r.replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,"");return{type:t.endsWith("page.tsx")?"registry:page":((o=t.match(/^(blocks|components\/ui|components|hooks|lib|utils)/))==null?void 0:o[1].replace("blocks","registry:block").replace("components/ui","registry:ui").replace("components","registry:component").replace("hooks","registry:hook").replace("lib","registry:lib").replace("utils","registry:lib"))||"registry:file",name:t.replace(/^(blocks|components\/ui|components|hooks|lib|utils)\//,"").replace(/\.[^\/.]+$/,""),import:"@/"+t.replace(process.cwd()+K.sep,"").replace(/\.[^/.]+$/,""),target:t,path:r}};var w=(r,i)=>Object.entries(i).sort(([o],[s])=>s.length-o.length).reduce((o,[s,e])=>o.replace(s,e),r),N=async(r,i={})=>{let{aliases:t={},resolved:o=new Set}=i,s={dependencies:[],files:[],content:{}};for(let e of r){if(o.has(e))continue;o.add(e),s.files.push(e),s.content[e]=s.content[e]||await I.promises.readFile(e,"utf8");let n=s.content[e].match(/import\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]/g);if(!n)continue;let a=n.map(l=>{var h;return(h=l.match(/['"](.*)['"]/))==null?void 0:h[1]});for(let l of a)if(Object.keys(t).some(p=>l.startsWith(p))){let p=w(l,t);p=W(p),p&&!s.files.includes(p)&&s.files.push(p)}else if(l.startsWith(".")){let p=A.resolve(A.dirname(e),l);p=W(p),p&&!s.files.includes(p)&&s.files.push(p)}else{let p=["fs","path","util"],d=l.split("/").slice(0,2).join("/");d=d.startsWith("@")?d:d.split("/")[0],/^[a-zA-Z0-9@/-]+$/.test(d)&&!p.includes(d)&&!s.dependencies.includes(d)&&s.dependencies.push(d)}}for(let e of s.files){let n=await N([e],{aliases:t,resolved:o});n.dependencies.forEach(a=>{s.dependencies.includes(a)||s.dependencies.push(a)}),n.files.forEach(a=>{s.files.includes(a)||s.files.push(a)}),s.content[e]=n.content[e]||await I.promises.readFile(e,"utf8")}for(let e of s.files)s.content[e]=s.content[e].replace(/import\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]/g,n=>{var h,p,d;let a=(h=n.match(/['"](.*)['"]/))==null?void 0:h[1];if(Object.keys(t).some(u=>a.startsWith(u))){let u=w(a,t),b=(p=f(u,{aliases:t}))==null?void 0:p.import;return n.replace(a,b)}else if(a.startsWith(".")){let u=A.resolve(A.dirname(e),a),b=(d=f(u,{aliases:t}))==null?void 0:d.import;return n.replace(a,b)}else return n});return s.dependencies.sort(),s.files.sort((e,n)=>f(e,{aliases:t}).target.localeCompare(f(n,{aliases:t}).target)),s.files.sort((e,n)=>{let a=["registry:file","registry:block","registry:component","registry:ui","registry:hook","registry:lib"],l=f(e,{aliases:t}).type,h=f(n,{aliases:t}).type;return a.indexOf(l)-a.indexOf(h)}),s};var S="smart-registry",_="0.5.5";var E={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var z=`Version:
4
+ ${S}@${_}
5
5
 
6
6
  Usage:
7
- $ ${A} [options]
7
+ $ ${S} [options]
8
8
 
9
9
  Options:
10
10
  -f, --files Files to build the registry from
11
11
  -d, --directories Directories to build the registry from
12
+ -i, --ignore Endings/Extensions to ignore (comma separated)
13
+ e.g. -i ".spec.ts, .test.ts, demo.tsx"
12
14
  -v, --version Display version
13
15
  -h, --help Display help
14
16
 
15
17
  Author:
16
- ${O.name} <${O.email}> (${O.url})`,L=r=>{try{return K(r)}catch(i){throw new Error(`Error parsing arguments: ${i.message}`)}},Q=async()=>{var r,i,t,n;try{let{positionals:s,values:e}=L({allowPositionals:!0,options:{files:{type:"string",multiple:!0,short:"f"},directories:{type:"string",multiple:!0,short:"d"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});s.length||(e.version&&(console.log(`${A}@${D}`),process.exit(0)),e.help&&(console.log(I),process.exit(0)));let a={files:e.files||[],directories:e.directories||[]},o=await C(),f=await V();if(!a.files.length&&!a.directories.length){let l=["registry","components"].map(p=>o["@/"]+p).find(p=>f.some(b=>b.startsWith(p+"/")));if(l)a.directories.push(l);else throw new Error("Neither registry nor components directory found")}let h=[...a.files.map(l=>w(l,o)),...a.directories.flatMap(l=>f.filter(p=>p.startsWith(w(l,o)+"/")))],c=S.resolve(process.cwd(),"registry.json"),g={};v.existsSync(c)&&(g=JSON.parse(await v.promises.readFile(c,"utf8")));let u=E($({},g),{items:[]}),y=[];for(let l of h)try{let p=await N([l,...((t=(i=(r=g.items)==null?void 0:r.find(m=>m.name===d(l,{aliases:o}).name))==null?void 0:i.files)==null?void 0:t.map(m=>m.path))||[]],{aliases:o}),b=$(E($({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:d(l,{aliases:o}).name,type:d(l,{aliases:o}).type||"registry:file"},p.dependencies.length&&{dependencies:p.dependencies}),{files:p.files.map(m=>({type:d(m,{aliases:o}).type||"registry:file",target:d(m,{aliases:o}).target||m,content:p.content[m],path:m}))}),Object.fromEntries(Object.entries(((n=g.items)==null?void 0:n.find(m=>m.name===d(l,{aliases:o}).name))||{}).filter(([m])=>!["$schema","name","type","files"].includes(m)))),P=S.resolve(process.cwd(),"public/r",b.name+".json");console.log(`- ${l.padEnd(Math.max(...h.map(m=>m.length))+2," ")} ${p.dependencies.length?"\u{1F4E6}"+String(p.dependencies.length).padEnd(2," "):" "} ${p.files.length-1?"\u{1F4C4}"+String(p.files.length).padEnd(2," "):" "} ${P.replace(process.cwd()+"/","")}`),await v.promises.mkdir(S.dirname(P),{recursive:!0}),await v.promises.writeFile(P,JSON.stringify(b,null,2)+`
17
- `),b.files.forEach(m=>delete m.content),u.items.push(b)}catch(p){y.push(l+": "+p.message);continue}u.items.sort((l,p)=>l.name.localeCompare(p.name)),await v.promises.writeFile(S.resolve(process.cwd(),"public/registry.json"),JSON.stringify(u,null,2)+`
18
- `),y.length&&(console.log(),y.forEach(l=>console.error(`\x1B[31m- ${l}\x1B[0m`))),process.exit(0)}catch(s){console.error(I),console.error(`
19
- ${s.message}
20
- `),process.exit(1)}};Q();
18
+ ${E.name} <${E.email}> (${E.url})`,Q=r=>{try{return L(r)}catch(i){throw new Error(`Error parsing arguments: ${i.message}`)}},X=async()=>{var r,i,t,o,s;try{let{positionals:e,values:n}=Q({allowPositionals:!0,options:{files:{type:"string",multiple:!0,short:"f"},directories:{type:"string",multiple:!0,short:"d"},ignore:{type:"string",multiple:!0,short:"i"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});e.length||(n.version&&(console.log(`${S}@${_}`),process.exit(0)),n.help&&(console.log(z),process.exit(0)));let a={files:n.files||[],directories:n.directories||[]},l=await M(),h=await V();if(!a.files.length&&!a.directories.length){let m=["registry","components"].map(c=>l["@/"]+c).find(c=>h.some(y=>y.startsWith(c+"/")));if(m)a.directories.push(m);else throw new Error("Neither registry nor components directory found")}let p=[...a.files.map(m=>w(m,l)),...a.directories.flatMap(m=>h.filter(c=>c.startsWith(w(m,l)+"/")))],d=O.resolve(process.cwd(),"registry.json"),u={};v.existsSync(d)&&(u=JSON.parse(await v.promises.readFile(d,"utf8")));let b=R(x({},u),{items:[]}),P=[];for(let m of p)if(!((r=n.ignore)!=null&&r.flatMap(c=>c.split(",").map(y=>y.trim())).some(c=>m.endsWith(c))))try{let c=await N([m,...((o=(t=(i=u.items)==null?void 0:i.find(g=>g.name===f(m,{aliases:l}).name))==null?void 0:t.files)==null?void 0:o.map(g=>g.path))||[]],{aliases:l}),y=x(R(x({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:f(m,{aliases:l}).name,type:f(m,{aliases:l}).type||"registry:file"},c.dependencies.length&&{dependencies:c.dependencies}),{files:c.files.map(g=>({type:f(g,{aliases:l}).type||"registry:file",target:f(g,{aliases:l}).target||g,content:c.content[g],path:g}))}),Object.fromEntries(Object.entries(((s=u.items)==null?void 0:s.find(g=>g.name===f(m,{aliases:l}).name))||{}).filter(([g])=>!["$schema","name","type","files"].includes(g)))),F=O.resolve(process.cwd(),"public/r",y.name+".json");console.log(`- ${m.padEnd(Math.max(...p.map(g=>g.length))+2," ")} ${c.dependencies.length?"\u{1F4E6}"+String(c.dependencies.length).padEnd(2," "):" "} ${c.files.length-1?"\u{1F4C4}"+String(c.files.length).padEnd(2," "):" "} ${F.replace(process.cwd()+"/","")}`),await v.promises.mkdir(O.dirname(F),{recursive:!0}),await v.promises.writeFile(F,JSON.stringify(y,null,2)+`
19
+ `),y.files.forEach(g=>delete g.content),b.items.push(y)}catch(c){P.push(m+": "+c.message);continue}b.items.sort((m,c)=>m.name.localeCompare(c.name)),await v.promises.writeFile(O.resolve(process.cwd(),"public/registry.json"),JSON.stringify(b,null,2)+`
20
+ `),P.length&&(console.log(),P.forEach(m=>console.error(`\x1B[31m- ${m}\x1B[0m`))),process.exit(0)}catch(e){console.error(z),console.error(`
21
+ ${e.message}
22
+ `),process.exit(1)}};X();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "smart-registry",
3
- "version": "0.5.4",
3
+ "version": "0.5.6",
4
4
  "description": "A zero-configuration (no registry.json required), shadcn add / open in v0 compatible registry builder.",
5
5
  "keywords": [
6
6
  "smart-registry"