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