@nlabs/lex 1.49.5 → 1.50.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/.swcrc +35 -0
  2. package/README.md +43 -59
  3. package/config.json +32 -8
  4. package/examples/lex.config.js +110 -10
  5. package/lex.config.js +34 -7
  6. package/lib/Button.stories.js +99 -0
  7. package/lib/LexConfig.d.ts +60 -22
  8. package/lib/LexConfig.js +285 -244
  9. package/lib/commands/ai/ai.js +287 -288
  10. package/lib/commands/ai/index.js +8 -7
  11. package/lib/commands/build/build.d.ts +2 -2
  12. package/lib/commands/build/build.js +349 -458
  13. package/lib/commands/clean/clean.js +45 -33
  14. package/lib/commands/compile/compile.js +214 -228
  15. package/lib/commands/config/config.js +46 -42
  16. package/lib/commands/copy/copy.js +36 -35
  17. package/lib/commands/create/create.js +200 -121
  18. package/lib/commands/dev/dev.d.ts +1 -0
  19. package/lib/commands/dev/dev.js +261 -259
  20. package/lib/commands/init/init.js +108 -88
  21. package/lib/commands/link/link.js +18 -14
  22. package/lib/commands/lint/lint.js +735 -742
  23. package/lib/commands/migrate/migrate.js +49 -36
  24. package/lib/commands/publish/publish.js +116 -96
  25. package/lib/commands/serverless/serverless.js +611 -585
  26. package/lib/commands/storybook/storybook.js +242 -238
  27. package/lib/commands/test/test.js +381 -409
  28. package/lib/commands/update/update.js +141 -120
  29. package/lib/commands/upgrade/upgrade.js +51 -44
  30. package/lib/commands/versions/versions.d.ts +1 -1
  31. package/lib/commands/versions/versions.js +36 -38
  32. package/lib/create/changelog.js +136 -125
  33. package/lib/index.js +40 -38
  34. package/lib/lex.js +95 -68
  35. package/lib/storybook/index.js +6 -1
  36. package/lib/test-react/index.js +7 -84
  37. package/lib/types.d.ts +1 -1
  38. package/lib/types.js +7 -1
  39. package/lib/utils/aiService.js +240 -227
  40. package/lib/utils/app.js +274 -273
  41. package/lib/utils/deepMerge.js +37 -23
  42. package/lib/utils/file.js +218 -215
  43. package/lib/utils/log.js +29 -27
  44. package/lib/utils/reactShim.js +7 -85
  45. package/lib/utils/translations.js +92 -82
  46. package/package.json +59 -60
  47. package/templates/typescript/DataLayer.js.txt +218 -0
  48. package/templates/typescript/DataLayer.test.js.txt +268 -0
  49. package/templates/typescript/DataLayer.test.ts.txt +269 -0
  50. package/templates/typescript/DataLayer.ts.txt +227 -0
  51. package/webpack.config.js +38 -28
  52. package/lib/commands/lint/autofix.d.ts +0 -2
@@ -1,128 +1,139 @@
1
- import { execa } from "execa";
2
- import { writeFileSync } from "fs";
3
- import capitalize from "lodash/capitalize.js";
4
- import isEmpty from "lodash/isEmpty.js";
5
- import merge from "lodash/merge.js";
6
- import { DateTime } from "luxon";
7
- import { join as pathJoin } from "path";
8
- import { createSpinner } from "../utils/app.js";
9
- import { log } from "../utils/log.js";
10
- const createChangelog = async ({ cliName, config, outputFile = "changelog.tmp.md", quiet }) => {
11
- const spinner = createSpinner(quiet);
12
- const gitOptions = [
13
- "log",
14
- "-3",
15
- '--pretty=format:{"authorName": "%an", "authorEmail": "%ae", "hashShort": "%h", "hashFull": "%H", "tag": "%D", "date": %ct, "subject": "%s","comments": "%b"}[lex_break]'
16
- ];
17
- try {
18
- const git = await execa("git", gitOptions, { encoding: "utf8" });
19
- const { stdout } = git;
20
- const entries = stdout.split("[lex_break]").filter((item) => !!item);
21
- const gitJson = JSON.parse(
22
- `[${entries.join(",")}]`.replace(/"[^"]*(?:""[^"]*)*"/g, (match) => match.replace(/\n/g, "[lex_break]"))
23
- );
24
- const commitContent = {};
25
- let version = "Unreleased";
26
- gitJson.forEach((item) => {
27
- const { comments, authorEmail, authorName, date, hashFull, hashShort, tag } = item;
28
- const formatDate = DateTime.fromMillis(date).toFormat("DDD");
29
- if (!isEmpty(tag)) {
30
- const refs = tag.split(", ");
31
- const updatedVersion = refs.reduce((ref, tagItem) => {
32
- let updatedRef = ref;
33
- if (updatedRef === "" && tagItem.includes("tag: v")) {
34
- updatedRef = tagItem.replace("tag: v", "").trim();
35
- }
36
- return updatedRef;
37
- }, "");
38
- if (!isEmpty(updatedVersion)) {
39
- version = updatedVersion;
40
- commitContent[version] = { date: formatDate, version: updatedVersion };
41
- }
42
- }
43
- if (!commitContent[version]) {
44
- commitContent[version] = { list: {} };
45
- }
46
- const subjectLines = comments.split("[lex_break]");
47
- const topics = {};
48
- for (let idx = 0, len = subjectLines.length; idx < len; idx++) {
49
- const nextLine = subjectLines[idx];
50
- const formatLine = nextLine.trim();
51
- const headerPattern = /^(\w*)(?:\(([\w$.\- *]*)\))?: (.*)$/;
52
- const matches = formatLine.match(headerPattern);
53
- if (matches) {
54
- const itemType = capitalize(matches[1]);
55
- const itemScope = matches[2];
56
- const itemDetails = matches[3];
57
- const details = {
58
- authorEmail,
59
- authorName,
60
- details: itemDetails,
61
- hashFull,
62
- hashShort,
63
- type: itemType
64
- };
65
- if (!topics[itemScope]) {
66
- topics[itemScope] = { [itemType]: [details] };
67
- } else {
68
- topics[itemScope][itemType].push(details);
69
- }
70
- }
71
- }
72
- commitContent[version] = merge(commitContent[version], { list: topics });
73
- });
74
- const formatLog = Object.keys(commitContent).reduce((content, versionKey) => {
75
- const { date, list = {}, version: version2 } = commitContent[versionKey];
76
- const formatScopes = Object.keys(list);
77
- let updatedContent = content;
78
- const versionLabel = version2 ? version2 : "Unreleased";
79
- const headerLabels = [versionLabel];
80
- if (date) {
81
- headerLabels.push(`(${date})`);
82
- }
83
- updatedContent += `
84
- ## ${headerLabels.join(" ")}
85
- `;
86
- formatScopes.forEach((scopeName) => {
87
- updatedContent += `
88
- ### ${scopeName}
89
-
90
- `;
91
- const itemList = list[scopeName];
92
- const itemNames = Object.keys(itemList);
93
- itemNames.forEach((itemName) => {
94
- updatedContent += `* ${itemName}
95
- `;
96
- itemList[itemName].forEach((changes) => {
97
- const { authorEmail, authorName, details, hashFull, hashShort } = changes;
98
- const { gitUrl } = config;
99
- let hash = `#${hashShort}`;
100
- if (!isEmpty(gitUrl)) {
101
- let commitPath = "commits";
102
- if (gitUrl.includes("github.com")) {
103
- commitPath = "commit";
104
- }
105
- hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;
1
+ /**
2
+ * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */ import { execa } from 'execa';
5
+ import { writeFileSync } from 'fs';
6
+ import capitalize from 'lodash/capitalize.js';
7
+ import isEmpty from 'lodash/isEmpty.js';
8
+ import merge from 'lodash/merge.js';
9
+ import { DateTime } from 'luxon';
10
+ import { join as pathJoin } from 'path';
11
+ import { createSpinner } from '../utils/app.js';
12
+ import { log } from '../utils/log.js';
13
+ export const createChangelog = async ({ cliName, config, outputFile = 'changelog.tmp.md', quiet })=>{
14
+ const spinner = createSpinner(quiet);
15
+ const gitOptions = [
16
+ 'log',
17
+ '-3',
18
+ '--pretty=format:{"authorName": "%an", "authorEmail": "%ae", "hashShort": "%h", "hashFull": "%H", "tag": "%D", "date": %ct, "subject": "%s","comments": "%b"}[lex_break]'
19
+ ];
20
+ try {
21
+ const git = await execa('git', gitOptions, {
22
+ encoding: 'utf8'
23
+ });
24
+ const { stdout } = git;
25
+ const entries = stdout.split('[lex_break]').filter((item)=>!!item);
26
+ const gitJson = JSON.parse(`[${entries.join(',')}]`.replace(/"[^"]*(?:""[^"]*)*"/g, (match)=>match.replace(/\n/g, '[lex_break]')));
27
+ const commitContent = {};
28
+ let version = 'Unreleased';
29
+ gitJson.forEach((item)=>{
30
+ const { comments, authorEmail, authorName, date, hashFull, hashShort, tag } = item;
31
+ const formatDate = DateTime.fromMillis(date).toFormat('DDD');
32
+ if (!isEmpty(tag)) {
33
+ const refs = tag.split(', ');
34
+ const updatedVersion = refs.reduce((ref, tagItem)=>{
35
+ let updatedRef = ref;
36
+ if (updatedRef === '' && tagItem.includes('tag: v')) {
37
+ updatedRef = tagItem.replace('tag: v', '').trim();
38
+ }
39
+ return updatedRef;
40
+ }, '');
41
+ if (!isEmpty(updatedVersion)) {
42
+ version = updatedVersion;
43
+ commitContent[version] = {
44
+ date: formatDate,
45
+ version: updatedVersion
46
+ };
47
+ }
48
+ }
49
+ if (!commitContent[version]) {
50
+ commitContent[version] = {
51
+ list: {}
52
+ };
53
+ }
54
+ const subjectLines = comments.split('[lex_break]');
55
+ const topics = {};
56
+ for(let idx = 0, len = subjectLines.length; idx < len; idx++){
57
+ const nextLine = subjectLines[idx];
58
+ const formatLine = nextLine.trim();
59
+ const headerPattern = /^(\w*)(?:\(([\w$.\- *]*)\))?: (.*)$/;
60
+ const matches = formatLine.match(headerPattern);
61
+ if (matches) {
62
+ const itemType = capitalize(matches[1]);
63
+ const itemScope = matches[2];
64
+ const itemDetails = matches[3];
65
+ const details = {
66
+ authorEmail,
67
+ authorName,
68
+ details: itemDetails,
69
+ hashFull,
70
+ hashShort,
71
+ type: itemType
72
+ };
73
+ if (!topics[itemScope]) {
74
+ topics[itemScope] = {
75
+ [itemType]: [
76
+ details
77
+ ]
78
+ };
79
+ } else {
80
+ topics[itemScope][itemType].push(details);
81
+ }
82
+ }
106
83
  }
107
- updatedContent += ` * ${details} ([${authorName}](mailto:${authorEmail}) in ${hash})
108
- `;
109
- });
84
+ commitContent[version] = merge(commitContent[version], {
85
+ list: topics
86
+ });
110
87
  });
111
- });
112
- return updatedContent;
113
- }, "# Changes\n");
114
- const logFile = pathJoin(process.cwd(), outputFile);
115
- writeFileSync(logFile, formatLog);
116
- spinner.succeed("Git change log complete!");
117
- return 0;
118
- } catch (error) {
119
- log(`
120
- ${cliName} Error: ${error.message}`, "error", quiet);
121
- spinner.fail("Failed generating change log!");
122
- return error.status;
123
- }
124
- };
125
- export {
126
- createChangelog
88
+ const formatLog = Object.keys(commitContent).reduce((content, versionKey)=>{
89
+ const { date, list = {}, version } = commitContent[versionKey];
90
+ const formatScopes = Object.keys(list);
91
+ let updatedContent = content;
92
+ const versionLabel = version ? version : 'Unreleased';
93
+ const headerLabels = [
94
+ versionLabel
95
+ ];
96
+ if (date) {
97
+ headerLabels.push(`(${date})`);
98
+ }
99
+ updatedContent += `\n## ${headerLabels.join(' ')}\n`;
100
+ formatScopes.forEach((scopeName)=>{
101
+ updatedContent += `\n### ${scopeName}\n\n`;
102
+ // Get the topic name
103
+ const itemList = list[scopeName];
104
+ const itemNames = Object.keys(itemList);
105
+ itemNames.forEach((itemName)=>{
106
+ updatedContent += `* ${itemName}\n`;
107
+ itemList[itemName].forEach((changes)=>{
108
+ const { authorEmail, authorName, details, hashFull, hashShort } = changes;
109
+ const { gitUrl } = config;
110
+ let hash = `#${hashShort}`;
111
+ if (!isEmpty(gitUrl)) {
112
+ let commitPath = 'commits';
113
+ if (gitUrl.includes('github.com')) {
114
+ commitPath = 'commit';
115
+ }
116
+ hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;
117
+ }
118
+ updatedContent += ` * ${details} ([${authorName}](mailto:${authorEmail}) in ${hash})\n`;
119
+ });
120
+ });
121
+ });
122
+ return updatedContent;
123
+ }, '# Changes\n');
124
+ const logFile = pathJoin(process.cwd(), outputFile);
125
+ writeFileSync(logFile, formatLog);
126
+ spinner.succeed('Git change log complete!');
127
+ // Kill process
128
+ return 0;
129
+ } catch (error) {
130
+ // Display error message
131
+ log(`\n${cliName} Error: ${error.message}`, 'error', quiet);
132
+ // Stop spinner
133
+ spinner.fail('Failed generating change log!');
134
+ // Kill process
135
+ return error.status;
136
+ }
127
137
  };
128
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/create/changelog.ts"],
  "sourcesContent": ["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {writeFileSync} from 'fs';\nimport capitalize from 'lodash/capitalize.js';\nimport isEmpty from 'lodash/isEmpty.js';\nimport merge from 'lodash/merge.js';\nimport {DateTime} from 'luxon';\nimport {join as pathJoin} from 'path';\n\n\nimport {createSpinner} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const createChangelog = async ({cliName, config, outputFile = 'changelog.tmp.md', quiet}): Promise<number> => {\n  const spinner = createSpinner(quiet);\n\n  const gitOptions: string[] = [\n    'log',\n    '-3',\n    '--pretty=format:{\"authorName\": \"%an\", \"authorEmail\": \"%ae\", \"hashShort\": \"%h\", \"hashFull\": \"%H\", \"tag\": \"%D\", \"date\": %ct, \"subject\": \"%s\",\"comments\": \"%b\"}[lex_break]'\n  ];\n\n  try {\n    const git = await execa('git', gitOptions, {encoding: 'utf8'});\n\n    const {stdout} = git;\n    const entries: string[] = stdout.split('[lex_break]').filter((item) => !!item);\n    const gitJson = JSON.parse(\n      (`[${entries.join(',')}]`).replace(/\"[^\"]*(?:\"\"[^\"]*)*\"/g, (match) => match.replace(/\\n/g, '[lex_break]'))\n    );\n    const commitContent = {};\n    let version: string = 'Unreleased';\n\n    gitJson.forEach((item) => {\n      const {comments, authorEmail, authorName, date, hashFull, hashShort, tag} = item;\n      const formatDate: string = DateTime.fromMillis(date).toFormat('DDD');\n\n      if(!isEmpty(tag)) {\n        const refs = tag.split(', ');\n        const updatedVersion: string = refs.reduce((ref: string, tagItem: string) => {\n          let updatedRef: string = ref;\n\n          if(updatedRef === '' && tagItem.includes('tag: v')) {\n            updatedRef = tagItem.replace('tag: v', '').trim();\n          }\n\n          return updatedRef;\n        }, '');\n\n        if(!isEmpty(updatedVersion)) {\n          version = updatedVersion;\n          commitContent[version] = {date: formatDate, version: updatedVersion};\n        }\n      }\n\n      if(!commitContent[version]) {\n        commitContent[version] = {list: {}};\n      }\n\n      const subjectLines: string[] = comments.split('[lex_break]');\n      const topics = {};\n\n\n      for(let idx: number = 0, len: number = subjectLines.length; idx < len; idx++) {\n        const nextLine: string = subjectLines[idx];\n        const formatLine: string = nextLine.trim();\n        const headerPattern: RegExp = /^(\\w*)(?:\\(([\\w$.\\- *]*)\\))?: (.*)$/;\n        const matches = formatLine.match(headerPattern);\n\n        if(matches) {\n          const itemType: string = capitalize(matches[1]);\n          const itemScope: string = matches[2];\n          const itemDetails: string = matches[3];\n          const details = {\n            authorEmail,\n            authorName,\n            details: itemDetails,\n            hashFull,\n            hashShort,\n            type: itemType\n          };\n\n          if(!topics[itemScope]) {\n            topics[itemScope] = {[itemType]: [details]};\n          } else {\n            topics[itemScope][itemType].push(details);\n          }\n        }\n      }\n\n      commitContent[version] = merge(commitContent[version], {list: topics});\n    });\n\n    const formatLog: string = Object.keys(commitContent).reduce((content: string, versionKey: string) => {\n      const {date, list = {}, version} = commitContent[versionKey];\n      const formatScopes: string[] = Object.keys(list);\n      let updatedContent: string = content;\n\n      const versionLabel: string = version ? version : 'Unreleased';\n      const headerLabels: string[] = [versionLabel];\n      if(date) {\n        headerLabels.push(`(${date})`);\n      }\n\n      updatedContent += `\\n## ${headerLabels.join(' ')}\\n`;\n\n      formatScopes.forEach((scopeName: string) => {\n        updatedContent += `\\n### ${scopeName}\\n\\n`;\n\n        // Get the topic name\n        const itemList = list[scopeName];\n        const itemNames: string[] = Object.keys(itemList);\n\n        itemNames.forEach((itemName: string) => {\n          updatedContent += `* ${itemName}\\n`;\n\n          itemList[itemName].forEach((changes) => {\n            const {authorEmail, authorName, details, hashFull, hashShort} = changes;\n            const {gitUrl} = config;\n            let hash: string = `#${hashShort}`;\n\n            if(!isEmpty(gitUrl)) {\n              let commitPath: string = 'commits';\n\n              if(gitUrl.includes('github.com')) {\n                commitPath = 'commit';\n              }\n\n              hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;\n            }\n\n            updatedContent += `  * ${details} ([${authorName}](mailto:${authorEmail}) in ${hash})\\n`;\n          });\n        });\n      });\n\n      return updatedContent;\n    }, '# Changes\\n');\n\n    const logFile: string = pathJoin(process.cwd(), outputFile);\n    writeFileSync(logFile, formatLog);\n    spinner.succeed('Git change log complete!');\n\n    // Kill process\n    return 0;\n  } catch (error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Failed generating change log!');\n\n    // Kill process\n    return error.status;\n  }\n};"],
  "mappings": "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",
  "names": ["version"]
}

138
+
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../../src/create/changelog.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {execa} from 'execa';\nimport {writeFileSync} from 'fs';\nimport capitalize from 'lodash/capitalize.js';\nimport isEmpty from 'lodash/isEmpty.js';\nimport merge from 'lodash/merge.js';\nimport {DateTime} from 'luxon';\nimport {join as pathJoin} from 'path';\n\n\nimport {createSpinner} from '../utils/app.js';\nimport {log} from '../utils/log.js';\n\nexport const createChangelog = async ({cliName, config, outputFile = 'changelog.tmp.md', quiet}): Promise<number> => {\n  const spinner = createSpinner(quiet);\n\n  const gitOptions: string[] = [\n    'log',\n    '-3',\n    '--pretty=format:{\"authorName\": \"%an\", \"authorEmail\": \"%ae\", \"hashShort\": \"%h\", \"hashFull\": \"%H\", \"tag\": \"%D\", \"date\": %ct, \"subject\": \"%s\",\"comments\": \"%b\"}[lex_break]'\n  ];\n\n  try {\n    const git = await execa('git', gitOptions, {encoding: 'utf8'});\n\n    const {stdout} = git;\n    const entries: string[] = stdout.split('[lex_break]').filter((item) => !!item);\n    const gitJson = JSON.parse(\n      (`[${entries.join(',')}]`).replace(/\"[^\"]*(?:\"\"[^\"]*)*\"/g, (match) => match.replace(/\\n/g, '[lex_break]'))\n    );\n    const commitContent = {};\n    let version: string = 'Unreleased';\n\n    gitJson.forEach((item) => {\n      const {comments, authorEmail, authorName, date, hashFull, hashShort, tag} = item;\n      const formatDate: string = DateTime.fromMillis(date).toFormat('DDD');\n\n      if(!isEmpty(tag)) {\n        const refs = tag.split(', ');\n        const updatedVersion: string = refs.reduce((ref: string, tagItem: string) => {\n          let updatedRef: string = ref;\n\n          if(updatedRef === '' && tagItem.includes('tag: v')) {\n            updatedRef = tagItem.replace('tag: v', '').trim();\n          }\n\n          return updatedRef;\n        }, '');\n\n        if(!isEmpty(updatedVersion)) {\n          version = updatedVersion;\n          commitContent[version] = {date: formatDate, version: updatedVersion};\n        }\n      }\n\n      if(!commitContent[version]) {\n        commitContent[version] = {list: {}};\n      }\n\n      const subjectLines: string[] = comments.split('[lex_break]');\n      const topics = {};\n\n\n      for(let idx: number = 0, len: number = subjectLines.length; idx < len; idx++) {\n        const nextLine: string = subjectLines[idx];\n        const formatLine: string = nextLine.trim();\n        const headerPattern: RegExp = /^(\\w*)(?:\\(([\\w$.\\- *]*)\\))?: (.*)$/;\n        const matches = formatLine.match(headerPattern);\n\n        if(matches) {\n          const itemType: string = capitalize(matches[1]);\n          const itemScope: string = matches[2];\n          const itemDetails: string = matches[3];\n          const details = {\n            authorEmail,\n            authorName,\n            details: itemDetails,\n            hashFull,\n            hashShort,\n            type: itemType\n          };\n\n          if(!topics[itemScope]) {\n            topics[itemScope] = {[itemType]: [details]};\n          } else {\n            topics[itemScope][itemType].push(details);\n          }\n        }\n      }\n\n      commitContent[version] = merge(commitContent[version], {list: topics});\n    });\n\n    const formatLog: string = Object.keys(commitContent).reduce((content: string, versionKey: string) => {\n      const {date, list = {}, version} = commitContent[versionKey];\n      const formatScopes: string[] = Object.keys(list);\n      let updatedContent: string = content;\n\n      const versionLabel: string = version ? version : 'Unreleased';\n      const headerLabels: string[] = [versionLabel];\n      if(date) {\n        headerLabels.push(`(${date})`);\n      }\n\n      updatedContent += `\\n## ${headerLabels.join(' ')}\\n`;\n\n      formatScopes.forEach((scopeName: string) => {\n        updatedContent += `\\n### ${scopeName}\\n\\n`;\n\n        // Get the topic name\n        const itemList = list[scopeName];\n        const itemNames: string[] = Object.keys(itemList);\n\n        itemNames.forEach((itemName: string) => {\n          updatedContent += `* ${itemName}\\n`;\n\n          itemList[itemName].forEach((changes) => {\n            const {authorEmail, authorName, details, hashFull, hashShort} = changes;\n            const {gitUrl} = config;\n            let hash: string = `#${hashShort}`;\n\n            if(!isEmpty(gitUrl)) {\n              let commitPath: string = 'commits';\n\n              if(gitUrl.includes('github.com')) {\n                commitPath = 'commit';\n              }\n\n              hash = `[#${hashShort}](${gitUrl}/${commitPath}/${hashFull})`;\n            }\n\n            updatedContent += `  * ${details} ([${authorName}](mailto:${authorEmail}) in ${hash})\\n`;\n          });\n        });\n      });\n\n      return updatedContent;\n    }, '# Changes\\n');\n\n    const logFile: string = pathJoin(process.cwd(), outputFile);\n    writeFileSync(logFile, formatLog);\n    spinner.succeed('Git change log complete!');\n\n    // Kill process\n    return 0;\n  } catch(error) {\n    // Display error message\n    log(`\\n${cliName} Error: ${error.message}`, 'error', quiet);\n\n    // Stop spinner\n    spinner.fail('Failed generating change log!');\n\n    // Kill process\n    return error.status;\n  }\n};"],"names":["execa","writeFileSync","capitalize","isEmpty","merge","DateTime","join","pathJoin","createSpinner","log","createChangelog","cliName","config","outputFile","quiet","spinner","gitOptions","git","encoding","stdout","entries","split","filter","item","gitJson","JSON","parse","replace","match","commitContent","version","forEach","comments","authorEmail","authorName","date","hashFull","hashShort","tag","formatDate","fromMillis","toFormat","refs","updatedVersion","reduce","ref","tagItem","updatedRef","includes","trim","list","subjectLines","topics","idx","len","length","nextLine","formatLine","headerPattern","matches","itemType","itemScope","itemDetails","details","type","push","formatLog","Object","keys","content","versionKey","formatScopes","updatedContent","versionLabel","headerLabels","scopeName","itemList","itemNames","itemName","changes","gitUrl","hash","commitPath","logFile","process","cwd","succeed","error","message","fail","status"],"mappings":"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"}
package/lib/index.js CHANGED
@@ -1,39 +1,41 @@
1
- export * from "./types.js";
2
- import {
3
- defaultConfigValues,
4
- LexConfig
5
- } from "./LexConfig.js";
6
- const Config = {
7
- create: (config) => config
1
+ /**
2
+ * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
3
+ * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
4
+ */ // Export types from types.ts
5
+ export * from './types.js';
6
+ // Export classes and values from LexConfig
7
+ export { defaultConfigValues, LexConfig } from './LexConfig.js';
8
+ // Export Config as both a type and a namespace with create method for backward compatibility
9
+ export const Config = {
10
+ create: (config)=>config
8
11
  };
9
- export * from "./utils/aiService.js";
10
- export * from "./utils/app.js";
11
- export * from "./utils/file.js";
12
- export * from "./utils/log.js";
13
- export * from "./utils/reactShim.js";
14
- export * from "./storybook/index.js";
15
- export * from "./commands/ai/ai.js";
16
- export * from "./commands/build/build.js";
17
- export * from "./commands/clean/clean.js";
18
- export * from "./commands/compile/compile.js";
19
- export * from "./commands/config/config.js";
20
- export * from "./commands/copy/copy.js";
21
- export * from "./commands/create/create.js";
22
- export * from "./commands/dev/dev.js";
23
- export * from "./commands/init/init.js";
24
- export * from "./commands/link/link.js";
25
- export * from "./commands/lint/lint.js";
26
- export * from "./commands/migrate/migrate.js";
27
- export * from "./commands/publish/publish.js";
28
- export * from "./commands/serverless/serverless.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";
34
- export {
35
- Config,
36
- LexConfig,
37
- defaultConfigValues
38
- };
39
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2luZGV4LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7TGV4Q29uZmlnVHlwZX0gZnJvbSAnLi9MZXhDb25maWcuanMnO1xuXG4vLyBFeHBvcnQgdHlwZXMgZnJvbSB0eXBlcy50c1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy5qcyc7XG5cbi8vIEV4cG9ydCBjbGFzc2VzIGFuZCB2YWx1ZXMgZnJvbSBMZXhDb25maWdcbmV4cG9ydCB7XG4gIGRlZmF1bHRDb25maWdWYWx1ZXMsIExleENvbmZpZ1xufSBmcm9tICcuL0xleENvbmZpZy5qcyc7XG5cbi8vIEV4cG9ydCBDb25maWcgYXMgYm90aCBhIHR5cGUgYW5kIGEgbmFtZXNwYWNlIHdpdGggY3JlYXRlIG1ldGhvZCBmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eVxuZXhwb3J0IGNvbnN0IENvbmZpZyA9IHtcbiAgY3JlYXRlOiAoY29uZmlnOiBMZXhDb25maWdUeXBlKSA9PiBjb25maWdcbn07XG5cbi8vIEV4cG9ydCB1dGlsaXR5IGZ1bmN0aW9uc1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9haVNlcnZpY2UuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9hcHAuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9maWxlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvbG9nLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvcmVhY3RTaGltLmpzJztcblxuLy8gRXhwb3J0IFN0b3J5Ym9vayBtb2R1bGVcbmV4cG9ydCAqIGZyb20gJy4vc3Rvcnlib29rL2luZGV4LmpzJztcblxuLy8gRXhwb3J0IGNvbW1hbmRzXG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2FpL2FpLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvYnVpbGQvYnVpbGQuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jbGVhbi9jbGVhbi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbXBpbGUvY29tcGlsZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbmZpZy9jb25maWcuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jb3B5L2NvcHkuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jcmVhdGUvY3JlYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvZGV2L2Rldi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2luaXQvaW5pdC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbmsvbGluay5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbnQvbGludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL21pZ3JhdGUvbWlncmF0ZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3B1Ymxpc2gvcHVibGlzaC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3NlcnZlcmxlc3Mvc2VydmVybGVzcy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3N0b3J5Ym9vay9zdG9yeWJvb2suanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy90ZXN0L3Rlc3QuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy91cGRhdGUvdXBkYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdXBncmFkZS91cGdyYWRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdmVyc2lvbnMvdmVyc2lvbnMuanMnO1xuIl0sCiAgIm1hcHBpbmdzIjogIkFBUUEsY0FBYztBQUdkO0FBQUEsRUFDRTtBQUFBLEVBQXFCO0FBQUEsT0FDaEI7QUFHQSxNQUFNLFNBQVM7QUFBQSxFQUNwQixRQUFRLENBQUMsV0FBMEI7QUFDckM7QUFHQSxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUdkLGNBQWM7QUFHZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjO0FBQ2QsY0FBYztBQUNkLGNBQWM7QUFDZCxjQUFjOyIsCiAgIm5hbWVzIjogW10KfQo=
12
+ // Export utility functions
13
+ export * from './utils/aiService.js';
14
+ export * from './utils/app.js';
15
+ export * from './utils/file.js';
16
+ export * from './utils/log.js';
17
+ export * from './utils/reactShim.js';
18
+ // Export Storybook module
19
+ export * from './storybook/index.js';
20
+ // Export commands
21
+ export * from './commands/ai/ai.js';
22
+ export * from './commands/build/build.js';
23
+ export * from './commands/clean/clean.js';
24
+ export * from './commands/compile/compile.js';
25
+ export * from './commands/config/config.js';
26
+ export * from './commands/copy/copy.js';
27
+ export * from './commands/create/create.js';
28
+ export * from './commands/dev/dev.js';
29
+ export * from './commands/init/init.js';
30
+ export * from './commands/link/link.js';
31
+ export * from './commands/lint/lint.js';
32
+ export * from './commands/migrate/migrate.js';
33
+ export * from './commands/publish/publish.js';
34
+ export * from './commands/serverless/serverless.js';
35
+ export * from './commands/storybook/storybook.js';
36
+ export * from './commands/test/test.js';
37
+ export * from './commands/update/update.js';
38
+ export * from './commands/upgrade/upgrade.js';
39
+ export * from './commands/versions/versions.js';
40
+
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIENvcHlyaWdodCAoYykgMjAxOC1QcmVzZW50LCBOaXRyb2dlbiBMYWJzLCBJbmMuXG4gKiBDb3B5cmlnaHRzIGxpY2Vuc2VkIHVuZGVyIHRoZSBNSVQgTGljZW5zZS4gU2VlIHRoZSBhY2NvbXBhbnlpbmcgTElDRU5TRSBmaWxlIGZvciB0ZXJtcy5cbiAqL1xuXG5pbXBvcnQgdHlwZSB7TGV4Q29uZmlnVHlwZX0gZnJvbSAnLi9MZXhDb25maWcuanMnO1xuXG4vLyBFeHBvcnQgdHlwZXMgZnJvbSB0eXBlcy50c1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcy5qcyc7XG5cbi8vIEV4cG9ydCBjbGFzc2VzIGFuZCB2YWx1ZXMgZnJvbSBMZXhDb25maWdcbmV4cG9ydCB7XG4gIGRlZmF1bHRDb25maWdWYWx1ZXMsIExleENvbmZpZ1xufSBmcm9tICcuL0xleENvbmZpZy5qcyc7XG5cbi8vIEV4cG9ydCBDb25maWcgYXMgYm90aCBhIHR5cGUgYW5kIGEgbmFtZXNwYWNlIHdpdGggY3JlYXRlIG1ldGhvZCBmb3IgYmFja3dhcmQgY29tcGF0aWJpbGl0eVxuZXhwb3J0IGNvbnN0IENvbmZpZyA9IHtcbiAgY3JlYXRlOiAoY29uZmlnOiBMZXhDb25maWdUeXBlKSA9PiBjb25maWdcbn07XG5cbi8vIEV4cG9ydCB1dGlsaXR5IGZ1bmN0aW9uc1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9haVNlcnZpY2UuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9hcHAuanMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscy9maWxlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvbG9nLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vdXRpbHMvcmVhY3RTaGltLmpzJztcblxuLy8gRXhwb3J0IFN0b3J5Ym9vayBtb2R1bGVcbmV4cG9ydCAqIGZyb20gJy4vc3Rvcnlib29rL2luZGV4LmpzJztcblxuLy8gRXhwb3J0IGNvbW1hbmRzXG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2FpL2FpLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvYnVpbGQvYnVpbGQuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jbGVhbi9jbGVhbi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbXBpbGUvY29tcGlsZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2NvbmZpZy9jb25maWcuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jb3B5L2NvcHkuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy9jcmVhdGUvY3JlYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvZGV2L2Rldi5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2luaXQvaW5pdC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbmsvbGluay5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL2xpbnQvbGludC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL21pZ3JhdGUvbWlncmF0ZS5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3B1Ymxpc2gvcHVibGlzaC5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3NlcnZlcmxlc3Mvc2VydmVybGVzcy5qcyc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1hbmRzL3N0b3J5Ym9vay9zdG9yeWJvb2suanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy90ZXN0L3Rlc3QuanMnO1xuZXhwb3J0ICogZnJvbSAnLi9jb21tYW5kcy91cGRhdGUvdXBkYXRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdXBncmFkZS91cGdyYWRlLmpzJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbWFuZHMvdmVyc2lvbnMvdmVyc2lvbnMuanMnO1xuIl0sIm5hbWVzIjpbImRlZmF1bHRDb25maWdWYWx1ZXMiLCJMZXhDb25maWciLCJDb25maWciLCJjcmVhdGUiLCJjb25maWciXSwibWFwcGluZ3MiOiJBQUFBOzs7Q0FHQyxHQUlELDZCQUE2QjtBQUM3QixjQUFjLGFBQWE7QUFFM0IsMkNBQTJDO0FBQzNDLFNBQ0VBLG1CQUFtQixFQUFFQyxTQUFTLFFBQ3pCLGlCQUFpQjtBQUV4Qiw2RkFBNkY7QUFDN0YsT0FBTyxNQUFNQyxTQUFTO0lBQ3BCQyxRQUFRLENBQUNDLFNBQTBCQTtBQUNyQyxFQUFFO0FBRUYsMkJBQTJCO0FBQzNCLGNBQWMsdUJBQXVCO0FBQ3JDLGNBQWMsaUJBQWlCO0FBQy9CLGNBQWMsa0JBQWtCO0FBQ2hDLGNBQWMsaUJBQWlCO0FBQy9CLGNBQWMsdUJBQXVCO0FBRXJDLDBCQUEwQjtBQUMxQixjQUFjLHVCQUF1QjtBQUVyQyxrQkFBa0I7QUFDbEIsY0FBYyxzQkFBc0I7QUFDcEMsY0FBYyw0QkFBNEI7QUFDMUMsY0FBYyw0QkFBNEI7QUFDMUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYyx3QkFBd0I7QUFDdEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxzQ0FBc0M7QUFDcEQsY0FBYyxvQ0FBb0M7QUFDbEQsY0FBYywwQkFBMEI7QUFDeEMsY0FBYyw4QkFBOEI7QUFDNUMsY0FBYyxnQ0FBZ0M7QUFDOUMsY0FBYyxrQ0FBa0MifQ==