smart-registry 0.20.0 → 0.20.1
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 +2 -2
- package/package.json +1 -1
package/dist/bin/index.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
var ne=Object.defineProperty,oe=Object.defineProperties;var ae=Object.getOwnPropertyDescriptors;var B=Object.getOwnPropertySymbols;var pe=Object.prototype.hasOwnProperty,ce=Object.prototype.propertyIsEnumerable;var V=(s,t,r)=>t in s?ne(s,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):s[t]=r,b=(s,t)=>{for(var r in t||(t={}))pe.call(t,r)&&V(s,r,t[r]);if(B)for(var r of B(t))ce.call(t,r)&&V(s,r,t[r]);return s},E=(s,t)=>oe(s,ae(t));import z from"node:fs";import k from"node:path";import{parseArgs as be}from"node:util";import D,{existsSync as L}from"node:fs";import{readFile as me}from"node:fs/promises";import J from"node:path";import{detect as le}from"@antfu/ni";async function q(s,{withFallback:t}={withFallback:!1}){let r=await le({programmatic:!0,cwd:s});if(r==="yarn@berry")return"yarn";if(r==="pnpm@6")return"pnpm";if(r==="bun")return"bun";if(r==="deno")return"deno";if(!t)return r!=null?r:"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 T}from"execa";import{glob as de}from"tinyglobby";var U=async({cwd:s})=>{let t=J.resolve(s,".gitignore"),r=L(t)?(await me(t,"utf8")).split(`
|
|
3
3
|
`).filter(n=>n.trim()&&!n.startsWith("#")).map(n=>n.replace(/^\//,"").replace(/^/,"**/")):[],a=await de(["**/*.ts","**/*.tsx","**/*.js","**/*.jsx"],{cwd:s,ignore:r}),e=new Set,p=a.map(async n=>{let g=J.resolve(s,n),l=await D.promises.readFile(g,"utf-8"),d=l.replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(x,u,m)=>(e.add(`@radix-ui/react-${m}`),`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(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")),D.promises.writeFile(g,d,"utf-8")});await Promise.all(p);let o=J.resolve(s,"registry.json");if(L(o)){let n=await D.promises.readFile(o,"utf-8"),g=JSON.parse(n),l=x=>{for(let u in x)u==="dependencies"||u==="devDependencies"?x[u]=Array.from(new Set(x[u].map(m=>e.has(m)?"radix-ui":m))):typeof x[u]=="object"&&x[u]!==null&&l(x[u])};l(g);let d=JSON.stringify(g,null,2);await D.promises.writeFile(o,d,"utf-8")}let i=await q(s);e.size&&await T(i,[i==="npm"?"uninstall":"remove",...Array.from(e)],{cwd:s}),await T(i,[i==="npm"?"install":"add","radix-ui"],{cwd:s}),console.log(`
|
|
4
|
-
Codemod ran successfully. Please run the command again without the --codemod-radix flag to generate the registry.`)};var G=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],R={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 _ from"node:fs";import N from"node:path";import ge from"strip-json-comments";var H=async s=>{let t={},r=["tsconfig.json","jsconfig.json"].find(a=>_.existsSync(N.resolve(s,a)));if(r){let a=await _.promises.readFile(N.resolve(s,r),"utf8"),{compilerOptions:e}=JSON.parse(ge(a,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((p,[o,[i]])=>(o.endsWith("*")&&i.endsWith("*")&&(p[o.replace(/\*$/,"")]=i.replace(/\*$/,"")),p),{}))}return t["@/"]||(t["@/"]=_.existsSync(N.resolve(s,"src"))?"./src/":"./"),t=Object.entries(t).sort(([a],[e])=>e.length-a.length).reduce((a,[e,p])=>(a[e]=p,a),{}),t};import K from"node:fs";import fe from"node:path";var Q=async s=>{let t=fe.resolve(s,"registry.json"),r={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};return K.existsSync(t)&&(r=b({},JSON.parse(await K.promises.readFile(t,"utf8")))),r};import X from"node:fs";import Y from"node:path";import{glob as ue}from"tinyglobby";var j=async({cwd:s,patterns:t=["**",".**"],ignore:r=[]})=>{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),r=typeof r=="string"?r.split(",").map(e=>e.trim()):r,r=r.filter(Boolean);let a=await ue(t,{cwd:s,ignore:r.filter(e=>!t.includes(e))});for(let e of t)if(!a.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let p=Y.resolve(s,e),o=await X.promises.stat(p);if(o.isDirectory()){let i=(await X.promises.readdir(p)).map(n=>Y.resolve(e,n));a.push(...i)}else o.isFile()&&a.push(e)}catch(p){continue}return[...new Set(a)]};var Z=async({cwd:s,patterns:t,ignore:r,patternsOnly:a})=>{let e=[];if(!a){for(let p of G)if(e=await j({cwd:s,patterns:p,ignore:r}),e.length)break}if(t.length&&(e=e.concat(await j({cwd:s,patterns:t,ignore:r}))),!e.length)throw new Error("No files/directories found to build the registry from!");return e};import ee from"node:fs";import te from"node:path";var O={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var I=async({cwd:s,aliases:t,filepaths:r,resolved:a})=>{a=a!=null?a:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let p of r){if(a.has(p))continue;a.add(p),e.files.push(p),e.content[p]||(e.content[p]=await ee.promises.readFile(te.resolve(s,p),"utf8"));let{dependencies:o,devDependencies:i,files:n,transformations:g}=await re({cwd:s,aliases:t,filepath:p,content:e.content[p]});e.content[p]=e.content[p].replace(O.imports,l=>{let d=l.match(/['"](.*)['"]/);return d&&g[d[1]]?l.replace(d[1],g[d[1]].import):l}),n.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l)),i.forEach(l=>e.devDependencies.push(l))}for(let p of e.files){let{dependencies:o,devDependencies:i,files:n,content:g}=await I({cwd:s,aliases:t,filepaths:[p],resolved:a});e.content[p]||(e.content[p]=g[p]||await ee.promises.readFile(te.resolve(s,p),"utf8")),n.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l)),i.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 se from"node:fs";import F from"node:path";import he from"node:path";var v=({cwd:s,aliases:t,filepath:r})=>{var o;let a=r;for(let i in t)r=r.replace(t[i].replaceAll("./","").replaceAll("../",""),"");let e=r.startsWith("registry/")?r.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(i,n)=>`blocks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(i,n)=>`charts/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(i,n)=>`${n?n+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(i,n)=>`components/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(i,n)=>`hooks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(i,n)=>`lib/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(i,n)=>`components/ui/${n?n+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):r.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),p=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:p,import:"@/"+e.replace(s+he.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:a.split("/").length>1?e:`~/${e}`,path:r}};var ye=async({cwd:s,current:t,aliases:r})=>{t=t.replace(new RegExp(`^${Object.keys(r).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))}`),r[Object.keys(r).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))]),t=t.replace(/\.\//g,"").replace(/\.\.\//g,"");let a=await j({cwd:s,patterns:t});return t=a.find(e=>e.startsWith(t+"."))||a.find(e=>e.startsWith(t+"/index"))||t,t.replace(s+"/","")},xe=async({cwd:s,filepath:t,current:r})=>{r=F.relative(s,F.resolve(s,F.dirname(t),r));let a=await j({cwd:s,patterns:r});return r=a.find(e=>e.startsWith(r+"."))||a.find(e=>e.startsWith(r+"/index"))||r,r.replace(s+"/","")},re=async({cwd:s,aliases:t,filepath:r,content:a})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},p=a.match(O.imports)||[];if(!p.length)return e;p=p.map(o=>{var i;return(i=o.match(/['"](.*)['"]/))==null?void 0:i[1].replace(/\/\//g,"/")});for(let o of p){let i=o;if(Object.keys(t).some(g=>o.startsWith(g.replace(/\.\//g,"").replace(/\.\.\//g,""))))o=await ye({cwd:s,aliases:t,current:o}),e.transformations[i]=v({cwd:s,aliases:t,filepath:o}),e.files.push(o);else if(o.startsWith("."))o=await xe({cwd:s,filepath:r,current:o}),e.transformations[i]=v({cwd:s,aliases:t,filepath:o}),e.files.push(o);else{let g=F.resolve(s,"package.json"),l={};if(se.existsSync(g)){let d=JSON.parse(await se.promises.readFile(g,"utf8"));l=b({},d.devDependencies)}if(o.startsWith("@")){let d=o.split("/").slice(0,2).join("/");l[d]?e.devDependencies.push(d):e.dependencies.push(d)}else{let d=o.split("/")[0];l[d]?e.devDependencies.push(d):e.dependencies.push(d)}}}return e};var P="smart-registry",C="0.20.
|
|
4
|
+
Codemod ran successfully. Please run the command again without the --codemod-radix flag to generate the registry.`)};var G=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]],R={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 _ from"node:fs";import N from"node:path";import ge from"strip-json-comments";var H=async s=>{let t={},r=["tsconfig.json","jsconfig.json"].find(a=>_.existsSync(N.resolve(s,a)));if(r){let a=await _.promises.readFile(N.resolve(s,r),"utf8"),{compilerOptions:e}=JSON.parse(ge(a,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((p,[o,[i]])=>(o.endsWith("*")&&i.endsWith("*")&&(p[o.replace(/\*$/,"")]=i.replace(/\*$/,"")),p),{}))}return t["@/"]||(t["@/"]=_.existsSync(N.resolve(s,"src"))?"./src/":"./"),t=Object.entries(t).sort(([a],[e])=>e.length-a.length).reduce((a,[e,p])=>(a[e]=p,a),{}),t};import K from"node:fs";import fe from"node:path";var Q=async s=>{let t=fe.resolve(s,"registry.json"),r={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};return K.existsSync(t)&&(r=b({},JSON.parse(await K.promises.readFile(t,"utf8")))),r};import X from"node:fs";import Y from"node:path";import{glob as ue}from"tinyglobby";var j=async({cwd:s,patterns:t=["**",".**"],ignore:r=[]})=>{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),r=typeof r=="string"?r.split(",").map(e=>e.trim()):r,r=r.filter(Boolean);let a=await ue(t,{cwd:s,ignore:r.filter(e=>!t.includes(e))});for(let e of t)if(!a.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let p=Y.resolve(s,e),o=await X.promises.stat(p);if(o.isDirectory()){let i=(await X.promises.readdir(p)).map(n=>Y.resolve(e,n));a.push(...i)}else o.isFile()&&a.push(e)}catch(p){continue}return[...new Set(a)]};var Z=async({cwd:s,patterns:t,ignore:r,patternsOnly:a})=>{let e=[];if(!a){for(let p of G)if(e=await j({cwd:s,patterns:p,ignore:r}),e.length)break}if(t.length&&(e=e.concat(await j({cwd:s,patterns:t,ignore:r}))),!e.length)throw new Error("No files/directories found to build the registry from!");return e};import ee from"node:fs";import te from"node:path";var O={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var I=async({cwd:s,aliases:t,filepaths:r,resolved:a})=>{a=a!=null?a:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let p of r){if(a.has(p))continue;a.add(p),e.files.push(p),e.content[p]||(e.content[p]=await ee.promises.readFile(te.resolve(s,p),"utf8"));let{dependencies:o,devDependencies:i,files:n,transformations:g}=await re({cwd:s,aliases:t,filepath:p,content:e.content[p]});e.content[p]=e.content[p].replace(O.imports,l=>{let d=l.match(/['"](.*)['"]/);return d&&g[d[1]]?l.replace(d[1],g[d[1]].import):l}),n.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l)),i.forEach(l=>e.devDependencies.push(l))}for(let p of e.files){let{dependencies:o,devDependencies:i,files:n,content:g}=await I({cwd:s,aliases:t,filepaths:[p],resolved:a});e.content[p]||(e.content[p]=g[p]||await ee.promises.readFile(te.resolve(s,p),"utf8")),n.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l)),i.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 se from"node:fs";import F from"node:path";import he from"node:path";var v=({cwd:s,aliases:t,filepath:r})=>{var o;let a=r;for(let i in t)r=r.replace(t[i].replaceAll("./","").replaceAll("../",""),"");let e=r.startsWith("registry/")?r.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(i,n)=>`blocks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(i,n)=>`charts/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(i,n)=>`${n?n+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(i,n)=>`components/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(i,n)=>`hooks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(i,n)=>`lib/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(i,n)=>`components/ui/${n?n+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):r.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),p=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:p,import:"@/"+e.replace(s+he.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:a.split("/").length>1?e:`~/${e}`,path:r}};var ye=async({cwd:s,current:t,aliases:r})=>{t=t.replace(new RegExp(`^${Object.keys(r).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))}`),r[Object.keys(r).find(e=>t.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))]),t=t.replace(/\.\//g,"").replace(/\.\.\//g,"");let a=await j({cwd:s,patterns:t});return t=a.find(e=>e.startsWith(t+"."))||a.find(e=>e.startsWith(t+"/index"))||t,t.replace(s+"/","")},xe=async({cwd:s,filepath:t,current:r})=>{r=F.relative(s,F.resolve(s,F.dirname(t),r));let a=await j({cwd:s,patterns:r});return r=a.find(e=>e.startsWith(r+"."))||a.find(e=>e.startsWith(r+"/index"))||r,r.replace(s+"/","")},re=async({cwd:s,aliases:t,filepath:r,content:a})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},p=a.match(O.imports)||[];if(!p.length)return e;p=p.map(o=>{var i;return(i=o.match(/['"](.*)['"]/))==null?void 0:i[1].replace(/\/\//g,"/")});for(let o of p){let i=o;if(Object.keys(t).some(g=>o.startsWith(g.replace(/\.\//g,"").replace(/\.\.\//g,""))))o=await ye({cwd:s,aliases:t,current:o}),e.transformations[i]=v({cwd:s,aliases:t,filepath:o}),e.files.push(o);else if(o.startsWith("."))o=await xe({cwd:s,filepath:r,current:o}),e.transformations[i]=v({cwd:s,aliases:t,filepath:o}),e.files.push(o);else{let g=F.resolve(s,"package.json"),l={};if(se.existsSync(g)){let d=JSON.parse(await se.promises.readFile(g,"utf8"));l=b({},d.devDependencies)}if(o.startsWith("@")){let d=o.split("/").slice(0,2).join("/");l[d]?e.devDependencies.push(d):e.dependencies.push(d)}else{let d=o.split("/")[0];l[d]?e.devDependencies.push(d):e.dependencies.push(d)}}}return e};var P="smart-registry",C="0.20.1";var W={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var ie=`Version:
|
|
5
5
|
${P}@${C}
|
|
6
6
|
|
|
7
7
|
Usage:
|
|
@@ -25,7 +25,7 @@ Codemods:
|
|
|
25
25
|
--codemod-radix migrate to unify "@radix-ui/react-*" imports to "radix-ui"
|
|
26
26
|
|
|
27
27
|
Author:
|
|
28
|
-
${W.name} <${W.email}> (${W.url})`,ve=s=>{try{return be(s)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},we=async()=>{var s,t,r,a,e;try{let{positionals:p,values:o}=ve({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"}}});p.length||(o.version&&(console.log(`${P}@${C}`),process.exit(0)),o.help&&(console.log(ie),process.exit(0)));let i=k.resolve((s=o.cwd)!=null?s:process.cwd());o["codemod-radix"]&&(await U({cwd:i}),process.exit(0));let n=await H(i),g=await Q(i),l=o["registry-only"]?[]:await Z({cwd:i,patterns:p,ignore:o.ignore,patternsOnly:o["patterns-only"]}),d=[],x=((t=g.items)==null?void 0:t.map(m=>m.name))||[],u=E(b({},g),{items:[]});for(let m of[...l,...x])try{if((r=u.items)!=null&&r.find(c=>c.name===m||c.name===v({cwd:i,aliases:n,filepath:m}).name))
|
|
28
|
+
${W.name} <${W.email}> (${W.url})`,ve=s=>{try{return be(s)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},we=async()=>{var s,t,r,a,e;try{let{positionals:p,values:o}=ve({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"}}});p.length||(o.version&&(console.log(`${P}@${C}`),process.exit(0)),o.help&&(console.log(ie),process.exit(0)));let i=k.resolve((s=o.cwd)!=null?s:process.cwd());o["codemod-radix"]&&(await U({cwd:i}),process.exit(0));let n=await H(i),g=await Q(i),l=o["registry-only"]?[]:await Z({cwd:i,patterns:p,ignore:o.ignore,patternsOnly:o["patterns-only"]}),d=[],x=((t=g.items)==null?void 0:t.map(m=>m.name))||[],u=E(b({},g),{items:[]});for(let m of[...l,...x])try{if((r=u.items)!=null&&r.find(c=>c.name===m||c.name===v({cwd:i,aliases:n,filepath:m}).name))continue;let f=((a=g.items)==null?void 0:a.find(c=>c.name===m||c.name===v({cwd:i,aliases:n,filepath:m}).name))||{},y=await I({cwd:i,aliases:n,filepaths:[...x.includes(m)?[]:[m],...((e=f==null?void 0:f.files)==null?void 0:e.map(c=>c.path))||[]]}),S={dependencies:[...new Set([...y.dependencies,...(f==null?void 0:f.dependencies)||[]])].sort(),devDependencies:[...new Set([...y.devDependencies,...(f==null?void 0:f.devDependencies)||[]])].sort(),registryDependencies:[...new Set([...(f==null?void 0:f.registryDependencies)||[]])].sort()},h=b(E(b(b(b({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:v({cwd:i,aliases:n,filepath:m}).name,type:v({cwd:i,aliases:n,filepath:m}).type||"registry:file"},S.dependencies.length&&{dependencies:S.dependencies}),S.devDependencies.length&&{devDependencies:S.devDependencies}),S.registryDependencies.length&&{registryDependencies:S.registryDependencies}),{files:y.files.map(c=>({type:v({cwd:i,aliases:n,filepath:c}).type||"registry:file",target:v({cwd:i,aliases:n,filepath:c}).target||c,content:y.content[c],path:c}))}),Object.fromEntries(Object.entries(f).filter(([c])=>!["$schema","name","type","dependencies","devDependencies","registryDependencies","files"].includes(c))));h.files.some(c=>c.path===m)?h.files=h.files.sort((c,w)=>{if(c.path===m)return-1;if(w.path===m)return 1;let $=R.items.files.type.default;return $.indexOf(c.type)-$.indexOf(w.type)}):h.files=[h.files[0],...h.files.slice(1).sort((c,w)=>{let $=R.items.files.type.default;return $.indexOf(c.type)-$.indexOf(w.type)})],h=Object.keys(h).sort((c,w)=>{let $=R.items.default;return $.indexOf(c)-$.indexOf(w)}).reduce((c,w)=>(c[w]=h[w],c),{});let A=k.resolve(i,o.output,h.name+".json");console.log(`- ${k.relative(process.cwd(),k.resolve(i,m)).padEnd(Math.max(...l.map(c=>k.relative(process.cwd(),k.resolve(i,c)).length))+2," ")} ${y.dependencies.length?"\u{1F4E6}"+String(y.dependencies.length).padEnd(2," "):" "} ${y.files.length-1?"\u{1F4C4}"+String(y.files.length).padEnd(2," "):" "} ${k.relative(process.cwd(),A)}`),await z.promises.mkdir(k.dirname(A),{recursive:!0}),await z.promises.writeFile(A,JSON.stringify(h,null,2)+`
|
|
29
29
|
`),h.files.forEach(c=>delete c.content),u.items.push(h)}catch(f){d.push(m+": "+f.message);continue}u.items.sort((m,f)=>m.name.localeCompare(f.name)).sort((m,f)=>{let y=R.items.type.default;return y.indexOf(m.type)-y.indexOf(f.type)}),await z.promises.writeFile(k.resolve(i,o.output,"registry.json"),JSON.stringify(u,null,2)+`
|
|
30
30
|
`),d.length&&(console.log(),d.forEach(m=>console.error(`\x1B[31m- ${m}\x1B[0m`))),process.exit(0)}catch(p){console.error(ie),console.error(`
|
|
31
31
|
${p.message}
|