@codedrifters/configulator 0.0.82 → 0.0.83
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +39 -0
- package/lib/projects/monorepo-project.js +38 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -147,6 +147,45 @@ The `MonorepoProject` accepts all options from `TypeScriptProjectOptions` plus:
|
|
|
147
147
|
- `packageManager: NodePackageManager.PNPM` - PNPM is mandatory
|
|
148
148
|
- `defaultReleaseBranch: "main"` - Standard branch name
|
|
149
149
|
|
|
150
|
+
**Pull Request Linting:**
|
|
151
|
+
- By default, pull request titles are validated to follow [Conventional Commits](https://www.conventionalcommits.org/)
|
|
152
|
+
- All conventional commit types are allowed by default: `feat`, `fix`, `docs`, `style`, `refactor`, `perf`, `test`, `build`, `ci`, `chore`, `revert`
|
|
153
|
+
- This provides flexibility for different types of changes while maintaining consistency
|
|
154
|
+
|
|
155
|
+
**Overriding Pull Request Lint Options:**
|
|
156
|
+
|
|
157
|
+
To customize which commit types are allowed, override the `githubOptions.pullRequestLintOptions`:
|
|
158
|
+
|
|
159
|
+
```typescript
|
|
160
|
+
const project = new MonorepoProject({
|
|
161
|
+
name: 'my-monorepo',
|
|
162
|
+
githubOptions: {
|
|
163
|
+
pullRequestLintOptions: {
|
|
164
|
+
semanticTitleOptions: {
|
|
165
|
+
types: ['feat', 'fix', 'docs', 'chore'], // Only allow these types
|
|
166
|
+
},
|
|
167
|
+
},
|
|
168
|
+
},
|
|
169
|
+
});
|
|
170
|
+
```
|
|
171
|
+
|
|
172
|
+
You can also configure other pull request linting options:
|
|
173
|
+
|
|
174
|
+
```typescript
|
|
175
|
+
const project = new MonorepoProject({
|
|
176
|
+
name: 'my-monorepo',
|
|
177
|
+
githubOptions: {
|
|
178
|
+
pullRequestLintOptions: {
|
|
179
|
+
semanticTitleOptions: {
|
|
180
|
+
types: ['feat', 'fix', 'docs'],
|
|
181
|
+
requireScope: true, // Require scope in commit type (e.g., feat(ui):)
|
|
182
|
+
scopes: ['ui', 'api', 'core'], // Only allow these scopes
|
|
183
|
+
},
|
|
184
|
+
},
|
|
185
|
+
},
|
|
186
|
+
});
|
|
187
|
+
```
|
|
188
|
+
|
|
150
189
|
The root project automatically includes `@codedrifters/configulator` and `constructs` as dev dependencies.
|
|
151
190
|
|
|
152
191
|
### TypeScriptProject
|
|
@@ -52,6 +52,43 @@ class MonorepoProject extends typescript_1.TypeScriptAppProject {
|
|
|
52
52
|
*/
|
|
53
53
|
githubOptions: {
|
|
54
54
|
mergify: false,
|
|
55
|
+
/**
|
|
56
|
+
* Configure pull request linting to validate PR titles follow Conventional Commits.
|
|
57
|
+
* By default, all conventional commit types are allowed, providing flexibility
|
|
58
|
+
* for different types of changes (features, fixes, documentation, refactoring, etc.).
|
|
59
|
+
*/
|
|
60
|
+
pullRequestLintOptions: {
|
|
61
|
+
semanticTitleOptions: {
|
|
62
|
+
/**
|
|
63
|
+
* Allowed conventional commit types for PR titles.
|
|
64
|
+
* This includes all standard types from the Conventional Commits specification:
|
|
65
|
+
* - feat: New features
|
|
66
|
+
* - fix: Bug fixes
|
|
67
|
+
* - docs: Documentation changes
|
|
68
|
+
* - style: Code style changes (formatting, etc.)
|
|
69
|
+
* - refactor: Code refactoring
|
|
70
|
+
* - perf: Performance improvements
|
|
71
|
+
* - test: Test additions or changes
|
|
72
|
+
* - build: Build system changes
|
|
73
|
+
* - ci: CI configuration changes
|
|
74
|
+
* - chore: Maintenance tasks
|
|
75
|
+
* - revert: Revert commits
|
|
76
|
+
*/
|
|
77
|
+
types: [
|
|
78
|
+
"feat",
|
|
79
|
+
"fix",
|
|
80
|
+
"docs",
|
|
81
|
+
"style",
|
|
82
|
+
"refactor",
|
|
83
|
+
"perf",
|
|
84
|
+
"test",
|
|
85
|
+
"build",
|
|
86
|
+
"ci",
|
|
87
|
+
"chore",
|
|
88
|
+
"revert",
|
|
89
|
+
],
|
|
90
|
+
},
|
|
91
|
+
},
|
|
55
92
|
},
|
|
56
93
|
/**
|
|
57
94
|
* Default PNPM version to use in the monorepo.
|
|
@@ -237,4 +274,4 @@ class MonorepoProject extends typescript_1.TypeScriptAppProject {
|
|
|
237
274
|
}
|
|
238
275
|
}
|
|
239
276
|
exports.MonorepoProject = MonorepoProject;
|
|
240
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monorepo-project.js","sourceRoot":"","sources":["../../src/projects/monorepo-project.ts"],"names":[],"mappings":"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","sourcesContent":["import { BuildWorkflowOptions } from \"projen/lib/build\";\nimport {\n  NodePackageManager,\n  UpgradeDependencies,\n  UpgradeDependenciesOptions,\n  UpgradeDependenciesSchedule,\n} from \"projen/lib/javascript\";\nimport {\n  TypeScriptAppProject,\n  TypeScriptProjectOptions,\n} from \"projen/lib/typescript\";\nimport { merge } from \"ts-deepmerge\";\nimport { PnpmWorkspace, PnpmWorkspaceOptions } from \"../pnpm/pnpm-workspace\";\nimport { ResetTask, ResetTaskOptions } from \"../tasks/reset-task\";\nimport {\n  ROOT_CI_TASK_NAME,\n  TurboRepo,\n  TurboRepoOptions,\n} from \"../turbo/turbo-repo\";\nimport { VERSION } from \"../versions\";\nimport { VSCodeConfig } from \"../vscode/vscode\";\n\n/*******************************************************************************\n *\n * Monorepo Root Project\n *\n * This project should be used as the base project for other projects in a\n * monorepo. The Monorepo root project generally won't contain any code, but it\n * will contain configuration for the monorepo, such as package management,\n * linting, testing, and other project-wide settings.\n *\n ******************************************************************************/\n\n/**\n * Configuration options for the monorepo.\n */\nexport interface MonorepoProjectOptions extends Omit<\n  TypeScriptProjectOptions,\n  \"defaultReleaseBranch\"\n> {\n  /**\n   * Turn on Turborepo support.\n   *\n   * @default true\n   */\n  turbo?: boolean;\n\n  /**\n   * Optionsal options for turborepo config\n   */\n  turboOptions?: TurboRepoOptions;\n\n  /**\n   * Enable the reset task that deletes all build artifacts.\n   *\n   * @default true\n   */\n  resetTask?: boolean;\n\n  /**\n   * Options for the reset task.\n   */\n  resetTaskOptions?: ResetTaskOptions;\n\n  /**\n   * PNPM options for the monorepo.\n   */\n  pnpmOptions?: {\n    /**\n     * The version of PNPM to use in the monorepo.\n     * @default VERSION.PNPM_VERSION\n     * @see {@link src/versions.ts}\n     */\n    version?: string;\n\n    /**\n     * Optional pnpm options for the monorepo workspace file.\n     */\n    pnpmWorkspaceOptions?: PnpmWorkspaceOptions;\n  };\n\n  /**\n   * Turn on the upgrade configurator task that will attempt to upgrade the\n   * @codedrifters/configulator package version nightly. This keeps the\n   * project up-to-date with the latest official CodeDrifters configs..\n   *\n   * @default true\n   */\n  readonly upgradeConfigulatorTask?: boolean;\n\n  /**\n   * Options for the upgrade configurator task.\n   *\n   * @default: daily schedule\n   */\n  readonly upgradeConfigulatorTaskOptions?: UpgradeDependenciesOptions;\n}\n\ninterface AppliedOptions\n  extends TypeScriptProjectOptions, MonorepoProjectOptions {}\n\nexport class MonorepoProject extends TypeScriptAppProject {\n  /**\n   * Version of PNPM which the whole monorepo should use.\n   */\n  readonly pnpmVersion: string;\n\n  /**\n   * Optional task that will attempt to upgrade the @codedrifters/configulator\n   * package version nightly. This keeps the project up-to-date with the latest\n   * official CodeDrifters configs.\n   */\n  readonly upgradeConfigulatorTask?: UpgradeDependencies;\n\n  constructor(userOptions: MonorepoProjectOptions) {\n    /***************************************************************************\n     *\n     * BUILD WORKFLOW OPTIONS\n     *\n     * discover some turbo options for build workflow, if needed.\n     *\n     **************************************************************************/\n\n    const buildWorkflowOptions: Partial<BuildWorkflowOptions> = userOptions\n      .turboOptions?.remoteCacheOptions\n      ? TurboRepo.buildWorkflowOptions(\n          userOptions.turboOptions.remoteCacheOptions,\n        )\n      : {};\n\n    /***************************************************************************\n     *\n     * DEFAULT OPTIONS\n     *\n     * These are the default options unless you override with option inputs.\n     *\n     **************************************************************************/\n\n    const defaultOptions: Omit<\n      MonorepoProjectOptions,\n      \"name\" | \"defaultReleaseBranch\"\n    > = {\n      /**\n       * Use typescript based config file.\n       */\n      projenrcTs: true,\n\n      /**\n       * Projen version should be pinned to the local specified version.\n       */\n      projenVersion: \"catalog:\",\n\n      /**\n       * Use Prettier for code formatting.\n       */\n      prettier: true,\n\n      /**\n       * Not licensed by default.\n       */\n      licensed: false,\n\n      /**\n       * GitHub options for the monorepo.\n       * Don't enable mergify by default.\n       */\n      githubOptions: {\n        mergify: false,\n      },\n\n      /**\n       * Default PNPM version to use in the monorepo.\n       */\n      pnpmVersion: VERSION.PNPM_VERSION,\n\n      /**\n       * We don't want sample code generated for the root project.\n       */\n      sampleCode: false,\n\n      /**\n       * Jest is not required in the root project.\n       */\n      jest: false,\n\n      /**\n       * Don't release the root project.\n       */\n      release: false,\n\n      /**\n       * Don't upgrade dependencies automatically.\n       */\n      depsUpgrade: false,\n\n      /**\n       * Disable tsconfig.dev.json in the root since we aren't going to be\n       * developing any code here. It's just a task runner and configuration\n       * tool for sub-projects.\n       */\n      disableTsconfigDev: true,\n\n      /**\n       * Kill the srcdir in the root since we aren't using one.\n       */\n      tsconfig: {\n        compilerOptions: {\n          rootDir: undefined,\n        },\n        exclude: [\"node_modules\"],\n      },\n\n      /**\n       * Enable turborepo by default.\n       */\n      turbo: true,\n\n      /**\n       * Enable reset task by default.\n       */\n      resetTask: true,\n\n      /**\n       * Include self as a devDep\n       */\n      devDeps: [\"@codedrifters/configulator\"],\n\n      pnpmOptions: {\n        pnpmWorkspaceOptions: {\n          defaultCatalog: {\n            [\"aws-cdk\"]: VERSION.AWS_CDK_CLI_VERSION,\n            [\"aws-cdk-lib\"]: VERSION.AWS_CDK_LIB_VERSION,\n            [\"projen\"]: VERSION.PROJEN_VERSION,\n            [\"constructs\"]: VERSION.AWS_CONSTRUCTS_VERSION,\n            [\"turbo\"]: VERSION.TURBO_VERSION,\n          },\n        },\n      },\n    };\n\n    /***************************************************************************\n     *\n     * REQUIRED OPTIONS\n     *\n     * These options cannot be changed by the user.\n     *\n     **************************************************************************/\n\n    const requiredOptions: Omit<TypeScriptProjectOptions, \"name\"> = {\n      /**\n       * This is required because it's standard practice and also to simplify\n       * some workflow design.\n       */\n      defaultReleaseBranch: \"main\",\n\n      /**\n       * Use PNPM instead of the default (Yarn). Much of the ecosystem depends\n       * on PNPM and making monorepos PNPM only simplifies many configurations.\n       */\n      packageManager: NodePackageManager.PNPM,\n\n      /**\n       * Some additional pre-build steps if we're using turbo's remote cache.\n       */\n      buildWorkflowOptions: {\n        permissions: {\n          ...buildWorkflowOptions?.permissions,\n          ...userOptions.buildWorkflowOptions?.permissions,\n        },\n        preBuildSteps: [\n          ...(buildWorkflowOptions?.preBuildSteps ?? []),\n          ...(userOptions.buildWorkflowOptions?.preBuildSteps ?? []),\n        ],\n      },\n    };\n\n    /***************************************************************************\n     *\n     * CONSTRUCTOR\n     *\n     * Combines default options with user provided options and required options.\n     * Store the options in a const so we can use them after super(), farther\n     * into the constructor for additional configuration.\n     *\n     **************************************************************************/\n\n    const options: AppliedOptions = merge(\n      defaultOptions,\n      userOptions,\n      requiredOptions,\n    );\n\n    super({ ...options });\n\n    /***************************************************************************\n     *\n     * PUBLIC PROPS\n     *\n     * Some props are hidden by Projen and we need to expose them for the\n     * monorepo to work properly. This is where we store them.\n     *\n     **************************************************************************/\n\n    this.pnpmVersion = options.pnpmVersion!;\n\n    /***************************************************************************\n     *\n     * CUSTOM CONFIGS\n     *\n     * We add some additional configurations to the monorepo root project below\n     * such as Turborepo, VS Code config, and the PNPM workspace file.\n     *\n     **************************************************************************/\n\n    /**\n     * Add VSCode configuration\n     */\n    new VSCodeConfig(this);\n\n    /**\n     * Add workspace definition to PNPM root\n     */\n    new PnpmWorkspace(this, options.pnpmOptions?.pnpmWorkspaceOptions);\n\n    /**\n     * Turn on turborepo support if requested.\n     */\n    if (options.turbo) {\n      new TurboRepo(this, options.turboOptions);\n\n      this.buildWorkflow?.addPostBuildSteps({\n        name: \"Build Sub Projects\",\n        run: `npx projen ${ROOT_CI_TASK_NAME}`,\n      });\n    }\n\n    /**\n     * Add reset task if enabled.\n     */\n    if (options.resetTask !== false) {\n      const defaultResetTaskOptions: ResetTaskOptions = {\n        pathsToRemove: [\"node_modules\", \".turbo\", \"dist\", \"lib\"],\n      };\n      const userResetTaskOptions = options.resetTaskOptions ?? {};\n      const resetTaskOptions: ResetTaskOptions = merge(\n        defaultResetTaskOptions,\n        {\n          ...userResetTaskOptions,\n          pathsToRemove: [\n            ...(defaultResetTaskOptions.pathsToRemove ?? []),\n            ...(userResetTaskOptions.pathsToRemove ?? []),\n          ],\n        },\n      );\n      new ResetTask(this, resetTaskOptions);\n    }\n\n    /**\n     * Specify package manager\n     */\n    // const pnpmVersion = options.pnpmVersion ?? VERSION.PNPM_VERSION;\n    this.package.file.addOverride(\n      \"packageManager\",\n      `pnpm@${options.pnpmVersion}`,\n    );\n\n    /**\n     * Add some silly things to the gitignore.\n     */\n    this.gitignore?.addPatterns(\".DS_Store\");\n\n    /**\n     * Use catalog version for constructs version\n     */\n    this.addDevDeps(\"constructs@catalog:\");\n\n    /**\n     * Add a task on the monorepo's root project that will attempt to upgrade\n     * the @codedrifters/configulator package version nightly. This keeps the\n     * project up-to-date with the latest official CodeDrifters configs..\n     */\n    if (options.upgradeConfigulatorTask !== false) {\n      this.upgradeConfigulatorTask = new UpgradeDependencies(\n        this,\n        merge(\n          {\n            include: [\"@codedrifters/configulator\"],\n            taskName: `upgrade-codedrifters-configulator`,\n            workflowOptions: {\n              schedule: UpgradeDependenciesSchedule.DAILY,\n            },\n          },\n          options.upgradeConfigulatorTaskOptions ?? {},\n        ),\n      );\n    }\n  }\n}\n"]}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"monorepo-project.js","sourceRoot":"","sources":["../../src/projects/monorepo-project.ts"],"names":[],"mappings":"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","sourcesContent":["import { BuildWorkflowOptions } from \"projen/lib/build\";\nimport {\n  NodePackageManager,\n  UpgradeDependencies,\n  UpgradeDependenciesOptions,\n  UpgradeDependenciesSchedule,\n} from \"projen/lib/javascript\";\nimport {\n  TypeScriptAppProject,\n  TypeScriptProjectOptions,\n} from \"projen/lib/typescript\";\nimport { merge } from \"ts-deepmerge\";\nimport { PnpmWorkspace, PnpmWorkspaceOptions } from \"../pnpm/pnpm-workspace\";\nimport { ResetTask, ResetTaskOptions } from \"../tasks/reset-task\";\nimport {\n  ROOT_CI_TASK_NAME,\n  TurboRepo,\n  TurboRepoOptions,\n} from \"../turbo/turbo-repo\";\nimport { VERSION } from \"../versions\";\nimport { VSCodeConfig } from \"../vscode/vscode\";\n\n/*******************************************************************************\n *\n * Monorepo Root Project\n *\n * This project should be used as the base project for other projects in a\n * monorepo. The Monorepo root project generally won't contain any code, but it\n * will contain configuration for the monorepo, such as package management,\n * linting, testing, and other project-wide settings.\n *\n ******************************************************************************/\n\n/**\n * Configuration options for the monorepo.\n */\nexport interface MonorepoProjectOptions extends Omit<\n  TypeScriptProjectOptions,\n  \"defaultReleaseBranch\"\n> {\n  /**\n   * Turn on Turborepo support.\n   *\n   * @default true\n   */\n  turbo?: boolean;\n\n  /**\n   * Optionsal options for turborepo config\n   */\n  turboOptions?: TurboRepoOptions;\n\n  /**\n   * Enable the reset task that deletes all build artifacts.\n   *\n   * @default true\n   */\n  resetTask?: boolean;\n\n  /**\n   * Options for the reset task.\n   */\n  resetTaskOptions?: ResetTaskOptions;\n\n  /**\n   * PNPM options for the monorepo.\n   */\n  pnpmOptions?: {\n    /**\n     * The version of PNPM to use in the monorepo.\n     * @default VERSION.PNPM_VERSION\n     * @see {@link src/versions.ts}\n     */\n    version?: string;\n\n    /**\n     * Optional pnpm options for the monorepo workspace file.\n     */\n    pnpmWorkspaceOptions?: PnpmWorkspaceOptions;\n  };\n\n  /**\n   * Turn on the upgrade configurator task that will attempt to upgrade the\n   * @codedrifters/configulator package version nightly. This keeps the\n   * project up-to-date with the latest official CodeDrifters configs..\n   *\n   * @default true\n   */\n  readonly upgradeConfigulatorTask?: boolean;\n\n  /**\n   * Options for the upgrade configurator task.\n   *\n   * @default: daily schedule\n   */\n  readonly upgradeConfigulatorTaskOptions?: UpgradeDependenciesOptions;\n}\n\ninterface AppliedOptions\n  extends TypeScriptProjectOptions, MonorepoProjectOptions {}\n\nexport class MonorepoProject extends TypeScriptAppProject {\n  /**\n   * Version of PNPM which the whole monorepo should use.\n   */\n  readonly pnpmVersion: string;\n\n  /**\n   * Optional task that will attempt to upgrade the @codedrifters/configulator\n   * package version nightly. This keeps the project up-to-date with the latest\n   * official CodeDrifters configs.\n   */\n  readonly upgradeConfigulatorTask?: UpgradeDependencies;\n\n  constructor(userOptions: MonorepoProjectOptions) {\n    /***************************************************************************\n     *\n     * BUILD WORKFLOW OPTIONS\n     *\n     * discover some turbo options for build workflow, if needed.\n     *\n     **************************************************************************/\n\n    const buildWorkflowOptions: Partial<BuildWorkflowOptions> = userOptions\n      .turboOptions?.remoteCacheOptions\n      ? TurboRepo.buildWorkflowOptions(\n          userOptions.turboOptions.remoteCacheOptions,\n        )\n      : {};\n\n    /***************************************************************************\n     *\n     * DEFAULT OPTIONS\n     *\n     * These are the default options unless you override with option inputs.\n     *\n     **************************************************************************/\n\n    const defaultOptions: Omit<\n      MonorepoProjectOptions,\n      \"name\" | \"defaultReleaseBranch\"\n    > = {\n      /**\n       * Use typescript based config file.\n       */\n      projenrcTs: true,\n\n      /**\n       * Projen version should be pinned to the local specified version.\n       */\n      projenVersion: \"catalog:\",\n\n      /**\n       * Use Prettier for code formatting.\n       */\n      prettier: true,\n\n      /**\n       * Not licensed by default.\n       */\n      licensed: false,\n\n      /**\n       * GitHub options for the monorepo.\n       * Don't enable mergify by default.\n       */\n      githubOptions: {\n        mergify: false,\n\n        /**\n         * Configure pull request linting to validate PR titles follow Conventional Commits.\n         * By default, all conventional commit types are allowed, providing flexibility\n         * for different types of changes (features, fixes, documentation, refactoring, etc.).\n         */\n        pullRequestLintOptions: {\n          semanticTitleOptions: {\n            /**\n             * Allowed conventional commit types for PR titles.\n             * This includes all standard types from the Conventional Commits specification:\n             * - feat: New features\n             * - fix: Bug fixes\n             * - docs: Documentation changes\n             * - style: Code style changes (formatting, etc.)\n             * - refactor: Code refactoring\n             * - perf: Performance improvements\n             * - test: Test additions or changes\n             * - build: Build system changes\n             * - ci: CI configuration changes\n             * - chore: Maintenance tasks\n             * - revert: Revert commits\n             */\n            types: [\n              \"feat\",\n              \"fix\",\n              \"docs\",\n              \"style\",\n              \"refactor\",\n              \"perf\",\n              \"test\",\n              \"build\",\n              \"ci\",\n              \"chore\",\n              \"revert\",\n            ],\n          },\n        },\n      },\n\n      /**\n       * Default PNPM version to use in the monorepo.\n       */\n      pnpmVersion: VERSION.PNPM_VERSION,\n\n      /**\n       * We don't want sample code generated for the root project.\n       */\n      sampleCode: false,\n\n      /**\n       * Jest is not required in the root project.\n       */\n      jest: false,\n\n      /**\n       * Don't release the root project.\n       */\n      release: false,\n\n      /**\n       * Don't upgrade dependencies automatically.\n       */\n      depsUpgrade: false,\n\n      /**\n       * Disable tsconfig.dev.json in the root since we aren't going to be\n       * developing any code here. It's just a task runner and configuration\n       * tool for sub-projects.\n       */\n      disableTsconfigDev: true,\n\n      /**\n       * Kill the srcdir in the root since we aren't using one.\n       */\n      tsconfig: {\n        compilerOptions: {\n          rootDir: undefined,\n        },\n        exclude: [\"node_modules\"],\n      },\n\n      /**\n       * Enable turborepo by default.\n       */\n      turbo: true,\n\n      /**\n       * Enable reset task by default.\n       */\n      resetTask: true,\n\n      /**\n       * Include self as a devDep\n       */\n      devDeps: [\"@codedrifters/configulator\"],\n\n      pnpmOptions: {\n        pnpmWorkspaceOptions: {\n          defaultCatalog: {\n            [\"aws-cdk\"]: VERSION.AWS_CDK_CLI_VERSION,\n            [\"aws-cdk-lib\"]: VERSION.AWS_CDK_LIB_VERSION,\n            [\"projen\"]: VERSION.PROJEN_VERSION,\n            [\"constructs\"]: VERSION.AWS_CONSTRUCTS_VERSION,\n            [\"turbo\"]: VERSION.TURBO_VERSION,\n          },\n        },\n      },\n    };\n\n    /***************************************************************************\n     *\n     * REQUIRED OPTIONS\n     *\n     * These options cannot be changed by the user.\n     *\n     **************************************************************************/\n\n    const requiredOptions: Omit<TypeScriptProjectOptions, \"name\"> = {\n      /**\n       * This is required because it's standard practice and also to simplify\n       * some workflow design.\n       */\n      defaultReleaseBranch: \"main\",\n\n      /**\n       * Use PNPM instead of the default (Yarn). Much of the ecosystem depends\n       * on PNPM and making monorepos PNPM only simplifies many configurations.\n       */\n      packageManager: NodePackageManager.PNPM,\n\n      /**\n       * Some additional pre-build steps if we're using turbo's remote cache.\n       */\n      buildWorkflowOptions: {\n        permissions: {\n          ...buildWorkflowOptions?.permissions,\n          ...userOptions.buildWorkflowOptions?.permissions,\n        },\n        preBuildSteps: [\n          ...(buildWorkflowOptions?.preBuildSteps ?? []),\n          ...(userOptions.buildWorkflowOptions?.preBuildSteps ?? []),\n        ],\n      },\n    };\n\n    /***************************************************************************\n     *\n     * CONSTRUCTOR\n     *\n     * Combines default options with user provided options and required options.\n     * Store the options in a const so we can use them after super(), farther\n     * into the constructor for additional configuration.\n     *\n     **************************************************************************/\n\n    const options: AppliedOptions = merge(\n      defaultOptions,\n      userOptions,\n      requiredOptions,\n    );\n\n    super({ ...options });\n\n    /***************************************************************************\n     *\n     * PUBLIC PROPS\n     *\n     * Some props are hidden by Projen and we need to expose them for the\n     * monorepo to work properly. This is where we store them.\n     *\n     **************************************************************************/\n\n    this.pnpmVersion = options.pnpmVersion!;\n\n    /***************************************************************************\n     *\n     * CUSTOM CONFIGS\n     *\n     * We add some additional configurations to the monorepo root project below\n     * such as Turborepo, VS Code config, and the PNPM workspace file.\n     *\n     **************************************************************************/\n\n    /**\n     * Add VSCode configuration\n     */\n    new VSCodeConfig(this);\n\n    /**\n     * Add workspace definition to PNPM root\n     */\n    new PnpmWorkspace(this, options.pnpmOptions?.pnpmWorkspaceOptions);\n\n    /**\n     * Turn on turborepo support if requested.\n     */\n    if (options.turbo) {\n      new TurboRepo(this, options.turboOptions);\n\n      this.buildWorkflow?.addPostBuildSteps({\n        name: \"Build Sub Projects\",\n        run: `npx projen ${ROOT_CI_TASK_NAME}`,\n      });\n    }\n\n    /**\n     * Add reset task if enabled.\n     */\n    if (options.resetTask !== false) {\n      const defaultResetTaskOptions: ResetTaskOptions = {\n        pathsToRemove: [\"node_modules\", \".turbo\", \"dist\", \"lib\"],\n      };\n      const userResetTaskOptions = options.resetTaskOptions ?? {};\n      const resetTaskOptions: ResetTaskOptions = merge(\n        defaultResetTaskOptions,\n        {\n          ...userResetTaskOptions,\n          pathsToRemove: [\n            ...(defaultResetTaskOptions.pathsToRemove ?? []),\n            ...(userResetTaskOptions.pathsToRemove ?? []),\n          ],\n        },\n      );\n      new ResetTask(this, resetTaskOptions);\n    }\n\n    /**\n     * Specify package manager\n     */\n    // const pnpmVersion = options.pnpmVersion ?? VERSION.PNPM_VERSION;\n    this.package.file.addOverride(\n      \"packageManager\",\n      `pnpm@${options.pnpmVersion}`,\n    );\n\n    /**\n     * Add some silly things to the gitignore.\n     */\n    this.gitignore?.addPatterns(\".DS_Store\");\n\n    /**\n     * Use catalog version for constructs version\n     */\n    this.addDevDeps(\"constructs@catalog:\");\n\n    /**\n     * Add a task on the monorepo's root project that will attempt to upgrade\n     * the @codedrifters/configulator package version nightly. This keeps the\n     * project up-to-date with the latest official CodeDrifters configs..\n     */\n    if (options.upgradeConfigulatorTask !== false) {\n      this.upgradeConfigulatorTask = new UpgradeDependencies(\n        this,\n        merge(\n          {\n            include: [\"@codedrifters/configulator\"],\n            taskName: `upgrade-codedrifters-configulator`,\n            workflowOptions: {\n              schedule: UpgradeDependenciesSchedule.DAILY,\n            },\n          },\n          options.upgradeConfigulatorTaskOptions ?? {},\n        ),\n      );\n    }\n  }\n}\n"]}
|
package/package.json
CHANGED