mrpj 0.1.98 → 0.1.100

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 (40) hide show
  1. package/.jsii +421 -312
  2. package/API.md +117 -0
  3. package/lib/construct-project-options.d.ts +12 -0
  4. package/lib/construct-project-options.js +1 -1
  5. package/lib/construct-project.js +1 -1
  6. package/lib/features/automation.d.ts +2 -2
  7. package/lib/features/automation.js +1 -1
  8. package/lib/features/dependencies.d.ts +3 -3
  9. package/lib/features/dependencies.js +1 -1
  10. package/lib/features/eslint.d.ts +2 -2
  11. package/lib/features/eslint.js +4 -3
  12. package/lib/features/force-defaults.d.ts +1 -1
  13. package/lib/features/force-defaults.js +1 -1
  14. package/lib/features/logo.d.ts +4 -3
  15. package/lib/features/logo.js +1 -1
  16. package/lib/features/node-version.d.ts +2 -2
  17. package/lib/features/node-version.js +1 -1
  18. package/lib/features/package-info.d.ts +1 -1
  19. package/lib/features/package-info.js +1 -1
  20. package/lib/features/release.d.ts +2 -2
  21. package/lib/features/release.js +1 -1
  22. package/lib/logo/Logo.d.ts +1 -1
  23. package/lib/logo/Logo.js +2 -2
  24. package/lib/logo/SvgFile.d.ts +2 -1
  25. package/lib/logo/SvgFile.js +2 -2
  26. package/lib/logo/Wordmark.d.ts +3 -2
  27. package/lib/logo/Wordmark.js +2 -2
  28. package/lib/logo/private.ts/logo-task.d.ts +1 -1
  29. package/lib/logo/private.ts/logo-task.js +1 -1
  30. package/lib/projen-project-options.d.ts +12 -0
  31. package/lib/projen-project-options.js +1 -1
  32. package/lib/projen-project.d.ts +2 -2
  33. package/lib/projen-project.js +2 -2
  34. package/lib/typescript-project-options.d.ts +12 -0
  35. package/lib/typescript-project-options.js +1 -1
  36. package/lib/typescript-project.d.ts +2 -2
  37. package/lib/typescript-project.js +2 -2
  38. package/lib/utils.d.ts +1 -1
  39. package/lib/utils.js +1 -1
  40. package/package.json +4 -4
@@ -13,4 +13,4 @@ const featureMiddleware = (project, options) => {
13
13
  return project;
14
14
  };
15
15
  exports.featureMiddleware = featureMiddleware;
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nby5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mZWF0dXJlcy9sb2dvLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUNBLGtDQUE0QztBQVNyQyxNQUFNLGlCQUFpQixHQUF1RCxDQUFDLE9BQU8sRUFBRSxPQUErRCxFQUFFLEVBQUU7SUFDaEssSUFBSSxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUIsT0FBTyxDQUFDLFFBQVEsR0FBRyxJQUFJLGVBQVEsQ0FBQyxPQUFPLEVBQUU7WUFDdkMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxJQUFJO1lBQ2xCLEdBQUcsT0FBTyxDQUFDLGVBQWU7U0FDM0IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU8sT0FBTyxDQUFDO0FBQ2pCLENBQUMsQ0FBQztBQVZXLFFBQUEsaUJBQWlCLHFCQVU1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByb2plY3QgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgU3ZnRmlsZSwgV29yZG1hcmsgfSBmcm9tICcuLi9sb2dvJztcbmltcG9ydCB7IFByb2plblByb2plY3RPcHRpb25zIH0gZnJvbSAnLi4vcHJvamVuLXByb2plY3Qtb3B0aW9ucyc7XG5pbXBvcnQgeyBGZWF0dXJlTWlkZGxld2FyZSwgTXV0YWJsZSB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGludGVyZmFjZSBQcm9qZWN0VHJhaXQge1xuICByZWFkb25seSBsb2dvPzogU3ZnRmlsZTtcbiAgcmVhZG9ubHkgd29yZG1hcms/OiBXb3JkbWFyaztcbn1cblxuZXhwb3J0IGNvbnN0IGZlYXR1cmVNaWRkbGV3YXJlOiBGZWF0dXJlTWlkZGxld2FyZTxQcm9qZWN0ICYgTXV0YWJsZTxQcm9qZWN0VHJhaXQ+PiA9IChwcm9qZWN0LCBvcHRpb25zOiBQaWNrPFByb2plblByb2plY3RPcHRpb25zLCAnbG9nbycgfCAnd29yZG1hcmtPcHRpb25zJz4pID0+IHtcbiAgaWYgKG9wdGlvbnMubG9nbykge1xuICAgIG9wdGlvbnMubG9nby5zeW50aChwcm9qZWN0KTtcbiAgICBwcm9qZWN0LndvcmRtYXJrID0gbmV3IFdvcmRtYXJrKHByb2plY3QsIHtcbiAgICAgIGxvZ286IG9wdGlvbnMubG9nbyxcbiAgICAgIC4uLm9wdGlvbnMud29yZG1hcmtPcHRpb25zLFxuICAgIH0pO1xuICB9XG5cbiAgcmV0dXJuIHByb2plY3Q7XG59O1xuIl19
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nby5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mZWF0dXJlcy9sb2dvLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLGtDQUFtQztBQVM1QixNQUFNLGlCQUFpQixHQUF1RCxDQUFDLE9BQU8sRUFBRSxPQUErRCxFQUFFLEVBQUU7SUFDaEssSUFBSSxPQUFPLENBQUMsSUFBSSxFQUFFLENBQUM7UUFDakIsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDNUIsT0FBTyxDQUFDLFFBQVEsR0FBRyxJQUFJLGVBQVEsQ0FBQyxPQUFPLEVBQUU7WUFDdkMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxJQUFJO1lBQ2xCLEdBQUcsT0FBTyxDQUFDLGVBQWU7U0FDM0IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE9BQU8sT0FBTyxDQUFDO0FBQ2pCLENBQUMsQ0FBQztBQVZXLFFBQUEsaUJBQWlCLHFCQVU1QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgUHJvamVjdCB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgdHlwZSB7IFN2Z0ZpbGUgfSBmcm9tICcuLi9sb2dvJztcbmltcG9ydCB7IFdvcmRtYXJrIH0gZnJvbSAnLi4vbG9nbyc7XG5pbXBvcnQgdHlwZSB7IFByb2plblByb2plY3RPcHRpb25zIH0gZnJvbSAnLi4vcHJvamVuLXByb2plY3Qtb3B0aW9ucyc7XG5pbXBvcnQgdHlwZSB7IEZlYXR1cmVNaWRkbGV3YXJlLCBNdXRhYmxlIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFByb2plY3RUcmFpdCB7XG4gIHJlYWRvbmx5IGxvZ28/OiBTdmdGaWxlO1xuICByZWFkb25seSB3b3JkbWFyaz86IFdvcmRtYXJrO1xufVxuXG5leHBvcnQgY29uc3QgZmVhdHVyZU1pZGRsZXdhcmU6IEZlYXR1cmVNaWRkbGV3YXJlPFByb2plY3QgJiBNdXRhYmxlPFByb2plY3RUcmFpdD4+ID0gKHByb2plY3QsIG9wdGlvbnM6IFBpY2s8UHJvamVuUHJvamVjdE9wdGlvbnMsICdsb2dvJyB8ICd3b3JkbWFya09wdGlvbnMnPikgPT4ge1xuICBpZiAob3B0aW9ucy5sb2dvKSB7XG4gICAgb3B0aW9ucy5sb2dvLnN5bnRoKHByb2plY3QpO1xuICAgIHByb2plY3Qud29yZG1hcmsgPSBuZXcgV29yZG1hcmsocHJvamVjdCwge1xuICAgICAgbG9nbzogb3B0aW9ucy5sb2dvLFxuICAgICAgLi4ub3B0aW9ucy53b3JkbWFya09wdGlvbnMsXG4gICAgfSk7XG4gIH1cblxuICByZXR1cm4gcHJvamVjdDtcbn07XG4iXX0=
@@ -1,5 +1,5 @@
1
- import { Project } from 'projen';
2
- import { FeatureMiddleware } from '../utils';
1
+ import type { Project } from 'projen';
2
+ import type { FeatureMiddleware } from '../utils';
3
3
  export interface ProjectTrait {
4
4
  readonly minNodeVersion?: string;
5
5
  }
@@ -12,4 +12,4 @@ const featureMiddleware = (project, options) => {
12
12
  return project;
13
13
  };
14
14
  exports.featureMiddleware = featureMiddleware;
15
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS12ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZlYXR1cmVzL25vZGUtdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxtQ0FBMkM7QUFPcEMsTUFBTSxpQkFBaUIsR0FBOEMsQ0FBQyxPQUFPLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDL0YsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLG1CQUFtQixJQUFJLE9BQU8sQ0FBQyxjQUFjLElBQUksSUFBSSxDQUFDO0lBQzlFLE1BQU0sS0FBSyxHQUFHLENBQUMsSUFBSSxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUVsQyxJQUFJLGlCQUFRLENBQUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDM0MsT0FBTyxDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ25DLElBQUksaUJBQVEsQ0FBQyxPQUFPLEVBQUUsZUFBZSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNsRCxPQUFPLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDLENBQUM7SUFFMUMsT0FBTyxPQUFPLENBQUM7QUFDakIsQ0FBQyxDQUFDO0FBVlcsUUFBQSxpQkFBaUIscUJBVTVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJvamVjdCwgVGV4dEZpbGUgfSBmcm9tICdwcm9qZW4nO1xuaW1wb3J0IHsgRmVhdHVyZU1pZGRsZXdhcmUgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvamVjdFRyYWl0IHtcbiAgcmVhZG9ubHkgbWluTm9kZVZlcnNpb24/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBmZWF0dXJlTWlkZGxld2FyZTogRmVhdHVyZU1pZGRsZXdhcmU8UHJvamVjdCAmIFByb2plY3RUcmFpdD4gPSAocHJvamVjdCwgb3B0aW9ucykgPT4ge1xuICBjb25zdCB2ZXJzaW9uID0gb3B0aW9ucy53b3JrZmxvd05vZGVWZXJzaW9uID8/IHByb2plY3QubWluTm9kZVZlcnNpb24gPz8gJzE4JztcbiAgY29uc3QgbGluZXMgPSBbYHYke3ZlcnNpb259YCwgJyddO1xuXG4gIG5ldyBUZXh0RmlsZShwcm9qZWN0LCAnLm52bXJjJywgeyBsaW5lcyB9KTtcbiAgcHJvamVjdC5hZGRQYWNrYWdlSWdub3JlKCcubnZtcmMnKTtcbiAgbmV3IFRleHRGaWxlKHByb2plY3QsICcubm9kZS12ZXJzaW9uJywgeyBsaW5lcyB9KTtcbiAgcHJvamVjdC5hZGRQYWNrYWdlSWdub3JlKCcubm9kZS12ZXJzaW9uJyk7XG5cbiAgcmV0dXJuIHByb2plY3Q7XG59O1xuIl19
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS12ZXJzaW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZlYXR1cmVzL25vZGUtdmVyc2lvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSxtQ0FBa0M7QUFPM0IsTUFBTSxpQkFBaUIsR0FBOEMsQ0FBQyxPQUFPLEVBQUUsT0FBTyxFQUFFLEVBQUU7SUFDL0YsTUFBTSxPQUFPLEdBQUcsT0FBTyxDQUFDLG1CQUFtQixJQUFJLE9BQU8sQ0FBQyxjQUFjLElBQUksSUFBSSxDQUFDO0lBQzlFLE1BQU0sS0FBSyxHQUFHLENBQUMsSUFBSSxPQUFPLEVBQUUsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUVsQyxJQUFJLGlCQUFRLENBQUMsT0FBTyxFQUFFLFFBQVEsRUFBRSxFQUFFLEtBQUssRUFBRSxDQUFDLENBQUM7SUFDM0MsT0FBTyxDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ25DLElBQUksaUJBQVEsQ0FBQyxPQUFPLEVBQUUsZUFBZSxFQUFFLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUNsRCxPQUFPLENBQUMsZ0JBQWdCLENBQUMsZUFBZSxDQUFDLENBQUM7SUFFMUMsT0FBTyxPQUFPLENBQUM7QUFDakIsQ0FBQyxDQUFDO0FBVlcsUUFBQSxpQkFBaUIscUJBVTVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBQcm9qZWN0IH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IFRleHRGaWxlIH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB0eXBlIHsgRmVhdHVyZU1pZGRsZXdhcmUgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvamVjdFRyYWl0IHtcbiAgcmVhZG9ubHkgbWluTm9kZVZlcnNpb24/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBmZWF0dXJlTWlkZGxld2FyZTogRmVhdHVyZU1pZGRsZXdhcmU8UHJvamVjdCAmIFByb2plY3RUcmFpdD4gPSAocHJvamVjdCwgb3B0aW9ucykgPT4ge1xuICBjb25zdCB2ZXJzaW9uID0gb3B0aW9ucy53b3JrZmxvd05vZGVWZXJzaW9uID8/IHByb2plY3QubWluTm9kZVZlcnNpb24gPz8gJzE4JztcbiAgY29uc3QgbGluZXMgPSBbYHYke3ZlcnNpb259YCwgJyddO1xuXG4gIG5ldyBUZXh0RmlsZShwcm9qZWN0LCAnLm52bXJjJywgeyBsaW5lcyB9KTtcbiAgcHJvamVjdC5hZGRQYWNrYWdlSWdub3JlKCcubnZtcmMnKTtcbiAgbmV3IFRleHRGaWxlKHByb2plY3QsICcubm9kZS12ZXJzaW9uJywgeyBsaW5lcyB9KTtcbiAgcHJvamVjdC5hZGRQYWNrYWdlSWdub3JlKCcubm9kZS12ZXJzaW9uJyk7XG5cbiAgcmV0dXJuIHByb2plY3Q7XG59O1xuIl19
@@ -1,4 +1,4 @@
1
- import { OptionsMiddleware } from '../utils';
1
+ import type { OptionsMiddleware } from '../utils';
2
2
  export interface RepoInfoTrait {
3
3
  readonly repo: string;
4
4
  }
@@ -21,4 +21,4 @@ function githubUser(options) {
21
21
  return options.repo.split('/')[0];
22
22
  }
23
23
  exports.githubUser = githubUser;
24
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFja2FnZS1pbmZvLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZlYXR1cmVzL3BhY2thZ2UtaW5mby50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxvQ0FBd0Q7QUFNeEQsU0FBZ0IsY0FBYyxDQUFDLFVBQWtCLEtBQUs7SUFDcEQsT0FBTyxDQUFDLE9BQU8sRUFBRSxFQUFFO1FBQ2pCLE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVqQyxPQUFPLElBQUEsaUJBQVMsRUFBQztZQUNmLElBQUksRUFBRSxJQUFJLE9BQU8sQ0FBQyxJQUFJLEVBQUU7WUFDeEIsYUFBYSxFQUFFLGtCQUFrQixPQUFPLENBQUMsSUFBSSxNQUFNO1lBQ25ELFVBQVUsRUFBRSxrQkFBa0IsT0FBTyxDQUFDLElBQUksTUFBTTtZQUNoRCxRQUFRLEVBQUUsc0JBQXNCLE9BQU8sQ0FBQyxJQUFJLEVBQUU7WUFDOUMsYUFBYSxFQUFFLHNCQUFzQixJQUFJLEVBQUU7WUFDM0MsU0FBUyxFQUFFLHNCQUFzQixJQUFJLEVBQUU7WUFDdkMsT0FBTztTQUNSLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDZCxDQUFDLENBQUM7QUFDSixDQUFDO0FBZEQsd0NBY0M7QUFFRCxTQUFnQixVQUFVLENBQUMsT0FBc0I7SUFDL0MsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNwQyxDQUFDO0FBRkQsZ0NBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPcHRpb25zTWlkZGxld2FyZSwgZGVlcE1lcmdlIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFJlcG9JbmZvVHJhaXQge1xuICByZWFkb25seSByZXBvOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBtYWtlTWlkZGxld2FyZShsaWNlbnNlOiBzdHJpbmcgPSAnTUlUJyk6IE9wdGlvbnNNaWRkbGV3YXJlPFJlcG9JbmZvVHJhaXQ+IHtcbiAgcmV0dXJuIChvcHRpb25zKSA9PiB7XG4gICAgY29uc3QgdXNlciA9IGdpdGh1YlVzZXIob3B0aW9ucyk7XG5cbiAgICByZXR1cm4gZGVlcE1lcmdlKHtcbiAgICAgIG5hbWU6IGBAJHtvcHRpb25zLnJlcG99YCxcbiAgICAgIHJlcG9zaXRvcnlVcmw6IGBnaXRAZ2l0aHViLmNvbToke29wdGlvbnMucmVwb30uZ2l0YCxcbiAgICAgIHJlcG9zaXRvcnk6IGBnaXRAZ2l0aHViLmNvbToke29wdGlvbnMucmVwb30uZ2l0YCxcbiAgICAgIGhvbWVwYWdlOiBgaHR0cHM6Ly9naXRodWIuY29tLyR7b3B0aW9ucy5yZXBvfWAsXG4gICAgICBhdXRob3JBZGRyZXNzOiBgaHR0cHM6Ly9naXRodWIuY29tLyR7dXNlcn1gLFxuICAgICAgYXV0aG9yVXJsOiBgaHR0cHM6Ly9naXRodWIuY29tLyR7dXNlcn1gLFxuICAgICAgbGljZW5zZSxcbiAgICB9LCBvcHRpb25zKTtcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdpdGh1YlVzZXIob3B0aW9uczogUmVwb0luZm9UcmFpdCk6IHN0cmluZyB7XG4gIHJldHVybiBvcHRpb25zLnJlcG8uc3BsaXQoJy8nKVswXTtcbn1cbiJdfQ==
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFja2FnZS1pbmZvLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2ZlYXR1cmVzL3BhY2thZ2UtaW5mby50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSxvQ0FBcUM7QUFNckMsU0FBZ0IsY0FBYyxDQUFDLFVBQWtCLEtBQUs7SUFDcEQsT0FBTyxDQUFDLE9BQU8sRUFBRSxFQUFFO1FBQ2pCLE1BQU0sSUFBSSxHQUFHLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVqQyxPQUFPLElBQUEsaUJBQVMsRUFBQztZQUNmLElBQUksRUFBRSxJQUFJLE9BQU8sQ0FBQyxJQUFJLEVBQUU7WUFDeEIsYUFBYSxFQUFFLGtCQUFrQixPQUFPLENBQUMsSUFBSSxNQUFNO1lBQ25ELFVBQVUsRUFBRSxrQkFBa0IsT0FBTyxDQUFDLElBQUksTUFBTTtZQUNoRCxRQUFRLEVBQUUsc0JBQXNCLE9BQU8sQ0FBQyxJQUFJLEVBQUU7WUFDOUMsYUFBYSxFQUFFLHNCQUFzQixJQUFJLEVBQUU7WUFDM0MsU0FBUyxFQUFFLHNCQUFzQixJQUFJLEVBQUU7WUFDdkMsT0FBTztTQUNSLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDZCxDQUFDLENBQUM7QUFDSixDQUFDO0FBZEQsd0NBY0M7QUFFRCxTQUFnQixVQUFVLENBQUMsT0FBc0I7SUFDL0MsT0FBTyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztBQUNwQyxDQUFDO0FBRkQsZ0NBRUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IE9wdGlvbnNNaWRkbGV3YXJlIH0gZnJvbSAnLi4vdXRpbHMnO1xuaW1wb3J0IHsgZGVlcE1lcmdlIH0gZnJvbSAnLi4vdXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFJlcG9JbmZvVHJhaXQge1xuICByZWFkb25seSByZXBvOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBtYWtlTWlkZGxld2FyZShsaWNlbnNlOiBzdHJpbmcgPSAnTUlUJyk6IE9wdGlvbnNNaWRkbGV3YXJlPFJlcG9JbmZvVHJhaXQ+IHtcbiAgcmV0dXJuIChvcHRpb25zKSA9PiB7XG4gICAgY29uc3QgdXNlciA9IGdpdGh1YlVzZXIob3B0aW9ucyk7XG5cbiAgICByZXR1cm4gZGVlcE1lcmdlKHtcbiAgICAgIG5hbWU6IGBAJHtvcHRpb25zLnJlcG99YCxcbiAgICAgIHJlcG9zaXRvcnlVcmw6IGBnaXRAZ2l0aHViLmNvbToke29wdGlvbnMucmVwb30uZ2l0YCxcbiAgICAgIHJlcG9zaXRvcnk6IGBnaXRAZ2l0aHViLmNvbToke29wdGlvbnMucmVwb30uZ2l0YCxcbiAgICAgIGhvbWVwYWdlOiBgaHR0cHM6Ly9naXRodWIuY29tLyR7b3B0aW9ucy5yZXBvfWAsXG4gICAgICBhdXRob3JBZGRyZXNzOiBgaHR0cHM6Ly9naXRodWIuY29tLyR7dXNlcn1gLFxuICAgICAgYXV0aG9yVXJsOiBgaHR0cHM6Ly9naXRodWIuY29tLyR7dXNlcn1gLFxuICAgICAgbGljZW5zZSxcbiAgICB9LCBvcHRpb25zKTtcbiAgfTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGdpdGh1YlVzZXIob3B0aW9uczogUmVwb0luZm9UcmFpdCk6IHN0cmluZyB7XG4gIHJldHVybiBvcHRpb25zLnJlcG8uc3BsaXQoJy8nKVswXTtcbn1cbiJdfQ==
@@ -1,5 +1,5 @@
1
- import { TypeScriptProjectOptions } from '../typescript-project-options';
2
- import { OptionsMiddleware } from '../utils';
1
+ import type { TypeScriptProjectOptions } from '../typescript-project-options';
2
+ import type { OptionsMiddleware } from '../utils';
3
3
  export interface ReleaseOptionsTrait {
4
4
  readonly projenrcTsOptions?: TypeScriptProjectOptions['projenrcTsOptions'];
5
5
  readonly releasableCommitTypes?: string[];
@@ -17,4 +17,4 @@ const optionsMiddleware = (options) => (0, utils_1.deepMerge)({
17
17
  }, options);
18
18
  exports.optionsMiddleware = optionsMiddleware;
19
19
  exports.RELEASABLE_COMMIT_TYPES_DEFAULT = ['feat', 'fix', 'chore', 'revert'];
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsZWFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mZWF0dXJlcy9yZWxlYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG1DQUF1RDtBQUV2RCxvQ0FBbUU7QUFPNUQsTUFBTSxpQkFBaUIsR0FBMkMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLElBQUEsaUJBQVMsRUFBQztJQUM5RixPQUFPLEVBQUUsS0FBSztJQUNkLG9CQUFvQixFQUFFLE1BQU07SUFDNUIsWUFBWSxFQUFFLElBQUk7SUFDbEIsU0FBUyxFQUFFLG1CQUFVLENBQUMsU0FBUyxDQUFDLE1BQU07SUFDdEMsU0FBUyxFQUFFLElBQUEsaUJBQVMsRUFBQztRQUNuQixPQUFPLENBQUMsaUJBQWlCLEVBQUUsUUFBUSxJQUFJLGNBQWM7UUFDckQsT0FBTyxDQUFDLGlCQUFpQixFQUFFLGFBQWEsSUFBSSxVQUFVO1FBQ3RELGdCQUFnQjtLQUNqQixDQUFDO0lBQ0YsaUJBQWlCLEVBQUUsMEJBQWlCLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxDQUFDLHFCQUFxQixJQUFJLHVDQUErQixDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsR0FBRyxDQUFDO0NBQzVILEVBQUUsT0FBTyxDQUFDLENBQUM7QUFYQyxRQUFBLGlCQUFpQixxQkFXbEI7QUFFQyxRQUFBLCtCQUErQixHQUFHLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsUUFBUSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWxlYXNhYmxlQ29tbWl0cywgamF2YXNjcmlwdCB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgeyBUeXBlU2NyaXB0UHJvamVjdE9wdGlvbnMgfSBmcm9tICcuLi90eXBlc2NyaXB0LXByb2plY3Qtb3B0aW9ucyc7XG5pbXBvcnQgeyBPcHRpb25zTWlkZGxld2FyZSwgZGVlcE1lcmdlLCBub0VtcHRpZXMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVsZWFzZU9wdGlvbnNUcmFpdCB7XG4gIHJlYWRvbmx5IHByb2plbnJjVHNPcHRpb25zPzogVHlwZVNjcmlwdFByb2plY3RPcHRpb25zWydwcm9qZW5yY1RzT3B0aW9ucyddO1xuICByZWFkb25seSByZWxlYXNhYmxlQ29tbWl0VHlwZXM/OiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGNvbnN0IG9wdGlvbnNNaWRkbGV3YXJlOiBPcHRpb25zTWlkZGxld2FyZTxSZWxlYXNlT3B0aW9uc1RyYWl0PiA9IChvcHRpb25zKSA9PiBkZWVwTWVyZ2Uoe1xuICByZWxlYXNlOiBmYWxzZSxcbiAgZGVmYXVsdFJlbGVhc2VCcmFuY2g6ICdtYWluJyxcbiAgcmVsZWFzZVRvTnBtOiB0cnVlLFxuICBucG1BY2Nlc3M6IGphdmFzY3JpcHQuTnBtQWNjZXNzLlBVQkxJQyxcbiAgbnBtaWdub3JlOiBub0VtcHRpZXMoW1xuICAgIG9wdGlvbnMucHJvamVucmNUc09wdGlvbnM/LmZpbGVuYW1lID8/ICcucHJvamVucmMudHMnLFxuICAgIG9wdGlvbnMucHJvamVucmNUc09wdGlvbnM/LnByb2plbkNvZGVEaXIgPz8gJ3Byb2plbnJjJyxcbiAgICAnLmdpdGF0dHJpYnV0ZXMnLFxuICBdKSxcbiAgcmVsZWFzYWJsZUNvbW1pdHM6IFJlbGVhc2FibGVDb21taXRzLm9mVHlwZSgob3B0aW9ucy5yZWxlYXNhYmxlQ29tbWl0VHlwZXMgPz8gUkVMRUFTQUJMRV9DT01NSVRfVFlQRVNfREVGQVVMVCkuc29ydCgpLCAnLicpLFxufSwgb3B0aW9ucyk7XG5cbmV4cG9ydCBjb25zdCBSRUxFQVNBQkxFX0NPTU1JVF9UWVBFU19ERUZBVUxUID0gWydmZWF0JywgJ2ZpeCcsICdjaG9yZScsICdyZXZlcnQnXTtcbiJdfQ==
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVsZWFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9mZWF0dXJlcy9yZWxlYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLG1DQUF1RDtBQUd2RCxvQ0FBZ0Q7QUFPekMsTUFBTSxpQkFBaUIsR0FBMkMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLElBQUEsaUJBQVMsRUFBQztJQUM5RixPQUFPLEVBQUUsS0FBSztJQUNkLG9CQUFvQixFQUFFLE1BQU07SUFDNUIsWUFBWSxFQUFFLElBQUk7SUFDbEIsU0FBUyxFQUFFLG1CQUFVLENBQUMsU0FBUyxDQUFDLE1BQU07SUFDdEMsU0FBUyxFQUFFLElBQUEsaUJBQVMsRUFBQztRQUNuQixPQUFPLENBQUMsaUJBQWlCLEVBQUUsUUFBUSxJQUFJLGNBQWM7UUFDckQsT0FBTyxDQUFDLGlCQUFpQixFQUFFLGFBQWEsSUFBSSxVQUFVO1FBQ3RELGdCQUFnQjtLQUNqQixDQUFDO0lBQ0YsaUJBQWlCLEVBQUUsMEJBQWlCLENBQUMsTUFBTSxDQUFDLENBQUMsT0FBTyxDQUFDLHFCQUFxQixJQUFJLHVDQUErQixDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsR0FBRyxDQUFDO0NBQzVILEVBQUUsT0FBTyxDQUFDLENBQUM7QUFYQyxRQUFBLGlCQUFpQixxQkFXbEI7QUFFQyxRQUFBLCtCQUErQixHQUFHLENBQUMsTUFBTSxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsUUFBUSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSZWxlYXNhYmxlQ29tbWl0cywgamF2YXNjcmlwdCB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgdHlwZSB7IFR5cGVTY3JpcHRQcm9qZWN0T3B0aW9ucyB9IGZyb20gJy4uL3R5cGVzY3JpcHQtcHJvamVjdC1vcHRpb25zJztcbmltcG9ydCB0eXBlIHsgT3B0aW9uc01pZGRsZXdhcmUgfSBmcm9tICcuLi91dGlscyc7XG5pbXBvcnQgeyBkZWVwTWVyZ2UsIG5vRW1wdGllcyB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGludGVyZmFjZSBSZWxlYXNlT3B0aW9uc1RyYWl0IHtcbiAgcmVhZG9ubHkgcHJvamVucmNUc09wdGlvbnM/OiBUeXBlU2NyaXB0UHJvamVjdE9wdGlvbnNbJ3Byb2plbnJjVHNPcHRpb25zJ107XG4gIHJlYWRvbmx5IHJlbGVhc2FibGVDb21taXRUeXBlcz86IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgY29uc3Qgb3B0aW9uc01pZGRsZXdhcmU6IE9wdGlvbnNNaWRkbGV3YXJlPFJlbGVhc2VPcHRpb25zVHJhaXQ+ID0gKG9wdGlvbnMpID0+IGRlZXBNZXJnZSh7XG4gIHJlbGVhc2U6IGZhbHNlLFxuICBkZWZhdWx0UmVsZWFzZUJyYW5jaDogJ21haW4nLFxuICByZWxlYXNlVG9OcG06IHRydWUsXG4gIG5wbUFjY2VzczogamF2YXNjcmlwdC5OcG1BY2Nlc3MuUFVCTElDLFxuICBucG1pZ25vcmU6IG5vRW1wdGllcyhbXG4gICAgb3B0aW9ucy5wcm9qZW5yY1RzT3B0aW9ucz8uZmlsZW5hbWUgPz8gJy5wcm9qZW5yYy50cycsXG4gICAgb3B0aW9ucy5wcm9qZW5yY1RzT3B0aW9ucz8ucHJvamVuQ29kZURpciA/PyAncHJvamVucmMnLFxuICAgICcuZ2l0YXR0cmlidXRlcycsXG4gIF0pLFxuICByZWxlYXNhYmxlQ29tbWl0czogUmVsZWFzYWJsZUNvbW1pdHMub2ZUeXBlKChvcHRpb25zLnJlbGVhc2FibGVDb21taXRUeXBlcyA/PyBSRUxFQVNBQkxFX0NPTU1JVF9UWVBFU19ERUZBVUxUKS5zb3J0KCksICcuJyksXG59LCBvcHRpb25zKTtcblxuZXhwb3J0IGNvbnN0IFJFTEVBU0FCTEVfQ09NTUlUX1RZUEVTX0RFRkFVTFQgPSBbJ2ZlYXQnLCAnZml4JywgJ2Nob3JlJywgJ3JldmVydCddO1xuIl19
@@ -1,4 +1,4 @@
1
- import { Project } from 'projen';
1
+ import type { Project } from 'projen';
2
2
  /**
3
3
  * Provide additional configuration for the logo.
4
4
  */
package/lib/logo/Logo.js CHANGED
@@ -102,5 +102,5 @@ class Logo {
102
102
  }
103
103
  exports.Logo = Logo;
104
104
  _a = JSII_RTTI_SYMBOL_1;
105
- Logo[_a] = { fqn: "mrpj.logo.Logo", version: "0.1.98" };
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Logo.js","sourceRoot":"","sources":["../../src/logo/Logo.ts"],"names":[],"mappings":"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","sourcesContent":["import { readFileSync } from 'fs';\nimport { Project } from 'projen';\nimport { logoToPngTask } from './private.ts/logo-task';\nimport { SvgFile } from './SvgFile';\n\n/**\n * Provide additional configuration for the logo.\n */\nexport interface LogoConfig {\n  /**\n   * The width of the logo in px.\n   */\n  readonly width: number;\n  /**\n   * The height of the logo in px.\n   */\n  readonly height: number;\n  /**\n   * Scale the logo by a factor.\n   * @default 1\n   */\n  readonly scale?: number;\n}\n\n/**\n * All required information to represent a logo.\n */\nexport interface LogoInfo extends LogoConfig {\n  /**\n   * The SVG content of the logo as a string.\n   **/\n  readonly content: string;\n}\n\n/**\n * Options to create a logo from an SVG string.\n */\nexport interface LogoFromContentOptions extends LogoConfig {\n  /**\n   * The path where the logo file will be created.\n   */\n  readonly outFile?: string;\n}\n\n/**\n * Options to create a logo from an SVG string.\n */\nexport interface LogoForProjenOptions {\n  /**\n   * The path where the logo file will be created.\n   */\n  readonly outFile?: string;\n  /**\n   * The hex code for the color of the parcel outline.\n   * @default \"#66200b\"\n   */\n  readonly outlineColor?: string;\n  /**\n   * The hex code for the color of the packaging tape.\n   * @default \"#cbdada\"\n   */\n  readonly tapeColor?: string;\n  /**\n   * The hex code for the color of the front of the box.\n   * @default \"#fa983c\"\n   */\n  readonly frontColor?: string;\n  /**\n   * The hex code for the color of the top of the box.\n   * @default \"#fcc161\"\n   */\n  readonly topColor?: string;\n  /**\n   * The icon in front of the parcel box.\n   * @default - no icon\n   */\n  readonly icon?: string;\n  /**\n   * SVG transform for the icon.\n   * Likely needed to position the icon correctly.\n   */\n  readonly iconTransform?: string;\n}\n\ninterface LogoFromOptions extends LogoConfig {\n  readonly sourceFile?: string;\n  readonly outFile?: string;\n}\n\n/**\n * Implementation interface of a logo\n */\nexport interface ILogo {\n  /**\n   * The width of the logo in px.\n   */\n  readonly width: number;\n  /**\n   * The height of the logo in px.\n   */\n  readonly height: number;\n  /**\n   * Scale the logo by a factor.\n   * @default 1\n   */\n  readonly scale?: number;\n  /**\n   * The SVG content of the logo as a string.\n   **/\n  readonly content: string;\n  /**\n   * Synth the logo.\n   */\n  synth(project: Project): void;\n}\n\n/**\n * Create a logo for the project.\n */\nexport class Logo implements ILogo {\n  /**\n   * Use an existing logo from a file.\n   */\n  public static fromFile(path: string, options: LogoConfig) {\n    const content = readFileSync(path).toString().trim();\n    return new Logo(content, {\n      ...options,\n      sourceFile: path,\n    });\n  }\n\n  /**\n   * Create the logo from this svg snippet.\n   * Content should NOT include the outermost <svg> tag.\n   */\n  public static fromContent(content: string, options: LogoFromContentOptions) {\n    return new Logo(content, {\n      outFile: 'images/logo.svg',\n      ...options,\n    });\n  }\n\n  /**\n   * An empty placeholder logo.\n   * Can be used the get started before a logo is created.\n   */\n  public static placeholder(path: string = 'images/logo.svg') {\n    const content = `<rect fill=\"#AAAAAA\" width=\"80\" height=\"80\" />\n    <line x1=\"0\" x2=\"80\" y1=\"0\" y2=\"80\" stroke=\"red\" stroke-width=\"2\" />\n    <line x1=\"80\" x2=\"0\" y1=\"0\" y2=\"80\" stroke=\"red\" stroke-width=\"2\" />`;\n\n    return new Logo(content, {\n      outFile: path,\n      width: 80,\n      height: 80,\n    });\n  }\n\n  /**\n   * A logo for projen related projects.\n   */\n  public static forProjen(path: string = 'images/logo.svg', options: LogoForProjenOptions = {}) {\n    const {\n      topColor = '#fcc161',\n      frontColor = '#fa983c',\n      tapeColor = '#cbdada',\n      outlineColor = '#66200b',\n      icon,\n      iconTransform,\n    } = options;\n\n    const iconGroupTransform = iconTransform ? ` transform=\"${iconTransform}\"` : '';\n    const iconGroup = icon ? `<g id=\"icon\"${iconGroupTransform}>${icon}</g>` : '';\n\n    const content = `<g transform=\"translate(4 19)\" shape-rendering=\"crispEdges\">\n    <!-- fill -->\n    <path d=\"m 0,0 l 10,-15.6 h 60 l 10,15.6 z\" fill=\"${topColor}\" />\n    <path d=\"m 0,0 h 80 v 65 h -80 z\" fill=\"${frontColor}\" />\n\n    <!-- lines -->\n    <g stroke-width=\"2.5\" stroke=\"${outlineColor}\">\n        <!-- outline -->\n        <path d=\"m 0,0 l 10,-15.6 h 60 l 10,15.6 v 65 h -80 z\" fill-opacity=\"0\" />\n\n        <!-- tape -->\n        <path d=\"m 30,0 v 12 l 5,-3 5,3 5,-3 5,3 v -12 l -4.5,-15.6 -11,0 z\" fill=\"${tapeColor}\" stroke-linejoin=\"bevel\" />\n\n        <!-- front line -->\n        <line x1=\"0\" x2=\"80\" y1=\"0\" y2=\"0\" />\n    </g>\n\n    <!-- Custom Icon -->\n    ${iconGroup}\n</g>`;\n\n    return new Logo(content, {\n      outFile: path,\n      width: 88,\n      height: 88,\n    });\n  }\n\n  public readonly width: number;\n  public readonly height: number;\n  public readonly scale?: number;\n  public readonly content: string;\n\n  private readonly outFile?: string;\n  private readonly sourceFile?: string;\n\n  private constructor(content: string, options: LogoFromOptions) {\n    this.content = content;\n    this.width = options.width;\n    this.height = options.height;\n    this.scale= options.scale;\n\n    this.sourceFile = options.sourceFile;\n    this.outFile = options.outFile;\n  }\n\n  public synth(project: Project) {\n    if (this.sourceFile) {\n      project.addPackageIgnore(this.sourceFile);\n    }\n    if (this.outFile) {\n      project.addPackageIgnore(this.outFile);\n    }\n\n    if (!this.outFile) {\n      logoToPngTask(project, this.sourceFile!);\n      return;\n    }\n\n    const svg = new SvgFile(project, this.outFile, this);\n    logoToPngTask(project, svg.filePath);\n  }\n}\n"]}
105
+ Logo[_a] = { fqn: "mrpj.logo.Logo", version: "0.1.100" };
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Logo.js","sourceRoot":"","sources":["../../src/logo/Logo.ts"],"names":[],"mappings":"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","sourcesContent":["import { readFileSync } from 'fs';\nimport type { Project } from 'projen';\nimport { logoToPngTask } from './private.ts/logo-task';\nimport { SvgFile } from './SvgFile';\n\n/**\n * Provide additional configuration for the logo.\n */\nexport interface LogoConfig {\n  /**\n   * The width of the logo in px.\n   */\n  readonly width: number;\n  /**\n   * The height of the logo in px.\n   */\n  readonly height: number;\n  /**\n   * Scale the logo by a factor.\n   * @default 1\n   */\n  readonly scale?: number;\n}\n\n/**\n * All required information to represent a logo.\n */\nexport interface LogoInfo extends LogoConfig {\n  /**\n   * The SVG content of the logo as a string.\n   **/\n  readonly content: string;\n}\n\n/**\n * Options to create a logo from an SVG string.\n */\nexport interface LogoFromContentOptions extends LogoConfig {\n  /**\n   * The path where the logo file will be created.\n   */\n  readonly outFile?: string;\n}\n\n/**\n * Options to create a logo from an SVG string.\n */\nexport interface LogoForProjenOptions {\n  /**\n   * The path where the logo file will be created.\n   */\n  readonly outFile?: string;\n  /**\n   * The hex code for the color of the parcel outline.\n   * @default \"#66200b\"\n   */\n  readonly outlineColor?: string;\n  /**\n   * The hex code for the color of the packaging tape.\n   * @default \"#cbdada\"\n   */\n  readonly tapeColor?: string;\n  /**\n   * The hex code for the color of the front of the box.\n   * @default \"#fa983c\"\n   */\n  readonly frontColor?: string;\n  /**\n   * The hex code for the color of the top of the box.\n   * @default \"#fcc161\"\n   */\n  readonly topColor?: string;\n  /**\n   * The icon in front of the parcel box.\n   * @default - no icon\n   */\n  readonly icon?: string;\n  /**\n   * SVG transform for the icon.\n   * Likely needed to position the icon correctly.\n   */\n  readonly iconTransform?: string;\n}\n\ninterface LogoFromOptions extends LogoConfig {\n  readonly sourceFile?: string;\n  readonly outFile?: string;\n}\n\n/**\n * Implementation interface of a logo\n */\nexport interface ILogo {\n  /**\n   * The width of the logo in px.\n   */\n  readonly width: number;\n  /**\n   * The height of the logo in px.\n   */\n  readonly height: number;\n  /**\n   * Scale the logo by a factor.\n   * @default 1\n   */\n  readonly scale?: number;\n  /**\n   * The SVG content of the logo as a string.\n   **/\n  readonly content: string;\n  /**\n   * Synth the logo.\n   */\n  synth(project: Project): void;\n}\n\n/**\n * Create a logo for the project.\n */\nexport class Logo implements ILogo {\n  /**\n   * Use an existing logo from a file.\n   */\n  public static fromFile(path: string, options: LogoConfig) {\n    const content = readFileSync(path).toString().trim();\n    return new Logo(content, {\n      ...options,\n      sourceFile: path,\n    });\n  }\n\n  /**\n   * Create the logo from this svg snippet.\n   * Content should NOT include the outermost <svg> tag.\n   */\n  public static fromContent(content: string, options: LogoFromContentOptions) {\n    return new Logo(content, {\n      outFile: 'images/logo.svg',\n      ...options,\n    });\n  }\n\n  /**\n   * An empty placeholder logo.\n   * Can be used the get started before a logo is created.\n   */\n  public static placeholder(path: string = 'images/logo.svg') {\n    const content = `<rect fill=\"#AAAAAA\" width=\"80\" height=\"80\" />\n    <line x1=\"0\" x2=\"80\" y1=\"0\" y2=\"80\" stroke=\"red\" stroke-width=\"2\" />\n    <line x1=\"80\" x2=\"0\" y1=\"0\" y2=\"80\" stroke=\"red\" stroke-width=\"2\" />`;\n\n    return new Logo(content, {\n      outFile: path,\n      width: 80,\n      height: 80,\n    });\n  }\n\n  /**\n   * A logo for projen related projects.\n   */\n  public static forProjen(path: string = 'images/logo.svg', options: LogoForProjenOptions = {}) {\n    const {\n      topColor = '#fcc161',\n      frontColor = '#fa983c',\n      tapeColor = '#cbdada',\n      outlineColor = '#66200b',\n      icon,\n      iconTransform,\n    } = options;\n\n    const iconGroupTransform = iconTransform ? ` transform=\"${iconTransform}\"` : '';\n    const iconGroup = icon ? `<g id=\"icon\"${iconGroupTransform}>${icon}</g>` : '';\n\n    const content = `<g transform=\"translate(4 19)\" shape-rendering=\"crispEdges\">\n    <!-- fill -->\n    <path d=\"m 0,0 l 10,-15.6 h 60 l 10,15.6 z\" fill=\"${topColor}\" />\n    <path d=\"m 0,0 h 80 v 65 h -80 z\" fill=\"${frontColor}\" />\n\n    <!-- lines -->\n    <g stroke-width=\"2.5\" stroke=\"${outlineColor}\">\n        <!-- outline -->\n        <path d=\"m 0,0 l 10,-15.6 h 60 l 10,15.6 v 65 h -80 z\" fill-opacity=\"0\" />\n\n        <!-- tape -->\n        <path d=\"m 30,0 v 12 l 5,-3 5,3 5,-3 5,3 v -12 l -4.5,-15.6 -11,0 z\" fill=\"${tapeColor}\" stroke-linejoin=\"bevel\" />\n\n        <!-- front line -->\n        <line x1=\"0\" x2=\"80\" y1=\"0\" y2=\"0\" />\n    </g>\n\n    <!-- Custom Icon -->\n    ${iconGroup}\n</g>`;\n\n    return new Logo(content, {\n      outFile: path,\n      width: 88,\n      height: 88,\n    });\n  }\n\n  public readonly width: number;\n  public readonly height: number;\n  public readonly scale?: number;\n  public readonly content: string;\n\n  private readonly outFile?: string;\n  private readonly sourceFile?: string;\n\n  private constructor(content: string, options: LogoFromOptions) {\n    this.content = content;\n    this.width = options.width;\n    this.height = options.height;\n    this.scale= options.scale;\n\n    this.sourceFile = options.sourceFile;\n    this.outFile = options.outFile;\n  }\n\n  public synth(project: Project) {\n    if (this.sourceFile) {\n      project.addPackageIgnore(this.sourceFile);\n    }\n    if (this.outFile) {\n      project.addPackageIgnore(this.outFile);\n    }\n\n    if (!this.outFile) {\n      logoToPngTask(project, this.sourceFile!);\n      return;\n    }\n\n    const svg = new SvgFile(project, this.outFile, this);\n    logoToPngTask(project, svg.filePath);\n  }\n}\n"]}
@@ -1,4 +1,5 @@
1
- import { Project, SourceCode, SourceCodeOptions } from 'projen';
1
+ import type { Project, SourceCodeOptions } from 'projen';
2
+ import { SourceCode } from 'projen';
2
3
  /**
3
4
  * Options for SvgFile
4
5
  */
@@ -37,5 +37,5 @@ class SvgFile extends projen_1.SourceCode {
37
37
  }
38
38
  exports.SvgFile = SvgFile;
39
39
  _a = JSII_RTTI_SYMBOL_1;
40
- SvgFile[_a] = { fqn: "mrpj.logo.SvgFile", version: "0.1.98" };
41
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3ZnRmlsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9sb2dvL1N2Z0ZpbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxtQ0FBZ0U7QUFhaEU7O0dBRUc7QUFDSCxNQUFhLE9BQVEsU0FBUSxtQkFBVTtJQUNyQyxZQUFtQixPQUFnQixFQUFFLFFBQWdCLEVBQUUsT0FBdUI7UUFDNUUsS0FBSyxDQUFDLE9BQU8sRUFBRSxRQUFRLEVBQUU7WUFDdkIsTUFBTSxFQUFFLENBQUM7WUFDVCxHQUFHLE9BQU87U0FDWCxDQUFDLENBQUM7UUFFSCxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxLQUFLLEdBQUcsQ0FBQyxFQUFFLEdBQUcsT0FBTyxDQUFDO1FBRTdDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsTUFBTSxNQUFNLENBQUMsQ0FBQztRQUNyQyxJQUFJLENBQUMsSUFBSSxDQUFDLGtEQUFrRCxLQUFLLEdBQUcsS0FBSyxhQUFhLE1BQU0sR0FBRyxLQUFLLGtCQUFrQixLQUFLLElBQUksTUFBTSxJQUFJLENBQUMsQ0FBQztRQUMzSSxJQUFJLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNsQixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3JCLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzFCLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDdkIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ2QsQ0FBQztRQUNELElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNsQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7SUFFRDs7O09BR0c7SUFDSyxLQUFLLENBQUMsS0FBYTtRQUN6QixLQUFLLE1BQU0sSUFBSSxJQUFJLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUNyQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2xCLENBQUM7SUFDSCxDQUFDOztBQTdCSCwwQkE4QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9qZWN0LCBTb3VyY2VDb2RlLCBTb3VyY2VDb2RlT3B0aW9ucyB9IGZyb20gJ3Byb2plbic7XG5cbi8qKlxuICogT3B0aW9ucyBmb3IgU3ZnRmlsZVxuICovXG5leHBvcnQgaW50ZXJmYWNlIFN2Z0ZpbGVPcHRpb25zIGV4dGVuZHMgU291cmNlQ29kZU9wdGlvbnMge1xuICByZWFkb25seSB3aWR0aDogbnVtYmVyO1xuICByZWFkb25seSBoZWlnaHQ6IG51bWJlcjtcbiAgcmVhZG9ubHkgc2NhbGU/OiBudW1iZXI7XG4gIHJlYWRvbmx5IHN0eWxlPzogc3RyaW5nO1xuICByZWFkb25seSBjb250ZW50Pzogc3RyaW5nO1xufVxuXG4vKipcbiAqIEEgU1ZHIGZpbGVcbiAqL1xuZXhwb3J0IGNsYXNzIFN2Z0ZpbGUgZXh0ZW5kcyBTb3VyY2VDb2RlIHtcbiAgcHVibGljIGNvbnN0cnVjdG9yKHByb2plY3Q6IFByb2plY3QsIGZpbGVQYXRoOiBzdHJpbmcsIG9wdGlvbnM6IFN2Z0ZpbGVPcHRpb25zKSB7XG4gICAgc3VwZXIocHJvamVjdCwgZmlsZVBhdGgsIHtcbiAgICAgIGluZGVudDogNCxcbiAgICAgIC4uLm9wdGlvbnMsXG4gICAgfSk7XG5cbiAgICBjb25zdCB7IHdpZHRoLCBoZWlnaHQsIHNjYWxlID0gMSB9ID0gb3B0aW9ucztcblxuICAgIHRoaXMubGluZShgPCEtLSAke3RoaXMubWFya2VyfSAtLT5gKTtcbiAgICB0aGlzLm9wZW4oYDxzdmcgeG1sbnM9XCJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2Z1wiIHdpZHRoPVwiJHt3aWR0aCAqIHNjYWxlfVwiIGhlaWdodD1cIiR7aGVpZ2h0ICogc2NhbGV9XCIgdmlld0JveD1cIjAgMCAke3dpZHRofSAke2hlaWdodH1cIj5gKTtcbiAgICBpZiAob3B0aW9ucy5zdHlsZSkge1xuICAgICAgdGhpcy5vcGVuKCc8c3R5bGU+Jyk7XG4gICAgICB0aGlzLmxpbmVzKG9wdGlvbnMuc3R5bGUpO1xuICAgICAgdGhpcy5jbG9zZSgnPC9zdHlsZT4nKTtcbiAgICAgIHRoaXMubGluZSgpO1xuICAgIH1cbiAgICB0aGlzLmxpbmVzKG9wdGlvbnMuY29udGVudCA/PyAnJyk7XG4gICAgdGhpcy5jbG9zZSgnPC9zdmc+Jyk7XG4gIH1cblxuICAvKipcbiAgICogQWRkcyB0ZXh0IGFzIGxpbmVzIHRvIHRoZSB0ZXh0IGZpbGUuXG4gICAqIEBwYXJhbSBsaW5lcyB0aGUgdGV4dCB3aXRoIGxpbmUgYnJlYWtzIHRvIGFkZFxuICAgKi9cbiAgcHJpdmF0ZSBsaW5lcyhsaW5lczogc3RyaW5nKSB7XG4gICAgZm9yIChjb25zdCBsaW5lIG9mIGxpbmVzLnNwbGl0KCdcXG4nKSkge1xuICAgICAgdGhpcy5saW5lKGxpbmUpO1xuICAgIH1cbiAgfVxufVxuIl19
40
+ SvgFile[_a] = { fqn: "mrpj.logo.SvgFile", version: "0.1.100" };
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3ZnRmlsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9sb2dvL1N2Z0ZpbGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFDQSxtQ0FBb0M7QUFhcEM7O0dBRUc7QUFDSCxNQUFhLE9BQVEsU0FBUSxtQkFBVTtJQUNyQyxZQUFtQixPQUFnQixFQUFFLFFBQWdCLEVBQUUsT0FBdUI7UUFDNUUsS0FBSyxDQUFDLE9BQU8sRUFBRSxRQUFRLEVBQUU7WUFDdkIsTUFBTSxFQUFFLENBQUM7WUFDVCxHQUFHLE9BQU87U0FDWCxDQUFDLENBQUM7UUFFSCxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxLQUFLLEdBQUcsQ0FBQyxFQUFFLEdBQUcsT0FBTyxDQUFDO1FBRTdDLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxJQUFJLENBQUMsTUFBTSxNQUFNLENBQUMsQ0FBQztRQUNyQyxJQUFJLENBQUMsSUFBSSxDQUFDLGtEQUFrRCxLQUFLLEdBQUcsS0FBSyxhQUFhLE1BQU0sR0FBRyxLQUFLLGtCQUFrQixLQUFLLElBQUksTUFBTSxJQUFJLENBQUMsQ0FBQztRQUMzSSxJQUFJLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNsQixJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBQ3JCLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzFCLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDdkIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ2QsQ0FBQztRQUNELElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLE9BQU8sSUFBSSxFQUFFLENBQUMsQ0FBQztRQUNsQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7SUFFRDs7O09BR0c7SUFDSyxLQUFLLENBQUMsS0FBYTtRQUN6QixLQUFLLE1BQU0sSUFBSSxJQUFJLEtBQUssQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztZQUNyQyxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQ2xCLENBQUM7SUFDSCxDQUFDOztBQTdCSCwwQkE4QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFByb2plY3QsIFNvdXJjZUNvZGVPcHRpb25zIH0gZnJvbSAncHJvamVuJztcbmltcG9ydCB7IFNvdXJjZUNvZGUgfSBmcm9tICdwcm9qZW4nO1xuXG4vKipcbiAqIE9wdGlvbnMgZm9yIFN2Z0ZpbGVcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTdmdGaWxlT3B0aW9ucyBleHRlbmRzIFNvdXJjZUNvZGVPcHRpb25zIHtcbiAgcmVhZG9ubHkgd2lkdGg6IG51bWJlcjtcbiAgcmVhZG9ubHkgaGVpZ2h0OiBudW1iZXI7XG4gIHJlYWRvbmx5IHNjYWxlPzogbnVtYmVyO1xuICByZWFkb25seSBzdHlsZT86IHN0cmluZztcbiAgcmVhZG9ubHkgY29udGVudD86IHN0cmluZztcbn1cblxuLyoqXG4gKiBBIFNWRyBmaWxlXG4gKi9cbmV4cG9ydCBjbGFzcyBTdmdGaWxlIGV4dGVuZHMgU291cmNlQ29kZSB7XG4gIHB1YmxpYyBjb25zdHJ1Y3Rvcihwcm9qZWN0OiBQcm9qZWN0LCBmaWxlUGF0aDogc3RyaW5nLCBvcHRpb25zOiBTdmdGaWxlT3B0aW9ucykge1xuICAgIHN1cGVyKHByb2plY3QsIGZpbGVQYXRoLCB7XG4gICAgICBpbmRlbnQ6IDQsXG4gICAgICAuLi5vcHRpb25zLFxuICAgIH0pO1xuXG4gICAgY29uc3QgeyB3aWR0aCwgaGVpZ2h0LCBzY2FsZSA9IDEgfSA9IG9wdGlvbnM7XG5cbiAgICB0aGlzLmxpbmUoYDwhLS0gJHt0aGlzLm1hcmtlcn0gLS0+YCk7XG4gICAgdGhpcy5vcGVuKGA8c3ZnIHhtbG5zPVwiaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmdcIiB3aWR0aD1cIiR7d2lkdGggKiBzY2FsZX1cIiBoZWlnaHQ9XCIke2hlaWdodCAqIHNjYWxlfVwiIHZpZXdCb3g9XCIwIDAgJHt3aWR0aH0gJHtoZWlnaHR9XCI+YCk7XG4gICAgaWYgKG9wdGlvbnMuc3R5bGUpIHtcbiAgICAgIHRoaXMub3BlbignPHN0eWxlPicpO1xuICAgICAgdGhpcy5saW5lcyhvcHRpb25zLnN0eWxlKTtcbiAgICAgIHRoaXMuY2xvc2UoJzwvc3R5bGU+Jyk7XG4gICAgICB0aGlzLmxpbmUoKTtcbiAgICB9XG4gICAgdGhpcy5saW5lcyhvcHRpb25zLmNvbnRlbnQgPz8gJycpO1xuICAgIHRoaXMuY2xvc2UoJzwvc3ZnPicpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgdGV4dCBhcyBsaW5lcyB0byB0aGUgdGV4dCBmaWxlLlxuICAgKiBAcGFyYW0gbGluZXMgdGhlIHRleHQgd2l0aCBsaW5lIGJyZWFrcyB0byBhZGRcbiAgICovXG4gIHByaXZhdGUgbGluZXMobGluZXM6IHN0cmluZykge1xuICAgIGZvciAoY29uc3QgbGluZSBvZiBsaW5lcy5zcGxpdCgnXFxuJykpIHtcbiAgICAgIHRoaXMubGluZShsaW5lKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
@@ -1,5 +1,6 @@
1
- import { Component, Project } from 'projen';
2
- import { LogoInfo } from './Logo';
1
+ import type { Project } from 'projen';
2
+ import { Component } from 'projen';
3
+ import type { LogoInfo } from './Logo';
3
4
  export interface WordmarkOptions {
4
5
  readonly fileBaseName?: string;
5
6
  readonly dirName?: string;
@@ -77,7 +77,7 @@ class Wordmark extends projen_1.Component {
77
77
  }
78
78
  exports.Wordmark = Wordmark;
79
79
  _a = JSII_RTTI_SYMBOL_1;
80
- Wordmark[_a] = { fqn: "mrpj.logo.Wordmark", version: "0.1.98" };
80
+ Wordmark[_a] = { fqn: "mrpj.logo.Wordmark", version: "0.1.100" };
81
81
  class WordmarkVariant extends projen_1.Component {
82
82
  constructor(project, options) {
83
83
  super(project);
@@ -143,4 +143,4 @@ ${this.options.logo.content.split('\n').map(l => ' '.repeat(indent) + l).join('\
143
143
  return statements.join('\n\n');
144
144
  }
145
145
  }
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Wordmark.js","sourceRoot":"","sources":["../../src/logo/Wordmark.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport { Component, Project } from 'projen';\nimport { Logo, LogoInfo } from './Logo';\nimport { logoToPngTask } from './private.ts/logo-task';\nimport { SvgFile } from './SvgFile';\nimport { deepDefaults, deepMerge } from '../utils';\n\nexport interface WordmarkOptions {\n  readonly fileBaseName?: string;\n  readonly dirName?: string;\n  readonly raw?: string;\n  readonly text?: string;\n  readonly textPosition?: TranslateOptions;\n  readonly font?: FontOptions;\n  readonly colorScheme?: ColorScheme;\n  readonly size?: SizeOptions;\n  readonly logo?: LogoInfo;\n  readonly logoPosition?: TranslateOptions;\n  readonly logoScale?: number;\n}\n\nexport interface ColorScheme {\n  readonly dark?: FontOptions;\n  readonly light?: FontOptions;\n}\n\nexport interface FontOptions {\n  readonly family?: string;\n  readonly size?: number;\n  readonly weight?: string;\n  readonly color?: string;\n};\n\nexport interface SizeOptions {\n  readonly width?: number;\n  readonly height?: number;\n  readonly scale?: number;\n}\n\nexport interface TranslateOptions {\n  readonly dx?: number;\n  readonly dy?: number;\n}\n\n/**\n * @internal\n */\ntype FullWordmarkOptions = Omit<Required<WordmarkOptions>, 'raw' | 'colorScheme' | 'logoPosition'> & WordmarkOptions & {\n  readonly size: Required<SizeOptions>;\n  readonly textPosition: Required<TranslateOptions>;\n};\n\nexport class Wordmark extends Component {\n  private readonly options: FullWordmarkOptions;\n\n  public constructor(project: Project, options: WordmarkOptions = {}) {\n    super(project);\n\n    this.options = deepDefaults<FullWordmarkOptions>({\n      ...options,\n      colorScheme: {},\n    }, {\n      dirName: 'images',\n      fileBaseName: 'wordmark',\n      text: this.project.name,\n      textPosition: {\n        dx: 35,\n        dy: 0,\n      },\n      font: {\n        family: '-apple-system, BlinkMacSystemFont, \"Segoe UI\", Helvetica, Arial, sans-serif',\n        weight: '700',\n        size: 90,\n        color: '#6F7174',\n      },\n      logo: Logo.placeholder(),\n      logoScale: 2,\n      size: {\n        width: 720,\n        height: 200,\n        scale: 1,\n      },\n    });\n\n    // Default variant\n    new WordmarkVariant(project, this.options);\n\n    // Allow colorScheme to be disabled\n    const colorScheme = options.colorScheme ?? {\n      dark: { color: '#f0f6fc' },\n      light: { color: '#191919' },\n    };\n\n    // Add variants\n    if (colorScheme.dark) {\n      this.variant('dark', {\n        font: colorScheme.dark,\n        colorScheme: {},\n      });\n    }\n\n    if (colorScheme.light) {\n      this.variant('light', {\n        font: colorScheme.light,\n        colorScheme: {},\n      });\n    }\n\n    if (colorScheme.dark && colorScheme.light) {\n      this.variant('dynamic', {\n        colorScheme: {\n          dark: colorScheme.dark,\n          light: colorScheme.light,\n        },\n      });\n    }\n  }\n\n  private variant(name: string, options: WordmarkOptions): WordmarkVariant {\n    const variant = {\n      ...options,\n      fileBaseName: `${this.options.fileBaseName}-${name}`,\n    };\n    return new WordmarkVariant(this.project, deepMerge(this.options, variant));\n  }\n\n}\n\nclass WordmarkVariant extends Component {\n  public constructor(project: Project, private readonly options: FullWordmarkOptions) {\n    super(project);\n\n    const halfHeight = this.options.size.height/2;\n    const expectedLogoScale = this.options.size.height/this.options.logo.height;\n    const logoScale = this.options.logoScale ?? expectedLogoScale;\n    const logoTranslate = {\n      x: 0 + (this.options.logoPosition?.dx ?? 0),\n      y: this.options.logoPosition?.dy ?? (logoScale/expectedLogoScale * -1 * halfHeight + halfHeight),\n    };\n\n    const wordmark = this.options.raw ?? this.wordmark(this.options.text, {\n      x: logoScale * this.options.logo.width + this.options.textPosition.dx,\n      y: this.options.size.height/2 + this.options.textPosition.dy,\n    });\n\n    const indent = 4;\n    const content = `\n<g transform=\"translate(${logoTranslate.x} ${logoTranslate.y}) scale(${logoScale})\">\n${this.options.logo.content.split('\\n').map(l => ' '.repeat(indent) + l).join('\\n')}\n</g>\n`;\n\n    // Render Wordmark\n    const file = new SvgFile(project, path.join(this.options.dirName, this.options.fileBaseName) + '.svg', {\n      ...this.options.size,\n      content: content + '\\n' + wordmark,\n      style: this.style(),\n      indent,\n    });\n    project.addPackageIgnore(file.filePath);\n\n    // Conversion task\n    logoToPngTask(project, file.filePath);\n  }\n\n  private wordmark(text: string, { x, y }: {\n    x: number;\n    y: number;\n  }): string {\n    return `<text x=\"${x}\" y=\"${y}\"><tspan dy=\"0.5ex\">${text}</tspan></text>`;\n  }\n\n  private style() {\n    const makeCSS = (opt: FontOptions, indent = 0, spaces = 4): string => {\n      const outer = ' '.repeat(indent*spaces);\n      const inner = ' '.repeat((indent+1)*spaces);\n\n      const css = [outer + 'text {'];\n      if (opt.family) {\n        css.push(inner + `font-family: ${opt.family};`);\n      }\n      if (opt.weight) {\n        css.push(inner + `font-weight: ${opt.weight};`);\n      }\n      if (opt.size) {\n        css.push(inner + `font-size: ${opt.size}px;`);\n      }\n      if (opt.color) {\n        css.push(inner + `fill: ${opt.color};`);\n      }\n      css.push(outer + '}');\n\n      return css.join('\\n');\n    };\n\n    const statements = [makeCSS(this.options.font)];\n\n    if (this.options.colorScheme?.dark) {\n      statements.push(`@media (prefers-color-scheme: dark) {\\n${makeCSS(this.options.colorScheme?.dark, 1)}\\n}`);\n    }\n\n    if (this.options.colorScheme?.light) {\n      statements.push(`@media (prefers-color-scheme: light) {\\n${makeCSS(this.options.colorScheme?.light, 1)}\\n}`);\n    }\n\n    return statements.join('\\n\\n');\n  }\n}\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Wordmark.js","sourceRoot":"","sources":["../../src/logo/Wordmark.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport type { Project } from 'projen';\nimport { Component } from 'projen';\nimport type { LogoInfo } from './Logo';\nimport { Logo } from './Logo';\nimport { logoToPngTask } from './private.ts/logo-task';\nimport { SvgFile } from './SvgFile';\nimport { deepDefaults, deepMerge } from '../utils';\n\nexport interface WordmarkOptions {\n  readonly fileBaseName?: string;\n  readonly dirName?: string;\n  readonly raw?: string;\n  readonly text?: string;\n  readonly textPosition?: TranslateOptions;\n  readonly font?: FontOptions;\n  readonly colorScheme?: ColorScheme;\n  readonly size?: SizeOptions;\n  readonly logo?: LogoInfo;\n  readonly logoPosition?: TranslateOptions;\n  readonly logoScale?: number;\n}\n\nexport interface ColorScheme {\n  readonly dark?: FontOptions;\n  readonly light?: FontOptions;\n}\n\nexport interface FontOptions {\n  readonly family?: string;\n  readonly size?: number;\n  readonly weight?: string;\n  readonly color?: string;\n};\n\nexport interface SizeOptions {\n  readonly width?: number;\n  readonly height?: number;\n  readonly scale?: number;\n}\n\nexport interface TranslateOptions {\n  readonly dx?: number;\n  readonly dy?: number;\n}\n\n/**\n * @internal\n */\ntype FullWordmarkOptions = Omit<Required<WordmarkOptions>, 'raw' | 'colorScheme' | 'logoPosition'> & WordmarkOptions & {\n  readonly size: Required<SizeOptions>;\n  readonly textPosition: Required<TranslateOptions>;\n};\n\nexport class Wordmark extends Component {\n  private readonly options: FullWordmarkOptions;\n\n  public constructor(project: Project, options: WordmarkOptions = {}) {\n    super(project);\n\n    this.options = deepDefaults<FullWordmarkOptions>({\n      ...options,\n      colorScheme: {},\n    }, {\n      dirName: 'images',\n      fileBaseName: 'wordmark',\n      text: this.project.name,\n      textPosition: {\n        dx: 35,\n        dy: 0,\n      },\n      font: {\n        family: '-apple-system, BlinkMacSystemFont, \"Segoe UI\", Helvetica, Arial, sans-serif',\n        weight: '700',\n        size: 90,\n        color: '#6F7174',\n      },\n      logo: Logo.placeholder(),\n      logoScale: 2,\n      size: {\n        width: 720,\n        height: 200,\n        scale: 1,\n      },\n    });\n\n    // Default variant\n    new WordmarkVariant(project, this.options);\n\n    // Allow colorScheme to be disabled\n    const colorScheme = options.colorScheme ?? {\n      dark: { color: '#f0f6fc' },\n      light: { color: '#191919' },\n    };\n\n    // Add variants\n    if (colorScheme.dark) {\n      this.variant('dark', {\n        font: colorScheme.dark,\n        colorScheme: {},\n      });\n    }\n\n    if (colorScheme.light) {\n      this.variant('light', {\n        font: colorScheme.light,\n        colorScheme: {},\n      });\n    }\n\n    if (colorScheme.dark && colorScheme.light) {\n      this.variant('dynamic', {\n        colorScheme: {\n          dark: colorScheme.dark,\n          light: colorScheme.light,\n        },\n      });\n    }\n  }\n\n  private variant(name: string, options: WordmarkOptions): WordmarkVariant {\n    const variant = {\n      ...options,\n      fileBaseName: `${this.options.fileBaseName}-${name}`,\n    };\n    return new WordmarkVariant(this.project, deepMerge(this.options, variant));\n  }\n\n}\n\nclass WordmarkVariant extends Component {\n  public constructor(project: Project, private readonly options: FullWordmarkOptions) {\n    super(project);\n\n    const halfHeight = this.options.size.height/2;\n    const expectedLogoScale = this.options.size.height/this.options.logo.height;\n    const logoScale = this.options.logoScale ?? expectedLogoScale;\n    const logoTranslate = {\n      x: 0 + (this.options.logoPosition?.dx ?? 0),\n      y: this.options.logoPosition?.dy ?? (logoScale/expectedLogoScale * -1 * halfHeight + halfHeight),\n    };\n\n    const wordmark = this.options.raw ?? this.wordmark(this.options.text, {\n      x: logoScale * this.options.logo.width + this.options.textPosition.dx,\n      y: this.options.size.height/2 + this.options.textPosition.dy,\n    });\n\n    const indent = 4;\n    const content = `\n<g transform=\"translate(${logoTranslate.x} ${logoTranslate.y}) scale(${logoScale})\">\n${this.options.logo.content.split('\\n').map(l => ' '.repeat(indent) + l).join('\\n')}\n</g>\n`;\n\n    // Render Wordmark\n    const file = new SvgFile(project, path.join(this.options.dirName, this.options.fileBaseName) + '.svg', {\n      ...this.options.size,\n      content: content + '\\n' + wordmark,\n      style: this.style(),\n      indent,\n    });\n    project.addPackageIgnore(file.filePath);\n\n    // Conversion task\n    logoToPngTask(project, file.filePath);\n  }\n\n  private wordmark(text: string, { x, y }: {\n    x: number;\n    y: number;\n  }): string {\n    return `<text x=\"${x}\" y=\"${y}\"><tspan dy=\"0.5ex\">${text}</tspan></text>`;\n  }\n\n  private style() {\n    const makeCSS = (opt: FontOptions, indent = 0, spaces = 4): string => {\n      const outer = ' '.repeat(indent*spaces);\n      const inner = ' '.repeat((indent+1)*spaces);\n\n      const css = [outer + 'text {'];\n      if (opt.family) {\n        css.push(inner + `font-family: ${opt.family};`);\n      }\n      if (opt.weight) {\n        css.push(inner + `font-weight: ${opt.weight};`);\n      }\n      if (opt.size) {\n        css.push(inner + `font-size: ${opt.size}px;`);\n      }\n      if (opt.color) {\n        css.push(inner + `fill: ${opt.color};`);\n      }\n      css.push(outer + '}');\n\n      return css.join('\\n');\n    };\n\n    const statements = [makeCSS(this.options.font)];\n\n    if (this.options.colorScheme?.dark) {\n      statements.push(`@media (prefers-color-scheme: dark) {\\n${makeCSS(this.options.colorScheme?.dark, 1)}\\n}`);\n    }\n\n    if (this.options.colorScheme?.light) {\n      statements.push(`@media (prefers-color-scheme: light) {\\n${makeCSS(this.options.colorScheme?.light, 1)}\\n}`);\n    }\n\n    return statements.join('\\n\\n');\n  }\n}\n"]}
@@ -1,2 +1,2 @@
1
- import { Project } from 'projen';
1
+ import type { Project } from 'projen';
2
2
  export declare function logoToPngTask(project: Project, path: string): void;
@@ -14,4 +14,4 @@ function logoToPngTask(project, path) {
14
14
  logoTask(project).exec(`rsvg-convert -h 1024 ${path} > ${pngPath}`);
15
15
  }
16
16
  exports.logoToPngTask = logoToPngTask;
17
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nby10YXNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xvZ28vcHJpdmF0ZS50cy9sb2dvLXRhc2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsU0FBUyxRQUFRLENBQUMsT0FBZ0I7SUFDaEMsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDM0MsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ1YsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUM7QUFFRCxTQUFnQixhQUFhLENBQUMsT0FBZ0IsRUFBRSxJQUFZO0lBQzFELE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxNQUFNLEdBQUMsQ0FBQyxDQUFDLEdBQUcsTUFBTSxDQUFDO0lBQzFELE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixJQUFJLE1BQU0sT0FBTyxFQUFFLENBQUMsQ0FBQztBQUN0RSxDQUFDO0FBSkQsc0NBSUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcm9qZWN0IH0gZnJvbSAncHJvamVuJztcblxuZnVuY3Rpb24gbG9nb1Rhc2socHJvamVjdDogUHJvamVjdCkge1xuICBjb25zdCB0YXNrID0gcHJvamVjdC50YXNrcy50cnlGaW5kKCdsb2dvJyk7XG4gIGlmICghdGFzaykge1xuICAgIHJldHVybiBwcm9qZWN0LmFkZFRhc2soJ2xvZ28nKTtcbiAgfVxuXG4gIHJldHVybiB0YXNrO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbG9nb1RvUG5nVGFzayhwcm9qZWN0OiBQcm9qZWN0LCBwYXRoOiBzdHJpbmcpIHtcbiAgY29uc3QgcG5nUGF0aCA9IHBhdGguc3Vic3RyaW5nKDAsIHBhdGgubGVuZ3RoLTQpICsgJy5wbmcnO1xuICBwcm9qZWN0LmFkZFBhY2thZ2VJZ25vcmUocG5nUGF0aCk7XG4gIGxvZ29UYXNrKHByb2plY3QpLmV4ZWMoYHJzdmctY29udmVydCAtaCAxMDI0ICR7cGF0aH0gPiAke3BuZ1BhdGh9YCk7XG59XG4iXX0=
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nby10YXNrLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2xvZ28vcHJpdmF0ZS50cy9sb2dvLXRhc2sudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBRUEsU0FBUyxRQUFRLENBQUMsT0FBZ0I7SUFDaEMsTUFBTSxJQUFJLEdBQUcsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDM0MsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1FBQ1YsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2pDLENBQUM7SUFFRCxPQUFPLElBQUksQ0FBQztBQUNkLENBQUM7QUFFRCxTQUFnQixhQUFhLENBQUMsT0FBZ0IsRUFBRSxJQUFZO0lBQzFELE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxNQUFNLEdBQUMsQ0FBQyxDQUFDLEdBQUcsTUFBTSxDQUFDO0lBQzFELE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLHdCQUF3QixJQUFJLE1BQU0sT0FBTyxFQUFFLENBQUMsQ0FBQztBQUN0RSxDQUFDO0FBSkQsc0NBSUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFByb2plY3QgfSBmcm9tICdwcm9qZW4nO1xuXG5mdW5jdGlvbiBsb2dvVGFzayhwcm9qZWN0OiBQcm9qZWN0KSB7XG4gIGNvbnN0IHRhc2sgPSBwcm9qZWN0LnRhc2tzLnRyeUZpbmQoJ2xvZ28nKTtcbiAgaWYgKCF0YXNrKSB7XG4gICAgcmV0dXJuIHByb2plY3QuYWRkVGFzaygnbG9nbycpO1xuICB9XG5cbiAgcmV0dXJuIHRhc2s7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBsb2dvVG9QbmdUYXNrKHByb2plY3Q6IFByb2plY3QsIHBhdGg6IHN0cmluZykge1xuICBjb25zdCBwbmdQYXRoID0gcGF0aC5zdWJzdHJpbmcoMCwgcGF0aC5sZW5ndGgtNCkgKyAnLnBuZyc7XG4gIHByb2plY3QuYWRkUGFja2FnZUlnbm9yZShwbmdQYXRoKTtcbiAgbG9nb1Rhc2socHJvamVjdCkuZXhlYyhgcnN2Zy1jb252ZXJ0IC1oIDEwMjQgJHtwYXRofSA+ICR7cG5nUGF0aH1gKTtcbn1cbiJdfQ==
@@ -353,6 +353,18 @@ export interface ProjenProjectOptions {
353
353
  * @stability stable
354
354
  */
355
355
  readonly buildWorkflow?: boolean;
356
+ /**
357
+ * Biome options.
358
+ * @default - default options
359
+ * @stability stable
360
+ */
361
+ readonly biomeOptions?: javascript.BiomeOptions;
362
+ /**
363
+ * Setup Biome.
364
+ * @default false
365
+ * @stability stable
366
+ */
367
+ readonly biome?: boolean;
356
368
  /**
357
369
  * Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued).
358
370
  * Throw if set to true but `autoApproveOptions` are not defined.
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"projen-project-options.js","sourceRoot":"","sources":["../src/projen-project-options.ts"],"names":[],"mappings":"","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\".\nimport type { cdk, github, GitOptions, GroupRunnerOptions, IgnoreFileOptions, javascript, LoggerOptions, Project, ProjenrcJsonOptions, release, RenovatebotOptions, SampleReadmeProps, typescript } from 'projen';\nimport type { logo } from './';\n\n/**\n * ProjenProjectOptions\n */\nexport interface ProjenProjectOptions {\n  /**\n   * @default \".\"\n   * @stability stable\n   */\n  readonly rootdir?: string;\n  /**\n   * Publish to pypi.\n   * @default - no publishing\n   * @stability stable\n   */\n  readonly publishToPypi?: cdk.JsiiPythonTarget;\n  /**\n   * Publish to NuGet.\n   * @default - no publishing\n   * @stability stable\n   */\n  readonly publishToNuget?: cdk.JsiiDotNetTarget;\n  /**\n   * Publish to maven.\n   * @default - no publishing\n   * @stability stable\n   */\n  readonly publishToMaven?: cdk.JsiiJavaTarget;\n  /**\n   * Publish Go bindings to a git repository.\n   * @default - no publishing\n   * @stability stable\n   */\n  readonly publishToGo?: cdk.JsiiGoTarget;\n  /**\n   * Accepts a list of glob patterns.\n   * Files matching any of those patterns will be excluded from the TypeScript compiler input.\n   *\n   * By default, jsii will include all *.ts files (except .d.ts files) in the TypeScript compiler input.\n   * This can be problematic for example when the package's build or test procedure generates .ts files\n   * that cannot be compiled with jsii's compiler settings.\n   * @stability stable\n   */\n  readonly excludeTypescript?: Array<string>;\n  /**\n   * File path for generated docs.\n   * @default \"API.md\"\n   * @stability stable\n   */\n  readonly docgenFilePath?: string;\n  /**\n   * Emit a compressed version of the assembly.\n   * @default false\n   * @stability stable\n   */\n  readonly compressAssembly?: boolean;\n  /**\n   * Name of the ignore file for API compatibility tests.\n   * @default \".compatignore\"\n   * @stability stable\n   */\n  readonly compatIgnore?: string;\n  /**\n   * Automatically run API compatibility test against the latest version published to npm after compilation.\n   * - You can manually run compatibility tests using `yarn compat` if this feature is disabled.\n   * - You can ignore compatibility failures by adding lines to a \".compatignore\" file.\n   * @default false\n   * @stability stable\n   */\n  readonly compat?: boolean;\n  /**\n   * Email or URL of the library author.\n   * @default $GIT_USER_EMAIL\n   * @stability stable\n   */\n  readonly authorAddress?: string;\n  /**\n   * Options for ts-jest.\n   * @stability stable\n   */\n  readonly tsJestOptions?: typescript.TsJestOptions;\n  /**\n   * The name of the development tsconfig.json file.\n   * @default \"tsconfig.dev.json\"\n   * @stability stable\n   */\n  readonly tsconfigDevFile?: string;\n  /**\n   * Custom tsconfig options for the development tsconfig.json file (used for testing).\n   * @default - use the production tsconfig options\n   * @stability stable\n   */\n  readonly tsconfigDev?: javascript.TypescriptConfigOptions;\n  /**\n   * Custom TSConfig.\n   * @default - default options\n   * @stability stable\n   */\n  readonly tsconfig?: javascript.TypescriptConfigOptions;\n  /**\n   * Jest tests directory. Tests files should be named `xxx.test.ts`.\n   * If this directory is under `srcdir` (e.g. `src/test`, `src/__tests__`),\n   * then tests are going to be compiled into `lib/` and executed as javascript.\n   * If the test directory is outside of `src`, then we configure jest to\n   * compile the code in-memory.\n   * @default \"test\"\n   * @stability stable\n   */\n  readonly testdir?: string;\n  /**\n   * Typescript sources directory.\n   * @default \"src\"\n   * @stability stable\n   */\n  readonly srcdir?: string;\n  /**\n   * Options for .projenrc.ts.\n   * @stability stable\n   */\n  readonly projenrcTsOptions?: typescript.ProjenrcOptions;\n  /**\n   * Typescript  artifacts output directory.\n   * @default \"lib\"\n   * @stability stable\n   */\n  readonly libdir?: string;\n  /**\n   * Eslint options.\n   * @default - opinionated default options\n   * @stability stable\n   */\n  readonly eslintOptions?: javascript.EslintOptions;\n  /**\n   * Setup eslint.\n   * @default true\n   * @stability stable\n   */\n  readonly eslint?: boolean;\n  /**\n   * The .d.ts file that includes the type declarations for this module.\n   * @default - .d.ts file derived from the project's entrypoint (usually lib/index.d.ts)\n   * @stability stable\n   */\n  readonly entrypointTypes?: string;\n  /**\n   * Docs directory.\n   * @default \"docs\"\n   * @stability stable\n   */\n  readonly docsDirectory?: string;\n  /**\n   * Docgen by Typedoc.\n   * @default false\n   * @stability stable\n   */\n  readonly docgen?: boolean;\n  /**\n   * Do not generate a `tsconfig.dev.json` file.\n   * @default false\n   * @stability stable\n   */\n  readonly disableTsconfigDev?: boolean;\n  /**\n   * Do not generate a `tsconfig.json` file (used by jsii projects since tsconfig.json is generated by the jsii compiler).\n   * @default false\n   * @stability stable\n   */\n  readonly disableTsconfig?: boolean;\n  /**\n   * Enable Node.js package cache in GitHub workflows.\n   * @default false\n   * @stability stable\n   */\n  readonly workflowPackageCache?: boolean;\n  /**\n   * The node version used in GitHub Actions workflows.\n   * Always use this option if your GitHub Actions workflows require a specific to run.\n   * @default - `minNodeVersion` if set, otherwise `lts/*`.\n   * @stability stable\n   */\n  readonly workflowNodeVersion?: string;\n  /**\n   * The git identity to use in workflows.\n   * @default - GitHub Actions\n   * @stability stable\n   */\n  readonly workflowGitIdentity?: github.GitIdentity;\n  /**\n   * Workflow steps to use in order to bootstrap this repo.\n   * @default \"yarn install --frozen-lockfile && yarn projen\"\n   * @stability stable\n   */\n  readonly workflowBootstrapSteps?: Array<github.workflows.JobStep>;\n  /**\n   * Automatically release to npm when new versions are introduced.\n   * @default false\n   * @stability stable\n   */\n  readonly releaseToNpm?: boolean;\n  /**\n   * Add release management to this project.\n   * @default false\n   * @stability stable\n   */\n  readonly release?: boolean;\n  /**\n   * The contents of the pull request template.\n   * @default - default content\n   * @stability stable\n   */\n  readonly pullRequestTemplateContents?: Array<string>;\n  /**\n   * Include a GitHub pull request template.\n   * @default true\n   * @stability stable\n   */\n  readonly pullRequestTemplate?: boolean;\n  /**\n   * Options for .projenrc.js.\n   * @default - default options\n   * @stability stable\n   */\n  readonly projenrcJsOptions?: javascript.ProjenrcOptions;\n  /**\n   * Generate (once) .projenrc.js (in JavaScript). Set to `false` in order to disable .projenrc.js generation.\n   * @default - true if projenrcJson is false\n   * @stability stable\n   */\n  readonly projenrcJs?: boolean;\n  /**\n   * Indicates of \"projen\" should be installed as a devDependency.\n   * @default - true if not a subproject\n   * @stability stable\n   */\n  readonly projenDevDependency?: boolean;\n  /**\n   * Prettier options.\n   * @default - default options\n   * @stability stable\n   */\n  readonly prettierOptions?: javascript.PrettierOptions;\n  /**\n   * Setup prettier.\n   * @default false\n   * @stability stable\n   */\n  readonly prettier?: boolean;\n  /**\n   * Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`).\n   * @default true\n   * @stability stable\n   */\n  readonly package?: boolean;\n  /**\n   * Configuration options for .npmignore file.\n   * @stability stable\n   */\n  readonly npmIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Defines an .npmignore file. Normally this is only needed for libraries that are packaged as tarballs.\n   * @default true\n   * @stability stable\n   */\n  readonly npmignoreEnabled?: boolean;\n  /**\n   * Jest options.\n   * @default - default options\n   * @stability stable\n   */\n  readonly jestOptions?: javascript.JestOptions;\n  /**\n   * Setup jest unit tests.\n   * @default true\n   * @stability stable\n   */\n  readonly jest?: boolean;\n  /**\n   * Additional entries to .gitignore.\n   * @stability stable\n   */\n  readonly gitignore?: Array<string>;\n  /**\n   * Options for `UpgradeDependencies`.\n   * @default - default options\n   * @stability stable\n   */\n  readonly depsUpgradeOptions?: javascript.UpgradeDependenciesOptions;\n  /**\n   * Use tasks and github workflows to handle dependency upgrades.\n   * Cannot be used in conjunction with `dependabot`.\n   * @default true\n   * @stability stable\n   */\n  readonly depsUpgrade?: boolean;\n  /**\n   * Options for dependabot.\n   * @default - default options\n   * @stability stable\n   */\n  readonly dependabotOptions?: github.DependabotOptions;\n  /**\n   * Use dependabot to handle dependency upgrades.\n   * Cannot be used in conjunction with `depsUpgrade`.\n   * @default false\n   * @stability stable\n   */\n  readonly dependabot?: boolean;\n  /**\n   * The copyright years to put in the LICENSE file.\n   * @default - current year\n   * @stability stable\n   */\n  readonly copyrightPeriod?: string;\n  /**\n   * License copyright owner.\n   * @default - defaults to the value of authorName or \"\" if `authorName` is undefined.\n   * @stability stable\n   */\n  readonly copyrightOwner?: string;\n  /**\n   * Define the secret name for a specified https://codecov.io/ token A secret is required to send coverage for private repositories.\n   * @default - if this option is not specified, only public repositories are supported\n   * @stability stable\n   */\n  readonly codeCovTokenSecret?: string;\n  /**\n   * Define a GitHub workflow step for sending code coverage metrics to https://codecov.io/ Uses codecov/codecov-action@v4 A secret is required for private repos. Configured with `@codeCovTokenSecret`.\n   * @default false\n   * @stability stable\n   */\n  readonly codeCov?: boolean;\n  /**\n   * Configure which licenses should be deemed acceptable for use by dependencies.\n   * This setting will cause the build to fail, if any prohibited or not allowed licenses ares encountered.\n   * @default - no license checks are run during the build and all licenses will be accepted\n   * @stability stable\n   */\n  readonly checkLicenses?: javascript.LicenseCheckerOptions;\n  /**\n   * Options for `Bundler`.\n   * @stability stable\n   */\n  readonly bundlerOptions?: javascript.BundlerOptions;\n  /**\n   * Options for PR build workflow.\n   * @stability stable\n   */\n  readonly buildWorkflowOptions?: javascript.BuildWorkflowOptions;\n  /**\n   * Define a GitHub workflow for building PRs.\n   * @default - true if not a subproject\n   * @stability stable\n   */\n  readonly buildWorkflow?: boolean;\n  /**\n   * Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued).\n   * Throw if set to true but `autoApproveOptions` are not defined.\n   * @default - true\n   * @stability stable\n   */\n  readonly autoApproveUpgrades?: boolean;\n  /**\n   * A directory which will contain build artifacts.\n   * @default \"dist\"\n   * @stability stable\n   */\n  readonly artifactsDirectory?: string;\n  /**\n   * The name of the main release branch.\n   * @default \"main\"\n   * @stability stable\n   */\n  readonly defaultReleaseBranch?: string;\n  /**\n   * Github Runner Group selection options.\n   * @stability stable\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOnGroup?: GroupRunnerOptions;\n  /**\n   * Github Runner selection labels.\n   * @default [\"ubuntu-latest\"]\n   * @stability stable\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOn?: Array<string>;\n  /**\n   * Container image to use for GitHub workflows.\n   * @default - default image\n   * @stability stable\n   */\n  readonly workflowContainerImage?: string;\n  /**\n   * Custom configuration used when creating changelog with commit-and-tag-version package.\n   * Given values either append to default configuration or overwrite values in it.\n   * @default - standard configuration applicable for GitHub repositories\n   * @stability stable\n   */\n  readonly versionrcOptions?: Record<string, any>;\n  /**\n   * A set of workflow steps to execute in order to setup the workflow container.\n   * @stability stable\n   */\n  readonly releaseWorkflowSetupSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The name of the default release workflow.\n   * @default \"release\"\n   * @stability stable\n   */\n  readonly releaseWorkflowName?: string;\n  /**\n   * The release trigger to use.\n   * @default - Continuous releases (`ReleaseTrigger.continuous()`)\n   * @stability stable\n   */\n  readonly releaseTrigger?: release.ReleaseTrigger;\n  /**\n   * Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers.\n   * Note: this prefix is used to detect the latest tagged version\n   * when bumping, so if you change this on a project with an existing version\n   * history, you may need to manually tag your latest release\n   * with the new prefix.\n   * @default \"v\"\n   * @stability stable\n   */\n  readonly releaseTagPrefix?: string;\n  /**\n   * The label to apply to issues indicating publish failures.\n   * Only applies if `releaseFailureIssue` is true.\n   * @default \"failed-release\"\n   * @stability stable\n   */\n  readonly releaseFailureIssueLabel?: string;\n  /**\n   * Create a github issue on every failed publishing task.\n   * @default false\n   * @stability stable\n   */\n  readonly releaseFailureIssue?: boolean;\n  /**\n   * Defines additional release branches.\n   * A workflow will be created for each\n   * release branch which will publish releases from commits in this branch.\n   * Each release branch _must_ be assigned a major version number which is used\n   * to enforce that versions published from that branch always use that major\n   * version. If multiple branches are used, the `majorVersion` field must also\n   * be provided for the default branch.\n   * @default - no additional branches are used for release. you can use\n`addBranch()` to add additional branches.\n   * @stability stable\n   */\n  readonly releaseBranches?: Record<string, release.BranchOptions>;\n  /**\n   * Define publishing tasks that can be executed manually as well as workflows.\n   * Normally, publishing only happens within automated workflows. Enable this\n   * in order to create a publishing task for each publishing activity.\n   * @default false\n   * @stability stable\n   */\n  readonly publishTasks?: boolean;\n  /**\n   * Instead of actually publishing to package managers, just print the publishing command.\n   * @default false\n   * @stability stable\n   */\n  readonly publishDryRun?: boolean;\n  /**\n   * Bump versions from the default branch as pre-releases (e.g. \"beta\", \"alpha\", \"pre\").\n   * @default - normal semantic versions\n   * @stability stable\n   */\n  readonly prerelease?: string;\n  /**\n   * Steps to execute after build as part of the release workflow.\n   * @default []\n   * @stability stable\n   */\n  readonly postBuildSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The npmDistTag to use when publishing from the default branch.\n   * To set the npm dist-tag for release branches, set the `npmDistTag` property\n   * for each branch.\n   * @default \"latest\"\n   * @stability stable\n   */\n  readonly npmDistTag?: string;\n  /**\n   * A shell command to control the next version to release.\n   * If present, this shell command will be run before the bump is executed, and\n   * it determines what version to release. It will be executed in the following\n   * environment:\n   *\n   * - Working directory: the project directory.\n   * - `$VERSION`: the current version. Looks like `1.2.3`.\n   * - `$LATEST_TAG`: the most recent tag. Looks like `prefix-v1.2.3`, or may be unset.\n   * - `$SUGGESTED_BUMP`: the suggested bump action based on commits. One of `major|minor|patch|none`.\n   *\n   * The command should print one of the following to `stdout`:\n   *\n   * - Nothing: the next version number will be determined based on commit history.\n   * - `x.y.z`: the next version number will be `x.y.z`.\n   * - `major|minor|patch`: the next version number will be the current version number\n   *   with the indicated component bumped.\n   *\n   * This setting cannot be specified together with `minMajorVersion`; the invoked\n   * script can be used to achieve the effects of `minMajorVersion`.\n   * @default - The next version will be determined based on the commit history and project settings.\n   * @stability stable\n   */\n  readonly nextVersionCommand?: string;\n  /**\n   * Minimal Major version to release.\n   * This can be useful to set to 1, as breaking changes before the 1.x major\n   * release are not incrementing the major version number.\n   *\n   * Can not be set together with `majorVersion`.\n   * @default - No minimum version is being enforced\n   * @stability stable\n   */\n  readonly minMajorVersion?: number;\n  /**\n   * Major version to release from the default branch.\n   * If this is specified, we bump the latest version of this major version line.\n   * If not specified, we bump the global latest version.\n   * @default - Major version is not enforced.\n   * @stability stable\n   */\n  readonly majorVersion?: number;\n  /**\n   * Version requirement of `publib` which is used to publish modules to npm.\n   * @default \"latest\"\n   * @stability stable\n   */\n  readonly jsiiReleaseVersion?: string;\n  /**\n   * The `commit-and-tag-version` compatible package used to bump the package version, as a dependency string.\n   * This can be any compatible package version, including the deprecated `standard-version@9`.\n   * @default - A recent version of \"commit-and-tag-version\"\n   * @stability stable\n   */\n  readonly bumpPackage?: string;\n  /**\n   * Options for Yarn Berry.\n   * @default - Yarn Berry v4 with all default options\n   * @stability stable\n   */\n  readonly yarnBerryOptions?: javascript.YarnBerryOptions;\n  /**\n   * Package's Stability.\n   * @stability stable\n   */\n  readonly stability?: string;\n  /**\n   * Options for privately hosted scoped packages.\n   * @default - fetch all scoped packages from the public npm registry\n   * @stability stable\n   */\n  readonly scopedPackagesOptions?: Array<javascript.ScopedPackagesOptions>;\n  /**\n   * If the package.json for your package is not in the root directory (for example if it is part of a monorepo), you can specify the directory in which it lives.\n   * @stability stable\n   */\n  readonly repositoryDirectory?: string;\n  /**\n   * The repository is the location where the actual code for your package lives.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-repository\n   * @stability stable\n   */\n  readonly repository?: string;\n  /**\n   * The version of PNPM to use if using PNPM as a package manager.\n   * @default \"9\"\n   * @stability stable\n   */\n  readonly pnpmVersion?: string;\n  /**\n   * Peer dependencies for this module.\n   * Dependencies listed here are required to\n   * be installed (and satisfied) by the _consumer_ of this library. Using peer\n   * dependencies allows you to ensure that only a single module of a certain\n   * library exists in the `node_modules` tree of your consumers.\n   *\n   * Note that prior to npm@7, peer dependencies are _not_ automatically\n   * installed, which means that adding peer dependencies to a library will be a\n   * breaking change for your customers.\n   *\n   * Unless `peerDependencyOptions.pinnedDevDependency` is disabled (it is\n   * enabled by default), projen will automatically add a dev dependency with a\n   * pinned version for each peer dependency. This will ensure that you build &\n   * test your module against the lowest peer version required.\n   * @default []\n   * @stability stable\n   */\n  readonly peerDeps?: Array<string>;\n  /**\n   * Options for `peerDeps`.\n   * @stability stable\n   */\n  readonly peerDependencyOptions?: javascript.PeerDependencyOptions;\n  /**\n   * The \"name\" in package.json.\n   * @default - defaults to project name\n   * @stability stable\n   * @featured true\n   */\n  readonly packageName?: string;\n  /**\n   * The Node Package Manager used to execute scripts.\n   * @default NodePackageManager.YARN_CLASSIC\n   * @stability stable\n   */\n  readonly packageManager?: javascript.NodePackageManager;\n  /**\n   * GitHub secret which contains the NPM token to use when publishing packages.\n   * @default \"NPM_TOKEN\"\n   * @stability stable\n   */\n  readonly npmTokenSecret?: string;\n  /**\n   * The base URL of the npm package registry.\n   * Must be a URL (e.g. start with \"https://\" or \"http://\")\n   * @default \"https://registry.npmjs.org\"\n   * @stability stable\n   */\n  readonly npmRegistryUrl?: string;\n  /**\n   * Should provenance statements be generated when the package is published.\n   * A supported package manager is required to publish a package with npm provenance statements and\n   * you will need to use a supported CI/CD provider.\n   *\n   * Note that the projen `Release` and `Publisher` components are using `publib` to publish packages,\n   * which is using npm internally and supports provenance statements independently of the package manager used.\n   * @default - true for public packages, false otherwise\n   * @stability stable\n   */\n  readonly npmProvenance?: boolean;\n  /**\n   * Access level of the npm package.\n   * @default - for scoped packages (e.g. `foo@bar`), the default is\n`NpmAccess.RESTRICTED`, for non-scoped packages, the default is\n`NpmAccess.PUBLIC`.\n   * @stability stable\n   */\n  readonly npmAccess?: javascript.NpmAccess;\n  /**\n   * The minimum node version required by this package to function. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any older versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option, even if your package is incompatible with EOL versions of node.\n   * Consider this option only if your package depends on a specific feature, that is not available in other LTS versions.\n   * Setting this option has very high impact on the consumers of your package,\n   * as package managers will actively prevent usage with node versions you have marked as incompatible.\n   *\n   * To change the node version of your CI/CD workflows, use `workflowNodeVersion`.\n   * @default - no minimum version is enforced\n   * @stability stable\n   */\n  readonly minNodeVersion?: string;\n  /**\n   * The maximum node version supported by this package. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any newer versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option.\n   * Consider this option only if your package is known to not function with newer versions of node.\n   * @default - no maximum version is enforced\n   * @stability stable\n   */\n  readonly maxNodeVersion?: string;\n  /**\n   * Indicates if a license should be added.\n   * @default true\n   * @stability stable\n   */\n  readonly licensed?: boolean;\n  /**\n   * License's SPDX identifier.\n   * See https://github.com/projen/projen/tree/main/license-text for a list of supported licenses.\n   * Use the `licensed` option if you want to no license to be specified.\n   * @default \"MIT\"\n   * @stability stable\n   */\n  readonly license?: string;\n  /**\n   * Keywords to include in `package.json`.\n   * @stability stable\n   */\n  readonly keywords?: Array<string>;\n  /**\n   * Package's Homepage / Website.\n   * @stability stable\n   */\n  readonly homepage?: string;\n  /**\n   * Module entrypoint (`main` in `package.json`).\n   * Set to an empty string to not include `main` in your package.json\n   * @default \"lib/index.js\"\n   * @stability stable\n   */\n  readonly entrypoint?: string;\n  /**\n   * Build dependencies for this module.\n   * These dependencies will only be\n   * available in your build environment but will not be fetched when this\n   * module is consumed.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability stable\n   * @featured true\n   */\n  readonly devDeps?: Array<string>;\n  /**\n   * The description is just a string that helps people understand the purpose of the package.\n   * It can be used when searching for packages in a package manager as well.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-description\n   * @stability stable\n   * @featured true\n   */\n  readonly description?: string;\n  /**\n   * Runtime dependencies of this module.\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability stable\n   * @featured true\n   */\n  readonly deps?: Array<string>;\n  /**\n   * Options for npm packages using AWS CodeArtifact.\n   * This is required if publishing packages to, or installing scoped packages from AWS CodeArtifact\n   * @default - undefined\n   * @stability stable\n   */\n  readonly codeArtifactOptions?: javascript.CodeArtifactOptions;\n  /**\n   * The version of Bun to use if using Bun as a package manager.\n   * @default \"latest\"\n   * @stability stable\n   */\n  readonly bunVersion?: string;\n  /**\n   * List of dependencies to bundle into this module.\n   * These modules will be\n   * added both to the `dependencies` section and `bundledDependencies` section of\n   * your `package.json`.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @stability stable\n   */\n  readonly bundledDeps?: Array<string>;\n  /**\n   * The url to your project's issue tracker.\n   * @stability stable\n   */\n  readonly bugsUrl?: string;\n  /**\n   * The email address to which issues should be reported.\n   * @stability stable\n   */\n  readonly bugsEmail?: string;\n  /**\n   * Binary programs vended with your module.\n   * You can use this option to add/customize how binaries are represented in\n   * your `package.json`, but unless `autoDetectBin` is `false`, every\n   * executable file under `bin` will automatically be added to this section.\n   * @stability stable\n   */\n  readonly bin?: Record<string, string>;\n  /**\n   * Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section.\n   * @default true\n   * @stability stable\n   */\n  readonly autoDetectBin?: boolean;\n  /**\n   * Author's URL / Website.\n   * @stability stable\n   */\n  readonly authorUrl?: string;\n  /**\n   * Is the author an organization.\n   * @stability stable\n   */\n  readonly authorOrganization?: boolean;\n  /**\n   * Author's name.\n   * @stability stable\n   */\n  readonly authorName: string;\n  /**\n   * Author's e-mail.\n   * @stability stable\n   */\n  readonly authorEmail?: string;\n  /**\n   * Allow the project to include `peerDependencies` and `bundledDependencies`.\n   * This is normally only allowed for libraries. For apps, there's no meaning\n   * for specifying these.\n   * @default true\n   * @stability stable\n   */\n  readonly allowLibraryDependencies?: boolean;\n  /**\n   * Enable VSCode integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability stable\n   */\n  readonly vscode?: boolean;\n  /**\n   * Auto-close stale issues and pull requests.\n   * To disable set `stale` to `false`.\n   * @default - see defaults in `StaleOptions`\n   * @stability stable\n   */\n  readonly staleOptions?: github.StaleOptions;\n  /**\n   * Auto-close of stale issues and pull request.\n   * See `staleOptions` for options.\n   * @default false\n   * @stability stable\n   */\n  readonly stale?: boolean;\n  /**\n   * The README setup.\n   * @default - { filename: 'README.md', contents: '# replace this' }\n   * @stability stable\n   */\n  readonly readme?: SampleReadmeProps;\n  /**\n   * Choose a method of providing GitHub API access for projen workflows.\n   * @default - use a personal access token named PROJEN_GITHUB_TOKEN\n   * @stability stable\n   */\n  readonly projenCredentials?: github.GithubCredentials;\n  /**\n   * Add a Gitpod development environment.\n   * @default false\n   * @stability stable\n   */\n  readonly gitpod?: boolean;\n  /**\n   * Options for GitHub integration.\n   * @default - see GitHubOptions\n   * @stability stable\n   */\n  readonly githubOptions?: github.GitHubOptions;\n  /**\n   * Enable GitHub integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability stable\n   */\n  readonly github?: boolean;\n  /**\n   * Add a VSCode development environment (used for GitHub Codespaces).\n   * @default false\n   * @stability stable\n   */\n  readonly devContainer?: boolean;\n  /**\n   * Add a `clobber` task which resets the repo to origin.\n   * @default - true, but false for subprojects\n   * @stability stable\n   */\n  readonly clobber?: boolean;\n  /**\n   * Configure options for automatic merging on GitHub.\n   * Has no effect if\n   * `github.mergify` or `autoMerge` is set to false.\n   * @default - see defaults in `AutoMergeOptions`\n   * @stability stable\n   */\n  readonly autoMergeOptions?: github.AutoMergeOptions;\n  /**\n   * Enable automatic merging on GitHub.\n   * Has no effect if `github.mergify`\n   * is set to false.\n   * @default true\n   * @stability stable\n   */\n  readonly autoMerge?: boolean;\n  /**\n   * Enable and configure the 'auto approve' workflow.\n   * @default - auto approve is disabled\n   * @stability stable\n   */\n  readonly autoApproveOptions?: github.AutoApproveOptions;\n  /**\n   * Options for renovatebot.\n   * @default - default options\n   * @stability stable\n   */\n  readonly renovatebotOptions?: RenovatebotOptions;\n  /**\n   * Use renovatebot to handle dependency upgrades.\n   * @default false\n   * @stability stable\n   */\n  readonly renovatebot?: boolean;\n  /**\n   * Options for .projenrc.json.\n   * @default - default options\n   * @stability stable\n   */\n  readonly projenrcJsonOptions?: ProjenrcJsonOptions;\n  /**\n   * Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation.\n   * @default false\n   * @stability stable\n   */\n  readonly projenrcJson?: boolean;\n  /**\n   * The shell command to use in order to run the projen CLI.\n   * Can be used to customize in special environments.\n   * @default \"npx projen\"\n   * @stability stable\n   */\n  readonly projenCommand?: string;\n  /**\n   * The parent project, if this project is part of a bigger project.\n   * @stability stable\n   */\n  readonly parent?: Project;\n  /**\n   * The root directory of the project.\n   * Relative to this directory, all files are synthesized.\n   *\n   * If this project has a parent, this directory is relative to the parent\n   * directory and it cannot be the same as the parent or any of it's other\n   * subprojects.\n   * @default \".\"\n   * @stability stable\n   */\n  readonly outdir?: string;\n  /**\n   * Configure logging options such as verbosity.\n   * @default {}\n   * @stability stable\n   */\n  readonly logging?: LoggerOptions;\n  /**\n   * Configuration options for git.\n   * @stability stable\n   */\n  readonly gitOptions?: GitOptions;\n  /**\n   * Configuration options for .gitignore file.\n   * @stability stable\n   */\n  readonly gitIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Whether to commit the managed files by default.\n   * @default true\n   * @stability stable\n   */\n  readonly commitGenerated?: boolean;\n  /**\n   * This is the name of your project.\n   * @default $BASEDIR\n   * @stability stable\n   * @featured true\n   */\n  readonly name?: string;\n  /**\n   * @stability stable\n   */\n  readonly repo: string;\n  /**\n   * Which conventional commit types should be released\n   * @default ['feat', 'fix', 'chore', 'revert']\n   * @stability stable\n   */\n  readonly releasableCommitTypes?: Array<string>;\n  /**\n   * Which conventional commit types are allowed to be used\n   * Types listed in `releasableCommitTypes` are always allowed\n   * @default ['feat', 'fix', 'chore', 'revert', 'docs', 'ci']\n   * @stability stable\n   */\n  readonly allowedCommitTypes?: Array<string>;\n  /**\n   * Use this app for workflow automation. Remember to install the app and to configure credentials.\n   * @default - tokens will be used\n   * @stability stable\n   */\n  readonly automationAppName?: string;\n  /**\n   * Allow the repo owner to self approve PRs by putting a label on it.\n   * @default true\n   * @stability stable\n   */\n  readonly ownerCanSelfApprovePRs?: boolean;\n  /**\n   * @default UpgradeDependenciesSchedule.WEEKLY\n   * @stability stable\n   */\n  readonly upgradesSchedule?: javascript.UpgradeDependenciesSchedule;\n  /**\n   * Add a logo.\n   * Use `Logo.placeholder()` to get started.\n   * @stability stable\n   */\n  readonly logo?: logo.ILogo;\n  /**\n   * Configure how the wordmark is created from a logo.\n   * Wordmarks are only created when a logo is available.\n   * @default - derived from logo and project\n   * @stability stable\n   */\n  readonly wordmarkOptions?: logo.WordmarkOptions;\n  /**\n   * The projen version constraint that is supported by this project\n   * @default \"0.x >=0.75.0\"\n   * @stability stable\n   */\n  readonly projenVersion?: string;\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"projen-project-options.js","sourceRoot":"","sources":["../src/projen-project-options.ts"],"names":[],"mappings":"","sourcesContent":["// ~~ Generated by projen. To modify, edit .projenrc.ts and run \"npx projen\".\nimport type { cdk, github, GitOptions, GroupRunnerOptions, IgnoreFileOptions, javascript, LoggerOptions, Project, ProjenrcJsonOptions, release, RenovatebotOptions, SampleReadmeProps, typescript } from 'projen';\nimport type { logo } from './';\n\n/**\n * ProjenProjectOptions\n */\nexport interface ProjenProjectOptions {\n  /**\n   * @default \".\"\n   * @stability stable\n   */\n  readonly rootdir?: string;\n  /**\n   * Publish to pypi.\n   * @default - no publishing\n   * @stability stable\n   */\n  readonly publishToPypi?: cdk.JsiiPythonTarget;\n  /**\n   * Publish to NuGet.\n   * @default - no publishing\n   * @stability stable\n   */\n  readonly publishToNuget?: cdk.JsiiDotNetTarget;\n  /**\n   * Publish to maven.\n   * @default - no publishing\n   * @stability stable\n   */\n  readonly publishToMaven?: cdk.JsiiJavaTarget;\n  /**\n   * Publish Go bindings to a git repository.\n   * @default - no publishing\n   * @stability stable\n   */\n  readonly publishToGo?: cdk.JsiiGoTarget;\n  /**\n   * Accepts a list of glob patterns.\n   * Files matching any of those patterns will be excluded from the TypeScript compiler input.\n   *\n   * By default, jsii will include all *.ts files (except .d.ts files) in the TypeScript compiler input.\n   * This can be problematic for example when the package's build or test procedure generates .ts files\n   * that cannot be compiled with jsii's compiler settings.\n   * @stability stable\n   */\n  readonly excludeTypescript?: Array<string>;\n  /**\n   * File path for generated docs.\n   * @default \"API.md\"\n   * @stability stable\n   */\n  readonly docgenFilePath?: string;\n  /**\n   * Emit a compressed version of the assembly.\n   * @default false\n   * @stability stable\n   */\n  readonly compressAssembly?: boolean;\n  /**\n   * Name of the ignore file for API compatibility tests.\n   * @default \".compatignore\"\n   * @stability stable\n   */\n  readonly compatIgnore?: string;\n  /**\n   * Automatically run API compatibility test against the latest version published to npm after compilation.\n   * - You can manually run compatibility tests using `yarn compat` if this feature is disabled.\n   * - You can ignore compatibility failures by adding lines to a \".compatignore\" file.\n   * @default false\n   * @stability stable\n   */\n  readonly compat?: boolean;\n  /**\n   * Email or URL of the library author.\n   * @default $GIT_USER_EMAIL\n   * @stability stable\n   */\n  readonly authorAddress?: string;\n  /**\n   * Options for ts-jest.\n   * @stability stable\n   */\n  readonly tsJestOptions?: typescript.TsJestOptions;\n  /**\n   * The name of the development tsconfig.json file.\n   * @default \"tsconfig.dev.json\"\n   * @stability stable\n   */\n  readonly tsconfigDevFile?: string;\n  /**\n   * Custom tsconfig options for the development tsconfig.json file (used for testing).\n   * @default - use the production tsconfig options\n   * @stability stable\n   */\n  readonly tsconfigDev?: javascript.TypescriptConfigOptions;\n  /**\n   * Custom TSConfig.\n   * @default - default options\n   * @stability stable\n   */\n  readonly tsconfig?: javascript.TypescriptConfigOptions;\n  /**\n   * Jest tests directory. Tests files should be named `xxx.test.ts`.\n   * If this directory is under `srcdir` (e.g. `src/test`, `src/__tests__`),\n   * then tests are going to be compiled into `lib/` and executed as javascript.\n   * If the test directory is outside of `src`, then we configure jest to\n   * compile the code in-memory.\n   * @default \"test\"\n   * @stability stable\n   */\n  readonly testdir?: string;\n  /**\n   * Typescript sources directory.\n   * @default \"src\"\n   * @stability stable\n   */\n  readonly srcdir?: string;\n  /**\n   * Options for .projenrc.ts.\n   * @stability stable\n   */\n  readonly projenrcTsOptions?: typescript.ProjenrcOptions;\n  /**\n   * Typescript  artifacts output directory.\n   * @default \"lib\"\n   * @stability stable\n   */\n  readonly libdir?: string;\n  /**\n   * Eslint options.\n   * @default - opinionated default options\n   * @stability stable\n   */\n  readonly eslintOptions?: javascript.EslintOptions;\n  /**\n   * Setup eslint.\n   * @default true\n   * @stability stable\n   */\n  readonly eslint?: boolean;\n  /**\n   * The .d.ts file that includes the type declarations for this module.\n   * @default - .d.ts file derived from the project's entrypoint (usually lib/index.d.ts)\n   * @stability stable\n   */\n  readonly entrypointTypes?: string;\n  /**\n   * Docs directory.\n   * @default \"docs\"\n   * @stability stable\n   */\n  readonly docsDirectory?: string;\n  /**\n   * Docgen by Typedoc.\n   * @default false\n   * @stability stable\n   */\n  readonly docgen?: boolean;\n  /**\n   * Do not generate a `tsconfig.dev.json` file.\n   * @default false\n   * @stability stable\n   */\n  readonly disableTsconfigDev?: boolean;\n  /**\n   * Do not generate a `tsconfig.json` file (used by jsii projects since tsconfig.json is generated by the jsii compiler).\n   * @default false\n   * @stability stable\n   */\n  readonly disableTsconfig?: boolean;\n  /**\n   * Enable Node.js package cache in GitHub workflows.\n   * @default false\n   * @stability stable\n   */\n  readonly workflowPackageCache?: boolean;\n  /**\n   * The node version used in GitHub Actions workflows.\n   * Always use this option if your GitHub Actions workflows require a specific to run.\n   * @default - `minNodeVersion` if set, otherwise `lts/*`.\n   * @stability stable\n   */\n  readonly workflowNodeVersion?: string;\n  /**\n   * The git identity to use in workflows.\n   * @default - GitHub Actions\n   * @stability stable\n   */\n  readonly workflowGitIdentity?: github.GitIdentity;\n  /**\n   * Workflow steps to use in order to bootstrap this repo.\n   * @default \"yarn install --frozen-lockfile && yarn projen\"\n   * @stability stable\n   */\n  readonly workflowBootstrapSteps?: Array<github.workflows.JobStep>;\n  /**\n   * Automatically release to npm when new versions are introduced.\n   * @default false\n   * @stability stable\n   */\n  readonly releaseToNpm?: boolean;\n  /**\n   * Add release management to this project.\n   * @default false\n   * @stability stable\n   */\n  readonly release?: boolean;\n  /**\n   * The contents of the pull request template.\n   * @default - default content\n   * @stability stable\n   */\n  readonly pullRequestTemplateContents?: Array<string>;\n  /**\n   * Include a GitHub pull request template.\n   * @default true\n   * @stability stable\n   */\n  readonly pullRequestTemplate?: boolean;\n  /**\n   * Options for .projenrc.js.\n   * @default - default options\n   * @stability stable\n   */\n  readonly projenrcJsOptions?: javascript.ProjenrcOptions;\n  /**\n   * Generate (once) .projenrc.js (in JavaScript). Set to `false` in order to disable .projenrc.js generation.\n   * @default - true if projenrcJson is false\n   * @stability stable\n   */\n  readonly projenrcJs?: boolean;\n  /**\n   * Indicates of \"projen\" should be installed as a devDependency.\n   * @default - true if not a subproject\n   * @stability stable\n   */\n  readonly projenDevDependency?: boolean;\n  /**\n   * Prettier options.\n   * @default - default options\n   * @stability stable\n   */\n  readonly prettierOptions?: javascript.PrettierOptions;\n  /**\n   * Setup prettier.\n   * @default false\n   * @stability stable\n   */\n  readonly prettier?: boolean;\n  /**\n   * Defines a `package` task that will produce an npm tarball under the artifacts directory (e.g. `dist`).\n   * @default true\n   * @stability stable\n   */\n  readonly package?: boolean;\n  /**\n   * Configuration options for .npmignore file.\n   * @stability stable\n   */\n  readonly npmIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Defines an .npmignore file. Normally this is only needed for libraries that are packaged as tarballs.\n   * @default true\n   * @stability stable\n   */\n  readonly npmignoreEnabled?: boolean;\n  /**\n   * Jest options.\n   * @default - default options\n   * @stability stable\n   */\n  readonly jestOptions?: javascript.JestOptions;\n  /**\n   * Setup jest unit tests.\n   * @default true\n   * @stability stable\n   */\n  readonly jest?: boolean;\n  /**\n   * Additional entries to .gitignore.\n   * @stability stable\n   */\n  readonly gitignore?: Array<string>;\n  /**\n   * Options for `UpgradeDependencies`.\n   * @default - default options\n   * @stability stable\n   */\n  readonly depsUpgradeOptions?: javascript.UpgradeDependenciesOptions;\n  /**\n   * Use tasks and github workflows to handle dependency upgrades.\n   * Cannot be used in conjunction with `dependabot`.\n   * @default true\n   * @stability stable\n   */\n  readonly depsUpgrade?: boolean;\n  /**\n   * Options for dependabot.\n   * @default - default options\n   * @stability stable\n   */\n  readonly dependabotOptions?: github.DependabotOptions;\n  /**\n   * Use dependabot to handle dependency upgrades.\n   * Cannot be used in conjunction with `depsUpgrade`.\n   * @default false\n   * @stability stable\n   */\n  readonly dependabot?: boolean;\n  /**\n   * The copyright years to put in the LICENSE file.\n   * @default - current year\n   * @stability stable\n   */\n  readonly copyrightPeriod?: string;\n  /**\n   * License copyright owner.\n   * @default - defaults to the value of authorName or \"\" if `authorName` is undefined.\n   * @stability stable\n   */\n  readonly copyrightOwner?: string;\n  /**\n   * Define the secret name for a specified https://codecov.io/ token A secret is required to send coverage for private repositories.\n   * @default - if this option is not specified, only public repositories are supported\n   * @stability stable\n   */\n  readonly codeCovTokenSecret?: string;\n  /**\n   * Define a GitHub workflow step for sending code coverage metrics to https://codecov.io/ Uses codecov/codecov-action@v4 A secret is required for private repos. Configured with `@codeCovTokenSecret`.\n   * @default false\n   * @stability stable\n   */\n  readonly codeCov?: boolean;\n  /**\n   * Configure which licenses should be deemed acceptable for use by dependencies.\n   * This setting will cause the build to fail, if any prohibited or not allowed licenses ares encountered.\n   * @default - no license checks are run during the build and all licenses will be accepted\n   * @stability stable\n   */\n  readonly checkLicenses?: javascript.LicenseCheckerOptions;\n  /**\n   * Options for `Bundler`.\n   * @stability stable\n   */\n  readonly bundlerOptions?: javascript.BundlerOptions;\n  /**\n   * Options for PR build workflow.\n   * @stability stable\n   */\n  readonly buildWorkflowOptions?: javascript.BuildWorkflowOptions;\n  /**\n   * Define a GitHub workflow for building PRs.\n   * @default - true if not a subproject\n   * @stability stable\n   */\n  readonly buildWorkflow?: boolean;\n  /**\n   * Biome options.\n   * @default - default options\n   * @stability stable\n   */\n  readonly biomeOptions?: javascript.BiomeOptions;\n  /**\n   * Setup Biome.\n   * @default false\n   * @stability stable\n   */\n  readonly biome?: boolean;\n  /**\n   * Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued).\n   * Throw if set to true but `autoApproveOptions` are not defined.\n   * @default - true\n   * @stability stable\n   */\n  readonly autoApproveUpgrades?: boolean;\n  /**\n   * A directory which will contain build artifacts.\n   * @default \"dist\"\n   * @stability stable\n   */\n  readonly artifactsDirectory?: string;\n  /**\n   * The name of the main release branch.\n   * @default \"main\"\n   * @stability stable\n   */\n  readonly defaultReleaseBranch?: string;\n  /**\n   * Github Runner Group selection options.\n   * @stability stable\n   * @description Defines a target Runner Group by name and/or labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOnGroup?: GroupRunnerOptions;\n  /**\n   * Github Runner selection labels.\n   * @default [\"ubuntu-latest\"]\n   * @stability stable\n   * @description Defines a target Runner by labels\n   * @throws {Error} if both `runsOn` and `runsOnGroup` are specified\n   */\n  readonly workflowRunsOn?: Array<string>;\n  /**\n   * Container image to use for GitHub workflows.\n   * @default - default image\n   * @stability stable\n   */\n  readonly workflowContainerImage?: string;\n  /**\n   * Custom configuration used when creating changelog with commit-and-tag-version package.\n   * Given values either append to default configuration or overwrite values in it.\n   * @default - standard configuration applicable for GitHub repositories\n   * @stability stable\n   */\n  readonly versionrcOptions?: Record<string, any>;\n  /**\n   * A set of workflow steps to execute in order to setup the workflow container.\n   * @stability stable\n   */\n  readonly releaseWorkflowSetupSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The name of the default release workflow.\n   * @default \"release\"\n   * @stability stable\n   */\n  readonly releaseWorkflowName?: string;\n  /**\n   * The release trigger to use.\n   * @default - Continuous releases (`ReleaseTrigger.continuous()`)\n   * @stability stable\n   */\n  readonly releaseTrigger?: release.ReleaseTrigger;\n  /**\n   * Automatically add the given prefix to release tags. Useful if you are releasing on multiple branches with overlapping version numbers.\n   * Note: this prefix is used to detect the latest tagged version\n   * when bumping, so if you change this on a project with an existing version\n   * history, you may need to manually tag your latest release\n   * with the new prefix.\n   * @default \"v\"\n   * @stability stable\n   */\n  readonly releaseTagPrefix?: string;\n  /**\n   * The label to apply to issues indicating publish failures.\n   * Only applies if `releaseFailureIssue` is true.\n   * @default \"failed-release\"\n   * @stability stable\n   */\n  readonly releaseFailureIssueLabel?: string;\n  /**\n   * Create a github issue on every failed publishing task.\n   * @default false\n   * @stability stable\n   */\n  readonly releaseFailureIssue?: boolean;\n  /**\n   * Defines additional release branches.\n   * A workflow will be created for each\n   * release branch which will publish releases from commits in this branch.\n   * Each release branch _must_ be assigned a major version number which is used\n   * to enforce that versions published from that branch always use that major\n   * version. If multiple branches are used, the `majorVersion` field must also\n   * be provided for the default branch.\n   * @default - no additional branches are used for release. you can use\n`addBranch()` to add additional branches.\n   * @stability stable\n   */\n  readonly releaseBranches?: Record<string, release.BranchOptions>;\n  /**\n   * Define publishing tasks that can be executed manually as well as workflows.\n   * Normally, publishing only happens within automated workflows. Enable this\n   * in order to create a publishing task for each publishing activity.\n   * @default false\n   * @stability stable\n   */\n  readonly publishTasks?: boolean;\n  /**\n   * Instead of actually publishing to package managers, just print the publishing command.\n   * @default false\n   * @stability stable\n   */\n  readonly publishDryRun?: boolean;\n  /**\n   * Bump versions from the default branch as pre-releases (e.g. \"beta\", \"alpha\", \"pre\").\n   * @default - normal semantic versions\n   * @stability stable\n   */\n  readonly prerelease?: string;\n  /**\n   * Steps to execute after build as part of the release workflow.\n   * @default []\n   * @stability stable\n   */\n  readonly postBuildSteps?: Array<github.workflows.JobStep>;\n  /**\n   * The npmDistTag to use when publishing from the default branch.\n   * To set the npm dist-tag for release branches, set the `npmDistTag` property\n   * for each branch.\n   * @default \"latest\"\n   * @stability stable\n   */\n  readonly npmDistTag?: string;\n  /**\n   * A shell command to control the next version to release.\n   * If present, this shell command will be run before the bump is executed, and\n   * it determines what version to release. It will be executed in the following\n   * environment:\n   *\n   * - Working directory: the project directory.\n   * - `$VERSION`: the current version. Looks like `1.2.3`.\n   * - `$LATEST_TAG`: the most recent tag. Looks like `prefix-v1.2.3`, or may be unset.\n   * - `$SUGGESTED_BUMP`: the suggested bump action based on commits. One of `major|minor|patch|none`.\n   *\n   * The command should print one of the following to `stdout`:\n   *\n   * - Nothing: the next version number will be determined based on commit history.\n   * - `x.y.z`: the next version number will be `x.y.z`.\n   * - `major|minor|patch`: the next version number will be the current version number\n   *   with the indicated component bumped.\n   *\n   * This setting cannot be specified together with `minMajorVersion`; the invoked\n   * script can be used to achieve the effects of `minMajorVersion`.\n   * @default - The next version will be determined based on the commit history and project settings.\n   * @stability stable\n   */\n  readonly nextVersionCommand?: string;\n  /**\n   * Minimal Major version to release.\n   * This can be useful to set to 1, as breaking changes before the 1.x major\n   * release are not incrementing the major version number.\n   *\n   * Can not be set together with `majorVersion`.\n   * @default - No minimum version is being enforced\n   * @stability stable\n   */\n  readonly minMajorVersion?: number;\n  /**\n   * Major version to release from the default branch.\n   * If this is specified, we bump the latest version of this major version line.\n   * If not specified, we bump the global latest version.\n   * @default - Major version is not enforced.\n   * @stability stable\n   */\n  readonly majorVersion?: number;\n  /**\n   * Version requirement of `publib` which is used to publish modules to npm.\n   * @default \"latest\"\n   * @stability stable\n   */\n  readonly jsiiReleaseVersion?: string;\n  /**\n   * The `commit-and-tag-version` compatible package used to bump the package version, as a dependency string.\n   * This can be any compatible package version, including the deprecated `standard-version@9`.\n   * @default - A recent version of \"commit-and-tag-version\"\n   * @stability stable\n   */\n  readonly bumpPackage?: string;\n  /**\n   * Options for Yarn Berry.\n   * @default - Yarn Berry v4 with all default options\n   * @stability stable\n   */\n  readonly yarnBerryOptions?: javascript.YarnBerryOptions;\n  /**\n   * Package's Stability.\n   * @stability stable\n   */\n  readonly stability?: string;\n  /**\n   * Options for privately hosted scoped packages.\n   * @default - fetch all scoped packages from the public npm registry\n   * @stability stable\n   */\n  readonly scopedPackagesOptions?: Array<javascript.ScopedPackagesOptions>;\n  /**\n   * If the package.json for your package is not in the root directory (for example if it is part of a monorepo), you can specify the directory in which it lives.\n   * @stability stable\n   */\n  readonly repositoryDirectory?: string;\n  /**\n   * The repository is the location where the actual code for your package lives.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-repository\n   * @stability stable\n   */\n  readonly repository?: string;\n  /**\n   * The version of PNPM to use if using PNPM as a package manager.\n   * @default \"9\"\n   * @stability stable\n   */\n  readonly pnpmVersion?: string;\n  /**\n   * Peer dependencies for this module.\n   * Dependencies listed here are required to\n   * be installed (and satisfied) by the _consumer_ of this library. Using peer\n   * dependencies allows you to ensure that only a single module of a certain\n   * library exists in the `node_modules` tree of your consumers.\n   *\n   * Note that prior to npm@7, peer dependencies are _not_ automatically\n   * installed, which means that adding peer dependencies to a library will be a\n   * breaking change for your customers.\n   *\n   * Unless `peerDependencyOptions.pinnedDevDependency` is disabled (it is\n   * enabled by default), projen will automatically add a dev dependency with a\n   * pinned version for each peer dependency. This will ensure that you build &\n   * test your module against the lowest peer version required.\n   * @default []\n   * @stability stable\n   */\n  readonly peerDeps?: Array<string>;\n  /**\n   * Options for `peerDeps`.\n   * @stability stable\n   */\n  readonly peerDependencyOptions?: javascript.PeerDependencyOptions;\n  /**\n   * The \"name\" in package.json.\n   * @default - defaults to project name\n   * @stability stable\n   * @featured true\n   */\n  readonly packageName?: string;\n  /**\n   * The Node Package Manager used to execute scripts.\n   * @default NodePackageManager.YARN_CLASSIC\n   * @stability stable\n   */\n  readonly packageManager?: javascript.NodePackageManager;\n  /**\n   * GitHub secret which contains the NPM token to use when publishing packages.\n   * @default \"NPM_TOKEN\"\n   * @stability stable\n   */\n  readonly npmTokenSecret?: string;\n  /**\n   * The base URL of the npm package registry.\n   * Must be a URL (e.g. start with \"https://\" or \"http://\")\n   * @default \"https://registry.npmjs.org\"\n   * @stability stable\n   */\n  readonly npmRegistryUrl?: string;\n  /**\n   * Should provenance statements be generated when the package is published.\n   * A supported package manager is required to publish a package with npm provenance statements and\n   * you will need to use a supported CI/CD provider.\n   *\n   * Note that the projen `Release` and `Publisher` components are using `publib` to publish packages,\n   * which is using npm internally and supports provenance statements independently of the package manager used.\n   * @default - true for public packages, false otherwise\n   * @stability stable\n   */\n  readonly npmProvenance?: boolean;\n  /**\n   * Access level of the npm package.\n   * @default - for scoped packages (e.g. `foo@bar`), the default is\n`NpmAccess.RESTRICTED`, for non-scoped packages, the default is\n`NpmAccess.PUBLIC`.\n   * @stability stable\n   */\n  readonly npmAccess?: javascript.NpmAccess;\n  /**\n   * The minimum node version required by this package to function. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any older versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option, even if your package is incompatible with EOL versions of node.\n   * Consider this option only if your package depends on a specific feature, that is not available in other LTS versions.\n   * Setting this option has very high impact on the consumers of your package,\n   * as package managers will actively prevent usage with node versions you have marked as incompatible.\n   *\n   * To change the node version of your CI/CD workflows, use `workflowNodeVersion`.\n   * @default - no minimum version is enforced\n   * @stability stable\n   */\n  readonly minNodeVersion?: string;\n  /**\n   * The maximum node version supported by this package. Most projects should not use this option.\n   * The value indicates that the package is incompatible with any newer versions of node.\n   * This requirement is enforced via the engines field.\n   *\n   * You will normally not need to set this option.\n   * Consider this option only if your package is known to not function with newer versions of node.\n   * @default - no maximum version is enforced\n   * @stability stable\n   */\n  readonly maxNodeVersion?: string;\n  /**\n   * Indicates if a license should be added.\n   * @default true\n   * @stability stable\n   */\n  readonly licensed?: boolean;\n  /**\n   * License's SPDX identifier.\n   * See https://github.com/projen/projen/tree/main/license-text for a list of supported licenses.\n   * Use the `licensed` option if you want to no license to be specified.\n   * @default \"MIT\"\n   * @stability stable\n   */\n  readonly license?: string;\n  /**\n   * Keywords to include in `package.json`.\n   * @stability stable\n   */\n  readonly keywords?: Array<string>;\n  /**\n   * Package's Homepage / Website.\n   * @stability stable\n   */\n  readonly homepage?: string;\n  /**\n   * Module entrypoint (`main` in `package.json`).\n   * Set to an empty string to not include `main` in your package.json\n   * @default \"lib/index.js\"\n   * @stability stable\n   */\n  readonly entrypoint?: string;\n  /**\n   * Build dependencies for this module.\n   * These dependencies will only be\n   * available in your build environment but will not be fetched when this\n   * module is consumed.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability stable\n   * @featured true\n   */\n  readonly devDeps?: Array<string>;\n  /**\n   * The description is just a string that helps people understand the purpose of the package.\n   * It can be used when searching for packages in a package manager as well.\n   * See https://classic.yarnpkg.com/en/docs/package-json/#toc-description\n   * @stability stable\n   * @featured true\n   */\n  readonly description?: string;\n  /**\n   * Runtime dependencies of this module.\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @default []\n   * @stability stable\n   * @featured true\n   */\n  readonly deps?: Array<string>;\n  /**\n   * Options for npm packages using AWS CodeArtifact.\n   * This is required if publishing packages to, or installing scoped packages from AWS CodeArtifact\n   * @default - undefined\n   * @stability stable\n   */\n  readonly codeArtifactOptions?: javascript.CodeArtifactOptions;\n  /**\n   * The version of Bun to use if using Bun as a package manager.\n   * @default \"latest\"\n   * @stability stable\n   */\n  readonly bunVersion?: string;\n  /**\n   * List of dependencies to bundle into this module.\n   * These modules will be\n   * added both to the `dependencies` section and `bundledDependencies` section of\n   * your `package.json`.\n   *\n   * The recommendation is to only specify the module name here (e.g.\n   * `express`). This will behave similar to `yarn add` or `npm install` in the\n   * sense that it will add the module as a dependency to your `package.json`\n   * file with the latest version (`^`). You can specify semver requirements in\n   * the same syntax passed to `npm i` or `yarn add` (e.g. `express@^2`) and\n   * this will be what you `package.json` will eventually include.\n   * @stability stable\n   */\n  readonly bundledDeps?: Array<string>;\n  /**\n   * The url to your project's issue tracker.\n   * @stability stable\n   */\n  readonly bugsUrl?: string;\n  /**\n   * The email address to which issues should be reported.\n   * @stability stable\n   */\n  readonly bugsEmail?: string;\n  /**\n   * Binary programs vended with your module.\n   * You can use this option to add/customize how binaries are represented in\n   * your `package.json`, but unless `autoDetectBin` is `false`, every\n   * executable file under `bin` will automatically be added to this section.\n   * @stability stable\n   */\n  readonly bin?: Record<string, string>;\n  /**\n   * Automatically add all executables under the `bin` directory to your `package.json` file under the `bin` section.\n   * @default true\n   * @stability stable\n   */\n  readonly autoDetectBin?: boolean;\n  /**\n   * Author's URL / Website.\n   * @stability stable\n   */\n  readonly authorUrl?: string;\n  /**\n   * Is the author an organization.\n   * @stability stable\n   */\n  readonly authorOrganization?: boolean;\n  /**\n   * Author's name.\n   * @stability stable\n   */\n  readonly authorName: string;\n  /**\n   * Author's e-mail.\n   * @stability stable\n   */\n  readonly authorEmail?: string;\n  /**\n   * Allow the project to include `peerDependencies` and `bundledDependencies`.\n   * This is normally only allowed for libraries. For apps, there's no meaning\n   * for specifying these.\n   * @default true\n   * @stability stable\n   */\n  readonly allowLibraryDependencies?: boolean;\n  /**\n   * Enable VSCode integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability stable\n   */\n  readonly vscode?: boolean;\n  /**\n   * Auto-close stale issues and pull requests.\n   * To disable set `stale` to `false`.\n   * @default - see defaults in `StaleOptions`\n   * @stability stable\n   */\n  readonly staleOptions?: github.StaleOptions;\n  /**\n   * Auto-close of stale issues and pull request.\n   * See `staleOptions` for options.\n   * @default false\n   * @stability stable\n   */\n  readonly stale?: boolean;\n  /**\n   * The README setup.\n   * @default - { filename: 'README.md', contents: '# replace this' }\n   * @stability stable\n   */\n  readonly readme?: SampleReadmeProps;\n  /**\n   * Choose a method of providing GitHub API access for projen workflows.\n   * @default - use a personal access token named PROJEN_GITHUB_TOKEN\n   * @stability stable\n   */\n  readonly projenCredentials?: github.GithubCredentials;\n  /**\n   * Add a Gitpod development environment.\n   * @default false\n   * @stability stable\n   */\n  readonly gitpod?: boolean;\n  /**\n   * Options for GitHub integration.\n   * @default - see GitHubOptions\n   * @stability stable\n   */\n  readonly githubOptions?: github.GitHubOptions;\n  /**\n   * Enable GitHub integration.\n   * Enabled by default for root projects. Disabled for non-root projects.\n   * @default true\n   * @stability stable\n   */\n  readonly github?: boolean;\n  /**\n   * Add a VSCode development environment (used for GitHub Codespaces).\n   * @default false\n   * @stability stable\n   */\n  readonly devContainer?: boolean;\n  /**\n   * Add a `clobber` task which resets the repo to origin.\n   * @default - true, but false for subprojects\n   * @stability stable\n   */\n  readonly clobber?: boolean;\n  /**\n   * Configure options for automatic merging on GitHub.\n   * Has no effect if\n   * `github.mergify` or `autoMerge` is set to false.\n   * @default - see defaults in `AutoMergeOptions`\n   * @stability stable\n   */\n  readonly autoMergeOptions?: github.AutoMergeOptions;\n  /**\n   * Enable automatic merging on GitHub.\n   * Has no effect if `github.mergify`\n   * is set to false.\n   * @default true\n   * @stability stable\n   */\n  readonly autoMerge?: boolean;\n  /**\n   * Enable and configure the 'auto approve' workflow.\n   * @default - auto approve is disabled\n   * @stability stable\n   */\n  readonly autoApproveOptions?: github.AutoApproveOptions;\n  /**\n   * Options for renovatebot.\n   * @default - default options\n   * @stability stable\n   */\n  readonly renovatebotOptions?: RenovatebotOptions;\n  /**\n   * Use renovatebot to handle dependency upgrades.\n   * @default false\n   * @stability stable\n   */\n  readonly renovatebot?: boolean;\n  /**\n   * Options for .projenrc.json.\n   * @default - default options\n   * @stability stable\n   */\n  readonly projenrcJsonOptions?: ProjenrcJsonOptions;\n  /**\n   * Generate (once) .projenrc.json (in JSON). Set to `false` in order to disable .projenrc.json generation.\n   * @default false\n   * @stability stable\n   */\n  readonly projenrcJson?: boolean;\n  /**\n   * The shell command to use in order to run the projen CLI.\n   * Can be used to customize in special environments.\n   * @default \"npx projen\"\n   * @stability stable\n   */\n  readonly projenCommand?: string;\n  /**\n   * The parent project, if this project is part of a bigger project.\n   * @stability stable\n   */\n  readonly parent?: Project;\n  /**\n   * The root directory of the project.\n   * Relative to this directory, all files are synthesized.\n   *\n   * If this project has a parent, this directory is relative to the parent\n   * directory and it cannot be the same as the parent or any of it's other\n   * subprojects.\n   * @default \".\"\n   * @stability stable\n   */\n  readonly outdir?: string;\n  /**\n   * Configure logging options such as verbosity.\n   * @default {}\n   * @stability stable\n   */\n  readonly logging?: LoggerOptions;\n  /**\n   * Configuration options for git.\n   * @stability stable\n   */\n  readonly gitOptions?: GitOptions;\n  /**\n   * Configuration options for .gitignore file.\n   * @stability stable\n   */\n  readonly gitIgnoreOptions?: IgnoreFileOptions;\n  /**\n   * Whether to commit the managed files by default.\n   * @default true\n   * @stability stable\n   */\n  readonly commitGenerated?: boolean;\n  /**\n   * This is the name of your project.\n   * @default $BASEDIR\n   * @stability stable\n   * @featured true\n   */\n  readonly name?: string;\n  /**\n   * @stability stable\n   */\n  readonly repo: string;\n  /**\n   * Which conventional commit types should be released\n   * @default ['feat', 'fix', 'chore', 'revert']\n   * @stability stable\n   */\n  readonly releasableCommitTypes?: Array<string>;\n  /**\n   * Which conventional commit types are allowed to be used\n   * Types listed in `releasableCommitTypes` are always allowed\n   * @default ['feat', 'fix', 'chore', 'revert', 'docs', 'ci']\n   * @stability stable\n   */\n  readonly allowedCommitTypes?: Array<string>;\n  /**\n   * Use this app for workflow automation. Remember to install the app and to configure credentials.\n   * @default - tokens will be used\n   * @stability stable\n   */\n  readonly automationAppName?: string;\n  /**\n   * Allow the repo owner to self approve PRs by putting a label on it.\n   * @default true\n   * @stability stable\n   */\n  readonly ownerCanSelfApprovePRs?: boolean;\n  /**\n   * @default UpgradeDependenciesSchedule.WEEKLY\n   * @stability stable\n   */\n  readonly upgradesSchedule?: javascript.UpgradeDependenciesSchedule;\n  /**\n   * Add a logo.\n   * Use `Logo.placeholder()` to get started.\n   * @stability stable\n   */\n  readonly logo?: logo.ILogo;\n  /**\n   * Configure how the wordmark is created from a logo.\n   * Wordmarks are only created when a logo is available.\n   * @default - derived from logo and project\n   * @stability stable\n   */\n  readonly wordmarkOptions?: logo.WordmarkOptions;\n  /**\n   * The projen version constraint that is supported by this project\n   * @default \"0.x >=0.75.0\"\n   * @stability stable\n   */\n  readonly projenVersion?: string;\n}\n"]}
@@ -1,6 +1,6 @@
1
1
  import { cdk } from 'projen';
2
- import { SvgFile, Wordmark } from './logo';
3
- import { ProjenProjectOptions } from './projen-project-options';
2
+ import type { SvgFile, Wordmark } from './logo';
3
+ import type { ProjenProjectOptions } from './projen-project-options';
4
4
  /**
5
5
  * A project to create new projen projects & components
6
6
  * @pjid projen
@@ -34,5 +34,5 @@ class ProjenProject extends projen_1.cdk.JsiiProject {
34
34
  }
35
35
  exports.ProjenProject = ProjenProject;
36
36
  _a = JSII_RTTI_SYMBOL_1;
37
- ProjenProject[_a] = { fqn: "mrpj.ProjenProject", version: "0.1.98" };
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvamVuLXByb2plY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcHJvamVuLXByb2plY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxtQ0FBNkI7QUFDN0IseUNBQWlLO0FBR2pLLG1DQUE0RDtBQUU1RDs7O0dBR0c7QUFDSCxNQUFhLGFBQWMsU0FBUSxZQUFHLENBQUMsV0FBVztJQUloRCxZQUFtQixPQUE2QjtRQUM5QyxNQUFNLElBQUksR0FBRyxJQUFBLHNCQUFjLEVBQ3pCLElBQUEsc0JBQVcsR0FBRSxFQUNiLGtCQUFPLEVBQ1AscUJBQVUsRUFDVixJQUFBLHVCQUFZLEVBQUM7WUFDWCxhQUFhLEVBQUUsT0FBTyxDQUFDLGFBQWEsSUFBSSxjQUFjO1lBQ3RELE9BQU8sRUFBRSxDQUFDLDhCQUE4QixFQUFFLFlBQVksRUFBRSxpQkFBaUIsQ0FBQztZQUMxRSxRQUFRLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztZQUNoQyxxQkFBcUIsRUFBRTtnQkFDckIsbUJBQW1CLEVBQUUsS0FBSzthQUMzQjtTQUNGLENBQUMsRUFDRixJQUFBLHdCQUFhLEVBQUM7WUFDWixNQUFNLEVBQUUsT0FBTyxDQUFDLFVBQVU7WUFDMUIsU0FBUyxFQUFFLFNBQVM7WUFDcEIsVUFBVSxFQUFFLEtBQUs7WUFDakIsVUFBVSxFQUFFLElBQUk7WUFDaEIsV0FBVyxFQUFFLE9BQU87WUFDcEIsaUJBQWlCLEVBQUUsT0FBTztZQUMxQixhQUFhLEVBQUUsU0FBUztTQUN6QixDQUFDLENBQ0gsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVYLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUVaLElBQUEseUJBQWlCLEVBQ2YsaUJBQU0sRUFDTixlQUFJLEVBQ0osc0JBQVcsRUFDWCw2QkFBa0IsRUFDbEIsZ0NBQXFCLENBQ3RCLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2hCLENBQUM7O0FBckNILHNDQXNDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNkayB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgeyBhdXRvbWF0aW9uLCBkZXBlbmRlbmNpZXMsIGVuc3VyZURlcGVuZGVuY2llcywgZXNsaW50LCBmb3JjZURlZmF1bHRzLCBsb2dvLCBub2RlVmVyc2lvbiwgcGFja2FnZUluZm8sIHByZXZlbnRTZWxmRGVwZW5kZW5jeSwgcmVsZWFzZSB9IGZyb20gJy4vZmVhdHVyZXMnO1xuaW1wb3J0IHsgU3ZnRmlsZSwgV29yZG1hcmsgfSBmcm9tICcuL2xvZ28nO1xuaW1wb3J0IHsgUHJvamVuUHJvamVjdE9wdGlvbnMgfSBmcm9tICcuL3Byb2plbi1wcm9qZWN0LW9wdGlvbnMnO1xuaW1wb3J0IHsgY29uZmlndXJlRmVhdHVyZXMsIGRlZmF1bHRPcHRpb25zIH0gZnJvbSAnLi91dGlscyc7XG5cbi8qKlxuICogQSBwcm9qZWN0IHRvIGNyZWF0ZSBuZXcgcHJvamVuIHByb2plY3RzICYgY29tcG9uZW50c1xuICogQHBqaWQgcHJvamVuXG4gKi9cbmV4cG9ydCBjbGFzcyBQcm9qZW5Qcm9qZWN0IGV4dGVuZHMgY2RrLkpzaWlQcm9qZWN0IHtcbiAgcHVibGljIHJlYWRvbmx5IGxvZ28/OiBTdmdGaWxlO1xuICBwdWJsaWMgcmVhZG9ubHkgd29yZG1hcms/OiBXb3JkbWFyaztcblxuICBwdWJsaWMgY29uc3RydWN0b3Iob3B0aW9uczogUHJvamVuUHJvamVjdE9wdGlvbnMpIHtcbiAgICBjb25zdCBvcHRzID0gZGVmYXVsdE9wdGlvbnM8UHJvamVuUHJvamVjdE9wdGlvbnM+KFxuICAgICAgcGFja2FnZUluZm8oKSxcbiAgICAgIHJlbGVhc2UsXG4gICAgICBhdXRvbWF0aW9uLFxuICAgICAgZGVwZW5kZW5jaWVzKHtcbiAgICAgICAgcHJvamVuVmVyc2lvbjogb3B0aW9ucy5wcm9qZW5WZXJzaW9uID8/ICcwLnggPj0wLjc1LjAnLFxuICAgICAgICBkZXZEZXBzOiBbJ0BtcmdyYWluL2pzaWktc3RydWN0LWJ1aWxkZXInLCAnQGpzaWkvc3BlYycsICdqc2lpLWRvY2dlbkBeMTAnXSxcbiAgICAgICAgcGVlckRlcHM6IFsnY29uc3RydWN0c0BeMTAuMC4wJ10sXG4gICAgICAgIHBlZXJEZXBlbmRlbmN5T3B0aW9uczoge1xuICAgICAgICAgIHBpbm5lZERldkRlcGVuZGVuY3k6IGZhbHNlLFxuICAgICAgICB9LFxuICAgICAgfSksXG4gICAgICBmb3JjZURlZmF1bHRzKHtcbiAgICAgICAgYXV0aG9yOiBvcHRpb25zLmF1dGhvck5hbWUsXG4gICAgICAgIGF1dGhvclVybDogdW5kZWZpbmVkLFxuICAgICAgICBzYW1wbGVDb2RlOiBmYWxzZSxcbiAgICAgICAgcHJvamVucmNUczogdHJ1ZSxcbiAgICAgICAganNpaVZlcnNpb246ICc1LjMueCcsXG4gICAgICAgIHR5cGVzY3JpcHRWZXJzaW9uOiAnNS4zLngnLFxuICAgICAgICBwcm9qZW5WZXJzaW9uOiB1bmRlZmluZWQsXG4gICAgICB9KSxcbiAgICApKG9wdGlvbnMpO1xuXG4gICAgc3VwZXIob3B0cyk7XG5cbiAgICBjb25maWd1cmVGZWF0dXJlcyhcbiAgICAgIGVzbGludCxcbiAgICAgIGxvZ28sXG4gICAgICBub2RlVmVyc2lvbixcbiAgICAgIGVuc3VyZURlcGVuZGVuY2llcyxcbiAgICAgIHByZXZlbnRTZWxmRGVwZW5kZW5jeSxcbiAgICApKHRoaXMsIG9wdHMpO1xuICB9XG59XG4iXX0=
37
+ ProjenProject[_a] = { fqn: "mrpj.ProjenProject", version: "0.1.100" };
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvamVuLXByb2plY3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvcHJvamVuLXByb2plY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSxtQ0FBNkI7QUFDN0IseUNBQWlLO0FBR2pLLG1DQUE0RDtBQUU1RDs7O0dBR0c7QUFDSCxNQUFhLGFBQWMsU0FBUSxZQUFHLENBQUMsV0FBVztJQUloRCxZQUFtQixPQUE2QjtRQUM5QyxNQUFNLElBQUksR0FBRyxJQUFBLHNCQUFjLEVBQ3pCLElBQUEsc0JBQVcsR0FBRSxFQUNiLGtCQUFPLEVBQ1AscUJBQVUsRUFDVixJQUFBLHVCQUFZLEVBQUM7WUFDWCxhQUFhLEVBQUUsT0FBTyxDQUFDLGFBQWEsSUFBSSxjQUFjO1lBQ3RELE9BQU8sRUFBRSxDQUFDLDhCQUE4QixFQUFFLFlBQVksRUFBRSxpQkFBaUIsQ0FBQztZQUMxRSxRQUFRLEVBQUUsQ0FBQyxvQkFBb0IsQ0FBQztZQUNoQyxxQkFBcUIsRUFBRTtnQkFDckIsbUJBQW1CLEVBQUUsS0FBSzthQUMzQjtTQUNGLENBQUMsRUFDRixJQUFBLHdCQUFhLEVBQUM7WUFDWixNQUFNLEVBQUUsT0FBTyxDQUFDLFVBQVU7WUFDMUIsU0FBUyxFQUFFLFNBQVM7WUFDcEIsVUFBVSxFQUFFLEtBQUs7WUFDakIsVUFBVSxFQUFFLElBQUk7WUFDaEIsV0FBVyxFQUFFLE9BQU87WUFDcEIsaUJBQWlCLEVBQUUsT0FBTztZQUMxQixhQUFhLEVBQUUsU0FBUztTQUN6QixDQUFDLENBQ0gsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUVYLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUVaLElBQUEseUJBQWlCLEVBQ2YsaUJBQU0sRUFDTixlQUFJLEVBQ0osc0JBQVcsRUFDWCw2QkFBa0IsRUFDbEIsZ0NBQXFCLENBQ3RCLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2hCLENBQUM7O0FBckNILHNDQXNDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNkayB9IGZyb20gJ3Byb2plbic7XG5pbXBvcnQgeyBhdXRvbWF0aW9uLCBkZXBlbmRlbmNpZXMsIGVuc3VyZURlcGVuZGVuY2llcywgZXNsaW50LCBmb3JjZURlZmF1bHRzLCBsb2dvLCBub2RlVmVyc2lvbiwgcGFja2FnZUluZm8sIHByZXZlbnRTZWxmRGVwZW5kZW5jeSwgcmVsZWFzZSB9IGZyb20gJy4vZmVhdHVyZXMnO1xuaW1wb3J0IHR5cGUgeyBTdmdGaWxlLCBXb3JkbWFyayB9IGZyb20gJy4vbG9nbyc7XG5pbXBvcnQgdHlwZSB7IFByb2plblByb2plY3RPcHRpb25zIH0gZnJvbSAnLi9wcm9qZW4tcHJvamVjdC1vcHRpb25zJztcbmltcG9ydCB7IGNvbmZpZ3VyZUZlYXR1cmVzLCBkZWZhdWx0T3B0aW9ucyB9IGZyb20gJy4vdXRpbHMnO1xuXG4vKipcbiAqIEEgcHJvamVjdCB0byBjcmVhdGUgbmV3IHByb2plbiBwcm9qZWN0cyAmIGNvbXBvbmVudHNcbiAqIEBwamlkIHByb2plblxuICovXG5leHBvcnQgY2xhc3MgUHJvamVuUHJvamVjdCBleHRlbmRzIGNkay5Kc2lpUHJvamVjdCB7XG4gIHB1YmxpYyByZWFkb25seSBsb2dvPzogU3ZnRmlsZTtcbiAgcHVibGljIHJlYWRvbmx5IHdvcmRtYXJrPzogV29yZG1hcms7XG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKG9wdGlvbnM6IFByb2plblByb2plY3RPcHRpb25zKSB7XG4gICAgY29uc3Qgb3B0cyA9IGRlZmF1bHRPcHRpb25zPFByb2plblByb2plY3RPcHRpb25zPihcbiAgICAgIHBhY2thZ2VJbmZvKCksXG4gICAgICByZWxlYXNlLFxuICAgICAgYXV0b21hdGlvbixcbiAgICAgIGRlcGVuZGVuY2llcyh7XG4gICAgICAgIHByb2plblZlcnNpb246IG9wdGlvbnMucHJvamVuVmVyc2lvbiA/PyAnMC54ID49MC43NS4wJyxcbiAgICAgICAgZGV2RGVwczogWydAbXJncmFpbi9qc2lpLXN0cnVjdC1idWlsZGVyJywgJ0Bqc2lpL3NwZWMnLCAnanNpaS1kb2NnZW5AXjEwJ10sXG4gICAgICAgIHBlZXJEZXBzOiBbJ2NvbnN0cnVjdHNAXjEwLjAuMCddLFxuICAgICAgICBwZWVyRGVwZW5kZW5jeU9wdGlvbnM6IHtcbiAgICAgICAgICBwaW5uZWREZXZEZXBlbmRlbmN5OiBmYWxzZSxcbiAgICAgICAgfSxcbiAgICAgIH0pLFxuICAgICAgZm9yY2VEZWZhdWx0cyh7XG4gICAgICAgIGF1dGhvcjogb3B0aW9ucy5hdXRob3JOYW1lLFxuICAgICAgICBhdXRob3JVcmw6IHVuZGVmaW5lZCxcbiAgICAgICAgc2FtcGxlQ29kZTogZmFsc2UsXG4gICAgICAgIHByb2plbnJjVHM6IHRydWUsXG4gICAgICAgIGpzaWlWZXJzaW9uOiAnNS4zLngnLFxuICAgICAgICB0eXBlc2NyaXB0VmVyc2lvbjogJzUuMy54JyxcbiAgICAgICAgcHJvamVuVmVyc2lvbjogdW5kZWZpbmVkLFxuICAgICAgfSksXG4gICAgKShvcHRpb25zKTtcblxuICAgIHN1cGVyKG9wdHMpO1xuXG4gICAgY29uZmlndXJlRmVhdHVyZXMoXG4gICAgICBlc2xpbnQsXG4gICAgICBsb2dvLFxuICAgICAgbm9kZVZlcnNpb24sXG4gICAgICBlbnN1cmVEZXBlbmRlbmNpZXMsXG4gICAgICBwcmV2ZW50U2VsZkRlcGVuZGVuY3ksXG4gICAgKSh0aGlzLCBvcHRzKTtcbiAgfVxufVxuIl19
@@ -296,6 +296,18 @@ export interface TypeScriptProjectOptions {
296
296
  * @stability stable
297
297
  */
298
298
  readonly buildWorkflow?: boolean;
299
+ /**
300
+ * Biome options.
301
+ * @default - default options
302
+ * @stability stable
303
+ */
304
+ readonly biomeOptions?: javascript.BiomeOptions;
305
+ /**
306
+ * Setup Biome.
307
+ * @default false
308
+ * @stability stable
309
+ */
310
+ readonly biome?: boolean;
299
311
  /**
300
312
  * Automatically approve deps upgrade PRs, allowing them to be merged by mergify (if configued).
301
313
  * Throw if set to true but `autoApproveOptions` are not defined.