@nlabs/lex 1.51.7 → 1.52.0
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/Button.stories.js +1 -1
- package/lib/LexConfig.d.ts +1 -1
- package/lib/LexConfig.js +36 -14
- package/lib/commands/build/build.js +111 -21
- package/lib/commands/clean/clean.js +1 -1
- package/lib/commands/compile/compile.js +95 -28
- package/lib/commands/config/config.js +1 -1
- package/lib/commands/copy/copy.js +1 -1
- package/lib/commands/create/create.js +1 -1
- package/lib/commands/dev/dev.js +5 -6
- package/lib/commands/init/init.js +1 -1
- package/lib/commands/link/link.js +1 -1
- package/lib/commands/lint/lint.js +1 -1
- package/lib/commands/serverless/serverless.js +1 -1
- package/lib/commands/storybook/storybook.js +1 -1
- package/lib/commands/versions/versions.js +1 -1
- package/lib/utils/aiService.js +1 -1
- package/lib/utils/app.d.ts +1 -1
- package/lib/utils/app.js +22 -17
- package/lib/utils/postcss/postcss-for.d.ts +1 -1
- package/lib/utils/postcss/postcss-for.js +6 -8
- package/lib/utils/postcss/postcss-percentage.d.ts +1 -1
- package/lib/utils/postcss/postcss-percentage.js +14 -13
- package/package.json +10 -3
- package/webpack.config.js +3 -1
package/lib/utils/app.js
CHANGED
|
@@ -21,7 +21,8 @@ export const getFilenames = (props)=>{
|
|
|
21
21
|
if (!name) {
|
|
22
22
|
if (itemTypes.includes(type)) {
|
|
23
23
|
log(`\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);
|
|
24
|
-
|
|
24
|
+
callback?.(1);
|
|
25
|
+
return undefined;
|
|
25
26
|
}
|
|
26
27
|
} else {
|
|
27
28
|
nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;
|
|
@@ -72,13 +73,13 @@ export const handleWebpackProgress = (output, spinner, quiet, emoji, action)=>{
|
|
|
72
73
|
}
|
|
73
74
|
const progressMatch = output.match(/\[webpack\.Progress\] (\d+)%/);
|
|
74
75
|
if (progressMatch) {
|
|
75
|
-
const progress = parseInt(progressMatch[1]
|
|
76
|
+
const progress = parseInt(progressMatch[1]);
|
|
76
77
|
const progressBar = createProgressBar(progress);
|
|
77
78
|
spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;
|
|
78
79
|
} else if (output.includes('[webpack.Progress]')) {
|
|
79
80
|
const generalProgressMatch = output.match(/(\d+)%/);
|
|
80
81
|
if (generalProgressMatch) {
|
|
81
|
-
const progress = parseInt(generalProgressMatch[1]
|
|
82
|
+
const progress = parseInt(generalProgressMatch[1]);
|
|
82
83
|
const progressBar = createProgressBar(progress);
|
|
83
84
|
spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;
|
|
84
85
|
}
|
|
@@ -120,6 +121,7 @@ export const copyConfiguredFiles = async (spinner, config, quiet)=>{
|
|
|
120
121
|
spinner.start('Copying configured files...');
|
|
121
122
|
let totalCopied = 0;
|
|
122
123
|
const baseDir = sourceFullPath || (sourcePath ? pathResolve(cwd, sourcePath) : cwd);
|
|
124
|
+
const allCopyPromises = [];
|
|
123
125
|
for (const pattern of copyFilesConfig){
|
|
124
126
|
const resolvedPattern = pathResolve(baseDir, pattern);
|
|
125
127
|
const matchingFiles = globSync(resolvedPattern, {
|
|
@@ -132,17 +134,14 @@ export const copyConfiguredFiles = async (spinner, config, quiet)=>{
|
|
|
132
134
|
}
|
|
133
135
|
continue;
|
|
134
136
|
}
|
|
135
|
-
|
|
136
|
-
// Calculate relative path from source directory
|
|
137
|
+
const copyPromises = matchingFiles.map((sourceFile)=>{
|
|
137
138
|
const relativePath = pathRelative(baseDir, sourceFile);
|
|
138
|
-
// Determine destination path in output directory
|
|
139
139
|
const destPath = pathResolve(outputFullPath, relativePath);
|
|
140
|
-
// Create destination directory if it doesn't exist
|
|
141
140
|
const destDir = pathResolve(destPath, '..');
|
|
142
141
|
mkdirSync(destDir, {
|
|
143
142
|
recursive: true
|
|
144
143
|
});
|
|
145
|
-
|
|
144
|
+
return new Promise((resolve, reject)=>{
|
|
146
145
|
copyFile(sourceFile, destPath, (copyError)=>{
|
|
147
146
|
if (copyError) {
|
|
148
147
|
reject(copyError);
|
|
@@ -151,9 +150,11 @@ export const copyConfiguredFiles = async (spinner, config, quiet)=>{
|
|
|
151
150
|
}
|
|
152
151
|
});
|
|
153
152
|
});
|
|
154
|
-
|
|
155
|
-
|
|
153
|
+
});
|
|
154
|
+
allCopyPromises.push(...copyPromises);
|
|
155
|
+
totalCopied += matchingFiles.length;
|
|
156
156
|
}
|
|
157
|
+
await Promise.all(allCopyPromises);
|
|
157
158
|
if (totalCopied > 0) {
|
|
158
159
|
spinner.succeed(`Successfully copied ${totalCopied} configured files!`);
|
|
159
160
|
} else {
|
|
@@ -199,7 +200,11 @@ export const getPackageJson = (packagePath)=>{
|
|
|
199
200
|
};
|
|
200
201
|
export const getFilesByExt = (ext, config)=>{
|
|
201
202
|
const { sourceFullPath } = config;
|
|
202
|
-
return globSync(
|
|
203
|
+
return globSync(`**/**${ext}`, {
|
|
204
|
+
absolute: true,
|
|
205
|
+
cwd: sourceFullPath,
|
|
206
|
+
nodir: true
|
|
207
|
+
});
|
|
203
208
|
};
|
|
204
209
|
export const removeConflictModules = (moduleList)=>{
|
|
205
210
|
const updatedList = {
|
|
@@ -224,11 +229,8 @@ export const removeFiles = (fileName, isRelative = false)=>new Promise((resolve,
|
|
|
224
229
|
});
|
|
225
230
|
export const removeModules = ()=>new Promise(async (resolve, reject)=>{
|
|
226
231
|
try {
|
|
227
|
-
// Remove node_modules
|
|
228
232
|
await removeFiles('./node_modules', true);
|
|
229
|
-
// Remove yarn lock
|
|
230
233
|
await removeFiles('./yarn.lock', true);
|
|
231
|
-
// Remove npm lock
|
|
232
234
|
await removeFiles('./package-lock.json', true);
|
|
233
235
|
resolve(null);
|
|
234
236
|
} catch (error) {
|
|
@@ -252,7 +254,11 @@ export const linkedModules = (startPath)=>{
|
|
|
252
254
|
} else {
|
|
253
255
|
modulePath = pathJoin(workingPath, 'node_modules');
|
|
254
256
|
}
|
|
255
|
-
const foundPaths = globSync(
|
|
257
|
+
const foundPaths = globSync('*', {
|
|
258
|
+
absolute: true,
|
|
259
|
+
cwd: modulePath,
|
|
260
|
+
nodir: false
|
|
261
|
+
});
|
|
256
262
|
return foundPaths.reduce((list, foundPath)=>{
|
|
257
263
|
try {
|
|
258
264
|
const stats = lstatSync(foundPath);
|
|
@@ -271,7 +277,6 @@ export const linkedModules = (startPath)=>{
|
|
|
271
277
|
}
|
|
272
278
|
return list;
|
|
273
279
|
} catch {
|
|
274
|
-
// Skip files that don't exist or can't be accessed
|
|
275
280
|
return list;
|
|
276
281
|
}
|
|
277
282
|
}, []);
|
|
@@ -294,4 +299,4 @@ export const updateTemplateName = (filePath, replace, replaceCaps)=>{
|
|
|
294
299
|
writeFileSync(filePath, data, 'utf8');
|
|
295
300
|
};
|
|
296
301
|
|
|
297
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/app.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 */\n\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport {copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport isEmpty from 'lodash/isEmpty.js';\nimport ora from 'ora';\nimport {basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve} from 'path';\nimport {rimrafSync} from 'rimraf';\n\n\nimport {log} from './log.js';\n\nimport type {LexConfigType} from '../LexConfig.js';\n\n\nexport const cwd: string = process.cwd();\n\nexport interface GetFilenamesProps {\n  readonly callback?: (status: number) => void;\n  readonly cliName?: string;\n  readonly name?: string;\n  readonly quiet?: boolean;\n  readonly type?: string;\n  readonly useTypescript?: boolean;\n}\n\ninterface FilenamesResult {\n  nameCaps: string;\n  templateExt: string;\n  templatePath: string;\n  templateReact: string;\n}\n\nexport const getFilenames = (props: GetFilenamesProps): FilenamesResult | void => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      return callback?.(1);\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport interface Spinner {\n  fail: (text?: string) => void;\n  start: (text?: string) => void;\n  succeed: (text?: string) => void;\n  text?: string;\n}\n\nexport const createSpinner = (quiet = false): Spinner => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const createProgressBar = (percentage: number): string => {\n  const width = 20;\n  const filled = Math.round((percentage / 100) * width);\n  const empty = width - filled;\n\n  const filledBar = chalk.cyan('█').repeat(filled);\n  const emptyBar = chalk.gray('░').repeat(empty);\n\n  return filledBar + emptyBar;\n};\n\nexport const handleWebpackProgress = (output: string, spinner: Spinner, quiet: boolean, emoji: string, action: string): void => {\n  if(quiet) {\n    return;\n  }\n\n  const progressMatch = output.match(/\\[webpack\\.Progress\\] (\\d+)%/);\n  if(progressMatch) {\n    const progress = parseInt(progressMatch[1], 10);\n    const progressBar = createProgressBar(progress);\n    spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n  } else if(output.includes('[webpack.Progress]')) {\n    const generalProgressMatch = output.match(/(\\d+)%/);\n    if(generalProgressMatch) {\n      const progress = parseInt(generalProgressMatch[1], 10);\n      const progressBar = createProgressBar(progress);\n      spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n    }\n  }\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    log(error, 'error');\n  }\n};\n\nexport const copyConfiguredFiles = async (spinner, config: LexConfigType, quiet: boolean) => {\n  const {copyFiles: copyFilesConfig, outputFullPath, sourceFullPath, sourcePath} = config;\n  if(!copyFilesConfig || copyFilesConfig.length === 0) {\n    return;\n  }\n\n  try {\n    spinner.start('Copying configured files...');\n    let totalCopied = 0;\n\n    const baseDir = sourceFullPath || (sourcePath ? pathResolve(cwd, sourcePath) : cwd);\n\n    for(const pattern of copyFilesConfig) {\n      const resolvedPattern = pathResolve(baseDir, pattern);\n      const matchingFiles = globSync(resolvedPattern, {\n        absolute: true,\n        nodir: true\n      });\n      if(matchingFiles.length === 0) {\n        if(!quiet) {\n          log(`Warning: No files found matching pattern: ${pattern}`, 'warn', quiet);\n        }\n        continue;\n      }\n\n      for(const sourceFile of matchingFiles) {\n        // Calculate relative path from source directory\n        const relativePath = pathRelative(baseDir, sourceFile);\n        // Determine destination path in output directory\n        const destPath = pathResolve(outputFullPath, relativePath);\n        // Create destination directory if it doesn't exist\n        const destDir = pathResolve(destPath, '..');\n        mkdirSync(destDir, {recursive: true});\n\n        await new Promise((resolve, reject) => {\n          copyFile(sourceFile, destPath, (copyError) => {\n            if(copyError) {\n              reject(copyError);\n            } else {\n              resolve(true);\n            }\n          });\n        });\n        totalCopied++;\n      }\n    }\n    if(totalCopied > 0) {\n      spinner.succeed(`Successfully copied ${totalCopied} configured files!`);\n    } else {\n      spinner.succeed('No configured files to copy');\n    }\n  } catch(error) {\n    spinner.fail('Failed to copy configured files');\n    log(`Error copying configured files: ${error.message}`, 'error', quiet);\n    throw error;\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  const packageData: string = readFileSync(formatPath).toString();\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`${sourceFullPath}/**/**${ext}`);\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types/).*?(jest|webpack).*$', 'gi');\n    if(regex.test(moduleName)) {\n      delete updatedList[moduleName];\n    }\n  });\n\n  return updatedList;\n};\n\nexport const removeFiles = (fileName: string, isRelative: boolean = false) => new Promise((resolve, reject) => {\n  const filePath: string = isRelative ? pathResolve(cwd, fileName) : fileName;\n  try {\n    rimrafSync(filePath);\n    return resolve(null);\n  } catch(error) {\n    return reject(error);\n  }\n});\n\nexport const removeModules = () => new Promise(async (resolve, reject) => {\n  try {\n    // Remove node_modules\n    await removeFiles('./node_modules', true);\n\n    // Remove yarn lock\n    await removeFiles('./yarn.lock', true);\n\n    // Remove npm lock\n    await removeFiles('./package-lock.json', true);\n\n    resolve(null);\n  } catch(error) {\n    reject(error);\n  }\n});\n\nexport const setPackageJson = (json, packagePath?: string) => {\n  if(!json) {\n    return;\n  }\n\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  writeFileSync(formatPath, JSON.stringify(json, null, 2));\n};\n\nexport interface LinkedModuleType {\n  readonly name: string;\n  readonly path: string;\n}\n\nexport const linkedModules = (startPath?: string): LinkedModuleType[] => {\n  const workingPath: string = startPath || process.cwd();\n  let modulePath: string;\n  let prefix: string;\n\n  if(workingPath.includes('@')) {\n    prefix = `@${workingPath.split('@').pop()}`;\n    modulePath = workingPath;\n  } else {\n    modulePath = pathJoin(workingPath, 'node_modules');\n  }\n\n  const foundPaths: string[] = globSync(`${modulePath}/*`);\n  return foundPaths.reduce((list: LinkedModuleType[], foundPath: string) => {\n    try {\n      const stats = lstatSync(foundPath);\n\n      if(stats.isDirectory()) {\n        const deepList: LinkedModuleType[] = linkedModules(foundPath);\n        list.push(...deepList);\n      } else if(stats.isSymbolicLink()) {\n        const moduleNames: string[] = ([prefix, pathBasename(foundPath)]).filter((item: string) => !isEmpty(item));\n        list.push({name: `${moduleNames.join('/')}`, path: foundPath});\n      }\n\n      return list;\n    } catch{\n      // Skip files that don't exist or can't be accessed\n      return list;\n    }\n  }, []);\n};\n\nexport const checkLinkedModules = () => {\n  const linked = linkedModules();\n\n  if(linked.length) {\n    const msgModule: string = linked.length > 1 ? 'Modules' : 'Module';\n    const linkedMsg: string = linked.reduce(\n      (msg: string, linkedModule: LinkedModuleType) =>\n        `${msg}\\n * ${linkedModule.name}`,\n      `Linked ${msgModule}:`\n    );\n    log(boxen(linkedMsg, {dimBorder: true, padding: 1}), 'warn');\n  }\n};\n\nexport const updateTemplateName = (filePath: string, replace: string, replaceCaps: string) => {\n  let data: string = readFileSync(filePath, 'utf8');\n  data = data.replace(/sample/g, replace);\n  data = data.replace(/Sample/g, replaceCaps);\n  writeFileSync(filePath, data, 'utf8');\n};"],"names":["boxen","chalk","copyFile","existsSync","lstatSync","mkdirSync","readdirSync","readFileSync","writeFileSync","sync","globSync","isEmpty","ora","basename","pathBasename","join","pathJoin","relative","pathRelative","resolve","pathResolve","rimrafSync","log","cwd","process","getFilenames","props","callback","cliName","name","quiet","type","useTypescript","nameCaps","itemTypes","includes","charAt","toUpperCase","substr","templatePath","templateExt","templateReact","createSpinner","fail","start","succeed","color","createProgressBar","percentage","width","filled","Math","round","empty","filledBar","cyan","repeat","emptyBar","gray","handleWebpackProgress","output","spinner","emoji","action","progressMatch","match","progress","parseInt","progressBar","text","generalProgressMatch","copyFiles","files","typeName","config","outputFullPath","sourceFullPath","items","map","fileName","from","to","Promise","all","reject","recursive","copyError","length","error","message","copyConfiguredFiles","copyFilesConfig","sourcePath","totalCopied","baseDir","pattern","resolvedPattern","matchingFiles","absolute","nodir","sourceFile","relativePath","destPath","destDir","copyFileSync","source","target","targetFile","isDirectory","copyFolderRecursiveSync","targetFolder","forEach","file","curSource","getPackageJson","packagePath","formatPath","packageData","toString","JSON","parse","getFilesByExt","ext","removeConflictModules","moduleList","updatedList","Object","keys","moduleName","regex","RegExp","test","removeFiles","isRelative","filePath","removeModules","setPackageJson","json","stringify","linkedModules","startPath","workingPath","modulePath","prefix","split","pop","foundPaths","reduce","list","foundPath","stats","deepList","push","isSymbolicLink","moduleNames","filter","item","path","checkLinkedModules","linked","msgModule","linkedMsg","msg","linkedModule","dimBorder","padding","updateTemplateName","replace","replaceCaps","data"],"mappings":"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"}
|
|
302
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/utils/app.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 */\n\nimport boxen from 'boxen';\nimport chalk from 'chalk';\nimport {copyFile, existsSync, lstatSync, mkdirSync, readdirSync, readFileSync, writeFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport isEmpty from 'lodash/isEmpty.js';\nimport ora from 'ora';\nimport {basename as pathBasename, join as pathJoin, relative as pathRelative, resolve as pathResolve} from 'path';\nimport {rimrafSync} from 'rimraf';\n\n\nimport {log} from './log.js';\n\nimport type {LexConfigType} from '../LexConfig.js';\n\n\nexport const cwd: string = process.cwd();\n\nexport interface GetFilenamesProps {\n  readonly callback?: (status: number)=> void;\n  readonly cliName?: string;\n  readonly name?: string;\n  readonly quiet?: boolean;\n  readonly type?: string;\n  readonly useTypescript?: boolean;\n}\n\ninterface FilenamesResult {\n  nameCaps: string;\n  templateExt: string;\n  templatePath: string;\n  templateReact: string;\n}\n\nexport const getFilenames = (props: GetFilenamesProps): FilenamesResult | undefined => {\n  const {callback, cliName, name, quiet, type, useTypescript} = props;\n\n  let nameCaps: string;\n  const itemTypes: string[] = ['stores', 'views'];\n\n  if(!name) {\n    if(itemTypes.includes(type)) {\n      log(`\\n${cliName} Error: ${type} name is required. Please use 'lex -h' for options.`, 'error', quiet);\n      callback?.(1);\n      return undefined;\n    }\n  } else {\n    nameCaps = `${name.charAt(0).toUpperCase()}${name.substr(1)}`;\n  }\n\n  log(`${cliName} adding ${name} ${type}...`, 'info', quiet);\n\n  let templatePath: string;\n  let templateExt: string;\n  let templateReact: string;\n\n  if(useTypescript) {\n    templatePath = '../../templates/typescript';\n    templateExt = '.ts';\n    templateReact = '.tsx';\n  } else {\n    templatePath = '../../templates/flow';\n    templateExt = '.js';\n    templateReact = '.js';\n  }\n\n  return {\n    nameCaps,\n    templateExt,\n    templatePath,\n    templateReact\n  };\n};\n\nexport interface Spinner {\n  fail: (text?: string)=> void;\n  start: (text?: string)=> void;\n  succeed: (text?: string)=> void;\n  text?: string;\n}\n\nexport const createSpinner = (quiet = false): Spinner => {\n  if(quiet) {\n    return {\n      fail: () => {},\n      start: () => {},\n      succeed: () => {}\n    };\n  }\n\n  return ora({color: 'yellow'});\n};\n\nexport const createProgressBar = (percentage: number): string => {\n  const width = 20;\n  const filled = Math.round((percentage / 100) * width);\n  const empty = width - filled;\n\n  const filledBar = chalk.cyan('█').repeat(filled);\n  const emptyBar = chalk.gray('░').repeat(empty);\n\n  return filledBar + emptyBar;\n};\n\nexport const handleWebpackProgress = (\n  output: string,\n  spinner: Spinner,\n  quiet: boolean,\n  emoji: string,\n  action: string\n): void => {\n  if(quiet) {\n    return;\n  }\n\n  const progressMatch = output.match(/\\[webpack\\.Progress\\] (\\d+)%/);\n  if(progressMatch) {\n    const progress = parseInt(progressMatch[1]);\n    const progressBar = createProgressBar(progress);\n    spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n  } else if(output.includes('[webpack.Progress]')) {\n    const generalProgressMatch = output.match(/(\\d+)%/);\n    if(generalProgressMatch) {\n      const progress = parseInt(generalProgressMatch[1]);\n      const progressBar = createProgressBar(progress);\n      spinner.text = `${emoji} ${action}: ${progressBar} ${progress}%`;\n    }\n  }\n};\n\nexport const copyFiles = async (files: string[], typeName: string, spinner, config: LexConfigType) => {\n  const {outputFullPath, sourceFullPath} = config;\n  const items = files.map((fileName: string) => ({\n    from: fileName,\n    to: pathResolve(outputFullPath, pathRelative(sourceFullPath, fileName))\n  }));\n\n  try {\n    spinner.start(`Copying ${typeName} files...`);\n    await Promise.all(items.map(({from, to}) => new Promise(\n      (resolve, reject) => {\n        mkdirSync(pathResolve(to, '..'), {recursive: true});\n        return copyFile(from, to, (copyError) => {\n          if(copyError) {\n            reject();\n          } else {\n            resolve(true);\n          }\n        });\n      }\n    )));\n    spinner.succeed(`Successfully copied ${files.length} ${typeName} files!`);\n  } catch(error) {\n    spinner.fail(`Copying of ${typeName} files failed.`);\n    log(`Error: ${error.message}`, 'error');\n    log(error, 'error');\n  }\n};\n\nexport const copyConfiguredFiles = async (spinner, config: LexConfigType, quiet: boolean) => {\n  const {copyFiles: copyFilesConfig, outputFullPath, sourceFullPath, sourcePath} = config;\n  if(!copyFilesConfig || copyFilesConfig.length === 0) {\n    return;\n  }\n\n  try {\n    spinner.start('Copying configured files...');\n    let totalCopied = 0;\n\n    const baseDir = sourceFullPath || (sourcePath ? pathResolve(cwd, sourcePath) : cwd);\n    const allCopyPromises: Promise<unknown>[] = [];\n\n    for(const pattern of copyFilesConfig) {\n      const resolvedPattern = pathResolve(baseDir, pattern);\n      const matchingFiles = globSync(resolvedPattern, {\n        absolute: true,\n        nodir: true\n      });\n\n      if(matchingFiles.length === 0) {\n        if(!quiet) {\n          log(`Warning: No files found matching pattern: ${pattern}`, 'warn', quiet);\n        }\n        continue;\n      }\n\n      const copyPromises = matchingFiles.map((sourceFile) => {\n        const relativePath = pathRelative(baseDir, sourceFile);\n        const destPath = pathResolve(outputFullPath, relativePath);\n        const destDir = pathResolve(destPath, '..');\n        mkdirSync(destDir, {recursive: true});\n\n        return new Promise((resolve, reject) => {\n          copyFile(sourceFile, destPath, (copyError) => {\n            if(copyError) {\n              reject(copyError);\n            } else {\n              resolve(true);\n            }\n          });\n        });\n      });\n\n      allCopyPromises.push(...copyPromises);\n      totalCopied += matchingFiles.length;\n    }\n\n    await Promise.all(allCopyPromises);\n\n    if(totalCopied > 0) {\n      spinner.succeed(`Successfully copied ${totalCopied} configured files!`);\n    } else {\n      spinner.succeed('No configured files to copy');\n    }\n  } catch(error) {\n    spinner.fail('Failed to copy configured files');\n    log(`Error copying configured files: ${error.message}`, 'error', quiet);\n    throw error;\n  }\n};\n\nexport const copyFileSync = (source: string, target: string) => {\n  let targetFile: string = target;\n\n  if(existsSync(target)) {\n    if(lstatSync(target).isDirectory()) {\n      targetFile = pathJoin(target, pathBasename(source));\n    }\n  }\n\n  writeFileSync(targetFile, readFileSync(source));\n};\n\nexport const copyFolderRecursiveSync = (source: string, target: string): void => {\n  let files: string[] = [];\n\n  const targetFolder: string = pathJoin(target, pathBasename(source));\n\n  if(!existsSync(targetFolder)) {\n    mkdirSync(targetFolder);\n  }\n\n  if(lstatSync(source).isDirectory()) {\n    files = readdirSync(source);\n    files.forEach((file: string) => {\n      const curSource: string = pathJoin(source, file);\n\n      if(lstatSync(curSource).isDirectory()) {\n        copyFolderRecursiveSync(curSource, targetFolder);\n      } else {\n        copyFileSync(curSource, targetFolder);\n      }\n    });\n  }\n};\n\nexport const getPackageJson = (packagePath?: string) => {\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n  const packageData: string = readFileSync(formatPath).toString();\n\n  return JSON.parse(packageData);\n};\n\nexport const getFilesByExt = (ext: string, config: LexConfigType): string[] => {\n  const {sourceFullPath} = config;\n  return globSync(`**/**${ext}`, {\n    absolute: true,\n    cwd: sourceFullPath,\n    nodir: true\n  });\n};\n\nexport const removeConflictModules = (moduleList: object) => {\n  const updatedList: object = {...moduleList};\n\n  Object.keys(updatedList).forEach((moduleName: string) => {\n    const regex: RegExp = new RegExp('^(?!@types/).*?(jest|webpack).*$', 'gi');\n    if(regex.test(moduleName)) {\n      delete updatedList[moduleName];\n    }\n  });\n\n  return updatedList;\n};\n\nexport const removeFiles = (fileName: string, isRelative: boolean = false) => new Promise((resolve, reject) => {\n  const filePath: string = isRelative ? pathResolve(cwd, fileName) : fileName;\n\n  try {\n    rimrafSync(filePath);\n    return resolve(null);\n  } catch(error) {\n    return reject(error);\n  }\n});\n\nexport const removeModules = () => new Promise(async (resolve, reject) => {\n  try {\n    await removeFiles('./node_modules', true);\n    await removeFiles('./yarn.lock', true);\n    await removeFiles('./package-lock.json', true);\n\n    resolve(null);\n  } catch(error) {\n    reject(error);\n  }\n});\n\nexport const setPackageJson = (json, packagePath?: string) => {\n  if(!json) {\n    return;\n  }\n\n  const formatPath: string = packagePath || `${process.cwd()}/package.json`;\n\n  writeFileSync(formatPath, JSON.stringify(json, null, 2));\n};\n\nexport interface LinkedModuleType {\n  readonly name: string;\n  readonly path: string;\n}\n\nexport const linkedModules = (startPath?: string): LinkedModuleType[] => {\n  const workingPath: string = startPath || process.cwd();\n  let modulePath: string;\n  let prefix: string;\n\n  if(workingPath.includes('@')) {\n    prefix = `@${workingPath.split('@').pop()}`;\n    modulePath = workingPath;\n  } else {\n    modulePath = pathJoin(workingPath, 'node_modules');\n  }\n\n  const foundPaths: string[] = globSync('*', {\n    absolute: true,\n    cwd: modulePath,\n    nodir: false\n  });\n\n  return foundPaths.reduce((list: LinkedModuleType[], foundPath: string) => {\n    try {\n      const stats = lstatSync(foundPath);\n\n      if(stats.isDirectory()) {\n        const deepList: LinkedModuleType[] = linkedModules(foundPath);\n        list.push(...deepList);\n      } else if(stats.isSymbolicLink()) {\n        const moduleNames: string[] = ([prefix, pathBasename(foundPath)]).filter((item: string) => !isEmpty(item));\n        list.push({name: `${moduleNames.join('/')}`, path: foundPath});\n      }\n\n      return list;\n    } catch{\n      return list;\n    }\n  }, []);\n};\n\nexport const checkLinkedModules = () => {\n  const linked = linkedModules();\n\n  if(linked.length) {\n    const msgModule: string = linked.length > 1 ? 'Modules' : 'Module';\n    const linkedMsg: string = linked.reduce(\n      (msg: string, linkedModule: LinkedModuleType) =>\n        `${msg}\\n * ${linkedModule.name}`,\n      `Linked ${msgModule}:`\n    );\n\n    log(boxen(linkedMsg, {dimBorder: true, padding: 1}), 'warn');\n  }\n};\n\nexport const updateTemplateName = (filePath: string, replace: string, replaceCaps: string) => {\n  let data: string = readFileSync(filePath, 'utf8');\n  data = data.replace(/sample/g, replace);\n  data = data.replace(/Sample/g, replaceCaps);\n  writeFileSync(filePath, data, 'utf8');\n};"],"names":["boxen","chalk","copyFile","existsSync","lstatSync","mkdirSync","readdirSync","readFileSync","writeFileSync","sync","globSync","isEmpty","ora","basename","pathBasename","join","pathJoin","relative","pathRelative","resolve","pathResolve","rimrafSync","log","cwd","process","getFilenames","props","callback","cliName","name","quiet","type","useTypescript","nameCaps","itemTypes","includes","undefined","charAt","toUpperCase","substr","templatePath","templateExt","templateReact","createSpinner","fail","start","succeed","color","createProgressBar","percentage","width","filled","Math","round","empty","filledBar","cyan","repeat","emptyBar","gray","handleWebpackProgress","output","spinner","emoji","action","progressMatch","match","progress","parseInt","progressBar","text","generalProgressMatch","copyFiles","files","typeName","config","outputFullPath","sourceFullPath","items","map","fileName","from","to","Promise","all","reject","recursive","copyError","length","error","message","copyConfiguredFiles","copyFilesConfig","sourcePath","totalCopied","baseDir","allCopyPromises","pattern","resolvedPattern","matchingFiles","absolute","nodir","copyPromises","sourceFile","relativePath","destPath","destDir","push","copyFileSync","source","target","targetFile","isDirectory","copyFolderRecursiveSync","targetFolder","forEach","file","curSource","getPackageJson","packagePath","formatPath","packageData","toString","JSON","parse","getFilesByExt","ext","removeConflictModules","moduleList","updatedList","Object","keys","moduleName","regex","RegExp","test","removeFiles","isRelative","filePath","removeModules","setPackageJson","json","stringify","linkedModules","startPath","workingPath","modulePath","prefix","split","pop","foundPaths","reduce","list","foundPath","stats","deepList","isSymbolicLink","moduleNames","filter","item","path","checkLinkedModules","linked","msgModule","linkedMsg","msg","linkedModule","dimBorder","padding","updateTemplateName","replace","replaceCaps","data"],"mappings":"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"}
|
|
@@ -11,7 +11,7 @@ const postcssFor = (opts = {})=>{
|
|
|
11
11
|
};
|
|
12
12
|
const iterStack = [];
|
|
13
13
|
const parentsHaveIterator = (rule, param)=>{
|
|
14
|
-
if (rule.parent
|
|
14
|
+
if (rule.parent === null) {
|
|
15
15
|
return false;
|
|
16
16
|
}
|
|
17
17
|
if (rule.parent.type === 'root') {
|
|
@@ -51,9 +51,8 @@ const postcssFor = (opts = {})=>{
|
|
|
51
51
|
iterStack.push(currentIterVar);
|
|
52
52
|
}
|
|
53
53
|
};
|
|
54
|
-
const checkNumber = (rule)=>{
|
|
55
|
-
|
|
56
|
-
if (isNaN(parseInt(param, 10)) || !param.match(/^-?\d+\.?\d*$/)) {
|
|
54
|
+
const checkNumber = (rule)=>(param)=>{
|
|
55
|
+
if (isNaN(Number(param)) || !param.match(/^-?\d+\.?\d*$/)) {
|
|
57
56
|
if (param.indexOf('$') !== -1) {
|
|
58
57
|
if (!parentsHaveIterator(rule, param)) {
|
|
59
58
|
throw rule.error('External variable (not from a parent for loop) cannot be used as a range parameter', {
|
|
@@ -67,7 +66,6 @@ const postcssFor = (opts = {})=>{
|
|
|
67
66
|
}
|
|
68
67
|
}
|
|
69
68
|
};
|
|
70
|
-
};
|
|
71
69
|
const checkParams = (rule, params)=>{
|
|
72
70
|
if (!params[0]?.startsWith('$') || params[1] !== 'from' || params[3] !== 'to' || params[5] && params[5] !== 'by') {
|
|
73
71
|
throw rule.error('Wrong loop syntax', {
|
|
@@ -132,13 +130,13 @@ const postcssFor = (opts = {})=>{
|
|
|
132
130
|
});
|
|
133
131
|
};
|
|
134
132
|
return {
|
|
135
|
-
postcssPlugin: 'postcss-for',
|
|
136
133
|
Once (root) {
|
|
137
134
|
processOriginalLoops(root);
|
|
138
|
-
}
|
|
135
|
+
},
|
|
136
|
+
postcssPlugin: 'postcss-for'
|
|
139
137
|
};
|
|
140
138
|
};
|
|
141
139
|
postcssFor.postcss = true;
|
|
142
140
|
export default postcssFor;
|
|
143
141
|
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/utils/postcss/postcss-for.ts"],"sourcesContent":["/**\n * Copyright (c) 2025-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n *\n * PostCSS 8-compatible version of postcss-for plugin\n * Original: https://github.com/antyakushev/postcss-for\n */\nimport postcss from 'postcss';\nimport postcssSimpleVars from 'postcss-simple-vars';\n\ninterface PostcssForOptions {\n  nested?: boolean;\n}\n\nconst postcssFor = (opts: PostcssForOptions = {}) => {\n  const options = {\n    nested: opts.nested !== false\n  };\n\n  const iterStack: string[] = [];\n\n  const parentsHaveIterator = (rule: postcss.AtRule, param: string): boolean => {\n    if (rule.parent == null) {\n      return false;\n    }\n    if (rule.parent.type === 'root') {\n      return false;\n    }\n    if (rule.parent.type !== 'atrule' || !rule.parent.params) {\n      return false;\n    }\n\n    const parentIterVar = rule.parent.params.split(/\\s+/)[0];\n    if (!parentIterVar) {\n      return false;\n    }\n    if (parentIterVar === param) {\n      return true;\n    }\n    if (iterStack.indexOf(param) !== -1) {\n      return true;\n    }\n    return parentsHaveIterator(rule.parent as postcss.AtRule, param);\n  };\n\n  const manageIterStack = (rule: postcss.AtRule) => {\n    if (rule.parent && rule.parent.type !== 'root') {\n      const parentIterVar = rule.parent.type === 'atrule' && rule.parent.params\n        ? rule.parent.params.split(/\\s+/)[0]\n        : null;\n      if (parentIterVar && iterStack.indexOf(parentIterVar) === -1) {\n        iterStack.splice(0, iterStack.length);\n      } else if (parentIterVar) {\n        const parentIndex = iterStack.indexOf(parentIterVar);\n        if (parentIndex !== -1) {\n          iterStack.splice(parentIndex + 1, iterStack.length - parentIndex - 1);\n        }\n      }\n    } else {\n      iterStack.splice(0, iterStack.length);\n    }\n    const currentIterVar = rule.params.split(/\\s+/)[0];\n    if (currentIterVar) {\n      iterStack.push(currentIterVar);\n    }\n  };\n\n  const checkNumber = (rule: postcss.AtRule) => {\n    return (param: string) => {\n      if (isNaN(parseInt(param, 10)) || !param.match(/^-?\\d+\\.?\\d*$/)) {\n        if (param.indexOf('$') !== -1) {\n          if (!parentsHaveIterator(rule, param)) {\n            throw rule.error('External variable (not from a parent for loop) cannot be used as a range parameter', {\n              plugin: 'postcss-for'\n            });\n          }\n        } else {\n          throw rule.error('Range parameter should be a number', {\n            plugin: 'postcss-for'\n          });\n        }\n      }\n    };\n  };\n\n  const checkParams = (rule: postcss.AtRule, params: string[]) => {\n    if (\n      !params[0]?.startsWith('$') ||\n      params[1] !== 'from' ||\n      params[3] !== 'to' ||\n      (params[5] && params[5] !== 'by')\n    ) {\n      throw rule.error('Wrong loop syntax', {\n        plugin: 'postcss-for'\n      });\n    }\n\n    [params[2], params[4], params[6] || '0'].forEach(checkNumber(rule));\n  };\n\n  const unrollLoop = (rule: postcss.AtRule) => {\n    const params = rule.params.split(/\\s+/);\n\n    checkParams(rule, params);\n\n    const iterator = params[0].slice(1);\n    const index = +params[2];\n    const top = +params[4];\n    const dir = top < index ? -1 : 1;\n    const by = (+(params[6] || 1)) * dir;\n\n    const value: Record<string, number> = {};\n    for (let i = index; i * dir <= top * dir; i = i + by) {\n      const content = rule.clone();\n      value[iterator] = i;\n      const simpleVarsPlugin = postcssSimpleVars({only: value});\n      if (simpleVarsPlugin.prepare) {\n        const prepared = simpleVarsPlugin.prepare({} as any);\n        if (prepared.Once) {\n          prepared.Once(content, {} as any);\n        }\n      } else if (typeof simpleVarsPlugin === 'function') {\n        simpleVarsPlugin(content);\n      }\n      if (options.nested) {\n        processLoops(content);\n      }\n      if (rule.parent) {\n        rule.parent.insertBefore(rule, content.nodes);\n      }\n    }\n    if (rule.parent) {\n      rule.remove();\n    }\n  };\n\n  const processLoops = (css: postcss.Container) => {\n    css.walkAtRules((rule) => {\n      if (rule.name === 'for') {\n        unrollLoop(rule);\n      }\n    });\n  };\n\n  const processOriginalLoops = (css: postcss.Root) => {\n    css.walkAtRules((rule) => {\n      if (rule.name === 'for') {\n        if (rule.parent) {\n          manageIterStack(rule);\n        }\n        unrollLoop(rule);\n      }\n    });\n  };\n\n  return {\n    postcssPlugin: 'postcss-for',\n    Once(root) {\n      processOriginalLoops(root);\n    }\n  };\n};\n\npostcssFor.postcss = true;\n\nexport default postcssFor;\n\n"],"names":["postcssSimpleVars","postcssFor","opts","options","nested","iterStack","parentsHaveIterator","rule","param","parent","type","params","parentIterVar","split","indexOf","manageIterStack","splice","length","parentIndex","currentIterVar","push","checkNumber","isNaN","parseInt","match","error","plugin","checkParams","startsWith","forEach","unrollLoop","iterator","slice","index","top","dir","by","value","i","content","clone","simpleVarsPlugin","only","prepare","prepared","Once","processLoops","insertBefore","nodes","remove","css","walkAtRules","name","processOriginalLoops","postcssPlugin","root","postcss"],"mappings":"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"}
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../../src/utils/postcss/postcss-for.ts"],"sourcesContent":["/**\n * Copyright (c) 2025-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n *\n * PostCSS 8-compatible version of postcss-for plugin\n * Original: https://github.com/antyakushev/postcss-for\n */\nimport postcss from 'postcss';\nimport postcssSimpleVars from 'postcss-simple-vars';\n\ninterface PostcssForOptions {\n  nested?: boolean;\n}\n\nconst postcssFor = (opts: PostcssForOptions = {}) => {\n  const options = {\n    nested: opts.nested !== false\n  };\n\n  const iterStack: string[] = [];\n\n  const parentsHaveIterator = (rule: postcss.AtRule, param: string): boolean => {\n    if(rule.parent === null) {\n      return false;\n    }\n    if(rule.parent.type === 'root') {\n      return false;\n    }\n    if(rule.parent.type !== 'atrule' || !rule.parent.params) {\n      return false;\n    }\n\n    const parentIterVar = rule.parent.params.split(/\\s+/)[0];\n    if(!parentIterVar) {\n      return false;\n    }\n    if(parentIterVar === param) {\n      return true;\n    }\n    if(iterStack.indexOf(param) !== -1) {\n      return true;\n    }\n    return parentsHaveIterator(rule.parent as postcss.AtRule, param);\n  };\n\n  const manageIterStack = (rule: postcss.AtRule) => {\n    if(rule.parent && rule.parent.type !== 'root') {\n      const parentIterVar = rule.parent.type === 'atrule' && rule.parent.params\n        ? rule.parent.params.split(/\\s+/)[0]\n        : null;\n      if(parentIterVar && iterStack.indexOf(parentIterVar) === -1) {\n        iterStack.splice(0, iterStack.length);\n      } else if(parentIterVar) {\n        const parentIndex = iterStack.indexOf(parentIterVar);\n        if(parentIndex !== -1) {\n          iterStack.splice(parentIndex + 1, iterStack.length - parentIndex - 1);\n        }\n      }\n    } else {\n      iterStack.splice(0, iterStack.length);\n    }\n    const currentIterVar = rule.params.split(/\\s+/)[0];\n    if(currentIterVar) {\n      iterStack.push(currentIterVar);\n    }\n  };\n\n  const checkNumber = (rule: postcss.AtRule) => (param: string) => {\n    if(isNaN(Number(param)) || !param.match(/^-?\\d+\\.?\\d*$/)) {\n      if(param.indexOf('$') !== -1) {\n        if(!parentsHaveIterator(rule, param)) {\n          throw rule.error('External variable (not from a parent for loop) cannot be used as a range parameter', {\n            plugin: 'postcss-for'\n          });\n        }\n      } else {\n        throw rule.error('Range parameter should be a number', {\n          plugin: 'postcss-for'\n        });\n      }\n    }\n  };\n\n  const checkParams = (rule: postcss.AtRule, params: string[]) => {\n    if(\n      !params[0]?.startsWith('$') ||\n      params[1] !== 'from' ||\n      params[3] !== 'to' ||\n      (params[5] && params[5] !== 'by')\n    ) {\n      throw rule.error('Wrong loop syntax', {\n        plugin: 'postcss-for'\n      });\n    }\n\n    [params[2], params[4], params[6] || '0'].forEach(checkNumber(rule));\n  };\n\n  const unrollLoop = (rule: postcss.AtRule) => {\n    const params = rule.params.split(/\\s+/);\n\n    checkParams(rule, params);\n\n    const iterator = params[0].slice(1);\n    const index = +params[2];\n    const top = +params[4];\n    const dir = top < index ? -1 : 1;\n    const by = (+(params[6] || 1)) * dir;\n\n    const value: Record<string, number> = {};\n    for(let i = index; i * dir <= top * dir; i = i + by) {\n      const content = rule.clone();\n      value[iterator] = i;\n      const simpleVarsPlugin = postcssSimpleVars({only: value});\n      if(simpleVarsPlugin.prepare) {\n        const prepared = simpleVarsPlugin.prepare({} as any);\n        if(prepared.Once) {\n          prepared.Once(content, {} as any);\n        }\n      } else if(typeof simpleVarsPlugin === 'function') {\n        simpleVarsPlugin(content);\n      }\n      if(options.nested) {\n        processLoops(content);\n      }\n      if(rule.parent) {\n        rule.parent.insertBefore(rule, content.nodes);\n      }\n    }\n    if(rule.parent) {\n      rule.remove();\n    }\n  };\n\n  const processLoops = (css: postcss.Container) => {\n    css.walkAtRules((rule) => {\n      if(rule.name === 'for') {\n        unrollLoop(rule);\n      }\n    });\n  };\n\n  const processOriginalLoops = (css: postcss.Root) => {\n    css.walkAtRules((rule) => {\n      if(rule.name === 'for') {\n        if(rule.parent) {\n          manageIterStack(rule);\n        }\n        unrollLoop(rule);\n      }\n    });\n  };\n\n  return {\n    Once(root) {\n      processOriginalLoops(root);\n    },\n    postcssPlugin: 'postcss-for'\n  };\n};\n\npostcssFor.postcss = true;\n\nexport default postcssFor;\n\n"],"names":["postcssSimpleVars","postcssFor","opts","options","nested","iterStack","parentsHaveIterator","rule","param","parent","type","params","parentIterVar","split","indexOf","manageIterStack","splice","length","parentIndex","currentIterVar","push","checkNumber","isNaN","Number","match","error","plugin","checkParams","startsWith","forEach","unrollLoop","iterator","slice","index","top","dir","by","value","i","content","clone","simpleVarsPlugin","only","prepare","prepared","Once","processLoops","insertBefore","nodes","remove","css","walkAtRules","name","processOriginalLoops","root","postcssPlugin","postcss"],"mappings":"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"}
|
|
@@ -5,10 +5,10 @@ interface PostcssPercentageOptions {
|
|
|
5
5
|
}
|
|
6
6
|
declare const postcssPercentage: {
|
|
7
7
|
(opts?: PostcssPercentageOptions): {
|
|
8
|
-
postcssPlugin: string;
|
|
9
8
|
Once(root: any, { result }: {
|
|
10
9
|
result: any;
|
|
11
10
|
}): void;
|
|
11
|
+
postcssPlugin: string;
|
|
12
12
|
};
|
|
13
13
|
postcss: boolean;
|
|
14
14
|
};
|
|
@@ -4,17 +4,16 @@
|
|
|
4
4
|
*
|
|
5
5
|
* PostCSS 8-compatible version of postcss-percentage plugin
|
|
6
6
|
* Original: https://github.com/antyakushev/postcss-percentage
|
|
7
|
-
*/ import
|
|
8
|
-
import { createRequire } from 'module';
|
|
7
|
+
*/ import Mexp from 'math-expression-evaluator';
|
|
9
8
|
import parser from 'postcss-value-parser';
|
|
10
|
-
const require = createRequire(fileURLToPath(import.meta.url));
|
|
11
|
-
const evaluator = require('math-expression-evaluator');
|
|
12
9
|
const transformPercentage = (value, precision, floor, trimTrailingZero)=>{
|
|
10
|
+
// @ts-expect-error - Mexp default export type issue
|
|
11
|
+
const evaluator = new Mexp();
|
|
13
12
|
return parser(value).walk((node)=>{
|
|
14
13
|
if (node.type !== 'function' || node.value !== 'percentage') {
|
|
15
14
|
return;
|
|
16
15
|
}
|
|
17
|
-
|
|
16
|
+
const result = evaluator.eval(parser.stringify(node.nodes)) * 100;
|
|
18
17
|
let resultStr;
|
|
19
18
|
if (result === 0) {
|
|
20
19
|
resultStr = '0';
|
|
@@ -29,6 +28,7 @@ const transformPercentage = (value, precision, floor, trimTrailingZero)=>{
|
|
|
29
28
|
resultStr = resultStr.replace(/\.0+$/, '').replace(/(\.\d*[1-9])0+$/, '$1');
|
|
30
29
|
}
|
|
31
30
|
resultStr += '%';
|
|
31
|
+
// eslint-disable-next-line no-restricted-properties
|
|
32
32
|
Object.assign(node, {
|
|
33
33
|
type: 'word',
|
|
34
34
|
value: resultStr
|
|
@@ -37,12 +37,12 @@ const transformPercentage = (value, precision, floor, trimTrailingZero)=>{
|
|
|
37
37
|
};
|
|
38
38
|
const postcssPercentage = (opts = {})=>{
|
|
39
39
|
const options = {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
40
|
+
floor: opts.floor,
|
|
41
|
+
precision: opts.precision === null || opts.precision === undefined || opts.precision > 20 || opts.precision < 0 ? 6 : opts.precision,
|
|
42
|
+
trimTrailingZero: opts.trimTrailingZero === null || opts.trimTrailingZero === undefined ? true : opts.trimTrailingZero
|
|
43
43
|
};
|
|
44
44
|
return {
|
|
45
|
-
|
|
45
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
46
46
|
Once (root, { result }) {
|
|
47
47
|
root.walkDecls((decl)=>{
|
|
48
48
|
if (!decl.value || !/percentage\s*\(/.test(decl.value)) {
|
|
@@ -53,15 +53,16 @@ const postcssPercentage = (opts = {})=>{
|
|
|
53
53
|
} catch (e) {
|
|
54
54
|
const error = e;
|
|
55
55
|
decl.warn(result, error.message, {
|
|
56
|
-
|
|
57
|
-
|
|
56
|
+
index: decl.index,
|
|
57
|
+
word: decl.value
|
|
58
58
|
});
|
|
59
59
|
}
|
|
60
60
|
});
|
|
61
|
-
}
|
|
61
|
+
},
|
|
62
|
+
postcssPlugin: 'postcss-percentage'
|
|
62
63
|
};
|
|
63
64
|
};
|
|
64
65
|
postcssPercentage.postcss = true;
|
|
65
66
|
export default postcssPercentage;
|
|
66
67
|
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy9wb3N0Y3NzL3Bvc3Rjc3MtcGVyY2VudGFnZS50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAyNS1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqXG4gKiBQb3N0Q1NTIDgtY29tcGF0aWJsZSB2ZXJzaW9uIG9mIHBvc3Rjc3MtcGVyY2VudGFnZSBwbHVnaW5cbiAqIE9yaWdpbmFsOiBodHRwczovL2dpdGh1Yi5jb20vYW50eWFrdXNoZXYvcG9zdGNzcy1wZXJjZW50YWdlXG4gKi9cbmltcG9ydCBNZXhwIGZyb20gJ21hdGgtZXhwcmVzc2lvbi1ldmFsdWF0b3InO1xuaW1wb3J0IHBhcnNlciBmcm9tICdwb3N0Y3NzLXZhbHVlLXBhcnNlcic7XG5cbmludGVyZmFjZSBQb3N0Y3NzUGVyY2VudGFnZU9wdGlvbnMge1xuICBmbG9vcj86IGJvb2xlYW47XG4gIHByZWNpc2lvbj86IG51bWJlcjtcbiAgdHJpbVRyYWlsaW5nWmVybz86IGJvb2xlYW47XG59XG5cbmNvbnN0IHRyYW5zZm9ybVBlcmNlbnRhZ2UgPSAoXG4gIHZhbHVlOiBzdHJpbmcsXG4gIHByZWNpc2lvbjogbnVtYmVyLFxuICBmbG9vcjogYm9vbGVhbiB8IHVuZGVmaW5lZCxcbiAgdHJpbVRyYWlsaW5nWmVybzogYm9vbGVhbiB8IHVuZGVmaW5lZFxuKTogc3RyaW5nID0+IHtcbiAgLy8gQHRzLWV4cGVjdC1lcnJvciAtIE1leHAgZGVmYXVsdCBleHBvcnQgdHlwZSBpc3N1ZVxuICBjb25zdCBldmFsdWF0b3IgPSBuZXcgTWV4cCgpO1xuICByZXR1cm4gcGFyc2VyKHZhbHVlKS53YWxrKChub2RlKSA9PiB7XG4gICAgaWYobm9kZS50eXBlICE9PSAnZnVuY3Rpb24nIHx8IG5vZGUudmFsdWUgIT09ICdwZXJjZW50YWdlJykge1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IHJlc3VsdCA9IGV2YWx1YXRvci5ldmFsKHBhcnNlci5zdHJpbmdpZnkobm9kZS5ub2RlcykpICogMTAwO1xuICAgIGxldCByZXN1bHRTdHI6IHN0cmluZztcbiAgICBpZihyZXN1bHQgPT09IDApIHtcbiAgICAgIHJlc3VsdFN0ciA9ICcwJztcbiAgICB9IGVsc2UgaWYoZmxvb3IpIHtcbiAgICAgIGNvbnN0IHJlc3VsdFN0cmluZyA9IHJlc3VsdC50b1N0cmluZygpO1xuICAgICAgY29uc3QgaW5kZXggPSByZXN1bHRTdHJpbmcuaW5kZXhPZignLicpO1xuICAgICAgcmVzdWx0U3RyID0gaW5kZXggPT09IC0xXG4gICAgICAgID8gcmVzdWx0U3RyaW5nXG4gICAgICAgIDogcmVzdWx0U3RyaW5nLnN1YnN0cmluZygwLCBpbmRleCArIDEgKyBwcmVjaXNpb24pO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXN1bHRTdHIgPSByZXN1bHQudG9GaXhlZChwcmVjaXNpb24pO1xuICAgIH1cbiAgICBpZih0cmltVHJhaWxpbmdaZXJvKSB7XG4gICAgICByZXN1bHRTdHIgPSByZXN1bHRTdHJcbiAgICAgICAgLnJlcGxhY2UoL1xcLjArJC8sICcnKVxuICAgICAgICAucmVwbGFjZSgvKFxcLlxcZCpbMS05XSkwKyQvLCAnJDEnKTtcbiAgICB9XG4gICAgcmVzdWx0U3RyICs9ICclJztcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tcmVzdHJpY3RlZC1wcm9wZXJ0aWVzXG4gICAgT2JqZWN0LmFzc2lnbihub2RlLCB7XG4gICAgICB0eXBlOiAnd29yZCcgYXMgY29uc3QsXG4gICAgICB2YWx1ZTogcmVzdWx0U3RyXG4gICAgfSk7XG4gIH0pLnRvU3RyaW5nKCk7XG59O1xuXG5jb25zdCBwb3N0Y3NzUGVyY2VudGFnZSA9IChvcHRzOiBQb3N0Y3NzUGVyY2VudGFnZU9wdGlvbnMgPSB7fSkgPT4ge1xuICBjb25zdCBvcHRpb25zID0ge1xuICAgIGZsb29yOiBvcHRzLmZsb29yLFxuICAgIHByZWNpc2lvbjogb3B0cy5wcmVjaXNpb24gPT09IG51bGwgfHwgb3B0cy5wcmVjaXNpb24gPT09IHVuZGVmaW5lZCB8fCBvcHRzLnByZWNpc2lvbiA+IDIwIHx8IG9wdHMucHJlY2lzaW9uIDwgMFxuICAgICAgPyA2XG4gICAgICA6IG9wdHMucHJlY2lzaW9uLFxuICAgIHRyaW1UcmFpbGluZ1plcm86IG9wdHMudHJpbVRyYWlsaW5nWmVybyA9PT0gbnVsbCB8fCBvcHRzLnRyaW1UcmFpbGluZ1plcm8gPT09IHVuZGVmaW5lZFxuICAgICAgPyB0cnVlXG4gICAgICA6IG9wdHMudHJpbVRyYWlsaW5nWmVyb1xuICB9O1xuXG4gIHJldHVybiB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgIE9uY2Uocm9vdCwge3Jlc3VsdH0pIHtcbiAgICAgIHJvb3Qud2Fsa0RlY2xzKChkZWNsKSA9PiB7XG4gICAgICAgIGlmKCFkZWNsLnZhbHVlIHx8ICEvcGVyY2VudGFnZVxccypcXCgvLnRlc3QoZGVjbC52YWx1ZSkpIHtcbiAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICB0cnkge1xuICAgICAgICAgIGRlY2wudmFsdWUgPSB0cmFuc2Zvcm1QZXJjZW50YWdlKFxuICAgICAgICAgICAgZGVjbC52YWx1ZSxcbiAgICAgICAgICAgIG9wdGlvbnMucHJlY2lzaW9uLFxuICAgICAgICAgICAgb3B0aW9ucy5mbG9vcixcbiAgICAgICAgICAgIG9wdGlvbnMudHJpbVRyYWlsaW5nWmVyb1xuICAgICAgICAgICk7XG4gICAgICAgIH0gY2F0Y2goZSkge1xuICAgICAgICAgIGNvbnN0IGVycm9yID0gZSBhcyBFcnJvcjtcbiAgICAgICAgICBkZWNsLndhcm4ocmVzdWx0LCBlcnJvci5tZXNzYWdlLCB7XG4gICAgICAgICAgICBpbmRleDogZGVjbC5pbmRleCxcbiAgICAgICAgICAgIHdvcmQ6IGRlY2wudmFsdWVcbiAgICAgICAgICB9KTtcbiAgICAgICAgfVxuICAgICAgfSk7XG4gICAgfSxcbiAgICBwb3N0Y3NzUGx1Z2luOiAncG9zdGNzcy1wZXJjZW50YWdlJ1xuICB9O1xufTtcblxucG9zdGNzc1BlcmNlbnRhZ2UucG9zdGNzcyA9IHRydWU7XG5cbmV4cG9ydCBkZWZhdWx0IHBvc3Rjc3NQZXJjZW50YWdlO1xuXG4iXSwibmFtZXMiOlsiTWV4cCIsInBhcnNlciIsInRyYW5zZm9ybVBlcmNlbnRhZ2UiLCJ2YWx1ZSIsInByZWNpc2lvbiIsImZsb29yIiwidHJpbVRyYWlsaW5nWmVybyIsImV2YWx1YXRvciIsIndhbGsiLCJub2RlIiwidHlwZSIsInJlc3VsdCIsImV2YWwiLCJzdHJpbmdpZnkiLCJub2RlcyIsInJlc3VsdFN0ciIsInJlc3VsdFN0cmluZyIsInRvU3RyaW5nIiwiaW5kZXgiLCJpbmRleE9mIiwic3Vic3RyaW5nIiwidG9GaXhlZCIsInJlcGxhY2UiLCJPYmplY3QiLCJhc3NpZ24iLCJwb3N0Y3NzUGVyY2VudGFnZSIsIm9wdHMiLCJvcHRpb25zIiwidW5kZWZpbmVkIiwiT25jZSIsInJvb3QiLCJ3YWxrRGVjbHMiLCJkZWNsIiwidGVzdCIsImUiLCJlcnJvciIsIndhcm4iLCJtZXNzYWdlIiwid29yZCIsInBvc3Rjc3NQbHVnaW4iLCJwb3N0Y3NzIl0sIm1hcHBpbmdzIjoiQUFBQTs7Ozs7O0NBTUMsR0FDRCxPQUFPQSxVQUFVLDRCQUE0QjtBQUM3QyxPQUFPQyxZQUFZLHVCQUF1QjtBQVExQyxNQUFNQyxzQkFBc0IsQ0FDMUJDLE9BQ0FDLFdBQ0FDLE9BQ0FDO0lBRUEsb0RBQW9EO0lBQ3BELE1BQU1DLFlBQVksSUFBSVA7SUFDdEIsT0FBT0MsT0FBT0UsT0FBT0ssSUFBSSxDQUFDLENBQUNDO1FBQ3pCLElBQUdBLEtBQUtDLElBQUksS0FBSyxjQUFjRCxLQUFLTixLQUFLLEtBQUssY0FBYztZQUMxRDtRQUNGO1FBRUEsTUFBTVEsU0FBU0osVUFBVUssSUFBSSxDQUFDWCxPQUFPWSxTQUFTLENBQUNKLEtBQUtLLEtBQUssS0FBSztRQUM5RCxJQUFJQztRQUNKLElBQUdKLFdBQVcsR0FBRztZQUNmSSxZQUFZO1FBQ2QsT0FBTyxJQUFHVixPQUFPO1lBQ2YsTUFBTVcsZUFBZUwsT0FBT00sUUFBUTtZQUNwQyxNQUFNQyxRQUFRRixhQUFhRyxPQUFPLENBQUM7WUFDbkNKLFlBQVlHLFVBQVUsQ0FBQyxJQUNuQkYsZUFDQUEsYUFBYUksU0FBUyxDQUFDLEdBQUdGLFFBQVEsSUFBSWQ7UUFDNUMsT0FBTztZQUNMVyxZQUFZSixPQUFPVSxPQUFPLENBQUNqQjtRQUM3QjtRQUNBLElBQUdFLGtCQUFrQjtZQUNuQlMsWUFBWUEsVUFDVE8sT0FBTyxDQUFDLFNBQVMsSUFDakJBLE9BQU8sQ0FBQyxtQkFBbUI7UUFDaEM7UUFDQVAsYUFBYTtRQUNiLG9EQUFvRDtRQUNwRFEsT0FBT0MsTUFBTSxDQUFDZixNQUFNO1lBQ2xCQyxNQUFNO1lBQ05QLE9BQU9ZO1FBQ1Q7SUFDRixHQUFHRSxRQUFRO0FBQ2I7QUFFQSxNQUFNUSxvQkFBb0IsQ0FBQ0MsT0FBaUMsQ0FBQyxDQUFDO0lBQzVELE1BQU1DLFVBQVU7UUFDZHRCLE9BQU9xQixLQUFLckIsS0FBSztRQUNqQkQsV0FBV3NCLEtBQUt0QixTQUFTLEtBQUssUUFBUXNCLEtBQUt0QixTQUFTLEtBQUt3QixhQUFhRixLQUFLdEIsU0FBUyxHQUFHLE1BQU1zQixLQUFLdEIsU0FBUyxHQUFHLElBQzFHLElBQ0FzQixLQUFLdEIsU0FBUztRQUNsQkUsa0JBQWtCb0IsS0FBS3BCLGdCQUFnQixLQUFLLFFBQVFvQixLQUFLcEIsZ0JBQWdCLEtBQUtzQixZQUMxRSxPQUNBRixLQUFLcEIsZ0JBQWdCO0lBQzNCO0lBRUEsT0FBTztRQUNMLGdFQUFnRTtRQUNoRXVCLE1BQUtDLElBQUksRUFBRSxFQUFDbkIsTUFBTSxFQUFDO1lBQ2pCbUIsS0FBS0MsU0FBUyxDQUFDLENBQUNDO2dCQUNkLElBQUcsQ0FBQ0EsS0FBSzdCLEtBQUssSUFBSSxDQUFDLGtCQUFrQjhCLElBQUksQ0FBQ0QsS0FBSzdCLEtBQUssR0FBRztvQkFDckQ7Z0JBQ0Y7Z0JBRUEsSUFBSTtvQkFDRjZCLEtBQUs3QixLQUFLLEdBQUdELG9CQUNYOEIsS0FBSzdCLEtBQUssRUFDVndCLFFBQVF2QixTQUFTLEVBQ2pCdUIsUUFBUXRCLEtBQUssRUFDYnNCLFFBQVFyQixnQkFBZ0I7Z0JBRTVCLEVBQUUsT0FBTTRCLEdBQUc7b0JBQ1QsTUFBTUMsUUFBUUQ7b0JBQ2RGLEtBQUtJLElBQUksQ0FBQ3pCLFFBQVF3QixNQUFNRSxPQUFPLEVBQUU7d0JBQy9CbkIsT0FBT2MsS0FBS2QsS0FBSzt3QkFDakJvQixNQUFNTixLQUFLN0IsS0FBSztvQkFDbEI7Z0JBQ0Y7WUFDRjtRQUNGO1FBQ0FvQyxlQUFlO0lBQ2pCO0FBQ0Y7QUFFQWQsa0JBQWtCZSxPQUFPLEdBQUc7QUFFNUIsZUFBZWYsa0JBQWtCIn0=
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nlabs/lex",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.52.0",
|
|
4
4
|
"description": "Lex",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"type": "module",
|
|
@@ -131,7 +131,7 @@
|
|
|
131
131
|
"dotenv-webpack": "^8.1.1",
|
|
132
132
|
"download-npm-package": "^3.1.12",
|
|
133
133
|
"eslint": "^9.39.1",
|
|
134
|
-
"eslint-config-styleguidejs": "^4.1.
|
|
134
|
+
"eslint-config-styleguidejs": "^4.1.12",
|
|
135
135
|
"execa": "9.6.1",
|
|
136
136
|
"expect": "^30.2.0",
|
|
137
137
|
"exports-loader": "^5.0.0",
|
|
@@ -176,9 +176,12 @@
|
|
|
176
176
|
"postcss-nesting": "^13.0.2",
|
|
177
177
|
"postcss-percentage": "^0.0.0",
|
|
178
178
|
"postcss-preset-env": "^10.5.0",
|
|
179
|
+
"postcss-value-parser": "^4.2.0",
|
|
180
|
+
"math-expression-evaluator": "^2.0.7",
|
|
179
181
|
"postcss-simple-vars": "^7.0.1",
|
|
180
182
|
"postcss-svgo": "7.1.0",
|
|
181
183
|
"postcss-url": "10.1.3",
|
|
184
|
+
"postcss": "^8.5.6",
|
|
182
185
|
"process": "^0.11.10",
|
|
183
186
|
"randombytes": "^2.1.0",
|
|
184
187
|
"react": "^19.2.1",
|
|
@@ -194,7 +197,7 @@
|
|
|
194
197
|
"stream-browserify": "^3.0.0",
|
|
195
198
|
"stream-http": "^3.2.0",
|
|
196
199
|
"style-loader": "^4.0.0",
|
|
197
|
-
"svg-spritemap-webpack-plugin": "^5.0
|
|
200
|
+
"svg-spritemap-webpack-plugin": "^5.1.0",
|
|
198
201
|
"svgo": "4.0.0",
|
|
199
202
|
"swc-loader": "^0.2.6",
|
|
200
203
|
"tailwindcss": "^4.1.17",
|
|
@@ -230,10 +233,14 @@
|
|
|
230
233
|
"css-loader": "7.1.2"
|
|
231
234
|
},
|
|
232
235
|
"overrides": {
|
|
236
|
+
"cheerio": "^1.0.0-rc.13",
|
|
233
237
|
"cross-spawn": "^7.0.6",
|
|
238
|
+
"css-select": "^5.1.0",
|
|
234
239
|
"got": "^14.6.5",
|
|
235
240
|
"http-cache-semantics": "^4.2.0",
|
|
236
241
|
"http-proxy-middleware": "^3.0.5",
|
|
242
|
+
"lodash.pick": "^4.4.0",
|
|
243
|
+
"nth-check": "^2.1.1",
|
|
237
244
|
"postcss": "^8.5.6",
|
|
238
245
|
"semver-regex": "^4.0.5",
|
|
239
246
|
"tmp": "^0.2.5"
|
package/webpack.config.js
CHANGED
|
@@ -315,6 +315,8 @@ const alias = aliasKeys.reduce((aliases, key) => {
|
|
|
315
315
|
|
|
316
316
|
export default (webpackEnv, webpackOptions) => {
|
|
317
317
|
const {bundleAnalyzer, watch, entry: cliEntry, mode: cliMode, port} = webpackOptions;
|
|
318
|
+
const envPort = process.env.WEBPACK_DEV_PORT ? parseInt(process.env.WEBPACK_DEV_PORT, 10) : null;
|
|
319
|
+
const finalPort = port || envPort || 3000;
|
|
318
320
|
const entryValue = Array.isArray(cliEntry) ? cliEntry[0] : cliEntry;
|
|
319
321
|
|
|
320
322
|
// Debug printout for environment and mode
|
|
@@ -763,7 +765,7 @@ export default (webpackEnv, webpackOptions) => {
|
|
|
763
765
|
});
|
|
764
766
|
},
|
|
765
767
|
open: process.env.WEBPACK_DEV_OPEN === 'true',
|
|
766
|
-
port:
|
|
768
|
+
port: finalPort,
|
|
767
769
|
progress: 'minimal',
|
|
768
770
|
static: existsSync(outputFullPath) ? [outputFullPath] : [],
|
|
769
771
|
status: true
|