@nlabs/lex 1.55.2 → 1.56.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.
@@ -119,7 +119,7 @@ const getNetworkAddresses = ()=>{
119
119
  }
120
120
  return addresses;
121
121
  };
122
- const displayServerStatus = (port = DEFAULT_DEV_PORT, quiet, publicIp)=>{
122
+ const displayServerStatus = (port = DEFAULT_DEV_PORT, quiet = false, publicIp)=>{
123
123
  if (quiet) {
124
124
  return;
125
125
  }
@@ -258,7 +258,7 @@ export const dev = async (cmd, callback = ()=>({}))=>{
258
258
  let detectedPort = finalPort;
259
259
  childProcess.stdout?.on('data', (data)=>{
260
260
  const output = data.toString();
261
- handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');
261
+ handleWebpackProgress(output, spinner, quiet ?? false, '🚀', 'Webpack Building');
262
262
  if (!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {
263
263
  serverStarted = true;
264
264
  spinner.succeed('Development server started.');
@@ -271,7 +271,7 @@ export const dev = async (cmd, callback = ()=>({}))=>{
271
271
  });
272
272
  childProcess.stderr?.on('data', (data)=>{
273
273
  const output = data.toString();
274
- handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');
274
+ handleWebpackProgress(output, spinner, quiet ?? false, '🚀', 'Webpack Building');
275
275
  if (!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {
276
276
  serverStarted = true;
277
277
  spinner.succeed('Development server started.');
@@ -303,4 +303,4 @@ export const dev = async (cmd, callback = ()=>({}))=>{
303
303
  }
304
304
  };
305
305
 
306
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/dev/dev.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport {execa} from 'execa';\nimport {existsSync, readFileSync, writeFileSync, mkdirSync} from 'fs';\nimport https from 'https';\nimport {networkInterfaces, homedir} from 'os';\nimport {dirname, resolve as pathResolve, join} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, handleWebpackProgress, removeFiles} from '../../utils/app.js';\nimport {resolveWebpackPaths} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {processTranslations} from '../../utils/translations.js';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  // eslint-disable-next-line no-eval\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch{\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface DevOptions {\n  readonly bundleAnalyzer?: boolean;\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly format?: string;\n  readonly open?: boolean;\n  readonly port?: number;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly translations?: boolean;\n  readonly usePublicIp?: boolean;\n  readonly variables?: string;\n}\n\nexport type DevCallback = (status: number) => void;\n\n// default port used by the development server when none is provided\nexport const DEFAULT_DEV_PORT = 3000;\n\ninterface PublicIpCache {\n  ip: string;\n  timestamp: number;\n}\n\nconst parsePort = (portValue: unknown): number | undefined => {\n  if(portValue === undefined || portValue === null || portValue === '') {\n    return undefined;\n  }\n\n  const parsed = Number(portValue);\n  if(Number.isInteger(parsed) && parsed > 0) {\n    return parsed;\n  }\n\n  return undefined;\n};\n\nconst getCacheDir = (): string => {\n  const cacheDir = join(homedir(), '.lex-cache');\n  if(!existsSync(cacheDir)) {\n    mkdirSync(cacheDir, {recursive: true});\n  }\n  return cacheDir;\n};\n\nconst getCachePath = (): string => join(getCacheDir(), 'public-ip.json');\n\nconst readPublicIpCache = (): PublicIpCache | null => {\n  const cachePath = getCachePath();\n  if(!existsSync(cachePath)) {\n    return null;\n  }\n\n  try {\n    const cacheData = readFileSync(cachePath, 'utf8');\n    const cache: PublicIpCache = JSON.parse(cacheData);\n    const oneWeekMs = 7 * 24 * 60 * 60 * 1000;\n\n    if(Date.now() - cache.timestamp > oneWeekMs) {\n      return null;\n    }\n\n    return cache;\n  } catch{\n    return null;\n  }\n};\n\nconst writePublicIpCache = (ip: string): void => {\n  const cachePath = getCachePath();\n  const cache: PublicIpCache = {\n    ip,\n    timestamp: Date.now()\n  };\n  writeFileSync(cachePath, JSON.stringify(cache, null, 2));\n};\n\nconst fetchPublicIp = (forceRefresh: boolean = false): Promise<string | undefined> => new Promise((resolve) => {\n  if(!forceRefresh) {\n    const cached = readPublicIpCache();\n    if(cached) {\n      resolve(cached.ip);\n      return;\n    }\n  }\n\n  https.get('https://api.ipify.org', (res) => {\n    let data = '';\n    res.on('data', (chunk) => (data += chunk));\n    res.on('end', () => {\n      const ip = data.trim();\n      if(ip) {\n        writePublicIpCache(ip);\n      }\n      resolve(ip);\n    });\n  }).on('error', () => resolve(undefined));\n});\n\nconst getNetworkAddresses = () => {\n  const interfaces = networkInterfaces();\n  const addresses = {\n    local: 'localhost',\n    private: null,\n    public: null\n  };\n\n  for(const name of Object.keys(interfaces)) {\n    const networkInterface = interfaces[name];\n    if(!networkInterface) {\n      continue;\n    }\n\n    for(const iface of networkInterface) {\n      if(iface.family === 'IPv4' && !iface.internal) {\n        const ip = iface.address;\n\n        if(ip.startsWith('10.') || ip.startsWith('192.168.') || ip.startsWith('172.')) {\n          if(!addresses.private) {\n            addresses.private = ip;\n          }\n        } else {\n          if(!addresses.public) {\n            addresses.public = ip;\n          }\n        }\n      }\n    }\n  }\n\n  return addresses;\n};\n\nconst displayServerStatus = (port: number = DEFAULT_DEV_PORT, quiet: boolean, publicIp?: string) => {\n  if(quiet) {\n    return;\n  }\n\n  const addresses = getNetworkAddresses();\n  const localUrl = `http://localhost:${port}`;\n  const privateUrl = addresses.private ? `http://${addresses.private}:${port}` : null;\n  let publicUrl = null;\n  if(publicIp) {\n    publicUrl = `http://${publicIp}:${port}`;\n  } else if(addresses.public) {\n    publicUrl = `http://${addresses.public}:${port}`;\n  }\n\n  let urlLines = `${chalk.green('Local:')}     ${chalk.underline(localUrl)}\\n`;\n\n  if(privateUrl) {\n    urlLines += `${chalk.green('Private:')}   ${chalk.underline(privateUrl)}\\n`;\n  }\n\n  if(publicUrl) {\n    urlLines += `${chalk.green('Public:')}    ${chalk.underline(publicUrl)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🚀 Development Server Running')}\\n\\n${urlLines}\\n` +\n    `${chalk.yellow('Press Ctrl+C to stop the server')}`,\n    {\n      backgroundColor: '#1a1a1a',\n      borderColor: 'cyan',\n      borderStyle: 'round',\n      margin: 1,\n      padding: 1\n    }\n  );\n\n  // eslint-disable-next-line no-console\n  console.log(`\\n${statusBox}\\n`);\n};\n\nexport const dev = async (cmd: DevOptions, callback: DevCallback = () => ({})): Promise<number> => {\n  const {bundleAnalyzer, cliName = 'Lex', config, format = 'esm', open = false, port: cliPort, quiet, remove, translations = false, usePublicIp, variables} = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} start development server...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {dev: devConfig, outputFullPath, useTypescript} = LexConfig.config;\n  const finalPort = parsePort(cliPort) ?? parsePort(devConfig?.port) ?? DEFAULT_DEV_PORT;\n\n  let variablesObj: object = {NODE_ENV: 'development'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  if(useTypescript) {\n    LexConfig.checkTypescriptConfig();\n  }\n\n  if(remove) {\n    spinner.start('Cleaning output directory...');\n\n    await removeFiles(outputFullPath || '');\n\n    spinner.succeed('Successfully cleaned output directory!');\n  }\n\n  if(translations) {\n    spinner.start('Processing translations...');\n\n    try {\n      const sourcePath = LexConfig.config.sourceFullPath || process.cwd();\n      const outputPath = LexConfig.config.outputFullPath || 'lib';\n\n      await processTranslations(sourcePath, outputPath, quiet);\n      spinner.succeed('Translations processed successfully!');\n    } catch(translationError) {\n      log(`\\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);\n      spinner.fail('Failed to process translations.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    const {webpackConfig: resolvedConfig} = resolveWebpackPaths(currentDirname);\n    webpackConfig = resolvedConfig;\n  }\n\n  const {webpackPath} = resolveWebpackPaths(currentDirname);\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--watch',\n    '--config', webpackConfig\n  ];\n\n  if(bundleAnalyzer) {\n    webpackOptions.push('--bundleAnalyzer');\n  }\n\n  try {\n    let executablePath = webpackPath;\n    let finalWebpackOptions: string[];\n\n    if(webpackPath === 'npx') {\n      finalWebpackOptions = ['webpack', ...webpackOptions];\n    } else if(webpackPath.endsWith('.js')) {\n      executablePath = 'node';\n      finalWebpackOptions = [webpackPath, ...webpackOptions];\n    } else {\n      finalWebpackOptions = webpackOptions;\n    }\n\n    spinner.start('Starting development server...');\n\n    const childProcess = execa(executablePath, finalWebpackOptions, {\n      encoding: 'utf8',\n      env: {\n        ...process.env,\n        LEX_QUIET: quiet,\n        WEBPACK_DEV_OPEN: open,\n        WEBPACK_DEV_PORT: finalPort.toString()\n      },\n      stdio: 'pipe'\n    } as any);\n\n    let serverStarted = false;\n    let statusShown = false;\n    const showStatusOnce = (portToShow: number) => {\n      if(statusShown) {\n        return;\n      }\n      statusShown = true;\n      if(usePublicIp) {\n        fetchPublicIp(usePublicIp).then((publicIp) => {\n          displayServerStatus(portToShow, quiet, publicIp);\n        });\n      } else {\n        displayServerStatus(portToShow, quiet);\n      }\n    };\n    let detectedPort = finalPort;\n\n    childProcess.stdout?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');\n\n      if(!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {\n        serverStarted = true;\n        spinner.succeed('Development server started.');\n\n        const portMatch = output.match(/Local:\\s*http:\\/\\/[^:]+:(\\d+)/) ||\n          output.match(/http:\\/\\/localhost:(\\d+)/) ||\n          output.match(/port:\\s*(\\d+)/) ||\n          output.match(/listening on port (\\d+)/) ||\n          output.match(/WebpackPluginServe listening on port (\\d+)/);\n        if(portMatch) {\n          detectedPort = parseInt(portMatch[1]);\n        }\n\n        showStatusOnce(detectedPort);\n      }\n    });\n\n    childProcess.stderr?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet, '🚀', 'Webpack Building');\n\n      if(!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {\n        serverStarted = true;\n        spinner.succeed('Development server started.');\n\n        const portMatch = output.match(/Local:\\s*http:\\/\\/[^:]+:(\\d+)/) ||\n          output.match(/http:\\/\\/localhost:(\\d+)/) ||\n          output.match(/port:\\s*(\\d+)/) ||\n          output.match(/listening on port (\\d+)/) ||\n          output.match(/WebpackPluginServe listening on port (\\d+)/);\n        if(portMatch) {\n          detectedPort = parseInt(portMatch[1]);\n        }\n\n        showStatusOnce(detectedPort);\n      }\n    });\n\n    setTimeout(() => {\n      if(!serverStarted) {\n        spinner.succeed('Development server started.');\n        showStatusOnce(detectedPort);\n      }\n    }, 5000);\n\n    await childProcess;\n\n    if(!serverStarted) {\n      spinner.succeed('Development server started.');\n      showStatusOnce(detectedPort);\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    spinner.fail('There was an error while running Webpack.');\n\n    callback(1);\n    return 1;\n  }\n};\n"],"names":["boxen","chalk","execa","existsSync","readFileSync","writeFileSync","mkdirSync","https","networkInterfaces","homedir","dirname","resolve","pathResolve","join","LexConfig","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","log","processTranslations","currentFilename","currentDirname","eval","process","cwd","DEFAULT_DEV_PORT","parsePort","portValue","undefined","parsed","Number","isInteger","getCacheDir","cacheDir","recursive","getCachePath","readPublicIpCache","cachePath","cacheData","cache","JSON","parse","oneWeekMs","Date","now","timestamp","writePublicIpCache","ip","stringify","fetchPublicIp","forceRefresh","Promise","cached","get","res","data","on","chunk","trim","getNetworkAddresses","interfaces","addresses","local","private","public","name","Object","keys","networkInterface","iface","family","internal","address","startsWith","displayServerStatus","port","quiet","publicIp","localUrl","privateUrl","publicUrl","urlLines","green","underline","statusBox","cyan","bold","yellow","backgroundColor","borderColor","borderStyle","margin","padding","console","dev","cmd","callback","bundleAnalyzer","cliName","config","format","open","cliPort","remove","translations","usePublicIp","variables","spinner","parseConfig","devConfig","outputFullPath","useTypescript","finalPort","variablesObj","NODE_ENV","_error","env","checkTypescriptConfig","start","succeed","sourcePath","sourceFullPath","outputPath","translationError","message","fail","webpackConfig","isRelativeConfig","substr","resolvedConfig","webpackPath","webpackOptions","push","executablePath","finalWebpackOptions","endsWith","childProcess","encoding","LEX_QUIET","WEBPACK_DEV_OPEN","WEBPACK_DEV_PORT","toString","stdio","serverStarted","statusShown","showStatusOnce","portToShow","then","detectedPort","stdout","output","includes","portMatch","match","parseInt","stderr","setTimeout","error"],"mappings":"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"}
306
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/dev/dev.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport {execa} from 'execa';\nimport {existsSync, readFileSync, writeFileSync, mkdirSync} from 'fs';\nimport https from 'https';\nimport {networkInterfaces, homedir} from 'os';\nimport {dirname, resolve as pathResolve, join} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, handleWebpackProgress, removeFiles} from '../../utils/app.js';\nimport {resolveWebpackPaths} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\nimport {processTranslations} from '../../utils/translations.js';\n\nlet currentFilename: string;\nlet currentDirname: string;\n\ntry {\n  // eslint-disable-next-line no-eval\n  currentFilename = eval('require(\"url\").fileURLToPath(import.meta.url)');\n  currentDirname = dirname(currentFilename);\n} catch{\n  currentFilename = process.cwd();\n  currentDirname = process.cwd();\n}\n\nexport interface DevOptions {\n  readonly bundleAnalyzer?: boolean;\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly format?: string;\n  readonly open?: boolean;\n  readonly port?: number;\n  readonly quiet?: boolean;\n  readonly remove?: boolean;\n  readonly translations?: boolean;\n  readonly usePublicIp?: boolean;\n  readonly variables?: string;\n}\n\nexport type DevCallback = (status: number) => void;\n\n// default port used by the development server when none is provided\nexport const DEFAULT_DEV_PORT = 3000;\n\ninterface PublicIpCache {\n  ip: string;\n  timestamp: number;\n}\n\nconst parsePort = (portValue: unknown): number | undefined => {\n  if(portValue === undefined || portValue === null || portValue === '') {\n    return undefined;\n  }\n\n  const parsed = Number(portValue);\n  if(Number.isInteger(parsed) && parsed > 0) {\n    return parsed;\n  }\n\n  return undefined;\n};\n\nconst getCacheDir = (): string => {\n  const cacheDir = join(homedir(), '.lex-cache');\n  if(!existsSync(cacheDir)) {\n    mkdirSync(cacheDir, {recursive: true});\n  }\n  return cacheDir;\n};\n\nconst getCachePath = (): string => join(getCacheDir(), 'public-ip.json');\n\nconst readPublicIpCache = (): PublicIpCache | null => {\n  const cachePath = getCachePath();\n  if(!existsSync(cachePath)) {\n    return null;\n  }\n\n  try {\n    const cacheData = readFileSync(cachePath, 'utf8');\n    const cache: PublicIpCache = JSON.parse(cacheData);\n    const oneWeekMs = 7 * 24 * 60 * 60 * 1000;\n\n    if(Date.now() - cache.timestamp > oneWeekMs) {\n      return null;\n    }\n\n    return cache;\n  } catch{\n    return null;\n  }\n};\n\nconst writePublicIpCache = (ip: string): void => {\n  const cachePath = getCachePath();\n  const cache: PublicIpCache = {\n    ip,\n    timestamp: Date.now()\n  };\n  writeFileSync(cachePath, JSON.stringify(cache, null, 2));\n};\n\nconst fetchPublicIp = (forceRefresh: boolean = false): Promise<string | undefined> => new Promise((resolve) => {\n  if(!forceRefresh) {\n    const cached = readPublicIpCache();\n    if(cached) {\n      resolve(cached.ip);\n      return;\n    }\n  }\n\n  https.get('https://api.ipify.org', (res) => {\n    let data = '';\n    res.on('data', (chunk) => (data += chunk));\n    res.on('end', () => {\n      const ip = data.trim();\n      if(ip) {\n        writePublicIpCache(ip);\n      }\n      resolve(ip);\n    });\n  }).on('error', () => resolve(undefined));\n});\n\nconst getNetworkAddresses = () => {\n  const interfaces = networkInterfaces();\n  const addresses = {\n    local: 'localhost',\n    private: null as string | null,\n    public: null as string | null\n  };\n\n  for(const name of Object.keys(interfaces)) {\n    const networkInterface = interfaces[name];\n    if(!networkInterface) {\n      continue;\n    }\n\n    for(const iface of networkInterface) {\n      if(iface.family === 'IPv4' && !iface.internal) {\n        const ip = iface.address;\n\n        if(ip.startsWith('10.') || ip.startsWith('192.168.') || ip.startsWith('172.')) {\n          if(!addresses.private) {\n            addresses.private = ip;\n          }\n        } else {\n          if(!addresses.public) {\n            addresses.public = ip;\n          }\n        }\n      }\n    }\n  }\n\n  return addresses;\n};\n\nconst displayServerStatus = (port: number = DEFAULT_DEV_PORT, quiet: boolean = false, publicIp?: string) => {\n  if(quiet) {\n    return;\n  }\n\n  const addresses = getNetworkAddresses();\n  const localUrl = `http://localhost:${port}`;\n  const privateUrl = addresses.private ? `http://${addresses.private}:${port}` : null;\n  let publicUrl = null;\n  if(publicIp) {\n    publicUrl = `http://${publicIp}:${port}`;\n  } else if(addresses.public) {\n    publicUrl = `http://${addresses.public}:${port}`;\n  }\n\n  let urlLines = `${chalk.green('Local:')}     ${chalk.underline(localUrl)}\\n`;\n\n  if(privateUrl) {\n    urlLines += `${chalk.green('Private:')}   ${chalk.underline(privateUrl)}\\n`;\n  }\n\n  if(publicUrl) {\n    urlLines += `${chalk.green('Public:')}    ${chalk.underline(publicUrl)}\\n`;\n  }\n\n  const statusBox = boxen(\n    `${chalk.cyan.bold('🚀 Development Server Running')}\\n\\n${urlLines}\\n` +\n    `${chalk.yellow('Press Ctrl+C to stop the server')}`,\n    {\n      backgroundColor: '#1a1a1a',\n      borderColor: 'cyan',\n      borderStyle: 'round',\n      margin: 1,\n      padding: 1\n    }\n  );\n\n  // eslint-disable-next-line no-console\n  console.log(`\\n${statusBox}\\n`);\n};\n\nexport const dev = async (cmd: DevOptions, callback: DevCallback = () => ({})): Promise<number> => {\n  const {bundleAnalyzer, cliName = 'Lex', config, format = 'esm', open = false, port: cliPort, quiet, remove, translations = false, usePublicIp, variables} = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(`${cliName} start development server...`, 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  const {dev: devConfig, outputFullPath, useTypescript} = LexConfig.config;\n  const finalPort = parsePort(cliPort) ?? parsePort(devConfig?.port) ?? DEFAULT_DEV_PORT;\n\n  let variablesObj: object = {NODE_ENV: 'development'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  if(useTypescript) {\n    LexConfig.checkTypescriptConfig();\n  }\n\n  if(remove) {\n    spinner.start('Cleaning output directory...');\n\n    await removeFiles(outputFullPath || '');\n\n    spinner.succeed('Successfully cleaned output directory!');\n  }\n\n  if(translations) {\n    spinner.start('Processing translations...');\n\n    try {\n      const sourcePath = LexConfig.config.sourceFullPath || process.cwd();\n      const outputPath = LexConfig.config.outputFullPath || 'lib';\n\n      await processTranslations(sourcePath, outputPath, quiet);\n      spinner.succeed('Translations processed successfully!');\n    } catch(translationError) {\n      log(`\\n${cliName} Error: Failed to process translations: ${translationError.message}`, 'error', quiet);\n      spinner.fail('Failed to process translations.');\n      callback(1);\n      return 1;\n    }\n  }\n\n  let webpackConfig: string;\n\n  if(config) {\n    const isRelativeConfig: boolean = config.substr(0, 2) === './';\n    webpackConfig = isRelativeConfig ? pathResolve(process.cwd(), config) : config;\n  } else {\n    const {webpackConfig: resolvedConfig} = resolveWebpackPaths(currentDirname);\n    webpackConfig = resolvedConfig;\n  }\n\n  const {webpackPath} = resolveWebpackPaths(currentDirname);\n\n  const webpackOptions: string[] = [\n    '--color',\n    '--watch',\n    '--config', webpackConfig\n  ];\n\n  if(bundleAnalyzer) {\n    webpackOptions.push('--bundleAnalyzer');\n  }\n\n  try {\n    let executablePath = webpackPath;\n    let finalWebpackOptions: string[];\n\n    if(webpackPath === 'npx') {\n      finalWebpackOptions = ['webpack', ...webpackOptions];\n    } else if(webpackPath.endsWith('.js')) {\n      executablePath = 'node';\n      finalWebpackOptions = [webpackPath, ...webpackOptions];\n    } else {\n      finalWebpackOptions = webpackOptions;\n    }\n\n    spinner.start('Starting development server...');\n\n    const childProcess = execa(executablePath, finalWebpackOptions, {\n      encoding: 'utf8',\n      env: {\n        ...process.env,\n        LEX_QUIET: quiet,\n        WEBPACK_DEV_OPEN: open,\n        WEBPACK_DEV_PORT: finalPort.toString()\n      },\n      stdio: 'pipe'\n    } as any);\n\n    let serverStarted = false;\n    let statusShown = false;\n    const showStatusOnce = (portToShow: number) => {\n      if(statusShown) {\n        return;\n      }\n      statusShown = true;\n      if(usePublicIp) {\n        fetchPublicIp(usePublicIp).then((publicIp) => {\n          displayServerStatus(portToShow, quiet, publicIp);\n        });\n      } else {\n        displayServerStatus(portToShow, quiet);\n      }\n    };\n    let detectedPort = finalPort;\n\n    childProcess.stdout?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet ?? false, '🚀', 'Webpack Building');\n\n      if(!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {\n        serverStarted = true;\n        spinner.succeed('Development server started.');\n\n        const portMatch = output.match(/Local:\\s*http:\\/\\/[^:]+:(\\d+)/) ||\n          output.match(/http:\\/\\/localhost:(\\d+)/) ||\n          output.match(/port:\\s*(\\d+)/) ||\n          output.match(/listening on port (\\d+)/) ||\n          output.match(/WebpackPluginServe listening on port (\\d+)/);\n        if(portMatch) {\n          detectedPort = parseInt(portMatch[1]);\n        }\n\n        showStatusOnce(detectedPort);\n      }\n    });\n\n    childProcess.stderr?.on('data', (data: Buffer) => {\n      const output = data.toString();\n\n      handleWebpackProgress(output, spinner, quiet ?? false, '🚀', 'Webpack Building');\n\n      if(!serverStarted && (output.includes('Local:') || output.includes('webpack compiled') || output.includes('webpack-plugin-serve') || output.includes('http://localhost') || output.includes('listening on port'))) {\n        serverStarted = true;\n        spinner.succeed('Development server started.');\n\n        const portMatch = output.match(/Local:\\s*http:\\/\\/[^:]+:(\\d+)/) ||\n          output.match(/http:\\/\\/localhost:(\\d+)/) ||\n          output.match(/port:\\s*(\\d+)/) ||\n          output.match(/listening on port (\\d+)/) ||\n          output.match(/WebpackPluginServe listening on port (\\d+)/);\n        if(portMatch) {\n          detectedPort = parseInt(portMatch[1]);\n        }\n\n        showStatusOnce(detectedPort);\n      }\n    });\n\n    setTimeout(() => {\n      if(!serverStarted) {\n        spinner.succeed('Development server started.');\n        showStatusOnce(detectedPort);\n      }\n    }, 5000);\n\n    await childProcess;\n\n    if(!serverStarted) {\n      spinner.succeed('Development server started.');\n      showStatusOnce(detectedPort);\n    }\n\n    callback(0);\n    return 0;\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    spinner.fail('There was an error while running Webpack.');\n\n    callback(1);\n    return 1;\n  }\n};\n"],"names":["boxen","chalk","execa","existsSync","readFileSync","writeFileSync","mkdirSync","https","networkInterfaces","homedir","dirname","resolve","pathResolve","join","LexConfig","createSpinner","handleWebpackProgress","removeFiles","resolveWebpackPaths","log","processTranslations","currentFilename","currentDirname","eval","process","cwd","DEFAULT_DEV_PORT","parsePort","portValue","undefined","parsed","Number","isInteger","getCacheDir","cacheDir","recursive","getCachePath","readPublicIpCache","cachePath","cacheData","cache","JSON","parse","oneWeekMs","Date","now","timestamp","writePublicIpCache","ip","stringify","fetchPublicIp","forceRefresh","Promise","cached","get","res","data","on","chunk","trim","getNetworkAddresses","interfaces","addresses","local","private","public","name","Object","keys","networkInterface","iface","family","internal","address","startsWith","displayServerStatus","port","quiet","publicIp","localUrl","privateUrl","publicUrl","urlLines","green","underline","statusBox","cyan","bold","yellow","backgroundColor","borderColor","borderStyle","margin","padding","console","dev","cmd","callback","bundleAnalyzer","cliName","config","format","open","cliPort","remove","translations","usePublicIp","variables","spinner","parseConfig","devConfig","outputFullPath","useTypescript","finalPort","variablesObj","NODE_ENV","_error","env","checkTypescriptConfig","start","succeed","sourcePath","sourceFullPath","outputPath","translationError","message","fail","webpackConfig","isRelativeConfig","substr","resolvedConfig","webpackPath","webpackOptions","push","executablePath","finalWebpackOptions","endsWith","childProcess","encoding","LEX_QUIET","WEBPACK_DEV_OPEN","WEBPACK_DEV_PORT","toString","stdio","serverStarted","statusShown","showStatusOnce","portToShow","then","detectedPort","stdout","output","includes","portMatch","match","parseInt","stderr","setTimeout","error"],"mappings":"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"}
@@ -14,7 +14,7 @@ export const publish = async (cmd, callback = process.exit)=>{
14
14
  // Get custom configuration
15
15
  await LexConfig.parseConfig(cmd);
16
16
  const { packageManager: configPackageManager } = LexConfig.config;
17
- const packageManager = cmdPackageManager || configPackageManager;
17
+ const packageManager = cmdPackageManager || configPackageManager || 'npm';
18
18
  const publishOptions = [
19
19
  'publish'
20
20
  ];
@@ -64,20 +64,25 @@ export const publish = async (cmd, callback = process.exit)=>{
64
64
  ];
65
65
  // Make sure the version in package.json is valid
66
66
  const packageVersion = semver.coerce(prevVersion);
67
- if (!semver.valid(packageVersion)) {
67
+ if (!packageVersion || !semver.valid(packageVersion)) {
68
68
  log(`\n${cliName} Error: Version is invalid in package.json`, 'error', quiet);
69
69
  callback(1);
70
70
  return 1;
71
71
  }
72
72
  if (validReleases.includes(formatBump)) {
73
- nextVersion = semver.inc(packageVersion, formatBump);
73
+ nextVersion = semver.inc(packageVersion, formatBump) || undefined;
74
74
  } else if (validPreReleases.includes(formatBump)) {
75
- nextVersion = semver.inc(packageVersion, 'prerelease', formatBump);
75
+ nextVersion = semver.inc(packageVersion, 'prerelease', formatBump) || undefined;
76
76
  } else {
77
77
  log(`\n${cliName} Error: Bump type is invalid. please make sure it is one of the following: ${validReleases.join(', ')}, ${validPreReleases.join(', ')}`, 'error', quiet);
78
78
  callback(1);
79
79
  return 1;
80
80
  }
81
+ if (!nextVersion) {
82
+ log(`\n${cliName} Error: Could not determine the next package version.`, 'error', quiet);
83
+ callback(1);
84
+ return 1;
85
+ }
81
86
  } else {
82
87
  log(`\n${cliName} Error: Bump type is missing.`, 'error', quiet);
83
88
  callback(1);
@@ -121,4 +126,4 @@ export const publish = async (cmd, callback = process.exit)=>{
121
126
  }
122
127
  };
123
128
 
124
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/publish/publish.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport semver, {ReleaseType} from 'semver';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, getPackageJson, setPackageJson} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface PublishOptions {\n  readonly bump?: string;\n  readonly cliName?: string;\n  readonly newVersion?: string;\n  readonly otp?: string;\n  readonly packageManager?: string;\n  readonly private?: boolean;\n  readonly quiet?: boolean;\n  readonly tag?: string;\n}\n\nexport type PublishCallback = typeof process.exit;\n\nexport const publish = async (cmd: PublishOptions, callback: PublishCallback = process.exit): Promise<number> => {\n  const {bump, cliName = 'Lex', newVersion, otp, packageManager: cmdPackageManager, private: accessPrivate, tag, quiet} = cmd;\n  log(`${cliName} publishing npm module...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  const {packageManager: configPackageManager} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager;\n  const publishOptions: string[] = ['publish'];\n\n  if(accessPrivate) {\n    publishOptions.push('--access', 'restricted');\n  }\n\n  if(otp) {\n    publishOptions.push('--otp', otp);\n  }\n\n  if(tag) {\n    publishOptions.push('--tag', tag);\n  }\n\n  // Get next version number\n  let nextVersion: string;\n  const packagePath: string = `${process.cwd()}/package.json`;\n  let packageJson;\n  let packageName: string;\n  let prevVersion: string;\n\n  // If not using yarn, we'll use npm and manually update the version number\n  try {\n    packageJson = getPackageJson(packagePath);\n    packageName = packageJson.name;\n    prevVersion = packageJson.version;\n  } catch(error) {\n    log(`\\n${cliName} Error: The file, ${packagePath}, was not found or is malformed.\\n`, 'error', quiet);\n    log(error.message, 'error');\n    callback(1);\n    return 1;\n  }\n\n  // Update package.json with the latest version\n  if(newVersion) {\n    // If using a specific version, we don't need to determine the next bump\n    nextVersion = newVersion;\n  } else if(bump) {\n    // Determine next version\n    const formatBump = bump.toString()\n      .trim()\n      .toLowerCase();\n\n    if(formatBump) {\n      const validReleases: string[] = ['major', 'minor', 'patch'];\n      const validPreReleases: string[] = ['alpha', 'beta', 'rc'];\n\n      // Make sure the version in package.json is valid\n      const packageVersion = semver.coerce(prevVersion);\n\n      if(!semver.valid(packageVersion)) {\n        log(`\\n${cliName} Error: Version is invalid in package.json`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n\n      if(validReleases.includes(formatBump)) {\n        nextVersion = semver.inc(packageVersion, formatBump as ReleaseType);\n      } else if(validPreReleases.includes(formatBump)) {\n        nextVersion = semver.inc(packageVersion, 'prerelease', formatBump);\n      } else {\n        log(`\\n${cliName} Error: Bump type is invalid. please make sure it is one of the following: ${validReleases.join(', ')}, ${validPreReleases.join(', ')}`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n    } else {\n      log(`\\n${cliName} Error: Bump type is missing.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  if(nextVersion && packageManager === 'yarn') {\n    publishOptions.push('--new-version', nextVersion);\n  } else if(nextVersion && packageJson) {\n    try {\n      // Save updated version\n      setPackageJson({...packageJson, version: nextVersion}, packagePath);\n    } catch(error) {\n      log(`\\n${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${error.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  } else {\n    nextVersion = prevVersion;\n  }\n\n  try {\n    await execa(packageManager, publishOptions, {\n      encoding: 'utf8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed(`Successfully published npm package: ${packageName}!`);\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Publishing to npm has failed.');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n};"],"names":["execa","semver","LexConfig","createSpinner","getPackageJson","setPackageJson","log","publish","cmd","callback","process","exit","bump","cliName","newVersion","otp","packageManager","cmdPackageManager","private","accessPrivate","tag","quiet","spinner","parseConfig","configPackageManager","config","publishOptions","push","nextVersion","packagePath","cwd","packageJson","packageName","prevVersion","name","version","error","message","formatBump","toString","trim","toLowerCase","validReleases","validPreReleases","packageVersion","coerce","valid","includes","inc","join","encoding","stdio","succeed","fail"],"mappings":"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"}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/commands/publish/publish.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport semver, {ReleaseType} from 'semver';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner, getPackageJson, setPackageJson} from '../../utils/app.js';\nimport {log} from '../../utils/log.js';\n\nexport interface PublishOptions {\n  readonly bump?: string;\n  readonly cliName?: string;\n  readonly newVersion?: string;\n  readonly otp?: string;\n  readonly packageManager?: string;\n  readonly private?: boolean;\n  readonly quiet?: boolean;\n  readonly tag?: string;\n}\n\nexport type PublishCallback = typeof process.exit;\n\nexport const publish = async (cmd: PublishOptions, callback: PublishCallback = process.exit): Promise<number> => {\n  const {bump, cliName = 'Lex', newVersion, otp, packageManager: cmdPackageManager, private: accessPrivate, tag, quiet} = cmd;\n  log(`${cliName} publishing npm module...`, 'info', quiet);\n\n  // Spinner\n  const spinner = createSpinner(quiet);\n\n  // Get custom configuration\n  await LexConfig.parseConfig(cmd);\n\n  const {packageManager: configPackageManager} = LexConfig.config;\n  const packageManager: string = cmdPackageManager || configPackageManager || 'npm';\n  const publishOptions: string[] = ['publish'];\n\n  if(accessPrivate) {\n    publishOptions.push('--access', 'restricted');\n  }\n\n  if(otp) {\n    publishOptions.push('--otp', otp);\n  }\n\n  if(tag) {\n    publishOptions.push('--tag', tag);\n  }\n\n  // Get next version number\n  let nextVersion: string | undefined;\n  const packagePath: string = `${process.cwd()}/package.json`;\n  let packageJson;\n  let packageName: string;\n  let prevVersion: string;\n\n  // If not using yarn, we'll use npm and manually update the version number\n  try {\n    packageJson = getPackageJson(packagePath);\n    packageName = packageJson.name;\n    prevVersion = packageJson.version;\n  } catch(error) {\n    log(`\\n${cliName} Error: The file, ${packagePath}, was not found or is malformed.\\n`, 'error', quiet);\n    log(error.message, 'error');\n    callback(1);\n    return 1;\n  }\n\n  // Update package.json with the latest version\n  if(newVersion) {\n    // If using a specific version, we don't need to determine the next bump\n    nextVersion = newVersion;\n  } else if(bump) {\n    // Determine next version\n    const formatBump = bump.toString()\n      .trim()\n      .toLowerCase();\n\n    if(formatBump) {\n      const validReleases: string[] = ['major', 'minor', 'patch'];\n      const validPreReleases: string[] = ['alpha', 'beta', 'rc'];\n\n      // Make sure the version in package.json is valid\n      const packageVersion = semver.coerce(prevVersion);\n\n      if(!packageVersion || !semver.valid(packageVersion)) {\n        log(`\\n${cliName} Error: Version is invalid in package.json`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n\n      if(validReleases.includes(formatBump)) {\n        nextVersion = semver.inc(packageVersion, formatBump as ReleaseType) || undefined;\n      } else if(validPreReleases.includes(formatBump)) {\n        nextVersion = semver.inc(packageVersion, 'prerelease', formatBump) || undefined;\n      } else {\n        log(`\\n${cliName} Error: Bump type is invalid. please make sure it is one of the following: ${validReleases.join(', ')}, ${validPreReleases.join(', ')}`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n\n      if(!nextVersion) {\n        log(`\\n${cliName} Error: Could not determine the next package version.`, 'error', quiet);\n        callback(1);\n        return 1;\n      }\n    } else {\n      log(`\\n${cliName} Error: Bump type is missing.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  if(nextVersion && packageManager === 'yarn') {\n    publishOptions.push('--new-version', nextVersion);\n  } else if(nextVersion && packageJson) {\n    try {\n      // Save updated version\n      setPackageJson({...packageJson, version: nextVersion}, packagePath);\n    } catch(error) {\n      log(`\\n${cliName} Error: The file, ${packagePath}, was not found or is malformed. ${error.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  } else {\n    nextVersion = prevVersion;\n  }\n\n  try {\n    await execa(packageManager, publishOptions, {\n      encoding: 'utf8',\n      stdio: 'inherit'\n    });\n\n    spinner.succeed(`Successfully published npm package: ${packageName}!`);\n\n    // Kill process\n    callback(0);\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Publishing to npm has failed.');\n\n    // Kill process\n    callback(1);\n    return 1;\n  }\n};\n"],"names":["execa","semver","LexConfig","createSpinner","getPackageJson","setPackageJson","log","publish","cmd","callback","process","exit","bump","cliName","newVersion","otp","packageManager","cmdPackageManager","private","accessPrivate","tag","quiet","spinner","parseConfig","configPackageManager","config","publishOptions","push","nextVersion","packagePath","cwd","packageJson","packageName","prevVersion","name","version","error","message","formatBump","toString","trim","toLowerCase","validReleases","validPreReleases","packageVersion","coerce","valid","includes","inc","undefined","join","encoding","stdio","succeed","fail"],"mappings":"AAAA;;;CAGC,GACD,SAAQA,KAAK,QAAO,QAAQ;AAC5B,OAAOC,YAA2B,SAAS;AAE3C,SAAQC,SAAS,QAAO,qBAAqB;AAC7C,SAAQC,aAAa,EAAEC,cAAc,EAAEC,cAAc,QAAO,qBAAqB;AACjF,SAAQC,GAAG,QAAO,qBAAqB;AAevC,OAAO,MAAMC,UAAU,OAAOC,KAAqBC,WAA4BC,QAAQC,IAAI;IACzF,MAAM,EAACC,IAAI,EAAEC,UAAU,KAAK,EAAEC,UAAU,EAAEC,GAAG,EAAEC,gBAAgBC,iBAAiB,EAAEC,SAASC,aAAa,EAAEC,GAAG,EAAEC,KAAK,EAAC,GAAGb;IACxHF,IAAI,GAAGO,QAAQ,yBAAyB,CAAC,EAAE,QAAQQ;IAEnD,UAAU;IACV,MAAMC,UAAUnB,cAAckB;IAE9B,2BAA2B;IAC3B,MAAMnB,UAAUqB,WAAW,CAACf;IAE5B,MAAM,EAACQ,gBAAgBQ,oBAAoB,EAAC,GAAGtB,UAAUuB,MAAM;IAC/D,MAAMT,iBAAyBC,qBAAqBO,wBAAwB;IAC5E,MAAME,iBAA2B;QAAC;KAAU;IAE5C,IAAGP,eAAe;QAChBO,eAAeC,IAAI,CAAC,YAAY;IAClC;IAEA,IAAGZ,KAAK;QACNW,eAAeC,IAAI,CAAC,SAASZ;IAC/B;IAEA,IAAGK,KAAK;QACNM,eAAeC,IAAI,CAAC,SAASP;IAC/B;IAEA,0BAA0B;IAC1B,IAAIQ;IACJ,MAAMC,cAAsB,GAAGnB,QAAQoB,GAAG,GAAG,aAAa,CAAC;IAC3D,IAAIC;IACJ,IAAIC;IACJ,IAAIC;IAEJ,0EAA0E;IAC1E,IAAI;QACFF,cAAc3B,eAAeyB;QAC7BG,cAAcD,YAAYG,IAAI;QAC9BD,cAAcF,YAAYI,OAAO;IACnC,EAAE,OAAMC,OAAO;QACb9B,IAAI,CAAC,EAAE,EAAEO,QAAQ,kBAAkB,EAAEgB,YAAY,kCAAkC,CAAC,EAAE,SAASR;QAC/Ff,IAAI8B,MAAMC,OAAO,EAAE;QACnB5B,SAAS;QACT,OAAO;IACT;IAEA,8CAA8C;IAC9C,IAAGK,YAAY;QACb,wEAAwE;QACxEc,cAAcd;IAChB,OAAO,IAAGF,MAAM;QACd,yBAAyB;QACzB,MAAM0B,aAAa1B,KAAK2B,QAAQ,GAC7BC,IAAI,GACJC,WAAW;QAEd,IAAGH,YAAY;YACb,MAAMI,gBAA0B;gBAAC;gBAAS;gBAAS;aAAQ;YAC3D,MAAMC,mBAA6B;gBAAC;gBAAS;gBAAQ;aAAK;YAE1D,iDAAiD;YACjD,MAAMC,iBAAiB3C,OAAO4C,MAAM,CAACZ;YAErC,IAAG,CAACW,kBAAkB,CAAC3C,OAAO6C,KAAK,CAACF,iBAAiB;gBACnDtC,IAAI,CAAC,EAAE,EAAEO,QAAQ,0CAA0C,CAAC,EAAE,SAASQ;gBACvEZ,SAAS;gBACT,OAAO;YACT;YAEA,IAAGiC,cAAcK,QAAQ,CAACT,aAAa;gBACrCV,cAAc3B,OAAO+C,GAAG,CAACJ,gBAAgBN,eAA8BW;YACzE,OAAO,IAAGN,iBAAiBI,QAAQ,CAACT,aAAa;gBAC/CV,cAAc3B,OAAO+C,GAAG,CAACJ,gBAAgB,cAAcN,eAAeW;YACxE,OAAO;gBACL3C,IAAI,CAAC,EAAE,EAAEO,QAAQ,2EAA2E,EAAE6B,cAAcQ,IAAI,CAAC,MAAM,EAAE,EAAEP,iBAAiBO,IAAI,CAAC,OAAO,EAAE,SAAS7B;gBACnKZ,SAAS;gBACT,OAAO;YACT;YAEA,IAAG,CAACmB,aAAa;gBACftB,IAAI,CAAC,EAAE,EAAEO,QAAQ,qDAAqD,CAAC,EAAE,SAASQ;gBAClFZ,SAAS;gBACT,OAAO;YACT;QACF,OAAO;YACLH,IAAI,CAAC,EAAE,EAAEO,QAAQ,6BAA6B,CAAC,EAAE,SAASQ;YAC1DZ,SAAS;YACT,OAAO;QACT;IACF;IAEA,IAAGmB,eAAeZ,mBAAmB,QAAQ;QAC3CU,eAAeC,IAAI,CAAC,iBAAiBC;IACvC,OAAO,IAAGA,eAAeG,aAAa;QACpC,IAAI;YACF,uBAAuB;YACvB1B,eAAe;gBAAC,GAAG0B,WAAW;gBAAEI,SAASP;YAAW,GAAGC;QACzD,EAAE,OAAMO,OAAO;YACb9B,IAAI,CAAC,EAAE,EAAEO,QAAQ,kBAAkB,EAAEgB,YAAY,iCAAiC,EAAEO,MAAMC,OAAO,EAAE,EAAE,SAAShB;YAC9GZ,SAAS;YACT,OAAO;QACT;IACF,OAAO;QACLmB,cAAcK;IAChB;IAEA,IAAI;QACF,MAAMjC,MAAMgB,gBAAgBU,gBAAgB;YAC1CyB,UAAU;YACVC,OAAO;QACT;QAEA9B,QAAQ+B,OAAO,CAAC,CAAC,oCAAoC,EAAErB,YAAY,CAAC,CAAC;QAErE,eAAe;QACfvB,SAAS;QACT,OAAO;IACT,EAAE,OAAM2B,OAAO;QACb,wBAAwB;QACxB9B,IAAI,CAAC,EAAE,EAAEO,QAAQ,QAAQ,EAAEuB,MAAMC,OAAO,EAAE,EAAE,SAAShB;QAErD,eAAe;QACfC,QAAQgC,IAAI,CAAC;QAEb,eAAe;QACf7C,SAAS;QACT,OAAO;IACT;AACF,EAAE"}