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