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