@nlabs/lex 1.51.7 → 1.52.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.
@@ -96,4 +96,4 @@ export const Disabled = {
96
96
  }
97
97
  };
98
98
 
99
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9CdXR0b24uc3Rvcmllcy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHR5cGUge01ldGEsIFN0b3J5T2JqfSBmcm9tICdAc3Rvcnlib29rL3JlYWN0JztcblxuaW50ZXJmYWNlIEJ1dHRvblByb3BzIHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBvbkNsaWNrPzogKCkgPT4gdm9pZDtcbiAgc2l6ZT86ICdsZycgfCAnbWQnIHwgJ3NtJztcbiAgdmFyaWFudD86ICdvdXRsaW5lJyB8ICdwcmltYXJ5JyB8ICdzZWNvbmRhcnknO1xufVxuXG5jb25zdCBCdXR0b246IFJlYWN0LkZDPEJ1dHRvblByb3BzPiA9ICh7XG4gIGNoaWxkcmVuLFxuICBkaXNhYmxlZCA9IGZhbHNlLFxuICBvbkNsaWNrLFxuICBzaXplID0gJ21kJyxcbiAgdmFyaWFudCA9ICdwcmltYXJ5J1xufSkgPT4ge1xuICBjb25zdCBiYXNlQ2xhc3NlcyA9ICdmb250LW1lZGl1bSByb3VuZGVkLWxnIHRyYW5zaXRpb24tY29sb3JzIGR1cmF0aW9uLTIwMCBmb2N1czpvdXRsaW5lLW5vbmUgZm9jdXM6cmluZy0yIGZvY3VzOnJpbmctb2Zmc2V0LTInO1xuXG4gIGNvbnN0IHZhcmlhbnRDbGFzc2VzID0ge1xuICAgIG91dGxpbmU6ICdib3JkZXItMiBib3JkZXItYmx1ZS02MDAgdGV4dC1ibHVlLTYwMCBob3ZlcjpiZy1ibHVlLTUwIGZvY3VzOnJpbmctYmx1ZS01MDAnLFxuICAgIHByaW1hcnk6ICdiZy1ibHVlLTYwMCB0ZXh0LXdoaXRlIGhvdmVyOmJnLWJsdWUtNzAwIGZvY3VzOnJpbmctYmx1ZS01MDAnLFxuICAgIHNlY29uZGFyeTogJ2JnLWdyYXktNjAwIHRleHQtd2hpdGUgaG92ZXI6YmctZ3JheS03MDAgZm9jdXM6cmluZy1ncmF5LTUwMCdcbiAgfTtcblxuICBjb25zdCBzaXplQ2xhc3NlcyA9IHtcbiAgICBsZzogJ3B4LTYgcHktMyB0ZXh0LWxnJyxcbiAgICBtZDogJ3B4LTQgcHktMiB0ZXh0LWJhc2UnLFxuICAgIHNtOiAncHgtMyBweS0xLjUgdGV4dC1zbSdcbiAgfTtcblxuICBjb25zdCBkaXNhYmxlZENsYXNzZXMgPSBkaXNhYmxlZCA/ICdvcGFjaXR5LTUwIGN1cnNvci1ub3QtYWxsb3dlZCcgOiAnY3Vyc29yLXBvaW50ZXInO1xuXG4gIGNvbnN0IGNsYXNzZXMgPSBgJHtiYXNlQ2xhc3Nlc30gJHt2YXJpYW50Q2xhc3Nlc1t2YXJpYW50XX0gJHtzaXplQ2xhc3Nlc1tzaXplXX0gJHtkaXNhYmxlZENsYXNzZXN9YDtcblxuICByZXR1cm4gKFxuICAgIDxidXR0b25cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3Nlc31cbiAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvYnV0dG9uPlxuICApO1xufTtcblxuY29uc3QgbWV0YTogTWV0YTx0eXBlb2YgQnV0dG9uPiA9IHtcbiAgYXJnVHlwZXM6IHtcbiAgICBkaXNhYmxlZDoge1xuICAgICAgY29udHJvbDoge3R5cGU6ICdib29sZWFuJ31cbiAgICB9LFxuICAgIHNpemU6IHtcbiAgICAgIGNvbnRyb2w6IHt0eXBlOiAnc2VsZWN0J30sXG4gICAgICBvcHRpb25zOiBbJ3NtJywgJ21kJywgJ2xnJ11cbiAgICB9LFxuICAgIHZhcmlhbnQ6IHtcbiAgICAgIGNvbnRyb2w6IHt0eXBlOiAnc2VsZWN0J30sXG4gICAgICBvcHRpb25zOiBbJ3ByaW1hcnknLCAnc2Vjb25kYXJ5JywgJ291dGxpbmUnXVxuICAgIH1cbiAgfSxcbiAgY29tcG9uZW50OiBCdXR0b24sXG4gIHBhcmFtZXRlcnM6IHtcbiAgICBsYXlvdXQ6ICdjZW50ZXJlZCdcbiAgfSxcbiAgdGFnczogWydhdXRvZG9jcyddLFxuICB0aXRsZTogJ0NvbXBvbmVudHMvQnV0dG9uJ1xufTtcblxuZXhwb3J0IGRlZmF1bHQgbWV0YTtcbnR5cGUgU3RvcnkgPSBTdG9yeU9iajx0eXBlb2YgbWV0YT47XG5cbmV4cG9ydCBjb25zdCBQcmltYXJ5OiBTdG9yeSA9IHtcbiAgYXJnczoge1xuICAgIGNoaWxkcmVuOiAnUHJpbWFyeSBCdXR0b24nLFxuICAgIHZhcmlhbnQ6ICdwcmltYXJ5J1xuICB9XG59O1xuXG5leHBvcnQgY29uc3QgU2Vjb25kYXJ5OiBTdG9yeSA9IHtcbiAgYXJnczoge1xuICAgIGNoaWxkcmVuOiAnU2Vjb25kYXJ5IEJ1dHRvbicsXG4gICAgdmFyaWFudDogJ3NlY29uZGFyeSdcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IE91dGxpbmU6IFN0b3J5ID0ge1xuICBhcmdzOiB7XG4gICAgY2hpbGRyZW46ICdPdXRsaW5lIEJ1dHRvbicsXG4gICAgdmFyaWFudDogJ291dGxpbmUnXG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBTbWFsbDogU3RvcnkgPSB7XG4gIGFyZ3M6IHtcbiAgICBjaGlsZHJlbjogJ1NtYWxsIEJ1dHRvbicsXG4gICAgc2l6ZTogJ3NtJ1xuICB9XG59O1xuXG5leHBvcnQgY29uc3QgTGFyZ2U6IFN0b3J5ID0ge1xuICBhcmdzOiB7XG4gICAgY2hpbGRyZW46ICdMYXJnZSBCdXR0b24nLFxuICAgIHNpemU6ICdsZydcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IERpc2FibGVkOiBTdG9yeSA9IHtcbiAgYXJnczoge1xuICAgIGNoaWxkcmVuOiAnRGlzYWJsZWQgQnV0dG9uJyxcbiAgICBkaXNhYmxlZDogdHJ1ZVxuICB9XG59OyJdLCJuYW1lcyI6WyJSZWFjdCIsIkJ1dHRvbiIsImNoaWxkcmVuIiwiZGlzYWJsZWQiLCJvbkNsaWNrIiwic2l6ZSIsInZhcmlhbnQiLCJiYXNlQ2xhc3NlcyIsInZhcmlhbnRDbGFzc2VzIiwib3V0bGluZSIsInByaW1hcnkiLCJzZWNvbmRhcnkiLCJzaXplQ2xhc3NlcyIsImxnIiwibWQiLCJzbSIsImRpc2FibGVkQ2xhc3NlcyIsImNsYXNzZXMiLCJidXR0b24iLCJjbGFzc05hbWUiLCJtZXRhIiwiYXJnVHlwZXMiLCJjb250cm9sIiwidHlwZSIsIm9wdGlvbnMiLCJjb21wb25lbnQiLCJwYXJhbWV0ZXJzIiwibGF5b3V0IiwidGFncyIsInRpdGxlIiwiUHJpbWFyeSIsImFyZ3MiLCJTZWNvbmRhcnkiLCJPdXRsaW5lIiwiU21hbGwiLCJMYXJnZSIsIkRpc2FibGVkIl0sIm1hcHBpbmdzIjoiO0FBQUEsT0FBT0EsV0FBVyxRQUFRO0FBWTFCLE1BQU1DLFNBQWdDLENBQUMsRUFDckNDLFFBQVEsRUFDUkMsV0FBVyxLQUFLLEVBQ2hCQyxPQUFPLEVBQ1BDLE9BQU8sSUFBSSxFQUNYQyxVQUFVLFNBQVMsRUFDcEI7SUFDQyxNQUFNQyxjQUFjO0lBRXBCLE1BQU1DLGlCQUFpQjtRQUNyQkMsU0FBUztRQUNUQyxTQUFTO1FBQ1RDLFdBQVc7SUFDYjtJQUVBLE1BQU1DLGNBQWM7UUFDbEJDLElBQUk7UUFDSkMsSUFBSTtRQUNKQyxJQUFJO0lBQ047SUFFQSxNQUFNQyxrQkFBa0JiLFdBQVcsa0NBQWtDO0lBRXJFLE1BQU1jLFVBQVUsR0FBR1YsWUFBWSxDQUFDLEVBQUVDLGNBQWMsQ0FBQ0YsUUFBUSxDQUFDLENBQUMsRUFBRU0sV0FBVyxDQUFDUCxLQUFLLENBQUMsQ0FBQyxFQUFFVyxpQkFBaUI7SUFFbkcscUJBQ0UsS0FBQ0U7UUFDQ0MsV0FBV0Y7UUFDWGQsVUFBVUE7UUFDVkMsU0FBU0E7a0JBRVJGOztBQUdQO0FBRUEsTUFBTWtCLE9BQTRCO0lBQ2hDQyxVQUFVO1FBQ1JsQixVQUFVO1lBQ1JtQixTQUFTO2dCQUFDQyxNQUFNO1lBQVM7UUFDM0I7UUFDQWxCLE1BQU07WUFDSmlCLFNBQVM7Z0JBQUNDLE1BQU07WUFBUTtZQUN4QkMsU0FBUztnQkFBQztnQkFBTTtnQkFBTTthQUFLO1FBQzdCO1FBQ0FsQixTQUFTO1lBQ1BnQixTQUFTO2dCQUFDQyxNQUFNO1lBQVE7WUFDeEJDLFNBQVM7Z0JBQUM7Z0JBQVc7Z0JBQWE7YUFBVTtRQUM5QztJQUNGO0lBQ0FDLFdBQVd4QjtJQUNYeUIsWUFBWTtRQUNWQyxRQUFRO0lBQ1Y7SUFDQUMsTUFBTTtRQUFDO0tBQVc7SUFDbEJDLE9BQU87QUFDVDtBQUVBLGVBQWVULEtBQUs7QUFHcEIsT0FBTyxNQUFNVSxVQUFpQjtJQUM1QkMsTUFBTTtRQUNKN0IsVUFBVTtRQUNWSSxTQUFTO0lBQ1g7QUFDRixFQUFFO0FBRUYsT0FBTyxNQUFNMEIsWUFBbUI7SUFDOUJELE1BQU07UUFDSjdCLFVBQVU7UUFDVkksU0FBUztJQUNYO0FBQ0YsRUFBRTtBQUVGLE9BQU8sTUFBTTJCLFVBQWlCO0lBQzVCRixNQUFNO1FBQ0o3QixVQUFVO1FBQ1ZJLFNBQVM7SUFDWDtBQUNGLEVBQUU7QUFFRixPQUFPLE1BQU00QixRQUFlO0lBQzFCSCxNQUFNO1FBQ0o3QixVQUFVO1FBQ1ZHLE1BQU07SUFDUjtBQUNGLEVBQUU7QUFFRixPQUFPLE1BQU04QixRQUFlO0lBQzFCSixNQUFNO1FBQ0o3QixVQUFVO1FBQ1ZHLE1BQU07SUFDUjtBQUNGLEVBQUU7QUFFRixPQUFPLE1BQU0rQixXQUFrQjtJQUM3QkwsTUFBTTtRQUNKN0IsVUFBVTtRQUNWQyxVQUFVO0lBQ1o7QUFDRixFQUFFIn0=
99
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uL3NyYy9CdXR0b24uc3Rvcmllcy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHR5cGUge01ldGEsIFN0b3J5T2JqfSBmcm9tICdAc3Rvcnlib29rL3JlYWN0JztcblxuaW50ZXJmYWNlIEJ1dHRvblByb3BzIHtcbiAgY2hpbGRyZW46IFJlYWN0LlJlYWN0Tm9kZTtcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBvbkNsaWNrPzogKCk9PiB2b2lkO1xuICBzaXplPzogJ2xnJyB8ICdtZCcgfCAnc20nO1xuICB2YXJpYW50PzogJ291dGxpbmUnIHwgJ3ByaW1hcnknIHwgJ3NlY29uZGFyeSc7XG59XG5cbmNvbnN0IEJ1dHRvbjogUmVhY3QuRkM8QnV0dG9uUHJvcHM+ID0gKHtcbiAgY2hpbGRyZW4sXG4gIGRpc2FibGVkID0gZmFsc2UsXG4gIG9uQ2xpY2ssXG4gIHNpemUgPSAnbWQnLFxuICB2YXJpYW50ID0gJ3ByaW1hcnknXG59KSA9PiB7XG4gIGNvbnN0IGJhc2VDbGFzc2VzID0gJ2ZvbnQtbWVkaXVtIHJvdW5kZWQtbGcgdHJhbnNpdGlvbi1jb2xvcnMgZHVyYXRpb24tMjAwIGZvY3VzOm91dGxpbmUtbm9uZSBmb2N1czpyaW5nLTIgZm9jdXM6cmluZy1vZmZzZXQtMic7XG5cbiAgY29uc3QgdmFyaWFudENsYXNzZXMgPSB7XG4gICAgb3V0bGluZTogJ2JvcmRlci0yIGJvcmRlci1ibHVlLTYwMCB0ZXh0LWJsdWUtNjAwIGhvdmVyOmJnLWJsdWUtNTAgZm9jdXM6cmluZy1ibHVlLTUwMCcsXG4gICAgcHJpbWFyeTogJ2JnLWJsdWUtNjAwIHRleHQtd2hpdGUgaG92ZXI6YmctYmx1ZS03MDAgZm9jdXM6cmluZy1ibHVlLTUwMCcsXG4gICAgc2Vjb25kYXJ5OiAnYmctZ3JheS02MDAgdGV4dC13aGl0ZSBob3ZlcjpiZy1ncmF5LTcwMCBmb2N1czpyaW5nLWdyYXktNTAwJ1xuICB9O1xuXG4gIGNvbnN0IHNpemVDbGFzc2VzID0ge1xuICAgIGxnOiAncHgtNiBweS0zIHRleHQtbGcnLFxuICAgIG1kOiAncHgtNCBweS0yIHRleHQtYmFzZScsXG4gICAgc206ICdweC0zIHB5LTEuNSB0ZXh0LXNtJ1xuICB9O1xuXG4gIGNvbnN0IGRpc2FibGVkQ2xhc3NlcyA9IGRpc2FibGVkID8gJ29wYWNpdHktNTAgY3Vyc29yLW5vdC1hbGxvd2VkJyA6ICdjdXJzb3ItcG9pbnRlcic7XG5cbiAgY29uc3QgY2xhc3NlcyA9IGAke2Jhc2VDbGFzc2VzfSAke3ZhcmlhbnRDbGFzc2VzW3ZhcmlhbnRdfSAke3NpemVDbGFzc2VzW3NpemVdfSAke2Rpc2FibGVkQ2xhc3Nlc31gO1xuXG4gIHJldHVybiAoXG4gICAgPGJ1dHRvblxuICAgICAgY2xhc3NOYW1lPXtjbGFzc2VzfVxuICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9idXR0b24+XG4gICk7XG59O1xuXG5jb25zdCBtZXRhOiBNZXRhPHR5cGVvZiBCdXR0b24+ID0ge1xuICBhcmdUeXBlczoge1xuICAgIGRpc2FibGVkOiB7XG4gICAgICBjb250cm9sOiB7dHlwZTogJ2Jvb2xlYW4nfVxuICAgIH0sXG4gICAgc2l6ZToge1xuICAgICAgY29udHJvbDoge3R5cGU6ICdzZWxlY3QnfSxcbiAgICAgIG9wdGlvbnM6IFsnc20nLCAnbWQnLCAnbGcnXVxuICAgIH0sXG4gICAgdmFyaWFudDoge1xuICAgICAgY29udHJvbDoge3R5cGU6ICdzZWxlY3QnfSxcbiAgICAgIG9wdGlvbnM6IFsncHJpbWFyeScsICdzZWNvbmRhcnknLCAnb3V0bGluZSddXG4gICAgfVxuICB9LFxuICBjb21wb25lbnQ6IEJ1dHRvbixcbiAgcGFyYW1ldGVyczoge1xuICAgIGxheW91dDogJ2NlbnRlcmVkJ1xuICB9LFxuICB0YWdzOiBbJ2F1dG9kb2NzJ10sXG4gIHRpdGxlOiAnQ29tcG9uZW50cy9CdXR0b24nXG59O1xuXG5leHBvcnQgZGVmYXVsdCBtZXRhO1xudHlwZSBTdG9yeSA9IFN0b3J5T2JqPHR5cGVvZiBtZXRhPjtcblxuZXhwb3J0IGNvbnN0IFByaW1hcnk6IFN0b3J5ID0ge1xuICBhcmdzOiB7XG4gICAgY2hpbGRyZW46ICdQcmltYXJ5IEJ1dHRvbicsXG4gICAgdmFyaWFudDogJ3ByaW1hcnknXG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBTZWNvbmRhcnk6IFN0b3J5ID0ge1xuICBhcmdzOiB7XG4gICAgY2hpbGRyZW46ICdTZWNvbmRhcnkgQnV0dG9uJyxcbiAgICB2YXJpYW50OiAnc2Vjb25kYXJ5J1xuICB9XG59O1xuXG5leHBvcnQgY29uc3QgT3V0bGluZTogU3RvcnkgPSB7XG4gIGFyZ3M6IHtcbiAgICBjaGlsZHJlbjogJ091dGxpbmUgQnV0dG9uJyxcbiAgICB2YXJpYW50OiAnb3V0bGluZSdcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IFNtYWxsOiBTdG9yeSA9IHtcbiAgYXJnczoge1xuICAgIGNoaWxkcmVuOiAnU21hbGwgQnV0dG9uJyxcbiAgICBzaXplOiAnc20nXG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBMYXJnZTogU3RvcnkgPSB7XG4gIGFyZ3M6IHtcbiAgICBjaGlsZHJlbjogJ0xhcmdlIEJ1dHRvbicsXG4gICAgc2l6ZTogJ2xnJ1xuICB9XG59O1xuXG5leHBvcnQgY29uc3QgRGlzYWJsZWQ6IFN0b3J5ID0ge1xuICBhcmdzOiB7XG4gICAgY2hpbGRyZW46ICdEaXNhYmxlZCBCdXR0b24nLFxuICAgIGRpc2FibGVkOiB0cnVlXG4gIH1cbn07Il0sIm5hbWVzIjpbIlJlYWN0IiwiQnV0dG9uIiwiY2hpbGRyZW4iLCJkaXNhYmxlZCIsIm9uQ2xpY2siLCJzaXplIiwidmFyaWFudCIsImJhc2VDbGFzc2VzIiwidmFyaWFudENsYXNzZXMiLCJvdXRsaW5lIiwicHJpbWFyeSIsInNlY29uZGFyeSIsInNpemVDbGFzc2VzIiwibGciLCJtZCIsInNtIiwiZGlzYWJsZWRDbGFzc2VzIiwiY2xhc3NlcyIsImJ1dHRvbiIsImNsYXNzTmFtZSIsIm1ldGEiLCJhcmdUeXBlcyIsImNvbnRyb2wiLCJ0eXBlIiwib3B0aW9ucyIsImNvbXBvbmVudCIsInBhcmFtZXRlcnMiLCJsYXlvdXQiLCJ0YWdzIiwidGl0bGUiLCJQcmltYXJ5IiwiYXJncyIsIlNlY29uZGFyeSIsIk91dGxpbmUiLCJTbWFsbCIsIkxhcmdlIiwiRGlzYWJsZWQiXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPQSxXQUFXLFFBQVE7QUFZMUIsTUFBTUMsU0FBZ0MsQ0FBQyxFQUNyQ0MsUUFBUSxFQUNSQyxXQUFXLEtBQUssRUFDaEJDLE9BQU8sRUFDUEMsT0FBTyxJQUFJLEVBQ1hDLFVBQVUsU0FBUyxFQUNwQjtJQUNDLE1BQU1DLGNBQWM7SUFFcEIsTUFBTUMsaUJBQWlCO1FBQ3JCQyxTQUFTO1FBQ1RDLFNBQVM7UUFDVEMsV0FBVztJQUNiO0lBRUEsTUFBTUMsY0FBYztRQUNsQkMsSUFBSTtRQUNKQyxJQUFJO1FBQ0pDLElBQUk7SUFDTjtJQUVBLE1BQU1DLGtCQUFrQmIsV0FBVyxrQ0FBa0M7SUFFckUsTUFBTWMsVUFBVSxHQUFHVixZQUFZLENBQUMsRUFBRUMsY0FBYyxDQUFDRixRQUFRLENBQUMsQ0FBQyxFQUFFTSxXQUFXLENBQUNQLEtBQUssQ0FBQyxDQUFDLEVBQUVXLGlCQUFpQjtJQUVuRyxxQkFDRSxLQUFDRTtRQUNDQyxXQUFXRjtRQUNYZCxVQUFVQTtRQUNWQyxTQUFTQTtrQkFFUkY7O0FBR1A7QUFFQSxNQUFNa0IsT0FBNEI7SUFDaENDLFVBQVU7UUFDUmxCLFVBQVU7WUFDUm1CLFNBQVM7Z0JBQUNDLE1BQU07WUFBUztRQUMzQjtRQUNBbEIsTUFBTTtZQUNKaUIsU0FBUztnQkFBQ0MsTUFBTTtZQUFRO1lBQ3hCQyxTQUFTO2dCQUFDO2dCQUFNO2dCQUFNO2FBQUs7UUFDN0I7UUFDQWxCLFNBQVM7WUFDUGdCLFNBQVM7Z0JBQUNDLE1BQU07WUFBUTtZQUN4QkMsU0FBUztnQkFBQztnQkFBVztnQkFBYTthQUFVO1FBQzlDO0lBQ0Y7SUFDQUMsV0FBV3hCO0lBQ1h5QixZQUFZO1FBQ1ZDLFFBQVE7SUFDVjtJQUNBQyxNQUFNO1FBQUM7S0FBVztJQUNsQkMsT0FBTztBQUNUO0FBRUEsZUFBZVQsS0FBSztBQUdwQixPQUFPLE1BQU1VLFVBQWlCO0lBQzVCQyxNQUFNO1FBQ0o3QixVQUFVO1FBQ1ZJLFNBQVM7SUFDWDtBQUNGLEVBQUU7QUFFRixPQUFPLE1BQU0wQixZQUFtQjtJQUM5QkQsTUFBTTtRQUNKN0IsVUFBVTtRQUNWSSxTQUFTO0lBQ1g7QUFDRixFQUFFO0FBRUYsT0FBTyxNQUFNMkIsVUFBaUI7SUFDNUJGLE1BQU07UUFDSjdCLFVBQVU7UUFDVkksU0FBUztJQUNYO0FBQ0YsRUFBRTtBQUVGLE9BQU8sTUFBTTRCLFFBQWU7SUFDMUJILE1BQU07UUFDSjdCLFVBQVU7UUFDVkcsTUFBTTtJQUNSO0FBQ0YsRUFBRTtBQUVGLE9BQU8sTUFBTThCLFFBQWU7SUFDMUJKLE1BQU07UUFDSjdCLFVBQVU7UUFDVkcsTUFBTTtJQUNSO0FBQ0YsRUFBRTtBQUVGLE9BQU8sTUFBTStCLFdBQWtCO0lBQzdCTCxNQUFNO1FBQ0o3QixVQUFVO1FBQ1ZDLFVBQVU7SUFDWjtBQUNGLEVBQUUifQ==
@@ -124,7 +124,7 @@ export declare class LexConfig {
124
124
  static addConfigParams(cmd: any, params: LexConfigType): void;
125
125
  static parseConfig(cmd: any, isRoot?: boolean): Promise<void>;
126
126
  static checkTypescriptConfig(): void;
127
- static checkCompileTypescriptConfig(): void;
127
+ static getTypeScriptDeclarationFlags(): string[];
128
128
  static checkLintTypescriptConfig(): void;
129
129
  static checkTestTypescriptConfig(): void;
130
130
  }
package/lib/LexConfig.js CHANGED
@@ -15,7 +15,7 @@ function _define_property(obj, key, value) {
15
15
  * Copyright (c) 2018-Present, Nitrogen Labs, Inc.
16
16
  * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.
17
17
  */ import { existsSync, readFileSync, writeFileSync } from 'fs';
18
- import { dirname, extname as pathExtname, resolve as pathResolve } from 'path';
18
+ import { dirname, extname as pathExtname, relative as pathRelative, resolve as pathResolve } from 'path';
19
19
  import { URL } from 'url';
20
20
  import { getDirName, getLexPackageJsonPath, relativeFilePath } from './utils/file.js';
21
21
  import { log } from './utils/log.js';
@@ -42,6 +42,8 @@ export const defaultConfigValues = {
42
42
  sourceFullPath: pathResolve(cwd, './src'),
43
43
  sourcePath: './src',
44
44
  swc: {
45
+ inlineSourcesContent: true,
46
+ isModule: true,
45
47
  jsc: {
46
48
  externalHelpers: false,
47
49
  keepClassNames: false,
@@ -59,6 +61,7 @@ export const defaultConfigValues = {
59
61
  }
60
62
  }
61
63
  },
64
+ minify: false,
62
65
  module: {
63
66
  lazy: false,
64
67
  noInterop: false,
@@ -66,9 +69,6 @@ export const defaultConfigValues = {
66
69
  strictMode: true,
67
70
  type: 'es6'
68
71
  },
69
- inlineSourcesContent: true,
70
- isModule: true,
71
- minify: false,
72
72
  sourceMaps: 'inline'
73
73
  },
74
74
  targetEnvironment: 'web',
@@ -153,13 +153,18 @@ export class LexConfig {
153
153
  static addConfigParams(cmd, params) {
154
154
  const nameProperty = '_name';
155
155
  const { environment, outputPath, sourcePath, typescript } = cmd;
156
+ const currentCwd = process.cwd();
156
157
  if (outputPath !== undefined) {
157
158
  params.outputPath = outputPath;
158
- params.outputFullPath = pathResolve(cwd, outputPath);
159
+ params.outputFullPath = pathResolve(currentCwd, outputPath);
160
+ } else if (params.outputPath && !params.outputFullPath) {
161
+ params.outputFullPath = pathResolve(currentCwd, params.outputPath);
159
162
  }
160
163
  if (sourcePath !== undefined) {
161
164
  params.sourcePath = sourcePath;
162
- params.sourceFullPath = pathResolve(cwd, sourcePath);
165
+ params.sourceFullPath = pathResolve(currentCwd, sourcePath);
166
+ } else if (params.sourcePath && !params.sourceFullPath) {
167
+ params.sourceFullPath = pathResolve(currentCwd, params.sourcePath);
163
168
  }
164
169
  if (typescript !== undefined) {
165
170
  params.useTypescript = true;
@@ -271,15 +276,37 @@ export class LexConfig {
271
276
  writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));
272
277
  }
273
278
  }
274
- static checkCompileTypescriptConfig() {
275
- const lexDir = LexConfig.getLexDir();
276
- const tsconfigCompilePath = pathResolve(lexDir, './tsconfig.build.json');
277
- if (!existsSync(tsconfigCompilePath)) {
278
- const templatePath = pathResolve(lexDir, 'tsconfig.build.json');
279
- if (existsSync(templatePath)) {
280
- writeFileSync(tsconfigCompilePath, readFileSync(templatePath));
281
- }
282
- }
279
+ static getTypeScriptDeclarationFlags() {
280
+ const cwd = process.cwd();
281
+ const outputPath = LexConfig.config.outputPath || './lib';
282
+ const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);
283
+ const sourcePath = LexConfig.config.sourcePath || './src';
284
+ const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);
285
+ const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';
286
+ const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';
287
+ return [
288
+ '--emitDeclarationOnly',
289
+ '--declaration',
290
+ '--declarationMap',
291
+ '--outDir',
292
+ relativeOutDir,
293
+ '--rootDir',
294
+ relativeRootDir,
295
+ '--skipLibCheck',
296
+ '--esModuleInterop',
297
+ '--allowSyntheticDefaultImports',
298
+ '--module',
299
+ 'NodeNext',
300
+ '--moduleResolution',
301
+ 'NodeNext',
302
+ '--target',
303
+ 'ESNext',
304
+ '--jsx',
305
+ 'react-jsx',
306
+ '--isolatedModules',
307
+ '--resolveJsonModule',
308
+ '--allowJs'
309
+ ];
283
310
  }
284
311
  static checkLintTypescriptConfig() {
285
312
  const lexDir = LexConfig.getLexDir();
@@ -306,4 +333,4 @@ _define_property(LexConfig, "config", {
306
333
  ...defaultConfigValues
307
334
  });
308
335
 
309
- //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/LexConfig.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {dirname, extname as pathExtname, resolve as pathResolve} from 'path';\nimport {URL} from 'url';\n\nimport {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface JestConfig {\n  [key: string]: unknown;\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  transformIgnorePatterns?: string[];\n  moduleNameMapper?: Record<string, string>;\n  extensionsToTreatAsEsm?: string[];\n  preset?: string;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface SWCConfig {\n  jsc?: {\n    parser?: {\n      syntax?: 'typescript' | 'ecmascript';\n      tsx?: boolean;\n      decorators?: boolean;\n      dynamicImport?: boolean;\n    };\n    target?: 'es3' | 'es5' | 'es2015' | 'es2016' | 'es2017' | 'es2018' | 'es2019' | 'es2020' | 'es2021' | 'es2022' | 'es2023';\n    transform?: {\n      react?: {\n        runtime?: 'automatic' | 'classic';\n        pragma?: string;\n        pragmaFrag?: string;\n        throwIfNamespace?: boolean;\n        development?: boolean;\n        useBuiltins?: boolean;\n        refresh?: boolean;\n      };\n    };\n    externalHelpers?: boolean;\n    keepClassNames?: boolean;\n    loose?: boolean;\n    minify?: {\n      compress?: boolean;\n      mangle?: boolean;\n    };\n  };\n  module?: {\n    type?: 'es6' | 'commonjs' | 'amd' | 'umd' | 'systemjs';\n    strict?: boolean;\n    strictMode?: boolean;\n    lazy?: boolean;\n    noInterop?: boolean;\n  };\n  minify?: boolean;\n  sourceMaps?: boolean | 'inline';\n  inlineSourcesContent?: boolean;\n  isModule?: boolean;\n  filename?: string;\n  configFile?: string;\n  swcrc?: boolean;\n  env?: {\n    targets?: string | string[] | Record<string, string>;\n    mode?: 'usage' | 'entry';\n    coreJs?: string;\n    path?: string;\n    debug?: boolean;\n    dynamicImport?: boolean;\n    loose?: boolean;\n    bugfixes?: boolean;\n    include?: string[];\n    exclude?: string[];\n    forceAllTransforms?: boolean;\n    modules?: 'amd' | 'umd' | 'systemjs' | 'auto' | false;\n    shippedProposals?: boolean;\n  };\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  jest?: JestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  swc?: SWCConfig;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  jest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2020',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    inlineSourcesContent: true,\n    isModule: true,\n    minify: false,\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n  return pathResolve(lexDir, configName);\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {sourceFullPath} = LexConfig.config;\n\n    const {entryJs} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            // eslint-disable-next-line no-console\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = getDirName();\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n\n  static checkCompileTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigCompilePath: string = pathResolve(lexDir, './tsconfig.build.json');\n\n    if(!existsSync(tsconfigCompilePath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.build.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigCompilePath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}"],"names":["existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","resolve","pathResolve","URL","getDirName","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","jest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","module","lazy","noInterop","strict","strictMode","type","inlineSourcesContent","isModule","minify","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getTypeScriptConfigPath","configName","projectBuildConfig","projectLintConfig","projectTestConfig","projectConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","LEX_CONFIG","JSON","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configFormats","configBaseName","configPath","configExists","format","potentialPath","ext","configContent","configJson","parse","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","dirName","checkCompileTypescriptConfig","tsconfigCompilePath","templatePath","checkLintTypescriptConfig","tsconfigLintPath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}
336
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["../src/LexConfig.ts"],"sourcesContent":["/**\n * Copyright (c) 2018-Present, Nitrogen Labs, Inc.\n * Copyrights licensed under the MIT License. See the accompanying LICENSE file for terms.\n */\nimport {existsSync, readFileSync, writeFileSync} from 'fs';\nimport {\n  dirname,\n  extname as pathExtname,\n  relative as pathRelative,\n  resolve as pathResolve\n} from 'path';\nimport {URL} from 'url';\n\nimport {getDirName, getLexPackageJsonPath, relativeFilePath} from './utils/file.js';\nimport {log} from './utils/log.js';\n\nimport type {Linter} from 'eslint';\n\nconst cwd: string = process.cwd();\n\n\nexport interface JestConfig {\n  [key: string]: unknown;\n  roots?: string[];\n  testEnvironment?: string;\n  transform?: Record<string, [string, Record<string, unknown>]>;\n  transformIgnorePatterns?: string[];\n  moduleNameMapper?: Record<string, string>;\n  extensionsToTreatAsEsm?: string[];\n  preset?: string;\n}\n\nexport interface WebpackConfig {\n  [key: string]: unknown;\n  entry?: string | string[];\n  output?: Record<string, unknown>;\n  module?: Record<string, unknown>;\n  plugins?: unknown[];\n  staticPath?: string;\n}\n\nexport interface AIConfig {\n  provider?: 'cursor' | 'copilot' | 'openai' | 'anthropic' | 'none';\n  apiKey?: string;\n  model?: string;\n  maxTokens?: number;\n  temperature?: number;\n}\n\nexport interface ESLintConfig {\n  [key: string]: unknown;\n  extends?: string[];\n  rules?: Linter.RulesRecord;\n}\n\nexport interface SWCConfig {\n  jsc?: {\n    parser?: {\n      syntax?: 'typescript' | 'ecmascript';\n      tsx?: boolean;\n      decorators?: boolean;\n      dynamicImport?: boolean;\n    };\n    target?: 'es3' | 'es5' | 'es2015' | 'es2016' | 'es2017' | 'es2018' | 'es2019' | 'es2020' | 'es2021' | 'es2022' | 'es2023';\n    transform?: {\n      react?: {\n        runtime?: 'automatic' | 'classic';\n        pragma?: string;\n        pragmaFrag?: string;\n        throwIfNamespace?: boolean;\n        development?: boolean;\n        useBuiltins?: boolean;\n        refresh?: boolean;\n      };\n    };\n    externalHelpers?: boolean;\n    keepClassNames?: boolean;\n    loose?: boolean;\n    minify?: {\n      compress?: boolean;\n      mangle?: boolean;\n    };\n  };\n  module?: {\n    type?: 'es6' | 'commonjs' | 'amd' | 'umd' | 'systemjs';\n    strict?: boolean;\n    strictMode?: boolean;\n    lazy?: boolean;\n    noInterop?: boolean;\n  };\n  minify?: boolean;\n  sourceMaps?: boolean | 'inline';\n  inlineSourcesContent?: boolean;\n  isModule?: boolean;\n  filename?: string;\n  configFile?: string;\n  swcrc?: boolean;\n  env?: {\n    targets?: string | string[] | Record<string, string>;\n    mode?: 'usage' | 'entry';\n    coreJs?: string;\n    path?: string;\n    debug?: boolean;\n    dynamicImport?: boolean;\n    loose?: boolean;\n    bugfixes?: boolean;\n    include?: string[];\n    exclude?: string[];\n    forceAllTransforms?: boolean;\n    modules?: 'amd' | 'umd' | 'systemjs' | 'auto' | false;\n    shippedProposals?: boolean;\n  };\n}\n\nexport interface LexConfigType {\n  ai?: AIConfig;\n  configFiles?: string[];\n  copyFiles?: string[];\n  entryHTML?: string;\n  entryJs?: string;\n  env?: object;\n  eslint?: ESLintConfig;\n  gitUrl?: string;\n  jest?: JestConfig;\n  libraryName?: string;\n  libraryTarget?: string;\n  outputFile?: string;\n  outputFullPath?: string;\n  outputHash?: boolean;\n  outputPath?: string;\n  packageManager?: 'npm' | 'yarn';\n  preset?: 'web' | 'node' | 'lambda' | 'mobile';\n  sourceFullPath?: string;\n  sourcePath?: string;\n  swc?: SWCConfig;\n  targetEnvironment?: 'node' | 'web';\n  useGraphQl?: boolean;\n  useTypescript?: boolean;\n  webpack?: WebpackConfig;\n}\n\nexport type Config = LexConfigType;\n\nexport const defaultConfigValues: LexConfigType = {\n  ai: {\n    maxTokens: 4000,\n    model: 'gpt-4o',\n    provider: 'none',\n    temperature: 0.1\n  },\n  configFiles: [],\n  copyFiles: [],\n  entryHTML: 'index.html',\n  entryJs: 'index.js',\n  env: null,\n  eslint: {},\n  jest: {},\n  outputFullPath: pathResolve(cwd, './lib'),\n  outputHash: false,\n  outputPath: './lib',\n  packageManager: 'npm',\n  preset: 'web',\n  sourceFullPath: pathResolve(cwd, './src'),\n  sourcePath: './src',\n  swc: {\n    inlineSourcesContent: true,\n    isModule: true,\n    jsc: {\n      externalHelpers: false,\n      keepClassNames: false,\n      loose: false,\n      parser: {\n        decorators: true,\n        dynamicImport: true,\n        syntax: 'typescript',\n        tsx: true\n      },\n      target: 'es2020',\n      transform: {\n        react: {\n          runtime: 'automatic'\n        }\n      }\n    },\n    minify: false,\n    module: {\n      lazy: false,\n      noInterop: false,\n      strict: false,\n      strictMode: true,\n      type: 'es6'\n    },\n    sourceMaps: 'inline'\n  },\n  targetEnvironment: 'web',\n  useGraphQl: false,\n  useTypescript: false,\n  webpack: {\n    staticPath: './src/static'\n  }\n};\n\nexport const getTypeScriptConfigPath = (configName: string): string => {\n  const cwd = process.cwd();\n\n  if(configName === 'tsconfig.build.json') {\n    const projectBuildConfig = pathResolve(cwd, 'tsconfig.build.json');\n    if(existsSync(projectBuildConfig)) {\n      return projectBuildConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.lint.json') {\n    const projectLintConfig = pathResolve(cwd, 'tsconfig.eslint.json');\n    if(existsSync(projectLintConfig)) {\n      return projectLintConfig;\n    }\n  }\n\n  if(configName === 'tsconfig.test.json') {\n    const projectTestConfig = pathResolve(cwd, 'tsconfig.test.json');\n    if(existsSync(projectTestConfig)) {\n      return projectTestConfig;\n    }\n  }\n\n  const projectConfigPath = pathResolve(cwd, configName);\n  if(existsSync(projectConfigPath)) {\n    return projectConfigPath;\n  }\n\n  const lexDir = LexConfig.getLexDir();\n  return pathResolve(lexDir, configName);\n};\n\nexport class LexConfig {\n  static config: LexConfigType = {\n    ...defaultConfigValues\n  };\n\n  static set useTypescript(value: boolean) {\n    LexConfig.config.useTypescript = value;\n    const {sourceFullPath} = LexConfig.config;\n\n    const {entryJs} = LexConfig.config;\n\n    if(entryJs === 'index.js' && value) {\n      const indexPath: string = pathResolve(cwd, sourceFullPath, 'index.tsx');\n      const hasIndexTsx: boolean = existsSync(indexPath);\n\n      if(hasIndexTsx) {\n        LexConfig.config.entryJs = 'index.tsx';\n      } else {\n        LexConfig.config.entryJs = 'index.ts';\n      }\n    }\n  }\n\n  static getLexDir(): string {\n    return dirname(getLexPackageJsonPath());\n  }\n\n  static updateConfig(updatedConfig: LexConfigType): LexConfigType {\n    const {outputFullPath, outputPath, sourcePath, sourceFullPath, useTypescript, ai} = updatedConfig;\n    const cwd: string = process.cwd();\n\n    if(useTypescript !== undefined) {\n      LexConfig.useTypescript = useTypescript;\n    }\n\n    if(outputPath !== undefined && outputFullPath === undefined) {\n      updatedConfig.outputFullPath = pathResolve(cwd, outputPath);\n    }\n\n    if(sourcePath !== undefined && sourceFullPath === undefined) {\n      updatedConfig.sourceFullPath = pathResolve(cwd, sourcePath);\n    }\n\n    if(ai) {\n      LexConfig.config.ai = {...LexConfig.config.ai, ...ai};\n\n      if(process.env.CURSOR_IDE === 'true' && LexConfig.config.ai.provider === 'none') {\n        LexConfig.config.ai.provider = 'cursor';\n      }\n    }\n\n    LexConfig.config = {...LexConfig.config, ...updatedConfig};\n\n    return LexConfig.config;\n  }\n\n  static addConfigParams(cmd, params: LexConfigType) {\n    const nameProperty: string = '_name';\n    const {environment, outputPath, sourcePath, typescript} = cmd;\n    const currentCwd = process.cwd();\n\n    if(outputPath !== undefined) {\n      params.outputPath = outputPath;\n      params.outputFullPath = pathResolve(currentCwd, outputPath);\n    } else if(params.outputPath && !params.outputFullPath) {\n      params.outputFullPath = pathResolve(currentCwd, params.outputPath);\n    }\n\n    if(sourcePath !== undefined) {\n      params.sourcePath = sourcePath;\n      params.sourceFullPath = pathResolve(currentCwd, sourcePath);\n    } else if(params.sourcePath && !params.sourceFullPath) {\n      params.sourceFullPath = pathResolve(currentCwd, params.sourcePath);\n    }\n\n    if(typescript !== undefined) {\n      params.useTypescript = true;\n    }\n\n    if(environment !== undefined) {\n      params.targetEnvironment = environment === 'web' ? 'web' : 'node';\n    }\n\n    process.env.LEX_CONFIG = JSON.stringify(\n      {\n        ...LexConfig.updateConfig(params),\n        commandName: cmd[nameProperty],\n        isStatic: cmd.static\n      }, null, 0\n    );\n  }\n\n  static async parseConfig(cmd, isRoot: boolean = true): Promise<void> {\n    const {cliName = 'Lex', lexConfig, lexConfigName, quiet, typescript, debug = false} = cmd;\n    const configFormats = ['js', 'mjs', 'cjs', 'ts', 'json'];\n    const configBaseName: string = lexConfigName || 'lex.config';\n    let configPath: string = lexConfig || '';\n    let configExists: boolean = lexConfig ? existsSync(configPath) : false;\n\n    if(!configPath || !configExists) {\n      if(debug) {\n        log(`Searching for config files with base name: ${configBaseName}`, 'info', quiet);\n      }\n\n      for(const format of configFormats) {\n        const potentialPath = isRoot\n          ? pathResolve(cwd, `./${configBaseName}.${format}`)\n          : relativeFilePath(`${configBaseName}.${format}`, cwd);\n\n        if(debug) {\n          log(`Checking for config file: ${potentialPath}`, 'info', quiet);\n        }\n\n        if(existsSync(potentialPath)) {\n          configPath = potentialPath;\n          configExists = true;\n          break;\n        }\n      }\n    }\n\n    if(configExists) {\n      log(`Using ${cliName} configuration file: ${configPath}`, 'note', quiet);\n      const ext: string = pathExtname(configPath);\n\n      if(ext === '.json') {\n        const configContent: string = readFileSync(configPath, 'utf8');\n\n        if(configContent) {\n          let configJson: LexConfigType;\n\n          try {\n            configJson = JSON.parse(configContent)?.default || {};\n          } catch(error) {\n            log(`\\n${cliName} Error: Failed to parse JSON config: ${error.message}`, 'error', quiet);\n            configJson = {};\n          }\n\n          LexConfig.addConfigParams(cmd, configJson);\n        } else {\n          log(`\\n${cliName} Error: Config file malformed, ${configPath}`, 'error', quiet);\n        }\n      } else if(['.js', '.mjs', '.cjs', '.ts'].includes(ext)) {\n        try {\n          let lexCustomConfig;\n\n          if(ext === '.cjs') {\n            const fileUrl = new URL(`file:///${pathResolve(configPath)}`).href;\n\n            if(debug) {\n              log(`Loading CommonJS config from: ${fileUrl}`, 'info', quiet);\n            }\n            lexCustomConfig = await import(fileUrl);\n          } else {\n            if(debug) {\n              log(`Loading ESM/TS config from: ${configPath}`, 'info', quiet);\n            }\n\n            lexCustomConfig = await import(configPath);\n          }\n\n          const config = lexCustomConfig.default || lexCustomConfig;\n\n          if(debug) {\n            log(`Loaded config: ${JSON.stringify(config, null, 2)}`, 'info', quiet);\n          }\n\n          if(!config) {\n            log(`\\n${cliName} Warning: Config file loaded but no configuration found`, 'warn', quiet);\n          }\n\n          LexConfig.addConfigParams(cmd, config || {});\n        } catch(error) {\n          log(`\\n${cliName} Error: Failed to load config file: ${error.message}`, 'error', quiet);\n          if(debug) {\n            // eslint-disable-next-line no-console\n            console.error(error);\n          }\n        }\n      } else {\n        log(`\\n${cliName} Error: Config file must be a JS, CJS, MJS, TS, or JSON file.`, 'error', quiet);\n      }\n    } else {\n      if(debug) {\n        log('No config file found. Using default configuration.', 'info', quiet);\n      }\n\n      LexConfig.useTypescript = !!typescript;\n      LexConfig.addConfigParams(cmd, LexConfig.config);\n    }\n  }\n\n  static checkTypescriptConfig() {\n    const tsconfigPath: string = pathResolve(cwd, './tsconfig.json');\n\n    if(!existsSync(tsconfigPath)) {\n      const dirName = getDirName();\n      writeFileSync(tsconfigPath, readFileSync(pathResolve(dirName, '../../../tsconfig.base.json')));\n    }\n  }\n\n  static getTypeScriptDeclarationFlags(): string[] {\n    const cwd = process.cwd();\n    const outputPath = LexConfig.config.outputPath || './lib';\n    const outputFullPath = LexConfig.config.outputFullPath || pathResolve(cwd, outputPath);\n    const sourcePath = LexConfig.config.sourcePath || './src';\n    const sourceFullPath = LexConfig.config.sourceFullPath || pathResolve(cwd, sourcePath);\n    const relativeOutDir = pathRelative(cwd, outputFullPath) || './lib';\n    const relativeRootDir = pathRelative(cwd, sourceFullPath) || './src';\n\n    return [\n      '--emitDeclarationOnly', // CRITICAL: Only emit .d.ts files, no JS files\n      '--declaration', // Generate declaration files\n      '--declarationMap', // Generate source maps for declarations\n      '--outDir', relativeOutDir,\n      '--rootDir', relativeRootDir,\n      '--skipLibCheck', // Skip type checking of declaration files (faster, more lenient)\n      '--esModuleInterop',\n      '--allowSyntheticDefaultImports',\n      '--module', 'NodeNext',\n      '--moduleResolution', 'NodeNext',\n      '--target', 'ESNext',\n      '--jsx', 'react-jsx',\n      '--isolatedModules',\n      '--resolveJsonModule',\n      '--allowJs'\n      // Note: --noUnusedLocals and --noUnusedParameters are not needed for declaration generation\n      // and would actually enable strict checking, which we want to avoid for faster declaration generation\n    ];\n  }\n\n  static checkLintTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigLintPath: string = pathResolve(lexDir, './tsconfig.lint.json');\n\n    if(!existsSync(tsconfigLintPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.lint.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigLintPath, readFileSync(templatePath));\n      }\n    }\n  }\n\n  static checkTestTypescriptConfig() {\n    const lexDir = LexConfig.getLexDir();\n    const tsconfigTestPath: string = pathResolve(lexDir, './tsconfig.test.json');\n\n    if(!existsSync(tsconfigTestPath)) {\n      const templatePath = pathResolve(lexDir, 'tsconfig.test.json');\n      if(existsSync(templatePath)) {\n        writeFileSync(tsconfigTestPath, readFileSync(templatePath));\n      }\n    }\n  }\n}"],"names":["existsSync","readFileSync","writeFileSync","dirname","extname","pathExtname","relative","pathRelative","resolve","pathResolve","URL","getDirName","getLexPackageJsonPath","relativeFilePath","log","cwd","process","defaultConfigValues","ai","maxTokens","model","provider","temperature","configFiles","copyFiles","entryHTML","entryJs","env","eslint","jest","outputFullPath","outputHash","outputPath","packageManager","preset","sourceFullPath","sourcePath","swc","inlineSourcesContent","isModule","jsc","externalHelpers","keepClassNames","loose","parser","decorators","dynamicImport","syntax","tsx","target","transform","react","runtime","minify","module","lazy","noInterop","strict","strictMode","type","sourceMaps","targetEnvironment","useGraphQl","useTypescript","webpack","staticPath","getTypeScriptConfigPath","configName","projectBuildConfig","projectLintConfig","projectTestConfig","projectConfigPath","lexDir","LexConfig","getLexDir","value","config","indexPath","hasIndexTsx","updateConfig","updatedConfig","undefined","CURSOR_IDE","addConfigParams","cmd","params","nameProperty","environment","typescript","currentCwd","LEX_CONFIG","JSON","stringify","commandName","isStatic","static","parseConfig","isRoot","cliName","lexConfig","lexConfigName","quiet","debug","configFormats","configBaseName","configPath","configExists","format","potentialPath","ext","configContent","configJson","parse","default","error","message","includes","lexCustomConfig","fileUrl","href","console","checkTypescriptConfig","tsconfigPath","dirName","getTypeScriptDeclarationFlags","relativeOutDir","relativeRootDir","checkLintTypescriptConfig","tsconfigLintPath","templatePath","checkTestTypescriptConfig","tsconfigTestPath"],"mappings":"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"}