smart-registry 0.9.0 → 0.10.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/dist/bin/index.js CHANGED
@@ -1,5 +1,5 @@
1
1
  #!/usr/bin/env node
2
- var X=Object.defineProperty,Y=Object.defineProperties;var Z=Object.getOwnPropertyDescriptors;var J=Object.getOwnPropertySymbols;var C=Object.prototype.hasOwnProperty,ee=Object.prototype.propertyIsEnumerable;var I=(r,t,s)=>t in r?X(r,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[t]=s,h=(r,t)=>{for(var s in t||(t={}))C.call(t,s)&&I(r,s,t[s]);if(J)for(var s of J(t))ee.call(t,s)&&I(r,s,t[s]);return r},F=(r,t)=>Y(r,Z(t));import _ from"node:fs";import y from"node:path";import{parseArgs as ae}from"node:util";var M=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],k={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 E from"node:fs";import W from"node:path";import te from"strip-json-comments";var V=async r=>{let t={},s=["tsconfig.json","jsconfig.json"].find(n=>E.existsSync(W.resolve(r,n)));if(s){let n=await E.promises.readFile(W.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(te(n,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((i,[o,[c]])=>(o.endsWith("*")&&c.endsWith("*")&&(i[o.replace(/\*$/,"")]=c.replace(/\*$/,"")),i),{}))}return t["@/"]||(t["@/"]=E.existsSync(W.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([n],[e])=>e.length-n.length).reduce((n,[e,i])=>(n[e]=i,n),{}),t};import B from"node:fs";import se from"node:path";var q=async r=>{let t=se.resolve(r,"registry.json"),s={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};return B.existsSync(t)&&(s=h({},JSON.parse(await B.promises.readFile(t,"utf8")))),s};import z from"node:fs";import L from"node:path";import{glob as re}from"tinyglobby";var x=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 n=await re(t,{cwd:r,ignore:s.filter(e=>!t.includes(e))});if(!n.length)for(let e of t)try{let i=L.resolve(r,e),o=await z.promises.stat(i);if(o.isDirectory()){let c=(await z.promises.readdir(i)).map(a=>L.resolve(e,a));n.push(...c)}else o.isFile()&&n.push(e)}catch(i){continue}return n};var T=async({cwd:r,patterns:t,ignore:s})=>{let n=[];if(t.length)n=await x({cwd:r,patterns:t,ignore:s});else for(let e of M)if(n=await x({cwd:r,patterns:e,ignore:s}),n.length)break;if(!n.length)throw new Error("No files/directories found to build the registry from!");return n};import U from"node:fs";import G from"node:path";var j={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var A=async({cwd:r,aliases:t,filepaths:s,resolved:n})=>{n=n!=null?n:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let i of s){if(n.has(i))continue;n.add(i),e.files.push(i),e.content[i]||(e.content[i]=await U.promises.readFile(G.resolve(r,i),"utf8"));let{dependencies:o,devDependencies:c,files:a,transformations:g}=await H({cwd:r,aliases:t,filepath:i,content:e.content[i]});e.content[i]=e.content[i].replace(j.imports,l=>{let p=l.match(/['"](.*)['"]/);return p&&g[p[1]]?l.replace(p[1],g[p[1]].import):l}),a.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l)),c.forEach(l=>e.devDependencies.push(l))}for(let i of e.files){let{dependencies:o,devDependencies:c,files:a,content:g}=await A({cwd:r,aliases:t,filepaths:[i],resolved:n});e.content[i]||(e.content[i]=g[i]||await U.promises.readFile(G.resolve(r,i),"utf8")),a.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l)),c.forEach(l=>e.devDependencies.push(l))}return e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort(),e};import K from"node:fs";import D from"node:path";import ie from"node:path";var u=({cwd:r,aliases:t,filepath:s})=>{var o;let n=s;for(let c in t)s=s.replace(t[c].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(c,a)=>`blocks/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(c,a)=>`charts/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(c,a)=>`${a?a+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(c,a)=>`components/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(c,a)=>`hooks/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(c,a)=>`lib/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(c,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,""),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":((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:i,import:"@/"+e.replace(r+ie.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:n.split("/").length>1?e:`~/${e}`,path:s}};var ne=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,"").replace(/\.\.\//g,"");let n=await x({cwd:r,patterns:t});return t=n.find(e=>e.startsWith(t+"."))||n.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},oe=async({cwd:r,filepath:t,current:s})=>{s=D.relative(r,D.resolve(r,D.dirname(t),s));let n=await x({cwd:r,patterns:s});return s=n.find(e=>e.startsWith(s+"."))||n.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},H=async({cwd:r,aliases:t,filepath:s,content:n})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},i=n.match(j.imports)||[];if(!i.length)return e;i=i.map(o=>{var c;return(c=o.match(/['"](.*)['"]/))==null?void 0:c[1].replace(/\/\//g,"/")});for(let o of i){let c=o;if(Object.keys(t).some(g=>o.startsWith(g.replace(/\.\//g,"").replace(/\.\.\//g,""))))o=await ne({cwd:r,aliases:t,current:o}),e.transformations[c]=u({cwd:r,aliases:t,filepath:o}),e.files.push(o);else if(o.startsWith("."))o=await oe({cwd:r,filepath:s,current:o}),e.transformations[c]=u({cwd:r,aliases:t,filepath:o}),e.files.push(o);else{let g=D.resolve(r,"package.json"),l={};if(K.existsSync(g)){let p=JSON.parse(await K.promises.readFile(g,"utf8"));l=h({},p.devDependencies)}if(o.startsWith("@")){let p=o.split("/").slice(0,2).join("/");l[p]?e.devDependencies.push(p):e.dependencies.push(p)}else{let p=o.split("/")[0];l[p]?e.devDependencies.push(p):e.dependencies.push(p)}}}return e};var R="smart-registry",P="0.9.0";var O={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var Q=`Version:
2
+ var X=Object.defineProperty,Y=Object.defineProperties;var Z=Object.getOwnPropertyDescriptors;var J=Object.getOwnPropertySymbols;var C=Object.prototype.hasOwnProperty,ee=Object.prototype.propertyIsEnumerable;var I=(r,t,s)=>t in r?X(r,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[t]=s,h=(r,t)=>{for(var s in t||(t={}))C.call(t,s)&&I(r,s,t[s]);if(J)for(var s of J(t))ee.call(t,s)&&I(r,s,t[s]);return r},F=(r,t)=>Y(r,Z(t));import _ from"node:fs";import y from"node:path";import{parseArgs as ae}from"node:util";var M=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],k={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 E from"node:fs";import W from"node:path";import te from"strip-json-comments";var V=async r=>{let t={},s=["tsconfig.json","jsconfig.json"].find(n=>E.existsSync(W.resolve(r,n)));if(s){let n=await E.promises.readFile(W.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(te(n,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((i,[o,[c]])=>(o.endsWith("*")&&c.endsWith("*")&&(i[o.replace(/\*$/,"")]=c.replace(/\*$/,"")),i),{}))}return t["@/"]||(t["@/"]=E.existsSync(W.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([n],[e])=>e.length-n.length).reduce((n,[e,i])=>(n[e]=i,n),{}),t};import B from"node:fs";import se from"node:path";var q=async r=>{let t=se.resolve(r,"registry.json"),s={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};return B.existsSync(t)&&(s=h({},JSON.parse(await B.promises.readFile(t,"utf8")))),s};import z from"node:fs";import L from"node:path";import{glob as re}from"tinyglobby";var x=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 n=await re(t,{cwd:r,ignore:s.filter(e=>!t.includes(e))});for(let e of t)if(!n.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let i=L.resolve(r,e),o=await z.promises.stat(i);if(o.isDirectory()){let c=(await z.promises.readdir(i)).map(a=>L.resolve(e,a));n.push(...c)}else o.isFile()&&n.push(e)}catch(i){continue}return[...new Set(n)]};var T=async({cwd:r,patterns:t,ignore:s})=>{let n=[];if(t.length)n=await x({cwd:r,patterns:t,ignore:s});else for(let e of M)if(n=await x({cwd:r,patterns:e,ignore:s}),n.length)break;if(!n.length)throw new Error("No files/directories found to build the registry from!");return n};import U from"node:fs";import G from"node:path";var j={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var A=async({cwd:r,aliases:t,filepaths:s,resolved:n})=>{n=n!=null?n:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let i of s){if(n.has(i))continue;n.add(i),e.files.push(i),e.content[i]||(e.content[i]=await U.promises.readFile(G.resolve(r,i),"utf8"));let{dependencies:o,devDependencies:c,files:a,transformations:g}=await H({cwd:r,aliases:t,filepath:i,content:e.content[i]});e.content[i]=e.content[i].replace(j.imports,l=>{let p=l.match(/['"](.*)['"]/);return p&&g[p[1]]?l.replace(p[1],g[p[1]].import):l}),a.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l)),c.forEach(l=>e.devDependencies.push(l))}for(let i of e.files){let{dependencies:o,devDependencies:c,files:a,content:g}=await A({cwd:r,aliases:t,filepaths:[i],resolved:n});e.content[i]||(e.content[i]=g[i]||await U.promises.readFile(G.resolve(r,i),"utf8")),a.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l)),c.forEach(l=>e.devDependencies.push(l))}return e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort(),e};import K from"node:fs";import D from"node:path";import ie from"node:path";var u=({cwd:r,aliases:t,filepath:s})=>{var o;let n=s;for(let c in t)s=s.replace(t[c].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(c,a)=>`blocks/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(c,a)=>`charts/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(c,a)=>`${a?a+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(c,a)=>`components/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(c,a)=>`hooks/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(c,a)=>`lib/${a?a+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(c,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,""),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":((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:i,import:"@/"+e.replace(r+ie.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:n.split("/").length>1?e:`~/${e}`,path:s}};var ne=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,"").replace(/\.\.\//g,"");let n=await x({cwd:r,patterns:t});return t=n.find(e=>e.startsWith(t+"."))||n.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},oe=async({cwd:r,filepath:t,current:s})=>{s=D.relative(r,D.resolve(r,D.dirname(t),s));let n=await x({cwd:r,patterns:s});return s=n.find(e=>e.startsWith(s+"."))||n.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},H=async({cwd:r,aliases:t,filepath:s,content:n})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},i=n.match(j.imports)||[];if(!i.length)return e;i=i.map(o=>{var c;return(c=o.match(/['"](.*)['"]/))==null?void 0:c[1].replace(/\/\//g,"/")});for(let o of i){let c=o;if(Object.keys(t).some(g=>o.startsWith(g.replace(/\.\//g,"").replace(/\.\.\//g,""))))o=await ne({cwd:r,aliases:t,current:o}),e.transformations[c]=u({cwd:r,aliases:t,filepath:o}),e.files.push(o);else if(o.startsWith("."))o=await oe({cwd:r,filepath:s,current:o}),e.transformations[c]=u({cwd:r,aliases:t,filepath:o}),e.files.push(o);else{let g=D.resolve(r,"package.json"),l={};if(K.existsSync(g)){let p=JSON.parse(await K.promises.readFile(g,"utf8"));l=h({},p.devDependencies)}if(o.startsWith("@")){let p=o.split("/").slice(0,2).join("/");l[p]?e.devDependencies.push(p):e.dependencies.push(p)}else{let p=o.split("/")[0];l[p]?e.devDependencies.push(p):e.dependencies.push(p)}}}return e};var R="smart-registry",P="0.10.0";var O={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var Q=`Version:
3
3
  ${R}@${P}
4
4
 
5
5
  Usage:
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "smart-registry",
3
- "version": "0.9.0",
3
+ "version": "0.10.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",