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