@nlabs/lex 1.52.10 → 1.52.11

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/lib/LexConfig.js CHANGED
@@ -14,7 +14,8 @@ function _define_property(obj, key, value) {
14
14
  /**
15
15
  * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
16
16
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
17
- */ import { existsSync, readFileSync, writeFileSync } from 'fs';
17
+ */ import findFileUp from 'find-file-up';
18
+ import { existsSync, readFileSync, writeFileSync } from 'fs';
18
19
  import { dirname, extname as pathExtname, relative as pathRelative, resolve as pathResolve } from 'path';
19
20
  import { URL } from 'url';
20
21
  import { getDirName, getLexPackageJsonPath, relativeFilePath } from './utils/file.js';
@@ -78,30 +79,94 @@ export const defaultConfigValues = {
78
79
  staticPath: './src/static'
79
80
  }
80
81
  };
82
+ const getPackageDir = ()=>{
83
+ const cwd = process.cwd();
84
+ const currentPkgPath = pathResolve(cwd, 'package.json');
85
+ if (existsSync(currentPkgPath)) {
86
+ try {
87
+ const pkg = JSON.parse(readFileSync(currentPkgPath, 'utf8'));
88
+ if (!pkg.workspaces) {
89
+ return cwd;
90
+ }
91
+ } catch {
92
+ return cwd;
93
+ }
94
+ }
95
+ let searchDir = cwd;
96
+ for(let i = 0; i < 10; i++){
97
+ const pkgPath = pathResolve(searchDir, 'package.json');
98
+ if (existsSync(pkgPath)) {
99
+ try {
100
+ const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));
101
+ if (!pkg.workspaces) {
102
+ return searchDir;
103
+ }
104
+ } catch {
105
+ // Continue searching
106
+ }
107
+ }
108
+ const parent = dirname(searchDir);
109
+ if (parent === searchDir) {
110
+ break;
111
+ }
112
+ searchDir = parent;
113
+ }
114
+ const configFormats = [
115
+ 'js',
116
+ 'mjs',
117
+ 'cjs',
118
+ 'ts',
119
+ 'json'
120
+ ];
121
+ for (const format of configFormats){
122
+ const configPath = findFileUp.sync(`lex.config.${format}`, cwd, 5);
123
+ if (configPath) {
124
+ return dirname(configPath);
125
+ }
126
+ }
127
+ return cwd;
128
+ };
81
129
  export const getTypeScriptConfigPath = (configName)=>{
130
+ const packageDir = getPackageDir();
82
131
  const cwd = process.cwd();
83
132
  if (configName === 'tsconfig.build.json') {
84
- const projectBuildConfig = pathResolve(cwd, 'tsconfig.build.json');
133
+ const projectBuildConfig = pathResolve(packageDir, 'tsconfig.build.json');
85
134
  if (existsSync(projectBuildConfig)) {
86
135
  return projectBuildConfig;
87
136
  }
137
+ const rootBuildConfig = pathResolve(cwd, 'tsconfig.build.json');
138
+ if (existsSync(rootBuildConfig)) {
139
+ return rootBuildConfig;
140
+ }
88
141
  }
89
142
  if (configName === 'tsconfig.lint.json') {
90
- const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');
143
+ const projectLintConfig = pathResolve(packageDir, 'tsconfig.eslint.json');
91
144
  if (existsSync(projectLintConfig)) {
92
145
  return projectLintConfig;
93
146
  }
147
+ const rootLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');
148
+ if (existsSync(rootLintConfig)) {
149
+ return rootLintConfig;
150
+ }
94
151
  }
95
152
  if (configName === 'tsconfig.test.json') {
96
- const projectTestConfig = pathResolve(cwd, 'tsconfig.test.json');
153
+ const projectTestConfig = pathResolve(packageDir, 'tsconfig.test.json');
97
154
  if (existsSync(projectTestConfig)) {
98
155
  return projectTestConfig;
99
156
  }
157
+ const rootTestConfig = pathResolve(cwd, 'tsconfig.test.json');
158
+ if (existsSync(rootTestConfig)) {
159
+ return rootTestConfig;
160
+ }
100
161
  }
101
- const projectConfigPath = pathResolve(cwd, configName);
162
+ const projectConfigPath = pathResolve(packageDir, configName);
102
163
  if (existsSync(projectConfigPath)) {
103
164
  return projectConfigPath;
104
165
  }
166
+ const rootConfigPath = pathResolve(cwd, configName);
167
+ if (existsSync(rootConfigPath)) {
168
+ return rootConfigPath;
169
+ }
105
170
  const lexDir = LexConfig.getLexDir();
106
171
  return pathResolve(lexDir, configName);
107
172
  };
@@ -343,4 +408,4 @@ _define_property(LexConfig, "config", {
343
408
  ...defaultConfigValues
344
409
  });
345
410
 
346
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/LexConfig.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 {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Options} from '@swc/core';\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface JestConfig {\n  [key: string]: unknown;\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  transformIgnorePatterns?: string[];\n  moduleNameMapper?: Record<string, string>;\n  extensionsToTreatAsEsm?: string[];\n  preset?: string;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  jest?: JestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  swc?: SWCOptions;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  jest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2023',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n  return pathResolve(lexDir, configName);\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {entryJs, sourceFullPath, targetEnvironment} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n\n    LexConfig.config.swc.jsc.parser = {\n      syntax: 'typescript',\n      tsx: true\n    };\n\n    if(targetEnvironment === 'web') {\n      LexConfig.config.swc.jsc.transform = {\n        react: {\n          runtime: 'automatic'\n        }\n      };\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n    const currentCwd = process.cwd();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(currentCwd, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(currentCwd, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(currentCwd, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(currentCwd, params.sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            // eslint-disable-next-line no-console\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = getDirName();\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\n    ];\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}\n\nexport type SWCOptions = Options;"],"names":["existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getDirName","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","jest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getTypeScriptConfigPath","configName","projectBuildConfig","projectLintConfig","projectTestConfig","projectConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","currentCwd","LEX_CONFIG","JSON","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configFormats","configBaseName","configPath","configExists","format","potentialPath","ext","configContent","configJson","parse","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","dirName","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
411
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/LexConfig.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 findFileUp from 'find-file-up';\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Options} from '@swc/core';\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface JestConfig {\n  [key: string]: unknown;\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  transformIgnorePatterns?: string[];\n  moduleNameMapper?: Record<string, string>;\n  extensionsToTreatAsEsm?: string[];\n  preset?: string;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  jest?: JestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  swc?: SWCOptions;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  jest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2023',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nconst getPackageDir = (): string => {\n  const cwd = process.cwd();\n  const currentPkgPath = pathResolve(cwd, 'package.json');\n\n  if(existsSync(currentPkgPath)) {\n    try {\n      const pkg = JSON.parse(readFileSync(currentPkgPath, 'utf8'));\n      if(!pkg.workspaces) {\n        return cwd;\n      }\n    } catch{\n      return cwd;\n    }\n  }\n\n  let searchDir = cwd;\n\n  for(let i = 0; i < 10; i++) {\n    const pkgPath = pathResolve(searchDir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n\n        if(!pkg.workspaces) {\n          return searchDir;\n        }\n      } catch{\n        // Continue searching\n      }\n    }\n\n    const parent = dirname(searchDir);\n\n    if(parent === searchDir) {\n      break;\n    }\n    searchDir = parent;\n  }\n\n  const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n\n  for(const format of configFormats) {\n    const configPath = findFileUp.sync(`lex.config.${format}`, cwd, 5);\n\n    if(configPath) {\n      return dirname(configPath);\n    }\n  }\n\n  return cwd;\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const packageDir = getPackageDir();\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(packageDir, 'tsconfig.build.json');\n\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n\n    const rootBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(rootBuildConfig)) {\n      return rootBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(packageDir, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n\n    const rootLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n\n    if(existsSync(rootLintConfig)) {\n      return rootLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(packageDir, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n\n    const rootTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n\n    if(existsSync(rootTestConfig)) {\n      return rootTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(packageDir, configName);\n\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const rootConfigPath = pathResolve(cwd, configName);\n\n  if(existsSync(rootConfigPath)) {\n    return rootConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n\n  return pathResolve(lexDir, configName);\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {entryJs, sourceFullPath, targetEnvironment} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n\n    LexConfig.config.swc.jsc.parser = {\n      syntax: 'typescript',\n      tsx: true\n    };\n\n    if(targetEnvironment === 'web') {\n      LexConfig.config.swc.jsc.transform = {\n        react: {\n          runtime: 'automatic'\n        }\n      };\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n    const currentCwd = process.cwd();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(currentCwd, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(currentCwd, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(currentCwd, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(currentCwd, params.sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            // eslint-disable-next-line no-console\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = getDirName();\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\n    ];\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}\n\nexport type SWCOptions = Options;"],"names":["findFileUp","existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getDirName","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","jest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getPackageDir","currentPkgPath","pkg","JSON","parse","workspaces","searchDir","i","pkgPath","parent","configFormats","format","configPath","sync","getTypeScriptConfigPath","configName","packageDir","projectBuildConfig","rootBuildConfig","projectLintConfig","rootLintConfig","projectTestConfig","rootTestConfig","projectConfigPath","rootConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","currentCwd","LEX_CONFIG","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configBaseName","configExists","potentialPath","ext","configContent","configJson","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","dirName","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@nlabs/lex",
3
- "version": "1.52.10",
3
+ "version": "1.52.11",
4
4
  "description": "Lex",
5
5
  "license": "MIT",
6
6
  "type": "module",
@@ -93,78 +93,67 @@
93
93
  "@babel/runtime-corejs3": "^7.28.4",
94
94
  "@mdx-js/loader": "^3.1.1",
95
95
  "@nlabs/webpack-plugin-static-site": "*",
96
- "@storybook/addon-docs": "^10.1.6",
97
- "@storybook/addon-links": "^10.1.6",
96
+ "@storybook/addon-docs": "^10.1.10",
97
+ "@storybook/addon-links": "^10.1.10",
98
98
  "@storybook/addon-postcss": "^2.0.0",
99
99
  "@storybook/addon-styling-webpack": "^3.0.0",
100
- "@storybook/addon-themes": "^10.1.6",
100
+ "@storybook/addon-themes": "^10.1.10",
101
101
  "@storybook/addon-webpack5-compiler-babel": "^4.0.0",
102
- "@storybook/cli": "^10.1.6",
103
- "@storybook/react": "^10.1.6",
104
- "@storybook/react-webpack5": "^10.1.6",
105
- "@swc/core": "^1.15.3",
102
+ "@storybook/cli": "^10.1.10",
103
+ "@storybook/react": "^10.1.10",
104
+ "@storybook/react-webpack5": "^10.1.10",
105
+ "@swc/core": "^1.15.7",
106
106
  "@tailwindcss/nesting": "^0.0.0-insiders.565cd3e",
107
- "@tailwindcss/postcss": "4.1.17",
107
+ "@tailwindcss/postcss": "4.1.18",
108
108
  "@testing-library/jest-dom": "^6.9.1",
109
- "@testing-library/react": "^16.3.0",
110
- "acorn": "^8.15.0",
111
- "ajv": "^8.17.1",
109
+ "@testing-library/react": "^16.3.1",
112
110
  "assert": "^2.1.0",
113
- "autoprefixer": "^10.4.22",
111
+ "autoprefixer": "^10.4.23",
114
112
  "babel-jest": "^30.2.0",
115
113
  "babel-loader": "^10.0.0",
116
- "babel-plugin-module-resolver": "^5.0.2",
117
- "babel-plugin-transform-import-meta": "^2.3.3",
118
114
  "boxen": "8.0.1",
119
115
  "buffer": "^6.0.3",
120
- "caniuse-lite": "1.0.30001760",
116
+ "caniuse-lite": "1.0.30001761",
121
117
  "chalk": "^5.6.2",
122
118
  "commander": "^14.0.2",
123
119
  "compare-versions": "^6.1.1",
124
120
  "compression-webpack-plugin": "^11.1.0",
125
- "config-webpack-plugin": "^1.1.0",
126
121
  "copy-webpack-plugin": "^13.0.1",
127
122
  "core-js": "^3.47.0",
128
123
  "crypto-js": "^4.2.0",
129
124
  "css-loader": "^7.1.2",
130
- "css-minimizer-webpack-plugin": "^7.0.3",
125
+ "css-minimizer-webpack-plugin": "^7.0.4",
131
126
  "cssnano": "^7.1.2",
132
127
  "dotenv-webpack": "^8.1.1",
133
128
  "download-npm-package": "^3.1.12",
134
- "eslint": "^9.39.1",
129
+ "eslint": "^9.39.2",
135
130
  "eslint-config-styleguidejs": "^4.1.12",
136
131
  "execa": "9.6.1",
137
132
  "expect": "^30.2.0",
138
- "exports-loader": "^5.0.0",
139
133
  "express": "^5.2.1",
140
134
  "favicons-webpack-plugin": "^6.0.1",
141
- "file-loader": "^6.2.0",
142
135
  "find-file-up": "^2.0.1",
143
136
  "glob": "^13.0.0",
144
137
  "global": "^4.4.0",
145
138
  "graphql": "^16.12.0",
146
- "graphql-http": "^1.22.4",
147
139
  "graphql-tag": "^2.12.6",
148
140
  "html-loader": "^5.1.0",
149
141
  "html-webpack-plugin": "^5.6.5",
150
142
  "https-browserify": "^1.0.0",
151
143
  "image-webpack-loader": "^8.1.0",
152
- "imports-loader": "^5.0.0",
153
144
  "jest": "^30.2.0",
154
145
  "jest-circus": "^30.2.0",
155
146
  "jest-cli": "^30.2.0",
156
147
  "jest-environment-jsdom": "^30.2.0",
157
148
  "jest-transform-graphql": "2.1.0",
158
149
  "jest-util": "^30.2.0",
159
- "json-d-ts": "1.0.1",
160
150
  "latest-version": "9.0.0",
161
151
  "lodash": "^4.17.21",
162
152
  "luxon": "^3.7.2",
163
153
  "math-expression-evaluator": "^2.0.7",
164
154
  "mini-css-extract-plugin": "^2.9.4",
165
- "net": "^1.0.2",
166
- "npm-check-updates": "^19.1.2",
167
- "openai": "^6.10.0",
155
+ "npm-check-updates": "^19.2.0",
156
+ "openai": "^6.15.0",
168
157
  "ora": "9.0.0",
169
158
  "os-browserify": "^0.3.0",
170
159
  "path-browserify": "^1.0.1",
@@ -186,37 +175,30 @@
186
175
  "postcss-value-parser": "^4.2.0",
187
176
  "process": "^0.11.10",
188
177
  "randombytes": "^2.1.0",
189
- "react": "^19.2.1",
190
- "react-dom": "^19.2.1",
178
+ "react": "^19.2.3",
179
+ "react-dom": "^19.2.3",
191
180
  "regenerator-runtime": "^0.14.1",
192
181
  "resolve": "^1.22.11",
193
182
  "rimraf": "^6.1.2",
194
183
  "semver": "^7.7.3",
195
184
  "source-map-loader": "^5.0.0",
196
- "speed-measure-webpack-plugin": "^1.5.0",
197
- "static-site-generator-webpack-plugin": "3.4.2",
198
- "storybook": "^10.1.6",
185
+ "storybook": "^10.1.10",
199
186
  "stream-browserify": "^3.0.0",
200
187
  "stream-http": "^3.2.0",
201
188
  "style-loader": "^4.0.0",
202
189
  "svg-spritemap-webpack-plugin": "^5.1.0",
203
190
  "svgo": "4.0.0",
204
191
  "swc-loader": "^0.2.6",
205
- "tailwindcss": "^4.1.17",
206
- "tls": "^0.0.1",
192
+ "tailwindcss": "^4.1.18",
207
193
  "ts-node": "^10.9.2",
208
194
  "tsconfig-paths-webpack-plugin": "^4.2.0",
209
195
  "typescript": "5.9.3",
210
- "uncrypto": "^0.1.3",
211
- "unicorn-magic": "^0.4.0",
212
- "url-loader": "^4.1.1",
213
196
  "util": "^0.12.5",
214
197
  "vm-browserify": "^1.1.2",
215
- "webpack": "5.103.0",
198
+ "webpack": "5.104.1",
216
199
  "webpack-bundle-analyzer": "^5.1.0",
217
200
  "webpack-cli": "^6.0.1",
218
201
  "webpack-merge": "^6.0.1",
219
- "webpack-nano": "^1.1.1",
220
202
  "webpack-plugin-serve": "^1.6.0",
221
203
  "ws": "^8.18.3"
222
204
  },
@@ -225,7 +207,7 @@
225
207
  "@types/express": "^5.0.6",
226
208
  "@types/jest": "^30.0.0",
227
209
  "@types/luxon": "^3.7.1",
228
- "@types/node": "^24.10.2",
210
+ "@types/node": "^25.0.3",
229
211
  "@types/ora": "^3.2.0",
230
212
  "@types/react": "^19.2.7",
231
213
  "@types/webpack": "^5.28.5"
@@ -234,9 +216,9 @@
234
216
  "css-loader": "7.1.2"
235
217
  },
236
218
  "overrides": {
237
- "cheerio": "^1.0.0-rc.13",
219
+ "cheerio": "^1.1.2",
238
220
  "cross-spawn": "^7.0.6",
239
- "css-select": "^5.1.0",
221
+ "css-select": "^5.2.2",
240
222
  "got": "^14.6.5",
241
223
  "http-cache-semantics": "^4.2.0",
242
224
  "http-proxy-middleware": "^3.0.5",
package/webpack.config.js CHANGED
@@ -4,6 +4,7 @@
4
4
  */
5
5
  import {StaticSitePlugin} from '@nlabs/webpack-plugin-static-site';
6
6
  import tailwindcss from '@tailwindcss/postcss';
7
+ import tailwindNesting from '@tailwindcss/nesting';
7
8
  import autoprefixer from 'autoprefixer';
8
9
  import CompressionWebpackPlugin from 'compression-webpack-plugin';
9
10
  import CopyWebpackPlugin from 'copy-webpack-plugin';
@@ -465,8 +466,6 @@ export default (webpackEnv, webpackOptions) => {
465
466
  {
466
467
  test: /\.css$/,
467
468
  use: [
468
- // In production, extract CSS to separate files for injection into HTML
469
- // In development, inject CSS via style-loader for HMR
470
469
  ...(isProduction && isWeb
471
470
  ? [{
472
471
  loader: require(miniCssExtractPluginPath).loader
@@ -504,6 +503,7 @@ export default (webpackEnv, webpackOptions) => {
504
503
  strict: false,
505
504
  warnings: false
506
505
  }),
506
+ tailwindNesting(),
507
507
  postcssNesting(),
508
508
  tailwindcss(),
509
509
  autoprefixer(),