smart-registry 1.11.0 → 1.13.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 +1 -1
- package/package.json +1 -1
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 a=process.env.npm_config_user_agent||"";return a.startsWith("yarn")?"yarn":a.startsWith("pnpm")?"pnpm":a.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
3
|
`).filter(o=>o.trim()&&!o.startsWith("#")).map(o=>o.replace(/^\//,"").replace(/^/,"**/")):[],a=await ye(["**/*.ts","**/*.tsx","**/*.js","**/*.jsx"],{cwd:r,ignore:s}),e=new Set,n=a.map(async o=>{let c=V.resolve(r,o),p=await A.promises.readFile(c,"utf-8"),f=p.replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(y,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(p)&&(f=f.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,f,"utf-8")});await Promise.all(n);let l=V.resolve(r,"registry.json");if(X(l)){let o=await A.promises.readFile(l,"utf-8"),c=JSON.parse(o),p=y=>{for(let h in y)h==="dependencies"||h==="devDependencies"?y[h]=Array.from(new Set(y[h].map(b=>e.has(b)?"radix-ui":b))):typeof y[h]=="object"&&y[h]!==null&&p(y[h])};p(c);let f=JSON.stringify(c,null,2);await A.promises.writeFile(l,f,"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/**"]],P={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(a=>B.existsSync(T.resolve(r,a)));if(s){let a=await B.promises.readFile(T.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(he(a,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((n,[l,[m]])=>(l.endsWith("*")&&m.endsWith("*")&&(n[l.replace(/\*$/,"")]=m.replace(/\*$/,"")),n),{}))}return t["@/"]||(t["@/"]=B.existsSync(T.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([a],[e])=>e.length-a.length).reduce((a,[e,n])=>(a[e]=n,a),{}),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 l;let a=s;for(let m in t)s=s.replace(t[m].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(m,o)=>`blocks/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(m,o)=>`charts/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(m,o)=>`${o?o+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(m,o)=>`components/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(m,o)=>`hooks/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(m,o)=>`lib/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(m,o)=>`components/ui/${o?o+"/":""}`).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":e.endsWith(".css")?"registry:style":((l=e.match(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:l[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+ve.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:a.split("/").length>1?e:`~/${e}`,path:s}};var se=async({cwd:r,aliases:t,registryFiles:s})=>{let a=j.resolve(r,"registry.json"),e={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};E.existsSync(a)&&(e=$({},JSON.parse(await E.promises.readFile(a,"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 l=null,m=null,o=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(o){let c=await E.promises.readFile(o,"utf8"),p=c.match(/:root\s*{([^}]*)}/);l=p?p[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(y=>y.trim()).filter(y=>y.length).map(y=>{let[h,b]=y.split(":").map(R=>R.trim());return{name:h.replace(/^--/,""),value:b}}):null;let f=c.match(/\.dark\s*{([^}]*)}/);m=f?f[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(y=>y.trim()).filter(y=>y.length).map(y=>{let[h,b]=y.split(":").map(R=>R.trim());return{name:h.replace(/^--/,""),value:b}}):null}return l&&m&&e.items.push({name:"style",type:"registry:style",cssVars:{light:Object.fromEntries(l.map(c=>[c.name,c.value])),dark:Object.fromEntries(m.map(c=>[c.name,c.value]))}}),n.length&&e.items.push({name:"ui",type:"registry:ui",files:n}),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 a=await we(t,{cwd:r,ignore:s.filter(e=>!t.includes(e))});for(let e of t)if(!a.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let n=xe.resolve(r,e);(await be.promises.stat(n)).isFile()&&a.push(e)}catch(n){continue}return[...new Set(a)]};var re=async({cwd:r,patterns:t,ignore:s,patternsOnly:a})=>{let e=[];if(!a){for(let n of ee)if(e=await F({cwd:r,patterns:n,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((n,l)=>n.localeCompare(l,void 0,{numeric:!0,sensitivity:"base"})).filter(n=>!n.startsWith("registry/registry")&&!n.startsWith("registry/index")&&!n.startsWith("src/registry/registry")&&!n.startsWith("src/registry/index")),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:a})=>{a=a!=null?a:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let n of s){if(a.has(n))continue;a.add(n),e.files.push(n),e.content[n]||(e.content[n]=await ie.promises.readFile(ne.resolve(r,n),"utf8"));let{dependencies:l,devDependencies:m,files:o,transformations:c}=await z({cwd:r,aliases:t,filepath:n,content:e.content[n]});o.forEach(p=>e.files.push(p)),l.forEach(p=>e.dependencies.push(p)),m.forEach(p=>e.devDependencies.push(p))}for(let n of e.files){let{dependencies:l,devDependencies:m,files:o,content:c}=await q({cwd:r,aliases:t,filepaths:[n],resolved:a});e.content[n]||(e.content[n]=c[n]||await ie.promises.readFile(ne.resolve(r,n),"utf8")),o.forEach(p=>e.files.push(p)),l.forEach(p=>e.dependencies.push(p)),m.forEach(p=>e.devDependencies.push(p))}e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort();for(let n of e.files){let{transformations:l}=await z({cwd:r,aliases:t,filepath:n,content:e.content[n]});e.content[n]=e.content[n].replace(_.imports,m=>{let o=m.match(/['"](.*)['"]/);return o&&l[o[1]]?m.replace(o[1],l[o[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 a=await F({cwd:r,patterns:t});return t=a.find(e=>e.startsWith(t+"."))||a.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 a=await F({cwd:r,patterns:s});return s=a.find(e=>e.startsWith(s+"."))||a.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},z=async({cwd:r,aliases:t,filepath:s,content:a})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},n=a.match(_.imports)||[];if(!n.length)return e;n=n.map(l=>{var m;return(m=l.match(/['"](.*)['"]/))==null?void 0:m[1].replace(/\/\//g,"/")});for(let l of n){let m=l;if(Object.keys(t).some(c=>l.startsWith(c.replace(/\.\//g,"").replace(/\.\.\//g,""))))l=await ke({cwd:r,aliases:t,current:l}),e.transformations[m]=w({cwd:r,aliases:t,filepath:l}),e.files.push(l);else if(l.startsWith("."))l=await $e({cwd:r,filepath:s,current:l}),e.transformations[m]=w({cwd:r,aliases:t,filepath:l}),e.files.push(l);else{let c=J.resolve(r,"package.json"),p={};if(oe.existsSync(c)){let f=JSON.parse(await oe.promises.readFile(c,"utf8"));p=$({},f.devDependencies)}if(l.startsWith("@")){let f=l.split("/").slice(0,2).join("/");p[f]?e.devDependencies.push(f):e.dependencies.push(f)}else{let f=l.split("/")[0];p[f]?e.devDependencies.push(f):e.dependencies.push(f)}}}return e};import{green as je}from"yoctocolors";var M="smart-registry",U="1.
|
|
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/**"]],P={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(a=>B.existsSync(T.resolve(r,a)));if(s){let a=await B.promises.readFile(T.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(he(a,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((n,[l,[m]])=>(l.endsWith("*")&&m.endsWith("*")&&(n[l.replace(/\*$/,"")]=m.replace(/\*$/,"")),n),{}))}return t["@/"]||(t["@/"]=B.existsSync(T.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([a],[e])=>e.length-a.length).reduce((a,[e,n])=>(a[e]=n,a),{}),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 l;let a=s;for(let m in t)s=s.replace(t[m].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(m,o)=>`blocks/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(m,o)=>`charts/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(m,o)=>`${o?o+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(m,o)=>`components/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(m,o)=>`hooks/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(m,o)=>`lib/${o?o+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(m,o)=>`components/ui/${o?o+"/":""}`).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":e.endsWith(".css")?"registry:style":((l=e.match(/^(blocks|components\/charts|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:l[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+ve.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:a.split("/").length>1?e.startsWith("blocks/")&&e.endsWith("page.tsx")?e.replace(/^blocks\//,"app/"):e:`~/${e}`,path:s}};var se=async({cwd:r,aliases:t,registryFiles:s})=>{let a=j.resolve(r,"registry.json"),e={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};E.existsSync(a)&&(e=$({},JSON.parse(await E.promises.readFile(a,"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 l=null,m=null,o=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(o){let c=await E.promises.readFile(o,"utf8"),p=c.match(/:root\s*{([^}]*)}/);l=p?p[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(y=>y.trim()).filter(y=>y.length).map(y=>{let[h,b]=y.split(":").map(R=>R.trim());return{name:h.replace(/^--/,""),value:b}}):null;let f=c.match(/\.dark\s*{([^}]*)}/);m=f?f[1].replace(/\/\*[\s\S]*?\*\//g,"").split(";").map(y=>y.trim()).filter(y=>y.length).map(y=>{let[h,b]=y.split(":").map(R=>R.trim());return{name:h.replace(/^--/,""),value:b}}):null}return l&&m&&e.items.push({name:"style",type:"registry:style",cssVars:{light:Object.fromEntries(l.map(c=>[c.name,c.value])),dark:Object.fromEntries(m.map(c=>[c.name,c.value]))}}),n.length&&e.items.push({name:"ui",type:"registry:ui",files:n}),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 a=await we(t,{cwd:r,ignore:s.filter(e=>!t.includes(e))});for(let e of t)if(!a.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let n=xe.resolve(r,e);(await be.promises.stat(n)).isFile()&&a.push(e)}catch(n){continue}return[...new Set(a)]};var re=async({cwd:r,patterns:t,ignore:s,patternsOnly:a})=>{let e=[];if(!a){for(let n of ee)if(e=await F({cwd:r,patterns:n,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((n,l)=>n.localeCompare(l,void 0,{numeric:!0,sensitivity:"base"})).filter(n=>!n.startsWith("registry/registry")&&!n.startsWith("registry/index")&&!n.startsWith("src/registry/registry")&&!n.startsWith("src/registry/index")),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:a})=>{a=a!=null?a:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let n of s){if(a.has(n))continue;a.add(n),e.files.push(n),e.content[n]||(e.content[n]=await ie.promises.readFile(ne.resolve(r,n),"utf8"));let{dependencies:l,devDependencies:m,files:o,transformations:c}=await z({cwd:r,aliases:t,filepath:n,content:e.content[n]});o.forEach(p=>e.files.push(p)),l.forEach(p=>e.dependencies.push(p)),m.forEach(p=>e.devDependencies.push(p))}for(let n of e.files){let{dependencies:l,devDependencies:m,files:o,content:c}=await q({cwd:r,aliases:t,filepaths:[n],resolved:a});e.content[n]||(e.content[n]=c[n]||await ie.promises.readFile(ne.resolve(r,n),"utf8")),o.forEach(p=>e.files.push(p)),l.forEach(p=>e.dependencies.push(p)),m.forEach(p=>e.devDependencies.push(p))}e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort();for(let n of e.files){let{transformations:l}=await z({cwd:r,aliases:t,filepath:n,content:e.content[n]});e.content[n]=e.content[n].replace(_.imports,m=>{let o=m.match(/['"](.*)['"]/);return o&&l[o[1]]?m.replace(o[1],l[o[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 a=await F({cwd:r,patterns:t});return t=a.find(e=>e.startsWith(t+"."))||a.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 a=await F({cwd:r,patterns:s});return s=a.find(e=>e.startsWith(s+"."))||a.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},z=async({cwd:r,aliases:t,filepath:s,content:a})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},n=a.match(_.imports)||[];if(!n.length)return e;n=n.map(l=>{var m;return(m=l.match(/['"](.*)['"]/))==null?void 0:m[1].replace(/\/\//g,"/")});for(let l of n){let m=l;if(Object.keys(t).some(c=>l.startsWith(c.replace(/\.\//g,"").replace(/\.\.\//g,""))))l=await ke({cwd:r,aliases:t,current:l}),e.transformations[m]=w({cwd:r,aliases:t,filepath:l}),e.files.push(l);else if(l.startsWith("."))l=await $e({cwd:r,filepath:s,current:l}),e.transformations[m]=w({cwd:r,aliases:t,filepath:l}),e.files.push(l);else{let c=J.resolve(r,"package.json"),p={};if(oe.existsSync(c)){let f=JSON.parse(await oe.promises.readFile(c,"utf8"));p=$({},f.devDependencies)}if(l.startsWith("@")){let f=l.split("/").slice(0,2).join("/");p[f]?e.devDependencies.push(f):e.dependencies.push(f)}else{let f=l.split("/")[0];p[f]?e.devDependencies.push(f):e.dependencies.push(f)}}}return e};import{green as je}from"yoctocolors";var M="smart-registry",U="1.13.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:
|