smart-registry 0.11.0-canary.1 → 0.11.0-canary.3
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 +8 -8
- package/package.json +5 -2
package/dist/bin/index.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
var
|
|
3
|
-
${
|
|
2
|
+
var Y=Object.defineProperty,Z=Object.defineProperties;var ee=Object.getOwnPropertyDescriptors;var J=Object.getOwnPropertySymbols;var te=Object.prototype.hasOwnProperty,re=Object.prototype.propertyIsEnumerable;var M=(s,t,r)=>t in s?Y(s,t,{enumerable:!0,configurable:!0,writable:!0,value:r}):s[t]=r,u=(s,t)=>{for(var r in t||(t={}))te.call(t,r)&&M(s,r,t[r]);if(J)for(var r of J(t))re.call(t,r)&&M(s,r,t[r]);return s},P=(s,t)=>Z(s,ee(t));import S from"node:fs";import y from"node:path";import{parseArgs as le}from"node:util";var I=["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 E from"node:fs";import W from"node:path";import se from"strip-json-comments";var V=async s=>{let t={},r=["tsconfig.json","jsconfig.json"].find(n=>E.existsSync(W.resolve(s,n)));if(r){let n=await E.promises.readFile(W.resolve(s,r),"utf8"),{compilerOptions:e}=JSON.parse(se(n,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((i,[o,[p]])=>(o.endsWith("*")&&p.endsWith("*")&&(i[o.replace(/\*$/,"")]=p.replace(/\*$/,"")),i),{}))}return t["@/"]||(t["@/"]=E.existsSync(W.resolve(s,"src"))?"./src/":"./"),t=Object.entries(t).sort(([n],[e])=>e.length-n.length).reduce((n,[e,i])=>(n[e]=i,n),{}),t};import z from"node:fs";import ie from"node:path";var B=async s=>{let t=ie.resolve(s,"registry.json"),r={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};return z.existsSync(t)&&(r=u({},JSON.parse(await z.promises.readFile(t,"utf8")))),r};import q from"node:fs";import C from"node:path";import{glob as ne}from"tinyglobby";var $=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 n=await ne(t,{cwd:s,ignore:r.filter(e=>!t.includes(e))});for(let e of t)if(!n.includes(e)&&!e.endsWith("**")&&!e.endsWith(".**"))try{let i=C.resolve(s,e),o=await q.promises.stat(i);if(o.isDirectory()){let p=(await q.promises.readdir(i)).map(c=>C.resolve(e,c));n.push(...p)}else o.isFile()&&n.push(e)}catch(i){continue}return[...new Set(n)]};var L=async({cwd:s,patterns:t,ignore:r})=>{let n=[];if(t.length)n=await $({cwd:s,patterns:t,ignore:r});else for(let e of I)if(n=await $({cwd:s,patterns:e,ignore:r}),n.length)break;if(!n.length)throw new Error("No files/directories found to build the registry from!");return n};import{detect as oe}from"@antfu/ni";async function T(s,{withFallback:t}={withFallback:!1}){let r=await oe({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 n=process.env.npm_config_user_agent||"";return n.startsWith("yarn")?"yarn":n.startsWith("pnpm")?"pnpm":n.startsWith("bun")?"bun":"npm"}import U from"node:fs";import G from"node:path";var j={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var A=async({cwd:s,aliases:t,filepaths:r,resolved:n})=>{n=n!=null?n:new Set;let e={dependencies:[],devDependencies:[],files:[],content:{}};for(let i of r){if(n.has(i))continue;n.add(i),e.files.push(i),e.content[i]||(e.content[i]=await U.promises.readFile(G.resolve(s,i),"utf8"));let{dependencies:o,devDependencies:p,files:c,transformations:g}=await H({cwd:s,aliases:t,filepath:i,content:e.content[i]});e.content[i]=e.content[i].replace(j.imports,d=>{let a=d.match(/['"](.*)['"]/);return a&&g[a[1]]?d.replace(a[1],g[a[1]].import):d}),c.forEach(d=>e.files.push(d)),o.forEach(d=>e.dependencies.push(d)),p.forEach(d=>e.devDependencies.push(d))}for(let i of e.files){let{dependencies:o,devDependencies:p,files:c,content:g}=await A({cwd:s,aliases:t,filepaths:[i],resolved:n});e.content[i]||(e.content[i]=g[i]||await U.promises.readFile(G.resolve(s,i),"utf8")),c.forEach(d=>e.files.push(d)),o.forEach(d=>e.dependencies.push(d)),p.forEach(d=>e.devDependencies.push(d))}return e.dependencies=[...new Set(e.dependencies)].sort(),e.devDependencies=[...new Set(e.devDependencies)].sort(),e.files=[...new Set(e.files)].sort(),e};import K from"node:fs";import R from"node:path";import ae from"node:path";var v=({cwd:s,aliases:t,filepath:r})=>{var o;let n=r;for(let p in t)r=r.replace(t[p].replaceAll("./","").replaceAll("../",""),"");let e=r.startsWith("registry/")?r.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(p,c)=>`blocks/${c?c+"/":""}`).replace(/^(?:([^\/]*)\/)?charts\//,(p,c)=>`charts/${c?c+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(p,c)=>`${c?c+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(p,c)=>`components/${c?c+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(p,c)=>`hooks/${c?c+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(p,c)=>`lib/${c?c+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(p,c)=>`components/ui/${c?c+"/":""}`).replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,"").replace(/^charts\//,"components/charts/"):r.replace(/\/default\//,"/").replace(/^default\//,"").replace(/\.\.\//g,"").replace(/\.\//g,""),i=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:i,import:"@/"+e.replace(s+ae.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:n.split("/").length>1?e:`~/${e}`,path:r}};var ce=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 n=await $({cwd:s,patterns:t});return t=n.find(e=>e.startsWith(t+"."))||n.find(e=>e.startsWith(t+"/index"))||t,t.replace(s+"/","")},pe=async({cwd:s,filepath:t,current:r})=>{r=R.relative(s,R.resolve(s,R.dirname(t),r));let n=await $({cwd:s,patterns:r});return r=n.find(e=>e.startsWith(r+"."))||n.find(e=>e.startsWith(r+"/index"))||r,r.replace(s+"/","")},H=async({cwd:s,aliases:t,filepath:r,content:n})=>{let e={dependencies:[],devDependencies:[],files:[],transformations:{}},i=n.match(j.imports)||[];if(!i.length)return e;i=i.map(o=>{var p;return(p=o.match(/['"](.*)['"]/))==null?void 0:p[1].replace(/\/\//g,"/")});for(let o of i){let p=o;if(Object.keys(t).some(g=>o.startsWith(g.replace(/\.\//g,"").replace(/\.\.\//g,""))))o=await ce({cwd:s,aliases:t,current:o}),e.transformations[p]=v({cwd:s,aliases:t,filepath:o}),e.files.push(o);else if(o.startsWith("."))o=await pe({cwd:s,filepath:r,current:o}),e.transformations[p]=v({cwd:s,aliases:t,filepath:o}),e.files.push(o);else{let g=R.resolve(s,"package.json"),d={};if(K.existsSync(g)){let a=JSON.parse(await K.promises.readFile(g,"utf8"));d=u({},a.devDependencies)}if(o.startsWith("@")){let a=o.split("/").slice(0,2).join("/");d[a]?e.devDependencies.push(a):e.dependencies.push(a)}else{let a=o.split("/")[0];d[a]?e.devDependencies.push(a):e.dependencies.push(a)}}}return e};import{execa as Q}from"execa";var F="smart-registry",N="0.11.0-canary.2";var O={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var X=`Version:
|
|
3
|
+
${F}@${N}
|
|
4
4
|
|
|
5
5
|
Usage:
|
|
6
|
-
$ ${
|
|
6
|
+
$ ${F} [files/directories] ... [options]
|
|
7
7
|
|
|
8
8
|
Arguments:
|
|
9
9
|
files/directories files or directories to build the registry from (optional)
|
|
@@ -15,9 +15,9 @@ Options:
|
|
|
15
15
|
-h, --help display help
|
|
16
16
|
|
|
17
17
|
Author:
|
|
18
|
-
${
|
|
19
|
-
Codemod ran successfully. Please run the command again without the --codemod-radix flag to generate the registry.`),process.exit(0)}let
|
|
20
|
-
`),
|
|
21
|
-
`),g.length&&(console.log(),g.forEach(a=>console.error(`\x1B[31m- ${a}\x1B[0m`))),process.exit(0)}catch(n){console.error(
|
|
18
|
+
${O.name} <${O.email}> (${O.url})`,me=s=>{try{return le(s)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},de=async()=>{var s,t,r;try{let{positionals:n,values:e}=me({allowPositionals:!0,options:{output:{type:"string",short:"o",default:"public/r"},cwd:{type:"string",short:"c"},ignore:{type:"string",short:"i",default:""},"codemod-radix":{type:"boolean"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});n.length||(e.version&&(console.log(`${F}@${N}`),process.exit(0)),e.help&&(console.log(X),process.exit(0)));let i=y.resolve((s=e.cwd)!=null?s:process.cwd()),o=await V(i),p=await B(i),c=await L({cwd:i,patterns:n,ignore:e.ignore}),g=[];if(e["codemod-radix"]){let a=new Set;for(let f of c){let b=y.resolve(f),k=(await S.promises.readFile(b,"utf-8")).replace(/import \* as (\w+Primitive) from "@radix-ui\/react-([\w-]+)"/g,(m,h,w)=>(a.add(`@radix-ui/react-${w}`),`import { ${h.replace("Primitive","")} as ${h} } from "radix-ui"`)).replace(/Sheet as SheetPrimitive/g,"Dialog as SheetPrimitive").replace(/import\s+\{\s+Slot\s+\}\s+from\s+"@radix-ui\/react-slot"/,()=>(a.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");await S.promises.writeFile(b,k,"utf-8")}let l=await T(i);a.size&&await Q(l,[l==="npm"?"uninstall":"remove",...Array.from(a)],{cwd:i}),await Q(l,[l==="npm"?"install":"add","radix-ui"],{cwd:i}),console.log(`
|
|
19
|
+
Codemod ran successfully. Please run the command again without the --codemod-radix flag to generate the registry.`),process.exit(0)}let d=P(u({},p),{items:[]});for(let a of c)try{let l=((t=p.items)==null?void 0:t.find(m=>m.name===v({cwd:i,aliases:o,filepath:a}).name))||{},f=await A({cwd:i,aliases:o,filepaths:[a,...((r=l==null?void 0:l.files)==null?void 0:r.map(m=>m.path))||[]]}),b={dependencies:[...new Set([...f.dependencies,...(l==null?void 0:l.dependencies)||[]])].sort(),devDependencies:[...new Set([...f.devDependencies,...(l==null?void 0:l.devDependencies)||[]])].sort(),registryDependencies:[...new Set([...(l==null?void 0:l.registryDependencies)||[]])].sort()},x=u(P(u(u(u({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:v({cwd:i,aliases:o,filepath:a}).name,type:v({cwd:i,aliases:o,filepath:a}).type||"registry:file"},b.dependencies.length&&{dependencies:b.dependencies}),b.devDependencies.length&&{devDependencies:b.devDependencies}),b.registryDependencies.length&&{registryDependencies:b.registryDependencies}),{files:f.files.map(m=>({type:v({cwd:i,aliases:o,filepath:m}).type||"registry:file",target:v({cwd:i,aliases:o,filepath:m}).target||m,content:f.content[m],path:m})).sort((m,h)=>{if(m.path===a)return-1;if(h.path===a)return 1;let w=D.items.files.type.default;return w.indexOf(m.type)-w.indexOf(h.type)})}),Object.fromEntries(Object.entries(l).filter(([m])=>!["$schema","name","type","dependencies","devDependencies","registryDependencies","files"].includes(m))));x=Object.keys(x).sort((m,h)=>{let w=D.items.default;return w.indexOf(m)-w.indexOf(h)}).reduce((m,h)=>(m[h]=x[h],m),{});let k=y.resolve(i,e.output,x.name+".json");console.log(`- ${y.relative(process.cwd(),y.resolve(i,a)).padEnd(Math.max(...c.map(m=>y.relative(process.cwd(),y.resolve(i,m)).length))+2," ")} ${f.dependencies.length?"\u{1F4E6}"+String(f.dependencies.length).padEnd(2," "):" "} ${f.files.length-1?"\u{1F4C4}"+String(f.files.length).padEnd(2," "):" "} ${y.relative(process.cwd(),k)}`),await S.promises.mkdir(y.dirname(k),{recursive:!0}),await S.promises.writeFile(k,JSON.stringify(x,null,2)+`
|
|
20
|
+
`),x.files.forEach(m=>delete m.content),d.items.push(x)}catch(l){g.push(a+": "+l.message);continue}d.items.sort((a,l)=>a.name.localeCompare(l.name)).sort((a,l)=>{let f=D.items.type.default;return f.indexOf(a.type)-f.indexOf(l.type)}),await S.promises.writeFile(y.resolve(i,e.output,"registry.json"),JSON.stringify(d,null,2)+`
|
|
21
|
+
`),g.length&&(console.log(),g.forEach(a=>console.error(`\x1B[31m- ${a}\x1B[0m`))),process.exit(0)}catch(n){console.error(X),console.error(`
|
|
22
22
|
${n.message}
|
|
23
|
-
`),process.exit(1)}};
|
|
23
|
+
`),process.exit(1)}};de();
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "smart-registry",
|
|
3
|
-
"version": "0.11.0-canary.
|
|
3
|
+
"version": "0.11.0-canary.3",
|
|
4
4
|
"description": "A zero-configuration (no registry.json required), shadcn add / open in v0 compatible registry builder.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"components",
|
|
@@ -56,6 +56,8 @@
|
|
|
56
56
|
"semi": false
|
|
57
57
|
},
|
|
58
58
|
"dependencies": {
|
|
59
|
+
"@antfu/ni": "^24.3.0",
|
|
60
|
+
"execa": "^9.5.2",
|
|
59
61
|
"strip-json-comments": "^5.0.1",
|
|
60
62
|
"tinyglobby": "^0.2.12"
|
|
61
63
|
},
|
|
@@ -72,5 +74,6 @@
|
|
|
72
74
|
"sort-package-json": "^2.14.0",
|
|
73
75
|
"tsup": "^8.3.5",
|
|
74
76
|
"typescript": "^5.7.2"
|
|
75
|
-
}
|
|
77
|
+
},
|
|
78
|
+
"packageManager": "yarn@1.22.22+sha512.a6b2f7906b721bba3d67d4aff083df04dad64c399707841b7acf00f6b133b7ac24255f2652fa22ae3534329dc6180534e98d17432037ff6fd140556e2bb3137e"
|
|
76
79
|
}
|