@mercurjs/cli 2.0.0-canary.99 → 2.0.1

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/index.js CHANGED
@@ -1,46 +1,48 @@
1
1
  #!/usr/bin/env node
2
- import {Command}from'commander';import*as R from'path';import R__default,{join,basename}from'path';import Qe from'prompts';import {z as z$1}from'zod';import Pt,{promises,existsSync,readFileSync,statSync}from'fs';import {cosmiconfig}from'cosmiconfig';import {loadConfig,createMatchPath}from'tsconfig-paths';import A from'fs-extra';import'typescript';import ot from'fast-glob';import {createHash}from'crypto';import tr from'deepmerge';import*as M from'fs/promises';import M__default,{writeFile,rm}from'fs/promises';import vo,{tmpdir,homedir}from'os';import {Project,ScriptKind}from'ts-morph';import H from'kleur';import Yi from'ora';import {execa}from'execa';import {detect}from'@antfu/ni';import {diffLines}from'diff';import {spawn,execSync}from'child_process';import {Readable}from'stream';import {pipeline}from'stream/promises';import kt from'pg';import ys from'open';import {x as x$1}from'tar';import vs from'terminal-link';import ws from'validate-npm-package-name';import js from'wait-on';import {builtinModules}from'module';import {generatePluginEntryModule}from'@mercurjs/dashboard-sdk';var $t={version:"2.0.0-canary.99"};var Dt="MISSING_DIR_OR_EMPTY_PROJECT",E="MISSING_CONFIG",z="BUILD_MISSING_REGISTRY_FILE";var ai=z$1.enum(["registry:api","registry:vendor","registry:admin"]),Ft=z$1.object({path:z$1.string(),content:z$1.string().optional(),type:ai,target:z$1.string().optional()}),Nt=z$1.object({$schema:z$1.string().optional(),name:z$1.string(),title:z$1.string().optional(),author:z$1.string().min(2).optional(),description:z$1.string().optional(),dependencies:z$1.array(z$1.string()).optional(),devDependencies:z$1.array(z$1.string()).optional(),registryDependencies:z$1.array(z$1.string()).optional(),meta:z$1.record(z$1.string(),z$1.any()).optional(),docs:z$1.string().optional(),categories:z$1.array(z$1.string()).optional()}),T=Nt.extend({files:z$1.array(Ft)}),Y=z$1.object({name:z$1.string(),homepage:z$1.string(),items:z$1.array(T)}),tn=z$1.array(Nt),Ot=T.pick({dependencies:true,devDependencies:true,files:true,docs:true}),di=z$1.union([z$1.string(),z$1.object({url:z$1.string(),params:z$1.record(z$1.string(),z$1.string()).optional(),headers:z$1.record(z$1.string(),z$1.string()).optional()})]),At=z$1.record(z$1.string().refine(e=>e.startsWith("@"),{message:"Registry names must start with @ (e.g., @mercurjs)"}),di);var $e="https://registry.mercurjs.com/registry.json",Mt="https://registry.mercurjs.com/registry-item.json",ge=process.env.REGISTRY_URL??"https://raw.githubusercontent.com/mercurjs/mercur/new/packages/registry/r",I={"@mercurjs":`${ge}/{name}.json`};var $={NOT_FOUND:"NOT_FOUND",UNAUTHORIZED:"UNAUTHORIZED",FORBIDDEN:"FORBIDDEN",FETCH_ERROR:"FETCH_ERROR",NOT_CONFIGURED:"NOT_CONFIGURED",INVALID_CONFIG:"INVALID_CONFIG",MISSING_ENV_VARS:"MISSING_ENV_VARS",LOCAL_FILE_ERROR:"LOCAL_FILE_ERROR",PARSE_ERROR:"PARSE_ERROR",VALIDATION_ERROR:"VALIDATION_ERROR",UNKNOWN_ERROR:"UNKNOWN_ERROR"},k=class extends Error{code;statusCode;context;suggestion;timestamp;cause;constructor(t,r={}){super(t),this.name="RegistryError",this.code=r.code||$.UNKNOWN_ERROR,this.statusCode=r.statusCode,this.cause=r.cause,this.context=r.context,this.suggestion=r.suggestion,this.timestamp=new Date,Error.captureStackTrace&&Error.captureStackTrace(this,this.constructor);}},oe=class extends k{constructor(r,i){let o=`The item at ${r} was not found. It may not exist at the registry.`;super(o,{code:$.NOT_FOUND,statusCode:404,cause:i,context:{url:r},suggestion:"Check if the item name is correct and the registry URL is accessible."});this.url=r;this.name="RegistryNotFoundError";}},De=class extends k{constructor(r,i){let o=`You are not authorized to access the item at ${r}. If this is a remote registry, you may need to authenticate.`;super(o,{code:$.UNAUTHORIZED,statusCode:401,cause:i,context:{url:r},suggestion:"Check your authentication credentials and environment variables."});this.url=r;this.name="RegistryUnauthorizedError";}},Fe=class extends k{constructor(r,i){let o=`You are not authorized to access the item at ${r}. If this is a remote registry, you may need to authenticate.`;super(o,{code:$.FORBIDDEN,statusCode:403,cause:i,context:{url:r},suggestion:"Check your authentication credentials and environment variables."});this.url=r;this.name="RegistryForbiddenError";}},Ne=class extends k{constructor(r,i,o,s){let n=i?`Failed to fetch from registry (${i}): ${r}`:`Failed to fetch from registry: ${r}`,m=typeof s=="string"&&s?`${n} - ${s}`:n,p="Check your network connection and try again.";i===404?p="The requested resource was not found. Check the URL or item name.":i===500?p="The registry server encountered an error. Try again later.":i&&i>=400&&i<500&&(p="There was a client error. Check your request parameters.");super(m,{code:$.FETCH_ERROR,statusCode:i,cause:s,context:{url:r,responseBody:o},suggestion:p});this.url=r;this.responseBody=o;this.name="RegistryFetchError";}},J=class extends k{constructor(r){let i=r?`Unknown registry "${r}". Make sure it is defined in agents.json as follows:
2
+ import {Command}from'commander';import*as R from'path';import R__default,{join,basename}from'path';import Pe from'prompts';import {z}from'zod';import Ot,{promises,existsSync,readFileSync,mkdirSync,writeFileSync,statSync}from'fs';import {cosmiconfig}from'cosmiconfig';import {loadConfig,createMatchPath}from'tsconfig-paths';import L from'fs-extra';import'typescript';import st from'fast-glob';import {createHash}from'crypto';import ar from'deepmerge';import*as U from'fs/promises';import U__default,{writeFile,rm}from'fs/promises';import {homedir,tmpdir}from'os';import {Project,ScriptKind}from'ts-morph';import S from'kleur';import to from'ora';import {execa}from'execa';import {detect}from'@antfu/ni';import {diffLines}from'diff';import {spawn,execSync}from'child_process';import {Readable}from'stream';import {pipeline}from'stream/promises';import It from'pg';import Es from'open';import {x as x$1}from'tar';import Is from'terminal-link';import Cs from'validate-npm-package-name';import Ps from'wait-on';import {builtinModules}from'module';import {generatePluginEntryModule}from'@mercurjs/dashboard-sdk';var Lt={version:"2.0.1"};var Mt="MISSING_DIR_OR_EMPTY_PROJECT",I="MISSING_CONFIG",B="BUILD_MISSING_REGISTRY_FILE";var fi=z.enum(["registry:api","registry:vendor","registry:admin"]),Ut=z.object({path:z.string(),content:z.string().optional(),type:fi,target:z.string().optional()}),zt=z.object({$schema:z.string().optional(),name:z.string(),title:z.string().optional(),author:z.string().min(2).optional(),description:z.string().optional(),dependencies:z.array(z.string()).optional(),devDependencies:z.array(z.string()).optional(),registryDependencies:z.array(z.string()).optional(),meta:z.record(z.string(),z.any()).optional(),docs:z.string().optional(),categories:z.array(z.string()).optional()}),$=zt.extend({files:z.array(Ut)}),K=z.object({name:z.string(),homepage:z.string(),items:z.array($)}),ln=z.array(zt),Bt=$.pick({dependencies:true,devDependencies:true,files:true,docs:true}),gi=z.union([z.string(),z.object({url:z.string(),params:z.record(z.string(),z.string()).optional(),headers:z.record(z.string(),z.string()).optional()})]),Wt=z.record(z.string().refine(e=>e.startsWith("@"),{message:"Registry names must start with @ (e.g., @mercurjs)"}),gi);var Fe="https://registry.mercurjs.com/registry.json",Gt="https://registry.mercurjs.com/registry-item.json",he=process.env.REGISTRY_URL??"https://raw.githubusercontent.com/mercurjs/mercur/canary/packages/registry/r",C={"@mercurjs":`${he}/{name}.json`};var D={NOT_FOUND:"NOT_FOUND",UNAUTHORIZED:"UNAUTHORIZED",FORBIDDEN:"FORBIDDEN",FETCH_ERROR:"FETCH_ERROR",NOT_CONFIGURED:"NOT_CONFIGURED",INVALID_CONFIG:"INVALID_CONFIG",MISSING_ENV_VARS:"MISSING_ENV_VARS",LOCAL_FILE_ERROR:"LOCAL_FILE_ERROR",PARSE_ERROR:"PARSE_ERROR",VALIDATION_ERROR:"VALIDATION_ERROR",UNKNOWN_ERROR:"UNKNOWN_ERROR"},k=class extends Error{code;statusCode;context;suggestion;timestamp;cause;constructor(t,r={}){super(t),this.name="RegistryError",this.code=r.code||D.UNKNOWN_ERROR,this.statusCode=r.statusCode,this.cause=r.cause,this.context=r.context,this.suggestion=r.suggestion,this.timestamp=new Date,Error.captureStackTrace&&Error.captureStackTrace(this,this.constructor);}},ae=class extends k{constructor(r,i){let o=`The item at ${r} was not found. It may not exist at the registry.`;super(o,{code:D.NOT_FOUND,statusCode:404,cause:i,context:{url:r},suggestion:"Check if the item name is correct and the registry URL is accessible."});this.url=r;this.name="RegistryNotFoundError";}},Oe=class extends k{constructor(r,i){let o=`You are not authorized to access the item at ${r}. If this is a remote registry, you may need to authenticate.`;super(o,{code:D.UNAUTHORIZED,statusCode:401,cause:i,context:{url:r},suggestion:"Check your authentication credentials and environment variables."});this.url=r;this.name="RegistryUnauthorizedError";}},Ae=class extends k{constructor(r,i){let o=`You are not authorized to access the item at ${r}. If this is a remote registry, you may need to authenticate.`;super(o,{code:D.FORBIDDEN,statusCode:403,cause:i,context:{url:r},suggestion:"Check your authentication credentials and environment variables."});this.url=r;this.name="RegistryForbiddenError";}},Le=class extends k{constructor(r,i,o,s){let n=i?`Failed to fetch from registry (${i}): ${r}`:`Failed to fetch from registry: ${r}`,m=typeof s=="string"&&s?`${n} - ${s}`:n,p="Check your network connection and try again.";i===404?p="The requested resource was not found. Check the URL or item name.":i===500?p="The registry server encountered an error. Try again later.":i&&i>=400&&i<500&&(p="There was a client error. Check your request parameters.");super(m,{code:D.FETCH_ERROR,statusCode:i,cause:s,context:{url:r,responseBody:o},suggestion:p});this.url=r;this.responseBody=o;this.name="RegistryFetchError";}},Z=class extends k{constructor(r){let i=r?`Unknown registry "${r}". Make sure it is defined in agents.json as follows:
3
3
  {
4
4
  "registries": {
5
5
  "${r}": "[URL_TO_REGISTRY]"
6
6
  }
7
- }`:'Unknown registry. Make sure it is defined in blocks.json under "registries".';super(i,{code:$.NOT_CONFIGURED,context:{registryName:r},suggestion:"Add the registry configuration to your blocks.json file. Consult the registry documentation for the correct format."});this.registryName=r;this.name="RegistryNotConfiguredError";}},K=class extends k{constructor(r,i){super(`Failed to read local registry file: ${r}`,{code:$.LOCAL_FILE_ERROR,cause:i,context:{filePath:r},suggestion:"Check if the file exists and you have read permissions."});this.filePath=r;this.name="RegistryLocalFileError";}},C=class extends k{constructor(r,i){let o=`Failed to parse registry item: ${r}`;i instanceof z$1.ZodError&&(o=`Failed to parse registry item: ${r}
7
+ }`:'Unknown registry. Make sure it is defined in blocks.json under "registries".';super(i,{code:D.NOT_CONFIGURED,context:{registryName:r},suggestion:"Add the registry configuration to your blocks.json file. Consult the registry documentation for the correct format."});this.registryName=r;this.name="RegistryNotConfiguredError";}},Q=class extends k{constructor(r,i){super(`Failed to read local registry file: ${r}`,{code:D.LOCAL_FILE_ERROR,cause:i,context:{filePath:r},suggestion:"Check if the file exists and you have read permissions."});this.filePath=r;this.name="RegistryLocalFileError";}},P=class extends k{constructor(r,i){let o=`Failed to parse registry item: ${r}`;i instanceof z.ZodError&&(o=`Failed to parse registry item: ${r}
8
8
  ${i.issues.map(s=>` - ${s.path.join(".")}: ${s.message}`).join(`
9
- `)}`);super(o,{code:$.PARSE_ERROR,cause:i,context:{item:r},suggestion:"The registry item may be corrupted or have an invalid format. Please make sure it returns a valid JSON object."});this.item=r;this.parseError=i,this.name="RegistryParseError";}parseError},Oe=class extends k{constructor(r,i){let o=`Registry "${r}" requires the following environment variables:
9
+ `)}`);super(o,{code:D.PARSE_ERROR,cause:i,context:{item:r},suggestion:"The registry item may be corrupted or have an invalid format. Please make sure it returns a valid JSON object."});this.item=r;this.parseError=i,this.name="RegistryParseError";}parseError},Me=class extends k{constructor(r,i){let o=`Registry "${r}" requires the following environment variables:
10
10
 
11
11
  `+i.map(s=>` \u2022 ${s}`).join(`
12
- `);super(o,{code:$.MISSING_ENV_VARS,context:{registryName:r,missingVars:i},suggestion:"Set the required environment variables to your .env or .env.local file."});this.registryName=r;this.missingVars=i;this.name="RegistryMissingEnvironmentVariablesError";}},Ae=class extends k{constructor(r){let i=`Invalid registry namespace: "${r}". Registry names must start with @ (e.g., @mercurjs).`;super(i,{code:$.VALIDATION_ERROR,context:{name:r},suggestion:"Use a valid registry name starting with @ or provide a direct URL to the registry."});this.name=r;this.name="RegistryInvalidNamespaceError";}};var Me=class extends k{constructor(r,i){let o=`Invalid blocks.json configuration in ${r}.`;i instanceof z$1.ZodError&&(o=`Invalid blocks.json configuration in ${r}:
12
+ `);super(o,{code:D.MISSING_ENV_VARS,context:{registryName:r,missingVars:i},suggestion:"Set the required environment variables to your .env or .env.local file."});this.registryName=r;this.missingVars=i;this.name="RegistryMissingEnvironmentVariablesError";}},Ue=class extends k{constructor(r){let i=`Invalid registry namespace: "${r}". Registry names must start with @ (e.g., @mercurjs).`;super(i,{code:D.VALIDATION_ERROR,context:{name:r},suggestion:"Use a valid registry name starting with @ or provide a direct URL to the registry."});this.name=r;this.name="RegistryInvalidNamespaceError";}};var ze=class extends k{constructor(r,i){let o=`Invalid blocks.json configuration in ${r}.`;i instanceof z.ZodError&&(o=`Invalid blocks.json configuration in ${r}:
13
13
  ${i.issues.map(s=>` - ${s.path.join(".")}: ${s.message}`).join(`
14
- `)}`);super(o,{code:$.INVALID_CONFIG,cause:i,context:{cwd:r},suggestion:"Check your blocks.json file for syntax errors or invalid configuration. Run '@mercurjs/cli init' to regenerate a valid configuration."});this.cwd=r;this.name="ConfigParseError";}};var U=z$1.object({$schema:z$1.string().optional(),aliases:z$1.object({api:z$1.string(),vendor:z$1.string(),admin:z$1.string()}),registries:At.optional()}).strict(),zt=U.extend({resolvedPaths:z$1.object({cwd:z$1.string(),api:z$1.string(),vendor:z$1.string(),admin:z$1.string()})});async function se(e,t){return createMatchPath(t.absoluteBaseUrl,t.paths)(e,void 0,()=>true,[".ts",".tsx"])}var ui="packages/api/src",li="apps/vendor/src",fi="apps/admin/src",gi=cosmiconfig("blocks",{searchPlaces:["blocks.json"]});async function b(e){let t=await yi(e);return t?await it(e,t):null}async function it(e,t){t.registries={...t.registries||{},...I};let r=await loadConfig(e);if(r.resultType==="failed")throw new Error(`Failed to load tsconfig.json. ${r.message??""}`.trim());return zt.parse({...t,resolvedPaths:{cwd:e,api:await se(t.aliases.api,r),vendor:await se(t.aliases.vendor,r),admin:await se(t.aliases.admin,r)}})}async function yi(e){try{let t=await gi.search(e);if(!t)return null;let r=U.parse(t.config);if(r.registries){for(let i of Object.keys(r.registries))if(i in I)throw new Error(`"${i}" is a built-in registry and cannot be overridden.`)}return r}catch(t){throw t instanceof Error&&t.message.includes("reserved registry")?t:new Me(e,t)}}function B(e){let t={resolvedPaths:{cwd:process.cwd(),api:"",vendor:"",admin:""},aliases:{api:ui,vendor:li,admin:fi},registries:{...I}};return e?{...t,...e,resolvedPaths:{...t.resolvedPaths,...e.resolvedPaths||{}},aliases:{...t.aliases,...e.aliases||{}},registries:{...t.registries,...e.registries||{}}}:t}var st=["**/node_modules/**","public","dist"];async function _(e){let[t,r,i,o,s,n]=await Promise.all([A.pathExists(R__default.resolve(e,"src")),vi(e),ye(e),wi(e),ji(e),bi(e)]);return {isSrcDir:t,aliasPrefix:r,packageJson:i,medusaConfigFile:o?.file??null,medusaVersion:s,mercurVersion:n}}async function vi(e){let t=loadConfig(e);if(t.resultType==="failed")return null;let r=t.paths||{},i=Object.keys(r);if(i.length===0)return null;let o=i[0];return o?.includes("*")?o.replace("/*",""):o?.replace("/","")??null}function ye(e="",t=true){let r=R__default.join(e,"package.json");return A.readJSONSync(r,{throws:t})}async function wi(e){let t=await ot.glob("medusa-config.*",{cwd:e,deep:3,ignore:st});if(!t.length)return null;let r=t[0];return {file:r,dir:R__default.resolve(e,R__default.dirname(r))}}async function ji(e){let r=ye(e,false)?.dependencies?.["@medusajs/framework"];if(r)return r;let i=await ot.glob("**/package.json",{cwd:e,deep:3,ignore:st});for(let o of i){let n=ye(R__default.join(e,R__default.dirname(o)),false)?.dependencies?.["@medusajs/framework"];if(n)return n}return null}async function bi(e){let r=ye(e,false)?.dependencies?.["@mercurjs/cli"];if(r)return r;let i=await ot.glob("**/package.json",{cwd:e,deep:3,ignore:st});for(let o of i){let n=ye(R__default.join(e,R__default.dirname(o)),false)?.dependencies?.["@mercurjs/cli"];if(n)return n}return null}z$1.object({cwd:z$1.string(),blocks:z$1.array(z$1.string()).optional(),yes:z$1.boolean(),overwrite:z$1.boolean(),silent:z$1.boolean()});async function Bt(e){let t={},r=R__default.resolve(e.cwd);if(!existsSync(r))return t[Dt]=true,{errors:t,config:null};let i=await b(r);if(!i)return t[E]=true,{errors:t,config:null};let o=await _(r);return {errors:t,config:i,projectInfo:o}}var Le={headers:{}};function nt(e){Le.headers={...Le.headers,...e};}function Wt(e){return Le.headers[e]||{}}function x(){Le.headers={};}function ne(e){let t={aliases:{api:"packages/api/src",vendor:"apps/vendor/src",admin:"apps/admin/src"},registries:I};return {...t,...e||{},aliases:{...t.aliases,...e?.aliases||{}},registries:{...e?.registries||{},...I}}}function he(e){return e.replace(/\${(\w+)}/g,(t,r)=>process.env[r]||"")}function ve(e){let t=[],r=/\${(\w+)}/g,i=r.exec(e);for(;i!==null;){let o=i[1];o&&t.push(o),i=r.exec(e);}return t}var ki=/^(@[a-zA-Z0-9](?:[a-zA-Z0-9-_]*[a-zA-Z0-9])?)\/(.+)$/;function ae(e){if(!e.startsWith("@"))return {registry:null,item:e};let t=e.match(ki);return t?{registry:t[1],item:t[2]}:{registry:null,item:e}}var Gt=[".tsx",".ts"],Vt=["lib/utils.ts"],Ci=[/^(react|react-dom)(\/.*)?$/,/^(node|jsr|npm):.*$/],Pi=new Project({compilerOptions:{}});function Ti(e){if(Ci.some(t=>t.test(e)))return null;if(!e.startsWith("@")&&e.includes("/")&&(e=e.split("/")[0]),e.startsWith("@")){let t=e.split("/");t.length>2&&(e=t.slice(0,2).join("/"));}return e}async function at(e,t,r,i=new Set){let o=R.resolve(t.resolvedPaths.cwd,e),s=R.relative(t.resolvedPaths.cwd,o);if(Vt.includes(s))return {dependencies:[],files:[]};let n=R.extname(e);if(!Gt.includes(n))return {dependencies:[],files:[]};if(i.has(s))return {dependencies:[],files:[]};i.add(s);try{if(!(await M.stat(o)).isFile())return {dependencies:[],files:[]}}catch{return {dependencies:[],files:[]}}let m=await M.readFile(o,"utf-8"),p=await $i(R.basename(o)),a=Pi.createSourceFile(p,m,{scriptKind:ScriptKind.TSX}),c=await loadConfig(t.resolvedPaths.cwd);if(c.resultType==="failed")return {dependencies:[],files:[]};let u=[],f=new Set,y=qt(e),v={path:s,type:y,target:"",content:""};u.push(v);let j=a.getImportDeclarations();for(let F of j){let L=F.getModuleSpecifierValue(),Ce=L.startsWith(".");if(!(r.aliasPrefix&&L.startsWith(`${r.aliasPrefix}/`))&&!Ce){let N=Ti(L);N&&f.add(N);continue}let re=await se(L,c);if(Ce&&(re=R.resolve(R.dirname(o),L)),!re)continue;if(!R.extname(re))for(let N of Gt){let Tt=`${re}${N}`;try{await M.access(Tt),re=Tt;break}catch{continue}}let Pe=R.relative(t.resolvedPaths.cwd,re);if(i.has(Pe)||Vt.includes(Pe))continue;let oi=qt(L),si={path:Pe,type:oi,target:"",content:""};u.push(si);let Te=await at(Pe,t,r,i);if(Te.files)for(let N of Te.files)i.has(N.path)||(i.add(N.path),u.push(N));Te.dependencies&&Te.dependencies.forEach(N=>f.add(N));}let S=Array.from(new Map(u.map(F=>[F.path,F])).values());return {dependencies:Array.from(f),files:S}}async function $i(e){let t=await M.mkdtemp(R.join(tmpdir(),"mercur-"));return R.join(t,e)}function qt(e){return e.includes("/vendor")?"registry:vendor":e.includes("/admin")?"registry:admin":"registry:api"}function V(e){try{return new URL(e),!0}catch{return false}}function Q(e){return e.endsWith(".json")&&!V(e)}function Di(e){let t=new Set;if(typeof e=="string")for(let r of ve(e))t.add(r);else {for(let r of ve(e.url))t.add(r);if(e.params)for(let r of Object.values(e.params))for(let i of ve(r))t.add(i);if(e.headers)for(let r of Object.values(e.headers))for(let i of ve(r))t.add(i);}return Array.from(t)}function Ht(e,t){let i=Di(t).filter(o=>!process.env[o]);if(i.length>0)throw new Oe(e,i)}var ze="{name}",Fi=`${ze}.json`,Yt=/\${(\w+)}/g,Jt="?",Ni="&";function Oi(e){return e.includes(ze)}function Kt(e){return Oi(e)?e:`${e.endsWith("/")?e:`${e}/`}${Fi}`}function we(e,t){let{registry:r,item:i}=ae(e);if(!r)return null;let s=(t?.registries||{})[r];if(!s)throw new J(r);return Ht(r,s),{url:Ai(i,s),headers:Mi(s)}}function Ai(e,t,r){if(typeof t=="string"){let n=Kt(t).replace(ze,e);return he(n)}let o=Kt(t.url).replace(ze,e);return o=he(o),t.params?Li(o,t.params):o}function Mi(e){if(typeof e=="string"||!e.headers)return {};let t={};for(let[r,i]of Object.entries(e.headers)){let o=he(i);zi(i,o)&&(t[r]=o);}return t}function Li(e,t){let r=new URLSearchParams;for(let[s,n]of Object.entries(t)){let m=he(n);m&&r.append(s,m);}let i=r.toString();if(!i)return e;let o=e.includes(Jt)?Ni:Jt;return `${e}${o}${i}`}function zi(e,t){let r=t.trim();if(!r)return false;if(e.includes("${")&&e.match(Yt)){let o=e.replace(Yt,"").trim();return r!==o}return true}function Zt(e){return V(e)||Q(e)?e:`${ge}/${e}`}var Ue=new Map;async function Ui(e){let t=e;t.startsWith("file://")&&(t=t.slice(7)),t.startsWith("~/")&&(t=R__default.join(homedir(),t.slice(2)));let r=R__default.resolve(t);try{let i=await promises.readFile(r,"utf8");return JSON.parse(i)}catch(i){throw i instanceof Error&&(i.message.includes("ENOENT")||i.message.includes("no such file"))?new K(e,i):new K(e,i)}}async function X(e){return await Promise.all(e.map(async r=>{let i=Zt(r);if(Ue.has(i))return Ue.get(i);if(Q(i)){let s=Ui(i);return Ue.set(i,s),s}let o=(async()=>{let s=Wt(i),n=await fetch(i,{headers:{...s}});if(!n.ok){let m;if(n.headers.get("content-type")?.includes("application/json")){let p=await n.json(),a=z$1.object({detail:z$1.string().optional(),title:z$1.string().optional(),message:z$1.string().optional(),error:z$1.string().optional()}).safeParse(p);a.success&&(m=a.data.detail||a.data.message,a.data.error&&(m=`[${a.data.error}] ${m}`));}throw n.status===401?new De(i,m):n.status===404?new oe(i,m):n.status===403?new Fe(i,m):new Ne(i,n.status,m)}return n.json()})();return Ue.set(i,o),o}))}async function er(e){try{let t=e;e.startsWith("~/")&&(t=R__default.join(homedir(),e.slice(2)));let r=R__default.resolve(t),i=await promises.readFile(r,"utf8"),o=JSON.parse(i);try{return T.parse(o)}catch(s){throw new C(e,s)}}catch(t){throw t instanceof Error&&(t.message.includes("ENOENT")||t.message.includes("no such file"))?new K(e,t):t instanceof C?t:new K(e,t)}}T.extend({_source:z$1.string().optional()});function dt(e,t){let r={},i=[...e];if(!t?.registries)return nt({}),i;for(let o=0;o<i.length;o++){let s=we(i[o],t);s&&(i[o]=s.url,Object.keys(s.headers).length>0&&(r[s.url]=s.headers));}return nt(r),i}async function We(e,t){return await Promise.all(e.map(async i=>{if(Q(i))return er(i);if(V(i)){let[n]=await X([i]);try{return T.parse(n)}catch(m){throw new C(i,m)}}if(i.startsWith("@")&&t?.registries){let n=dt([i],t),[m]=await X(n);try{return T.parse(m)}catch(p){throw new C(i,p)}}let o=`${ge}/${i}.json`,[s]=await X([o]);try{return T.parse(s)}catch(n){throw new C(i,n)}}))}async function pt(e,t){let r=[],i=[],o=Array.from(new Set(e)),s=await We(o,t),n=new Map;for(let a=0;a<s.length;a++)s[a]&&n.set(o[a],s[a]);for(let[a,c]of Array.from(n.entries())){let u={...c,_source:a};if(r.push(u),c.registryDependencies){let f=c.registryDependencies;if(t?.registries)f=dt(c.registryDependencies,t);else {let v=c.registryDependencies.filter(j=>j.startsWith("@"));if(v.length>0){let{registry:j}=ae(v[0]);throw new J(j)}}let{blocks:y}=await ir(f,t,new Set(o));i.push(...y);}}r.push(...i);let m=new Map;for(let a of r){let c=a._source||a.name;m.set(a,c);}return r=Vi(r,m),Ot.parse({dependencies:tr.all(r.map(a=>a.dependencies??[])),devDependencies:tr.all(r.map(a=>a.devDependencies??[])),files:qi(r.map(a=>a.files??[])),docs:r.map(a=>a.docs).filter(Boolean).join(`
15
- `)})}async function ir(e,t,r=new Set){let i=[];for(let o of e){if(r.has(o))continue;if(r.add(o),o.startsWith("@")&&t?.registries){let{registry:n}=ae(o);if(n&&!(n in t.registries))throw new J(n)}let[s]=await We([o],t);if(s&&(i.push({...s,_source:o}),s.registryDependencies)){let n=t?.registries?dt(s.registryDependencies,t):s.registryDependencies,m=await ir(n,t,r);i.push(...m.blocks);}}return {blocks:i}}function q(e,t){let r=t||e.name,i=createHash("sha256").update(r).digest("hex").substring(0,8);return `${e.name}::${i}`}function Gi(e){if(V(e)){let i=new URL(e).pathname,o=i.match(/\/([^/]+)\.json$/),s=o?o[1]:R__default.basename(i,".json");return {name:s,hash:q({name:s},e)}}if(Q(e)){let r=e.match(/\/([^/]+)\.json$/),i=r?r[1]:R__default.basename(e,".json");return {name:i,hash:q({name:i},e)}}let{item:t}=ae(e);return {name:t,hash:q({name:t},e)}}function Vi(e,t){let r=new Map,i=new Map,o=new Map,s=new Map;for(let a of e){let c=t.get(a)||a.name,u=q(a,c);r.set(u,a),i.set(u,a),o.set(u,0),s.set(u,[]);}let n=new Map;for(let a of e){let c=t.get(a)||a.name,u=q(a,c);n.has(a.name)||n.set(a.name,[]),n.get(a.name).push(u),c!==a.name&&(n.has(c)||n.set(c,[]),n.get(c).push(u));}for(let a of e){let c=t.get(a)||a.name,u=q(a,c);if(a.registryDependencies)for(let f of a.registryDependencies){let y,v=n.get(f)||[];if(v.length===1)y=v[0];else if(v.length>1)y=v[0];else {let{name:j}=Gi(f),S=n.get(j)||[];S.length>0&&(y=S[0]);}y&&r.has(y)&&(s.get(y).push(u),o.set(u,o.get(u)+1));}}let m=[],p=[];for(let[a,c]of o)c===0&&m.push(a);for(;m.length>0;){let a=m.shift(),c=r.get(a);p.push(c);for(let u of s.get(a)){let f=o.get(u)-1;o.set(u,f),f===0&&m.push(u);}}if(p.length!==e.length){let a=Array.from(r.keys()).filter(c=>!p.some(u=>q(u,t.get(u))===c));console.warn(`Warning: Circular dependencies detected. Some items may not be sorted correctly: ${a.join(", ")}`);for(let[c,u]of r.entries())p.some(f=>q(f,t.get(f))===c)||p.push(u);}return p}function qi(e){let t=new Map,r=[];for(let i of e)if(i)for(let o of i){let s=o.target||o.path;t.has(s)||(t.set(s,o),r.push(o));}return r}var l={error:e=>H.red(e),warn:e=>H.yellow(e),info:e=>H.blue(e),success:e=>H.green(e),dim:e=>H.cyan(e)};var d={error(...e){console.log(l.error(e.join(" ")));},warn(...e){console.log(l.warn(e.join(" ")));},info(...e){console.log(l.info(e.join(" ")));},success(...e){console.log(l.success(e.join(" ")));},log(...e){console.log(e.join(" "));},break(){console.log("");}};function w(e){if(d.break(),d.error("Something went wrong. Please check the error below for more details."),d.error("If the problem persists, please open an issue on GitHub."),d.error(""),typeof e=="string"&&(d.error(e),d.break(),process.exit(1)),e instanceof k&&(e.message&&(d.error(e.cause?"Error:":"Message:"),d.error(e.message)),e.cause&&(d.error(`
16
- Message:`),d.error(e.cause)),e.suggestion&&(d.error(`
17
- Suggestion:`),d.error(e.suggestion)),d.break(),process.exit(1)),e instanceof z$1.ZodError){d.error("Validation failed:");for(let t of e.issues){let r=t.path.join(".")||"root";d.error(`- ${l.info(r)}: ${t.message}`);}d.break(),process.exit(1);}e instanceof Error&&(d.error(e.message),d.break(),process.exit(1)),d.break(),process.exit(1);}function h(e,t){return Yi({text:e,isSilent:t?.silent??false})}async function O(e){let t=await detect({programmatic:true,cwd:e});if(t?.startsWith("bun"))return "bun";if(t?.startsWith("yarn"))return "yarn";if(t?.startsWith("pnpm"))return "pnpm";if(t?.startsWith("deno"))return "deno";if(t?.startsWith("npm"))return "npm";let r=process.env.npm_config_user_agent||"";return r.startsWith("bun")?"bun":r.startsWith("yarn")?"yarn":r.startsWith("pnpm")?"pnpm":r.startsWith("deno")?"deno":"npm"}async function or(e,t,r,i={}){if(e=Array.from(new Set(e||[])),t=Array.from(new Set(t||[])),!e?.length&&!t?.length)return;i={silent:false,...i};let o=h("Installing dependencies.",{silent:i.silent})?.start(),s=await O(r.resolvedPaths.cwd);o?.start(),await Ki(s,e,t,r.resolvedPaths.cwd),o?.succeed();}async function Ki(e,t,r,i){if(e==="npm")return Zi(t,r,i);if(e==="deno")return Qi(t,r,i);t?.length&&await execa(e,["add",...t],{cwd:i}),r?.length&&await execa(e,["add","-D",...r],{cwd:i});}async function Zi(e,t,r){e.length&&await execa("npm",["install",...e],{cwd:r}),t.length&&await execa("npm",["install","-D",...t],{cwd:r});}async function Qi(e,t,r){e?.length&&await execa("deno",["add",...e.map(i=>`npm:${i}`)],{cwd:r}),t?.length&&await execa("deno",["add","-D",...t.map(i=>`npm:${i}`)],{cwd:r});}function sr(e,t,r={}){let{ignoreImports:i=false}=r,o=e.replace(/\r\n/g,`
14
+ `)}`);super(o,{code:D.INVALID_CONFIG,cause:i,context:{cwd:r},suggestion:"Check your blocks.json file for syntax errors or invalid configuration. Run '@mercurjs/cli init' to regenerate a valid configuration."});this.cwd=r;this.name="ConfigParseError";}};var W=z.object({$schema:z.string().optional(),aliases:z.object({api:z.string(),vendor:z.string(),admin:z.string()}),registries:Wt.optional()}).strict(),Yt=W.extend({resolvedPaths:z.object({cwd:z.string(),api:z.string(),vendor:z.string(),admin:z.string()})});async function de(e,t){return createMatchPath(t.absoluteBaseUrl,t.paths)(e,void 0,()=>true,[".ts",".tsx"])}var wi="packages/api/src",ji="apps/vendor/src",bi="apps/admin/src",Ri=cosmiconfig("blocks",{searchPlaces:["blocks.json"]});async function b(e){let t=await xi(e);return t?await ot(e,t):null}async function ot(e,t){t.registries={...t.registries||{},...C};let r=await loadConfig(e);if(r.resultType==="failed")throw new Error(`Failed to load tsconfig.json. ${r.message??""}`.trim());return Yt.parse({...t,resolvedPaths:{cwd:e,api:await de(t.aliases.api,r),vendor:await de(t.aliases.vendor,r),admin:await de(t.aliases.admin,r)}})}async function xi(e){try{let t=await Ri.search(e);if(!t)return null;let r=W.parse(t.config);if(r.registries){for(let i of Object.keys(r.registries))if(i in C)throw new Error(`"${i}" is a built-in registry and cannot be overridden.`)}return r}catch(t){throw t instanceof Error&&t.message.includes("reserved registry")?t:new ze(e,t)}}function G(e){let t={resolvedPaths:{cwd:process.cwd(),api:"",vendor:"",admin:""},aliases:{api:wi,vendor:ji,admin:bi},registries:{...C}};return e?{...t,...e,resolvedPaths:{...t.resolvedPaths,...e.resolvedPaths||{}},aliases:{...t.aliases,...e.aliases||{}},registries:{...t.registries,...e.registries||{}}}:t}var nt=["**/node_modules/**","public","dist"];async function E(e){let[t,r,i,o,s,n]=await Promise.all([L.pathExists(R__default.resolve(e,"src")),ki(e),ve(e),Ei(e),Si(e),Ii(e)]);return {isSrcDir:t,aliasPrefix:r,packageJson:i,medusaConfigFile:o?.file??null,medusaVersion:s,mercurVersion:n}}async function ki(e){let t=loadConfig(e);if(t.resultType==="failed")return null;let r=t.paths||{},i=Object.keys(r);if(i.length===0)return null;let o=i[0];return o?.includes("*")?o.replace("/*",""):o?.replace("/","")??null}function ve(e="",t=true){let r=R__default.join(e,"package.json");return L.readJSONSync(r,{throws:t})}async function Ei(e){let t=await st.glob("medusa-config.*",{cwd:e,deep:3,ignore:nt});if(!t.length)return null;let r=t[0];return {file:r,dir:R__default.resolve(e,R__default.dirname(r))}}async function Si(e){let r=ve(e,false)?.dependencies?.["@medusajs/framework"];if(r)return r;let i=await st.glob("**/package.json",{cwd:e,deep:3,ignore:nt});for(let o of i){let n=ve(R__default.join(e,R__default.dirname(o)),false)?.dependencies?.["@medusajs/framework"];if(n)return n}return null}async function Ii(e){let r=ve(e,false)?.dependencies?.["@mercurjs/cli"];if(r)return r;let i=await st.glob("**/package.json",{cwd:e,deep:3,ignore:nt});for(let o of i){let n=ve(R__default.join(e,R__default.dirname(o)),false)?.dependencies?.["@mercurjs/cli"];if(n)return n}return null}z.object({cwd:z.string(),blocks:z.array(z.string()).optional(),yes:z.boolean(),overwrite:z.boolean(),silent:z.boolean()});async function Jt(e){let t={},r=R__default.resolve(e.cwd);if(!existsSync(r))return t[Mt]=true,{errors:t,config:null};let i=await b(r);if(!i)return t[I]=true,{errors:t,config:null};let o=await E(r);return {errors:t,config:i,projectInfo:o}}var Be={headers:{}};function at(e){Be.headers={...Be.headers,...e};}function Ht(e){return Be.headers[e]||{}}function x(){Be.headers={};}function me(e){let t={aliases:{api:"packages/api/src",vendor:"apps/vendor/src",admin:"apps/admin/src"},registries:C};return {...t,...e||{},aliases:{...t.aliases,...e?.aliases||{}},registries:{...e?.registries||{},...C}}}function we(e){return e.replace(/\${(\w+)}/g,(t,r)=>process.env[r]||"")}function je(e){let t=[],r=/\${(\w+)}/g,i=r.exec(e);for(;i!==null;){let o=i[1];o&&t.push(o),i=r.exec(e);}return t}var Ti=/^(@[a-zA-Z0-9](?:[a-zA-Z0-9-_]*[a-zA-Z0-9])?)\/(.+)$/;function pe(e){if(!e.startsWith("@"))return {registry:null,item:e};let t=e.match(Ti);return t?{registry:t[1],item:t[2]}:{registry:null,item:e}}var Kt=[".tsx",".ts"],Zt=["lib/utils.ts"],Oi=[/^(react|react-dom)(\/.*)?$/,/^(node|jsr|npm):.*$/],Ai=new Project({compilerOptions:{}});function Li(e){if(Oi.some(t=>t.test(e)))return null;if(!e.startsWith("@")&&e.includes("/")&&(e=e.split("/")[0]),e.startsWith("@")){let t=e.split("/");t.length>2&&(e=t.slice(0,2).join("/"));}return e}async function dt(e,t,r,i=new Set){let o=R.resolve(t.resolvedPaths.cwd,e),s=R.relative(t.resolvedPaths.cwd,o);if(Zt.includes(s))return {dependencies:[],files:[]};let n=R.extname(e);if(!Kt.includes(n))return {dependencies:[],files:[]};if(i.has(s))return {dependencies:[],files:[]};i.add(s);try{if(!(await U.stat(o)).isFile())return {dependencies:[],files:[]}}catch{return {dependencies:[],files:[]}}let m=await U.readFile(o,"utf-8"),p=await Mi(R.basename(o)),d=Ai.createSourceFile(p,m,{scriptKind:ScriptKind.TSX}),c=await loadConfig(t.resolvedPaths.cwd);if(c.resultType==="failed")return {dependencies:[],files:[]};let u=[],l=new Set,g=Qt(e),h={path:s,type:g,target:"",content:""};u.push(h);let w=d.getImportDeclarations();for(let F of w){let z=F.getModuleSpecifierValue(),$e=z.startsWith(".");if(!(r.aliasPrefix&&z.startsWith(`${r.aliasPrefix}/`))&&!$e){let O=Li(z);O&&l.add(O);continue}let se=await de(z,c);if($e&&(se=R.resolve(R.dirname(o),z)),!se)continue;if(!R.extname(se))for(let O of Kt){let At=`${se}${O}`;try{await U.access(At),se=At;break}catch{continue}}let De=R.relative(t.resolvedPaths.cwd,se);if(i.has(De)||Zt.includes(De))continue;let ci=Qt(z),ui={path:De,type:ci,target:"",content:""};u.push(ui);let Ne=await dt(De,t,r,i);if(Ne.files)for(let O of Ne.files)i.has(O.path)||(i.add(O.path),u.push(O));Ne.dependencies&&Ne.dependencies.forEach(O=>l.add(O));}let _=Array.from(new Map(u.map(F=>[F.path,F])).values());return {dependencies:Array.from(l),files:_}}async function Mi(e){let t=await U.mkdtemp(R.join(tmpdir(),"mercur-"));return R.join(t,e)}function Qt(e){return e.includes("/vendor")?"registry:vendor":e.includes("/admin")?"registry:admin":"registry:api"}function q(e){try{return new URL(e),!0}catch{return false}}function ee(e){return e.endsWith(".json")&&!q(e)}function Ui(e){let t=new Set;if(typeof e=="string")for(let r of je(e))t.add(r);else {for(let r of je(e.url))t.add(r);if(e.params)for(let r of Object.values(e.params))for(let i of je(r))t.add(i);if(e.headers)for(let r of Object.values(e.headers))for(let i of je(r))t.add(i);}return Array.from(t)}function Xt(e,t){let i=Ui(t).filter(o=>!process.env[o]);if(i.length>0)throw new Me(e,i)}var We="{name}",zi=`${We}.json`,er=/\${(\w+)}/g,tr="?",Bi="&";function Wi(e){return e.includes(We)}function rr(e){return Wi(e)?e:`${e.endsWith("/")?e:`${e}/`}${zi}`}function be(e,t){let{registry:r,item:i}=pe(e);if(!r)return null;let s=(t?.registries||{})[r];if(!s)throw new Z(r);return Xt(r,s),{url:Gi(i,s),headers:Vi(s)}}function Gi(e,t,r){if(typeof t=="string"){let n=rr(t).replace(We,e);return we(n)}let o=rr(t.url).replace(We,e);return o=we(o),t.params?Yi(o,t.params):o}function Vi(e){if(typeof e=="string"||!e.headers)return {};let t={};for(let[r,i]of Object.entries(e.headers)){let o=we(i);qi(i,o)&&(t[r]=o);}return t}function Yi(e,t){let r=new URLSearchParams;for(let[s,n]of Object.entries(t)){let m=we(n);m&&r.append(s,m);}let i=r.toString();if(!i)return e;let o=e.includes(tr)?Bi:tr;return `${e}${o}${i}`}function qi(e,t){let r=t.trim();if(!r)return false;if(e.includes("${")&&e.match(er)){let o=e.replace(er,"").trim();return r!==o}return true}function ir(e){return q(e)||ee(e)?e:`${he}/${e}`}var Ge=new Map;async function Ji(e){let t=e;t.startsWith("file://")&&(t=t.slice(7)),t.startsWith("~/")&&(t=R__default.join(homedir(),t.slice(2)));let r=R__default.resolve(t);try{let i=await promises.readFile(r,"utf8");return JSON.parse(i)}catch(i){throw i instanceof Error&&(i.message.includes("ENOENT")||i.message.includes("no such file"))?new Q(e,i):new Q(e,i)}}async function te(e){return await Promise.all(e.map(async r=>{let i=ir(r);if(Ge.has(i))return Ge.get(i);if(ee(i)){let s=Ji(i);return Ge.set(i,s),s}let o=(async()=>{let s=Ht(i),n=await fetch(i,{headers:{...s}});if(!n.ok){let m;if(n.headers.get("content-type")?.includes("application/json")){let p=await n.json(),d=z.object({detail:z.string().optional(),title:z.string().optional(),message:z.string().optional(),error:z.string().optional()}).safeParse(p);d.success&&(m=d.data.detail||d.data.message,d.data.error&&(m=`[${d.data.error}] ${m}`));}throw n.status===401?new Oe(i,m):n.status===404?new ae(i,m):n.status===403?new Ae(i,m):new Le(i,n.status,m)}return n.json()})();return Ge.set(i,o),o}))}async function nr(e){try{let t=e;e.startsWith("~/")&&(t=R__default.join(homedir(),e.slice(2)));let r=R__default.resolve(t),i=await promises.readFile(r,"utf8"),o=JSON.parse(i);try{return $.parse(o)}catch(s){throw new P(e,s)}}catch(t){throw t instanceof Error&&(t.message.includes("ENOENT")||t.message.includes("no such file"))?new Q(e,t):t instanceof P?t:new Q(e,t)}}$.extend({_source:z.string().optional()});function mt(e,t){let r={},i=[...e];if(!t?.registries)return at({}),i;for(let o=0;o<i.length;o++){let s=be(i[o],t);s&&(i[o]=s.url,Object.keys(s.headers).length>0&&(r[s.url]=s.headers));}return at(r),i}async function Ye(e,t){return await Promise.all(e.map(async i=>{if(ee(i))return nr(i);if(q(i)){let[n]=await te([i]);try{return $.parse(n)}catch(m){throw new P(i,m)}}if(i.startsWith("@")&&t?.registries){let n=mt([i],t),[m]=await te(n);try{return $.parse(m)}catch(p){throw new P(i,p)}}let o=`${he}/${i}.json`,[s]=await te([o]);try{return $.parse(s)}catch(n){throw new P(i,n)}}))}async function pt(e,t){let r=[],i=[],o=Array.from(new Set(e)),s=await Ye(o,t),n=new Map;for(let d=0;d<s.length;d++)s[d]&&n.set(o[d],s[d]);for(let[d,c]of Array.from(n.entries())){let u={...c,_source:d};if(r.push(u),c.registryDependencies){let l=c.registryDependencies;if(t?.registries)l=mt(c.registryDependencies,t);else {let h=c.registryDependencies.filter(w=>w.startsWith("@"));if(h.length>0){let{registry:w}=pe(h[0]);throw new Z(w)}}let{blocks:g}=await mr(l,t,new Set(o));i.push(...g);}}r.push(...i);let m=new Map;for(let d of r){let c=d._source||d.name;m.set(d,c);}return r=Qi(r,m),Bt.parse({dependencies:ar.all(r.map(d=>d.dependencies??[])),devDependencies:ar.all(r.map(d=>d.devDependencies??[])),files:Xi(r.map(d=>d.files??[])),docs:r.map(d=>d.docs).filter(Boolean).join(`
15
+ `)})}async function mr(e,t,r=new Set){let i=[];for(let o of e){if(r.has(o))continue;if(r.add(o),o.startsWith("@")&&t?.registries){let{registry:n}=pe(o);if(n&&!(n in t.registries))throw new Z(n)}let[s]=await Ye([o],t);if(s&&(i.push({...s,_source:o}),s.registryDependencies)){let n=t?.registries?mt(s.registryDependencies,t):s.registryDependencies,m=await mr(n,t,r);i.push(...m.blocks);}}return {blocks:i}}function J(e,t){let r=t||e.name,i=createHash("sha256").update(r).digest("hex").substring(0,8);return `${e.name}::${i}`}function Zi(e){if(q(e)){let i=new URL(e).pathname,o=i.match(/\/([^/]+)\.json$/),s=o?o[1]:R__default.basename(i,".json");return {name:s,hash:J({name:s},e)}}if(ee(e)){let r=e.match(/\/([^/]+)\.json$/),i=r?r[1]:R__default.basename(e,".json");return {name:i,hash:J({name:i},e)}}let{item:t}=pe(e);return {name:t,hash:J({name:t},e)}}function Qi(e,t){let r=new Map,i=new Map,o=new Map,s=new Map;for(let d of e){let c=t.get(d)||d.name,u=J(d,c);r.set(u,d),i.set(u,d),o.set(u,0),s.set(u,[]);}let n=new Map;for(let d of e){let c=t.get(d)||d.name,u=J(d,c);n.has(d.name)||n.set(d.name,[]),n.get(d.name).push(u),c!==d.name&&(n.has(c)||n.set(c,[]),n.get(c).push(u));}for(let d of e){let c=t.get(d)||d.name,u=J(d,c);if(d.registryDependencies)for(let l of d.registryDependencies){let g,h=n.get(l)||[];if(h.length===1)g=h[0];else if(h.length>1)g=h[0];else {let{name:w}=Zi(l),_=n.get(w)||[];_.length>0&&(g=_[0]);}g&&r.has(g)&&(s.get(g).push(u),o.set(u,o.get(u)+1));}}let m=[],p=[];for(let[d,c]of o)c===0&&m.push(d);for(;m.length>0;){let d=m.shift(),c=r.get(d);p.push(c);for(let u of s.get(d)){let l=o.get(u)-1;o.set(u,l),l===0&&m.push(u);}}if(p.length!==e.length){let d=Array.from(r.keys()).filter(c=>!p.some(u=>J(u,t.get(u))===c));console.warn(`Warning: Circular dependencies detected. Some items may not be sorted correctly: ${d.join(", ")}`);for(let[c,u]of r.entries())p.some(l=>J(l,t.get(l))===c)||p.push(u);}return p}function Xi(e){let t=new Map,r=[];for(let i of e)if(i)for(let o of i){let s=o.target||o.path;t.has(s)||(t.set(s,o),r.push(o));}return r}var f={error:e=>S.red(e),warn:e=>S.yellow(e),info:e=>S.blue(e),success:e=>S.green(e),dim:e=>S.cyan(e)};var a={error(...e){console.log(f.error(e.join(" ")));},warn(...e){console.log(f.warn(e.join(" ")));},info(...e){console.log(f.info(e.join(" ")));},success(...e){console.log(f.success(e.join(" ")));},log(...e){console.log(e.join(" "));},break(){console.log("");}};function j(e){if(a.break(),a.error("Something went wrong. Please check the error below for more details."),a.error("If the problem persists, please open an issue on GitHub."),a.error(""),typeof e=="string"&&(a.error(e),a.break(),process.exit(1)),e instanceof k&&(e.message&&(a.error(e.cause?"Error:":"Message:"),a.error(e.message)),e.cause&&(a.error(`
16
+ Message:`),a.error(e.cause)),e.suggestion&&(a.error(`
17
+ Suggestion:`),a.error(e.suggestion)),a.break(),process.exit(1)),e instanceof z.ZodError){a.error("Validation failed:");for(let t of e.issues){let r=t.path.join(".")||"root";a.error(`- ${f.info(r)}: ${t.message}`);}a.break(),process.exit(1);}e instanceof Error&&(a.error(e.message),a.break(),process.exit(1)),a.break(),process.exit(1);}function v(e,t){return to({text:e,isSilent:t?.silent??false})}async function A(e){let t=await detect({programmatic:true,cwd:e});if(t?.startsWith("bun"))return "bun";if(t?.startsWith("yarn"))return "yarn";if(t?.startsWith("pnpm"))return "pnpm";if(t?.startsWith("deno"))return "deno";if(t?.startsWith("npm"))return "npm";let r=process.env.npm_config_user_agent||"";return r.startsWith("bun")?"bun":r.startsWith("yarn")?"yarn":r.startsWith("pnpm")?"pnpm":r.startsWith("deno")?"deno":"npm"}async function pr(e,t,r,i={}){if(e=Array.from(new Set(e||[])),t=Array.from(new Set(t||[])),!e?.length&&!t?.length)return;i={silent:false,...i};let o=v("Installing dependencies.",{silent:i.silent})?.start(),s=await A(r.resolvedPaths.cwd);o?.start(),await io(s,e,t,r.resolvedPaths.cwd),o?.succeed();}async function io(e,t,r,i){if(e==="npm")return oo(t,r,i);if(e==="deno")return so(t,r,i);t?.length&&await execa(e,["add",...t],{cwd:i}),r?.length&&await execa(e,["add","-D",...r],{cwd:i});}async function oo(e,t,r){e.length&&await execa("npm",["install",...e],{cwd:r}),t.length&&await execa("npm",["install","-D",...t],{cwd:r});}async function so(e,t,r){e?.length&&await execa("deno",["add",...e.map(i=>`npm:${i}`)],{cwd:r}),t?.length&&await execa("deno",["add","-D",...t.map(i=>`npm:${i}`)],{cwd:r});}function cr(e,t,r={}){let{ignoreImports:i=false}=r,o=e.replace(/\r\n/g,`
18
18
  `).trim(),s=t.replace(/\r\n/g,`
19
- `).trim();if(o===s)return true;if(!i)return false;let n=/^(import\s+(?:type\s+)?(?:\*\s+as\s+\w+|\{[^}]*\}|\w+)?(?:\s*,\s*(?:\{[^}]*\}|\w+))?\s+from\s+["'])([^"']+)(["'])/gm,m=c=>c.replace(n,(u,f,y,v)=>{if(y.startsWith("."))return `${f}${y}${v}`;let j=y.split("/"),S=j[j.length-1];return `${f}@normalized/${S}${v}`}),p=m(o),a=m(s);return p===a}function Xi(e,t){if(e.type==="registry:api")return t.resolvedPaths.api;if(e.type==="registry:vendor")return t.resolvedPaths.vendor;if(e.type==="registry:admin")return t.resolvedPaths.admin;throw new Error(`Unknown file type: ${e.type}`)}function Ge(e,t,r){let i=Xi(e,t);if(e.type==="registry:api"){let n=e.path.replace(/^\/|\/$/g,"").split("/").slice(1).join("/");return R__default.join(i,n)}let o=eo(e.path,i);return R__default.join(i,o)}function eo(e,t){let r=e.replace(/^\/|\/$/g,""),i=t.replace(/^\/|\/$/g,""),o=r.split("/"),s=i.split("/");for(let n=s.length-1;n>=0;n--){let m=o.findIndex(p=>p===s[n]);if(m!==-1)return o.slice(m+1).join("/")}return o[o.length-1]}var oo=new Project({compilerOptions:{}});async function so(e){let t=await promises.mkdtemp(R__default.join(tmpdir(),"mercurjs-")),r=R__default.basename(e,R__default.extname(e));return R__default.join(t,`${r}.ts`)}function no(e){switch(R__default.extname(e).toLowerCase()){case ".tsx":case ".ts":return ScriptKind.TS;default:return ScriptKind.Unknown}}async function Ve(e){let t=R__default.extname(e.filename).toLowerCase();if(![".tsx",".ts"].includes(t))return e.raw;let r=no(e.filename),i=await so(e.filename),o=oo.createSourceFile(i,e.raw,{scriptKind:r});for(let s of o.getImportStringLiterals()){let n=ao(s.getLiteralValue(),e.config);s.setLiteralValue(n);}return o.getText()}function ao(e,t){if(e.startsWith("@/workflows/")){let r=e.replace(/^@\/workflows\//,"");return `${t.aliases.api}/workflows/${r}`}if(e==="@/workflows")return `${t.aliases.api}/workflows`;if(e.startsWith("@/api/")){let r=e.replace(/^@\/api\//,"");return `${t.aliases.api}/api/${r}`}if(e==="@/api")return `${t.aliases.api}/api`;if(e.startsWith("@/links/")){let r=e.replace(/^@\/links\//,"");return `${t.aliases.api}/links/${r}`}if(e==="@/links")return `${t.aliases.api}/links`;if(e.startsWith("@/modules/")){let r=e.replace(/^@\/modules\//,"");return `${t.aliases.api}/modules/${r}`}if(e==="@/modules")return `${t.aliases.api}/modules`;if(e.startsWith("@/lib/")){let r=e.replace(/^@\/lib\//,"");return `${t.aliases.api}/lib/${r}`}if(e==="@/lib")return `${t.aliases.api}/lib`;if(e.startsWith("@/vendor/")){let r=e.replace(/^@\/vendor\//,"");return `${t.aliases.vendor}/${r}`}if(e==="@/vendor")return t.aliases.vendor;if(e.startsWith("@/admin/")){let r=e.replace(/^@\/admin\//,"");return `${t.aliases.admin}/${r}`}return e==="@/admin"?t.aliases.admin:e}async function pr(e,t,r){if(!e?.length)return {filesCreated:[],filesUpdated:[],filesSkipped:[],filesDeclined:[]};r={overwrite:false,silent:false,yes:false,...r};let i=h("Updating files.",{silent:r.silent})?.start(),o=await _(t.resolvedPaths.cwd),s=[],n=[],m=[],p=[];for(let u of e){let f=Ge(u,t,{isSrcDir:o?.isSrcDir??false,path:r.path??""}),y=basename(u.path),v=R__default.dirname(f),j=existsSync(f);if(j&&statSync(f).isDirectory())throw new Error(`Cannot write to ${f}: path exists and is a directory. Please provide a file path instead.`);let S=await Ve({filename:u.path,raw:u.content,config:t});if(j&&!r.overwrite){let F=await promises.readFile(f,"utf-8");if(sr(F,S)){m.push(R__default.relative(t.resolvedPaths.cwd,f));continue}if(!r.yes){i.stop();let L=diffLines(F,S);d.info(`
20
- File: ${l.info(y)}`),go(L);let{overwrite:Ce}=await Qe({type:"confirm",name:"overwrite",message:`The file ${l.info(y)} already exists. Would you like to overwrite?`,initial:false});if(!Ce){p.push(R__default.relative(t.resolvedPaths.cwd,f));continue}}}existsSync(v)||await promises.mkdir(v,{recursive:true}),await promises.writeFile(f,S,"utf-8"),j?n.push(R__default.relative(t.resolvedPaths.cwd,f)):s.push(R__default.relative(t.resolvedPaths.cwd,f));}let a=s.length+n.length,c=m.length+p.length;if(a>0){if(i?.succeed(),c>0&&!r.silent){let u=[];a===1?u.push("1 file updated"):u.push(`${a} files updated`),c===1?u.push("1 file skipped"):u.push(`${c} files skipped`),d.info(`${u.join(", ")}.`);}}else p.length?i?.info("No files were updated."):m.length?i?.info("Already up to date."):i?.info("No files to update.");return {filesCreated:s,filesUpdated:n,filesSkipped:m,filesDeclined:p}}var lo=3;function fo(e,t=lo){let r=[],i=new Set;for(let s=0;s<e.length;s++)(e[s]?.added||e[s]?.removed)&&i.add(s);if(i.size===0)return r;let o=new Map;for(let s=0;s<e.length;s++){let n=e[s];if(n)if(n.added||n.removed)o.set(s,"full");else {let m=i.has(s-1),p=i.has(s+1);m&&p?o.set(s,"both"):m?o.set(s,"start"):p&&o.set(s,"end");}}for(let s=0;s<e.length;s++){let n=e[s],m=o.get(s);if(!(!n||!m))if(n.added){let p=n.value.split(`
21
- `);p[p.length-1]===""&&p.pop();for(let a of p)r.push(`+ ${a}`);}else if(n.removed){let p=n.value.split(`
22
- `);p[p.length-1]===""&&p.pop();for(let a of p)r.push(`- ${a}`);}else {let p=n.value.split(`
23
- `);p[p.length-1]===""&&p.pop();let a=[];m==="full"||p.length<=t*2+1?a=p.map(c=>` ${c}`):m==="start"?(a=p.slice(0,t).map(c=>` ${c}`),p.length>t&&a.push(` ... ${p.length-t} lines hidden ...`)):m==="end"?(p.length>t&&a.push(` ... ${p.length-t} lines hidden ...`),a.push(...p.slice(-t).map(c=>` ${c}`))):m==="both"&&(p.length<=t*2+1?a=p.map(c=>` ${c}`):a=[...p.slice(0,t).map(c=>` ${c}`),` ... ${p.length-t*2} lines hidden ...`,...p.slice(-t).map(c=>` ${c}`)]),r.push(...a);}}return r}function go(e){let t=fo(e);if(t.length!==0)for(let r of t)r.startsWith("+ ")?process.stdout.write(`${l.success(r)}
24
- `):r.startsWith("- ")?process.stdout.write(`${l.error(r)}
25
- `):r.includes("lines hidden")?process.stdout.write(`${l.info(r)}
19
+ `).trim();if(o===s)return true;if(!i)return false;let n=/^(import\s+(?:type\s+)?(?:\*\s+as\s+\w+|\{[^}]*\}|\w+)?(?:\s*,\s*(?:\{[^}]*\}|\w+))?\s+from\s+["'])([^"']+)(["'])/gm,m=c=>c.replace(n,(u,l,g,h)=>{if(g.startsWith("."))return `${l}${g}${h}`;let w=g.split("/"),_=w[w.length-1];return `${l}@normalized/${_}${h}`}),p=m(o),d=m(s);return p===d}function no(e,t){if(e.type==="registry:api")return t.resolvedPaths.api;if(e.type==="registry:vendor")return t.resolvedPaths.vendor;if(e.type==="registry:admin")return t.resolvedPaths.admin;throw new Error(`Unknown file type: ${e.type}`)}function qe(e,t,r){let i=no(e,t);if(e.type==="registry:api"){let n=e.path.replace(/^\/|\/$/g,"").split("/").slice(1).join("/");return R__default.join(i,n)}let o=ao(e.path,i);return R__default.join(i,o)}function ao(e,t){let r=e.replace(/^\/|\/$/g,""),i=t.replace(/^\/|\/$/g,""),o=r.split("/"),s=i.split("/");for(let n=s.length-1;n>=0;n--){let m=o.findIndex(p=>p===s[n]);if(m!==-1)return o.slice(m+1).join("/")}return o[o.length-1]}var uo=new Project({compilerOptions:{}});async function lo(e){let t=await promises.mkdtemp(R__default.join(tmpdir(),"mercurjs-")),r=R__default.basename(e,R__default.extname(e));return R__default.join(t,`${r}.ts`)}function fo(e){switch(R__default.extname(e).toLowerCase()){case ".tsx":case ".ts":return ScriptKind.TS;default:return ScriptKind.Unknown}}async function Je(e){let t=R__default.extname(e.filename).toLowerCase();if(![".tsx",".ts"].includes(t))return e.raw;let r=fo(e.filename),i=await lo(e.filename),o=uo.createSourceFile(i,e.raw,{scriptKind:r});for(let s of o.getImportStringLiterals()){let n=go(s.getLiteralValue(),e.config);s.setLiteralValue(n);}return o.getText()}function go(e,t){if(e.startsWith("@/workflows/")){let r=e.replace(/^@\/workflows\//,"");return `${t.aliases.api}/workflows/${r}`}if(e==="@/workflows")return `${t.aliases.api}/workflows`;if(e.startsWith("@/api/")){let r=e.replace(/^@\/api\//,"");return `${t.aliases.api}/api/${r}`}if(e==="@/api")return `${t.aliases.api}/api`;if(e.startsWith("@/links/")){let r=e.replace(/^@\/links\//,"");return `${t.aliases.api}/links/${r}`}if(e==="@/links")return `${t.aliases.api}/links`;if(e.startsWith("@/modules/")){let r=e.replace(/^@\/modules\//,"");return `${t.aliases.api}/modules/${r}`}if(e==="@/modules")return `${t.aliases.api}/modules`;if(e.startsWith("@/lib/")){let r=e.replace(/^@\/lib\//,"");return `${t.aliases.api}/lib/${r}`}if(e==="@/lib")return `${t.aliases.api}/lib`;if(e.startsWith("@/vendor/")){let r=e.replace(/^@\/vendor\//,"");return `${t.aliases.vendor}/${r}`}if(e==="@/vendor")return t.aliases.vendor;if(e.startsWith("@/admin/")){let r=e.replace(/^@\/admin\//,"");return `${t.aliases.admin}/${r}`}return e==="@/admin"?t.aliases.admin:e}async function gr(e,t,r){if(!e?.length)return {filesCreated:[],filesUpdated:[],filesSkipped:[],filesDeclined:[]};r={overwrite:false,silent:false,yes:false,...r};let i=v("Updating files.",{silent:r.silent})?.start(),o=await E(t.resolvedPaths.cwd),s=[],n=[],m=[],p=[];for(let u of e){let l=qe(u,t,{isSrcDir:o?.isSrcDir??false,path:r.path??""}),g=basename(u.path),h=R__default.dirname(l),w=existsSync(l);if(w&&statSync(l).isDirectory())throw new Error(`Cannot write to ${l}: path exists and is a directory. Please provide a file path instead.`);let _=await Je({filename:u.path,raw:u.content,config:t});if(w&&!r.overwrite){let F=await promises.readFile(l,"utf-8");if(cr(F,_)){m.push(R__default.relative(t.resolvedPaths.cwd,l));continue}if(!r.yes){i.stop();let z=diffLines(F,_);a.info(`
20
+ File: ${f.info(g)}`),Ro(z);let{overwrite:$e}=await Pe({type:"confirm",name:"overwrite",message:`The file ${f.info(g)} already exists. Would you like to overwrite?`,initial:false});if(!$e){p.push(R__default.relative(t.resolvedPaths.cwd,l));continue}}}existsSync(h)||await promises.mkdir(h,{recursive:true}),await promises.writeFile(l,_,"utf-8"),w?n.push(R__default.relative(t.resolvedPaths.cwd,l)):s.push(R__default.relative(t.resolvedPaths.cwd,l));}let d=s.length+n.length,c=m.length+p.length;if(d>0){if(i?.succeed(),c>0&&!r.silent){let u=[];d===1?u.push("1 file updated"):u.push(`${d} files updated`),c===1?u.push("1 file skipped"):u.push(`${c} files skipped`),a.info(`${u.join(", ")}.`);}}else p.length?i?.info("No files were updated."):m.length?i?.info("Already up to date."):i?.info("No files to update.");return {filesCreated:s,filesUpdated:n,filesSkipped:m,filesDeclined:p}}var jo=3;function bo(e,t=jo){let r=[],i=new Set;for(let s=0;s<e.length;s++)(e[s]?.added||e[s]?.removed)&&i.add(s);if(i.size===0)return r;let o=new Map;for(let s=0;s<e.length;s++){let n=e[s];if(n)if(n.added||n.removed)o.set(s,"full");else {let m=i.has(s-1),p=i.has(s+1);m&&p?o.set(s,"both"):m?o.set(s,"start"):p&&o.set(s,"end");}}for(let s=0;s<e.length;s++){let n=e[s],m=o.get(s);if(!(!n||!m))if(n.added){let p=n.value.split(`
21
+ `);p[p.length-1]===""&&p.pop();for(let d of p)r.push(`+ ${d}`);}else if(n.removed){let p=n.value.split(`
22
+ `);p[p.length-1]===""&&p.pop();for(let d of p)r.push(`- ${d}`);}else {let p=n.value.split(`
23
+ `);p[p.length-1]===""&&p.pop();let d=[];m==="full"||p.length<=t*2+1?d=p.map(c=>` ${c}`):m==="start"?(d=p.slice(0,t).map(c=>` ${c}`),p.length>t&&d.push(` ... ${p.length-t} lines hidden ...`)):m==="end"?(p.length>t&&d.push(` ... ${p.length-t} lines hidden ...`),d.push(...p.slice(-t).map(c=>` ${c}`))):m==="both"&&(p.length<=t*2+1?d=p.map(c=>` ${c}`):d=[...p.slice(0,t).map(c=>` ${c}`),` ... ${p.length-t*2} lines hidden ...`,...p.slice(-t).map(c=>` ${c}`)]),r.push(...d);}}return r}function Ro(e){let t=bo(e);if(t.length!==0)for(let r of t)r.startsWith("+ ")?process.stdout.write(`${f.success(r)}
24
+ `):r.startsWith("- ")?process.stdout.write(`${f.error(r)}
25
+ `):r.includes("lines hidden")?process.stdout.write(`${f.info(r)}
26
26
  `):process.stdout.write(`${r}
27
- `);}async function mr(e,t,r){if(r={overwrite:false,silent:false,yes:false,...r},!e.length)return;let i=h("Checking registry.",{silent:r.silent})?.start(),o=await pt(e,ne(t));if(!o)return i?.fail(),w(new Error("Failed to fetch items from registry."));i?.succeed();let{filesCreated:s,filesUpdated:n}=await pr(o.files,t,{overwrite:r.overwrite,silent:r.silent,path:r.path,yes:r.yes});(s.length||n.length)&&await or(o.dependencies,o.devDependencies,t,{silent:r.silent}),o.docs&&d.info(o.docs);}z$1.object({cwd:z$1.string(),yes:z$1.boolean(),defaults:z$1.boolean(),silent:z$1.boolean()});async function cr(e){let t={},r=R__default.resolve(e.cwd);existsSync(r)||(t.MISSING_DIR=true);let i=await _(r);return {errors:t,projectInfo:i}}var ct=class{config;path=join(vo.tmpdir(),"mercur");constructor(){this.config=this.createBaseConfig();}createBaseConfig(){return {telemetry_enabled:true,telemetry_email:null}}get(t){return this.config[t]}set(t,r){this.config[t]=r;}all(){return this.config}size(){return Object.keys(this.config).length}has(t){return t in this.config&&this.config[t]!==void 0}del(t){delete this.config[t];}clear(){this.config=this.createBaseConfig();}},ke=new ct;var me=e=>Function("mm","return import(mm)")(e);function jo(){let e=(...t)=>t.some(r=>!!process.env[r]);return e("MEDUSA_CLOUD_ENVIRONMENT_HANDLE","MEDUSA_CLOUD_SANDBOX_HANDLE","MEDUSA_CLOUD_API_KEY")?"medusa-cloud":e("RENDER","RENDER_URL","RENDER_INTERNAL_HOSTNAME","RENDER_SERVICE_ID")?"render":e("FLY_APP_NAME","FLY_REGION","FLY_ALLOC_ID")?"fly-io":e("RAILWAY_STATIC_URL","RAILWAY_ENVIRONMENT_NAME")?"railway":e("DYNO","HEROKU_APP_NAME")?"heroku":e("DO_DEPLOYMENT_ID","DO_APP_NAME","DIGITALOCEAN")?"digitalocean":e("KOYEB","KOYEB_DEPLOYMENT_ID","KOYEB_APP_NAME")?"koyeb":null}async function lr(){try{let e=await me("os"),t=e.cpus();return {deploymentVendor:jo(),systemPlatform:e.platform(),systemRelease:e.release(),systemArchitecture:e.arch(),cpuCount:t.length,cpuModel:t.length?t[0].model:null,cpuSpeed:t.length?t[0].speed:null,memory:e.totalmem(),isWSL:await bo(),isDocker:await fr(),isTTY:typeof process<"u"&&process.stdout?process.stdout.isTTY:null}}catch{return {systemPlatform:null,systemRelease:null,systemArchitecture:null,cpuCount:null,cpuModel:null,cpuSpeed:null,memory:null,isWSL:null,isDocker:null,isTTY:null}}}async function bo(){try{if(typeof process>"u"||process?.platform!=="linux")return !1;let e=await me("fs");return (await me("os")).release().toLowerCase().includes("microsoft")?!await ur():e.readFileSync("/proc/version","utf8").toLowerCase().includes("microsoft")?!await ur():!1}catch{return false}}var Ro=async()=>{try{return (await me("fs")).statSync("/run/.containerenv"),!0}catch{return false}};async function fr(){return await xo()||await ko()}async function xo(){try{return (await me("fs")).statSync("/.dockerenv"),!0}catch{return false}}async function ko(){try{return (await me("fs")).readFileSync("/proc/self/cgroup","utf8").includes("docker")}catch{return false}}async function ur(){return await Ro()||await fr()}var qe=e=>createHash("sha256").update(e).digest("base64");var Eo=process.env.MERCUR_TELEMETRY_PROXY_URL||"https://telemetry.mercurjs.com/api/v1/events",gr=e=>{ke.set("telemetry_email",e);},yr=e=>{ke.set("telemetry_enabled",e);},Io=()=>ke.get("telemetry_enabled")&&process.env.MERCUR_DISABLE_TELEMETRY!=="true",P=async(e,t)=>{try{if(!Io())return;let r=await _(t.cwd),{projectId:i}=To(r.packageJson),o={nodeEnv:Co(),nodeVersion:process.version,mercurVersion:r.mercurVersion,medusaVersion:r.medusaVersion,isSrcDir:r.isSrcDir,aliasPrefix:r.aliasPrefix,config:await b(t.cwd),projectId:i,systemInfo:await lr(),packageManager:await O(t.cwd),email:$o()};await fetch(Eo,{body:JSON.stringify({...o,...e}),headers:{"Content-Type":"application/json"},method:"post"});}catch{}};function Co(){return process.env.NODE_ENV||"development"}var Po=()=>{try{let e=execSync("git config --local --get remote.origin.url",{stdio:"pipe",timeout:1e3});return String(e).trim()}catch{return null}},To=e=>{let t=Po();if(t)return {projectId:qe(t)};let r=e.name;if(r)return {projectId:qe(r)};let i=process.cwd();return {projectId:qe(i)}},$o=()=>ke.get("telemetry_email")||void 0;var No=z$1.object({cwd:z$1.string(),yes:z$1.boolean(),defaults:z$1.boolean(),silent:z$1.boolean()}),vr=new Command().name("init").description("initialize your project and install dependencies").option("-y, --yes","skip confirmation prompt.",true).option("-d, --defaults","use default configuration.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-s, --silent","mute output.",false).action(async e=>{try{let t=No.parse({cwd:R__default.resolve(e.cwd),...e});await lt(t),d.log(`${l.success("Success!")} Project initialization completed.
28
- You may now add blocks.`),d.break(),await P({type:"init",payload:{outcome:"success"}},{cwd:t.cwd});}catch(t){d.break(),w(t);}finally{x();}});async function lt(e){await cr(e);let t=await b(e.cwd),r=t?await Ao(t,e):await Oo(e);if(!e.yes){let{proceed:s}=await Qe({type:"confirm",name:"proceed",message:`Write configuration to ${l.info("blocks.json")}. Proceed?`,initial:true});s||process.exit(0);}let i=h("Writing blocks.json.").start(),o=R__default.resolve(e.cwd,"blocks.json");return r.registries=Object.fromEntries(Object.entries(r.registries||{}).filter(([s])=>!Object.keys(I).includes(s))),await promises.writeFile(o,`${JSON.stringify(r,null,2)}
29
- `,"utf8"),i.succeed(),await it(e.cwd,r)}async function Oo(e){if(e.defaults)return U.parse({$schema:$e,aliases:{api:"packages/api/src",vendor:"apps/vendor/src",admin:"apps/admin/src"},registries:I});d.info("");let t=await Qe([{type:"text",name:"api",message:`Configure the import alias for ${l.info("api")}:`,initial:"packages/api/src"},{type:"text",name:"vendor",message:`Configure the import alias for ${l.info("vendor")}:`,initial:"apps/vendor/src"},{type:"text",name:"admin",message:`Configure the import alias for ${l.info("admin")}:`,initial:"apps/admin/src"}],{onCancel:()=>{process.exit(0);}});return U.parse({$schema:$e,aliases:{api:t.api??"packages/api/src",vendor:t.vendor??"apps/vendor/src",admin:t.admin??"apps/admin/src"},registries:I})}async function Ao(e,t){if(t.defaults)return U.parse({$schema:$e,aliases:{api:"packages/api/src",vendor:"apps/vendor/src",admin:"apps/admin/src"},registries:I});let r=await Qe([{type:"text",name:"api",message:`Configure the import alias for ${l.info("api")}:`,initial:e.aliases.api},{type:"text",name:"vendor",message:`Configure the import alias for ${l.info("vendor")}:`,initial:e.aliases.vendor},{type:"text",name:"admin",message:`Configure the import alias for ${l.info("admin")}:`,initial:e.aliases.admin}],{onCancel:()=>{process.exit(0);}});return U.parse({$schema:e.$schema,aliases:{api:r.api??e.aliases.api,vendor:r.vendor??e.aliases.vendor,admin:r.admin??e.aliases.admin}})}var Uo=z$1.object({blocks:z$1.array(z$1.string()).optional(),yes:z$1.boolean(),overwrite:z$1.boolean(),cwd:z$1.string(),silent:z$1.boolean()}),wr=new Command().name("add").description("add blocks to your project").argument("[blocks...]","names of blocks to add").option("-y, --yes","skip confirmation prompt.",false).option("-o, --overwrite","overwrite existing files.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-s, --silent","mute output.",false).action(async(e,t)=>{try{let r=Uo.parse({blocks:e,cwd:R__default.resolve(t.cwd),...t}),i=await b(r.cwd);i||(i=B({resolvedPaths:{cwd:r.cwd}})),r.blocks?.length||(d.error("Please specify at least one item to add."),process.exit(1));let{errors:o}=await Bt(r);if(o[E]){let{proceed:s}=await Qe({type:"confirm",name:"proceed",message:`You need to create a ${l.info("blocks.json")} file to add items. Proceed?`,initial:!0});s||(d.break(),process.exit(1)),i=await lt({cwd:r.cwd,yes:!0,defaults:!1,silent:r.silent});}if(!i)throw new Error(`Failed to read config at ${l.info(r.cwd)}.`);await mr(r.blocks,i,{overwrite:r.overwrite,silent:r.silent,yes:r.yes,path:r.cwd}),await P({type:"add",payload:{outcome:"success",blocks:r.blocks}},{cwd:r.cwd});}catch(r){d.break(),w(r);}finally{x();}});async function jr(e){let t={},r={cwd:e.cwd,registryFile:R__default.resolve(e.cwd,e.registryFile),outputDir:R__default.resolve(e.cwd,e.outputDir)};if(!A.existsSync(r.registryFile))return t[z]=true,{errors:t,resolvePaths:null,config:null};if(!A.existsSync(R__default.resolve(e.cwd,"blocks.json")))return t[E]=true,{errors:t,resolvePaths:null,config:null};await A.mkdir(r.outputDir,{recursive:true});try{let i=await b(e.cwd);return {errors:t,config:i,resolvePaths:r}}catch{d.break(),d.error(`An invalid ${l.info("blocks.json")} file was found at ${l.info(e.cwd)}.
30
- Before you can build the registry, you must create a valid ${l.info("blocks.json")} file by running the ${l.info("init")} command.`),d.break(),process.exit(1);}}var Wo=z$1.object({cwd:z$1.string(),registryFile:z$1.string(),outputDir:z$1.string(),verbose:z$1.boolean().optional().default(false)}),br=new Command().name("registry:build").description("builds the registry").argument("[registry]","path to registry.json file","./registry.json").option("-o, --output <path>","destination directory for json files","./r").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-v, --verbose","verbose output").action(async(e,t)=>{await Go({cwd:R.resolve(t.cwd),registryFile:e,outputDir:t.output,verbose:t.verbose});});async function Go(e){try{let t=Wo.parse(e),[{errors:r,resolvePaths:i,config:o},s]=await Promise.all([jr(t),_(t.cwd)]);(r[E]||!s)&&(d.error(`A ${l.info("blocks.json")} file is required to build the registry. Run ${l.info("mercur init")} to create one.`),d.break(),await P({type:"build",payload:{outcome:"missing_config"}},{cwd:t.cwd}),process.exit(1)),(r[z]||!i)&&(d.error(`We could not find a registry file at ${l.info(R.resolve(t.cwd,t.registryFile))}.`),d.break(),await P({type:"build",payload:{outcome:"missing_registry_file"}},{cwd:t.cwd}),process.exit(1));let n=await M.readFile(i.registryFile,"utf-8"),m=Y.safeParse(JSON.parse(n));m.success||(d.error(`Invalid registry file found at ${l.info(i.registryFile)}.`),d.break(),process.exit(1));let p=h("Building registry..."),a=await Vo(m.data,o,s);for(let c of a.items)c.files=c.files?.filter((u,f,y)=>f===y.findIndex(v=>v.path===u.path)),c.dependencies&&(c.dependencies=c.dependencies.filter((u,f,y)=>f===y.findIndex(v=>v===u)));for(let c of a.items){if(!c.files)continue;p.start(`Building ${c.name}...`),c.$schema=Mt;for(let f of c.files){let y=s.isSrcDir?"src":"",v=R.resolve(i.cwd,y,f.path);try{if(!(await M.stat(v)).isFile())continue;f.content=await M.readFile(v,"utf-8");}catch(j){console.error("Error reading file in registry build:",v,j);continue}}let u=T.safeParse(c);if(!u.success){d.error(`Invalid registry item found for ${l.info(c.name)}.`);continue}await M.writeFile(R.resolve(i.outputDir,`${u.data.name}.json`),JSON.stringify(u.data,null,2));}if(await M.copyFile(i.registryFile,R.resolve(i.outputDir,"registry.json")),p.succeed("Building registry."),t.verbose){h(`The registry has ${l.info(a.items.length.toString())} items:`).succeed();for(let c of a.items){d.log(` - ${c.name}`);for(let u of c.files??[])d.log(` - ${u.path}`);}}await P({type:"build",payload:{outcome:"success"}},{cwd:t.cwd});}catch(t){d.break(),w(t);}}async function Vo(e,t,r){for(let i of e.items)if(i.files?.length)for(let o of i.files){let s=await at(o.path,t,r);s.files=s.files?.filter(n=>n.path!==o.path),s.files&&i.files.push(...s.files),s.dependencies&&(i.dependencies=i.dependencies?i.dependencies.concat(s.dependencies):s.dependencies);}return e}var He=".mercur/_generated",te=/route\.(ts|js)$/,Rr={"/admin/api-keys":'typeof import("@medusajs/medusa/api/admin/api-keys/route")',"/admin/api-keys/:id":'typeof import("@medusajs/medusa/api/admin/api-keys/[id]/route")',"/admin/api-keys/:id/revoke":'typeof import("@medusajs/medusa/api/admin/api-keys/[id]/revoke/route")',"/admin/api-keys/:id/sales-channels":'typeof import("@medusajs/medusa/api/admin/api-keys/[id]/sales-channels/route")',"/admin/campaigns":'typeof import("@medusajs/medusa/api/admin/campaigns/route")',"/admin/campaigns/:id":'typeof import("@medusajs/medusa/api/admin/campaigns/[id]/route")',"/admin/campaigns/:id/promotions":'typeof import("@medusajs/medusa/api/admin/campaigns/[id]/promotions/route")',"/admin/claims":'typeof import("@medusajs/medusa/api/admin/claims/route")',"/admin/claims/:id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/route")',"/admin/claims/:id/cancel":'typeof import("@medusajs/medusa/api/admin/claims/[id]/cancel/route")',"/admin/claims/:id/claim-items":'typeof import("@medusajs/medusa/api/admin/claims/[id]/claim-items/route")',"/admin/claims/:id/claim-items/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/claim-items/[action_id]/route")',"/admin/claims/:id/inbound/items":'typeof import("@medusajs/medusa/api/admin/claims/[id]/inbound/items/route")',"/admin/claims/:id/inbound/items/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/inbound/items/[action_id]/route")',"/admin/claims/:id/inbound/shipping-method":'typeof import("@medusajs/medusa/api/admin/claims/[id]/inbound/shipping-method/route")',"/admin/claims/:id/inbound/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/inbound/shipping-method/[action_id]/route")',"/admin/claims/:id/outbound/items":'typeof import("@medusajs/medusa/api/admin/claims/[id]/outbound/items/route")',"/admin/claims/:id/outbound/items/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/outbound/items/[action_id]/route")',"/admin/claims/:id/outbound/shipping-method":'typeof import("@medusajs/medusa/api/admin/claims/[id]/outbound/shipping-method/route")',"/admin/claims/:id/outbound/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/outbound/shipping-method/[action_id]/route")',"/admin/claims/:id/request":'typeof import("@medusajs/medusa/api/admin/claims/[id]/request/route")',"/admin/collections":'typeof import("@medusajs/medusa/api/admin/collections/route")',"/admin/collections/:id":'typeof import("@medusajs/medusa/api/admin/collections/[id]/route")',"/admin/collections/:id/products":'typeof import("@medusajs/medusa/api/admin/collections/[id]/products/route")',"/admin/currencies":'typeof import("@medusajs/medusa/api/admin/currencies/route")',"/admin/currencies/:code":'typeof import("@medusajs/medusa/api/admin/currencies/[code]/route")',"/admin/customer-groups":'typeof import("@medusajs/medusa/api/admin/customer-groups/route")',"/admin/customer-groups/:id":'typeof import("@medusajs/medusa/api/admin/customer-groups/[id]/route")',"/admin/customer-groups/:id/customers":'typeof import("@medusajs/medusa/api/admin/customer-groups/[id]/customers/route")',"/admin/customers":'typeof import("@medusajs/medusa/api/admin/customers/route")',"/admin/customers/:id":'typeof import("@medusajs/medusa/api/admin/customers/[id]/route")',"/admin/customers/:id/addresses":'typeof import("@medusajs/medusa/api/admin/customers/[id]/addresses/route")',"/admin/customers/:id/addresses/:address_id":'typeof import("@medusajs/medusa/api/admin/customers/[id]/addresses/[address_id]/route")',"/admin/customers/:id/customer-groups":'typeof import("@medusajs/medusa/api/admin/customers/[id]/customer-groups/route")',"/admin/draft-orders":'typeof import("@medusajs/medusa/api/admin/draft-orders/route")',"/admin/draft-orders/:id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/route")',"/admin/draft-orders/:id/convert-to-order":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/convert-to-order/route")',"/admin/draft-orders/:id/edit":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/route")',"/admin/draft-orders/:id/edit/confirm":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/confirm/route")',"/admin/draft-orders/:id/edit/items":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/items/route")',"/admin/draft-orders/:id/edit/items/:action_id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/items/[action_id]/route")',"/admin/draft-orders/:id/edit/items/item/:item_id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/items/item/[item_id]/route")',"/admin/draft-orders/:id/edit/promotions":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/promotions/route")',"/admin/draft-orders/:id/edit/request":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/request/route")',"/admin/draft-orders/:id/edit/shipping-methods":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/shipping-methods/route")',"/admin/draft-orders/:id/edit/shipping-methods/:action_id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/shipping-methods/[action_id]/route")',"/admin/draft-orders/:id/edit/shipping-methods/method/:method_id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/shipping-methods/method/[method_id]/route")',"/admin/exchanges":'typeof import("@medusajs/medusa/api/admin/exchanges/route")',"/admin/exchanges/:id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/route")',"/admin/exchanges/:id/cancel":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/cancel/route")',"/admin/exchanges/:id/inbound/items":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/inbound/items/route")',"/admin/exchanges/:id/inbound/items/:action_id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/inbound/items/[action_id]/route")',"/admin/exchanges/:id/inbound/shipping-method":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/inbound/shipping-method/route")',"/admin/exchanges/:id/inbound/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/inbound/shipping-method/[action_id]/route")',"/admin/exchanges/:id/outbound/items":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/outbound/items/route")',"/admin/exchanges/:id/outbound/items/:action_id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/outbound/items/[action_id]/route")',"/admin/exchanges/:id/outbound/shipping-method":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/outbound/shipping-method/route")',"/admin/exchanges/:id/outbound/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/outbound/shipping-method/[action_id]/route")',"/admin/exchanges/:id/request":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/request/route")',"/admin/feature-flags":'typeof import("@medusajs/medusa/api/admin/feature-flags/route")',"/admin/fulfillment-providers":'typeof import("@medusajs/medusa/api/admin/fulfillment-providers/route")',"/admin/fulfillment-providers/:id/options":'typeof import("@medusajs/medusa/api/admin/fulfillment-providers/[id]/options/route")',"/admin/fulfillment-sets/:id":'typeof import("@medusajs/medusa/api/admin/fulfillment-sets/[id]/route")',"/admin/fulfillment-sets/:id/service-zones":'typeof import("@medusajs/medusa/api/admin/fulfillment-sets/[id]/service-zones/route")',"/admin/fulfillment-sets/:id/service-zones/:zone_id":'typeof import("@medusajs/medusa/api/admin/fulfillment-sets/[id]/service-zones/[zone_id]/route")',"/admin/fulfillments":'typeof import("@medusajs/medusa/api/admin/fulfillments/route")',"/admin/fulfillments/:id/cancel":'typeof import("@medusajs/medusa/api/admin/fulfillments/[id]/cancel/route")',"/admin/fulfillments/:id/shipment":'typeof import("@medusajs/medusa/api/admin/fulfillments/[id]/shipment/route")',"/admin/index/details":'typeof import("@medusajs/medusa/api/admin/index/details/route")',"/admin/index/sync":'typeof import("@medusajs/medusa/api/admin/index/sync/route")',"/admin/inventory-items":'typeof import("@medusajs/medusa/api/admin/inventory-items/route")',"/admin/inventory-items/:id":'typeof import("@medusajs/medusa/api/admin/inventory-items/[id]/route")',"/admin/inventory-items/:id/location-levels":'typeof import("@medusajs/medusa/api/admin/inventory-items/[id]/location-levels/route")',"/admin/inventory-items/:id/location-levels/:location_id":'typeof import("@medusajs/medusa/api/admin/inventory-items/[id]/location-levels/[location_id]/route")',"/admin/inventory-items/:id/location-levels/batch":'typeof import("@medusajs/medusa/api/admin/inventory-items/[id]/location-levels/batch/route")',"/admin/inventory-items/location-levels/batch":'typeof import("@medusajs/medusa/api/admin/inventory-items/location-levels/batch/route")',"/admin/invites":'typeof import("@medusajs/medusa/api/admin/invites/route")',"/admin/invites/:id":'typeof import("@medusajs/medusa/api/admin/invites/[id]/route")',"/admin/invites/:id/resend":'typeof import("@medusajs/medusa/api/admin/invites/[id]/resend/route")',"/admin/invites/accept":'typeof import("@medusajs/medusa/api/admin/invites/accept/route")',"/admin/locales":'typeof import("@medusajs/medusa/api/admin/locales/route")',"/admin/locales/:code":'typeof import("@medusajs/medusa/api/admin/locales/[code]/route")',"/admin/notifications":'typeof import("@medusajs/medusa/api/admin/notifications/route")',"/admin/notifications/:id":'typeof import("@medusajs/medusa/api/admin/notifications/[id]/route")',"/admin/order-changes/:id":'typeof import("@medusajs/medusa/api/admin/order-changes/[id]/route")',"/admin/order-edits":'typeof import("@medusajs/medusa/api/admin/order-edits/route")',"/admin/order-edits/:id":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/route")',"/admin/order-edits/:id/confirm":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/confirm/route")',"/admin/order-edits/:id/items":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/items/route")',"/admin/order-edits/:id/items/:action_id":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/items/[action_id]/route")',"/admin/order-edits/:id/items/item/:item_id":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/items/item/[item_id]/route")',"/admin/order-edits/:id/request":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/request/route")',"/admin/order-edits/:id/shipping-method":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/shipping-method/route")',"/admin/order-edits/:id/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/shipping-method/[action_id]/route")',"/admin/orders":'typeof import("@medusajs/medusa/api/admin/orders/route")',"/admin/orders/:id":'typeof import("@medusajs/medusa/api/admin/orders/[id]/route")',"/admin/orders/:id/archive":'typeof import("@medusajs/medusa/api/admin/orders/[id]/archive/route")',"/admin/orders/:id/cancel":'typeof import("@medusajs/medusa/api/admin/orders/[id]/cancel/route")',"/admin/orders/:id/changes":'typeof import("@medusajs/medusa/api/admin/orders/[id]/changes/route")',"/admin/orders/:id/complete":'typeof import("@medusajs/medusa/api/admin/orders/[id]/complete/route")',"/admin/orders/:id/credit-lines":'typeof import("@medusajs/medusa/api/admin/orders/[id]/credit-lines/route")',"/admin/orders/:id/fulfillments":'typeof import("@medusajs/medusa/api/admin/orders/[id]/fulfillments/route")',"/admin/orders/:id/fulfillments/:fulfillment_id/cancel":'typeof import("@medusajs/medusa/api/admin/orders/[id]/fulfillments/[fulfillment_id]/cancel/route")',"/admin/orders/:id/fulfillments/:fulfillment_id/mark-as-delivered":'typeof import("@medusajs/medusa/api/admin/orders/[id]/fulfillments/[fulfillment_id]/mark-as-delivered/route")',"/admin/orders/:id/fulfillments/:fulfillment_id/shipments":'typeof import("@medusajs/medusa/api/admin/orders/[id]/fulfillments/[fulfillment_id]/shipments/route")',"/admin/orders/:id/line-items":'typeof import("@medusajs/medusa/api/admin/orders/[id]/line-items/route")',"/admin/orders/:id/preview":'typeof import("@medusajs/medusa/api/admin/orders/[id]/preview/route")',"/admin/orders/:id/shipping-options":'typeof import("@medusajs/medusa/api/admin/orders/[id]/shipping-options/route")',"/admin/orders/:id/transfer":'typeof import("@medusajs/medusa/api/admin/orders/[id]/transfer/route")',"/admin/orders/:id/transfer/cancel":'typeof import("@medusajs/medusa/api/admin/orders/[id]/transfer/cancel/route")',"/admin/orders/export":'typeof import("@medusajs/medusa/api/admin/orders/export/route")',"/admin/payment-collections":'typeof import("@medusajs/medusa/api/admin/payment-collections/route")',"/admin/payment-collections/:id":'typeof import("@medusajs/medusa/api/admin/payment-collections/[id]/route")',"/admin/payment-collections/:id/mark-as-paid":'typeof import("@medusajs/medusa/api/admin/payment-collections/[id]/mark-as-paid/route")',"/admin/payments":'typeof import("@medusajs/medusa/api/admin/payments/route")',"/admin/payments/:id":'typeof import("@medusajs/medusa/api/admin/payments/[id]/route")',"/admin/payments/:id/capture":'typeof import("@medusajs/medusa/api/admin/payments/[id]/capture/route")',"/admin/payments/:id/refund":'typeof import("@medusajs/medusa/api/admin/payments/[id]/refund/route")',"/admin/payments/payment-providers":'typeof import("@medusajs/medusa/api/admin/payments/payment-providers/route")',"/admin/plugins":'typeof import("@medusajs/medusa/api/admin/plugins/route")',"/admin/price-lists":'typeof import("@medusajs/medusa/api/admin/price-lists/route")',"/admin/price-lists/:id":'typeof import("@medusajs/medusa/api/admin/price-lists/[id]/route")',"/admin/price-lists/:id/prices":'typeof import("@medusajs/medusa/api/admin/price-lists/[id]/prices/route")',"/admin/price-lists/:id/prices/batch":'typeof import("@medusajs/medusa/api/admin/price-lists/[id]/prices/batch/route")',"/admin/price-lists/:id/products":'typeof import("@medusajs/medusa/api/admin/price-lists/[id]/products/route")',"/admin/price-preferences":'typeof import("@medusajs/medusa/api/admin/price-preferences/route")',"/admin/price-preferences/:id":'typeof import("@medusajs/medusa/api/admin/price-preferences/[id]/route")',"/admin/product-categories":'typeof import("@medusajs/medusa/api/admin/product-categories/route")',"/admin/product-categories/:id":'typeof import("@medusajs/medusa/api/admin/product-categories/[id]/route")',"/admin/product-categories/:id/products":'typeof import("@medusajs/medusa/api/admin/product-categories/[id]/products/route")',"/admin/product-tags":'typeof import("@medusajs/medusa/api/admin/product-tags/route")',"/admin/product-tags/:id":'typeof import("@medusajs/medusa/api/admin/product-tags/[id]/route")',"/admin/product-types":'typeof import("@medusajs/medusa/api/admin/product-types/route")',"/admin/product-types/:id":'typeof import("@medusajs/medusa/api/admin/product-types/[id]/route")',"/admin/product-variants":'typeof import("@medusajs/medusa/api/admin/product-variants/route")',"/admin/products":'typeof import("@medusajs/medusa/api/admin/products/route")',"/admin/products/:id":'typeof import("@medusajs/medusa/api/admin/products/[id]/route")',"/admin/products/:id/images/:image_id/variants/batch":'typeof import("@medusajs/medusa/api/admin/products/[id]/images/[image_id]/variants/batch/route")',"/admin/products/:id/options":'typeof import("@medusajs/medusa/api/admin/products/[id]/options/route")',"/admin/products/:id/options/:option_id":'typeof import("@medusajs/medusa/api/admin/products/[id]/options/[option_id]/route")',"/admin/products/:id/variants":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/route")',"/admin/products/:id/variants/:variant_id":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/[variant_id]/route")',"/admin/products/:id/variants/:variant_id/images/batch":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/[variant_id]/images/batch/route")',"/admin/products/:id/variants/:variant_id/inventory-items":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/[variant_id]/inventory-items/route")',"/admin/products/:id/variants/:variant_id/inventory-items/:inventory_item_id":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/[variant_id]/inventory-items/[inventory_item_id]/route")',"/admin/products/:id/variants/batch":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/batch/route")',"/admin/products/:id/variants/inventory-items/batch":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/inventory-items/batch/route")',"/admin/products/batch":'typeof import("@medusajs/medusa/api/admin/products/batch/route")',"/admin/products/export":'typeof import("@medusajs/medusa/api/admin/products/export/route")',"/admin/products/import":'typeof import("@medusajs/medusa/api/admin/products/import/route")',"/admin/products/import/:transaction_id/confirm":'typeof import("@medusajs/medusa/api/admin/products/import/[transaction_id]/confirm/route")',"/admin/products/imports":'typeof import("@medusajs/medusa/api/admin/products/imports/route")',"/admin/products/imports/:transaction_id/confirm":'typeof import("@medusajs/medusa/api/admin/products/imports/[transaction_id]/confirm/route")',"/admin/promotions":'typeof import("@medusajs/medusa/api/admin/promotions/route")',"/admin/promotions/:id":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/route")',"/admin/promotions/:id/:rule_type":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/[rule_type]/route")',"/admin/promotions/:id/buy-rules/batch":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/buy-rules/batch/route")',"/admin/promotions/:id/rules/batch":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/rules/batch/route")',"/admin/promotions/:id/target-rules/batch":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/target-rules/batch/route")',"/admin/promotions/rule-attribute-options/:rule_type":'typeof import("@medusajs/medusa/api/admin/promotions/rule-attribute-options/[rule_type]/route")',"/admin/promotions/rule-value-options/:rule_type/:rule_attribute_id":'typeof import("@medusajs/medusa/api/admin/promotions/rule-value-options/[rule_type]/[rule_attribute_id]/route")',"/admin/rbac/policies":'typeof import("@medusajs/medusa/api/admin/rbac/policies/route")',"/admin/rbac/policies/:id":'typeof import("@medusajs/medusa/api/admin/rbac/policies/[id]/route")',"/admin/rbac/roles":'typeof import("@medusajs/medusa/api/admin/rbac/roles/route")',"/admin/rbac/roles/:id":'typeof import("@medusajs/medusa/api/admin/rbac/roles/[id]/route")',"/admin/rbac/roles/:id/policies":'typeof import("@medusajs/medusa/api/admin/rbac/roles/[id]/policies/route")',"/admin/rbac/roles/:id/policies/:policy_id":'typeof import("@medusajs/medusa/api/admin/rbac/roles/[id]/policies/[policy_id]/route")',"/admin/refund-reasons":'typeof import("@medusajs/medusa/api/admin/refund-reasons/route")',"/admin/refund-reasons/:id":'typeof import("@medusajs/medusa/api/admin/refund-reasons/[id]/route")',"/admin/regions":'typeof import("@medusajs/medusa/api/admin/regions/route")',"/admin/regions/:id":'typeof import("@medusajs/medusa/api/admin/regions/[id]/route")',"/admin/reservations":'typeof import("@medusajs/medusa/api/admin/reservations/route")',"/admin/reservations/:id":'typeof import("@medusajs/medusa/api/admin/reservations/[id]/route")',"/admin/return-reasons":'typeof import("@medusajs/medusa/api/admin/return-reasons/route")',"/admin/return-reasons/:id":'typeof import("@medusajs/medusa/api/admin/return-reasons/[id]/route")',"/admin/returns":'typeof import("@medusajs/medusa/api/admin/returns/route")',"/admin/returns/:id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/route")',"/admin/returns/:id/cancel":'typeof import("@medusajs/medusa/api/admin/returns/[id]/cancel/route")',"/admin/returns/:id/dismiss-items":'typeof import("@medusajs/medusa/api/admin/returns/[id]/dismiss-items/route")',"/admin/returns/:id/dismiss-items/:action_id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/dismiss-items/[action_id]/route")',"/admin/returns/:id/receive":'typeof import("@medusajs/medusa/api/admin/returns/[id]/receive/route")',"/admin/returns/:id/receive-items":'typeof import("@medusajs/medusa/api/admin/returns/[id]/receive-items/route")',"/admin/returns/:id/receive-items/:action_id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/receive-items/[action_id]/route")',"/admin/returns/:id/receive/confirm":'typeof import("@medusajs/medusa/api/admin/returns/[id]/receive/confirm/route")',"/admin/returns/:id/request":'typeof import("@medusajs/medusa/api/admin/returns/[id]/request/route")',"/admin/returns/:id/request-items":'typeof import("@medusajs/medusa/api/admin/returns/[id]/request-items/route")',"/admin/returns/:id/request-items/:action_id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/request-items/[action_id]/route")',"/admin/returns/:id/shipping-method":'typeof import("@medusajs/medusa/api/admin/returns/[id]/shipping-method/route")',"/admin/returns/:id/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/shipping-method/[action_id]/route")',"/admin/sales-channels":'typeof import("@medusajs/medusa/api/admin/sales-channels/route")',"/admin/sales-channels/:id":'typeof import("@medusajs/medusa/api/admin/sales-channels/[id]/route")',"/admin/sales-channels/:id/products":'typeof import("@medusajs/medusa/api/admin/sales-channels/[id]/products/route")',"/admin/shipping-option-types":'typeof import("@medusajs/medusa/api/admin/shipping-option-types/route")',"/admin/shipping-option-types/:id":'typeof import("@medusajs/medusa/api/admin/shipping-option-types/[id]/route")',"/admin/shipping-options":'typeof import("@medusajs/medusa/api/admin/shipping-options/route")',"/admin/shipping-options/:id":'typeof import("@medusajs/medusa/api/admin/shipping-options/[id]/route")',"/admin/shipping-options/:id/rules/batch":'typeof import("@medusajs/medusa/api/admin/shipping-options/[id]/rules/batch/route")',"/admin/shipping-profiles":'typeof import("@medusajs/medusa/api/admin/shipping-profiles/route")',"/admin/shipping-profiles/:id":'typeof import("@medusajs/medusa/api/admin/shipping-profiles/[id]/route")',"/admin/stock-locations":'typeof import("@medusajs/medusa/api/admin/stock-locations/route")',"/admin/stock-locations/:id":'typeof import("@medusajs/medusa/api/admin/stock-locations/[id]/route")',"/admin/stock-locations/:id/fulfillment-providers":'typeof import("@medusajs/medusa/api/admin/stock-locations/[id]/fulfillment-providers/route")',"/admin/stock-locations/:id/fulfillment-sets":'typeof import("@medusajs/medusa/api/admin/stock-locations/[id]/fulfillment-sets/route")',"/admin/stock-locations/:id/sales-channels":'typeof import("@medusajs/medusa/api/admin/stock-locations/[id]/sales-channels/route")',"/admin/stores":'typeof import("@medusajs/medusa/api/admin/stores/route")',"/admin/stores/:id":'typeof import("@medusajs/medusa/api/admin/stores/[id]/route")',"/admin/tax-providers":'typeof import("@medusajs/medusa/api/admin/tax-providers/route")',"/admin/tax-rates":'typeof import("@medusajs/medusa/api/admin/tax-rates/route")',"/admin/tax-rates/:id":'typeof import("@medusajs/medusa/api/admin/tax-rates/[id]/route")',"/admin/tax-rates/:id/rules":'typeof import("@medusajs/medusa/api/admin/tax-rates/[id]/rules/route")',"/admin/tax-rates/:id/rules/:rule_id":'typeof import("@medusajs/medusa/api/admin/tax-rates/[id]/rules/[rule_id]/route")',"/admin/tax-regions":'typeof import("@medusajs/medusa/api/admin/tax-regions/route")',"/admin/tax-regions/:id":'typeof import("@medusajs/medusa/api/admin/tax-regions/[id]/route")',"/admin/translations":'typeof import("@medusajs/medusa/api/admin/translations/route")',"/admin/translations/batch":'typeof import("@medusajs/medusa/api/admin/translations/batch/route")',"/admin/translations/entities":'typeof import("@medusajs/medusa/api/admin/translations/entities/route")',"/admin/translations/settings":'typeof import("@medusajs/medusa/api/admin/translations/settings/route")',"/admin/translations/settings/batch":'typeof import("@medusajs/medusa/api/admin/translations/settings/batch/route")',"/admin/translations/statistics":'typeof import("@medusajs/medusa/api/admin/translations/statistics/route")',"/admin/uploads":'typeof import("@medusajs/medusa/api/admin/uploads/route")',"/admin/uploads/:id":'typeof import("@medusajs/medusa/api/admin/uploads/[id]/route")',"/admin/uploads/presigned-urls":'typeof import("@medusajs/medusa/api/admin/uploads/presigned-urls/route")',"/admin/users":'typeof import("@medusajs/medusa/api/admin/users/route")',"/admin/users/:id":'typeof import("@medusajs/medusa/api/admin/users/[id]/route")',"/admin/users/me":'typeof import("@medusajs/medusa/api/admin/users/me/route")',"/admin/views/:entity/columns":'typeof import("@medusajs/medusa/api/admin/views/[entity]/columns/route")',"/admin/views/:entity/configurations":'typeof import("@medusajs/medusa/api/admin/views/[entity]/configurations/route")',"/admin/views/:entity/configurations/:id":'typeof import("@medusajs/medusa/api/admin/views/[entity]/configurations/[id]/route")',"/admin/views/:entity/configurations/active":'typeof import("@medusajs/medusa/api/admin/views/[entity]/configurations/active/route")',"/admin/workflows-executions":'typeof import("@medusajs/medusa/api/admin/workflows-executions/route")',"/admin/workflows-executions/:id":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[id]/route")',"/admin/workflows-executions/:workflow_id/:transaction_id":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/[transaction_id]/route")',"/admin/workflows-executions/:workflow_id/:transaction_id/:step_id/subscribe":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/[transaction_id]/[step_id]/subscribe/route")',"/admin/workflows-executions/:workflow_id/run":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/run/route")',"/admin/workflows-executions/:workflow_id/steps/failure":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/steps/failure/route")',"/admin/workflows-executions/:workflow_id/steps/success":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/steps/success/route")',"/admin/workflows-executions/:workflow_id/subscribe":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/subscribe/route")',"/auth/:actor_type/:auth_provider":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/route")',"/auth/:actor_type/:auth_provider/callback":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/callback/route")',"/auth/:actor_type/:auth_provider/register":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/register/route")',"/auth/:actor_type/:auth_provider/reset-password":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/reset-password/route")',"/auth/:actor_type/:auth_provider/update":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/update/route")',"/auth/session":'typeof import("@medusajs/medusa/api/auth/session/route")',"/auth/token/refresh":'typeof import("@medusajs/medusa/api/auth/token/refresh/route")',"/store/carts":'typeof import("@medusajs/medusa/api/store/carts/route")',"/store/carts/:id":'typeof import("@medusajs/medusa/api/store/carts/[id]/route")',"/store/carts/:id/complete":'typeof import("@medusajs/medusa/api/store/carts/[id]/complete/route")',"/store/carts/:id/customer":'typeof import("@medusajs/medusa/api/store/carts/[id]/customer/route")',"/store/carts/:id/line-items":'typeof import("@medusajs/medusa/api/store/carts/[id]/line-items/route")',"/store/carts/:id/line-items/:line_id":'typeof import("@medusajs/medusa/api/store/carts/[id]/line-items/[line_id]/route")',"/store/carts/:id/promotions":'typeof import("@medusajs/medusa/api/store/carts/[id]/promotions/route")',"/store/carts/:id/shipping-methods":'typeof import("@medusajs/medusa/api/store/carts/[id]/shipping-methods/route")',"/store/carts/:id/taxes":'typeof import("@medusajs/medusa/api/store/carts/[id]/taxes/route")',"/store/collections":'typeof import("@medusajs/medusa/api/store/collections/route")',"/store/collections/:id":'typeof import("@medusajs/medusa/api/store/collections/[id]/route")',"/store/currencies":'typeof import("@medusajs/medusa/api/store/currencies/route")',"/store/currencies/:code":'typeof import("@medusajs/medusa/api/store/currencies/[code]/route")',"/store/customers":'typeof import("@medusajs/medusa/api/store/customers/route")',"/store/customers/me":'typeof import("@medusajs/medusa/api/store/customers/me/route")',"/store/customers/me/addresses":'typeof import("@medusajs/medusa/api/store/customers/me/addresses/route")',"/store/customers/me/addresses/:address_id":'typeof import("@medusajs/medusa/api/store/customers/me/addresses/[address_id]/route")',"/store/locales":'typeof import("@medusajs/medusa/api/store/locales/route")',"/store/orders":'typeof import("@medusajs/medusa/api/store/orders/route")',"/store/orders/:id":'typeof import("@medusajs/medusa/api/store/orders/[id]/route")',"/store/orders/:id/transfer/accept":'typeof import("@medusajs/medusa/api/store/orders/[id]/transfer/accept/route")',"/store/orders/:id/transfer/cancel":'typeof import("@medusajs/medusa/api/store/orders/[id]/transfer/cancel/route")',"/store/orders/:id/transfer/decline":'typeof import("@medusajs/medusa/api/store/orders/[id]/transfer/decline/route")',"/store/orders/:id/transfer/request":'typeof import("@medusajs/medusa/api/store/orders/[id]/transfer/request/route")',"/store/payment-collections":'typeof import("@medusajs/medusa/api/store/payment-collections/route")',"/store/payment-collections/:id/payment-sessions":'typeof import("@medusajs/medusa/api/store/payment-collections/[id]/payment-sessions/route")',"/store/payment-providers":'typeof import("@medusajs/medusa/api/store/payment-providers/route")',"/store/product-categories":'typeof import("@medusajs/medusa/api/store/product-categories/route")',"/store/product-categories/:id":'typeof import("@medusajs/medusa/api/store/product-categories/[id]/route")',"/store/product-tags":'typeof import("@medusajs/medusa/api/store/product-tags/route")',"/store/product-tags/:id":'typeof import("@medusajs/medusa/api/store/product-tags/[id]/route")',"/store/product-types":'typeof import("@medusajs/medusa/api/store/product-types/route")',"/store/product-types/:id":'typeof import("@medusajs/medusa/api/store/product-types/[id]/route")',"/store/product-variants":'typeof import("@medusajs/medusa/api/store/product-variants/route")',"/store/product-variants/:id":'typeof import("@medusajs/medusa/api/store/product-variants/[id]/route")',"/store/products":'typeof import("@medusajs/medusa/api/store/products/route")',"/store/products/:id":'typeof import("@medusajs/medusa/api/store/products/[id]/route")',"/store/regions":'typeof import("@medusajs/medusa/api/store/regions/route")',"/store/regions/:id":'typeof import("@medusajs/medusa/api/store/regions/[id]/route")',"/store/return-reasons":'typeof import("@medusajs/medusa/api/store/return-reasons/route")',"/store/return-reasons/:id":'typeof import("@medusajs/medusa/api/store/return-reasons/[id]/route")',"/store/returns":'typeof import("@medusajs/medusa/api/store/returns/route")',"/store/shipping-options":'typeof import("@medusajs/medusa/api/store/shipping-options/route")',"/store/shipping-options/:id/calculate":'typeof import("@medusajs/medusa/api/store/shipping-options/[id]/calculate/route")'},xr={"/admin/commission-rates":'typeof import("@mercurjs/core-plugin/api/admin/commission-rates/route")',"/admin/commission-rates/:id":'typeof import("@mercurjs/core-plugin/api/admin/commission-rates/[id]/route")',"/admin/commission-rates/:id/rules":'typeof import("@mercurjs/core-plugin/api/admin/commission-rates/[id]/rules/route")',"/admin/order-groups":'typeof import("@mercurjs/core-plugin/api/admin/order-groups/route")',"/admin/order-groups/:id":'typeof import("@mercurjs/core-plugin/api/admin/order-groups/[id]/route")',"/admin/payouts":'typeof import("@mercurjs/core-plugin/api/admin/payouts/route")',"/admin/payouts/:id":'typeof import("@mercurjs/core-plugin/api/admin/payouts/[id]/route")',"/admin/orders":'typeof import("@mercurjs/core-plugin/api/admin/orders/route")',"/admin/products":'typeof import("@mercurjs/core-plugin/api/admin/products/route")',"/admin/invites/accept":'typeof import("@mercurjs/core-plugin/api/admin/invites/accept/route")',"/admin/sellers":'typeof import("@mercurjs/core-plugin/api/admin/sellers/route")',"/admin/sellers/invite":'typeof import("@mercurjs/core-plugin/api/admin/sellers/invite/route")',"/admin/sellers/:id":'typeof import("@mercurjs/core-plugin/api/admin/sellers/[id]/route")',"/store/carts/:id/complete":'typeof import("@mercurjs/core-plugin/api/store/carts/[id]/complete/route")',"/store/carts/:id/promotions":'typeof import("@mercurjs/core-plugin/api/store/carts/[id]/promotions/route")',"/store/carts/:id/shipping-methods":'typeof import("@mercurjs/core-plugin/api/store/carts/[id]/shipping-methods/route")',"/store/order-groups":'typeof import("@mercurjs/core-plugin/api/store/order-groups/route")',"/store/order-groups/:id":'typeof import("@mercurjs/core-plugin/api/store/order-groups/[id]/route")',"/store/sellers":'typeof import("@mercurjs/core-plugin/api/store/sellers/route")',"/store/sellers/:id":'typeof import("@mercurjs/core-plugin/api/store/sellers/[id]/route")',"/store/shipping-options":'typeof import("@mercurjs/core-plugin/api/store/shipping-options/route")',"/vendor/campaigns":'typeof import("@mercurjs/core-plugin/api/vendor/campaigns/route")',"/vendor/campaigns/:id":'typeof import("@mercurjs/core-plugin/api/vendor/campaigns/[id]/route")',"/vendor/campaigns/:id/promotions":'typeof import("@mercurjs/core-plugin/api/vendor/campaigns/[id]/promotions/route")',"/vendor/collections":'typeof import("@mercurjs/core-plugin/api/vendor/collections/route")',"/vendor/collections/:id":'typeof import("@mercurjs/core-plugin/api/vendor/collections/[id]/route")',"/vendor/collections/:id/products":'typeof import("@mercurjs/core-plugin/api/vendor/collections/[id]/products/route")',"/vendor/currencies":'typeof import("@mercurjs/core-plugin/api/vendor/currencies/route")',"/vendor/currencies/:code":'typeof import("@mercurjs/core-plugin/api/vendor/currencies/[code]/route")',"/vendor/customers":'typeof import("@mercurjs/core-plugin/api/vendor/customers/route")',"/vendor/customers/:id":'typeof import("@mercurjs/core-plugin/api/vendor/customers/[id]/route")',"/vendor/fulfillment-sets/:id":'typeof import("@mercurjs/core-plugin/api/vendor/fulfillment-sets/[id]/route")',"/vendor/fulfillment-sets/:id/service-zones":'typeof import("@mercurjs/core-plugin/api/vendor/fulfillment-sets/[id]/service-zones/route")',"/vendor/fulfillment-sets/:id/service-zones/:zone_id":'typeof import("@mercurjs/core-plugin/api/vendor/fulfillment-sets/[id]/service-zones/[zone_id]/route")',"/vendor/inventory-items":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/route")',"/vendor/inventory-items/:id":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/[id]/route")',"/vendor/inventory-items/:id/location-levels":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/[id]/location-levels/route")',"/vendor/inventory-items/:id/location-levels/:location_id":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/[id]/location-levels/[location_id]/route")',"/vendor/inventory-items/:id/location-levels/batch":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/[id]/location-levels/batch/route")',"/vendor/orders":'typeof import("@mercurjs/core-plugin/api/vendor/orders/route")',"/vendor/orders/:id":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/route")',"/vendor/orders/:id/cancel":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/cancel/route")',"/vendor/orders/:id/changes":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/changes/route")',"/vendor/orders/:id/complete":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/complete/route")',"/vendor/orders/:id/fulfillments":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/fulfillments/route")',"/vendor/orders/:id/fulfillments/:fulfillment_id/cancel":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/fulfillments/[fulfillment_id]/cancel/route")',"/vendor/orders/:id/fulfillments/:fulfillment_id/mark-as-delivered":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/fulfillments/[fulfillment_id]/mark-as-delivered/route")',"/vendor/orders/:id/fulfillments/:fulfillment_id/shipments":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/fulfillments/[fulfillment_id]/shipments/route")',"/vendor/orders/:id/preview":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/preview/route")',"/vendor/payments":'typeof import("@mercurjs/core-plugin/api/vendor/payments/route")',"/vendor/payments/:id":'typeof import("@mercurjs/core-plugin/api/vendor/payments/[id]/route")',"/vendor/payments/:id/capture":'typeof import("@mercurjs/core-plugin/api/vendor/payments/[id]/capture/route")',"/vendor/payments/:id/refund":'typeof import("@mercurjs/core-plugin/api/vendor/payments/[id]/refund/route")',"/vendor/payments/payment-providers":'typeof import("@mercurjs/core-plugin/api/vendor/payments/payment-providers/route")',"/vendor/payout-accounts":'typeof import("@mercurjs/core-plugin/api/vendor/payout-accounts/route")',"/vendor/payout-accounts/:id":'typeof import("@mercurjs/core-plugin/api/vendor/payout-accounts/[id]/route")',"/vendor/payout-accounts/:id/onboarding":'typeof import("@mercurjs/core-plugin/api/vendor/payout-accounts/[id]/onboarding/route")',"/vendor/payouts":'typeof import("@mercurjs/core-plugin/api/vendor/payouts/route")',"/vendor/payouts/:id":'typeof import("@mercurjs/core-plugin/api/vendor/payouts/[id]/route")',"/vendor/price-lists":'typeof import("@mercurjs/core-plugin/api/vendor/price-lists/route")',"/vendor/price-lists/:id":'typeof import("@mercurjs/core-plugin/api/vendor/price-lists/[id]/route")',"/vendor/price-lists/:id/products":'typeof import("@mercurjs/core-plugin/api/vendor/price-lists/[id]/products/route")',"/vendor/price-preferences":'typeof import("@mercurjs/core-plugin/api/vendor/price-preferences/route")',"/vendor/price-preferences/:id":'typeof import("@mercurjs/core-plugin/api/vendor/price-preferences/[id]/route")',"/vendor/product-categories":'typeof import("@mercurjs/core-plugin/api/vendor/product-categories/route")',"/vendor/product-categories/:id":'typeof import("@mercurjs/core-plugin/api/vendor/product-categories/[id]/route")',"/vendor/product-categories/:id/products":'typeof import("@mercurjs/core-plugin/api/vendor/product-categories/[id]/products/route")',"/vendor/product-tags":'typeof import("@mercurjs/core-plugin/api/vendor/product-tags/route")',"/vendor/product-tags/:id":'typeof import("@mercurjs/core-plugin/api/vendor/product-tags/[id]/route")',"/vendor/product-types":'typeof import("@mercurjs/core-plugin/api/vendor/product-types/route")',"/vendor/product-types/:id":'typeof import("@mercurjs/core-plugin/api/vendor/product-types/[id]/route")',"/vendor/products":'typeof import("@mercurjs/core-plugin/api/vendor/products/route")',"/vendor/products/:id":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/route")',"/vendor/products/:id/options":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/options/route")',"/vendor/products/:id/options/:option_id":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/options/[option_id]/route")',"/vendor/products/:id/variants":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/variants/route")',"/vendor/products/:id/variants/:variant_id":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/variants/[variant_id]/route")',"/vendor/promotions":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/route")',"/vendor/promotions/:id":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/route")',"/vendor/promotions/:id/:rule_type":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/[rule_type]/route")',"/vendor/promotions/:id/buy-rules/batch":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/buy-rules/batch/route")',"/vendor/promotions/:id/rules/batch":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/rules/batch/route")',"/vendor/promotions/:id/target-rules/batch":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/target-rules/batch/route")',"/vendor/promotions/rule-attribute-options/:rule_type":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/rule-attribute-options/[rule_type]/route")',"/vendor/promotions/rule-value-options/:rule_type/:rule_attribute_id":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/rule-value-options/[rule_type]/[rule_attribute_id]/route")',"/vendor/refund-reasons":'typeof import("@mercurjs/core-plugin/api/vendor/refund-reasons/route")',"/vendor/refund-reasons/:id":'typeof import("@mercurjs/core-plugin/api/vendor/refund-reasons/[id]/route")',"/vendor/regions":'typeof import("@mercurjs/core-plugin/api/vendor/regions/route")',"/vendor/regions/:id":'typeof import("@mercurjs/core-plugin/api/vendor/regions/[id]/route")',"/vendor/return-reasons":'typeof import("@mercurjs/core-plugin/api/vendor/return-reasons/route")',"/vendor/return-reasons/:id":'typeof import("@mercurjs/core-plugin/api/vendor/return-reasons/[id]/route")',"/vendor/returns":'typeof import("@mercurjs/core-plugin/api/vendor/returns/route")',"/vendor/returns/:id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/route")',"/vendor/returns/:id/cancel":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/cancel/route")',"/vendor/returns/:id/dismiss-items":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/dismiss-items/route")',"/vendor/returns/:id/dismiss-items/:action_id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/dismiss-items/[action_id]/route")',"/vendor/returns/:id/receive":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/receive/route")',"/vendor/returns/:id/receive-items":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/receive-items/route")',"/vendor/returns/:id/receive-items/:action_id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/receive-items/[action_id]/route")',"/vendor/returns/:id/receive/confirm":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/receive/confirm/route")',"/vendor/returns/:id/request":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/request/route")',"/vendor/returns/:id/request-items":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/request-items/route")',"/vendor/returns/:id/request-items/:action_id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/request-items/[action_id]/route")',"/vendor/returns/:id/shipping-method":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/shipping-method/route")',"/vendor/returns/:id/shipping-method/:action_id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/shipping-method/[action_id]/route")',"/vendor/sales-channels":'typeof import("@mercurjs/core-plugin/api/vendor/sales-channels/route")',"/vendor/sales-channels/:id":'typeof import("@mercurjs/core-plugin/api/vendor/sales-channels/[id]/route")',"/vendor/sales-channels/:id/products":'typeof import("@mercurjs/core-plugin/api/vendor/sales-channels/[id]/products/route")',"/vendor/sellers":'typeof import("@mercurjs/core-plugin/api/vendor/sellers/route")',"/vendor/sellers/me":'typeof import("@mercurjs/core-plugin/api/vendor/sellers/me/route")',"/vendor/shipping-option-types":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-option-types/route")',"/vendor/shipping-option-types/:id":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-option-types/[id]/route")',"/vendor/shipping-options":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-options/route")',"/vendor/shipping-options/:id":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-options/[id]/route")',"/vendor/shipping-options/:id/rules/batch":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-options/[id]/rules/batch/route")',"/vendor/shipping-profiles":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-profiles/route")',"/vendor/shipping-profiles/:id":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-profiles/[id]/route")',"/vendor/stock-locations":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/route")',"/vendor/stock-locations/:id":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/[id]/route")',"/vendor/stock-locations/:id/fulfillment-providers":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/[id]/fulfillment-providers/route")',"/vendor/stock-locations/:id/fulfillment-sets":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/[id]/fulfillment-sets/route")',"/vendor/stock-locations/:id/sales-channels":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/[id]/sales-channels/route")',"/vendor/uploads":'typeof import("@mercurjs/core-plugin/api/vendor/uploads/route")'};async function ht(e,t={}){let{pathnameFilter:r,ignoreFilter:i,ignorePartFilter:o,sortPathnames:s=true}=t,n=[],m=[e];for(;m.length>0;){let p=await Promise.all(m.map(async a=>{let c={directories:[],pathnames:[]};try{let u=await M__default.readdir(a,{withFileTypes:!0});for(let f of u){if(o&&o(f.name))continue;let y=R__default.join(a,f.name);i&&i(y)||(f.isDirectory()?c.directories.push(y):(!r||r(y))&&c.pathnames.push(y));}}catch(u){if(u.code!=="ENOENT"||a===e)throw u;return null}return c}));m=[];for(let a of p)a&&(m.push(...a.directories),n.push(...a.pathnames));}return s&&n.sort(),n}async function Ye(e){return await M__default.stat(e).catch(()=>null)!==null}async function Je(e){await Ye(e)||await M__default.mkdir(e,{recursive:true});}function ue(e){return e.replace(/\\/g,"/")}function Ee(e){return e.split("/").reduce((r,i)=>{if(!i||te.test(i))return r;if(i.startsWith("[")&&i.endsWith("]")){let o=i.slice(1,-1);return `${r}/:${o}`}return `${r}/${i}`},"")||"/"}async function vt(e){return await Ye(e)?(await ht(e,{pathnameFilter:i=>te.test(i),ignorePartFilter:i=>i.startsWith("_")||i==="node_modules"})).map(i=>{let o=R__default.relative(e,i);return {filePath:ue(o),route:Ee(ue(o))}}):[]}function wt(e){return e.replace(/[-_]+(.)?/g,(t,r)=>r?r.toUpperCase():"").replace(/^[A-Z]/,t=>t.toLowerCase())}function Yo(e){return `../../src/api/${e.replace(/\.ts$/,"")}`}function Jo(e){return e.startsWith(":")?`$${wt(e.slice(1))}`:wt(e)}function kr(){return {children:new Map}}function Ko(e){let t=kr();for(let[r,i]of e){let o=r.split("/").filter(Boolean),s=t;for(let n of o){let m=Jo(n);s.children.has(m)||s.children.set(m,kr()),s=s.children.get(m);}s.importType=i;}return t}function Sr(e,t=" "){let r=[];if(e.importType&&r.push(e.importType),e.children.size>0){let i=[];for(let[o,s]of e.children){let n=Sr(s,t+" ");i.push(`${t} ${o}: ${n}`);}r.push(`{
27
+ `);}async function yr(e,t,r){if(r={overwrite:false,silent:false,yes:false,...r},!e.length)return;let i=v("Checking registry.",{silent:r.silent})?.start(),o=await pt(e,me(t));if(!o)return i?.fail(),j(new Error("Failed to fetch items from registry."));i?.succeed();let{filesCreated:s,filesUpdated:n}=await gr(o.files,t,{overwrite:r.overwrite,silent:r.silent,path:r.path,yes:r.yes});(s.length||n.length)&&await pr(o.dependencies,o.devDependencies,t,{silent:r.silent}),o.docs&&a.info(o.docs);}z.object({cwd:z.string(),yes:z.boolean(),defaults:z.boolean(),silent:z.boolean()});async function hr(e){let t={},r=R__default.resolve(e.cwd);existsSync(r)||(t.MISSING_DIR=true);let i=await E(r);return {errors:t,projectInfo:i}}var wr=join(homedir(),".mercur"),ut=join(wr,"config.json"),lt={telemetry_enabled:true,telemetry_email:null,notice_shown:false},ft=class{get(t){return this.read()[t]}set(t,r){let i=this.read();i[t]=r,this.write(i);}read(){try{if(!existsSync(ut))return {...lt};let t=readFileSync(ut,"utf-8"),r=JSON.parse(t);return {...lt,...r}}catch{return {...lt}}}write(t){try{mkdirSync(wr,{recursive:!0}),writeFileSync(ut,JSON.stringify(t,null,2)+`
28
+ `,{mode:384});}catch{}}},M=new ft;var le=e=>Function("mm","return import(mm)")(e);function Po(){let e=(...t)=>t.some(r=>!!process.env[r]);return e("MEDUSA_CLOUD_ENVIRONMENT_HANDLE","MEDUSA_CLOUD_SANDBOX_HANDLE","MEDUSA_CLOUD_API_KEY")?"medusa-cloud":e("RENDER","RENDER_URL","RENDER_INTERNAL_HOSTNAME","RENDER_SERVICE_ID")?"render":e("FLY_APP_NAME","FLY_REGION","FLY_ALLOC_ID")?"fly-io":e("RAILWAY_STATIC_URL","RAILWAY_ENVIRONMENT_NAME")?"railway":e("DYNO","HEROKU_APP_NAME")?"heroku":e("DO_DEPLOYMENT_ID","DO_APP_NAME","DIGITALOCEAN")?"digitalocean":e("KOYEB","KOYEB_DEPLOYMENT_ID","KOYEB_APP_NAME")?"koyeb":null}async function br(){try{let e=await le("os"),t=e.cpus();return {deploymentVendor:Po(),systemPlatform:e.platform(),systemRelease:e.release(),systemArchitecture:e.arch(),cpuCount:t.length,cpuModel:t.length?t[0].model:null,cpuSpeed:t.length?t[0].speed:null,memory:e.totalmem(),isWSL:await To(),isDocker:await Rr(),isTTY:typeof process<"u"&&process.stdout?process.stdout.isTTY:null}}catch{return {systemPlatform:null,systemRelease:null,systemArchitecture:null,cpuCount:null,cpuModel:null,cpuSpeed:null,memory:null,isWSL:null,isDocker:null,isTTY:null}}}async function To(){try{if(typeof process>"u"||process?.platform!=="linux")return !1;let e=await le("fs");return (await le("os")).release().toLowerCase().includes("microsoft")?!await jr():e.readFileSync("/proc/version","utf8").toLowerCase().includes("microsoft")?!await jr():!1}catch{return false}}var $o=async()=>{try{return (await le("fs")).statSync("/run/.containerenv"),!0}catch{return false}};async function Rr(){return await Do()||await No()}async function Do(){try{return (await le("fs")).statSync("/.dockerenv"),!0}catch{return false}}async function No(){try{return (await le("fs")).readFileSync("/proc/self/cgroup","utf8").includes("docker")}catch{return false}}async function jr(){return await $o()||await Rr()}var gt=e=>createHash("sha256").update(e).digest("base64");var Ao=process.env.MERCUR_TELEMETRY_PROXY_URL||"https://telemetry.mercurjs.com/api/v1/events",xr=e=>{M.set("telemetry_email",e);},_r=e=>{M.set("telemetry_enabled",e);},He="https://docs.mercurjs.com/v2/telemetry",H=()=>{M.get("notice_shown")||(M.set("notice_shown",true),process.env.MERCUR_DISABLE_TELEMETRY!=="true"&&console.error(["","Mercur collects anonymous usage data to improve the CLI experience.",`You can disable this at any time by running: ${f.info("mercurjs telemetry --disable")}`,`Or by setting ${f.info("MERCUR_DISABLE_TELEMETRY=true")}`,`Learn more: ${f.info(He)}`,""].join(`
29
+ `)));},Lo=()=>M.get("telemetry_enabled")&&process.env.MERCUR_DISABLE_TELEMETRY!=="true",T=async(e,t)=>{try{if(!Lo())return;let r=await E(t.cwd),{projectId:i}=zo(r.packageJson),o={nodeEnv:Mo(),nodeVersion:process.version,mercurVersion:r.mercurVersion,medusaVersion:r.medusaVersion,isSrcDir:r.isSrcDir,aliasPrefix:r.aliasPrefix,config:await b(t.cwd),projectId:i,systemInfo:await br(),packageManager:await A(t.cwd),email:Bo()};await fetch(Ao,{body:JSON.stringify({...o,...e}),headers:{"Content-Type":"application/json"},method:"post"});}catch{}};function Mo(){return process.env.NODE_ENV||"development"}var Uo=()=>{try{let e=execSync("git config --local --get remote.origin.url",{stdio:"pipe",timeout:1e3});return String(e).trim()}catch{return null}},zo=e=>{let t=Uo();if(t)return {projectId:gt(t)};let r=process.cwd();return {projectId:gt(r)}},Bo=()=>M.get("telemetry_email")||void 0;var Vo=z.object({cwd:z.string(),yes:z.boolean(),defaults:z.boolean(),silent:z.boolean()}),Er=new Command().name("init").description("initialize your project and install dependencies").option("-y, --yes","skip confirmation prompt.",true).option("-d, --defaults","use default configuration.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-s, --silent","mute output.",false).action(async e=>{try{H();let t=Vo.parse({cwd:R__default.resolve(e.cwd),...e});await ht(t),a.log(`${f.success("Success!")} Project initialization completed.
30
+ You may now add blocks.`),a.break(),await T({type:"init",payload:{outcome:"success"}},{cwd:t.cwd});}catch(t){a.break(),j(t);}finally{x();}});async function ht(e){await hr(e);let t=await b(e.cwd),r=t?await qo(t,e):await Yo(e);if(!e.yes){let{proceed:s}=await Pe({type:"confirm",name:"proceed",message:`Write configuration to ${f.info("blocks.json")}. Proceed?`,initial:true});s||process.exit(0);}let i=v("Writing blocks.json.").start(),o=R__default.resolve(e.cwd,"blocks.json");return r.registries=Object.fromEntries(Object.entries(r.registries||{}).filter(([s])=>!Object.keys(C).includes(s))),await promises.writeFile(o,`${JSON.stringify(r,null,2)}
31
+ `,"utf8"),i.succeed(),await ot(e.cwd,r)}async function Yo(e){if(e.defaults)return W.parse({$schema:Fe,aliases:{api:"packages/api/src",vendor:"apps/vendor/src",admin:"apps/admin/src"},registries:C});a.info("");let t=await Pe([{type:"text",name:"api",message:`Configure the import alias for ${f.info("api")}:`,initial:"packages/api/src"},{type:"text",name:"vendor",message:`Configure the import alias for ${f.info("vendor")}:`,initial:"apps/vendor/src"},{type:"text",name:"admin",message:`Configure the import alias for ${f.info("admin")}:`,initial:"apps/admin/src"}],{onCancel:()=>{process.exit(0);}});return W.parse({$schema:Fe,aliases:{api:t.api??"packages/api/src",vendor:t.vendor??"apps/vendor/src",admin:t.admin??"apps/admin/src"},registries:C})}async function qo(e,t){if(t.defaults)return W.parse({$schema:Fe,aliases:{api:"packages/api/src",vendor:"apps/vendor/src",admin:"apps/admin/src"},registries:C});let r=await Pe([{type:"text",name:"api",message:`Configure the import alias for ${f.info("api")}:`,initial:e.aliases.api},{type:"text",name:"vendor",message:`Configure the import alias for ${f.info("vendor")}:`,initial:e.aliases.vendor},{type:"text",name:"admin",message:`Configure the import alias for ${f.info("admin")}:`,initial:e.aliases.admin}],{onCancel:()=>{process.exit(0);}});return W.parse({$schema:e.$schema,aliases:{api:r.api??e.aliases.api,vendor:r.vendor??e.aliases.vendor,admin:r.admin??e.aliases.admin}})}var Zo=z.object({blocks:z.array(z.string()).optional(),yes:z.boolean(),overwrite:z.boolean(),cwd:z.string(),silent:z.boolean()}),Sr=new Command().name("add").description("add blocks to your project").argument("[blocks...]","names of blocks to add").option("-y, --yes","skip confirmation prompt.",false).option("-o, --overwrite","overwrite existing files.",false).option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-s, --silent","mute output.",false).action(async(e,t)=>{try{H();let r=Zo.parse({blocks:e,cwd:R__default.resolve(t.cwd),...t}),i=await b(r.cwd);i||(i=G({resolvedPaths:{cwd:r.cwd}})),r.blocks?.length||(a.error("Please specify at least one item to add."),process.exit(1));let{errors:o}=await Jt(r);if(o[I]){let{proceed:s}=await Pe({type:"confirm",name:"proceed",message:`You need to create a ${f.info("blocks.json")} file to add items. Proceed?`,initial:!0});s||(a.break(),process.exit(1)),i=await ht({cwd:r.cwd,yes:!0,defaults:!1,silent:r.silent});}if(!i)throw new Error(`Failed to read config at ${f.info(r.cwd)}.`);await yr(r.blocks,i,{overwrite:r.overwrite,silent:r.silent,yes:r.yes,path:r.cwd}),await T({type:"add",payload:{outcome:"success",blocks:r.blocks}},{cwd:r.cwd});}catch(r){a.break(),j(r);}finally{x();}});async function Ir(e){let t={},r={cwd:e.cwd,registryFile:R__default.resolve(e.cwd,e.registryFile),outputDir:R__default.resolve(e.cwd,e.outputDir)};if(!L.existsSync(r.registryFile))return t[B]=true,{errors:t,resolvePaths:null,config:null};if(!L.existsSync(R__default.resolve(e.cwd,"blocks.json")))return t[I]=true,{errors:t,resolvePaths:null,config:null};await L.mkdir(r.outputDir,{recursive:true});try{let i=await b(e.cwd);return {errors:t,config:i,resolvePaths:r}}catch{a.break(),a.error(`An invalid ${f.info("blocks.json")} file was found at ${f.info(e.cwd)}.
32
+ Before you can build the registry, you must create a valid ${f.info("blocks.json")} file by running the ${f.info("init")} command.`),a.break(),process.exit(1);}}var Xo=z.object({cwd:z.string(),registryFile:z.string(),outputDir:z.string(),verbose:z.boolean().optional().default(false)}),Cr=new Command().name("registry:build").description("builds the registry").argument("[registry]","path to registry.json file","./registry.json").option("-o, --output <path>","destination directory for json files","./r").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-v, --verbose","verbose output").action(async(e,t)=>{await es({cwd:R.resolve(t.cwd),registryFile:e,outputDir:t.output,verbose:t.verbose});});async function es(e){try{H();let t=Xo.parse(e),[{errors:r,resolvePaths:i,config:o},s]=await Promise.all([Ir(t),E(t.cwd)]);(r[I]||!s)&&(a.error(`A ${f.info("blocks.json")} file is required to build the registry. Run ${f.info("mercur init")} to create one.`),a.break(),await T({type:"build",payload:{outcome:"missing_config"}},{cwd:t.cwd}),process.exit(1)),(r[B]||!i)&&(a.error(`We could not find a registry file at ${f.info(R.resolve(t.cwd,t.registryFile))}.`),a.break(),await T({type:"build",payload:{outcome:"missing_registry_file"}},{cwd:t.cwd}),process.exit(1));let n=await U.readFile(i.registryFile,"utf-8"),m=K.safeParse(JSON.parse(n));m.success||(a.error(`Invalid registry file found at ${f.info(i.registryFile)}.`),a.break(),process.exit(1));let p=v("Building registry..."),d=await ts(m.data,o,s);for(let c of d.items)c.files=c.files?.filter((u,l,g)=>l===g.findIndex(h=>h.path===u.path)),c.dependencies&&(c.dependencies=c.dependencies.filter((u,l,g)=>l===g.findIndex(h=>h===u)));for(let c of d.items){if(!c.files)continue;p.start(`Building ${c.name}...`),c.$schema=Gt;for(let l of c.files){let g=s.isSrcDir?"src":"",h=R.resolve(i.cwd,g,l.path);try{if(!(await U.stat(h)).isFile())continue;l.content=await U.readFile(h,"utf-8");}catch(w){console.error("Error reading file in registry build:",h,w);continue}}let u=$.safeParse(c);if(!u.success){a.error(`Invalid registry item found for ${f.info(c.name)}.`);continue}await U.writeFile(R.resolve(i.outputDir,`${u.data.name}.json`),JSON.stringify(u.data,null,2));}if(await U.copyFile(i.registryFile,R.resolve(i.outputDir,"registry.json")),p.succeed("Building registry."),t.verbose){v(`The registry has ${f.info(d.items.length.toString())} items:`).succeed();for(let c of d.items){a.log(` - ${c.name}`);for(let u of c.files??[])a.log(` - ${u.path}`);}}await T({type:"build",payload:{outcome:"success"}},{cwd:t.cwd});}catch(t){a.break(),j(t);}}async function ts(e,t,r){for(let i of e.items)if(i.files?.length)for(let o of i.files){let s=await dt(o.path,t,r);s.files=s.files?.filter(n=>n.path!==o.path),s.files&&i.files.push(...s.files),s.dependencies&&(i.dependencies=i.dependencies?i.dependencies.concat(s.dependencies):s.dependencies);}return e}var Ke=".mercur/_generated",ie=/route\.(ts|js)$/,Pr={"/admin/api-keys":'typeof import("@medusajs/medusa/api/admin/api-keys/route")',"/admin/api-keys/:id":'typeof import("@medusajs/medusa/api/admin/api-keys/[id]/route")',"/admin/api-keys/:id/revoke":'typeof import("@medusajs/medusa/api/admin/api-keys/[id]/revoke/route")',"/admin/api-keys/:id/sales-channels":'typeof import("@medusajs/medusa/api/admin/api-keys/[id]/sales-channels/route")',"/admin/campaigns":'typeof import("@medusajs/medusa/api/admin/campaigns/route")',"/admin/campaigns/:id":'typeof import("@medusajs/medusa/api/admin/campaigns/[id]/route")',"/admin/campaigns/:id/promotions":'typeof import("@medusajs/medusa/api/admin/campaigns/[id]/promotions/route")',"/admin/claims":'typeof import("@medusajs/medusa/api/admin/claims/route")',"/admin/claims/:id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/route")',"/admin/claims/:id/cancel":'typeof import("@medusajs/medusa/api/admin/claims/[id]/cancel/route")',"/admin/claims/:id/claim-items":'typeof import("@medusajs/medusa/api/admin/claims/[id]/claim-items/route")',"/admin/claims/:id/claim-items/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/claim-items/[action_id]/route")',"/admin/claims/:id/inbound/items":'typeof import("@medusajs/medusa/api/admin/claims/[id]/inbound/items/route")',"/admin/claims/:id/inbound/items/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/inbound/items/[action_id]/route")',"/admin/claims/:id/inbound/shipping-method":'typeof import("@medusajs/medusa/api/admin/claims/[id]/inbound/shipping-method/route")',"/admin/claims/:id/inbound/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/inbound/shipping-method/[action_id]/route")',"/admin/claims/:id/outbound/items":'typeof import("@medusajs/medusa/api/admin/claims/[id]/outbound/items/route")',"/admin/claims/:id/outbound/items/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/outbound/items/[action_id]/route")',"/admin/claims/:id/outbound/shipping-method":'typeof import("@medusajs/medusa/api/admin/claims/[id]/outbound/shipping-method/route")',"/admin/claims/:id/outbound/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/claims/[id]/outbound/shipping-method/[action_id]/route")',"/admin/claims/:id/request":'typeof import("@medusajs/medusa/api/admin/claims/[id]/request/route")',"/admin/collections":'typeof import("@medusajs/medusa/api/admin/collections/route")',"/admin/collections/:id":'typeof import("@medusajs/medusa/api/admin/collections/[id]/route")',"/admin/collections/:id/products":'typeof import("@medusajs/medusa/api/admin/collections/[id]/products/route")',"/admin/currencies":'typeof import("@medusajs/medusa/api/admin/currencies/route")',"/admin/currencies/:code":'typeof import("@medusajs/medusa/api/admin/currencies/[code]/route")',"/admin/customer-groups":'typeof import("@medusajs/medusa/api/admin/customer-groups/route")',"/admin/customer-groups/:id":'typeof import("@medusajs/medusa/api/admin/customer-groups/[id]/route")',"/admin/customer-groups/:id/customers":'typeof import("@medusajs/medusa/api/admin/customer-groups/[id]/customers/route")',"/admin/customers":'typeof import("@medusajs/medusa/api/admin/customers/route")',"/admin/customers/:id":'typeof import("@medusajs/medusa/api/admin/customers/[id]/route")',"/admin/customers/:id/addresses":'typeof import("@medusajs/medusa/api/admin/customers/[id]/addresses/route")',"/admin/customers/:id/addresses/:address_id":'typeof import("@medusajs/medusa/api/admin/customers/[id]/addresses/[address_id]/route")',"/admin/customers/:id/customer-groups":'typeof import("@medusajs/medusa/api/admin/customers/[id]/customer-groups/route")',"/admin/draft-orders":'typeof import("@medusajs/medusa/api/admin/draft-orders/route")',"/admin/draft-orders/:id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/route")',"/admin/draft-orders/:id/convert-to-order":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/convert-to-order/route")',"/admin/draft-orders/:id/edit":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/route")',"/admin/draft-orders/:id/edit/confirm":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/confirm/route")',"/admin/draft-orders/:id/edit/items":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/items/route")',"/admin/draft-orders/:id/edit/items/:action_id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/items/[action_id]/route")',"/admin/draft-orders/:id/edit/items/item/:item_id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/items/item/[item_id]/route")',"/admin/draft-orders/:id/edit/promotions":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/promotions/route")',"/admin/draft-orders/:id/edit/request":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/request/route")',"/admin/draft-orders/:id/edit/shipping-methods":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/shipping-methods/route")',"/admin/draft-orders/:id/edit/shipping-methods/:action_id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/shipping-methods/[action_id]/route")',"/admin/draft-orders/:id/edit/shipping-methods/method/:method_id":'typeof import("@medusajs/medusa/api/admin/draft-orders/[id]/edit/shipping-methods/method/[method_id]/route")',"/admin/exchanges":'typeof import("@medusajs/medusa/api/admin/exchanges/route")',"/admin/exchanges/:id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/route")',"/admin/exchanges/:id/cancel":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/cancel/route")',"/admin/exchanges/:id/inbound/items":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/inbound/items/route")',"/admin/exchanges/:id/inbound/items/:action_id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/inbound/items/[action_id]/route")',"/admin/exchanges/:id/inbound/shipping-method":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/inbound/shipping-method/route")',"/admin/exchanges/:id/inbound/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/inbound/shipping-method/[action_id]/route")',"/admin/exchanges/:id/outbound/items":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/outbound/items/route")',"/admin/exchanges/:id/outbound/items/:action_id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/outbound/items/[action_id]/route")',"/admin/exchanges/:id/outbound/shipping-method":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/outbound/shipping-method/route")',"/admin/exchanges/:id/outbound/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/outbound/shipping-method/[action_id]/route")',"/admin/exchanges/:id/request":'typeof import("@medusajs/medusa/api/admin/exchanges/[id]/request/route")',"/admin/feature-flags":'typeof import("@medusajs/medusa/api/admin/feature-flags/route")',"/admin/fulfillment-providers":'typeof import("@medusajs/medusa/api/admin/fulfillment-providers/route")',"/admin/fulfillment-providers/:id/options":'typeof import("@medusajs/medusa/api/admin/fulfillment-providers/[id]/options/route")',"/admin/fulfillment-sets/:id":'typeof import("@medusajs/medusa/api/admin/fulfillment-sets/[id]/route")',"/admin/fulfillment-sets/:id/service-zones":'typeof import("@medusajs/medusa/api/admin/fulfillment-sets/[id]/service-zones/route")',"/admin/fulfillment-sets/:id/service-zones/:zone_id":'typeof import("@medusajs/medusa/api/admin/fulfillment-sets/[id]/service-zones/[zone_id]/route")',"/admin/fulfillments":'typeof import("@medusajs/medusa/api/admin/fulfillments/route")',"/admin/fulfillments/:id/cancel":'typeof import("@medusajs/medusa/api/admin/fulfillments/[id]/cancel/route")',"/admin/fulfillments/:id/shipment":'typeof import("@medusajs/medusa/api/admin/fulfillments/[id]/shipment/route")',"/admin/index/details":'typeof import("@medusajs/medusa/api/admin/index/details/route")',"/admin/index/sync":'typeof import("@medusajs/medusa/api/admin/index/sync/route")',"/admin/inventory-items":'typeof import("@medusajs/medusa/api/admin/inventory-items/route")',"/admin/inventory-items/:id":'typeof import("@medusajs/medusa/api/admin/inventory-items/[id]/route")',"/admin/inventory-items/:id/location-levels":'typeof import("@medusajs/medusa/api/admin/inventory-items/[id]/location-levels/route")',"/admin/inventory-items/:id/location-levels/:location_id":'typeof import("@medusajs/medusa/api/admin/inventory-items/[id]/location-levels/[location_id]/route")',"/admin/inventory-items/:id/location-levels/batch":'typeof import("@medusajs/medusa/api/admin/inventory-items/[id]/location-levels/batch/route")',"/admin/inventory-items/location-levels/batch":'typeof import("@medusajs/medusa/api/admin/inventory-items/location-levels/batch/route")',"/admin/invites":'typeof import("@medusajs/medusa/api/admin/invites/route")',"/admin/invites/:id":'typeof import("@medusajs/medusa/api/admin/invites/[id]/route")',"/admin/invites/:id/resend":'typeof import("@medusajs/medusa/api/admin/invites/[id]/resend/route")',"/admin/invites/accept":'typeof import("@medusajs/medusa/api/admin/invites/accept/route")',"/admin/locales":'typeof import("@medusajs/medusa/api/admin/locales/route")',"/admin/locales/:code":'typeof import("@medusajs/medusa/api/admin/locales/[code]/route")',"/admin/notifications":'typeof import("@medusajs/medusa/api/admin/notifications/route")',"/admin/notifications/:id":'typeof import("@medusajs/medusa/api/admin/notifications/[id]/route")',"/admin/order-changes/:id":'typeof import("@medusajs/medusa/api/admin/order-changes/[id]/route")',"/admin/order-edits":'typeof import("@medusajs/medusa/api/admin/order-edits/route")',"/admin/order-edits/:id":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/route")',"/admin/order-edits/:id/confirm":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/confirm/route")',"/admin/order-edits/:id/items":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/items/route")',"/admin/order-edits/:id/items/:action_id":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/items/[action_id]/route")',"/admin/order-edits/:id/items/item/:item_id":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/items/item/[item_id]/route")',"/admin/order-edits/:id/request":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/request/route")',"/admin/order-edits/:id/shipping-method":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/shipping-method/route")',"/admin/order-edits/:id/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/order-edits/[id]/shipping-method/[action_id]/route")',"/admin/orders":'typeof import("@medusajs/medusa/api/admin/orders/route")',"/admin/orders/:id":'typeof import("@medusajs/medusa/api/admin/orders/[id]/route")',"/admin/orders/:id/archive":'typeof import("@medusajs/medusa/api/admin/orders/[id]/archive/route")',"/admin/orders/:id/cancel":'typeof import("@medusajs/medusa/api/admin/orders/[id]/cancel/route")',"/admin/orders/:id/changes":'typeof import("@medusajs/medusa/api/admin/orders/[id]/changes/route")',"/admin/orders/:id/complete":'typeof import("@medusajs/medusa/api/admin/orders/[id]/complete/route")',"/admin/orders/:id/credit-lines":'typeof import("@medusajs/medusa/api/admin/orders/[id]/credit-lines/route")',"/admin/orders/:id/fulfillments":'typeof import("@medusajs/medusa/api/admin/orders/[id]/fulfillments/route")',"/admin/orders/:id/fulfillments/:fulfillment_id/cancel":'typeof import("@medusajs/medusa/api/admin/orders/[id]/fulfillments/[fulfillment_id]/cancel/route")',"/admin/orders/:id/fulfillments/:fulfillment_id/mark-as-delivered":'typeof import("@medusajs/medusa/api/admin/orders/[id]/fulfillments/[fulfillment_id]/mark-as-delivered/route")',"/admin/orders/:id/fulfillments/:fulfillment_id/shipments":'typeof import("@medusajs/medusa/api/admin/orders/[id]/fulfillments/[fulfillment_id]/shipments/route")',"/admin/orders/:id/line-items":'typeof import("@medusajs/medusa/api/admin/orders/[id]/line-items/route")',"/admin/orders/:id/preview":'typeof import("@medusajs/medusa/api/admin/orders/[id]/preview/route")',"/admin/orders/:id/shipping-options":'typeof import("@medusajs/medusa/api/admin/orders/[id]/shipping-options/route")',"/admin/orders/:id/transfer":'typeof import("@medusajs/medusa/api/admin/orders/[id]/transfer/route")',"/admin/orders/:id/transfer/cancel":'typeof import("@medusajs/medusa/api/admin/orders/[id]/transfer/cancel/route")',"/admin/orders/export":'typeof import("@medusajs/medusa/api/admin/orders/export/route")',"/admin/payment-collections":'typeof import("@medusajs/medusa/api/admin/payment-collections/route")',"/admin/payment-collections/:id":'typeof import("@medusajs/medusa/api/admin/payment-collections/[id]/route")',"/admin/payment-collections/:id/mark-as-paid":'typeof import("@medusajs/medusa/api/admin/payment-collections/[id]/mark-as-paid/route")',"/admin/payments":'typeof import("@medusajs/medusa/api/admin/payments/route")',"/admin/payments/:id":'typeof import("@medusajs/medusa/api/admin/payments/[id]/route")',"/admin/payments/:id/capture":'typeof import("@medusajs/medusa/api/admin/payments/[id]/capture/route")',"/admin/payments/:id/refund":'typeof import("@medusajs/medusa/api/admin/payments/[id]/refund/route")',"/admin/payments/payment-providers":'typeof import("@medusajs/medusa/api/admin/payments/payment-providers/route")',"/admin/plugins":'typeof import("@medusajs/medusa/api/admin/plugins/route")',"/admin/price-lists":'typeof import("@medusajs/medusa/api/admin/price-lists/route")',"/admin/price-lists/:id":'typeof import("@medusajs/medusa/api/admin/price-lists/[id]/route")',"/admin/price-lists/:id/prices":'typeof import("@medusajs/medusa/api/admin/price-lists/[id]/prices/route")',"/admin/price-lists/:id/prices/batch":'typeof import("@medusajs/medusa/api/admin/price-lists/[id]/prices/batch/route")',"/admin/price-lists/:id/products":'typeof import("@medusajs/medusa/api/admin/price-lists/[id]/products/route")',"/admin/price-preferences":'typeof import("@medusajs/medusa/api/admin/price-preferences/route")',"/admin/price-preferences/:id":'typeof import("@medusajs/medusa/api/admin/price-preferences/[id]/route")',"/admin/product-categories":'typeof import("@medusajs/medusa/api/admin/product-categories/route")',"/admin/product-categories/:id":'typeof import("@medusajs/medusa/api/admin/product-categories/[id]/route")',"/admin/product-categories/:id/products":'typeof import("@medusajs/medusa/api/admin/product-categories/[id]/products/route")',"/admin/product-tags":'typeof import("@medusajs/medusa/api/admin/product-tags/route")',"/admin/product-tags/:id":'typeof import("@medusajs/medusa/api/admin/product-tags/[id]/route")',"/admin/product-types":'typeof import("@medusajs/medusa/api/admin/product-types/route")',"/admin/product-types/:id":'typeof import("@medusajs/medusa/api/admin/product-types/[id]/route")',"/admin/product-variants":'typeof import("@medusajs/medusa/api/admin/product-variants/route")',"/admin/products":'typeof import("@medusajs/medusa/api/admin/products/route")',"/admin/products/:id":'typeof import("@medusajs/medusa/api/admin/products/[id]/route")',"/admin/products/:id/images/:image_id/variants/batch":'typeof import("@medusajs/medusa/api/admin/products/[id]/images/[image_id]/variants/batch/route")',"/admin/products/:id/options":'typeof import("@medusajs/medusa/api/admin/products/[id]/options/route")',"/admin/products/:id/options/:option_id":'typeof import("@medusajs/medusa/api/admin/products/[id]/options/[option_id]/route")',"/admin/products/:id/variants":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/route")',"/admin/products/:id/variants/:variant_id":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/[variant_id]/route")',"/admin/products/:id/variants/:variant_id/images/batch":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/[variant_id]/images/batch/route")',"/admin/products/:id/variants/:variant_id/inventory-items":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/[variant_id]/inventory-items/route")',"/admin/products/:id/variants/:variant_id/inventory-items/:inventory_item_id":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/[variant_id]/inventory-items/[inventory_item_id]/route")',"/admin/products/:id/variants/batch":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/batch/route")',"/admin/products/:id/variants/inventory-items/batch":'typeof import("@medusajs/medusa/api/admin/products/[id]/variants/inventory-items/batch/route")',"/admin/products/batch":'typeof import("@medusajs/medusa/api/admin/products/batch/route")',"/admin/products/export":'typeof import("@medusajs/medusa/api/admin/products/export/route")',"/admin/products/import":'typeof import("@medusajs/medusa/api/admin/products/import/route")',"/admin/products/import/:transaction_id/confirm":'typeof import("@medusajs/medusa/api/admin/products/import/[transaction_id]/confirm/route")',"/admin/products/imports":'typeof import("@medusajs/medusa/api/admin/products/imports/route")',"/admin/products/imports/:transaction_id/confirm":'typeof import("@medusajs/medusa/api/admin/products/imports/[transaction_id]/confirm/route")',"/admin/promotions":'typeof import("@medusajs/medusa/api/admin/promotions/route")',"/admin/promotions/:id":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/route")',"/admin/promotions/:id/:rule_type":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/[rule_type]/route")',"/admin/promotions/:id/buy-rules/batch":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/buy-rules/batch/route")',"/admin/promotions/:id/rules/batch":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/rules/batch/route")',"/admin/promotions/:id/target-rules/batch":'typeof import("@medusajs/medusa/api/admin/promotions/[id]/target-rules/batch/route")',"/admin/promotions/rule-attribute-options/:rule_type":'typeof import("@medusajs/medusa/api/admin/promotions/rule-attribute-options/[rule_type]/route")',"/admin/promotions/rule-value-options/:rule_type/:rule_attribute_id":'typeof import("@medusajs/medusa/api/admin/promotions/rule-value-options/[rule_type]/[rule_attribute_id]/route")',"/admin/rbac/policies":'typeof import("@medusajs/medusa/api/admin/rbac/policies/route")',"/admin/rbac/policies/:id":'typeof import("@medusajs/medusa/api/admin/rbac/policies/[id]/route")',"/admin/rbac/roles":'typeof import("@medusajs/medusa/api/admin/rbac/roles/route")',"/admin/rbac/roles/:id":'typeof import("@medusajs/medusa/api/admin/rbac/roles/[id]/route")',"/admin/rbac/roles/:id/policies":'typeof import("@medusajs/medusa/api/admin/rbac/roles/[id]/policies/route")',"/admin/rbac/roles/:id/policies/:policy_id":'typeof import("@medusajs/medusa/api/admin/rbac/roles/[id]/policies/[policy_id]/route")',"/admin/refund-reasons":'typeof import("@medusajs/medusa/api/admin/refund-reasons/route")',"/admin/refund-reasons/:id":'typeof import("@medusajs/medusa/api/admin/refund-reasons/[id]/route")',"/admin/regions":'typeof import("@medusajs/medusa/api/admin/regions/route")',"/admin/regions/:id":'typeof import("@medusajs/medusa/api/admin/regions/[id]/route")',"/admin/reservations":'typeof import("@medusajs/medusa/api/admin/reservations/route")',"/admin/reservations/:id":'typeof import("@medusajs/medusa/api/admin/reservations/[id]/route")',"/admin/return-reasons":'typeof import("@medusajs/medusa/api/admin/return-reasons/route")',"/admin/return-reasons/:id":'typeof import("@medusajs/medusa/api/admin/return-reasons/[id]/route")',"/admin/returns":'typeof import("@medusajs/medusa/api/admin/returns/route")',"/admin/returns/:id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/route")',"/admin/returns/:id/cancel":'typeof import("@medusajs/medusa/api/admin/returns/[id]/cancel/route")',"/admin/returns/:id/dismiss-items":'typeof import("@medusajs/medusa/api/admin/returns/[id]/dismiss-items/route")',"/admin/returns/:id/dismiss-items/:action_id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/dismiss-items/[action_id]/route")',"/admin/returns/:id/receive":'typeof import("@medusajs/medusa/api/admin/returns/[id]/receive/route")',"/admin/returns/:id/receive-items":'typeof import("@medusajs/medusa/api/admin/returns/[id]/receive-items/route")',"/admin/returns/:id/receive-items/:action_id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/receive-items/[action_id]/route")',"/admin/returns/:id/receive/confirm":'typeof import("@medusajs/medusa/api/admin/returns/[id]/receive/confirm/route")',"/admin/returns/:id/request":'typeof import("@medusajs/medusa/api/admin/returns/[id]/request/route")',"/admin/returns/:id/request-items":'typeof import("@medusajs/medusa/api/admin/returns/[id]/request-items/route")',"/admin/returns/:id/request-items/:action_id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/request-items/[action_id]/route")',"/admin/returns/:id/shipping-method":'typeof import("@medusajs/medusa/api/admin/returns/[id]/shipping-method/route")',"/admin/returns/:id/shipping-method/:action_id":'typeof import("@medusajs/medusa/api/admin/returns/[id]/shipping-method/[action_id]/route")',"/admin/sales-channels":'typeof import("@medusajs/medusa/api/admin/sales-channels/route")',"/admin/sales-channels/:id":'typeof import("@medusajs/medusa/api/admin/sales-channels/[id]/route")',"/admin/sales-channels/:id/products":'typeof import("@medusajs/medusa/api/admin/sales-channels/[id]/products/route")',"/admin/shipping-option-types":'typeof import("@medusajs/medusa/api/admin/shipping-option-types/route")',"/admin/shipping-option-types/:id":'typeof import("@medusajs/medusa/api/admin/shipping-option-types/[id]/route")',"/admin/shipping-options":'typeof import("@medusajs/medusa/api/admin/shipping-options/route")',"/admin/shipping-options/:id":'typeof import("@medusajs/medusa/api/admin/shipping-options/[id]/route")',"/admin/shipping-options/:id/rules/batch":'typeof import("@medusajs/medusa/api/admin/shipping-options/[id]/rules/batch/route")',"/admin/shipping-profiles":'typeof import("@medusajs/medusa/api/admin/shipping-profiles/route")',"/admin/shipping-profiles/:id":'typeof import("@medusajs/medusa/api/admin/shipping-profiles/[id]/route")',"/admin/stock-locations":'typeof import("@medusajs/medusa/api/admin/stock-locations/route")',"/admin/stock-locations/:id":'typeof import("@medusajs/medusa/api/admin/stock-locations/[id]/route")',"/admin/stock-locations/:id/fulfillment-providers":'typeof import("@medusajs/medusa/api/admin/stock-locations/[id]/fulfillment-providers/route")',"/admin/stock-locations/:id/fulfillment-sets":'typeof import("@medusajs/medusa/api/admin/stock-locations/[id]/fulfillment-sets/route")',"/admin/stock-locations/:id/sales-channels":'typeof import("@medusajs/medusa/api/admin/stock-locations/[id]/sales-channels/route")',"/admin/stores":'typeof import("@medusajs/medusa/api/admin/stores/route")',"/admin/stores/:id":'typeof import("@medusajs/medusa/api/admin/stores/[id]/route")',"/admin/tax-providers":'typeof import("@medusajs/medusa/api/admin/tax-providers/route")',"/admin/tax-rates":'typeof import("@medusajs/medusa/api/admin/tax-rates/route")',"/admin/tax-rates/:id":'typeof import("@medusajs/medusa/api/admin/tax-rates/[id]/route")',"/admin/tax-rates/:id/rules":'typeof import("@medusajs/medusa/api/admin/tax-rates/[id]/rules/route")',"/admin/tax-rates/:id/rules/:rule_id":'typeof import("@medusajs/medusa/api/admin/tax-rates/[id]/rules/[rule_id]/route")',"/admin/tax-regions":'typeof import("@medusajs/medusa/api/admin/tax-regions/route")',"/admin/tax-regions/:id":'typeof import("@medusajs/medusa/api/admin/tax-regions/[id]/route")',"/admin/translations":'typeof import("@medusajs/medusa/api/admin/translations/route")',"/admin/translations/batch":'typeof import("@medusajs/medusa/api/admin/translations/batch/route")',"/admin/translations/entities":'typeof import("@medusajs/medusa/api/admin/translations/entities/route")',"/admin/translations/settings":'typeof import("@medusajs/medusa/api/admin/translations/settings/route")',"/admin/translations/settings/batch":'typeof import("@medusajs/medusa/api/admin/translations/settings/batch/route")',"/admin/translations/statistics":'typeof import("@medusajs/medusa/api/admin/translations/statistics/route")',"/admin/uploads":'typeof import("@medusajs/medusa/api/admin/uploads/route")',"/admin/uploads/:id":'typeof import("@medusajs/medusa/api/admin/uploads/[id]/route")',"/admin/uploads/presigned-urls":'typeof import("@medusajs/medusa/api/admin/uploads/presigned-urls/route")',"/admin/users":'typeof import("@medusajs/medusa/api/admin/users/route")',"/admin/users/:id":'typeof import("@medusajs/medusa/api/admin/users/[id]/route")',"/admin/users/me":'typeof import("@medusajs/medusa/api/admin/users/me/route")',"/admin/views/:entity/columns":'typeof import("@medusajs/medusa/api/admin/views/[entity]/columns/route")',"/admin/views/:entity/configurations":'typeof import("@medusajs/medusa/api/admin/views/[entity]/configurations/route")',"/admin/views/:entity/configurations/:id":'typeof import("@medusajs/medusa/api/admin/views/[entity]/configurations/[id]/route")',"/admin/views/:entity/configurations/active":'typeof import("@medusajs/medusa/api/admin/views/[entity]/configurations/active/route")',"/admin/workflows-executions":'typeof import("@medusajs/medusa/api/admin/workflows-executions/route")',"/admin/workflows-executions/:id":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[id]/route")',"/admin/workflows-executions/:workflow_id/:transaction_id":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/[transaction_id]/route")',"/admin/workflows-executions/:workflow_id/:transaction_id/:step_id/subscribe":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/[transaction_id]/[step_id]/subscribe/route")',"/admin/workflows-executions/:workflow_id/run":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/run/route")',"/admin/workflows-executions/:workflow_id/steps/failure":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/steps/failure/route")',"/admin/workflows-executions/:workflow_id/steps/success":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/steps/success/route")',"/admin/workflows-executions/:workflow_id/subscribe":'typeof import("@medusajs/medusa/api/admin/workflows-executions/[workflow_id]/subscribe/route")',"/auth/:actor_type/:auth_provider":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/route")',"/auth/:actor_type/:auth_provider/callback":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/callback/route")',"/auth/:actor_type/:auth_provider/register":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/register/route")',"/auth/:actor_type/:auth_provider/reset-password":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/reset-password/route")',"/auth/:actor_type/:auth_provider/update":'typeof import("@medusajs/medusa/api/auth/[actor_type]/[auth_provider]/update/route")',"/auth/session":'typeof import("@medusajs/medusa/api/auth/session/route")',"/auth/token/refresh":'typeof import("@medusajs/medusa/api/auth/token/refresh/route")',"/store/carts":'typeof import("@medusajs/medusa/api/store/carts/route")',"/store/carts/:id":'typeof import("@medusajs/medusa/api/store/carts/[id]/route")',"/store/carts/:id/complete":'typeof import("@medusajs/medusa/api/store/carts/[id]/complete/route")',"/store/carts/:id/customer":'typeof import("@medusajs/medusa/api/store/carts/[id]/customer/route")',"/store/carts/:id/line-items":'typeof import("@medusajs/medusa/api/store/carts/[id]/line-items/route")',"/store/carts/:id/line-items/:line_id":'typeof import("@medusajs/medusa/api/store/carts/[id]/line-items/[line_id]/route")',"/store/carts/:id/promotions":'typeof import("@medusajs/medusa/api/store/carts/[id]/promotions/route")',"/store/carts/:id/shipping-methods":'typeof import("@medusajs/medusa/api/store/carts/[id]/shipping-methods/route")',"/store/carts/:id/taxes":'typeof import("@medusajs/medusa/api/store/carts/[id]/taxes/route")',"/store/collections":'typeof import("@medusajs/medusa/api/store/collections/route")',"/store/collections/:id":'typeof import("@medusajs/medusa/api/store/collections/[id]/route")',"/store/currencies":'typeof import("@medusajs/medusa/api/store/currencies/route")',"/store/currencies/:code":'typeof import("@medusajs/medusa/api/store/currencies/[code]/route")',"/store/customers":'typeof import("@medusajs/medusa/api/store/customers/route")',"/store/customers/me":'typeof import("@medusajs/medusa/api/store/customers/me/route")',"/store/customers/me/addresses":'typeof import("@medusajs/medusa/api/store/customers/me/addresses/route")',"/store/customers/me/addresses/:address_id":'typeof import("@medusajs/medusa/api/store/customers/me/addresses/[address_id]/route")',"/store/locales":'typeof import("@medusajs/medusa/api/store/locales/route")',"/store/orders":'typeof import("@medusajs/medusa/api/store/orders/route")',"/store/orders/:id":'typeof import("@medusajs/medusa/api/store/orders/[id]/route")',"/store/orders/:id/transfer/accept":'typeof import("@medusajs/medusa/api/store/orders/[id]/transfer/accept/route")',"/store/orders/:id/transfer/cancel":'typeof import("@medusajs/medusa/api/store/orders/[id]/transfer/cancel/route")',"/store/orders/:id/transfer/decline":'typeof import("@medusajs/medusa/api/store/orders/[id]/transfer/decline/route")',"/store/orders/:id/transfer/request":'typeof import("@medusajs/medusa/api/store/orders/[id]/transfer/request/route")',"/store/payment-collections":'typeof import("@medusajs/medusa/api/store/payment-collections/route")',"/store/payment-collections/:id/payment-sessions":'typeof import("@medusajs/medusa/api/store/payment-collections/[id]/payment-sessions/route")',"/store/payment-providers":'typeof import("@medusajs/medusa/api/store/payment-providers/route")',"/store/product-categories":'typeof import("@medusajs/medusa/api/store/product-categories/route")',"/store/product-categories/:id":'typeof import("@medusajs/medusa/api/store/product-categories/[id]/route")',"/store/product-tags":'typeof import("@medusajs/medusa/api/store/product-tags/route")',"/store/product-tags/:id":'typeof import("@medusajs/medusa/api/store/product-tags/[id]/route")',"/store/product-types":'typeof import("@medusajs/medusa/api/store/product-types/route")',"/store/product-types/:id":'typeof import("@medusajs/medusa/api/store/product-types/[id]/route")',"/store/product-variants":'typeof import("@medusajs/medusa/api/store/product-variants/route")',"/store/product-variants/:id":'typeof import("@medusajs/medusa/api/store/product-variants/[id]/route")',"/store/products":'typeof import("@medusajs/medusa/api/store/products/route")',"/store/products/:id":'typeof import("@medusajs/medusa/api/store/products/[id]/route")',"/store/regions":'typeof import("@medusajs/medusa/api/store/regions/route")',"/store/regions/:id":'typeof import("@medusajs/medusa/api/store/regions/[id]/route")',"/store/return-reasons":'typeof import("@medusajs/medusa/api/store/return-reasons/route")',"/store/return-reasons/:id":'typeof import("@medusajs/medusa/api/store/return-reasons/[id]/route")',"/store/returns":'typeof import("@medusajs/medusa/api/store/returns/route")',"/store/shipping-options":'typeof import("@medusajs/medusa/api/store/shipping-options/route")',"/store/shipping-options/:id/calculate":'typeof import("@medusajs/medusa/api/store/shipping-options/[id]/calculate/route")'},Tr={"/admin/commission-rates":'typeof import("@mercurjs/core-plugin/api/admin/commission-rates/route")',"/admin/commission-rates/:id":'typeof import("@mercurjs/core-plugin/api/admin/commission-rates/[id]/route")',"/admin/commission-rates/:id/rules":'typeof import("@mercurjs/core-plugin/api/admin/commission-rates/[id]/rules/route")',"/admin/order-groups":'typeof import("@mercurjs/core-plugin/api/admin/order-groups/route")',"/admin/order-groups/:id":'typeof import("@mercurjs/core-plugin/api/admin/order-groups/[id]/route")',"/admin/payouts":'typeof import("@mercurjs/core-plugin/api/admin/payouts/route")',"/admin/payouts/:id":'typeof import("@mercurjs/core-plugin/api/admin/payouts/[id]/route")',"/admin/orders":'typeof import("@mercurjs/core-plugin/api/admin/orders/route")',"/admin/products":'typeof import("@mercurjs/core-plugin/api/admin/products/route")',"/admin/invites/accept":'typeof import("@mercurjs/core-plugin/api/admin/invites/accept/route")',"/admin/sellers":'typeof import("@mercurjs/core-plugin/api/admin/sellers/route")',"/admin/sellers/invite":'typeof import("@mercurjs/core-plugin/api/admin/sellers/invite/route")',"/admin/sellers/:id":'typeof import("@mercurjs/core-plugin/api/admin/sellers/[id]/route")',"/store/carts/:id/complete":'typeof import("@mercurjs/core-plugin/api/store/carts/[id]/complete/route")',"/store/carts/:id/promotions":'typeof import("@mercurjs/core-plugin/api/store/carts/[id]/promotions/route")',"/store/carts/:id/shipping-methods":'typeof import("@mercurjs/core-plugin/api/store/carts/[id]/shipping-methods/route")',"/store/order-groups":'typeof import("@mercurjs/core-plugin/api/store/order-groups/route")',"/store/order-groups/:id":'typeof import("@mercurjs/core-plugin/api/store/order-groups/[id]/route")',"/store/sellers":'typeof import("@mercurjs/core-plugin/api/store/sellers/route")',"/store/sellers/:id":'typeof import("@mercurjs/core-plugin/api/store/sellers/[id]/route")',"/store/shipping-options":'typeof import("@mercurjs/core-plugin/api/store/shipping-options/route")',"/vendor/campaigns":'typeof import("@mercurjs/core-plugin/api/vendor/campaigns/route")',"/vendor/campaigns/:id":'typeof import("@mercurjs/core-plugin/api/vendor/campaigns/[id]/route")',"/vendor/campaigns/:id/promotions":'typeof import("@mercurjs/core-plugin/api/vendor/campaigns/[id]/promotions/route")',"/vendor/collections":'typeof import("@mercurjs/core-plugin/api/vendor/collections/route")',"/vendor/collections/:id":'typeof import("@mercurjs/core-plugin/api/vendor/collections/[id]/route")',"/vendor/collections/:id/products":'typeof import("@mercurjs/core-plugin/api/vendor/collections/[id]/products/route")',"/vendor/currencies":'typeof import("@mercurjs/core-plugin/api/vendor/currencies/route")',"/vendor/currencies/:code":'typeof import("@mercurjs/core-plugin/api/vendor/currencies/[code]/route")',"/vendor/customers":'typeof import("@mercurjs/core-plugin/api/vendor/customers/route")',"/vendor/customers/:id":'typeof import("@mercurjs/core-plugin/api/vendor/customers/[id]/route")',"/vendor/fulfillment-sets/:id":'typeof import("@mercurjs/core-plugin/api/vendor/fulfillment-sets/[id]/route")',"/vendor/fulfillment-sets/:id/service-zones":'typeof import("@mercurjs/core-plugin/api/vendor/fulfillment-sets/[id]/service-zones/route")',"/vendor/fulfillment-sets/:id/service-zones/:zone_id":'typeof import("@mercurjs/core-plugin/api/vendor/fulfillment-sets/[id]/service-zones/[zone_id]/route")',"/vendor/inventory-items":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/route")',"/vendor/inventory-items/:id":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/[id]/route")',"/vendor/inventory-items/:id/location-levels":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/[id]/location-levels/route")',"/vendor/inventory-items/:id/location-levels/:location_id":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/[id]/location-levels/[location_id]/route")',"/vendor/inventory-items/:id/location-levels/batch":'typeof import("@mercurjs/core-plugin/api/vendor/inventory-items/[id]/location-levels/batch/route")',"/vendor/orders":'typeof import("@mercurjs/core-plugin/api/vendor/orders/route")',"/vendor/orders/:id":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/route")',"/vendor/orders/:id/cancel":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/cancel/route")',"/vendor/orders/:id/changes":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/changes/route")',"/vendor/orders/:id/complete":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/complete/route")',"/vendor/orders/:id/fulfillments":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/fulfillments/route")',"/vendor/orders/:id/fulfillments/:fulfillment_id/cancel":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/fulfillments/[fulfillment_id]/cancel/route")',"/vendor/orders/:id/fulfillments/:fulfillment_id/mark-as-delivered":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/fulfillments/[fulfillment_id]/mark-as-delivered/route")',"/vendor/orders/:id/fulfillments/:fulfillment_id/shipments":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/fulfillments/[fulfillment_id]/shipments/route")',"/vendor/orders/:id/preview":'typeof import("@mercurjs/core-plugin/api/vendor/orders/[id]/preview/route")',"/vendor/payments":'typeof import("@mercurjs/core-plugin/api/vendor/payments/route")',"/vendor/payments/:id":'typeof import("@mercurjs/core-plugin/api/vendor/payments/[id]/route")',"/vendor/payments/:id/capture":'typeof import("@mercurjs/core-plugin/api/vendor/payments/[id]/capture/route")',"/vendor/payments/:id/refund":'typeof import("@mercurjs/core-plugin/api/vendor/payments/[id]/refund/route")',"/vendor/payments/payment-providers":'typeof import("@mercurjs/core-plugin/api/vendor/payments/payment-providers/route")',"/vendor/payout-accounts":'typeof import("@mercurjs/core-plugin/api/vendor/payout-accounts/route")',"/vendor/payout-accounts/:id":'typeof import("@mercurjs/core-plugin/api/vendor/payout-accounts/[id]/route")',"/vendor/payout-accounts/:id/onboarding":'typeof import("@mercurjs/core-plugin/api/vendor/payout-accounts/[id]/onboarding/route")',"/vendor/payouts":'typeof import("@mercurjs/core-plugin/api/vendor/payouts/route")',"/vendor/payouts/:id":'typeof import("@mercurjs/core-plugin/api/vendor/payouts/[id]/route")',"/vendor/price-lists":'typeof import("@mercurjs/core-plugin/api/vendor/price-lists/route")',"/vendor/price-lists/:id":'typeof import("@mercurjs/core-plugin/api/vendor/price-lists/[id]/route")',"/vendor/price-lists/:id/products":'typeof import("@mercurjs/core-plugin/api/vendor/price-lists/[id]/products/route")',"/vendor/price-preferences":'typeof import("@mercurjs/core-plugin/api/vendor/price-preferences/route")',"/vendor/price-preferences/:id":'typeof import("@mercurjs/core-plugin/api/vendor/price-preferences/[id]/route")',"/vendor/product-categories":'typeof import("@mercurjs/core-plugin/api/vendor/product-categories/route")',"/vendor/product-categories/:id":'typeof import("@mercurjs/core-plugin/api/vendor/product-categories/[id]/route")',"/vendor/product-categories/:id/products":'typeof import("@mercurjs/core-plugin/api/vendor/product-categories/[id]/products/route")',"/vendor/product-tags":'typeof import("@mercurjs/core-plugin/api/vendor/product-tags/route")',"/vendor/product-tags/:id":'typeof import("@mercurjs/core-plugin/api/vendor/product-tags/[id]/route")',"/vendor/product-types":'typeof import("@mercurjs/core-plugin/api/vendor/product-types/route")',"/vendor/product-types/:id":'typeof import("@mercurjs/core-plugin/api/vendor/product-types/[id]/route")',"/vendor/products":'typeof import("@mercurjs/core-plugin/api/vendor/products/route")',"/vendor/products/:id":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/route")',"/vendor/products/:id/options":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/options/route")',"/vendor/products/:id/options/:option_id":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/options/[option_id]/route")',"/vendor/products/:id/variants":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/variants/route")',"/vendor/products/:id/variants/:variant_id":'typeof import("@mercurjs/core-plugin/api/vendor/products/[id]/variants/[variant_id]/route")',"/vendor/promotions":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/route")',"/vendor/promotions/:id":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/route")',"/vendor/promotions/:id/:rule_type":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/[rule_type]/route")',"/vendor/promotions/:id/buy-rules/batch":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/buy-rules/batch/route")',"/vendor/promotions/:id/rules/batch":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/rules/batch/route")',"/vendor/promotions/:id/target-rules/batch":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/[id]/target-rules/batch/route")',"/vendor/promotions/rule-attribute-options/:rule_type":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/rule-attribute-options/[rule_type]/route")',"/vendor/promotions/rule-value-options/:rule_type/:rule_attribute_id":'typeof import("@mercurjs/core-plugin/api/vendor/promotions/rule-value-options/[rule_type]/[rule_attribute_id]/route")',"/vendor/refund-reasons":'typeof import("@mercurjs/core-plugin/api/vendor/refund-reasons/route")',"/vendor/refund-reasons/:id":'typeof import("@mercurjs/core-plugin/api/vendor/refund-reasons/[id]/route")',"/vendor/regions":'typeof import("@mercurjs/core-plugin/api/vendor/regions/route")',"/vendor/regions/:id":'typeof import("@mercurjs/core-plugin/api/vendor/regions/[id]/route")',"/vendor/return-reasons":'typeof import("@mercurjs/core-plugin/api/vendor/return-reasons/route")',"/vendor/return-reasons/:id":'typeof import("@mercurjs/core-plugin/api/vendor/return-reasons/[id]/route")',"/vendor/returns":'typeof import("@mercurjs/core-plugin/api/vendor/returns/route")',"/vendor/returns/:id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/route")',"/vendor/returns/:id/cancel":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/cancel/route")',"/vendor/returns/:id/dismiss-items":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/dismiss-items/route")',"/vendor/returns/:id/dismiss-items/:action_id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/dismiss-items/[action_id]/route")',"/vendor/returns/:id/receive":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/receive/route")',"/vendor/returns/:id/receive-items":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/receive-items/route")',"/vendor/returns/:id/receive-items/:action_id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/receive-items/[action_id]/route")',"/vendor/returns/:id/receive/confirm":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/receive/confirm/route")',"/vendor/returns/:id/request":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/request/route")',"/vendor/returns/:id/request-items":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/request-items/route")',"/vendor/returns/:id/request-items/:action_id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/request-items/[action_id]/route")',"/vendor/returns/:id/shipping-method":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/shipping-method/route")',"/vendor/returns/:id/shipping-method/:action_id":'typeof import("@mercurjs/core-plugin/api/vendor/returns/[id]/shipping-method/[action_id]/route")',"/vendor/sales-channels":'typeof import("@mercurjs/core-plugin/api/vendor/sales-channels/route")',"/vendor/sales-channels/:id":'typeof import("@mercurjs/core-plugin/api/vendor/sales-channels/[id]/route")',"/vendor/sales-channels/:id/products":'typeof import("@mercurjs/core-plugin/api/vendor/sales-channels/[id]/products/route")',"/vendor/sellers":'typeof import("@mercurjs/core-plugin/api/vendor/sellers/route")',"/vendor/sellers/me":'typeof import("@mercurjs/core-plugin/api/vendor/sellers/me/route")',"/vendor/shipping-option-types":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-option-types/route")',"/vendor/shipping-option-types/:id":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-option-types/[id]/route")',"/vendor/shipping-options":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-options/route")',"/vendor/shipping-options/:id":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-options/[id]/route")',"/vendor/shipping-options/:id/rules/batch":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-options/[id]/rules/batch/route")',"/vendor/shipping-profiles":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-profiles/route")',"/vendor/shipping-profiles/:id":'typeof import("@mercurjs/core-plugin/api/vendor/shipping-profiles/[id]/route")',"/vendor/stock-locations":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/route")',"/vendor/stock-locations/:id":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/[id]/route")',"/vendor/stock-locations/:id/fulfillment-providers":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/[id]/fulfillment-providers/route")',"/vendor/stock-locations/:id/fulfillment-sets":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/[id]/fulfillment-sets/route")',"/vendor/stock-locations/:id/sales-channels":'typeof import("@mercurjs/core-plugin/api/vendor/stock-locations/[id]/sales-channels/route")',"/vendor/uploads":'typeof import("@mercurjs/core-plugin/api/vendor/uploads/route")'};async function bt(e,t={}){let{pathnameFilter:r,ignoreFilter:i,ignorePartFilter:o,sortPathnames:s=true}=t,n=[],m=[e];for(;m.length>0;){let p=await Promise.all(m.map(async d=>{let c={directories:[],pathnames:[]};try{let u=await U__default.readdir(d,{withFileTypes:!0});for(let l of u){if(o&&o(l.name))continue;let g=R__default.join(d,l.name);i&&i(g)||(l.isDirectory()?c.directories.push(g):(!r||r(g))&&c.pathnames.push(g));}}catch(u){if(u.code!=="ENOENT"||d===e)throw u;return null}return c}));m=[];for(let d of p)d&&(m.push(...d.directories),n.push(...d.pathnames));}return s&&n.sort(),n}async function Ze(e){return await U__default.stat(e).catch(()=>null)!==null}async function Qe(e){await Ze(e)||await U__default.mkdir(e,{recursive:true});}function ge(e){return e.replace(/\\/g,"/")}function Ie(e){return e.split("/").reduce((r,i)=>{if(!i||ie.test(i))return r;if(i.startsWith("[")&&i.endsWith("]")){let o=i.slice(1,-1);return `${r}/:${o}`}return `${r}/${i}`},"")||"/"}async function Rt(e){return await Ze(e)?(await bt(e,{pathnameFilter:i=>ie.test(i),ignorePartFilter:i=>i.startsWith("_")||i==="node_modules"})).map(i=>{let o=R__default.relative(e,i);return {filePath:ge(o),route:Ie(ge(o))}}):[]}function xt(e){return e.replace(/[-_]+(.)?/g,(t,r)=>r?r.toUpperCase():"").replace(/^[A-Z]/,t=>t.toLowerCase())}function os(e){return `../../src/api/${e.replace(/\.ts$/,"")}`}function ss(e){return e.startsWith(":")?`$${xt(e.slice(1))}`:xt(e)}function $r(){return {children:new Map}}function ns(e){let t=$r();for(let[r,i]of e){let o=r.split("/").filter(Boolean),s=t;for(let n of o){let m=ss(n);s.children.has(m)||s.children.set(m,$r()),s=s.children.get(m);}s.importType=i;}return t}function Nr(e,t=" "){let r=[];if(e.importType&&r.push(e.importType),e.children.size>0){let i=[];for(let[o,s]of e.children){let n=Nr(s,t+" ");i.push(`${t} ${o}: ${n}`);}r.push(`{
31
33
  ${i.join(`;
32
34
  `)};
33
- ${t}}`);}return r.length===0?"{}":r.length===1?r[0]:r.join(" & ")}function Er(e,t){let r=new Map;for(let[n,m]of Object.entries(Rr))r.set(n,m);for(let[n,m]of Object.entries(xr))r.set(n,m);let i=t??Yo;for(let n of e){let m=i(n.filePath);r.set(n.route,`typeof import("${m}")`);}let o=Ko(r);return `// This file is generated automatically by Mercur CLI
35
+ ${t}}`);}return r.length===0?"{}":r.length===1?r[0]:r.join(" & ")}function Fr(e,t){let r=new Map;for(let[n,m]of Object.entries(Pr))r.set(n,m);for(let[n,m]of Object.entries(Tr))r.set(n,m);let i=t??os;for(let n of e){let m=i(n.filePath);r.set(n.route,`typeof import("${m}")`);}let o=ns(r);return `// This file is generated automatically by Mercur CLI
34
36
  // Do not edit this file manually
35
37
 
36
- export type Routes = ${Sr(o,"")};
37
- `}async function Ir(e){let t=R__default.join(e,He,"index.ts"),r=R__default.join(e,"src","api"),i=R__default.dirname(t);await Je(i);let o=await vt(r),s=Er(o);await M__default.writeFile(t,s,"utf-8");}async function Cr(e,t){let r=R__default.join(e,He,"index.ts"),i=R__default.dirname(r);await Je(i);let o=t.map(m=>{let p=m.indexOf("/api/"),a=p!==-1?m.slice(p+5):m;return {filePath:m,route:Ee(ue(a))}}),n=Er(o,m=>`../../src/${m.replace(/\.ts$/,"")}`);await M__default.writeFile(r,n,"utf-8");}async function $r(e){let t={},r={cwd:e.cwd,registryFile:R__default.resolve(e.cwd,e.registryFile)};if(!A.existsSync(r.registryFile))return t[z]=true,{errors:t,resolvePaths:null,config:null};if(!A.existsSync(R__default.resolve(e.cwd,"blocks.json")))return t[E]=true,{errors:t,resolvePaths:null,config:null};try{let i=await b(e.cwd);return {errors:t,config:i,resolvePaths:r}}catch{d.break(),d.error(`An invalid ${l.info("blocks.json")} file was found at ${l.info(e.cwd)}.
38
- Before you can run registry:codegen, you must create a valid ${l.info("blocks.json")} file by running the ${l.info("init")} command.`),d.break(),process.exit(1);}}var Qo=z$1.object({cwd:z$1.string(),registryFile:z$1.string()}),Fr=new Command().name("registry:codegen").description("generate type definitions for registry block API routes").argument("[registry]","path to registry.json file","./registry.json").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{await Xo({cwd:R.resolve(t.cwd),registryFile:e});});async function Xo(e){try{let t=Qo.parse(e),{errors:r,resolvePaths:i}=await $r(t);r[E]&&(d.error(`A ${l.info("blocks.json")} file is required to run registry:codegen. Run ${l.info("mercur init")} to create one.`),d.break(),process.exit(1)),(r[z]||!i)&&(d.error(`Could not find a registry file at ${l.info(R.resolve(t.cwd,t.registryFile))}.`),d.break(),process.exit(1));let o=await M.readFile(i.registryFile,"utf-8"),s=Y.safeParse(JSON.parse(o));s.success||(d.error(`Invalid registry file at ${l.info(i.registryFile)}.`),d.break(),process.exit(1));let n=[];for(let p of s.data.items)if(p.files)for(let a of p.files)a.type==="registry:api"&&te.test(a.path)&&n.push(a.path);if(n.length===0){d.warn("No API route files found in registry.");return}let m=h("Generating registry route types...");await Cr(t.cwd,n),m.succeed("Registry route types generated successfully."),d.break();}catch(t){d.break(),w(t);}}var ts=z$1.object({cwd:z$1.string()}),Ar=new Command().name("codegen").description("generate type definitions for API routes").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{await rs({cwd:R.resolve(e.cwd)});});async function rs(e){try{let t=ts.parse(e),r=h("Generating route types...");await Ir(t.cwd),r.succeed("Route types generated successfully."),d.break();}catch(t){d.break(),w(t);}}var xt=({contents:e,databaseUri:t})=>{let r=new Set,i=e;return e.includes("DATABASE_URL")||(i+=`
38
+ export type Routes = ${Nr(o,"")};
39
+ `}async function Or(e){let t=R__default.join(e,Ke,"index.ts"),r=R__default.join(e,"src","api"),i=R__default.dirname(t);await Qe(i);let o=await Rt(r),s=Fr(o);await U__default.writeFile(t,s,"utf-8");}async function Ar(e,t){let r=R__default.join(e,Ke,"index.ts"),i=R__default.dirname(r);await Qe(i);let o=t.map(m=>{let p=m.indexOf("/api/"),d=p!==-1?m.slice(p+5):m;return {filePath:m,route:Ie(ge(d))}}),n=Fr(o,m=>`../../src/${m.replace(/\.ts$/,"")}`);await U__default.writeFile(r,n,"utf-8");}async function Ur(e){let t={},r={cwd:e.cwd,registryFile:R__default.resolve(e.cwd,e.registryFile)};if(!L.existsSync(r.registryFile))return t[B]=true,{errors:t,resolvePaths:null,config:null};if(!L.existsSync(R__default.resolve(e.cwd,"blocks.json")))return t[I]=true,{errors:t,resolvePaths:null,config:null};try{let i=await b(e.cwd);return {errors:t,config:i,resolvePaths:r}}catch{a.break(),a.error(`An invalid ${f.info("blocks.json")} file was found at ${f.info(e.cwd)}.
40
+ Before you can run registry:codegen, you must create a valid ${f.info("blocks.json")} file by running the ${f.info("init")} command.`),a.break(),process.exit(1);}}var ds=z.object({cwd:z.string(),registryFile:z.string()}),Br=new Command().name("registry:codegen").description("generate type definitions for registry block API routes").argument("[registry]","path to registry.json file","./registry.json").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{await ms({cwd:R.resolve(t.cwd),registryFile:e});});async function ms(e){try{let t=ds.parse(e),{errors:r,resolvePaths:i}=await Ur(t);r[I]&&(a.error(`A ${f.info("blocks.json")} file is required to run registry:codegen. Run ${f.info("mercur init")} to create one.`),a.break(),process.exit(1)),(r[B]||!i)&&(a.error(`Could not find a registry file at ${f.info(R.resolve(t.cwd,t.registryFile))}.`),a.break(),process.exit(1));let o=await U.readFile(i.registryFile,"utf-8"),s=K.safeParse(JSON.parse(o));s.success||(a.error(`Invalid registry file at ${f.info(i.registryFile)}.`),a.break(),process.exit(1));let n=[];for(let p of s.data.items)if(p.files)for(let d of p.files)d.type==="registry:api"&&ie.test(d.path)&&n.push(d.path);if(n.length===0){a.warn("No API route files found in registry.");return}let m=v("Generating registry route types...");await Ar(t.cwd,n),m.succeed("Registry route types generated successfully."),a.break();}catch(t){a.break(),j(t);}}var cs=z.object({cwd:z.string()}),Vr=new Command().name("codegen").description("generate type definitions for API routes").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{await us({cwd:R.resolve(e.cwd)});});async function us(e){try{let t=cs.parse(e),r=v("Generating route types...");await Or(t.cwd),r.succeed("Route types generated successfully."),a.break();}catch(t){a.break(),j(t);}}var St=({contents:e,databaseUri:t})=>{let r=new Set,i=e;return e.includes("DATABASE_URL")||(i+=`
39
41
  DATABASE_URL=your-connection-string-here`),i.split(`
40
42
  `).map(s=>{if(s.startsWith("#")||!s.includes("="))return s;let[n]=s.split("=");if(n)return n==="DATABASE_URL"&&(s=`DATABASE_URL=${t||"postgresql://localhost:5432/your-database-name"}`),r.has(n)?null:(r.add(n),s)}).filter(Boolean).join(`
41
- `)},is=[{path:"packages/api"},{path:"apps/vendor"},{path:"apps/admin"}];async function Ke({projectDir:e,databaseUri:t}){try{await Promise.all(is.map(async({path:r})=>{let i=R__default.join(e,r);if(!A.existsSync(i))return;let o=R__default.join(i,".env.template"),s=R__default.join(i,".env");if(!r.includes("api")){A.existsSync(o)&&!A.existsSync(s)&&await A.copy(o,s);return}let m="";if(A.existsSync(o)){let p=await A.readFile(o,"utf8");m=xt({contents:p,databaseUri:t});}if(A.existsSync(s)){let p=await A.readFile(s,"utf8"),a=xt({contents:p,databaseUri:t});await A.writeFile(s,a);}else {let p=xt({contents:m,databaseUri:t});await A.writeFile(s,p);}}));}catch(r){d.error("Unable to manage environment files"),r instanceof Error&&d.error(r.message),process.exit(1);}}var ss="localhost",zr=5432,St="packages/api",ns="admin@mercur-test.com";async function Ur(e){let t=e.projectName.replace(/[^a-zA-Z0-9]/g,"-"),{client:r,dbConnectionString:i}=await as({dbConnectionString:e.dbConnectionString,dbHost:e.dbHost??ss,dbPort:e.dbPort??zr,dbName:t,spinner:e.spinner});if(!r||!i)return {success:false,dbName:t,connectionString:null};try{return e.spinner&&(e.spinner.text="Checking if database exists..."),await ds(r,t)?(await r.end(),Mr({...e,dbName:t,connectionString:i,alreadyExists:!0})):(e.spinner&&(e.spinner.text=`Creating database "${t}"...`),await r.query(`CREATE DATABASE "${t}"`),await r.end(),Mr({...e,dbName:t,connectionString:i,alreadyExists:!1}))}catch(o){return d.error(`Error creating database${o instanceof Error?`: ${o.message}`:""}.`),await r.end().catch(()=>{}),{success:false,dbName:t,connectionString:null}}}async function Mr(e){let{projectDir:t,spinner:r,dbName:i,connectionString:o,alreadyExists:s}=e;if(await Ke({projectDir:t,databaseUri:o}),!await ps({projectDir:t,spinner:r}))return {success:false,dbName:i,connectionString:null};if(!await cs({projectDir:t,spinner:r}))return {success:false,dbName:i,connectionString:null};let p=await ms({projectDir:t});return {success:true,dbName:i,connectionString:o,alreadyExists:s,inviteToken:p}}async function as({dbConnectionString:e,dbHost:t,dbPort:r,dbName:i,spinner:o}){if(e)try{let n=new kt.Client({connectionString:e});return await n.connect(),{client:n,dbConnectionString:e}}catch(n){return d.error(`Invalid database connection string${n instanceof Error?`: ${n.message}`:""}.`),{client:null,dbConnectionString:null}}o&&(o.text=`Trying default connection (postgres@${t}:${r})...`);try{let n=new kt.Client({user:"postgres",password:"",host:t,port:r,database:"postgres"});return await n.connect(),{client:n,dbConnectionString:Lr({user:"postgres",password:"",host:t,port:r,db:i})}}catch{}o?.stop(),d.break(),d.log(`PostgreSQL is required. Make sure it is installed and running on ${t}:${r}.`),d.break();let s=3;for(let n=1;n<=s;n++){let m=n>1?` (attempt ${n}/${s})`:"",p=await Qe([{type:"text",name:"postgresUsername",message:`Enter your Postgres username${m}`,initial:"postgres"},{type:"password",name:"postgresPassword",message:'Enter your Postgres password (press Enter for "postgres")'}]);if(!p.postgresUsername)return {client:null,dbConnectionString:null};let a=p.postgresUsername,c=p.postgresPassword||"postgres";o?.start("Connecting to database...");try{let u=new kt.Client({user:a,password:c,host:t,port:r,database:"postgres"});return await u.connect(),o?.stop(),{client:u,dbConnectionString:Lr({user:a,password:c,host:t,port:r,db:i})}}catch(u){o?.stop();let f=u instanceof Error?u.message:String(u);n<s?d.warn(`Attempt ${n}/${s} failed: ${f}`):d.error(`Couldn't connect to PostgreSQL: ${f}
43
+ `)},ls=[{path:"packages/api"},{path:"apps/vendor"},{path:"apps/admin"}];async function Xe({projectDir:e,databaseUri:t}){try{await Promise.all(ls.map(async({path:r})=>{let i=R__default.join(e,r);if(!L.existsSync(i))return;let o=R__default.join(i,".env.template"),s=R__default.join(i,".env");if(!r.includes("api")){L.existsSync(o)&&!L.existsSync(s)&&await L.copy(o,s);return}let m="";if(L.existsSync(o)){let p=await L.readFile(o,"utf8");m=St({contents:p,databaseUri:t});}if(L.existsSync(s)){let p=await L.readFile(s,"utf8"),d=St({contents:p,databaseUri:t});await L.writeFile(s,d);}else {let p=St({contents:m,databaseUri:t});await L.writeFile(s,p);}}));}catch(r){a.error("Unable to manage environment files"),r instanceof Error&&a.error(r.message),process.exit(1);}}var gs="localhost",Jr=5432,Pt="packages/api",ys="admin@mercur-test.com";async function Hr(e){let t=e.projectName.replace(/[^a-zA-Z0-9]/g,"-"),{client:r,dbConnectionString:i}=await hs({dbConnectionString:e.dbConnectionString,dbHost:e.dbHost??gs,dbPort:e.dbPort??Jr,dbName:t,spinner:e.spinner});if(!r||!i)return {success:false,dbName:t,connectionString:null};try{return e.spinner&&(e.spinner.text="Checking if database exists..."),await vs(r,t)?(await r.end(),Yr({...e,dbName:t,connectionString:i,alreadyExists:!0})):(e.spinner&&(e.spinner.text=`Creating database "${t}"...`),await r.query(`CREATE DATABASE "${t}"`),await r.end(),Yr({...e,dbName:t,connectionString:i,alreadyExists:!1}))}catch(o){return a.error(`Error creating database${o instanceof Error?`: ${o.message}`:""}.`),await r.end().catch(()=>{}),{success:false,dbName:t,connectionString:null}}}async function Yr(e){let{projectDir:t,spinner:r,dbName:i,connectionString:o,alreadyExists:s}=e;if(await Xe({projectDir:t,databaseUri:o}),!await ws({projectDir:t,spinner:r}))return {success:false,dbName:i,connectionString:null};if(!await bs({projectDir:t,spinner:r}))return {success:false,dbName:i,connectionString:null};let p=await js({projectDir:t});return {success:true,dbName:i,connectionString:o,alreadyExists:s,inviteToken:p}}async function hs({dbConnectionString:e,dbHost:t,dbPort:r,dbName:i,spinner:o}){if(e)try{let n=new It.Client({connectionString:e});return await n.connect(),{client:n,dbConnectionString:e}}catch(n){return a.error(`Invalid database connection string${n instanceof Error?`: ${n.message}`:""}.`),{client:null,dbConnectionString:null}}o&&(o.text=`Trying default connection (postgres@${t}:${r})...`);try{let n=new It.Client({user:"postgres",password:"",host:t,port:r,database:"postgres",connectionTimeoutMillis:5e3});return await n.connect(),{client:n,dbConnectionString:qr({user:"postgres",password:"",host:t,port:r,db:i})}}catch{}o?.stop(),a.break(),a.log(`PostgreSQL is required. Make sure it is installed and running on ${t}:${r}.`),a.break();let s=3;for(let n=1;n<=s;n++){let m=n>1?` (attempt ${n}/${s})`:"",p=await Pe([{type:"text",name:"postgresUsername",message:`Enter your Postgres username${m}`,initial:"postgres"},{type:"password",name:"postgresPassword",message:'Enter your Postgres password (press Enter for "postgres")'}]);if(!p.postgresUsername)return {client:null,dbConnectionString:null};let d=p.postgresUsername,c=p.postgresPassword||"postgres";o?.start("Connecting to database...");try{let u=new It.Client({user:d,password:c,host:t,port:r,database:"postgres",connectionTimeoutMillis:5e3});return await u.connect(),{client:u,dbConnectionString:qr({user:d,password:c,host:t,port:r,db:i})}}catch(u){o?.stop();let l=u instanceof Error?u.message:String(u);n<s?a.warn(`Attempt ${n}/${s} failed: ${l}`):a.error(`Couldn't connect to PostgreSQL: ${l}
42
44
  \u2192 Is PostgreSQL running? Try: pg_isready -h ${t} -p ${r}
43
- \u2192 Check your username, password, and that the server is accessible.`);}}return {client:null,dbConnectionString:null}}async function ds(e,t){return ((await e.query(`SELECT datname FROM pg_catalog.pg_database WHERE datname='${t}';`)).rowCount??0)>0}function Lr({user:e,password:t,host:r,port:i=zr,db:o}){let s=encodeURIComponent(t);return `postgresql://${e}:${s}@${r}:${i}/${o}`}async function ps({projectDir:e,spinner:t}){let r=R__default.join(e,St),i=await O(r),o=t||h("Running migrations...").start(),s=i==="yarn"?["yarn","run","build"]:i==="pnpm"?["pnpm","run","build"]:i==="bun"?["bun","run","build"]:["npm","run","build"],n=i==="pnpm"?["pnpm","dlx"]:i==="bun"?["bunx"]:["npx"];try{return o.text="Building project...",await execa(s[0],s.slice(1),{cwd:r}),o.text="Running database migrations...",await execa(n[0],[...n.slice(1),"medusa","db:migrate"],{cwd:r}),t||o.succeed("Migrations completed successfully."),!0}catch(m){return o.fail("Failed to run migrations."),d.error(`Error running migrations${m instanceof Error?`: ${m.message}`:""}.`),false}}async function ms({projectDir:e}){let t=R__default.join(e,St),r=await O(t),i=r==="pnpm"?["pnpm","dlx"]:r==="bun"?["bunx"]:["npx"];try{return (await execa(i[0],[...i.slice(1),"medusa","user","-e",ns,"--invite"],{cwd:t})).stdout.match(/Invite token: (?<token>.+)/)?.groups?.token||null}catch(o){return d.error(`Error creating admin invite${o instanceof Error?`: ${o.message}`:""}.`),null}}async function cs({projectDir:e,spinner:t}){let r=R__default.join(e,St),i=await O(r),o=t||h("Seeding database...").start();try{let s=i==="yarn"?["yarn","seed"]:i==="pnpm"?["pnpm","run","seed"]:i==="bun"?["bun","run","seed"]:["npm","run","seed"];return o.text="Seeding database...",await execa(s[0],s.slice(1),{cwd:r}),t||o.succeed("Database seeded successfully."),!0}catch(s){return o.fail("Failed to seed database."),d.error(`Error seeding database${s instanceof Error?`: ${s.message}`:""}.`),false}}var Br="canary",Et=20,Gr={basic:"basic",plugin:"plugin"},Vr=new Command().name("create").description("create a new Mercur project").argument("[name]","the name of your project").option("-t, --template <template>","the template to use. e.g. basic, registry, or plugin").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("--no-deps","skip installing dependencies.").option("--skip-db","skip database configuration.",false).option("--skip-email","skip email prompt.",false).option("--db-connection-string <string>","PostgreSQL connection string.").option("--db-host <host>","PostgreSQL host.","localhost").option("--db-port <port>","PostgreSQL port.","5432").action(async(e,t)=>{try{Is();let r=e;if(!r){let{enteredName:a}=await Qe({type:"text",name:"enteredName",message:"What is your project named?",initial:t.template?`${t.template}-app`:"my-mercur",format:c=>c.trim(),validate:c=>ws(R__default.basename(R__default.resolve(c))).validForNewPackages?!0:"Invalid project name. Name should be lowercase, URL-friendly, and not start with a period or underscore."});a||process.exit(0),r=a;}let i=t.template;if(!i){let{selectedTemplate:a}=await Qe({type:"select",name:"selectedTemplate",message:`Which ${l.info("template")} would you like to use?`,choices:Object.entries(Gr).map(([c,u])=>({title:u,value:c}))});a||process.exit(0),i=a;}if(!t.skipEmail){let{wantsEmail:a}=await Qe({type:"confirm",name:"wantsEmail",message:"Mind sharing your email? We reach out for priority support, community events, and invite-only meetups. We never spam.",initial:!1});if(a){let{email:c}=await Qe({type:"text",name:"email",message:"Enter your email:",format:u=>u.trim()});c&&gr(c);}}let o=R__default.resolve(t.cwd,r);await bs(o);let s=h("Downloading template...").start();await Rs({projectDir:o,template:i}),s.succeed("Template downloaded successfully.");let n=await O(o);if(await _s(o,n),!t.deps)h("Dependency installation skipped.").warn();else {let a=h("Installing dependencies...").start(),c=Date.now(),u=await ks({projectDir:o,packageManager:n}),f=((Date.now()-c)/1e3).toFixed(1);u?a.succeed(`Dependencies installed successfully in ${f}s.`):(a.fail("Failed to install dependencies"),await P({type:"create",payload:{outcome:"dependency_installation_failed",packageManager:n}},{cwd:o}),process.exit(1));}let m=t.dbConnectionString,p;if(t.skipDb)h("Database setup skipped.").warn();else {let a=h("Setting up database...").start();p=await Ur({projectDir:o,projectName:r,dbConnectionString:m,dbHost:t.dbHost,dbPort:parseInt(t.dbPort,10),spinner:a}),p.success?(p.alreadyExists?a.warn(`Database ${l.info(p.dbName)} already exists. Skipping database creation.`):a.succeed(`Database ${l.info(p.dbName)} setup successfully.`),m=p.connectionString):(a.fail("Failed to setup database."),d.log(It()),await P({type:"create",payload:{outcome:"database_setup_failed"}},{cwd:o}),process.exit(1));}if(await Ke({projectDir:o,databaseUri:m}),await Ss(o),await P({type:"create",payload:{outcome:"created"}},{cwd:o}),h("Mercur project successfully created!").succeed(),p?.success){h("Starting development server...").info();let a=p.inviteToken?`http://localhost:9000/dashboard/invite?token=${p.inviteToken}&first_run=true`:"http://localhost:9000/dashboard",f=spawn(n==="npm"?"npm":n,n==="npm"?["run","dev"]:["dev"],{cwd:o,stdio:"inherit",env:process.env}),y=()=>{d.break(),d.log(H.bgGreen(H.black(" Project stopped. To start again: "))),d.log(Wr(o,n)),d.log(It()),d.break();};process.on("SIGINT",()=>{}),f.on("close",()=>{y(),process.exit(0);}),js({resources:["http://localhost:9000/health"],timeout:6e4}).then(async()=>{try{await ys(a);}catch{h("Open this URL in your browser to create your admin account:").info(),d.log(l.info(a));}}).catch(()=>{h("To create your admin account, visit:").info(),d.log(l.info(a));});}else d.log(H.bgGreen(H.black(" Next Steps "))),d.log(Wr(o,n)),d.log(It()),d.break();}catch(r){d.break(),w(r);}finally{x();}});async function bs(e){await A.pathExists(e)||await A.mkdir(e);}async function Rs({projectDir:e,template:t}){let r=`https://codeload.github.com/mercurjs/mercur/tar.gz/${Br}`,i=Gr[t],o=`mercur-${Br.replace(/^v/,"").replaceAll("/","-")}/templates/${i}/`;await pipeline(await xs(r),x$1({cwd:e,filter:s=>s.includes(o),strip:2+i.split("/").length}));}async function xs(e){let t=await fetch(e);if(!t.body)throw new Error(`Failed to download: ${e}`);return Readable.from(t.body)}async function ks({projectDir:e,packageManager:t}){let r="npm",i=["install"];t==="yarn"?(r="yarn",i=[]):t==="pnpm"?(r="pnpm",i=["install"]):t==="bun"&&(r="bun",i=["install"]);try{return await execa(r,i,{cwd:R__default.resolve(e),stdin:"inherit",stdout:"inherit",stderr:"inherit",env:{...process.env,npm_config_yes:"true"}}),!0}catch(o){return d.error(`Error installing dependencies${o instanceof Error?`: ${o.message}`:""}.`),false}}function Wr(e,t){let r=R__default.relative(process.cwd(),e),i=o=>H.bold(o);return `
45
+ \u2192 Check your username, password, and that the server is accessible.`);}}return {client:null,dbConnectionString:null}}async function vs(e,t){return ((await e.query(`SELECT datname FROM pg_catalog.pg_database WHERE datname='${t}';`)).rowCount??0)>0}function qr({user:e,password:t,host:r,port:i=Jr,db:o}){let s=encodeURIComponent(t);return `postgresql://${e}:${s}@${r}:${i}/${o}`}async function ws({projectDir:e,spinner:t}){let r=R__default.join(e,Pt),i=await A(r),o=t||v("Running migrations...").start(),s=i==="yarn"?["yarn","run","build"]:i==="pnpm"?["pnpm","run","build"]:i==="bun"?["bun","run","build"]:["npm","run","build"],n=i==="pnpm"?["pnpm","dlx"]:i==="bun"?["bunx"]:["npx"];try{return o.text="Building project...",await execa(s[0],s.slice(1),{cwd:r}),o.text="Running database migrations...",await execa(n[0],[...n.slice(1),"medusa","db:migrate"],{cwd:r}),t||o.succeed("Migrations completed successfully."),!0}catch(m){return o.fail("Failed to run migrations."),a.error(`Error running migrations${m instanceof Error?`: ${m.message}`:""}.`),false}}async function js({projectDir:e}){let t=R__default.join(e,Pt),r=await A(t),i=r==="pnpm"?["pnpm","dlx"]:r==="bun"?["bunx"]:["npx"];try{return (await execa(i[0],[...i.slice(1),"medusa","user","-e",ys,"--invite"],{cwd:t})).stdout.match(/Invite token: (?<token>.+)/)?.groups?.token||null}catch(o){return a.error(`Error creating admin invite${o instanceof Error?`: ${o.message}`:""}.`),null}}async function bs({projectDir:e,spinner:t}){let r=R__default.join(e,Pt),i=await A(r),o=t||v("Seeding database...").start();try{let s=i==="yarn"?["yarn","seed"]:i==="pnpm"?["pnpm","run","seed"]:i==="bun"?["bun","run","seed"]:["npm","run","seed"];return o.text="Seeding database with demo data...",await execa(s[0],s.slice(1),{cwd:r}),t||o.succeed("Database seeded successfully."),!0}catch(s){return o.fail("Failed to seed database."),a.error(`Error seeding database${s instanceof Error?`: ${s.message}`:""}.`),false}}var Kr="main",Tt=20,Qr={basic:{path:"basic",description:"Full marketplace starter \u2014 sellers, products, orders, admin & vendor panels"},plugin:{path:"plugin",description:"MedusaJS plugin template \u2014 for building reusable marketplace extensions"}},Xr=new Command().name("create").description("create a new Mercur project").argument("[name]","the name of your project").option("-t, --template <template>","the template to use. e.g. basic, registry, or plugin").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("--no-deps","skip installing dependencies.").option("--skip-db","skip database configuration.",false).option("--skip-email","skip email prompt.",false).option("--db-connection-string <string>","PostgreSQL connection string.").option("--db-host <host>","PostgreSQL host.","localhost").option("--db-port <port>","PostgreSQL port.","5432").action(async(e,t)=>{try{let r=Date.now();Ms(),H();let i=e;if(!i){let{enteredName:l}=await Pe({type:"text",name:"enteredName",message:"What is your project named?",initial:t.template?`${t.template}-app`:"my-mercur",format:g=>g.trim(),validate:g=>Cs(R__default.basename(R__default.resolve(g))).validForNewPackages?!0:"Invalid project name. Name should be lowercase, URL-friendly, and not start with a period or underscore."});l||process.exit(0),i=l;}let o=t.template;if(!o){let{selectedTemplate:l}=await Pe({type:"select",name:"selectedTemplate",message:`Which ${f.info("template")} would you like to use?`,choices:Object.entries(Qr).map(([g,h])=>({title:g,value:g,description:h.description}))});l||process.exit(0),o=l;}if(!t.skipEmail){let{wantsEmail:l}=await Pe({type:"confirm",name:"wantsEmail",message:"Mind sharing your email? We reach out for priority support, community events, and invite-only meetups. We never spam.",initial:!1});if(l){let{email:g}=await Pe({type:"text",name:"email",message:"Enter your email:",format:h=>h.trim()});g&&xr(g);}}let s=R__default.resolve(t.cwd,i);await Ts(s);let n=v("Downloading template...").start();await $s({projectDir:s,template:o}),n.succeed("Template downloaded successfully.");let m=await A(s);if(await Os(s,m),!t.deps)v("Dependency installation skipped.").warn();else {let l=v("Installing dependencies...").start(),g=Date.now(),h=await Ns({projectDir:s,packageManager:m}),w=((Date.now()-g)/1e3).toFixed(1);h?l.succeed(`Dependencies installed successfully in ${w}s.`):(l.fail("Failed to install dependencies"),await T({type:"create",payload:{outcome:"dependency_installation_failed",packageManager:m}},{cwd:s}),process.exit(1));}let p=t.dbConnectionString,d;if(t.skipDb)v("Database setup skipped.").warn();else {let l=v("Setting up database...").start();d=await Hr({projectDir:s,projectName:i,dbConnectionString:p,dbHost:t.dbHost,dbPort:parseInt(t.dbPort,10),spinner:l}),d.success?(d.alreadyExists?l.warn(`Database ${f.info(d.dbName)} already exists. Skipping database creation.`):l.succeed(`Database ${f.info(d.dbName)} setup successfully.`),p=d.connectionString):(l.fail("Failed to setup database."),a.log(Dt()),await T({type:"create",payload:{outcome:"database_setup_failed"}},{cwd:s}),process.exit(1));}await Xe({projectDir:s,databaseUri:p}),await As(s),await T({type:"create",payload:{outcome:"created"}},{cwd:s});let c=((Date.now()-r)/1e3).toFixed(1);v(`Mercur project successfully created! (${c}s)`).succeed();let u=d?.success&&!d.alreadyExists;if(u&&a.log($t()),d?.success){v("Starting development server...").info();let l=d.inviteToken?`http://localhost:9000/dashboard/invite?token=${d.inviteToken}&first_run=true`:"http://localhost:9000/dashboard",w=spawn(m==="npm"?"npm":m,m==="npm"?["run","dev"]:["dev"],{cwd:s,stdio:"inherit",env:process.env}),_=()=>{a.break(),u&&a.log($t()),a.log(S.bgGreen(S.black(" Project stopped. To start again: "))),a.log(Zr(s,m)),a.log(Dt()),a.break();};process.on("SIGINT",()=>{}),w.on("close",()=>{_(),process.exit(0);}),Ps({resources:["http://localhost:9000/health"],timeout:6e4}).then(async()=>{a.break(),a.log(Fs()),u&&a.log($t());try{await Es(l),v("Admin panel opened in your browser.").succeed();}catch{v("Open this URL in your browser to create your admin account:").info(),a.log(f.info(l));}}).catch(()=>{v("To create your admin account, visit:").info(),a.log(f.info(l));});}else a.log(S.bgGreen(S.black(" Next Steps "))),a.log(Zr(s,m)),a.log(Dt()),a.break();}catch(r){a.break(),j(r);}finally{x();}});async function Ts(e){if(!await L.pathExists(e)){await L.mkdir(e);return}let i=(await L.readdir(e)).filter(o=>!o.startsWith("."));if(i.length>0){let{proceed:o}=await Pe({type:"confirm",name:"proceed",message:`Directory ${f.info(R__default.basename(e))} already exists and contains ${i.length} file(s). Continue and overwrite?`,initial:false});o||process.exit(0);}}async function $s({projectDir:e,template:t}){let r=`https://codeload.github.com/mercurjs/mercur/tar.gz/${Kr}`,i=Qr[t].path,o=`mercur-${Kr.replace(/^v/,"").replaceAll("/","-")}/templates/${i}/`;await pipeline(await Ds(r),x$1({cwd:e,filter:s=>s.includes(o),strip:2+i.split("/").length}));}async function Ds(e){let t=await fetch(e);if(!t.body)throw new Error(`Failed to download: ${e}`);return Readable.from(t.body)}async function Ns({projectDir:e,packageManager:t}){let r="npm",i=["install"];t==="yarn"?(r="yarn",i=[]):t==="pnpm"?(r="pnpm",i=["install"]):t==="bun"&&(r="bun",i=["install"]);try{return await execa(r,i,{cwd:R__default.resolve(e),stdin:"inherit",stdout:"inherit",stderr:"inherit",env:{...process.env,npm_config_yes:"true"}}),!0}catch(o){return a.error(`Error installing dependencies${o instanceof Error?`: ${o.message}`:""}.`),false}}function Zr(e,t){let r=R__default.relative(process.cwd(),e),i=o=>S.bold(o);return `
44
46
  ${i("Launch Application:")}
45
47
 
46
48
  - cd ./${r}
@@ -48,7 +50,20 @@ ${i("Launch Application:")}
48
50
 
49
51
  ${i("Documentation:")}
50
52
 
51
- - ${qr("Getting Started","https://docs.mercurjs.com/v2/welcome")}
52
- `}function It(){return `${H.bgCyan(H.black(" Have feedback? "))} Visit us on ${qr("GitHub","https://github.com/mercurjs/mercur")}.`}function qr(e,t){return vs(e,t,{fallback:(r,i)=>`${r}: ${H.cyan().underline(i)}`})}async function _s(e,t){let r=R__default.join(e,"package.json"),i=await A.readJSON(r),{stdout:o}=await execa(t,["--version"]);i.packageManager=`${t}@${o.trim()}`,await A.writeJSON(r,i,{spaces:2});}async function Ss(e){try{await execa("git",["init"],{cwd:e}),d.info("Initialized a git repository.");}catch{throw new Error("Failed to initialize git repository.")}}function Es(){let[e]=process.versions.node.split(".").map(Number);return e}function Is(){let e=Es();if(e<Et)throw new Error(`Mercur requires at least v${Et} of Node.js. You're using v${e}. Please install at least v${Et} and try again: https://nodejs.org/en/download`)}async function Hr(e,t){let{config:r}=t||{};if(V(e)){let[n]=await X([e]);try{return Y.parse(n)}catch(m){throw new C(e,m)}}if(!e.startsWith("@"))throw new Ae(e);let i=e;i.endsWith("/registry")||(i=`${i}/registry`);let o=we(i,ne(r));if(!o?.url)throw new oe(i);let[s]=await X([o.url]);try{return Y.parse(s)}catch(n){throw new C(i,n)}}async function et(e,t){let{config:r}=t||{};return x(),We(e,ne(r))}var Fs=z$1.object({blocks:z$1.array(z$1.string()).optional(),cwd:z$1.string()}),Yr=new Command().name("diff").description("check for updates against the registry").argument("[blocks...]","the block names to diff").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{try{let r=Fs.parse({blocks:e,cwd:R__default.resolve(t.cwd),type:t.type}),i=await b(r.cwd);i||(i=B({resolvedPaths:{cwd:r.cwd}})),r.blocks?.length||(d.error("Please specify at least one block to diff."),process.exit(1));let o=await et(r.blocks,{config:i}),s=r.blocks.filter(m=>!o.some(p=>p.name===m));s.length>0&&(d.error(`Blocks ${s.join(", ")} not found in registry.`),process.exit(1));let n=await _(i.resolvedPaths.cwd);for(let m of o)for(let p of m.files){let a=Ge(p,i,{isSrcDir:n?.isSrcDir??!1,path:r.cwd});if(!existsSync(a)){d.info(`File ${a} does not exist locally.`);continue}let c=await promises.readFile(a,"utf-8"),u=await Ve({filename:p.path,raw:p.content,config:i,isRemote:!1}),f=diffLines(c,u);f.length>1&&(d.info(`
53
- File: ${l.info(p.path)}`),Ns(f));}}catch(r){w(r);}finally{x();}});function Ns(e){for(let t of e)t&&(t.added?process.stdout.write(l.success(t.value)):t.removed?process.stdout.write(l.error(t.value)):process.stdout.write(t.value));}var Jr=new Command().name("info").description("get information about your project").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{try{d.info("> project info"),console.log(await _(e.cwd)),d.break(),d.info("> blocks.json"),console.log(await b(e.cwd));}catch(t){w(t);}});var Ls=z$1.object({cwd:z$1.string(),query:z$1.string().optional(),registry:z$1.string().optional()}),Kr=new Command().name("search").description("search blocks from registries").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-q, --query <query>","query string").option("-r, --registry <registry>","the registry to search from (default: @mercurjs)","@mercurjs").action(async e=>{try{let t=Ls.parse({cwd:R__default.resolve(e.cwd),query:e.query,type:e.type,registry:e.registry}),r=await b(t.cwd);r||(r=B({resolvedPaths:{cwd:t.cwd}}));let o=(await Hr(t.registry??"@mercurjs",{config:r})).items;if(t.query){let s=t.query.toLowerCase();o=o.filter(n=>n.name.toLowerCase().includes(s)||n.description?.toLowerCase().includes(s));}console.log(JSON.stringify(o,null,2)),process.exit(0);}catch(t){w(t);}finally{x();}});var Zr=new Command().name("telemetry").description("enable or disable the collection of anonymous usage data. If no option is provided, the command enables the collection of anonymous usage data.").option("--enable","enable telemetry (default)").option("--disable","disable telemetry").action(async e=>{try{let t=!e.disable;yr(t),t?d.success("Telemetry enabled."):d.success("Telemetry disabled.");}catch(t){w(t);}});var Ws=z$1.object({cwd:z$1.string()}),Xr=new Command().name("view").description("view block details from the registry").argument("<blocks...>","the block names to view").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{try{let r=Ws.parse({cwd:R__default.resolve(t.cwd),type:t.type}),i=await b(r.cwd);i||(i=B({resolvedPaths:{cwd:r.cwd}}));let o=await et(e,{config:i});console.log(JSON.stringify(o,null,2)),process.exit(0);}catch(r){w(r);}finally{x();}});async function ti(e){let t=R__default.resolve(e.root,"src/vendor");if(!Pt.existsSync(t))return true;let r=await import('vite'),i=(await import('@vitejs/plugin-react')).default,o=JSON.parse(readFileSync(R__default.resolve(e.root,"package.json"),"utf-8")),s=new Set([...Object.keys(o.dependencies||{}),...Object.keys(o.peerDependencies||{}),...Object.keys(o.devDependencies||{}),"react","react/jsx-runtime","react-router-dom","react-i18next","@medusajs/js-sdk","@medusajs/admin-sdk","@mercurjs/client","@tanstack/react-query"]),n=R__default.resolve(e.outDir,"src/vendor"),m=R__default.resolve(e.root,"src/vendor/__vendor-extensions__.js");try{let p=generatePluginEntryModule(t);await writeFile(m,p,"utf-8");let a=process.env.NODE_ENV;process.env.NODE_ENV="production",await r.build({build:{lib:{entry:m,formats:["es","cjs"],fileName:"index"},emptyOutDir:!1,minify:!1,outDir:n,rollupOptions:{external:(f,y)=>{let v=f.split("/"),j=v[0]?.startsWith("@")?`${v[0]}/${v[1]}`:v[0],S=[...builtinModules,...builtinModules.map(F=>`node:${F}`)];return y?!!(j&&s.has(j)):!!(j&&s.has(j)||j&&S.includes(j))},output:{preserveModules:!1,interop:"auto",chunkFileNames:()=>"_chunks/[name]-[hash]"}}},plugins:[i()],logLevel:"silent",clearScreen:!1}),process.env.NODE_ENV=a;let c=R__default.join(n,"index.es.js"),u=R__default.join(n,"index.mjs");return Pt.existsSync(c)&&Pt.renameSync(c,u),!0}catch(p){return console.error(p),false}finally{try{await rm(m,{force:!0});}catch{}}}var ii=new Command().name("plugin:build").description("build a Medusa plugin").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{try{let t=R__default.resolve(e.cwd),r=h("Building plugin..."),{Compiler:i}=await import('@medusajs/framework/build-tools'),o=new i(t,d),s=await o.loadTSConfigFile();s||(r.fail("Unable to compile plugin \u2014 tsconfig not found."),process.exit(1));let n=await import('@medusajs/admin-bundler'),m=R__default.resolve(t,".medusa/server");(await Promise.all([o.buildPluginBackend(s),o.buildPluginAdminExtensions(n),ti({root:t,outDir:m})])).every(a=>a===!0)?r.succeed("Plugin built successfully."):(r.fail("Plugin build failed."),process.exit(1));}catch(t){d.break(),w(t);}});process.on("SIGINT",()=>process.exit(0));process.on("SIGTERM",()=>process.exit(0));async function Ks(){let e=new Command().name("@mercurjs/cli").description("Add blocks from registries to your project").version($t.version,"-v, --version","display the version number");e.addCommand(wr).addCommand(br).addCommand(Fr).addCommand(Ar).addCommand(Vr).addCommand(Yr).addCommand(Jr).addCommand(vr).addCommand(Kr).addCommand(Zr).addCommand(Xr).addCommand(ii),e.parse();}Ks();export{di as registryConfigItemSchema,At as registryConfigSchema,tn as registryIndexSchema,Ft as registryItemFileSchema,T as registryItemSchema,ai as registryItemTypeSchema,Ot as registryResolvedItemsTreeSchema,Y as registrySchema};//# sourceMappingURL=index.js.map
53
+ - ${Nt("Getting Started","https://docs.mercurjs.com/v2/welcome")}
54
+ `}function $t(){return `
55
+ ${S.bgCyan(S.black(" Demo Seller Credentials "))}
56
+
57
+ Email: ${f.info("seller@medusa-test.com")}
58
+ Password: ${f.info("supersecret")}
59
+ Login at: ${f.info("http://localhost:9000/seller")}
60
+ `}function Fs(){return `
61
+ ${(t=>S.bold(t))("Your marketplace is running:")}
62
+
63
+ API: ${f.info("http://localhost:9000")}
64
+ Admin Panel: ${f.info("http://localhost:9000/dashboard")}
65
+ Vendor Panel: ${f.info("http://localhost:9000/seller")}
66
+ `}function Dt(){return `${S.bgCyan(S.black(" Have feedback? "))} Visit us on ${Nt("GitHub","https://github.com/mercurjs/mercur")}.
67
+ ${S.bgMagenta(S.black(" Join the community! "))} Chat with us on ${Nt("Discord","https://discord.gg/hnZBzc4NJU")}.`}function Nt(e,t){return Is(e,t,{fallback:(r,i)=>`${r}: ${S.cyan().underline(i)}`})}async function Os(e,t){let r=R__default.join(e,"package.json"),i=await L.readJSON(r),{stdout:o}=await execa(t,["--version"]);i.packageManager=`${t}@${o.trim()}`,await L.writeJSON(r,i,{spaces:2});}async function As(e){try{await execa("git",["init"],{cwd:e}),a.info("Initialized a git repository.");}catch{throw new Error("Failed to initialize git repository.")}}function Ls(){let[e]=process.versions.node.split(".").map(Number);return e}function Ms(){let e=Ls();if(e<Tt)throw new Error(`Mercur requires at least v${Tt} of Node.js. You're using v${e}. Please install at least v${Tt} and try again: https://nodejs.org/en/download`)}async function ei(e,t){let{config:r}=t||{};if(q(e)){let[n]=await te([e]);try{return K.parse(n)}catch(m){throw new P(e,m)}}if(!e.startsWith("@"))throw new Ue(e);let i=e;i.endsWith("/registry")||(i=`${i}/registry`);let o=be(i,me(r));if(!o?.url)throw new ae(i);let[s]=await te([o.url]);try{return K.parse(s)}catch(n){throw new P(i,n)}}async function tt(e,t){let{config:r}=t||{};return x(),Ye(e,me(r))}var Vs=z.object({blocks:z.array(z.string()).optional(),cwd:z.string()}),ti=new Command().name("diff").description("check for updates against the registry").argument("[blocks...]","the block names to diff").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{try{let r=Vs.parse({blocks:e,cwd:R__default.resolve(t.cwd),type:t.type}),i=await b(r.cwd);i||(i=G({resolvedPaths:{cwd:r.cwd}})),r.blocks?.length||(a.error("Please specify at least one block to diff."),process.exit(1));let o=await tt(r.blocks,{config:i}),s=r.blocks.filter(m=>!o.some(p=>p.name===m));s.length>0&&(a.error(`Blocks ${s.join(", ")} not found in registry.`),process.exit(1));let n=await E(i.resolvedPaths.cwd);for(let m of o)for(let p of m.files){let d=qe(p,i,{isSrcDir:n?.isSrcDir??!1,path:r.cwd});if(!existsSync(d)){a.info(`File ${d} does not exist locally.`);continue}let c=await promises.readFile(d,"utf-8"),u=await Je({filename:p.path,raw:p.content,config:i,isRemote:!1}),l=diffLines(c,u);l.length>1&&(a.info(`
68
+ File: ${f.info(p.path)}`),Ys(l));}}catch(r){j(r);}finally{x();}});function Ys(e){for(let t of e)t&&(t.added?process.stdout.write(f.success(t.value)):t.removed?process.stdout.write(f.error(t.value)):process.stdout.write(t.value));}var ri=new Command().name("info").description("get information about your project").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{try{a.info("> project info"),console.log(await E(e.cwd)),a.break(),a.info("> blocks.json"),console.log(await b(e.cwd));}catch(t){j(t);}});var Ks=z.object({cwd:z.string(),query:z.string().optional(),registry:z.string().optional()}),ii=new Command().name("search").description("search blocks from registries").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).option("-q, --query <query>","query string").option("-r, --registry <registry>","the registry to search from (default: @mercurjs)","@mercurjs").action(async e=>{try{let t=Ks.parse({cwd:R__default.resolve(e.cwd),query:e.query,type:e.type,registry:e.registry}),r=await b(t.cwd);r||(r=G({resolvedPaths:{cwd:t.cwd}}));let o=(await ei(t.registry??"@mercurjs",{config:r})).items;if(t.query){let s=t.query.toLowerCase();o=o.filter(n=>n.name.toLowerCase().includes(s)||n.description?.toLowerCase().includes(s));}console.log(JSON.stringify(o,null,2)),process.exit(0);}catch(t){j(t);}finally{x();}});var oi=new Command().name("telemetry").description("manage the collection of anonymous usage data").option("--enable","enable telemetry").option("--disable","disable telemetry").action(async e=>{try{if(e.enable&&e.disable){a.error("Cannot use --enable and --disable together.");return}if(!e.enable&&!e.disable){let r=M.get("telemetry_enabled"),i=process.env.MERCUR_DISABLE_TELEMETRY==="true",o=r&&!i,s=o?"enabled":"disabled";a.log(`Telemetry is currently ${s}.`),i&&r&&a.log("(Disabled via MERCUR_DISABLE_TELEMETRY environment variable)"),a.log(o?'Run "mercurjs telemetry --disable" to opt out.':'Run "mercurjs telemetry --enable" to opt in.'),a.log(`Learn more: ${He}`);return}let t=!!e.enable;_r(t),t?a.success(`Telemetry enabled. Learn more: ${He}`):a.success("Telemetry disabled. No data will be collected.");}catch(t){j(t);}});var en=z.object({cwd:z.string()}),ni=new Command().name("view").description("view block details from the registry").argument("<blocks...>","the block names to view").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async(e,t)=>{try{let r=en.parse({cwd:R__default.resolve(t.cwd),type:t.type}),i=await b(r.cwd);i||(i=G({resolvedPaths:{cwd:r.cwd}}));let o=await tt(e,{config:i});console.log(JSON.stringify(o,null,2)),process.exit(0);}catch(r){j(r);}finally{x();}});async function di(e){let t=R__default.resolve(e.root,"src/vendor");if(!Ot.existsSync(t))return true;let r=await import('vite'),i=(await import('@vitejs/plugin-react')).default,o=JSON.parse(readFileSync(R__default.resolve(e.root,"package.json"),"utf-8")),s=new Set([...Object.keys(o.dependencies||{}),...Object.keys(o.peerDependencies||{}),...Object.keys(o.devDependencies||{}),"react","react/jsx-runtime","react-router-dom","react-i18next","@medusajs/js-sdk","@medusajs/admin-sdk","@mercurjs/client","@tanstack/react-query"]),n=R__default.resolve(e.outDir,"src/vendor"),m=R__default.resolve(e.root,"src/vendor/__vendor-extensions__.js");try{let p=generatePluginEntryModule(t);await writeFile(m,p,"utf-8");let d=process.env.NODE_ENV;process.env.NODE_ENV="production",await r.build({build:{lib:{entry:m,formats:["es","cjs"],fileName:"index"},emptyOutDir:!1,minify:!1,outDir:n,rollupOptions:{external:(l,g)=>{let h=l.split("/"),w=h[0]?.startsWith("@")?`${h[0]}/${h[1]}`:h[0],_=[...builtinModules,...builtinModules.map(F=>`node:${F}`)];return g?!!(w&&s.has(w)):!!(w&&s.has(w)||w&&_.includes(w))},output:{preserveModules:!1,interop:"auto",chunkFileNames:()=>"_chunks/[name]-[hash]"}}},plugins:[i()],logLevel:"silent",clearScreen:!1}),process.env.NODE_ENV=d;let c=R__default.join(n,"index.es.js"),u=R__default.join(n,"index.mjs");return Ot.existsSync(c)&&Ot.renameSync(c,u),!0}catch(p){return console.error(p),false}finally{try{await rm(m,{force:!0});}catch{}}}var pi=new Command().name("plugin:build").description("build a Medusa plugin").option("-c, --cwd <cwd>","the working directory. defaults to the current directory.",process.cwd()).action(async e=>{try{let t=R__default.resolve(e.cwd),r=v("Building plugin..."),{Compiler:i}=await import('@medusajs/framework/build-tools'),o=new i(t,a),s=await o.loadTSConfigFile();s||(r.fail("Unable to compile plugin \u2014 tsconfig not found."),process.exit(1));let n=await import('@medusajs/admin-bundler'),m=R__default.resolve(t,".medusa/server");(await Promise.all([o.buildPluginBackend(s),o.buildPluginAdminExtensions(n),di({root:t,outDir:m})])).every(d=>d===!0)?r.succeed("Plugin built successfully."):(r.fail("Plugin build failed."),process.exit(1));}catch(t){a.break(),j(t);}});process.on("SIGINT",()=>process.exit(0));process.on("SIGTERM",()=>process.exit(0));async function dn(){let e=new Command().name("@mercurjs/cli").description("Add blocks from registries to your project").version(Lt.version,"-v, --version","display the version number");e.addCommand(Sr).addCommand(Cr).addCommand(Br).addCommand(Vr).addCommand(Xr).addCommand(ti).addCommand(ri).addCommand(Er).addCommand(ii).addCommand(oi).addCommand(ni).addCommand(pi),e.parse();}dn();export{gi as registryConfigItemSchema,Wt as registryConfigSchema,ln as registryIndexSchema,Ut as registryItemFileSchema,$ as registryItemSchema,fi as registryItemTypeSchema,Bt as registryResolvedItemsTreeSchema,K as registrySchema};//# sourceMappingURL=index.js.map
54
69
  //# sourceMappingURL=index.js.map