@nlabs/lex 1.48.3 → 1.48.5

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.
Files changed (63) hide show
  1. package/.storybook/main.ts +25 -4
  2. package/.vscode/settings.json +1 -1
  3. package/README.md +293 -22
  4. package/__mocks__/compare-versions.js +3 -0
  5. package/__mocks__/fileMock.js +1 -0
  6. package/__mocks__/latest-version.js +1 -0
  7. package/__mocks__/react-markdown.js +12 -0
  8. package/babel.config.json +2 -1
  9. package/dist/Button.stories.d.ts +19 -0
  10. package/dist/LexConfig.d.ts +84 -0
  11. package/dist/LexConfig.js +1 -4
  12. package/dist/commands/ai/ai.d.ts +17 -0
  13. package/dist/commands/ai/index.d.ts +8 -0
  14. package/dist/commands/build/build.d.ts +18 -0
  15. package/dist/commands/clean/clean.d.ts +7 -0
  16. package/dist/commands/compile/compile.d.ts +2 -0
  17. package/dist/commands/config/config.d.ts +7 -0
  18. package/dist/commands/config/config.js +2 -2
  19. package/dist/commands/copy/copy.d.ts +6 -0
  20. package/dist/commands/create/create.d.ts +8 -0
  21. package/dist/commands/dev/dev.d.ts +11 -0
  22. package/dist/commands/init/init.d.ts +9 -0
  23. package/dist/commands/link/link.d.ts +6 -0
  24. package/dist/commands/lint/autofix.d.ts +2 -0
  25. package/dist/commands/lint/lint.d.ts +39 -0
  26. package/dist/commands/migrate/migrate.d.ts +7 -0
  27. package/dist/commands/publish/publish.d.ts +12 -0
  28. package/dist/commands/storybook/storybook.d.ts +13 -0
  29. package/dist/commands/storybook/storybook.js +3 -5
  30. package/dist/commands/test/test.d.ts +50 -0
  31. package/dist/commands/test/test.js +80 -10
  32. package/dist/commands/update/update.d.ts +9 -0
  33. package/dist/commands/upgrade/upgrade.d.ts +7 -0
  34. package/dist/commands/versions/versions.d.ts +13 -0
  35. package/dist/create/changelog.d.ts +6 -0
  36. package/dist/index.d.ts +33 -0
  37. package/dist/index.js +2 -1
  38. package/dist/lex.d.ts +2 -0
  39. package/dist/test-react/index.d.ts +8 -0
  40. package/dist/test-react/index.js +86 -0
  41. package/dist/types.d.ts +5 -0
  42. package/dist/utils/aiService.d.ts +9 -0
  43. package/dist/utils/app.d.ts +45 -0
  44. package/dist/utils/file.d.ts +8 -0
  45. package/dist/utils/file.js +9 -3
  46. package/dist/utils/log.d.ts +1 -0
  47. package/dist/utils/reactShim.d.ts +4 -0
  48. package/dist/utils/reactShim.js +82 -2
  49. package/jest.config.d.mts +50 -0
  50. package/jest.config.mjs +69 -0
  51. package/jest.config.template.cjs +63 -0
  52. package/jest.setup.js +18 -15
  53. package/jest.setup.template.js +18 -0
  54. package/package.json +24 -7
  55. package/tsconfig.build.json +8 -10
  56. package/tsconfig.lint.json +2 -2
  57. package/tsconfig.test.json +2 -2
  58. package/dist/dist/LexConfig.d.ts +0 -119
  59. package/dist/dist/utils/file.d.ts +0 -8
  60. package/dist/dist/utils/log.d.ts +0 -1
  61. package/dist/jest.config.lex.d.ts +0 -2
  62. package/jest.config.cjs +0 -43
  63. package/jest.config.lex.js +0 -118
@@ -0,0 +1,17 @@
1
+ import { Command } from 'commander';
2
+ export interface AIOptions {
3
+ readonly cliName?: string;
4
+ readonly context?: boolean;
5
+ readonly file?: string;
6
+ readonly lexConfig?: string;
7
+ readonly model?: string;
8
+ readonly prompt?: string;
9
+ readonly quiet?: boolean;
10
+ readonly task?: 'generate' | 'explain' | 'test' | 'optimize' | 'help' | 'ask' | 'analyze';
11
+ readonly debug?: boolean;
12
+ readonly provider?: string;
13
+ readonly dir?: string;
14
+ }
15
+ export declare const aiFunction: (options: AIOptions) => Promise<any>;
16
+ export declare const ai: Command;
17
+ export default ai;
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */
5
+ import ai, { type AIOptions } from './ai.js';
6
+ export { ai };
7
+ export type { AIOptions };
8
+ export default ai;
@@ -0,0 +1,18 @@
1
+ export interface BuildOptions {
2
+ readonly assist?: boolean;
3
+ readonly analyze?: boolean;
4
+ readonly bundler?: 'webpack' | 'esbuild';
5
+ readonly cliName?: string;
6
+ readonly format?: string;
7
+ readonly outputPath?: string;
8
+ readonly quiet?: boolean;
9
+ readonly remove?: boolean;
10
+ readonly sourcePath?: string;
11
+ readonly variables?: string;
12
+ readonly watch?: boolean;
13
+ }
14
+ export type BuildCallback = (status: number) => void;
15
+ export declare const buildWithEsBuild: (spinner: any, commandOptions: BuildOptions, callback: BuildCallback) => Promise<1 | 0>;
16
+ export declare const buildWithWebpack: (spinner: any, cmd: any, callback: any) => Promise<1 | 0>;
17
+ export declare const build: (cmd: BuildOptions, callback?: BuildCallback) => Promise<number>;
18
+ export default build;
@@ -0,0 +1,7 @@
1
+ export interface CleanOptions {
2
+ readonly cliName?: string;
3
+ readonly quiet?: boolean;
4
+ readonly snapshots?: boolean;
5
+ }
6
+ export type CleanCallback = (status: number) => void;
7
+ export declare const clean: (cmd: CleanOptions, callback?: CleanCallback) => Promise<number>;
@@ -0,0 +1,2 @@
1
+ export declare const hasFileType: (startPath: string, ext: string[]) => boolean;
2
+ export declare const compile: (cmd: any, callback?: any) => Promise<number>;
@@ -0,0 +1,7 @@
1
+ export interface ConfigOptions {
2
+ readonly cliName?: string;
3
+ readonly json?: string;
4
+ readonly quiet?: boolean;
5
+ }
6
+ export type ConfigCallback = (status: number) => void;
7
+ export declare const config: (type: string, cmd: ConfigOptions, callback?: ConfigCallback) => Promise<number>;
@@ -21,7 +21,7 @@ ${cliName} Error: Option for ${type} not found. Configurations only available fo
21
21
  configOptions = LexConfig.config;
22
22
  break;
23
23
  case "jest":
24
- configOptions = import("../../../jest.config.lex.js");
24
+ configOptions = import("../../../jest.config.mjs");
25
25
  break;
26
26
  case "webpack":
27
27
  configOptions = import("../../../webpack.config.js");
@@ -40,4 +40,4 @@ ${cliName} Error: Option for ${type} not found. Configurations only available fo
40
40
  export {
41
41
  config
42
42
  };
43
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2NvbmZpZy9jb25maWcudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge3dyaXRlRmlsZVN5bmN9IGZyb20gJ2ZzJztcbmltcG9ydCBzdGFydENhc2UgZnJvbSAnbG9kYXNoL3N0YXJ0Q2FzZS5qcyc7XG5pbXBvcnQge3JlbGF0aXZlIGFzIHBhdGhSZWxhdGl2ZX0gZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7TGV4Q29uZmlnfSBmcm9tICcuLi8uLi9MZXhDb25maWcuanMnO1xuaW1wb3J0IHtjcmVhdGVTcGlubmVyfSBmcm9tICcuLi8uLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29uZmlnT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGpzb24/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHF1aWV0PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgQ29uZmlnQ2FsbGJhY2sgPSAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQ7XG5cbmV4cG9ydCBjb25zdCBjb25maWcgPSBhc3luYyAodHlwZTogc3RyaW5nLCBjbWQ6IENvbmZpZ09wdGlvbnMsIGNhbGxiYWNrOiBDb25maWdDYWxsYmFjayA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBqc29uLCBxdWlldH0gPSBjbWQ7XG4gIGNvbnN0IHZhbGlkVHlwZXM6IHN0cmluZ1tdID0gWydhcHAnLCAnamVzdCcsICd3ZWJwYWNrJ107XG5cbiAgaWYoIXZhbGlkVHlwZXMuaW5jbHVkZXModHlwZSkpIHtcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IE9wdGlvbiBmb3IgJHt0eXBlfSBub3QgZm91bmQuIENvbmZpZ3VyYXRpb25zIG9ubHkgYXZhaWxhYmxlIGZvciBhcHAsIGplc3QsIGFuZCB3ZWJwYWNrLmAsICdlcnJvcicsIHF1aWV0KTtcbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDEpO1xuICB9XG5cbiAgLy8gRGlzcGxheSBzdGF0dXNcbiAgbG9nKGAke2NsaU5hbWV9IGdlbmVyYXRpbmcgY29uZmlndXJhdGlvbiBmb3IgJHtzdGFydENhc2UodHlwZSl9Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgLy8gR2V0IGN1c3RvbSBjb25maWd1cmF0aW9uXG4gIGF3YWl0IExleENvbmZpZy5wYXJzZUNvbmZpZyhjbWQpO1xuXG4gIGxldCBjb25maWdPcHRpb25zO1xuXG4gIHN3aXRjaCh0eXBlKSB7XG4gICAgY2FzZSAnYXBwJzpcbiAgICAgIGNvbmZpZ09wdGlvbnMgPSBMZXhDb25maWcuY29uZmlnO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnamVzdCc6XG4gICAgICBjb25maWdPcHRpb25zID0gaW1wb3J0KCcuLi8uLi8uLi9qZXN0LmNvbmZpZy5sZXguanMnKTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ3dlYnBhY2snOlxuICAgICAgY29uZmlnT3B0aW9ucyA9IGltcG9ydCgnLi4vLi4vLi4vd2VicGFjay5jb25maWcuanMnKTtcbiAgICAgIGJyZWFrO1xuICB9XG5cbiAgLy8gT3V0cHV0IGNvbmZpZyB0byBjb25zb2xlXG4gIGNvbnN0IGpzb25PdXRwdXQ6IHN0cmluZyA9IEpTT04uc3RyaW5naWZ5KGNvbmZpZ09wdGlvbnMsIG51bGwsIDIpO1xuXG4gIGlmKGpzb24pIHtcbiAgICAvLyBTcGlubmVyXG4gICAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gICAgLy8gU3RhcnQgc3Bpbm5lclxuICAgIHNwaW5uZXIuc3RhcnQoJ0NyZWF0aW5nIEpTT04gb3V0cHV0Li4uJyk7XG5cbiAgICAvLyBTYXZlIGpzb24gbG9jYWxseVxuICAgIHdyaXRlRmlsZVN5bmMoanNvbiwganNvbk91dHB1dCk7XG5cbiAgICAvLyBTdWNjZXNzIHNwaW5uZXJcbiAgICBzcGlubmVyLnN1Y2NlZWQoYFN1Y2Nlc3NmdWxseSBzYXZlZCBKU09OIG91dHB1dCB0byAke3BhdGhSZWxhdGl2ZShwcm9jZXNzLmN3ZCgpLCBqc29uKX1gKTtcbiAgfVxuXG4gIGNhbGxiYWNrKDApO1xuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDApO1xufTsiXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLHFCQUFvQjtBQUM1QixPQUFPLGVBQWU7QUFDdEIsU0FBUSxZQUFZLG9CQUFtQjtBQUV2QyxTQUFRLGlCQUFnQjtBQUN4QixTQUFRLHFCQUFvQjtBQUM1QixTQUFRLFdBQVU7QUFVWCxNQUFNLFNBQVMsT0FBTyxNQUFjLEtBQW9CLFdBQTJCLE9BQU8sQ0FBQyxPQUF3QjtBQUN4SCxRQUFNLEVBQUMsVUFBVSxPQUFPLE1BQU0sTUFBSyxJQUFJO0FBQ3ZDLFFBQU0sYUFBdUIsQ0FBQyxPQUFPLFFBQVEsU0FBUztBQUV0RCxNQUFHLENBQUMsV0FBVyxTQUFTLElBQUksR0FBRztBQUM3QixRQUFJO0FBQUEsRUFBSyxPQUFPLHNCQUFzQixJQUFJLHlFQUF5RSxTQUFTLEtBQUs7QUFDakksYUFBUyxDQUFDO0FBQ1YsV0FBTyxRQUFRLFFBQVEsQ0FBQztBQUFBLEVBQzFCO0FBR0EsTUFBSSxHQUFHLE9BQU8saUNBQWlDLFVBQVUsSUFBSSxDQUFDLE9BQU8sUUFBUSxLQUFLO0FBR2xGLFFBQU0sVUFBVSxZQUFZLEdBQUc7QUFFL0IsTUFBSTtBQUVKLFVBQU8sTUFBTTtBQUFBLElBQ1gsS0FBSztBQUNILHNCQUFnQixVQUFVO0FBQzFCO0FBQUEsSUFDRixLQUFLO0FBQ0gsc0JBQWdCLE9BQU8sNkJBQTZCO0FBQ3BEO0FBQUEsSUFDRixLQUFLO0FBQ0gsc0JBQWdCLE9BQU8sNEJBQTRCO0FBQ25EO0FBQUEsRUFDSjtBQUdBLFFBQU0sYUFBcUIsS0FBSyxVQUFVLGVBQWUsTUFBTSxDQUFDO0FBRWhFLE1BQUcsTUFBTTtBQUVQLFVBQU0sVUFBVSxjQUFjLEtBQUs7QUFHbkMsWUFBUSxNQUFNLHlCQUF5QjtBQUd2QyxrQkFBYyxNQUFNLFVBQVU7QUFHOUIsWUFBUSxRQUFRLHFDQUFxQyxhQUFhLFFBQVEsSUFBSSxHQUFHLElBQUksQ0FBQyxFQUFFO0FBQUEsRUFDMUY7QUFFQSxXQUFTLENBQUM7QUFDVixTQUFPLFFBQVEsUUFBUSxDQUFDO0FBQzFCOyIsCiAgIm5hbWVzIjogW10KfQo=
43
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vLi4vc3JjL2NvbW1hbmRzL2NvbmZpZy9jb25maWcudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQge3dyaXRlRmlsZVN5bmN9IGZyb20gJ2ZzJztcbmltcG9ydCBzdGFydENhc2UgZnJvbSAnbG9kYXNoL3N0YXJ0Q2FzZS5qcyc7XG5pbXBvcnQge3JlbGF0aXZlIGFzIHBhdGhSZWxhdGl2ZX0gZnJvbSAncGF0aCc7XG5cbmltcG9ydCB7TGV4Q29uZmlnfSBmcm9tICcuLi8uLi9MZXhDb25maWcuanMnO1xuaW1wb3J0IHtjcmVhdGVTcGlubmVyfSBmcm9tICcuLi8uLi91dGlscy9hcHAuanMnO1xuaW1wb3J0IHtsb2d9IGZyb20gJy4uLy4uL3V0aWxzL2xvZy5qcyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29uZmlnT3B0aW9ucyB7XG4gIHJlYWRvbmx5IGNsaU5hbWU/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IGpzb24/OiBzdHJpbmc7XG4gIHJlYWRvbmx5IHF1aWV0PzogYm9vbGVhbjtcbn1cblxuZXhwb3J0IHR5cGUgQ29uZmlnQ2FsbGJhY2sgPSAoc3RhdHVzOiBudW1iZXIpID0+IHZvaWQ7XG5cbmV4cG9ydCBjb25zdCBjb25maWcgPSBhc3luYyAodHlwZTogc3RyaW5nLCBjbWQ6IENvbmZpZ09wdGlvbnMsIGNhbGxiYWNrOiBDb25maWdDYWxsYmFjayA9ICgpID0+ICh7fSkpOiBQcm9taXNlPG51bWJlcj4gPT4ge1xuICBjb25zdCB7Y2xpTmFtZSA9ICdMZXgnLCBqc29uLCBxdWlldH0gPSBjbWQ7XG4gIGNvbnN0IHZhbGlkVHlwZXM6IHN0cmluZ1tdID0gWydhcHAnLCAnamVzdCcsICd3ZWJwYWNrJ107XG5cbiAgaWYoIXZhbGlkVHlwZXMuaW5jbHVkZXModHlwZSkpIHtcbiAgICBsb2coYFxcbiR7Y2xpTmFtZX0gRXJyb3I6IE9wdGlvbiBmb3IgJHt0eXBlfSBub3QgZm91bmQuIENvbmZpZ3VyYXRpb25zIG9ubHkgYXZhaWxhYmxlIGZvciBhcHAsIGplc3QsIGFuZCB3ZWJwYWNrLmAsICdlcnJvcicsIHF1aWV0KTtcbiAgICBjYWxsYmFjaygxKTtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDEpO1xuICB9XG5cbiAgbG9nKGAke2NsaU5hbWV9IGdlbmVyYXRpbmcgY29uZmlndXJhdGlvbiBmb3IgJHtzdGFydENhc2UodHlwZSl9Li4uYCwgJ2luZm8nLCBxdWlldCk7XG5cbiAgYXdhaXQgTGV4Q29uZmlnLnBhcnNlQ29uZmlnKGNtZCk7XG5cbiAgbGV0IGNvbmZpZ09wdGlvbnM7XG5cbiAgc3dpdGNoKHR5cGUpIHtcbiAgICBjYXNlICdhcHAnOlxuICAgICAgY29uZmlnT3B0aW9ucyA9IExleENvbmZpZy5jb25maWc7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdqZXN0JzpcbiAgICAgIGNvbmZpZ09wdGlvbnMgPSBpbXBvcnQoJy4uLy4uLy4uL2plc3QuY29uZmlnLm1qcycpO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAnd2VicGFjayc6XG4gICAgICBjb25maWdPcHRpb25zID0gaW1wb3J0KCcuLi8uLi8uLi93ZWJwYWNrLmNvbmZpZy5qcycpO1xuICAgICAgYnJlYWs7XG4gIH1cblxuICBjb25zdCBqc29uT3V0cHV0OiBzdHJpbmcgPSBKU09OLnN0cmluZ2lmeShjb25maWdPcHRpb25zLCBudWxsLCAyKTtcblxuICBpZihqc29uKSB7XG4gICAgY29uc3Qgc3Bpbm5lciA9IGNyZWF0ZVNwaW5uZXIocXVpZXQpO1xuXG4gICAgc3Bpbm5lci5zdGFydCgnQ3JlYXRpbmcgSlNPTiBvdXRwdXQuLi4nKTtcblxuICAgIHdyaXRlRmlsZVN5bmMoanNvbiwganNvbk91dHB1dCk7XG5cbiAgICBzcGlubmVyLnN1Y2NlZWQoYFN1Y2Nlc3NmdWxseSBzYXZlZCBKU09OIG91dHB1dCB0byAke3BhdGhSZWxhdGl2ZShwcm9jZXNzLmN3ZCgpLCBqc29uKX1gKTtcbiAgfVxuXG4gIGNhbGxiYWNrKDApO1xuICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKDApO1xufTsiXSwKICAibWFwcGluZ3MiOiAiQUFJQSxTQUFRLHFCQUFvQjtBQUM1QixPQUFPLGVBQWU7QUFDdEIsU0FBUSxZQUFZLG9CQUFtQjtBQUV2QyxTQUFRLGlCQUFnQjtBQUN4QixTQUFRLHFCQUFvQjtBQUM1QixTQUFRLFdBQVU7QUFVWCxNQUFNLFNBQVMsT0FBTyxNQUFjLEtBQW9CLFdBQTJCLE9BQU8sQ0FBQyxPQUF3QjtBQUN4SCxRQUFNLEVBQUMsVUFBVSxPQUFPLE1BQU0sTUFBSyxJQUFJO0FBQ3ZDLFFBQU0sYUFBdUIsQ0FBQyxPQUFPLFFBQVEsU0FBUztBQUV0RCxNQUFHLENBQUMsV0FBVyxTQUFTLElBQUksR0FBRztBQUM3QixRQUFJO0FBQUEsRUFBSyxPQUFPLHNCQUFzQixJQUFJLHlFQUF5RSxTQUFTLEtBQUs7QUFDakksYUFBUyxDQUFDO0FBQ1YsV0FBTyxRQUFRLFFBQVEsQ0FBQztBQUFBLEVBQzFCO0FBRUEsTUFBSSxHQUFHLE9BQU8saUNBQWlDLFVBQVUsSUFBSSxDQUFDLE9BQU8sUUFBUSxLQUFLO0FBRWxGLFFBQU0sVUFBVSxZQUFZLEdBQUc7QUFFL0IsTUFBSTtBQUVKLFVBQU8sTUFBTTtBQUFBLElBQ1gsS0FBSztBQUNILHNCQUFnQixVQUFVO0FBQzFCO0FBQUEsSUFDRixLQUFLO0FBQ0gsc0JBQWdCLE9BQU8sMEJBQTBCO0FBQ2pEO0FBQUEsSUFDRixLQUFLO0FBQ0gsc0JBQWdCLE9BQU8sNEJBQTRCO0FBQ25EO0FBQUEsRUFDSjtBQUVBLFFBQU0sYUFBcUIsS0FBSyxVQUFVLGVBQWUsTUFBTSxDQUFDO0FBRWhFLE1BQUcsTUFBTTtBQUNQLFVBQU0sVUFBVSxjQUFjLEtBQUs7QUFFbkMsWUFBUSxNQUFNLHlCQUF5QjtBQUV2QyxrQkFBYyxNQUFNLFVBQVU7QUFFOUIsWUFBUSxRQUFRLHFDQUFxQyxhQUFhLFFBQVEsSUFBSSxHQUFHLElBQUksQ0FBQyxFQUFFO0FBQUEsRUFDMUY7QUFFQSxXQUFTLENBQUM7QUFDVixTQUFPLFFBQVEsUUFBUSxDQUFDO0FBQzFCOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -0,0 +1,6 @@
1
+ export interface CopyOptions {
2
+ readonly cliName?: string;
3
+ readonly quiet?: boolean;
4
+ }
5
+ export type CopyCallback = (status: number) => void;
6
+ export declare const copy: (from: string, to: string, cmd: CopyOptions, callback?: CopyCallback) => Promise<number>;
@@ -0,0 +1,8 @@
1
+ export interface CreateOptions {
2
+ readonly cliName?: string;
3
+ readonly outputFile?: string;
4
+ readonly outputName?: string;
5
+ readonly quiet?: boolean;
6
+ }
7
+ export type CreateCallback = (status: number) => void;
8
+ export declare const create: (type: string, cmd: CreateOptions, callback?: CreateCallback) => Promise<number>;
@@ -0,0 +1,11 @@
1
+ export interface DevOptions {
2
+ readonly bundleAnalyzer?: boolean;
3
+ readonly cliName?: string;
4
+ readonly config?: string;
5
+ readonly open?: boolean;
6
+ readonly quiet?: boolean;
7
+ readonly remove?: boolean;
8
+ readonly variables?: string;
9
+ }
10
+ export type DevCallback = (status: number) => void;
11
+ export declare const dev: (cmd: DevOptions, callback?: DevCallback) => Promise<number>;
@@ -0,0 +1,9 @@
1
+ export interface InitOptions {
2
+ readonly cliName?: string;
3
+ readonly install?: boolean;
4
+ readonly packageManager?: string;
5
+ readonly quiet?: boolean;
6
+ readonly typescript?: boolean;
7
+ }
8
+ export type InitCallback = (status: number) => void;
9
+ export declare const init: (appName: string, packageName: string, cmd: InitOptions, callback?: InitCallback) => Promise<number>;
@@ -0,0 +1,6 @@
1
+ export interface LinkOptions {
2
+ readonly cliName?: string;
3
+ readonly quiet?: boolean;
4
+ }
5
+ export type LinkCallback = (status: number) => void;
6
+ export declare const linked: (cmd: LinkOptions, callback?: LinkCallback) => Promise<number>;
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ export {};
@@ -0,0 +1,39 @@
1
+ export interface LintOptions {
2
+ readonly cache?: boolean;
3
+ readonly cacheFile?: string;
4
+ readonly cacheLocation?: string;
5
+ readonly cliName?: string;
6
+ readonly color?: boolean;
7
+ readonly config?: string;
8
+ readonly debug?: boolean;
9
+ readonly env?: string;
10
+ readonly envInfo?: boolean;
11
+ readonly ext?: string;
12
+ readonly fix?: boolean;
13
+ readonly fixDryRun?: boolean;
14
+ readonly fixType?: string;
15
+ readonly format?: string;
16
+ readonly global?: string;
17
+ readonly ignorePath?: string;
18
+ readonly ignorePattern?: string;
19
+ readonly init?: boolean;
20
+ readonly maxWarnings?: string;
21
+ readonly noColor?: boolean;
22
+ readonly noEslintrc?: boolean;
23
+ readonly noIgnore?: boolean;
24
+ readonly noInlineConfig?: boolean;
25
+ readonly outputFile?: string;
26
+ readonly parser?: string;
27
+ readonly parserOptions?: string;
28
+ readonly plugin?: string;
29
+ readonly printConfig?: string;
30
+ readonly quiet?: boolean;
31
+ readonly reportUnusedDisableDirectives?: boolean;
32
+ readonly resolvePluginsRelativeTo?: string;
33
+ readonly rule?: string;
34
+ readonly rulesdir?: string;
35
+ readonly stdin?: boolean;
36
+ readonly stdinFilename?: string;
37
+ }
38
+ export type LintCallback = typeof process.exit;
39
+ export declare const lint: (cmd: LintOptions, callback?: LintCallback) => Promise<number>;
@@ -0,0 +1,7 @@
1
+ export interface MigrateOptions {
2
+ readonly cliName?: string;
3
+ readonly packageManager?: string;
4
+ readonly quiet?: boolean;
5
+ }
6
+ export type MigrateCallback = typeof process.exit;
7
+ export declare const migrate: (cmd: MigrateOptions, callback?: MigrateCallback) => Promise<number>;
@@ -0,0 +1,12 @@
1
+ export interface PublishOptions {
2
+ readonly bump?: string;
3
+ readonly cliName?: string;
4
+ readonly newVersion?: string;
5
+ readonly otp?: string;
6
+ readonly packageManager?: string;
7
+ readonly private?: boolean;
8
+ readonly quiet?: boolean;
9
+ readonly tag?: string;
10
+ }
11
+ export type PublishCallback = typeof process.exit;
12
+ export declare const publish: (cmd: PublishOptions, callback?: PublishCallback) => Promise<number>;
@@ -0,0 +1,13 @@
1
+ export interface StorybookOptions {
2
+ readonly cliName?: string;
3
+ readonly config?: string;
4
+ readonly open?: boolean;
5
+ readonly port?: number;
6
+ readonly quiet?: boolean;
7
+ readonly static?: boolean;
8
+ readonly useLexConfig?: boolean;
9
+ readonly variables?: string;
10
+ readonly verbose?: boolean;
11
+ }
12
+ export type StorybookCallback = (status: number) => void;
13
+ export declare const storybook: (cmd: StorybookOptions, callback?: StorybookCallback) => Promise<number>;
@@ -1,8 +1,8 @@
1
+ import chalk from "chalk";
1
2
  import { execa } from "execa";
2
3
  import { existsSync } from "fs";
3
4
  import { sync as globSync } from "glob";
4
5
  import { resolve as pathResolve } from "path";
5
- import chalk from "chalk";
6
6
  import { LexConfig } from "../../LexConfig.js";
7
7
  import { createSpinner } from "../../utils/app.js";
8
8
  import { findTailwindCssPath, resolveBinaryPath } from "../../utils/file.js";
@@ -56,9 +56,7 @@ const filterAndBeautifyOutput = (output, isVerbose) => {
56
56
  });
57
57
  return filteredLines.join("\n");
58
58
  };
59
- const beautifyOutput = (output) => {
60
- return output.replace(/Storybook v[\d.]+/g, chalk.cyan("$&")).replace(/info =>/g, chalk.blue("info =>")).replace(/Local:/g, chalk.green("Local:")).replace(/On your network:/g, chalk.green("On your network:")).replace(/Storybook.*started/g, chalk.green("$&")).replace(/Storybook.*ready/g, chalk.green("$&")).replace(/error/g, chalk.red("$&")).replace(/warning/g, chalk.yellow("$&")).replace(/(\d+)%/g, chalk.magenta("$1%"));
61
- };
59
+ const beautifyOutput = (output) => output.replace(/Storybook v[\d.]+/g, chalk.cyan("$&")).replace(/info =>/g, chalk.blue("info =>")).replace(/Local:/g, chalk.green("Local:")).replace(/On your network:/g, chalk.green("On your network:")).replace(/Storybook.*started/g, chalk.green("$&")).replace(/Storybook.*ready/g, chalk.green("$&")).replace(/error/g, chalk.red("$&")).replace(/warning/g, chalk.yellow("$&")).replace(/(\d+)%/g, chalk.magenta("$1%"));
62
60
  const storybook = async (cmd, callback = () => ({})) => {
63
61
  const { cliName = "Lex", config, open = false, port = 6007, quiet, static: staticBuild = false, useLexConfig = false, variables, verbose = false } = cmd;
64
62
  const spinner = createSpinner(quiet);
@@ -248,4 +246,4 @@ ${cliName} Error: ${error.message}`, "error", quiet);
248
246
  export {
249
247
  storybook
250
248
  };
251
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/storybook/storybook.ts"],
  "sourcesContent": ["import {execa} from 'execa';\nimport {existsSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\nimport chalk from 'chalk';\nimport ora from 'ora';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {findTailwindCssPath, resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport interface StorybookOptions {\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly open?: boolean;\n  readonly port?: number;\n  readonly quiet?: boolean;\n  readonly static?: boolean;\n  readonly useLexConfig?: boolean;\n  readonly variables?: string;\n  readonly verbose?: boolean;\n}\n\nexport type StorybookCallback = (status: number) => void;\n\nconst findStoryFiles = (): string[] => {\n  const storyPatterns = [\n    '**/*.stories.{ts,tsx,js,jsx}',\n    '**/*.story.{ts,tsx,js,jsx}',\n    '**/stories/**/*.{ts,tsx,js,jsx}'\n  ];\n\n  const storyFiles: string[] = [];\n\n  storyPatterns.forEach((pattern) => {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/build/**']\n    });\n    storyFiles.push(...files);\n  });\n\n  return storyFiles;\n};\n\nconst checkStorybookInitialization = (): boolean => {\n  const projectConfigDir = pathResolve(process.cwd(), '.storybook');\n  const lexConfigDir = pathResolve(LexConfig.getLexDir(), '.storybook');\n\n  return existsSync(projectConfigDir) || existsSync(lexConfigDir);\n};\n\nconst extractProgressPercentage = (output: string): number | null => {\n  const lines = output.split('\\n');\n  for(const line of lines) {\n    if(line.includes('[webpack.Progress]') && line.includes('%')) {\n      const percentageMatch = line.match(/(\\d+)%/);\n      if(percentageMatch) {\n        return parseInt(percentageMatch[1]);\n      }\n    }\n  }\n  return null;\n};\n\nconst filterAndBeautifyOutput = (output: string, isVerbose: boolean): string => {\n  if(isVerbose) {\n    return output;\n  }\n\n  // Filter out ALL webpack progress lines completely\n  const lines = output.split('\\n');\n  const filteredLines = lines.filter(line => {\n    // Completely filter out ALL webpack progress lines\n    if(line.includes('[webpack.Progress]')) {\n      return false;\n    }\n\n    // Keep important Storybook messages\n    if(line.includes('Storybook') ||\n      line.includes('Local:') ||\n      line.includes('http://localhost') ||\n      line.includes('info =>') ||\n      line.includes('Starting') ||\n      line.includes('ready') ||\n      line.includes('error') ||\n      line.includes('warning')) {\n      return true;\n    }\n\n    return true;\n  });\n\n  return filteredLines.join('\\n');\n};\n\nconst beautifyOutput = (output: string): string => {\n  return output\n    .replace(/Storybook v[\\d.]+/g, chalk.cyan('$&'))\n    .replace(/info =>/g, chalk.blue('info =>'))\n    .replace(/Local:/g, chalk.green('Local:'))\n    .replace(/On your network:/g, chalk.green('On your network:'))\n    .replace(/Storybook.*started/g, chalk.green('$&'))\n    .replace(/Storybook.*ready/g, chalk.green('$&'))\n    .replace(/error/g, chalk.red('$&'))\n    .replace(/warning/g, chalk.yellow('$&'))\n    .replace(/(\\d+)%/g, chalk.magenta('$1%'));\n};\n\nexport const storybook = async (cmd: StorybookOptions, callback: StorybookCallback = () => ({})): Promise<number> => {\n  const {cliName = 'Lex', config, open = false, port = 6007, quiet, static: staticBuild = false, useLexConfig = false, variables, verbose = false} = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(chalk.cyan(`${cliName} starting Storybook...`), 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  let variablesObj: object = {NODE_ENV: 'development'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  spinner.start('Finding story files...');\n  const storyFiles = findStoryFiles();\n\n  if(storyFiles.length === 0) {\n    spinner.fail('No story files found in the project.');\n    log('Please create story files with .stories.ts/.stories.js extensions or in a stories/ directory.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  spinner.succeed(`Found ${storyFiles.length} story file(s)`);\n\n  const tailwindCssPath = findTailwindCssPath();\n\n  console.log({tailwindCssPath});\n  if(tailwindCssPath) {\n    if(!quiet) {\n      log(chalk.green(`\u2713 Tailwind CSS integration detected: ${tailwindCssPath}`), 'info', quiet);\n    }\n  } else {\n    if(!quiet) {\n      log(chalk.yellow('\u26A0 No Tailwind CSS file found in project'), 'info', quiet);\n      log(chalk.gray('Create a tailwind.css file with @tailwind directives for full Tailwind support'), 'info', quiet);\n    }\n  }\n\n  if(!checkStorybookInitialization()) {\n    spinner.fail('Storybook is not initialized in this project or in Lex.');\n    log('Please run \"npx storybook@latest init\" to set up Storybook in your project, or ensure Lex has a valid .storybook configuration.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const projectConfigDir = pathResolve(process.cwd(), '.storybook');\n  const lexConfigDir = pathResolve(LexConfig.getLexDir(), '.storybook');\n\n  let configDir = config;\n  if(!configDir) {\n    configDir = lexConfigDir;\n    if(!useLexConfig && existsSync(projectConfigDir)) {\n      configDir = projectConfigDir;\n    }\n  }\n\n  if(!quiet) {\n    log(chalk.gray(`Project config dir: ${projectConfigDir} (exists: ${existsSync(projectConfigDir)})`), 'info', quiet);\n    log(chalk.gray(`Lex config dir: ${lexConfigDir} (exists: ${existsSync(lexConfigDir)})`), 'info', quiet);\n    if(useLexConfig) {\n      log(chalk.blue('Using Lex Storybook configuration (--use-lex-config flag)'), 'info', quiet);\n    }\n    log(chalk.gray(`Initial config dir: ${configDir}`), 'info', quiet);\n  }\n\n  if(configDir === lexConfigDir) {\n    if(!quiet) {\n      log(chalk.blue('Using Lex config, will create temporary config in project .storybook directory'), 'info', quiet);\n    }\n    const projectStorybookDir = pathResolve(process.cwd(), '.storybook');\n\n    const fs = await import('fs/promises');\n    await fs.mkdir(projectStorybookDir, {recursive: true});\n\n    const lexMainPath = pathResolve(lexConfigDir, 'main.ts');\n    const projectMainPath = pathResolve(projectStorybookDir, 'main.ts');\n    let mainContent = await fs.readFile(lexMainPath, 'utf8');\n\n    mainContent = mainContent.replace(\n      /stories:\\s*\\[.*?\\]/,\n      `stories: ['${pathResolve(process.cwd(), 'src/**/*.stories.@(ts|tsx)')}', '${pathResolve(process.cwd(), 'src/**/*.mdx')}']`\n    );\n\n    const lexNodeModules = pathResolve(LexConfig.getLexDir(), 'node_modules');\n    mainContent = mainContent.replace(\n      /const lexModule = \\(modulePath: string\\) => resolve\\(getLexNodeModulesPath\\(\\), modulePath\\);/,\n      `const lexModule = (modulePath: string) => resolve('${lexNodeModules}', modulePath);`\n    );\n\n    await fs.writeFile(projectMainPath, mainContent);\n\n    const lexPreviewPath = pathResolve(lexConfigDir, 'preview.tsx');\n    if(existsSync(lexPreviewPath)) {\n      const previewContent = await fs.readFile(lexPreviewPath, 'utf8');\n      await fs.writeFile(pathResolve(projectStorybookDir, 'preview.tsx'), previewContent);\n    }\n\n    configDir = projectStorybookDir;\n  }\n  if(!existsSync(configDir)) {\n    spinner.fail('Storybook configuration not found.');\n    log(`Project config: ${projectConfigDir}`, 'info', quiet);\n    log(`Lex config: ${lexConfigDir}`, 'info', quiet);\n    log('Please run \"npx storybook@latest init\" to set up Storybook in your project, or ensure Lex has a valid .storybook configuration.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const storybookPath = resolveBinaryPath('storybook');\n\n  if(!storybookPath) {\n    log(`\\n${cliName} Error: storybook binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your Storybook installation.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const storybookArgs = [staticBuild ? 'build' : 'dev'];\n  storybookArgs.push('--config-dir', configDir);\n\n  if(port) {\n    storybookArgs.push('--port', port.toString());\n  }\n\n  if(open) {\n    storybookArgs.push('--open');\n  }\n\n  if(staticBuild) {\n    const outputDir = pathResolve(process.cwd(), 'storybook-static');\n    storybookArgs.push('--output-dir', outputDir);\n  }\n\n  if(!quiet) {\n    log(chalk.gray(`Config directory: ${configDir}`), 'info', quiet);\n  }\n\n  process.env.TAILWIND_CSS_PATH = tailwindCssPath;\n\n  try {\n    spinner.start(staticBuild ? 'Building static Storybook...' : 'Starting Storybook development server...');\n\n    const storybookProcess = execa(storybookPath as any, storybookArgs, {\n      encoding: 'utf8',\n      env: {\n        ...process.env,\n        LEX_QUIET: quiet,\n        LEX_VERBOSE: verbose,\n        STORYBOOK_OPEN: open,\n        ...(tailwindCssPath && {TAILWIND_CSS_PATH: tailwindCssPath})\n      } as any,\n      stdio: 'pipe'\n    });\n\n    let urlFound = false;\n    let lastProgressPercentage = 0;\n\n    storybookProcess.stdout?.on('data', (data) => {\n      const output = data.toString();\n      const progressPercentage = extractProgressPercentage(output);\n\n      // Update spinner and print beautified progress line if found\n      if(progressPercentage !== null && progressPercentage !== lastProgressPercentage) {\n        lastProgressPercentage = progressPercentage;\n        const action = staticBuild ? 'Building' : 'Starting';\n        (spinner as any).text = `${action} Storybook... ${progressPercentage}%`;\n        // Print beautified progress line\n        process.stdout.write(`\\nWebpack Progress: ${chalk.magenta(`${progressPercentage}%`)}\\n`);\n      }\n\n      const filteredOutput = filterAndBeautifyOutput(output, verbose);\n      const beautifiedOutput = beautifyOutput(filteredOutput);\n\n      if(!urlFound && (output.includes('Local:') || output.includes('http://localhost') || output.includes('Storybook'))) {\n        spinner.succeed(chalk.green('Storybook development server is ready!'));\n        urlFound = true;\n      }\n\n      // Only write filtered output, completely ignoring webpack progress lines\n      if(filteredOutput.trim()) {\n        process.stdout.write(beautifiedOutput);\n      }\n    });\n\n    storybookProcess.stderr?.on('data', (data) => {\n      const output = data.toString();\n      // Also filter stderr to remove webpack progress lines\n      const filteredOutput = filterAndBeautifyOutput(output, verbose);\n      const beautifiedOutput = beautifyOutput(filteredOutput);\n\n      if(filteredOutput.trim()) {\n        process.stderr.write(beautifiedOutput);\n      }\n    });\n\n    // Remove setTimeout fallback. Instead, handle spinner on process exit.\n    try {\n      await storybookProcess;\n      if(!urlFound) {\n        spinner.succeed(chalk.green('Storybook development server started.'));\n      }\n      callback(0);\n      return 0;\n    } catch(error) {\n      spinner.fail(chalk.red('There was an error while running storybook.'));\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('There was an error while running storybook.');\n    callback(1);\n    return 1;\n  }\n};"],
  "mappings": "AAAA,SAAQ,aAAY;AACpB,SAAQ,kBAAiB;AACzB,SAAQ,QAAQ,gBAAe;AAC/B,SAAQ,WAAW,mBAAkB;AACrC,OAAO,WAAW;AAGlB,SAAQ,iBAAgB;AACxB,SAAQ,qBAAoB;AAC5B,SAAQ,qBAAqB,yBAAwB;AACrD,SAAQ,WAAU;AAgBlB,MAAM,iBAAiB,MAAgB;AACrC,QAAM,gBAAgB;AAAA,IACpB;AAAA,IACA;AAAA,IACA;AAAA,EACF;AAEA,QAAM,aAAuB,CAAC;AAE9B,gBAAc,QAAQ,CAAC,YAAY;AACjC,UAAM,QAAQ,SAAS,SAAS;AAAA,MAC9B,KAAK,QAAQ,IAAI;AAAA,MACjB,QAAQ,CAAC,sBAAsB,cAAc,aAAa;AAAA,IAC5D,CAAC;AACD,eAAW,KAAK,GAAG,KAAK;AAAA,EAC1B,CAAC;AAED,SAAO;AACT;AAEA,MAAM,+BAA+B,MAAe;AAClD,QAAM,mBAAmB,YAAY,QAAQ,IAAI,GAAG,YAAY;AAChE,QAAM,eAAe,YAAY,UAAU,UAAU,GAAG,YAAY;AAEpE,SAAO,WAAW,gBAAgB,KAAK,WAAW,YAAY;AAChE;AAEA,MAAM,4BAA4B,CAAC,WAAkC;AACnE,QAAM,QAAQ,OAAO,MAAM,IAAI;AAC/B,aAAU,QAAQ,OAAO;AACvB,QAAG,KAAK,SAAS,oBAAoB,KAAK,KAAK,SAAS,GAAG,GAAG;AAC5D,YAAM,kBAAkB,KAAK,MAAM,QAAQ;AAC3C,UAAG,iBAAiB;AAClB,eAAO,SAAS,gBAAgB,CAAC,CAAC;AAAA,MACpC;AAAA,IACF;AAAA,EACF;AACA,SAAO;AACT;AAEA,MAAM,0BAA0B,CAAC,QAAgB,cAA+B;AAC9E,MAAG,WAAW;AACZ,WAAO;AAAA,EACT;AAGA,QAAM,QAAQ,OAAO,MAAM,IAAI;AAC/B,QAAM,gBAAgB,MAAM,OAAO,UAAQ;AAEzC,QAAG,KAAK,SAAS,oBAAoB,GAAG;AACtC,aAAO;AAAA,IACT;AAGA,QAAG,KAAK,SAAS,WAAW,KAC1B,KAAK,SAAS,QAAQ,KACtB,KAAK,SAAS,kBAAkB,KAChC,KAAK,SAAS,SAAS,KACvB,KAAK,SAAS,UAAU,KACxB,KAAK,SAAS,OAAO,KACrB,KAAK,SAAS,OAAO,KACrB,KAAK,SAAS,SAAS,GAAG;AAC1B,aAAO;AAAA,IACT;AAEA,WAAO;AAAA,EACT,CAAC;AAED,SAAO,cAAc,KAAK,IAAI;AAChC;AAEA,MAAM,iBAAiB,CAAC,WAA2B;AACjD,SAAO,OACJ,QAAQ,sBAAsB,MAAM,KAAK,IAAI,CAAC,EAC9C,QAAQ,YAAY,MAAM,KAAK,SAAS,CAAC,EACzC,QAAQ,WAAW,MAAM,MAAM,QAAQ,CAAC,EACxC,QAAQ,qBAAqB,MAAM,MAAM,kBAAkB,CAAC,EAC5D,QAAQ,uBAAuB,MAAM,MAAM,IAAI,CAAC,EAChD,QAAQ,qBAAqB,MAAM,MAAM,IAAI,CAAC,EAC9C,QAAQ,UAAU,MAAM,IAAI,IAAI,CAAC,EACjC,QAAQ,YAAY,MAAM,OAAO,IAAI,CAAC,EACtC,QAAQ,WAAW,MAAM,QAAQ,KAAK,CAAC;AAC5C;AAEO,MAAM,YAAY,OAAO,KAAuB,WAA8B,OAAO,CAAC,OAAwB;AACnH,QAAM,EAAC,UAAU,OAAO,QAAQ,OAAO,OAAO,OAAO,MAAM,OAAO,QAAQ,cAAc,OAAO,eAAe,OAAO,WAAW,UAAU,MAAK,IAAI;AAEnJ,QAAM,UAAU,cAAc,KAAK;AAEnC,MAAI,MAAM,KAAK,GAAG,OAAO,wBAAwB,GAAG,QAAQ,KAAK;AAEjE,QAAM,UAAU,YAAY,GAAG;AAE/B,MAAI,eAAuB,EAAC,UAAU,cAAa;AAEnD,MAAG,WAAW;AACZ,QAAI;AACF,qBAAe,KAAK,MAAM,SAAS;AAAA,IACrC,SAAQ,QAAQ;AACd,UAAI;AAAA,EAAK,OAAO,oEAAoE,SAAS,KAAK;AAClG,eAAS,CAAC;AACV,aAAO;AAAA,IACT;AAAA,EACF;AAEA,UAAQ,MAAM,EAAC,GAAG,QAAQ,KAAK,GAAG,aAAY;AAE9C,UAAQ,MAAM,wBAAwB;AACtC,QAAM,aAAa,eAAe;AAElC,MAAG,WAAW,WAAW,GAAG;AAC1B,YAAQ,KAAK,sCAAsC;AACnD,QAAI,iGAAiG,QAAQ,KAAK;AAClH,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAEA,UAAQ,QAAQ,SAAS,WAAW,MAAM,gBAAgB;AAE1D,QAAM,kBAAkB,oBAAoB;AAE5C,UAAQ,IAAI,EAAC,gBAAe,CAAC;AAC7B,MAAG,iBAAiB;AAClB,QAAG,CAAC,OAAO;AACT,UAAI,MAAM,MAAM,6CAAwC,eAAe,EAAE,GAAG,QAAQ,KAAK;AAAA,IAC3F;AAAA,EACF,OAAO;AACL,QAAG,CAAC,OAAO;AACT,UAAI,MAAM,OAAO,8CAAyC,GAAG,QAAQ,KAAK;AAC1E,UAAI,MAAM,KAAK,gFAAgF,GAAG,QAAQ,KAAK;AAAA,IACjH;AAAA,EACF;AAEA,MAAG,CAAC,6BAA6B,GAAG;AAClC,YAAQ,KAAK,yDAAyD;AACtE,QAAI,mIAAmI,QAAQ,KAAK;AACpJ,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAEA,QAAM,mBAAmB,YAAY,QAAQ,IAAI,GAAG,YAAY;AAChE,QAAM,eAAe,YAAY,UAAU,UAAU,GAAG,YAAY;AAEpE,MAAI,YAAY;AAChB,MAAG,CAAC,WAAW;AACb,gBAAY;AACZ,QAAG,CAAC,gBAAgB,WAAW,gBAAgB,GAAG;AAChD,kBAAY;AAAA,IACd;AAAA,EACF;AAEA,MAAG,CAAC,OAAO;AACT,QAAI,MAAM,KAAK,uBAAuB,gBAAgB,aAAa,WAAW,gBAAgB,CAAC,GAAG,GAAG,QAAQ,KAAK;AAClH,QAAI,MAAM,KAAK,mBAAmB,YAAY,aAAa,WAAW,YAAY,CAAC,GAAG,GAAG,QAAQ,KAAK;AACtG,QAAG,cAAc;AACf,UAAI,MAAM,KAAK,2DAA2D,GAAG,QAAQ,KAAK;AAAA,IAC5F;AACA,QAAI,MAAM,KAAK,uBAAuB,SAAS,EAAE,GAAG,QAAQ,KAAK;AAAA,EACnE;AAEA,MAAG,cAAc,cAAc;AAC7B,QAAG,CAAC,OAAO;AACT,UAAI,MAAM,KAAK,gFAAgF,GAAG,QAAQ,KAAK;AAAA,IACjH;AACA,UAAM,sBAAsB,YAAY,QAAQ,IAAI,GAAG,YAAY;AAEnE,UAAM,KAAK,MAAM,OAAO,aAAa;AACrC,UAAM,GAAG,MAAM,qBAAqB,EAAC,WAAW,KAAI,CAAC;AAErD,UAAM,cAAc,YAAY,cAAc,SAAS;AACvD,UAAM,kBAAkB,YAAY,qBAAqB,SAAS;AAClE,QAAI,cAAc,MAAM,GAAG,SAAS,aAAa,MAAM;AAEvD,kBAAc,YAAY;AAAA,MACxB;AAAA,MACA,cAAc,YAAY,QAAQ,IAAI,GAAG,4BAA4B,CAAC,OAAO,YAAY,QAAQ,IAAI,GAAG,cAAc,CAAC;AAAA,IACzH;AAEA,UAAM,iBAAiB,YAAY,UAAU,UAAU,GAAG,cAAc;AACxE,kBAAc,YAAY;AAAA,MACxB;AAAA,MACA,sDAAsD,cAAc;AAAA,IACtE;AAEA,UAAM,GAAG,UAAU,iBAAiB,WAAW;AAE/C,UAAM,iBAAiB,YAAY,cAAc,aAAa;AAC9D,QAAG,WAAW,cAAc,GAAG;AAC7B,YAAM,iBAAiB,MAAM,GAAG,SAAS,gBAAgB,MAAM;AAC/D,YAAM,GAAG,UAAU,YAAY,qBAAqB,aAAa,GAAG,cAAc;AAAA,IACpF;AAEA,gBAAY;AAAA,EACd;AACA,MAAG,CAAC,WAAW,SAAS,GAAG;AACzB,YAAQ,KAAK,oCAAoC;AACjD,QAAI,mBAAmB,gBAAgB,IAAI,QAAQ,KAAK;AACxD,QAAI,eAAe,YAAY,IAAI,QAAQ,KAAK;AAChD,QAAI,mIAAmI,QAAQ,KAAK;AACpJ,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB,kBAAkB,WAAW;AAEnD,MAAG,CAAC,eAAe;AACjB,QAAI;AAAA,EAAK,OAAO,6EAA6E,SAAS,KAAK;AAC3G,QAAI,8DAA8D,QAAQ,KAAK;AAC/E,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AAEA,QAAM,gBAAgB,CAAC,cAAc,UAAU,KAAK;AACpD,gBAAc,KAAK,gBAAgB,SAAS;AAE5C,MAAG,MAAM;AACP,kBAAc,KAAK,UAAU,KAAK,SAAS,CAAC;AAAA,EAC9C;AAEA,MAAG,MAAM;AACP,kBAAc,KAAK,QAAQ;AAAA,EAC7B;AAEA,MAAG,aAAa;AACd,UAAM,YAAY,YAAY,QAAQ,IAAI,GAAG,kBAAkB;AAC/D,kBAAc,KAAK,gBAAgB,SAAS;AAAA,EAC9C;AAEA,MAAG,CAAC,OAAO;AACT,QAAI,MAAM,KAAK,qBAAqB,SAAS,EAAE,GAAG,QAAQ,KAAK;AAAA,EACjE;AAEA,UAAQ,IAAI,oBAAoB;AAEhC,MAAI;AACF,YAAQ,MAAM,cAAc,iCAAiC,0CAA0C;AAEvG,UAAM,mBAAmB,MAAM,eAAsB,eAAe;AAAA,MAClE,UAAU;AAAA,MACV,KAAK;AAAA,QACH,GAAG,QAAQ;AAAA,QACX,WAAW;AAAA,QACX,aAAa;AAAA,QACb,gBAAgB;AAAA,QAChB,GAAI,mBAAmB,EAAC,mBAAmB,gBAAe;AAAA,MAC5D;AAAA,MACA,OAAO;AAAA,IACT,CAAC;AAED,QAAI,WAAW;AACf,QAAI,yBAAyB;AAE7B,qBAAiB,QAAQ,GAAG,QAAQ,CAAC,SAAS;AAC5C,YAAM,SAAS,KAAK,SAAS;AAC7B,YAAM,qBAAqB,0BAA0B,MAAM;AAG3D,UAAG,uBAAuB,QAAQ,uBAAuB,wBAAwB;AAC/E,iCAAyB;AACzB,cAAM,SAAS,cAAc,aAAa;AAC1C,QAAC,QAAgB,OAAO,GAAG,MAAM,iBAAiB,kBAAkB;AAEpE,gBAAQ,OAAO,MAAM;AAAA,oBAAuB,MAAM,QAAQ,GAAG,kBAAkB,GAAG,CAAC;AAAA,CAAI;AAAA,MACzF;AAEA,YAAM,iBAAiB,wBAAwB,QAAQ,OAAO;AAC9D,YAAM,mBAAmB,eAAe,cAAc;AAEtD,UAAG,CAAC,aAAa,OAAO,SAAS,QAAQ,KAAK,OAAO,SAAS,kBAAkB,KAAK,OAAO,SAAS,WAAW,IAAI;AAClH,gBAAQ,QAAQ,MAAM,MAAM,wCAAwC,CAAC;AACrE,mBAAW;AAAA,MACb;AAGA,UAAG,eAAe,KAAK,GAAG;AACxB,gBAAQ,OAAO,MAAM,gBAAgB;AAAA,MACvC;AAAA,IACF,CAAC;AAED,qBAAiB,QAAQ,GAAG,QAAQ,CAAC,SAAS;AAC5C,YAAM,SAAS,KAAK,SAAS;AAE7B,YAAM,iBAAiB,wBAAwB,QAAQ,OAAO;AAC9D,YAAM,mBAAmB,eAAe,cAAc;AAEtD,UAAG,eAAe,KAAK,GAAG;AACxB,gBAAQ,OAAO,MAAM,gBAAgB;AAAA,MACvC;AAAA,IACF,CAAC;AAGD,QAAI;AACF,YAAM;AACN,UAAG,CAAC,UAAU;AACZ,gBAAQ,QAAQ,MAAM,MAAM,uCAAuC,CAAC;AAAA,MACtE;AACA,eAAS,CAAC;AACV,aAAO;AAAA,IACT,SAAQ,OAAO;AACb,cAAQ,KAAK,MAAM,IAAI,6CAA6C,CAAC;AACrE,UAAI;AAAA,EAAK,OAAO,WAAW,MAAM,OAAO,IAAI,SAAS,KAAK;AAC1D,eAAS,CAAC;AACV,aAAO;AAAA,IACT;AAAA,EACF,SAAQ,OAAO;AACb,QAAI;AAAA,EAAK,OAAO,WAAW,MAAM,OAAO,IAAI,SAAS,KAAK;AAC1D,YAAQ,KAAK,6CAA6C;AAC1D,aAAS,CAAC;AACV,WAAO;AAAA,EACT;AACF;",
  "names": []
}

249
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/commands/storybook/storybook.ts"],
  "sourcesContent": ["import chalk from 'chalk';\nimport {execa} from 'execa';\nimport {existsSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve} from 'path';\n\nimport {LexConfig} from '../../LexConfig.js';\nimport {createSpinner} from '../../utils/app.js';\nimport {findTailwindCssPath, resolveBinaryPath} from '../../utils/file.js';\nimport {log} from '../../utils/log.js';\n\nexport interface StorybookOptions {\n  readonly cliName?: string;\n  readonly config?: string;\n  readonly open?: boolean;\n  readonly port?: number;\n  readonly quiet?: boolean;\n  readonly static?: boolean;\n  readonly useLexConfig?: boolean;\n  readonly variables?: string;\n  readonly verbose?: boolean;\n}\n\nexport type StorybookCallback = (status: number) => void;\n\nconst findStoryFiles = (): string[] => {\n  const storyPatterns = [\n    '**/*.stories.{ts,tsx,js,jsx}',\n    '**/*.story.{ts,tsx,js,jsx}',\n    '**/stories/**/*.{ts,tsx,js,jsx}'\n  ];\n\n  const storyFiles: string[] = [];\n\n  storyPatterns.forEach((pattern) => {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/build/**']\n    });\n    storyFiles.push(...files);\n  });\n\n  return storyFiles;\n};\n\nconst checkStorybookInitialization = (): boolean => {\n  const projectConfigDir = pathResolve(process.cwd(), '.storybook');\n  const lexConfigDir = pathResolve(LexConfig.getLexDir(), '.storybook');\n\n  return existsSync(projectConfigDir) || existsSync(lexConfigDir);\n};\n\nconst extractProgressPercentage = (output: string): number | null => {\n  const lines = output.split('\\n');\n  for(const line of lines) {\n    if(line.includes('[webpack.Progress]') && line.includes('%')) {\n      const percentageMatch = line.match(/(\\d+)%/);\n      if(percentageMatch) {\n        return parseInt(percentageMatch[1]);\n      }\n    }\n  }\n  return null;\n};\n\nconst filterAndBeautifyOutput = (output: string, isVerbose: boolean): string => {\n  if(isVerbose) {\n    return output;\n  }\n\n  const lines = output.split('\\n');\n  const filteredLines = lines.filter((line) => {\n    if(line.includes('[webpack.Progress]')) {\n      return false;\n    }\n\n    if(line.includes('Storybook') ||\n      line.includes('Local:') ||\n      line.includes('http://localhost') ||\n      line.includes('info =>') ||\n      line.includes('Starting') ||\n      line.includes('ready') ||\n      line.includes('error') ||\n      line.includes('warning')) {\n      return true;\n    }\n\n    return true;\n  });\n\n  return filteredLines.join('\\n');\n};\n\nconst beautifyOutput = (output: string): string => output\n  .replace(/Storybook v[\\d.]+/g, chalk.cyan('$&'))\n  .replace(/info =>/g, chalk.blue('info =>'))\n  .replace(/Local:/g, chalk.green('Local:'))\n  .replace(/On your network:/g, chalk.green('On your network:'))\n  .replace(/Storybook.*started/g, chalk.green('$&'))\n  .replace(/Storybook.*ready/g, chalk.green('$&'))\n  .replace(/error/g, chalk.red('$&'))\n  .replace(/warning/g, chalk.yellow('$&'))\n  .replace(/(\\d+)%/g, chalk.magenta('$1%'));\n\nexport const storybook = async (cmd: StorybookOptions, callback: StorybookCallback = () => ({})): Promise<number> => {\n  const {cliName = 'Lex', config, open = false, port = 6007, quiet, static: staticBuild = false, useLexConfig = false, variables, verbose = false} = cmd;\n\n  const spinner = createSpinner(quiet);\n\n  log(chalk.cyan(`${cliName} starting Storybook...`), 'info', quiet);\n\n  await LexConfig.parseConfig(cmd);\n\n  let variablesObj: object = {NODE_ENV: 'development'};\n\n  if(variables) {\n    try {\n      variablesObj = JSON.parse(variables);\n    } catch(_error) {\n      log(`\\n${cliName} Error: Environment variables option is not a valid JSON object.`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  }\n\n  process.env = {...process.env, ...variablesObj};\n\n  spinner.start('Finding story files...');\n  const storyFiles = findStoryFiles();\n\n  if(storyFiles.length === 0) {\n    spinner.fail('No story files found in the project.');\n    log('Please create story files with .stories.ts/.stories.js extensions or in a stories/ directory.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  spinner.succeed(`Found ${storyFiles.length} story file(s)`);\n\n  const tailwindCssPath = findTailwindCssPath();\n\n  console.log({tailwindCssPath});\n  if(tailwindCssPath) {\n    if(!quiet) {\n      log(chalk.green(`\u2713 Tailwind CSS integration detected: ${tailwindCssPath}`), 'info', quiet);\n    }\n  } else {\n    if(!quiet) {\n      log(chalk.yellow('\u26A0 No Tailwind CSS file found in project'), 'info', quiet);\n      log(chalk.gray('Create a tailwind.css file with @tailwind directives for full Tailwind support'), 'info', quiet);\n    }\n  }\n\n  if(!checkStorybookInitialization()) {\n    spinner.fail('Storybook is not initialized in this project or in Lex.');\n    log('Please run \"npx storybook@latest init\" to set up Storybook in your project, or ensure Lex has a valid .storybook configuration.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const projectConfigDir = pathResolve(process.cwd(), '.storybook');\n  const lexConfigDir = pathResolve(LexConfig.getLexDir(), '.storybook');\n\n  let configDir = config;\n  if(!configDir) {\n    configDir = lexConfigDir;\n    if(!useLexConfig && existsSync(projectConfigDir)) {\n      configDir = projectConfigDir;\n    }\n  }\n\n  if(!quiet) {\n    log(chalk.gray(`Project config dir: ${projectConfigDir} (exists: ${existsSync(projectConfigDir)})`), 'info', quiet);\n    log(chalk.gray(`Lex config dir: ${lexConfigDir} (exists: ${existsSync(lexConfigDir)})`), 'info', quiet);\n    if(useLexConfig) {\n      log(chalk.blue('Using Lex Storybook configuration (--use-lex-config flag)'), 'info', quiet);\n    }\n    log(chalk.gray(`Initial config dir: ${configDir}`), 'info', quiet);\n  }\n\n  if(configDir === lexConfigDir) {\n    if(!quiet) {\n      log(chalk.blue('Using Lex config, will create temporary config in project .storybook directory'), 'info', quiet);\n    }\n    const projectStorybookDir = pathResolve(process.cwd(), '.storybook');\n\n    const fs = await import('fs/promises');\n    await fs.mkdir(projectStorybookDir, {recursive: true});\n\n    const lexMainPath = pathResolve(lexConfigDir, 'main.ts');\n    const projectMainPath = pathResolve(projectStorybookDir, 'main.ts');\n    let mainContent = await fs.readFile(lexMainPath, 'utf8');\n\n    mainContent = mainContent.replace(\n      /stories:\\s*\\[.*?\\]/,\n      `stories: ['${pathResolve(process.cwd(), 'src/**/*.stories.@(ts|tsx)')}', '${pathResolve(process.cwd(), 'src/**/*.mdx')}']`\n    );\n\n    const lexNodeModules = pathResolve(LexConfig.getLexDir(), 'node_modules');\n    mainContent = mainContent.replace(\n      /const lexModule = \\(modulePath: string\\) => resolve\\(getLexNodeModulesPath\\(\\), modulePath\\);/,\n      `const lexModule = (modulePath: string) => resolve('${lexNodeModules}', modulePath);`\n    );\n\n    await fs.writeFile(projectMainPath, mainContent);\n\n    const lexPreviewPath = pathResolve(lexConfigDir, 'preview.tsx');\n    if(existsSync(lexPreviewPath)) {\n      const previewContent = await fs.readFile(lexPreviewPath, 'utf8');\n      await fs.writeFile(pathResolve(projectStorybookDir, 'preview.tsx'), previewContent);\n    }\n\n    configDir = projectStorybookDir;\n  }\n  if(!existsSync(configDir)) {\n    spinner.fail('Storybook configuration not found.');\n    log(`Project config: ${projectConfigDir}`, 'info', quiet);\n    log(`Lex config: ${lexConfigDir}`, 'info', quiet);\n    log('Please run \"npx storybook@latest init\" to set up Storybook in your project, or ensure Lex has a valid .storybook configuration.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const storybookPath = resolveBinaryPath('storybook');\n\n  if(!storybookPath) {\n    log(`\\n${cliName} Error: storybook binary not found in Lex's node_modules or monorepo root`, 'error', quiet);\n    log('Please reinstall Lex or check your Storybook installation.', 'info', quiet);\n    callback(1);\n    return 1;\n  }\n\n  const storybookArgs = [staticBuild ? 'build' : 'dev'];\n  storybookArgs.push('--config-dir', configDir);\n\n  if(port) {\n    storybookArgs.push('--port', port.toString());\n  }\n\n  if(open) {\n    storybookArgs.push('--open');\n  }\n\n  if(staticBuild) {\n    const outputDir = pathResolve(process.cwd(), 'storybook-static');\n    storybookArgs.push('--output-dir', outputDir);\n  }\n\n  if(!quiet) {\n    log(chalk.gray(`Config directory: ${configDir}`), 'info', quiet);\n  }\n\n  process.env.TAILWIND_CSS_PATH = tailwindCssPath;\n\n  try {\n    spinner.start(staticBuild ? 'Building static Storybook...' : 'Starting Storybook development server...');\n\n    const storybookProcess = execa(storybookPath as any, storybookArgs, {\n      encoding: 'utf8',\n      env: {\n        ...process.env,\n        LEX_QUIET: quiet,\n        LEX_VERBOSE: verbose,\n        STORYBOOK_OPEN: open,\n        ...(tailwindCssPath && {TAILWIND_CSS_PATH: tailwindCssPath})\n      } as any,\n      stdio: 'pipe'\n    });\n\n    let urlFound = false;\n    let lastProgressPercentage = 0;\n\n    storybookProcess.stdout?.on('data', (data) => {\n      const output = data.toString();\n      const progressPercentage = extractProgressPercentage(output);\n\n      if(progressPercentage !== null && progressPercentage !== lastProgressPercentage) {\n        lastProgressPercentage = progressPercentage;\n        const action = staticBuild ? 'Building' : 'Starting';\n        (spinner as any).text = `${action} Storybook... ${progressPercentage}%`;\n        process.stdout.write(`\\nWebpack Progress: ${chalk.magenta(`${progressPercentage}%`)}\\n`);\n      }\n\n      const filteredOutput = filterAndBeautifyOutput(output, verbose);\n      const beautifiedOutput = beautifyOutput(filteredOutput);\n\n      if(!urlFound && (output.includes('Local:') || output.includes('http://localhost') || output.includes('Storybook'))) {\n        spinner.succeed(chalk.green('Storybook development server is ready!'));\n        urlFound = true;\n      }\n\n      if(filteredOutput.trim()) {\n        process.stdout.write(beautifiedOutput);\n      }\n    });\n\n    storybookProcess.stderr?.on('data', (data) => {\n      const output = data.toString();\n      const filteredOutput = filterAndBeautifyOutput(output, verbose);\n      const beautifiedOutput = beautifyOutput(filteredOutput);\n\n      if(filteredOutput.trim()) {\n        process.stderr.write(beautifiedOutput);\n      }\n    });\n\n    try {\n      await storybookProcess;\n      if(!urlFound) {\n        spinner.succeed(chalk.green('Storybook development server started.'));\n      }\n      callback(0);\n      return 0;\n    } catch(error) {\n      spinner.fail(chalk.red('There was an error while running storybook.'));\n      log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n      callback(1);\n      return 1;\n    }\n  } catch(error) {\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n    spinner.fail('There was an error while running storybook.');\n    callback(1);\n    return 1;\n  }\n};"],
  "mappings": "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",
  "names": []
}

@@ -0,0 +1,50 @@
1
+ export interface TestOptions {
2
+ readonly analyze?: boolean;
3
+ readonly aiDebug?: boolean;
4
+ readonly aiGenerate?: boolean;
5
+ readonly aiAnalyze?: boolean;
6
+ readonly bail?: boolean;
7
+ readonly changedFilesWithAncestor?: boolean;
8
+ readonly changedSince?: string;
9
+ readonly ci?: boolean;
10
+ readonly cliName?: string;
11
+ readonly collectCoverageFrom?: string;
12
+ readonly colors?: boolean;
13
+ readonly config?: string;
14
+ readonly debug?: boolean;
15
+ readonly debugTests?: boolean;
16
+ readonly detectOpenHandles?: boolean;
17
+ readonly env?: string;
18
+ readonly errorOnDeprecated?: boolean;
19
+ readonly expand?: boolean;
20
+ readonly forceExit?: boolean;
21
+ readonly generate?: boolean;
22
+ readonly json?: boolean;
23
+ readonly lastCommit?: boolean;
24
+ readonly listTests?: boolean;
25
+ readonly logHeapUsage?: boolean;
26
+ readonly maxWorkers?: string;
27
+ readonly noStackTrace?: boolean;
28
+ readonly notify?: boolean;
29
+ readonly onlyChanged?: boolean;
30
+ readonly outputFile?: string;
31
+ readonly passWithNoTests?: boolean;
32
+ readonly quiet?: boolean;
33
+ readonly removeCache?: boolean;
34
+ readonly runInBand?: boolean;
35
+ readonly setup?: string;
36
+ readonly showConfig?: boolean;
37
+ readonly silent?: boolean;
38
+ readonly testLocationInResults?: boolean;
39
+ readonly testNamePattern?: string;
40
+ readonly testPathPattern?: string;
41
+ readonly update?: boolean;
42
+ readonly useStderr?: boolean;
43
+ readonly verbose?: boolean;
44
+ readonly watch?: string;
45
+ readonly watchAll?: boolean;
46
+ }
47
+ export type TestCallback = typeof process.exit;
48
+ export declare const getTestFilePatterns: (testPathPattern?: string) => string[];
49
+ export declare const test: (options: TestOptions, args: string[], callback?: TestCallback) => Promise<number>;
50
+ export default test;