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