@nlabs/lex 1.48.4 → 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.
- package/.vscode/settings.json +1 -1
- package/README.md +293 -22
- package/__mocks__/compare-versions.js +3 -0
- package/__mocks__/fileMock.js +1 -0
- package/__mocks__/latest-version.js +1 -0
- package/__mocks__/react-markdown.js +12 -0
- package/babel.config.json +2 -1
- package/dist/Button.stories.d.ts +19 -0
- package/dist/LexConfig.d.ts +84 -0
- package/dist/LexConfig.js +1 -4
- package/dist/commands/ai/ai.d.ts +17 -0
- package/dist/commands/ai/index.d.ts +8 -0
- package/dist/commands/build/build.d.ts +18 -0
- package/dist/commands/clean/clean.d.ts +7 -0
- package/dist/commands/compile/compile.d.ts +2 -0
- package/dist/commands/config/config.d.ts +7 -0
- package/dist/commands/config/config.js +2 -2
- package/dist/commands/copy/copy.d.ts +6 -0
- package/dist/commands/create/create.d.ts +8 -0
- package/dist/commands/dev/dev.d.ts +11 -0
- package/dist/commands/init/init.d.ts +9 -0
- package/dist/commands/link/link.d.ts +6 -0
- package/dist/commands/lint/autofix.d.ts +2 -0
- package/dist/commands/lint/lint.d.ts +39 -0
- package/dist/commands/migrate/migrate.d.ts +7 -0
- package/dist/commands/publish/publish.d.ts +12 -0
- package/dist/commands/storybook/storybook.d.ts +13 -0
- package/dist/commands/storybook/storybook.js +3 -5
- package/dist/commands/test/test.d.ts +50 -0
- package/dist/commands/test/test.js +80 -10
- package/dist/commands/update/update.d.ts +9 -0
- package/dist/commands/upgrade/upgrade.d.ts +7 -0
- package/dist/commands/versions/versions.d.ts +13 -0
- package/dist/create/changelog.d.ts +6 -0
- package/dist/index.d.ts +33 -0
- package/dist/index.js +2 -1
- package/dist/lex.d.ts +2 -0
- package/dist/test-react/index.d.ts +8 -0
- package/dist/test-react/index.js +86 -0
- package/dist/types.d.ts +5 -0
- package/dist/utils/aiService.d.ts +9 -0
- package/dist/utils/app.d.ts +45 -0
- package/dist/utils/file.d.ts +8 -0
- package/dist/utils/file.js +9 -3
- package/dist/utils/log.d.ts +1 -0
- package/dist/utils/reactShim.d.ts +4 -0
- package/dist/utils/reactShim.js +82 -2
- package/jest.config.d.mts +50 -0
- package/jest.config.mjs +69 -0
- package/jest.config.template.cjs +63 -0
- package/jest.setup.js +18 -15
- package/jest.setup.template.js +18 -0
- package/package.json +24 -7
- package/tsconfig.build.json +8 -10
- package/tsconfig.lint.json +2 -2
- package/tsconfig.test.json +2 -2
- package/dist/dist/LexConfig.d.ts +0 -119
- package/dist/dist/utils/file.d.ts +0 -8
- package/dist/dist/utils/log.d.ts +0 -1
- package/dist/jest.config.lex.d.ts +0 -2
- package/jest.config.cjs +0 -43
- package/jest.config.lex.js +0 -118
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export interface UpgradeOptions {
|
|
2
|
+
readonly cliName?: string;
|
|
3
|
+
readonly cliPackage?: string;
|
|
4
|
+
readonly quiet?: boolean;
|
|
5
|
+
}
|
|
6
|
+
export type UpgradeCallback = typeof process.exit;
|
|
7
|
+
export declare const upgrade: (cmd: UpgradeOptions, callback?: UpgradeCallback) => Promise<number>;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export declare const parseVersion: (packageVersion: string) => string;
|
|
2
|
+
export declare const packages: {
|
|
3
|
+
esbuild: string;
|
|
4
|
+
jest: string;
|
|
5
|
+
lex: any;
|
|
6
|
+
typescript: string;
|
|
7
|
+
webpack: string;
|
|
8
|
+
};
|
|
9
|
+
export declare const jsonVersions: (lexPackages: any) => {};
|
|
10
|
+
export interface VersionsCmd {
|
|
11
|
+
readonly json?: boolean;
|
|
12
|
+
}
|
|
13
|
+
export declare const versions: (cmd: VersionsCmd, callback: (status: number) => void) => Promise<number>;
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,33 @@
|
|
|
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 type { LexConfigType } from './LexConfig.js';
|
|
6
|
+
export * from './types.js';
|
|
7
|
+
export { defaultConfigValues, LexConfig } from './LexConfig.js';
|
|
8
|
+
export declare const Config: {
|
|
9
|
+
create: (config: LexConfigType) => LexConfigType;
|
|
10
|
+
};
|
|
11
|
+
export * from './utils/aiService.js';
|
|
12
|
+
export * from './utils/app.js';
|
|
13
|
+
export * from './utils/file.js';
|
|
14
|
+
export * from './utils/log.js';
|
|
15
|
+
export * from './utils/reactShim.js';
|
|
16
|
+
export * from './commands/ai/ai.js';
|
|
17
|
+
export * from './commands/build/build.js';
|
|
18
|
+
export * from './commands/clean/clean.js';
|
|
19
|
+
export * from './commands/compile/compile.js';
|
|
20
|
+
export * from './commands/config/config.js';
|
|
21
|
+
export * from './commands/copy/copy.js';
|
|
22
|
+
export * from './commands/create/create.js';
|
|
23
|
+
export * from './commands/dev/dev.js';
|
|
24
|
+
export * from './commands/init/init.js';
|
|
25
|
+
export * from './commands/link/link.js';
|
|
26
|
+
export * from './commands/lint/lint.js';
|
|
27
|
+
export * from './commands/migrate/migrate.js';
|
|
28
|
+
export * from './commands/publish/publish.js';
|
|
29
|
+
export * from './commands/storybook/storybook.js';
|
|
30
|
+
export * from './commands/test/test.js';
|
|
31
|
+
export * from './commands/update/update.js';
|
|
32
|
+
export * from './commands/upgrade/upgrade.js';
|
|
33
|
+
export * from './commands/versions/versions.js';
|
package/dist/index.js
CHANGED
|
@@ -10,6 +10,7 @@ export * from "./utils/aiService.js";
|
|
|
10
10
|
export * from "./utils/app.js";
|
|
11
11
|
export * from "./utils/file.js";
|
|
12
12
|
export * from "./utils/log.js";
|
|
13
|
+
export * from "./utils/reactShim.js";
|
|
13
14
|
export * from "./commands/ai/ai.js";
|
|
14
15
|
export * from "./commands/build/build.js";
|
|
15
16
|
export * from "./commands/clean/clean.js";
|
|
@@ -33,4 +34,4 @@ export {
|
|
|
33
34
|
LexConfig,
|
|
34
35
|
defaultConfigValues
|
|
35
36
|
};
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7TGV4Q29uZmlnVHlwZX0gZnJvbSAnLi9MZXhDb25maWcuanMnO1xuXG4vLyBFeHBvcnQgdHlwZXMgZnJvbSB0eXBlcy50c1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy5qcyc7XG5cbi8vIEV4cG9ydCBjbGFzc2VzIGFuZCB2YWx1ZXMgZnJvbSBMZXhDb25maWdcbmV4cG9ydCB7XG4gIGRlZmF1bHRDb25maWdWYWx1ZXMsIExleENvbmZpZ1xufSBmcm9tICcuL0xleENvbmZpZy5qcyc7XG5cbi8vIEV4cG9ydCBDb25maWcgYXMgYm90aCBhIHR5cGUgYW5kIGEgbmFtZXNwYWNlIHdpdGggY3JlYXRlIG1ldGhvZCBmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eVxuZXhwb3J0IGNvbnN0IENvbmZpZyA9IHtcbiAgY3JlYXRlOiAoY29uZmlnOiBMZXhDb25maWdUeXBlKSA9PiBjb25maWdcbn07XG5cbi8vIEV4cG9ydCB1dGlsaXR5IGZ1bmN0aW9uc1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9haVNlcnZpY2UuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9hcHAuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9maWxlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvbG9nLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvcmVhY3RTaGltLmpzJztcblxuLy8gRXhwb3J0IGNvbW1hbmRzXG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2FpL2FpLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvYnVpbGQvYnVpbGQuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jbGVhbi9jbGVhbi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbXBpbGUvY29tcGlsZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbmZpZy9jb25maWcuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jb3B5L2NvcHkuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jcmVhdGUvY3JlYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvZGV2L2Rldi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2luaXQvaW5pdC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbmsvbGluay5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbnQvbGludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL21pZ3JhdGUvbWlncmF0ZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3B1Ymxpc2gvcHVibGlzaC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3N0b3J5Ym9vay9zdG9yeWJvb2suanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy90ZXN0L3Rlc3QuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy91cGRhdGUvdXBkYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdXBncmFkZS91cGdyYWRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdmVyc2lvbnMvdmVyc2lvbnMuanMnO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBUUEsY0FBYztBQUdkO0FBQUEsRUFDRTtBQUFBLEVBQXFCO0FBQUEsT0FDaEI7QUFHQSxNQUFNLFNBQVM7QUFBQSxFQUNwQixRQUFRLENBQUMsV0FBMEI7QUFDckM7QUFHQSxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUdkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYzsiLAogICJuYW1lcyI6IFtdCn0K
|
package/dist/lex.d.ts
ADDED
|
@@ -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 '@testing-library/jest-dom';
|
|
6
|
+
import * as react from 'react';
|
|
7
|
+
export { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup } from '@testing-library/react';
|
|
8
|
+
export { react };
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import "@testing-library/jest-dom";
|
|
2
|
+
import * as react from "react";
|
|
3
|
+
import {
|
|
4
|
+
render,
|
|
5
|
+
screen,
|
|
6
|
+
fireEvent,
|
|
7
|
+
waitFor,
|
|
8
|
+
waitForElementToBeRemoved,
|
|
9
|
+
within,
|
|
10
|
+
getByRole,
|
|
11
|
+
getByLabelText,
|
|
12
|
+
getByPlaceholderText,
|
|
13
|
+
getByText,
|
|
14
|
+
getByTestId,
|
|
15
|
+
getAllByRole,
|
|
16
|
+
getAllByLabelText,
|
|
17
|
+
getAllByPlaceholderText,
|
|
18
|
+
getAllByText,
|
|
19
|
+
getAllByTestId,
|
|
20
|
+
queryByRole,
|
|
21
|
+
queryByLabelText,
|
|
22
|
+
queryByPlaceholderText,
|
|
23
|
+
queryByText,
|
|
24
|
+
queryByTestId,
|
|
25
|
+
queryAllByRole,
|
|
26
|
+
queryAllByLabelText,
|
|
27
|
+
queryAllByPlaceholderText,
|
|
28
|
+
queryAllByText,
|
|
29
|
+
queryAllByTestId,
|
|
30
|
+
findByRole,
|
|
31
|
+
findByLabelText,
|
|
32
|
+
findByPlaceholderText,
|
|
33
|
+
findByText,
|
|
34
|
+
findByTestId,
|
|
35
|
+
findAllByRole,
|
|
36
|
+
findAllByLabelText,
|
|
37
|
+
findAllByPlaceholderText,
|
|
38
|
+
findAllByText,
|
|
39
|
+
findAllByTestId,
|
|
40
|
+
renderHook,
|
|
41
|
+
act,
|
|
42
|
+
cleanup
|
|
43
|
+
} from "@testing-library/react";
|
|
44
|
+
export {
|
|
45
|
+
act,
|
|
46
|
+
cleanup,
|
|
47
|
+
findAllByLabelText,
|
|
48
|
+
findAllByPlaceholderText,
|
|
49
|
+
findAllByRole,
|
|
50
|
+
findAllByTestId,
|
|
51
|
+
findAllByText,
|
|
52
|
+
findByLabelText,
|
|
53
|
+
findByPlaceholderText,
|
|
54
|
+
findByRole,
|
|
55
|
+
findByTestId,
|
|
56
|
+
findByText,
|
|
57
|
+
fireEvent,
|
|
58
|
+
getAllByLabelText,
|
|
59
|
+
getAllByPlaceholderText,
|
|
60
|
+
getAllByRole,
|
|
61
|
+
getAllByTestId,
|
|
62
|
+
getAllByText,
|
|
63
|
+
getByLabelText,
|
|
64
|
+
getByPlaceholderText,
|
|
65
|
+
getByRole,
|
|
66
|
+
getByTestId,
|
|
67
|
+
getByText,
|
|
68
|
+
queryAllByLabelText,
|
|
69
|
+
queryAllByPlaceholderText,
|
|
70
|
+
queryAllByRole,
|
|
71
|
+
queryAllByTestId,
|
|
72
|
+
queryAllByText,
|
|
73
|
+
queryByLabelText,
|
|
74
|
+
queryByPlaceholderText,
|
|
75
|
+
queryByRole,
|
|
76
|
+
queryByTestId,
|
|
77
|
+
queryByText,
|
|
78
|
+
react,
|
|
79
|
+
render,
|
|
80
|
+
renderHook,
|
|
81
|
+
screen,
|
|
82
|
+
waitFor,
|
|
83
|
+
waitForElementToBeRemoved,
|
|
84
|
+
within
|
|
85
|
+
};
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3Rlc3QtcmVhY3QvaW5kZXgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbIi8qKlxuICogQ29weXJpZ2h0IChjKSAyMDE4LVByZXNlbnQsIE5pdHJvZ2VuIExhYnMsIEluYy5cbiAqIENvcHlyaWdodHMgbGljZW5zZWQgdW5kZXIgdGhlIE1JVCBMaWNlbnNlLiBTZWUgdGhlIGFjY29tcGFueWluZyBMSUNFTlNFIGZpbGUgZm9yIHRlcm1zLlxuICovXG5pbXBvcnQgJ0B0ZXN0aW5nLWxpYnJhcnkvamVzdC1kb20nO1xuXG4vLyBSZS1leHBvcnQgUmVhY3QgdGVzdGluZyB1dGlsaXRpZXMgd2l0aG91dCBhbnkgTGV4IGRlcGVuZGVuY2llc1xuLy8gRXhwb3J0IFJlYWN0IGZvciBjb252ZW5pZW5jZVxuaW1wb3J0ICogYXMgcmVhY3QgZnJvbSAncmVhY3QnO1xuXG5leHBvcnQge1xuICByZW5kZXIsXG4gIHNjcmVlbixcbiAgZmlyZUV2ZW50LFxuICB3YWl0Rm9yLFxuICB3YWl0Rm9yRWxlbWVudFRvQmVSZW1vdmVkLFxuICB3aXRoaW4sXG4gIGdldEJ5Um9sZSxcbiAgZ2V0QnlMYWJlbFRleHQsXG4gIGdldEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBnZXRCeVRleHQsXG4gIGdldEJ5VGVzdElkLFxuICBnZXRBbGxCeVJvbGUsXG4gIGdldEFsbEJ5TGFiZWxUZXh0LFxuICBnZXRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QWxsQnlUZXh0LFxuICBnZXRBbGxCeVRlc3RJZCxcbiAgcXVlcnlCeVJvbGUsXG4gIHF1ZXJ5QnlMYWJlbFRleHQsXG4gIHF1ZXJ5QnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QnlUZXh0LFxuICBxdWVyeUJ5VGVzdElkLFxuICBxdWVyeUFsbEJ5Um9sZSxcbiAgcXVlcnlBbGxCeUxhYmVsVGV4dCxcbiAgcXVlcnlBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgcXVlcnlBbGxCeVRleHQsXG4gIHF1ZXJ5QWxsQnlUZXN0SWQsXG4gIGZpbmRCeVJvbGUsXG4gIGZpbmRCeUxhYmVsVGV4dCxcbiAgZmluZEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBmaW5kQnlUZXh0LFxuICBmaW5kQnlUZXN0SWQsXG4gIGZpbmRBbGxCeVJvbGUsXG4gIGZpbmRBbGxCeUxhYmVsVGV4dCxcbiAgZmluZEFsbEJ5UGxhY2Vob2xkZXJUZXh0LFxuICBmaW5kQWxsQnlUZXh0LFxuICBmaW5kQWxsQnlUZXN0SWQsXG4gIHJlbmRlckhvb2ssXG4gIGFjdCxcbiAgY2xlYW51cFxufSBmcm9tICdAdGVzdGluZy1saWJyYXJ5L3JlYWN0JztcbmV4cG9ydCB7cmVhY3R9OyJdLAogICJtYXBwaW5ncyI6ICJBQUlBLE9BQU87QUFJUCxZQUFZLFdBQVc7QUFFdkI7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxPQUNLOyIsCiAgIm5hbWVzIjogW10KfQo=
|
package/dist/types.d.ts
ADDED
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AIConfig } from '../LexConfig.js';
|
|
2
|
+
export declare const callCursorAI: (prompt: string, options: AIConfig) => Promise<string>;
|
|
3
|
+
export declare const callOpenAIAI: (prompt: string, options: AIConfig) => Promise<string>;
|
|
4
|
+
export declare const callAnthropicAI: (prompt: string, options: AIConfig) => Promise<string>;
|
|
5
|
+
export declare const callCopilotAI: (prompt: string, options: AIConfig) => Promise<string>;
|
|
6
|
+
export declare const promptForAIProvider: (quiet?: boolean) => Promise<"cursor" | "copilot" | "openai" | "anthropic" | "none">;
|
|
7
|
+
export declare const promptForAPIKey: (provider: string, quiet?: boolean) => Promise<string>;
|
|
8
|
+
export declare const getAIService: (provider: string, options: AIConfig) => (prompt: string, options: AIConfig) => Promise<string>;
|
|
9
|
+
export declare const callAIService: (prompt: string, quiet?: boolean) => Promise<string>;
|
|
@@ -0,0 +1,45 @@
|
|
|
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 type { LexConfigType } from '../LexConfig.js';
|
|
6
|
+
export declare const cwd: string;
|
|
7
|
+
export interface GetFilenamesProps {
|
|
8
|
+
readonly callback?: (status: number) => void;
|
|
9
|
+
readonly cliName?: string;
|
|
10
|
+
readonly name?: string;
|
|
11
|
+
readonly quiet?: boolean;
|
|
12
|
+
readonly type?: string;
|
|
13
|
+
readonly useTypescript?: boolean;
|
|
14
|
+
}
|
|
15
|
+
interface FilenamesResult {
|
|
16
|
+
nameCaps: string;
|
|
17
|
+
templateExt: string;
|
|
18
|
+
templatePath: string;
|
|
19
|
+
templateReact: string;
|
|
20
|
+
}
|
|
21
|
+
export declare const getFilenames: (props: GetFilenamesProps) => FilenamesResult | void;
|
|
22
|
+
export interface Spinner {
|
|
23
|
+
fail: (text?: string) => void;
|
|
24
|
+
start: (text?: string) => void;
|
|
25
|
+
succeed: (text?: string) => void;
|
|
26
|
+
}
|
|
27
|
+
export declare const createSpinner: (quiet?: boolean) => Spinner;
|
|
28
|
+
export declare const copyFiles: (files: string[], typeName: string, spinner: any, config: LexConfigType) => Promise<void>;
|
|
29
|
+
export declare const copyConfiguredFiles: (spinner: any, config: LexConfigType, quiet: boolean) => Promise<void>;
|
|
30
|
+
export declare const copyFileSync: (source: string, target: string) => void;
|
|
31
|
+
export declare const copyFolderRecursiveSync: (source: string, target: string) => void;
|
|
32
|
+
export declare const getPackageJson: (packagePath?: string) => any;
|
|
33
|
+
export declare const getFilesByExt: (ext: string, config: LexConfigType) => string[];
|
|
34
|
+
export declare const removeConflictModules: (moduleList: object) => object;
|
|
35
|
+
export declare const removeFiles: (fileName: string, isRelative?: boolean) => Promise<unknown>;
|
|
36
|
+
export declare const removeModules: () => Promise<unknown>;
|
|
37
|
+
export declare const setPackageJson: (json: any, packagePath?: string) => void;
|
|
38
|
+
export interface LinkedModuleType {
|
|
39
|
+
readonly name: string;
|
|
40
|
+
readonly path: string;
|
|
41
|
+
}
|
|
42
|
+
export declare const linkedModules: (startPath?: string) => LinkedModuleType[];
|
|
43
|
+
export declare const checkLinkedModules: () => void;
|
|
44
|
+
export declare const updateTemplateName: (filePath: string, replace: string, replaceCaps: string) => void;
|
|
45
|
+
export {};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export declare function getDirName(): string;
|
|
2
|
+
export declare function getFilePath(relativePath: string): string;
|
|
3
|
+
export declare function getLexPackageJsonPath(): string;
|
|
4
|
+
export declare const relativeFilePath: (filename: string, dirPath?: string, backUp?: number) => string;
|
|
5
|
+
export declare const relativeNodePath: (filename: string, dirPath?: string, backUp?: number) => string;
|
|
6
|
+
export declare const getNodePath: (moduleName: string) => string;
|
|
7
|
+
export declare const resolveBinaryPath: (binaryName: string, packageName?: string) => string;
|
|
8
|
+
export declare const findTailwindCssPath: () => string;
|
package/dist/utils/file.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import findFileUp from "find-file-up";
|
|
2
2
|
import { existsSync, readFileSync } from "fs";
|
|
3
|
-
import { resolve as pathResolve, dirname } from "path";
|
|
4
3
|
import { sync as globSync } from "glob";
|
|
4
|
+
import { resolve as pathResolve, dirname } from "path";
|
|
5
5
|
import { LexConfig } from "../LexConfig.js";
|
|
6
6
|
function getDirName() {
|
|
7
7
|
try {
|
|
@@ -22,6 +22,10 @@ function getFilePath(relativePath) {
|
|
|
22
22
|
}
|
|
23
23
|
function getLexPackageJsonPath() {
|
|
24
24
|
const LEX_PACKAGE_NAME = "@nlabs/lex";
|
|
25
|
+
const lexInNodeModules = pathResolve(process.cwd(), "node_modules/@nlabs/lex/package.json");
|
|
26
|
+
if (existsSync(lexInNodeModules)) {
|
|
27
|
+
return lexInNodeModules;
|
|
28
|
+
}
|
|
25
29
|
let startDir;
|
|
26
30
|
if (process.env.LEX_ROOT) {
|
|
27
31
|
startDir = process.env.LEX_ROOT;
|
|
@@ -60,7 +64,9 @@ function getLexPackageJsonPath() {
|
|
|
60
64
|
}
|
|
61
65
|
}
|
|
62
66
|
const parent = dirname(dir);
|
|
63
|
-
if (parent === dir)
|
|
67
|
+
if (parent === dir) {
|
|
68
|
+
break;
|
|
69
|
+
}
|
|
64
70
|
dir = parent;
|
|
65
71
|
}
|
|
66
72
|
return pathResolve(process.cwd(), "package.json");
|
|
@@ -176,4 +182,4 @@ export {
|
|
|
176
182
|
relativeNodePath,
|
|
177
183
|
resolveBinaryPath
|
|
178
184
|
};
|
|
179
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/utils/file.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport findFileUp from 'find-file-up';\nimport {existsSync, readFileSync} from 'fs';\nimport {resolve as pathResolve, dirname} from 'path';\nimport {sync as globSync} from 'glob';\n\n\nimport {LexConfig} from '../LexConfig.js';\n\n/**\n * Safely get directory name that works in both ESM and Jest environments\n */\nexport function getDirName(): string {\n  try {\n    // Only works in ESM environments\n    // eslint-disable-next-line no-eval\n    return eval('new URL(\".\", import.meta.url).pathname');\n  } catch {\n    // Fallback for Jest or CJS\n    return process.cwd();\n  }\n}\n\n/**\n * Safely get file path that works in both ESM and Jest environments\n */\nexport function getFilePath(relativePath: string): string {\n  try {\n    // Only works in ESM environments\n    // eslint-disable-next-line no-eval\n    return eval('require(\"url\").fileURLToPath(new URL(relativePath, import.meta.url))');\n  } catch {\n    // Fallback for Jest or CJS\n    if(relativePath === '../../../package.json') {\n      return pathResolve(process.cwd(), 'package.json');\n    }\n    return pathResolve(process.cwd(), relativePath);\n  }\n}\n\n/**\n * Get the path to Lex's own package.json, regardless of CWD\n */\nexport function getLexPackageJsonPath(): string {\n  const LEX_PACKAGE_NAME = '@nlabs/lex';\n  let startDir: string;\n\n  if(process.env.LEX_ROOT) {\n    startDir = process.env.LEX_ROOT;\n  } else {\n    // Try multiple approaches to get the Lex CLI's directory\n    try {\n      // Approach 1: ESM import.meta.url\n      startDir = eval('new URL(\".\", import.meta.url).pathname');\n    } catch(err1) {\n      try {\n        // Approach 2: CJS __filename (if available)\n        startDir = eval('__filename ? require(\"path\").dirname(__filename) : null');\n        if(!startDir) {\n          throw new Error('__filename not available');\n        }\n      } catch(err2) {\n        try {\n          // Approach 3: Use process.argv[1] (the actual script being executed)\n          if(process.argv[1] && !process.argv[1].includes('node')) {\n            startDir = dirname(process.argv[1]);\n          } else {\n            throw new Error('process.argv[1] not suitable');\n          }\n        } catch(err3) {\n          // Approach 4: Fallback to process.cwd()\n          startDir = process.cwd();\n        }\n      }\n    }\n  }\n\n  let dir = startDir;\n  for(let i = 0; i < 8; i++) {\n    const pkgPath = pathResolve(dir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n        if(pkg.name === LEX_PACKAGE_NAME) {\n          return pkgPath;\n        }\n      } catch(error) {\n        // Silently continue if package.json can't be read\n      }\n    }\n    const parent = dirname(dir);\n    if(parent === dir) break;\n    dir = parent;\n  }\n  // Fallback to process.cwd() as last resort\n  return pathResolve(process.cwd(), 'package.json');\n}\n\n// Get file paths relative to Lex\nexport const relativeFilePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(filename, dirPath, nestDepth);\n    const previousPath: string = Array(backUp).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(filename, dirPath, nestDepth);\n};\n\nexport const relativeNodePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n  const modulePath = `node_modules/${filename}`;\n\n  // First, check the Lex package's node_modules directory\n  if(dirPath !== './') {\n    const lexModulePath = pathResolve(dirPath, modulePath);\n    if(existsSync(lexModulePath)) {\n      return lexModulePath;\n    }\n  }\n\n  // Second, check the user's project node_modules directory\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  // Original implementation as fallback\n  if(backUp) {\n    const filePath: string = findFileUp.sync(modulePath, dirPath, nestDepth);\n    const previousPath: string = Array(nestDepth).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(modulePath, dirPath, nestDepth) || `/node_modules/${filename}`;\n};\n\n// Get file paths relative to Lex\nexport const getNodePath = (moduleName: string): string => {\n  const dirName = getDirName();\n  const modulePath: string = `node_modules/${moduleName}`;\n\n  // Try project root first\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  // Then try module local to Lex\n  const repoPath: string = findFileUp.sync(modulePath, dirName);\n  if(repoPath && existsSync(repoPath)) {\n    return repoPath;\n  }\n\n  // Fallback to general search\n  const localPath: string = findFileUp.sync(modulePath, './', 10) || `./${modulePath}`;\n  return localPath;\n};\n\n/**\n * Resolve binary path with fallback logic for monorepo and package scenarios\n * Checks: 1) Lex's node_modules/.bin/, 2) Lex's node_modules/<package>/bin/, 3) Monorepo root node_modules/.bin/ (from process.cwd()), 4) Monorepo root node_modules/.bin/ (from Lex's dir)\n */\nexport const resolveBinaryPath = (binaryName: string, packageName?: string): string => {\n  const lexDir = LexConfig.getLexDir();\n\n  // 1. Check Lex's node_modules/.bin/\n  const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);\n  if(existsSync(lexBinPath)) {\n    return lexBinPath;\n  }\n\n  // 2. Check Lex's node_modules/<package>/bin/ (if packageName provided)\n  if(packageName) {\n    const lexPackageBinPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}`);\n    if(existsSync(lexPackageBinPath)) {\n      return lexPackageBinPath;\n    }\n\n    // Also check for .js extension\n    const lexPackageBinJsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.js`);\n    if(existsSync(lexPackageBinJsPath)) {\n      return lexPackageBinJsPath;\n    }\n\n    // Check for .cjs extension\n    const lexPackageBinCjsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.cjs`);\n    if(existsSync(lexPackageBinCjsPath)) {\n      return lexPackageBinCjsPath;\n    }\n  }\n\n  // 3. Walk up from process.cwd() and check node_modules/.bin/\n  const checkBinUp = (startDir: string) => {\n    let checkDir = startDir;\n    for(let i = 0; i < 5; i++) {\n      const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);\n      if(existsSync(monorepoBinPath)) {\n        return monorepoBinPath;\n      }\n      const parentDir = pathResolve(checkDir, '..');\n      if(parentDir === checkDir) {\n        break;\n      }\n      checkDir = parentDir;\n    }\n    return '';\n  };\n\n  // 3a. Walk up from process.cwd()\n  const fromCwd = checkBinUp(process.cwd());\n  if(fromCwd) {\n    return fromCwd;\n  }\n\n  // 3b. Walk up from Lex's directory\n  const fromLex = checkBinUp(lexDir);\n  if(fromLex) {\n    return fromLex;\n  }\n\n  // Not found\n  return '';\n};\n\nexport const findTailwindCssPath = (): string => {\n  const tailwindPatterns = ['**/tailwind.css'];\n\n  for(const pattern of tailwindPatterns) {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/build/**', '**/.storybook/**']\n    });\n\n    if(files.length > 0) {\n      return pathResolve(process.cwd(), files[0]);\n    }\n  }\n\n  return '';\n};"],
  "mappings": "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",
  "names": ["startDir"]
}

|
|
185
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/utils/file.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport findFileUp from 'find-file-up';\nimport {existsSync, readFileSync} from 'fs';\nimport {sync as globSync} from 'glob';\nimport {resolve as pathResolve, dirname} from 'path';\n\nimport {LexConfig} from '../LexConfig.js';\n\nexport function getDirName(): string {\n  try {\n    return eval('new URL(\".\", import.meta.url).pathname');\n  } catch{\n    return process.cwd();\n  }\n}\n\nexport function getFilePath(relativePath: string): string {\n  try {\n    return eval('require(\"url\").fileURLToPath(new URL(relativePath, import.meta.url))');\n  } catch{\n    if(relativePath === '../../../package.json') {\n      return pathResolve(process.cwd(), 'package.json');\n    }\n    return pathResolve(process.cwd(), relativePath);\n  }\n}\n\nexport function getLexPackageJsonPath(): string {\n  const LEX_PACKAGE_NAME = '@nlabs/lex';\n\n  const lexInNodeModules = pathResolve(process.cwd(), 'node_modules/@nlabs/lex/package.json');\n\n  if(existsSync(lexInNodeModules)) {\n    return lexInNodeModules;\n  }\n\n  let startDir: string;\n\n  if(process.env.LEX_ROOT) {\n    startDir = process.env.LEX_ROOT;\n  } else {\n    try {\n      startDir = eval('new URL(\".\", import.meta.url).pathname');\n    } catch(err1) {\n      try {\n        startDir = eval('__filename ? require(\"path\").dirname(__filename) : null');\n        if(!startDir) {\n          throw new Error('__filename not available');\n        }\n      } catch(err2) {\n        try {\n          if(process.argv[1] && !process.argv[1].includes('node')) {\n            startDir = dirname(process.argv[1]);\n          } else {\n            throw new Error('process.argv[1] not suitable');\n          }\n        } catch(err3) {\n          startDir = process.cwd();\n        }\n      }\n    }\n  }\n\n  let dir = startDir;\n  for(let i = 0; i < 8; i++) {\n    const pkgPath = pathResolve(dir, 'package.json');\n    if(existsSync(pkgPath)) {\n      try {\n        const pkg = JSON.parse(readFileSync(pkgPath, 'utf8'));\n        if(pkg.name === LEX_PACKAGE_NAME) {\n          return pkgPath;\n        }\n      } catch(error) {\n      }\n    }\n    const parent = dirname(dir);\n    if(parent === dir) {\n      break;\n    }\n    dir = parent;\n  }\n\n  return pathResolve(process.cwd(), 'package.json');\n}\n\nexport const relativeFilePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(filename, dirPath, nestDepth);\n    const previousPath: string = Array(backUp).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(filename, dirPath, nestDepth);\n};\n\nexport const relativeNodePath = (filename: string, dirPath: string = './', backUp: number = 0): string => {\n  const nestDepth: number = 10;\n  const modulePath = `node_modules/${filename}`;\n\n  if(dirPath !== './') {\n    const lexModulePath = pathResolve(dirPath, modulePath);\n    if(existsSync(lexModulePath)) {\n      return lexModulePath;\n    }\n  }\n\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  if(backUp) {\n    const filePath: string = findFileUp.sync(modulePath, dirPath, nestDepth);\n    const previousPath: string = Array(nestDepth).fill(null).map(() => '../').join('');\n    return pathResolve(filePath, previousPath);\n  }\n\n  return findFileUp.sync(modulePath, dirPath, nestDepth) || `/node_modules/${filename}`;\n};\n\nexport const getNodePath = (moduleName: string): string => {\n  const dirName = getDirName();\n  const modulePath: string = `node_modules/${moduleName}`;\n\n  const projectPath = pathResolve(process.cwd(), modulePath);\n  if(existsSync(projectPath)) {\n    return projectPath;\n  }\n\n  const repoPath: string = findFileUp.sync(modulePath, dirName);\n  if(repoPath && existsSync(repoPath)) {\n    return repoPath;\n  }\n\n  const localPath: string = findFileUp.sync(modulePath, './', 10) || `./${modulePath}`;\n  return localPath;\n};\n\nexport const resolveBinaryPath = (binaryName: string, packageName?: string): string => {\n  const lexDir = LexConfig.getLexDir();\n\n  const lexBinPath = pathResolve(lexDir, `node_modules/.bin/${binaryName}`);\n  if(existsSync(lexBinPath)) {\n    return lexBinPath;\n  }\n\n  if(packageName) {\n    const lexPackageBinPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}`);\n    if(existsSync(lexPackageBinPath)) {\n      return lexPackageBinPath;\n    }\n\n    const lexPackageBinJsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.js`);\n    if(existsSync(lexPackageBinJsPath)) {\n      return lexPackageBinJsPath;\n    }\n\n    const lexPackageBinCjsPath = pathResolve(lexDir, `node_modules/${packageName}/bin/${binaryName}.cjs`);\n    if(existsSync(lexPackageBinCjsPath)) {\n      return lexPackageBinCjsPath;\n    }\n  }\n\n  const checkBinUp = (startDir: string) => {\n    let checkDir = startDir;\n    for(let i = 0; i < 5; i++) {\n      const monorepoBinPath = pathResolve(checkDir, `node_modules/.bin/${binaryName}`);\n      if(existsSync(monorepoBinPath)) {\n        return monorepoBinPath;\n      }\n      const parentDir = pathResolve(checkDir, '..');\n      if(parentDir === checkDir) {\n        break;\n      }\n      checkDir = parentDir;\n    }\n    return '';\n  };\n\n  const fromCwd = checkBinUp(process.cwd());\n  if(fromCwd) {\n    return fromCwd;\n  }\n\n  const fromLex = checkBinUp(lexDir);\n  if(fromLex) {\n    return fromLex;\n  }\n\n  return '';\n};\n\nexport const findTailwindCssPath = (): string => {\n  const tailwindPatterns = ['**/tailwind.css'];\n\n  for(const pattern of tailwindPatterns) {\n    const files = globSync(pattern, {\n      cwd: process.cwd(),\n      ignore: ['**/node_modules/**', '**/dist/**', '**/build/**', '**/.storybook/**']\n    });\n\n    if(files.length > 0) {\n      return pathResolve(process.cwd(), files[0]);\n    }\n  }\n\n  return '';\n};"],
  "mappings": "AAIA,OAAO,gBAAgB;AACvB,SAAQ,YAAY,oBAAmB;AACvC,SAAQ,QAAQ,gBAAe;AAC/B,SAAQ,WAAW,aAAa,eAAc;AAE9C,SAAQ,iBAAgB;AAEjB,SAAS,aAAqB;AACnC,MAAI;AACF,WAAO,KAAK,wCAAwC;AAAA,EACtD,QAAO;AACL,WAAO,QAAQ,IAAI;AAAA,EACrB;AACF;AAEO,SAAS,YAAY,cAA8B;AACxD,MAAI;AACF,WAAO,KAAK,sEAAsE;AAAA,EACpF,QAAO;AACL,QAAG,iBAAiB,yBAAyB;AAC3C,aAAO,YAAY,QAAQ,IAAI,GAAG,cAAc;AAAA,IAClD;AACA,WAAO,YAAY,QAAQ,IAAI,GAAG,YAAY;AAAA,EAChD;AACF;AAEO,SAAS,wBAAgC;AAC9C,QAAM,mBAAmB;AAEzB,QAAM,mBAAmB,YAAY,QAAQ,IAAI,GAAG,sCAAsC;AAE1F,MAAG,WAAW,gBAAgB,GAAG;AAC/B,WAAO;AAAA,EACT;AAEA,MAAI;AAEJ,MAAG,QAAQ,IAAI,UAAU;AACvB,eAAW,QAAQ,IAAI;AAAA,EACzB,OAAO;AACL,QAAI;AACF,iBAAW,KAAK,wCAAwC;AAAA,IAC1D,SAAQ,MAAM;AACZ,UAAI;AACF,mBAAW,KAAK,yDAAyD;AACzE,YAAG,CAAC,UAAU;AACZ,gBAAM,IAAI,MAAM,0BAA0B;AAAA,QAC5C;AAAA,MACF,SAAQ,MAAM;AACZ,YAAI;AACF,cAAG,QAAQ,KAAK,CAAC,KAAK,CAAC,QAAQ,KAAK,CAAC,EAAE,SAAS,MAAM,GAAG;AACvD,uBAAW,QAAQ,QAAQ,KAAK,CAAC,CAAC;AAAA,UACpC,OAAO;AACL,kBAAM,IAAI,MAAM,8BAA8B;AAAA,UAChD;AAAA,QACF,SAAQ,MAAM;AACZ,qBAAW,QAAQ,IAAI;AAAA,QACzB;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,MAAI,MAAM;AACV,WAAQ,IAAI,GAAG,IAAI,GAAG,KAAK;AACzB,UAAM,UAAU,YAAY,KAAK,cAAc;AAC/C,QAAG,WAAW,OAAO,GAAG;AACtB,UAAI;AACF,cAAM,MAAM,KAAK,MAAM,aAAa,SAAS,MAAM,CAAC;AACpD,YAAG,IAAI,SAAS,kBAAkB;AAChC,iBAAO;AAAA,QACT;AAAA,MACF,SAAQ,OAAO;AAAA,MACf;AAAA,IACF;AACA,UAAM,SAAS,QAAQ,GAAG;AAC1B,QAAG,WAAW,KAAK;AACjB;AAAA,IACF;AACA,UAAM;AAAA,EACR;AAEA,SAAO,YAAY,QAAQ,IAAI,GAAG,cAAc;AAClD;AAEO,MAAM,mBAAmB,CAAC,UAAkB,UAAkB,MAAM,SAAiB,MAAc;AACxG,QAAM,YAAoB;AAE1B,MAAG,QAAQ;AACT,UAAM,WAAmB,WAAW,KAAK,UAAU,SAAS,SAAS;AACrE,UAAM,eAAuB,MAAM,MAAM,EAAE,KAAK,IAAI,EAAE,IAAI,MAAM,KAAK,EAAE,KAAK,EAAE;AAC9E,WAAO,YAAY,UAAU,YAAY;AAAA,EAC3C;AAEA,SAAO,WAAW,KAAK,UAAU,SAAS,SAAS;AACrD;AAEO,MAAM,mBAAmB,CAAC,UAAkB,UAAkB,MAAM,SAAiB,MAAc;AACxG,QAAM,YAAoB;AAC1B,QAAM,aAAa,gBAAgB,QAAQ;AAE3C,MAAG,YAAY,MAAM;AACnB,UAAM,gBAAgB,YAAY,SAAS,UAAU;AACrD,QAAG,WAAW,aAAa,GAAG;AAC5B,aAAO;AAAA,IACT;AAAA,EACF;AAEA,QAAM,cAAc,YAAY,QAAQ,IAAI,GAAG,UAAU;AACzD,MAAG,WAAW,WAAW,GAAG;AAC1B,WAAO;AAAA,EACT;AAEA,MAAG,QAAQ;AACT,UAAM,WAAmB,WAAW,KAAK,YAAY,SAAS,SAAS;AACvE,UAAM,eAAuB,MAAM,SAAS,EAAE,KAAK,IAAI,EAAE,IAAI,MAAM,KAAK,EAAE,KAAK,EAAE;AACjF,WAAO,YAAY,UAAU,YAAY;AAAA,EAC3C;AAEA,SAAO,WAAW,KAAK,YAAY,SAAS,SAAS,KAAK,iBAAiB,QAAQ;AACrF;AAEO,MAAM,cAAc,CAAC,eAA+B;AACzD,QAAM,UAAU,WAAW;AAC3B,QAAM,aAAqB,gBAAgB,UAAU;AAErD,QAAM,cAAc,YAAY,QAAQ,IAAI,GAAG,UAAU;AACzD,MAAG,WAAW,WAAW,GAAG;AAC1B,WAAO;AAAA,EACT;AAEA,QAAM,WAAmB,WAAW,KAAK,YAAY,OAAO;AAC5D,MAAG,YAAY,WAAW,QAAQ,GAAG;AACnC,WAAO;AAAA,EACT;AAEA,QAAM,YAAoB,WAAW,KAAK,YAAY,MAAM,EAAE,KAAK,KAAK,UAAU;AAClF,SAAO;AACT;AAEO,MAAM,oBAAoB,CAAC,YAAoB,gBAAiC;AACrF,QAAM,SAAS,UAAU,UAAU;AAEnC,QAAM,aAAa,YAAY,QAAQ,qBAAqB,UAAU,EAAE;AACxE,MAAG,WAAW,UAAU,GAAG;AACzB,WAAO;AAAA,EACT;AAEA,MAAG,aAAa;AACd,UAAM,oBAAoB,YAAY,QAAQ,gBAAgB,WAAW,QAAQ,UAAU,EAAE;AAC7F,QAAG,WAAW,iBAAiB,GAAG;AAChC,aAAO;AAAA,IACT;AAEA,UAAM,sBAAsB,YAAY,QAAQ,gBAAgB,WAAW,QAAQ,UAAU,KAAK;AAClG,QAAG,WAAW,mBAAmB,GAAG;AAClC,aAAO;AAAA,IACT;AAEA,UAAM,uBAAuB,YAAY,QAAQ,gBAAgB,WAAW,QAAQ,UAAU,MAAM;AACpG,QAAG,WAAW,oBAAoB,GAAG;AACnC,aAAO;AAAA,IACT;AAAA,EACF;AAEA,QAAM,aAAa,CAACA,cAAqB;AACvC,QAAI,WAAWA;AACf,aAAQ,IAAI,GAAG,IAAI,GAAG,KAAK;AACzB,YAAM,kBAAkB,YAAY,UAAU,qBAAqB,UAAU,EAAE;AAC/E,UAAG,WAAW,eAAe,GAAG;AAC9B,eAAO;AAAA,MACT;AACA,YAAM,YAAY,YAAY,UAAU,IAAI;AAC5C,UAAG,cAAc,UAAU;AACzB;AAAA,MACF;AACA,iBAAW;AAAA,IACb;AACA,WAAO;AAAA,EACT;AAEA,QAAM,UAAU,WAAW,QAAQ,IAAI,CAAC;AACxC,MAAG,SAAS;AACV,WAAO;AAAA,EACT;AAEA,QAAM,UAAU,WAAW,MAAM;AACjC,MAAG,SAAS;AACV,WAAO;AAAA,EACT;AAEA,SAAO;AACT;AAEO,MAAM,sBAAsB,MAAc;AAC/C,QAAM,mBAAmB,CAAC,iBAAiB;AAE3C,aAAU,WAAW,kBAAkB;AACrC,UAAM,QAAQ,SAAS,SAAS;AAAA,MAC9B,KAAK,QAAQ,IAAI;AAAA,MACjB,QAAQ,CAAC,sBAAsB,cAAc,eAAe,kBAAkB;AAAA,IAChF,CAAC;AAED,QAAG,MAAM,SAAS,GAAG;AACnB,aAAO,YAAY,QAAQ,IAAI,GAAG,MAAM,CAAC,CAAC;AAAA,IAC5C;AAAA,EACF;AAEA,SAAO;AACT;",
  "names": ["startDir"]
}

|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const log: (message: string, type?: string, quiet?: boolean) => void;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup } from '@testing-library/react';
|
|
2
|
+
import * as react from 'react';
|
|
3
|
+
export { react };
|
|
4
|
+
export { render, screen, fireEvent, waitFor, waitForElementToBeRemoved, within, getByRole, getByLabelText, getByPlaceholderText, getByText, getByTestId, getAllByRole, getAllByLabelText, getAllByPlaceholderText, getAllByText, getAllByTestId, queryByRole, queryByLabelText, queryByPlaceholderText, queryByText, queryByTestId, queryAllByRole, queryAllByLabelText, queryAllByPlaceholderText, queryAllByText, queryAllByTestId, findByRole, findByLabelText, findByPlaceholderText, findByText, findByTestId, findAllByRole, findAllByLabelText, findAllByPlaceholderText, findAllByText, findAllByTestId, renderHook, act, cleanup };
|
package/dist/utils/reactShim.js
CHANGED
|
@@ -1,5 +1,85 @@
|
|
|
1
|
+
import {
|
|
2
|
+
render,
|
|
3
|
+
screen,
|
|
4
|
+
fireEvent,
|
|
5
|
+
waitFor,
|
|
6
|
+
waitForElementToBeRemoved,
|
|
7
|
+
within,
|
|
8
|
+
getByRole,
|
|
9
|
+
getByLabelText,
|
|
10
|
+
getByPlaceholderText,
|
|
11
|
+
getByText,
|
|
12
|
+
getByTestId,
|
|
13
|
+
getAllByRole,
|
|
14
|
+
getAllByLabelText,
|
|
15
|
+
getAllByPlaceholderText,
|
|
16
|
+
getAllByText,
|
|
17
|
+
getAllByTestId,
|
|
18
|
+
queryByRole,
|
|
19
|
+
queryByLabelText,
|
|
20
|
+
queryByPlaceholderText,
|
|
21
|
+
queryByText,
|
|
22
|
+
queryByTestId,
|
|
23
|
+
queryAllByRole,
|
|
24
|
+
queryAllByLabelText,
|
|
25
|
+
queryAllByPlaceholderText,
|
|
26
|
+
queryAllByText,
|
|
27
|
+
queryAllByTestId,
|
|
28
|
+
findByRole,
|
|
29
|
+
findByLabelText,
|
|
30
|
+
findByPlaceholderText,
|
|
31
|
+
findByText,
|
|
32
|
+
findByTestId,
|
|
33
|
+
findAllByRole,
|
|
34
|
+
findAllByLabelText,
|
|
35
|
+
findAllByPlaceholderText,
|
|
36
|
+
findAllByText,
|
|
37
|
+
findAllByTestId,
|
|
38
|
+
renderHook,
|
|
39
|
+
act,
|
|
40
|
+
cleanup
|
|
41
|
+
} from "@testing-library/react";
|
|
1
42
|
import * as react from "react";
|
|
2
43
|
export {
|
|
3
|
-
|
|
44
|
+
act,
|
|
45
|
+
cleanup,
|
|
46
|
+
findAllByLabelText,
|
|
47
|
+
findAllByPlaceholderText,
|
|
48
|
+
findAllByRole,
|
|
49
|
+
findAllByTestId,
|
|
50
|
+
findAllByText,
|
|
51
|
+
findByLabelText,
|
|
52
|
+
findByPlaceholderText,
|
|
53
|
+
findByRole,
|
|
54
|
+
findByTestId,
|
|
55
|
+
findByText,
|
|
56
|
+
fireEvent,
|
|
57
|
+
getAllByLabelText,
|
|
58
|
+
getAllByPlaceholderText,
|
|
59
|
+
getAllByRole,
|
|
60
|
+
getAllByTestId,
|
|
61
|
+
getAllByText,
|
|
62
|
+
getByLabelText,
|
|
63
|
+
getByPlaceholderText,
|
|
64
|
+
getByRole,
|
|
65
|
+
getByTestId,
|
|
66
|
+
getByText,
|
|
67
|
+
queryAllByLabelText,
|
|
68
|
+
queryAllByPlaceholderText,
|
|
69
|
+
queryAllByRole,
|
|
70
|
+
queryAllByTestId,
|
|
71
|
+
queryAllByText,
|
|
72
|
+
queryByLabelText,
|
|
73
|
+
queryByPlaceholderText,
|
|
74
|
+
queryByRole,
|
|
75
|
+
queryByTestId,
|
|
76
|
+
queryByText,
|
|
77
|
+
react,
|
|
78
|
+
render,
|
|
79
|
+
renderHook,
|
|
80
|
+
screen,
|
|
81
|
+
waitFor,
|
|
82
|
+
waitForElementToBeRemoved,
|
|
83
|
+
within
|
|
4
84
|
};
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vLi4vc3JjL3V0aWxzL3JlYWN0U2hpbS50cyJdLAogICJzb3VyY2VzQ29udGVudCI6IFsiaW1wb3J0IHtcbiAgcmVuZGVyLFxuICBzY3JlZW4sXG4gIGZpcmVFdmVudCxcbiAgd2FpdEZvcixcbiAgd2FpdEZvckVsZW1lbnRUb0JlUmVtb3ZlZCxcbiAgd2l0aGluLFxuICBnZXRCeVJvbGUsXG4gIGdldEJ5TGFiZWxUZXh0LFxuICBnZXRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QnlUZXh0LFxuICBnZXRCeVRlc3RJZCxcbiAgZ2V0QWxsQnlSb2xlLFxuICBnZXRBbGxCeUxhYmVsVGV4dCxcbiAgZ2V0QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIGdldEFsbEJ5VGV4dCxcbiAgZ2V0QWxsQnlUZXN0SWQsXG4gIHF1ZXJ5QnlSb2xlLFxuICBxdWVyeUJ5TGFiZWxUZXh0LFxuICBxdWVyeUJ5UGxhY2Vob2xkZXJUZXh0LFxuICBxdWVyeUJ5VGV4dCxcbiAgcXVlcnlCeVRlc3RJZCxcbiAgcXVlcnlBbGxCeVJvbGUsXG4gIHF1ZXJ5QWxsQnlMYWJlbFRleHQsXG4gIHF1ZXJ5QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QWxsQnlUZXh0LFxuICBxdWVyeUFsbEJ5VGVzdElkLFxuICBmaW5kQnlSb2xlLFxuICBmaW5kQnlMYWJlbFRleHQsXG4gIGZpbmRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEJ5VGV4dCxcbiAgZmluZEJ5VGVzdElkLFxuICBmaW5kQWxsQnlSb2xlLFxuICBmaW5kQWxsQnlMYWJlbFRleHQsXG4gIGZpbmRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEFsbEJ5VGV4dCxcbiAgZmluZEFsbEJ5VGVzdElkLFxuICByZW5kZXJIb29rLFxuICBhY3QsXG4gIGNsZWFudXBcbn0gZnJvbSAnQHRlc3RpbmctbGlicmFyeS9yZWFjdCc7XG5pbXBvcnQgKiBhcyByZWFjdCBmcm9tICdyZWFjdCc7XG5cbmV4cG9ydCB7cmVhY3R9O1xuXG4vLyBFeHBvcnQgc3BlY2lmaWMgdGVzdGluZyBsaWJyYXJ5IGZ1bmN0aW9uc1xuZXhwb3J0IHtcbiAgcmVuZGVyLFxuICBzY3JlZW4sXG4gIGZpcmVFdmVudCxcbiAgd2FpdEZvcixcbiAgd2FpdEZvckVsZW1lbnRUb0JlUmVtb3ZlZCxcbiAgd2l0aGluLFxuICBnZXRCeVJvbGUsXG4gIGdldEJ5TGFiZWxUZXh0LFxuICBnZXRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZ2V0QnlUZXh0LFxuICBnZXRCeVRlc3RJZCxcbiAgZ2V0QWxsQnlSb2xlLFxuICBnZXRBbGxCeUxhYmVsVGV4dCxcbiAgZ2V0QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIGdldEFsbEJ5VGV4dCxcbiAgZ2V0QWxsQnlUZXN0SWQsXG4gIHF1ZXJ5QnlSb2xlLFxuICBxdWVyeUJ5TGFiZWxUZXh0LFxuICBxdWVyeUJ5UGxhY2Vob2xkZXJUZXh0LFxuICBxdWVyeUJ5VGV4dCxcbiAgcXVlcnlCeVRlc3RJZCxcbiAgcXVlcnlBbGxCeVJvbGUsXG4gIHF1ZXJ5QWxsQnlMYWJlbFRleHQsXG4gIHF1ZXJ5QWxsQnlQbGFjZWhvbGRlclRleHQsXG4gIHF1ZXJ5QWxsQnlUZXh0LFxuICBxdWVyeUFsbEJ5VGVzdElkLFxuICBmaW5kQnlSb2xlLFxuICBmaW5kQnlMYWJlbFRleHQsXG4gIGZpbmRCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEJ5VGV4dCxcbiAgZmluZEJ5VGVzdElkLFxuICBmaW5kQWxsQnlSb2xlLFxuICBmaW5kQWxsQnlMYWJlbFRleHQsXG4gIGZpbmRBbGxCeVBsYWNlaG9sZGVyVGV4dCxcbiAgZmluZEFsbEJ5VGV4dCxcbiAgZmluZEFsbEJ5VGVzdElkLFxuICByZW5kZXJIb29rLFxuICBhY3QsXG4gIGNsZWFudXBcbn07Il0sCiAgIm1hcHBpbmdzIjogIkFBQUE7QUFBQSxFQUNFO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxFQUNBO0FBQUEsRUFDQTtBQUFBLEVBQ0E7QUFBQSxPQUNLO0FBQ1AsWUFBWSxXQUFXOyIsCiAgIm5hbWVzIjogW10KfQo=
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
declare namespace _default {
|
|
2
|
+
let displayName: any;
|
|
3
|
+
let testEnvironment: string;
|
|
4
|
+
let moduleFileExtensions: string[];
|
|
5
|
+
let moduleDirectories: string[];
|
|
6
|
+
let moduleNameMapper: {
|
|
7
|
+
'^(\\.{1,2}/.*)\\.js$': string;
|
|
8
|
+
'^execa$': string;
|
|
9
|
+
'^boxen$': string;
|
|
10
|
+
'^chalk$': string;
|
|
11
|
+
'^ora$': string;
|
|
12
|
+
'^latest-version$': string;
|
|
13
|
+
'^compare-versions$': string;
|
|
14
|
+
'.*LexConfig.*': string;
|
|
15
|
+
'.*build\\.js$': string;
|
|
16
|
+
'.*versions\\.js$': string;
|
|
17
|
+
'.*compile\\.js$': string;
|
|
18
|
+
'utils/file\\.js$': string;
|
|
19
|
+
'.*/utils/file\\.js$': string;
|
|
20
|
+
'^(\\.{1,2}/)*utils/file\\.js$': string;
|
|
21
|
+
'.(css|less|scss|sass)$': string;
|
|
22
|
+
'.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$': string;
|
|
23
|
+
};
|
|
24
|
+
let rootDir: string;
|
|
25
|
+
let transformIgnorePatterns: string[];
|
|
26
|
+
let setupFilesAfterEnv: string[];
|
|
27
|
+
let transform: {
|
|
28
|
+
'^.+.js$|^.+.jsx$': (string | {
|
|
29
|
+
presets: (string | (string | {
|
|
30
|
+
targets: {
|
|
31
|
+
node: string;
|
|
32
|
+
};
|
|
33
|
+
})[])[];
|
|
34
|
+
})[];
|
|
35
|
+
'^.+.ts$|^.+.tsx$': (string | {
|
|
36
|
+
presets: (string | (string | {
|
|
37
|
+
targets: {
|
|
38
|
+
node: string;
|
|
39
|
+
};
|
|
40
|
+
})[])[];
|
|
41
|
+
})[];
|
|
42
|
+
};
|
|
43
|
+
let testRegex: string;
|
|
44
|
+
let collectCoverage: boolean;
|
|
45
|
+
let coverageDirectory: string;
|
|
46
|
+
let coveragePathIgnorePatterns: string[];
|
|
47
|
+
let coverageReporters: string[];
|
|
48
|
+
let verbose: boolean;
|
|
49
|
+
}
|
|
50
|
+
export default _default;
|
package/jest.config.mjs
ADDED
|
@@ -0,0 +1,69 @@
|
|
|
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 {readFileSync} from 'fs';
|
|
6
|
+
import {fileURLToPath} from 'url';
|
|
7
|
+
import {dirname, resolve} from 'path';
|
|
8
|
+
|
|
9
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
10
|
+
const __dirname = dirname(__filename);
|
|
11
|
+
const pack = JSON.parse(readFileSync(resolve(__dirname, 'package.json'), 'utf8'));
|
|
12
|
+
|
|
13
|
+
export default {
|
|
14
|
+
displayName: pack.name,
|
|
15
|
+
testEnvironment: 'jsdom',
|
|
16
|
+
moduleFileExtensions: ['ts', 'tsx', 'js', 'json', 'node'],
|
|
17
|
+
moduleDirectories: ['js', '.', 'node_modules'],
|
|
18
|
+
moduleNameMapper: {
|
|
19
|
+
'^(\\.{1,2}/.*)\\.js$': '$1',
|
|
20
|
+
'^execa$': resolve(__dirname, '__mocks__/execa.js'),
|
|
21
|
+
'^boxen$': resolve(__dirname, '__mocks__/boxen.js'),
|
|
22
|
+
'^chalk$': resolve(__dirname, '__mocks__/chalk.js'),
|
|
23
|
+
'^ora$': resolve(__dirname, '__mocks__/ora.js'),
|
|
24
|
+
'^latest-version$': resolve(__dirname, '__mocks__/latest-version.js'),
|
|
25
|
+
'^compare-versions$': resolve(__dirname, '__mocks__/compare-versions.js'),
|
|
26
|
+
'.*LexConfig.*': resolve(__dirname, '__mocks__/LexConfig.js'),
|
|
27
|
+
'.*build\\.js$': resolve(__dirname, '__mocks__/build.js'),
|
|
28
|
+
'.*versions\\.js$': resolve(__dirname, '__mocks__/versions.js'),
|
|
29
|
+
'.*compile\\.js$': resolve(__dirname, '__mocks__/compile.js'),
|
|
30
|
+
'utils/file\\.js$': resolve(__dirname, '__mocks__/file.js'),
|
|
31
|
+
'.*/utils/file\\.js$': resolve(__dirname, '__mocks__/file.js'),
|
|
32
|
+
'^(\\.{1,2}/)*utils/file\\.js$': resolve(__dirname, '__mocks__/file.js'),
|
|
33
|
+
// '^(\.{1,2}/.*)\.js$': '$1',
|
|
34
|
+
'\.(css|less|scss|sass)$': 'identity-obj-proxy',
|
|
35
|
+
'\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$': resolve(__dirname, '__mocks__/fileMock.js')
|
|
36
|
+
},
|
|
37
|
+
rootDir: process.cwd(),
|
|
38
|
+
transformIgnorePatterns: [
|
|
39
|
+
'node_modules/(?!(strip-indent|chalk|@testing-library/jest-dom|zod|@nlabs|@nlabs/arkhamjs|@nlabs/utils|@nlabs/lex|react-markdown|devlop)/.*)'
|
|
40
|
+
],
|
|
41
|
+
setupFilesAfterEnv: ['<rootDir>/jest.setup.js'],
|
|
42
|
+
transform: {
|
|
43
|
+
'^.+\.js$|^.+\.jsx$': ['babel-jest', {
|
|
44
|
+
presets: [
|
|
45
|
+
['@babel/preset-env', {targets: {node: 'current'}}],
|
|
46
|
+
'@babel/preset-react'
|
|
47
|
+
]
|
|
48
|
+
}],
|
|
49
|
+
'^.+\.ts$|^.+\.tsx$': ['babel-jest', {
|
|
50
|
+
presets: [
|
|
51
|
+
['@babel/preset-env', {targets: {node: 'current'}}],
|
|
52
|
+
'@babel/preset-typescript',
|
|
53
|
+
'@babel/preset-react'
|
|
54
|
+
]
|
|
55
|
+
}]
|
|
56
|
+
},
|
|
57
|
+
testRegex: '(/__tests__/.*|\\.(test|spec|integration))\\.(ts|tsx)?$',
|
|
58
|
+
collectCoverage: true,
|
|
59
|
+
coverageDirectory: '<rootDir>/coverage',
|
|
60
|
+
coveragePathIgnorePatterns: [
|
|
61
|
+
'/node_modules/',
|
|
62
|
+
'/dist',
|
|
63
|
+
'/lib',
|
|
64
|
+
'__snapshots__',
|
|
65
|
+
'.d.ts'
|
|
66
|
+
],
|
|
67
|
+
coverageReporters: ['html', 'text'],
|
|
68
|
+
verbose: true
|
|
69
|
+
};
|
|
@@ -0,0 +1,63 @@
|
|
|
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
|
+
|
|
6
|
+
// Read Jest config from LEX_CONFIG environment variable if available
|
|
7
|
+
let lexConfig = null;
|
|
8
|
+
if(process.env.LEX_CONFIG) {
|
|
9
|
+
try {
|
|
10
|
+
lexConfig = JSON.parse(process.env.LEX_CONFIG);
|
|
11
|
+
} catch(error) {
|
|
12
|
+
console.warn('Failed to parse LEX_CONFIG:', error.message);
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
const baseConfig = {
|
|
17
|
+
testEnvironment: 'jsdom',
|
|
18
|
+
moduleFileExtensions: ['ts', 'tsx', 'js', 'json', 'node'],
|
|
19
|
+
moduleNameMapper: {
|
|
20
|
+
'^(\\.{1,2}/.*)\\.js$': '$1',
|
|
21
|
+
'\\.(css|less|scss|sass)$': 'identity-obj-proxy',
|
|
22
|
+
'\\.(jpg|jpeg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$': '<rootDir>/__mocks__/fileMock.js'
|
|
23
|
+
},
|
|
24
|
+
transformIgnorePatterns: [
|
|
25
|
+
'node_modules/(?!(strip-indent|chalk|@testing-library/jest-dom|zod|@nlabs|@nlabs/arkhamjs|@nlabs/utils|@nlabs/lex)/.*)'
|
|
26
|
+
],
|
|
27
|
+
setupFilesAfterEnv: ['<rootDir>/jest.setup.js'],
|
|
28
|
+
transform: {
|
|
29
|
+
'^.+\\.ts$|^.+\\.tsx$': ['ts-jest', {
|
|
30
|
+
useESM: false,
|
|
31
|
+
tsconfig: 'tsconfig.test.json'
|
|
32
|
+
}],
|
|
33
|
+
'^.+\\.js$|^.+\\.jsx$': ['babel-jest', {
|
|
34
|
+
presets: [
|
|
35
|
+
['@babel/preset-env', {targets: {node: 'current'}}],
|
|
36
|
+
'@babel/preset-react'
|
|
37
|
+
]
|
|
38
|
+
}]
|
|
39
|
+
},
|
|
40
|
+
moduleDirectories: ['node_modules', '<rootDir>'],
|
|
41
|
+
testRegex: '(/__tests__/.*|\\.(test|spec|integration))\\.(ts|tsx|js|jsx)?$',
|
|
42
|
+
collectCoverage: true,
|
|
43
|
+
coverageDirectory: '<rootDir>/coverage',
|
|
44
|
+
coveragePathIgnorePatterns: [
|
|
45
|
+
'/node_modules/',
|
|
46
|
+
'/dist',
|
|
47
|
+
'/lib',
|
|
48
|
+
'__snapshots__',
|
|
49
|
+
'.d.ts'
|
|
50
|
+
],
|
|
51
|
+
coverageReporters: ['html', 'text'],
|
|
52
|
+
verbose: true
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
// Merge with Lex config if available
|
|
56
|
+
if(lexConfig && lexConfig.jest) {
|
|
57
|
+
module.exports = {
|
|
58
|
+
...baseConfig,
|
|
59
|
+
...lexConfig.jest
|
|
60
|
+
};
|
|
61
|
+
} else {
|
|
62
|
+
module.exports = baseConfig;
|
|
63
|
+
}
|