smart-registry 0.6.0-canary.1 → 0.6.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 CHANGED
@@ -1,9 +1,9 @@
1
1
  #!/usr/bin/env node
2
- var U=Object.defineProperty,G=Object.defineProperties;var H=Object.getOwnPropertyDescriptors;var N=Object.getOwnPropertySymbols;var K=Object.prototype.hasOwnProperty,L=Object.prototype.propertyIsEnumerable;var D=(r,s,t)=>s in r?U(r,s,{enumerable:!0,configurable:!0,writable:!0,value:t}):r[s]=t,f=(r,s)=>{for(var t in s||(s={}))K.call(s,t)&&D(r,t,s[t]);if(N)for(var t of N(s))L.call(s,t)&&D(r,t,s[t]);return r},$=(r,s)=>G(r,H(s));import E from"node:fs";import m from"node:path";import{parseArgs as se}from"node:util";import j from"node:fs";import R from"node:path";import Q from"strip-json-comments";var P=async r=>{let s={},t=["tsconfig.json","jsconfig.json"].find(o=>j.existsSync(R.resolve(r,o)));if(t){let o=await j.promises.readFile(R.resolve(r,t),"utf8"),{compilerOptions:e}=JSON.parse(Q(o,{trailingCommas:!0}));e.paths&&(s=Object.entries(e.paths).reduce((i,[n,[a]])=>(n.endsWith("*")&&a.endsWith("*")&&(i[n.replace(/\*$/,"")]=a.replace(/\*$/,"")),i),{}))}return s["@/"]||(s["@/"]=j.existsSync(R.resolve(r,"src"))?"./src/":"./"),s=Object.entries(s).sort(([o],[e])=>e.length-o.length).reduce((o,[e,i])=>(o[e]=i,o),{}),s};import _ from"node:fs";import X from"node:path";var I=async r=>{let s=X.resolve(r,"registry.json"),t={$schema:"https://ui.shadcn.com/schema/registry.json",name:"shadcn",homepage:"https://ui.shadcn.com",items:[]};return _.existsSync(s)&&(t=f({},JSON.parse(await _.promises.readFile(s,"utf8")))),t};import{glob as Y}from"tinyglobby";var h=async({cwd:r,patterns:s=["**",".**"],ignore:t=[]})=>(s=Array.isArray(s)?s:[s],s=s.flatMap(e=>e.includes("*")?e:[e+".*",e+"/**"]),s=s.filter(Boolean),t=typeof t=="string"?t.split(",").map(e=>e.trim()):t,t=t.filter(Boolean),await Y(s,{cwd:r,ignore:t.filter(e=>!s.includes(e))}));var J=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]];var M=async({cwd:r,patterns:s,ignore:t})=>{let o=[];if(s.length)o=await h({cwd:r,patterns:s,ignore:t});else for(let e of J)if(o=await h({cwd:r,patterns:e,ignore:t}),o.length)break;if(!o.length)throw new Error("No files/directories found to build the registry from!");return o};import V from"node:fs";import C from"node:path";var F=async({cwd:r,aliases:s,filepaths:t,resolved:o})=>{o=o!=null?o:new Set;let e={dependencies:[],files:[],content:{}};for(let i of t){if(o.has(i))continue;o.add(i),e.files.push(i),e.content[i]=e.content[i]||await V.promises.readFile(C.resolve(r,i),"utf8");let{dependencies:n,files:a}=await B({cwd:r,aliases:s,filepath:i,content:e.content[i]});e.dependencies.push(...n.filter(l=>!e.dependencies.includes(l))),e.files.push(...a.filter(l=>!e.files.includes(l)))}for(let i of e.files)if(!o.has(i)){let{dependencies:n,files:a}=await F({cwd:r,aliases:s,filepaths:[i],resolved:o});e.dependencies.push(...n.filter(l=>!e.dependencies.includes(l))),e.files.push(...a.filter(l=>!e.files.includes(l))),e.content[i]=e.content[i]||await V.promises.readFile(C.resolve(r,i),"utf8")}return e.dependencies=e.dependencies.sort(),e.files=e.files.sort(),e};import O from"node:path";var q={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var Z=async({cwd:r,current:s,aliases:t})=>{s=s.replace(new RegExp(`^${Object.keys(t).find(e=>s.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))}`),t[Object.keys(t).find(e=>s.startsWith(e.replace(/\.\//g,"").replace(/\.\.\//g,"")))]),s=s.replace(/\.\//g,"").replace(/\.\.\//g,"");let o=await h({cwd:r,patterns:s});return s=o.find(e=>e.startsWith(s+"."))||o.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},ee=async({cwd:r,filepath:s,current:t})=>{t=O.relative(r,O.resolve(r,O.dirname(s),t));let o=await h({cwd:r,patterns:t});return t=o.find(e=>e.startsWith(t+"."))||o.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},B=async({cwd:r,aliases:s,filepath:t,content:o})=>{let e={dependencies:[],files:[]},i=o.match(q.imports)||[];if(!i.length)return e;i=i.map(n=>{var a;return(a=n.match(/['"](.*)['"]/))==null?void 0:a[1].replace(/\/\//g,"/")});for(let n of i)Object.keys(s).some(l=>n.startsWith(l.replace(/\.\//g,"").replace(/\.\.\//g,"")))?(n=await Z({cwd:r,aliases:s,current:n}),e.files.push(n)):n.startsWith(".")?(n=await ee({cwd:r,filepath:t,current:n}),e.files.push(n)):n.startsWith("@")?e.dependencies.push(n.split("/").slice(0,2).join("/")):e.dependencies.push(n.replace(/\/.*/,""));return e};import z from"node:path";var d=(r,s={})=>{var o;r=s.aliases?r.replace(s.aliases["@/"],""):r,r=r.replace(process.cwd()+z.sep,"");let t=r.startsWith("registry/")?r.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(e,i)=>`blocks/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(e,i)=>`${i?i+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(e,i)=>`components/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(e,i)=>`hooks/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(e,i)=>`lib/${i?i+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(e,i)=>`components/ui/${i?i+"/":""}`).replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,""):r.replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,"");return{type:t.endsWith("page.tsx")?"registry:page":((o=t.match(/^(blocks|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:o[1].replace("blocks","registry:block").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:t.replace(/^(blocks|components\/ui|components|hooks|lib|utils|helpers)\//,"").replace(/\.[^\/.]+$/,""),import:"@/"+t.replace(process.cwd()+z.sep,"").replace(/\.[^/.]+$/,""),target:t,path:r}};var y="smart-registry",W="0.6.0-canary.1";var b={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var T=`Version:
3
- ${y}@${W}
2
+ var K=Object.defineProperty,L=Object.defineProperties;var Q=Object.getOwnPropertyDescriptors;var _=Object.getOwnPropertySymbols;var X=Object.prototype.hasOwnProperty,Y=Object.prototype.propertyIsEnumerable;var I=(r,t,s)=>t in r?K(r,t,{enumerable:!0,configurable:!0,writable:!0,value:s}):r[t]=s,y=(r,t)=>{for(var s in t||(t={}))X.call(t,s)&&I(r,s,t[s]);if(_)for(var s of _(t))Y.call(t,s)&&I(r,s,t[s]);return r},F=(r,t)=>L(r,Q(t));import N from"node:fs";import h from"node:path";import{parseArgs as oe}from"node:util";import E from"node:fs";import S from"node:path";import Z from"strip-json-comments";var J=async r=>{let t={},s=["tsconfig.json","jsconfig.json"].find(i=>E.existsSync(S.resolve(r,i)));if(s){let i=await E.promises.readFile(S.resolve(r,s),"utf8"),{compilerOptions:e}=JSON.parse(Z(i,{trailingCommas:!0}));e.paths&&(t=Object.entries(e.paths).reduce((a,[o,[n]])=>(o.endsWith("*")&&n.endsWith("*")&&(a[o.replace(/\*$/,"")]=n.replace(/\*$/,"")),a),{}))}return t["@/"]||(t["@/"]=E.existsSync(S.resolve(r,"src"))?"./src/":"./"),t=Object.entries(t).sort(([i],[e])=>e.length-i.length).reduce((i,[e,a])=>(i[e]=a,i),{}),t};import M from"node:fs";import ee from"node:path";var V=async r=>{let t=ee.resolve(r,"registry.json"),s={$schema:"https://ui.shadcn.com/schema/registry.json",name:"nrjdalal",homepage:"https://nrjdalal.com",items:[]};return M.existsSync(t)&&(s=y({},JSON.parse(await M.promises.readFile(t,"utf8")))),s};import C from"node:fs";import B from"node:path";import{glob as te}from"tinyglobby";var u=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 i=await te(t,{cwd:r,ignore:s.filter(e=>!t.includes(e))});if(!i.length)for(let e of t)try{let a=B.resolve(r,e),o=await C.promises.stat(a);if(o.isDirectory()){let n=(await C.promises.readdir(a)).map(c=>B.resolve(e,c));i.push(...n)}else o.isFile()&&i.push(e)}catch(a){continue}return i};var q=["registry/**",["blocks/**","components/**","helpers/**","hooks/**","lib/**","ui/**","utils/**"],["src/blocks/**","src/components/**","src/helpers/**","src/hooks/**","src/lib/**","src/ui/**","src/utils/**"]];var z=async({cwd:r,patterns:t,ignore:s})=>{let i=[];if(t.length)i=await u({cwd:r,patterns:t,ignore:s});else for(let e of q)if(i=await u({cwd:r,patterns:e,ignore:s}),i.length)break;if(!i.length)throw new Error("No files/directories found to build the registry from!");return i};import T from"node:fs";import U from"node:path";var w={imports:/import\s+type\s+[\s\S]+?from\s+['"][^'"]+['"]|import\s+['"][^'"]+['"]|import\s+[\s\S]+?from\s+['"][^'"]+['"]/g};var O=async({cwd:r,aliases:t,filepaths:s,resolved:i})=>{i=i!=null?i:new Set;let e={dependencies:[],files:[],content:{}};for(let a of s){if(i.has(a))continue;i.add(a),e.files.push(a),e.content[a]||(e.content[a]=await T.promises.readFile(U.resolve(r,a),"utf8"));let{dependencies:o,files:n,transformations:c}=await G({cwd:r,aliases:t,filepath:a,content:e.content[a]});e.content[a]=e.content[a].replace(w.imports,l=>{let m=l.match(/['"](.*)['"]/);return m&&c[m[1]]?l.replace(m[1],c[m[1]].import):l}),n.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l))}for(let a of e.files){let{dependencies:o,files:n,content:c}=await O({cwd:r,aliases:t,filepaths:[a],resolved:i});e.content[a]||(e.content[a]=c[a]||await T.promises.readFile(U.resolve(r,a),"utf8")),n.forEach(l=>e.files.push(l)),o.forEach(l=>e.dependencies.push(l))}return e.dependencies=[...new Set(e.dependencies)].sort(),e.files=[...new Set(e.files)].sort(),e};import W from"node:path";import se from"node:path";var d=({cwd:r,aliases:t,filepath:s})=>{var a;let i=s;for(let o in t)s=s.replace(t[o].replaceAll("./","").replaceAll("../",""),"");let e=s.startsWith("registry/")?s.replace(/^registry\//,"").replace(/^(?:([^\/]*)\/)?blocks\//,(o,n)=>`blocks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?components\/ui\//,(o,n)=>`${n?n+"/":""}ui/`).replace(/^(?:([^\/]*)\/)?components\//,(o,n)=>`components/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?hooks\//,(o,n)=>`hooks/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?lib\//,(o,n)=>`lib/${n?n+"/":""}`).replace(/^(?:([^\/]*)\/)?ui\//,(o,n)=>`components/ui/${n?n+"/":""}`).replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,""):s.replace(/\/default\//,"/").replace(/\.\.\//g,"").replace(/\.\//g,"");return{type:e.endsWith("page.tsx")?"registry:page":((a=e.match(/^(blocks|components\/ui|components|hooks|lib|utils|helpers)/))==null?void 0:a[1].replace("blocks","registry:block").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:e.replace(/^(blocks|components\/ui|components|hooks|lib|utils|helpers)\//,"").replace(/\.[^\/.]+$/,"").replace(/\/index$/,"").replace(/\/route$/,"").replace(/\/\[.*\]$/,""),import:"@/"+e.replace(r+se.sep,"").replace(/\.[^/.]+$/,"").replace(/\/index$/,""),target:i.split("/").length>1?e:`~/${e}`,path:s}};var re=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 i=await u({cwd:r,patterns:t});return t=i.find(e=>e.startsWith(t+"."))||i.find(e=>e.startsWith(t+"/index"))||t,t.replace(r+"/","")},ie=async({cwd:r,filepath:t,current:s})=>{s=W.relative(r,W.resolve(r,W.dirname(t),s));let i=await u({cwd:r,patterns:s});return s=i.find(e=>e.startsWith(s+"."))||i.find(e=>e.startsWith(s+"/index"))||s,s.replace(r+"/","")},G=async({cwd:r,aliases:t,filepath:s,content:i})=>{let e={dependencies:[],files:[],transformations:{}},a=i.match(w.imports)||[];if(!a.length)return e;a=a.map(o=>{var n;return(n=o.match(/['"](.*)['"]/))==null?void 0:n[1].replace(/\/\//g,"/")});for(let o of a){let n=o;Object.keys(t).some(l=>o.startsWith(l.replace(/\.\//g,"").replace(/\.\.\//g,"")))?(o=await re({cwd:r,aliases:t,current:o}),e.transformations[n]=d({cwd:r,aliases:t,filepath:o}),e.files.push(o)):o.startsWith(".")?(o=await ie({cwd:r,filepath:s,current:o}),e.transformations[n]=d({cwd:r,aliases:t,filepath:o}),e.files.push(o)):o.startsWith("@")?e.dependencies.push(o.split("/").slice(0,2).join("/")):e.dependencies.push(o.replace(/\/.*/,""))}return e};var $="smart-registry",D="0.6.0-canary.2";var v={name:"Neeraj Dalal",email:"admin@nrjdalal.com",url:"https://nrjdalal.com"};var H=`Version:
3
+ ${$}@${D}
4
4
 
5
5
  Usage:
6
- $ ${y} [options] [files/directories] ...
6
+ $ ${$} [options] [files/directories] ...
7
7
 
8
8
  Arguments:
9
9
  files/directories files or directories to build the registry from (optional)
@@ -15,8 +15,8 @@ Options:
15
15
  -h, --help display help
16
16
 
17
17
  Author:
18
- ${b.name} <${b.email}> (${b.url})`,te=r=>{try{return se(r)}catch(s){throw new Error(`Error parsing arguments: ${s.message}`)}},re=async()=>{var r,s,t,o,e;try{let{positionals:i,values:n}=te({allowPositionals:!0,options:{cwd:{type:"string",short:"c"},ignore:{type:"string",short:"i",default:""},output:{type:"string",short:"o",default:"public/r"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});i.length||(n.version&&(console.log(`${y}@${W}`),process.exit(0)),n.help&&(console.log(T),process.exit(0)));let a=m.resolve((r=n.cwd)!=null?r:process.cwd()),l=await P(a),w=await I(a),A=await M({cwd:a,patterns:i,ignore:n.ignore}),x=[],k=$(f({},w),{items:[]});for(let g of A)try{let p=await F({cwd:a,aliases:l,filepaths:[g,...((o=(t=(s=w.items)==null?void 0:s.find(c=>c.name===d(g,{aliases:l}).name))==null?void 0:t.files)==null?void 0:o.map(c=>c.path))||[]]}),u=f($(f({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:d(g,{aliases:l}).name,type:d(g,{aliases:l}).type||"registry:file"},p.dependencies.length&&{dependencies:p.dependencies}),{files:p.files.map(c=>({type:d(c,{aliases:l}).type||"registry:file",target:d(c,{aliases:l}).target||c,content:p.content[c],path:c}))}),Object.fromEntries(Object.entries(((e=w.items)==null?void 0:e.find(c=>c.name===d(g,{aliases:l}).name))||{}).filter(([c])=>!["$schema","name","type","files"].includes(c)))),v=m.resolve(a,n.output,u.name+".json");console.log(`- ${m.relative(process.cwd(),m.resolve(a,g)).padEnd(Math.max(...A.map(c=>m.relative(process.cwd(),m.resolve(a,c)).length))+2," ")} ${p.dependencies.length?"\u{1F4E6}"+String(p.dependencies.length).padEnd(2," "):" "} ${p.files.length-1?"\u{1F4C4}"+String(p.files.length).padEnd(2," "):" "} ${m.relative(process.cwd(),v)}`),await E.promises.mkdir(m.dirname(v),{recursive:!0}),await E.promises.writeFile(v,JSON.stringify(u,null,2)+`
19
- `),u.files.forEach(c=>delete c.content),k.items.push(u)}catch(p){x.push(g+": "+p.message);continue}k.items.sort((g,p)=>g.name.localeCompare(p.name)),await E.promises.writeFile(m.resolve(a,n.output,"registry.json"),JSON.stringify(k,null,2)+`
20
- `),x.length&&(console.log(),x.forEach(g=>console.error(`\x1B[31m- ${g}\x1B[0m`))),process.exit(0)}catch(i){console.error(T),console.error(`
21
- ${i.message}
22
- `),process.exit(1)}};re();
18
+ ${v.name} <${v.email}> (${v.url})`,ne=r=>{try{return oe(r)}catch(t){throw new Error(`Error parsing arguments: ${t.message}`)}},ae=async()=>{var r,t,s,i,e,a,o;try{let{positionals:n,values:c}=ne({allowPositionals:!0,options:{cwd:{type:"string",short:"c"},ignore:{type:"string",short:"i",default:""},output:{type:"string",short:"o",default:"public/r"},help:{type:"boolean",short:"h"},version:{type:"boolean",short:"v"}}});n.length||(c.version&&(console.log(`${$}@${D}`),process.exit(0)),c.help&&(console.log(H),process.exit(0)));let l=h.resolve((r=c.cwd)!=null?r:process.cwd()),m=await J(l),b=await V(l),P=await z({cwd:l,patterns:n,ignore:c.ignore}),j=[],k=F(y({},b),{items:[]});for(let g of P)try{let f=await O({cwd:l,aliases:m,filepaths:[g,...((i=(s=(t=b.items)==null?void 0:t.find(p=>p.name===d({cwd:l,aliases:m,filepath:g}).name))==null?void 0:s.files)==null?void 0:i.map(p=>p.path))||[]]}),x=y(F(y({$schema:"https://ui.shadcn.com/schema/registry-item.json",name:d({cwd:l,aliases:m,filepath:g}).name,type:d({cwd:l,aliases:m,filepath:g}).type||"registry:file"},f.dependencies.length&&{dependencies:[...new Set([...f.dependencies,...((a=(e=b.items)==null?void 0:e.find(p=>p.name===d({cwd:l,aliases:m,filepath:g}).name))==null?void 0:a.dependencies)||[]])].sort()}),{files:f.files.map(p=>({type:d({cwd:l,aliases:m,filepath:p}).type||"registry:file",target:d({cwd:l,aliases:m,filepath:p}).target||p,content:f.content[p],path:p}))}),Object.fromEntries(Object.entries(((o=b.items)==null?void 0:o.find(p=>p.name===d({cwd:l,aliases:m,filepath:g}).name))||{}).filter(([p])=>!["$schema","name","type","dependencies","files"].includes(p)))),R=h.resolve(l,c.output,x.name+".json");console.log(`- ${h.relative(process.cwd(),h.resolve(l,g)).padEnd(Math.max(...P.map(p=>h.relative(process.cwd(),h.resolve(l,p)).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," "):" "} ${h.relative(process.cwd(),R)}`),await N.promises.mkdir(h.dirname(R),{recursive:!0}),await N.promises.writeFile(R,JSON.stringify(x,null,2)+`
19
+ `),x.files.forEach(p=>delete p.content),k.items.push(x)}catch(f){j.push(g+": "+f.message);continue}k.items.sort((g,f)=>g.name.localeCompare(f.name)),await N.promises.writeFile(h.resolve(l,c.output,"registry.json"),JSON.stringify(k,null,2)+`
20
+ `),j.length&&(console.log(),j.forEach(g=>console.error(`\x1B[31m- ${g}\x1B[0m`))),process.exit(0)}catch(n){console.error(H),console.error(`
21
+ ${n.message}
22
+ `),process.exit(1)}};ae();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "smart-registry",
3
- "version": "0.6.0-canary.1",
3
+ "version": "0.6.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
  "smart-registry"
@@ -22,7 +22,6 @@
22
22
  ],
23
23
  "scripts": {
24
24
  "build": "tsup",
25
- "cli": "bash scripts/cli.sh",
26
25
  "dev": "tsup --watch",
27
26
  "prepare": "if [ \"$NODE_ENV\" != \"production\" ]; then npx simple-git-hooks; fi",
28
27
  "publish:latest": "NODE_ENV=production changeset publish",
@@ -39,7 +38,6 @@
39
38
  },
40
39
  "lint-staged": {
41
40
  "*": "prettier --write --ignore-unknown",
42
- "public/**/*": "prettier --ignore",
43
41
  "package.json": "sort-package-json"
44
42
  },
45
43
  "prettier": {
@@ -65,6 +63,5 @@
65
63
  "sort-package-json": "^2.14.0",
66
64
  "tsup": "^8.3.5",
67
65
  "typescript": "^5.7.2"
68
- },
69
- "packageManager": "pnpm@10.5.2+sha512.da9dc28cd3ff40d0592188235ab25d3202add8a207afbedc682220e4a0029ffbff4562102b9e6e46b4e3f9e8bd53e6d05de48544b0c57d4b0179e22c76d1199b"
66
+ }
70
67
  }