@nikovirtala/projen-constructs 0.1.8 → 0.2.0
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/.jsii +622 -97
- package/API.md +769 -52
- package/README.md +37 -8
- package/lib/components/typedoc-config.d.ts +321 -0
- package/lib/components/typedoc-config.js +73 -1
- package/lib/components/typedoc.d.ts +19 -0
- package/lib/components/typedoc.js +10 -1
- package/lib/components/vitest.d.ts +197 -0
- package/lib/components/vitest.js +72 -2
- package/lib/config.d.ts +4 -4
- package/lib/errors.d.ts +16 -0
- package/lib/errors.js +26 -2
- package/lib/index.d.ts +1 -0
- package/lib/index.js +2 -1
- package/lib/project-generator.d.ts +87 -63
- package/lib/project-generator.js +344 -60
- package/lib/project-type.d.ts +78 -16
- package/lib/project-type.js +79 -17
- package/lib/projects/awscdk-construct-library.generated.js +4 -4
- package/lib/projects/awscdk-typescript-app.generated.js +4 -4
- package/lib/projects/jsii.generated.js +4 -4
- package/lib/projects/typescript.generated.js +4 -4
- package/lib/utils.d.ts +2 -2
- package/lib/utils.js +3 -3
- package/package.json +1 -1
- package/scripts/generate-project-types.ts +103 -0
package/README.md
CHANGED
|
@@ -8,21 +8,26 @@ Projen project types with standard configuration for consistent project setup ac
|
|
|
8
8
|
pnpm add -D @nikovirtala/projen-constructs projen constructs
|
|
9
9
|
```
|
|
10
10
|
|
|
11
|
-
##
|
|
11
|
+
## Features
|
|
12
|
+
|
|
13
|
+
- **Standard Configuration**: Opinionated defaults for author, release branch, package manager, Node.js, TypeScript, and tooling
|
|
14
|
+
- **Automatic Project Type Discovery**: Generates `ProjectType` enum from Projen's JSII manifest (18 project types)
|
|
15
|
+
- **Component System**: Reusable components (Vitest, Mise, TypeDoc, LocalStack, etc.)
|
|
16
|
+
- **Code Generation**: `ProjectGenerator` creates project classes with standard configuration
|
|
17
|
+
- **ES Modules**: TypeScript and CDK App projects use ES modules (JSII uses CommonJS)
|
|
18
|
+
- **Code Quality**: Biome for formatting and linting
|
|
19
|
+
- **Testing**: Vitest with coverage
|
|
20
|
+
- **Auto-merge**: Enabled with auto-approve
|
|
21
|
+
- **VSCode**: Recommended extensions and settings
|
|
22
|
+
- **mise**: Node version management
|
|
12
23
|
|
|
13
|
-
|
|
24
|
+
## Standard Configuration
|
|
14
25
|
|
|
15
26
|
- **Author**: Niko Virtala (niko.virtala@hey.com)
|
|
16
27
|
- **Default Release Branch**: main
|
|
17
28
|
- **Package Manager**: pnpm 10
|
|
18
29
|
- **Node Version**: 22.21.1
|
|
19
30
|
- **TypeScript**: 5.9.3
|
|
20
|
-
- **Module Type**: ES modules (TypeScript and CDK App projects only; JSII projects use CommonJS)
|
|
21
|
-
- **Code Quality**: Biome for formatting and linting
|
|
22
|
-
- **Testing**: Vitest
|
|
23
|
-
- **Auto-merge**: Enabled with auto-approve
|
|
24
|
-
- **VSCode**: Recommended extensions and settings
|
|
25
|
-
- **mise**: Node version management (via Homebrew)
|
|
26
31
|
- **CDK Version**: 2.223.0 (for CDK projects)
|
|
27
32
|
- **JSII Version**: ~5.9.3 (for JSII projects)
|
|
28
33
|
|
|
@@ -235,3 +240,27 @@ new LambdaFunctionCodeBundle(project, {
|
|
|
235
240
|
extension: ".lambda.ts",
|
|
236
241
|
});
|
|
237
242
|
```
|
|
243
|
+
|
|
244
|
+
#### ProjectGenerator
|
|
245
|
+
|
|
246
|
+
Generates TypeScript project classes with standard configuration.
|
|
247
|
+
|
|
248
|
+
```typescript
|
|
249
|
+
import { ProjectGenerator, ProjectType } from "@nikovirtala/projen-constructs";
|
|
250
|
+
|
|
251
|
+
new ProjectGenerator(project, {
|
|
252
|
+
name: "TypeScriptProject",
|
|
253
|
+
projectType: ProjectType.TYPESCRIPT,
|
|
254
|
+
filePath: "./src/projects/typescript.generated.ts",
|
|
255
|
+
components: [
|
|
256
|
+
{ componentClass: Mise },
|
|
257
|
+
{ componentClass: Vitest }, // Auto-detects VitestOptions from JSII manifest
|
|
258
|
+
],
|
|
259
|
+
});
|
|
260
|
+
```
|
|
261
|
+
|
|
262
|
+
Features:
|
|
263
|
+
- Automatically generates the `ProjectType` enum from Projen's JSII manifest
|
|
264
|
+
- Auto-detects component options types from JSII manifests
|
|
265
|
+
- Validates paths to prevent directory traversal attacks
|
|
266
|
+
- Structured error handling with custom error classes
|
|
@@ -1,78 +1,399 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* TypeDoc configuration
|
|
3
|
+
*
|
|
4
|
+
* @see https://typedoc.org/options/
|
|
5
|
+
*/
|
|
1
6
|
export interface TypeDocConfiguration {
|
|
7
|
+
/**
|
|
8
|
+
* Specifies the entry points to be documented by TypeDoc.
|
|
9
|
+
*
|
|
10
|
+
* @see https://typedoc.org/documents/Options.Input.html#entrypoints
|
|
11
|
+
*/
|
|
2
12
|
readonly entryPoints?: string[];
|
|
13
|
+
/**
|
|
14
|
+
* Specifies the strategy to be used to convert entry points into documentation.
|
|
15
|
+
*
|
|
16
|
+
* @see https://typedoc.org/documents/Options.Input.html#entrypointstrategy
|
|
17
|
+
*/
|
|
3
18
|
readonly entryPointStrategy?: EntryPointStrategy;
|
|
19
|
+
/**
|
|
20
|
+
* Define patterns to be excluded when expanding directories.
|
|
21
|
+
*
|
|
22
|
+
* @see https://typedoc.org/documents/Options.Input.html#exclude
|
|
23
|
+
*/
|
|
4
24
|
readonly exclude?: string[];
|
|
25
|
+
/**
|
|
26
|
+
* Prevent externally resolved symbols from being documented.
|
|
27
|
+
*
|
|
28
|
+
* @see https://typedoc.org/documents/Options.Input.html#excludeexternals
|
|
29
|
+
*/
|
|
5
30
|
readonly excludeExternals?: boolean;
|
|
31
|
+
/**
|
|
32
|
+
* Prevent private members from being included in the generated documentation.
|
|
33
|
+
*
|
|
34
|
+
* @see https://typedoc.org/documents/Options.Input.html#excludeprivate
|
|
35
|
+
*/
|
|
6
36
|
readonly excludePrivate?: boolean;
|
|
37
|
+
/**
|
|
38
|
+
* Prevent protected members from being included in the generated documentation.
|
|
39
|
+
*
|
|
40
|
+
* @see https://typedoc.org/documents/Options.Input.html#excludeprotected
|
|
41
|
+
*/
|
|
7
42
|
readonly excludeProtected?: boolean;
|
|
43
|
+
/**
|
|
44
|
+
* Prevent symbols that are not exported from being documented.
|
|
45
|
+
*
|
|
46
|
+
* @see https://typedoc.org/documents/Options.Input.html#excludeinternal
|
|
47
|
+
*/
|
|
8
48
|
readonly excludeInternal?: boolean;
|
|
49
|
+
/**
|
|
50
|
+
* Specifies the output directory the documentation should be written to.
|
|
51
|
+
*
|
|
52
|
+
* @see https://typedoc.org/documents/Options.Output.html#out
|
|
53
|
+
*/
|
|
9
54
|
readonly out?: string;
|
|
55
|
+
/**
|
|
56
|
+
* Specify the location the documentation should be written to.
|
|
57
|
+
*
|
|
58
|
+
* @see https://typedoc.org/documents/Options.Output.html#json
|
|
59
|
+
*/
|
|
10
60
|
readonly json?: string;
|
|
61
|
+
/**
|
|
62
|
+
* Specify a theme name to use.
|
|
63
|
+
*
|
|
64
|
+
* @see https://typedoc.org/documents/Options.Output.html#theme
|
|
65
|
+
*/
|
|
11
66
|
readonly theme?: string;
|
|
67
|
+
/**
|
|
68
|
+
* Specify the base path for all urls.
|
|
69
|
+
*
|
|
70
|
+
* @see https://typedoc.org/documents/Options.Output.html#basepath
|
|
71
|
+
*/
|
|
12
72
|
readonly basePath?: string;
|
|
73
|
+
/**
|
|
74
|
+
* Set the name of the project that will be used in the header of the template.
|
|
75
|
+
*
|
|
76
|
+
* @see https://typedoc.org/documents/Options.Output.html#name
|
|
77
|
+
*/
|
|
13
78
|
readonly name?: string;
|
|
79
|
+
/**
|
|
80
|
+
* Prevent TypeDoc from cleaning the output directory specified with --out.
|
|
81
|
+
*
|
|
82
|
+
* @see https://typedoc.org/documents/Options.Output.html#cleanoutputdir
|
|
83
|
+
*/
|
|
14
84
|
readonly cleanOutputDir?: boolean;
|
|
85
|
+
/**
|
|
86
|
+
* Specify the location to look for included documents.
|
|
87
|
+
*
|
|
88
|
+
* @see https://typedoc.org/documents/Options.Output.html#includes
|
|
89
|
+
*/
|
|
15
90
|
readonly includes?: string;
|
|
91
|
+
/**
|
|
92
|
+
* Specify the location with media files that should be copied to the output directory.
|
|
93
|
+
*
|
|
94
|
+
* @see https://typedoc.org/documents/Options.Output.html#media
|
|
95
|
+
*/
|
|
16
96
|
readonly media?: string;
|
|
97
|
+
/**
|
|
98
|
+
* Specify the location and filename a .tsbuildinfo file should be written to.
|
|
99
|
+
*
|
|
100
|
+
* @see https://typedoc.org/documents/Options.Input.html#tsbuildinfo
|
|
101
|
+
*/
|
|
17
102
|
readonly tsBuildInfo?: string;
|
|
103
|
+
/**
|
|
104
|
+
* Specify a TypeScript config file that should be used to load TypeScript configuration.
|
|
105
|
+
*
|
|
106
|
+
* @see https://typedoc.org/documents/Options.Input.html#tsconfig
|
|
107
|
+
*/
|
|
18
108
|
readonly tsconfig?: string;
|
|
109
|
+
/**
|
|
110
|
+
* Specify the logger that should be used.
|
|
111
|
+
*
|
|
112
|
+
* @see https://typedoc.org/documents/Options.Other.html#loglevel
|
|
113
|
+
*/
|
|
19
114
|
readonly logLevel?: LogLevel;
|
|
115
|
+
/**
|
|
116
|
+
* Specify the sort strategy for documented values.
|
|
117
|
+
*
|
|
118
|
+
* @see https://typedoc.org/documents/Options.Organization.html#sort
|
|
119
|
+
*/
|
|
20
120
|
readonly sort?: string[];
|
|
121
|
+
/**
|
|
122
|
+
* Specify the sort strategy for static and instance members.
|
|
123
|
+
*
|
|
124
|
+
* @see https://typedoc.org/documents/Options.Organization.html#sortentrypoints
|
|
125
|
+
*/
|
|
21
126
|
readonly sortEntryPoints?: boolean;
|
|
127
|
+
/**
|
|
128
|
+
* Specify the documentation mode TypeDoc should use.
|
|
129
|
+
*
|
|
130
|
+
* @see https://typedoc.org/documents/Options.Comments.html#commentstyle
|
|
131
|
+
*/
|
|
22
132
|
readonly commentStyle?: CommentStyle;
|
|
133
|
+
/**
|
|
134
|
+
* Specify the default visibility for members without a visibility tag.
|
|
135
|
+
*
|
|
136
|
+
* @see https://typedoc.org/documents/Options.Comments.html#defaultvisibility
|
|
137
|
+
*/
|
|
23
138
|
readonly defaultVisibility?: Visibility;
|
|
139
|
+
/**
|
|
140
|
+
* Specify the default category for reflections without a category.
|
|
141
|
+
*
|
|
142
|
+
* @see https://typedoc.org/documents/Options.Organization.html#defaultcategory
|
|
143
|
+
*/
|
|
24
144
|
readonly defaultCategory?: string;
|
|
145
|
+
/**
|
|
146
|
+
* Specify the default group for reflections without a group.
|
|
147
|
+
*
|
|
148
|
+
* @see https://typedoc.org/documents/Options.Organization.html#defaultgroup
|
|
149
|
+
*/
|
|
25
150
|
readonly defaultGroup?: string;
|
|
151
|
+
/**
|
|
152
|
+
* Specify the categories that will be used to group reflections.
|
|
153
|
+
*
|
|
154
|
+
* @see https://typedoc.org/documents/Options.Organization.html#categorizebygroup
|
|
155
|
+
*/
|
|
26
156
|
readonly categorizeByGroup?: boolean;
|
|
157
|
+
/**
|
|
158
|
+
* Specify the search group boosts.
|
|
159
|
+
*
|
|
160
|
+
* @see https://typedoc.org/documents/Options.Organization.html#searchgroupboosts
|
|
161
|
+
*/
|
|
27
162
|
readonly searchGroupBoosts?: Record<string, number>;
|
|
163
|
+
/**
|
|
164
|
+
* Specify the search category boosts.
|
|
165
|
+
*
|
|
166
|
+
* @see https://typedoc.org/documents/Options.Organization.html#searchcategoryboosts
|
|
167
|
+
*/
|
|
28
168
|
readonly searchCategoryBoosts?: Record<string, number>;
|
|
169
|
+
/**
|
|
170
|
+
* Specify the readme file that should be displayed on the index page.
|
|
171
|
+
*
|
|
172
|
+
* @see https://typedoc.org/documents/Options.Input.html#readme
|
|
173
|
+
*/
|
|
29
174
|
readonly readme?: string;
|
|
175
|
+
/**
|
|
176
|
+
* Specify the package.json file that should be used to determine the package name.
|
|
177
|
+
*
|
|
178
|
+
* @see https://typedoc.org/documents/Options.Input.html#packagejson
|
|
179
|
+
*/
|
|
30
180
|
readonly packageJson?: string;
|
|
181
|
+
/**
|
|
182
|
+
* Specify the git revision that should be used to link to source files.
|
|
183
|
+
*
|
|
184
|
+
* @see https://typedoc.org/documents/Options.Comments.html#gitrevision
|
|
185
|
+
*/
|
|
31
186
|
readonly gitRevision?: string;
|
|
187
|
+
/**
|
|
188
|
+
* Specify the git remote that should be used to link to source files.
|
|
189
|
+
*
|
|
190
|
+
* @see https://typedoc.org/documents/Options.Comments.html#gitremote
|
|
191
|
+
*/
|
|
32
192
|
readonly gitRemote?: string;
|
|
193
|
+
/**
|
|
194
|
+
* Specify a link template to be used when generating source urls.
|
|
195
|
+
*
|
|
196
|
+
* @see https://typedoc.org/documents/Options.Input.html#sourcelinktemplate
|
|
197
|
+
*/
|
|
33
198
|
readonly sourceLinkTemplate?: string;
|
|
199
|
+
/**
|
|
200
|
+
* Disables automatically linking to source code.
|
|
201
|
+
*
|
|
202
|
+
* @see https://typedoc.org/documents/Options.Comments.html#disablesources
|
|
203
|
+
*/
|
|
34
204
|
readonly disableSources?: boolean;
|
|
205
|
+
/**
|
|
206
|
+
* Disables setting the source of reflections when documenting projects within a Git repository.
|
|
207
|
+
*
|
|
208
|
+
* @see https://typedoc.org/documents/Options.Comments.html#disablegit
|
|
209
|
+
*/
|
|
35
210
|
readonly disableGit?: boolean;
|
|
211
|
+
/**
|
|
212
|
+
* Do not print the TypeDoc link at the end of the page.
|
|
213
|
+
*
|
|
214
|
+
* @see https://typedoc.org/documents/Options.Output.html#hidegenerator
|
|
215
|
+
*/
|
|
36
216
|
readonly hideGenerator?: boolean;
|
|
217
|
+
/**
|
|
218
|
+
* Hide parameter types in the signature.
|
|
219
|
+
*
|
|
220
|
+
* @see https://typedoc.org/documents/Options.Output.html#hideparametertypesintitle
|
|
221
|
+
*/
|
|
37
222
|
readonly hideParameterTypesInTitle?: boolean;
|
|
223
|
+
/**
|
|
224
|
+
* Include the generation time in links to prevent browsers from using a cached version.
|
|
225
|
+
*
|
|
226
|
+
* @see https://typedoc.org/documents/Options.Output.html#cachebust
|
|
227
|
+
*/
|
|
38
228
|
readonly cacheBust?: boolean;
|
|
229
|
+
/**
|
|
230
|
+
* If set, the search index will also include comments.
|
|
231
|
+
*
|
|
232
|
+
* @see https://typedoc.org/documents/Options.Output.html#searchincomments
|
|
233
|
+
*/
|
|
39
234
|
readonly searchInComments?: boolean;
|
|
235
|
+
/**
|
|
236
|
+
* If set, the search index will also include documents.
|
|
237
|
+
*
|
|
238
|
+
* @see https://typedoc.org/documents/Options.Output.html#searchindocuments
|
|
239
|
+
*/
|
|
40
240
|
readonly searchInDocuments?: boolean;
|
|
241
|
+
/**
|
|
242
|
+
* Specify validation options.
|
|
243
|
+
*
|
|
244
|
+
* @see https://typedoc.org/documents/Options.Validation.html
|
|
245
|
+
*/
|
|
41
246
|
readonly validation?: ValidationOptions;
|
|
247
|
+
/**
|
|
248
|
+
* Specify the type of reflections that must be documented.
|
|
249
|
+
*
|
|
250
|
+
* @see https://typedoc.org/documents/Options.Validation.html#requiredtobedocumented
|
|
251
|
+
*/
|
|
42
252
|
readonly requiredToBeDocumented?: string[];
|
|
253
|
+
/**
|
|
254
|
+
* If set, warnings will be treated as errors.
|
|
255
|
+
*
|
|
256
|
+
* @see https://typedoc.org/documents/Options.Validation.html#treatwarningsaserrors
|
|
257
|
+
*/
|
|
43
258
|
readonly treatWarningsAsErrors?: boolean;
|
|
259
|
+
/**
|
|
260
|
+
* If set, validation warnings will be treated as errors.
|
|
261
|
+
*
|
|
262
|
+
* @see https://typedoc.org/documents/Options.Validation.html#treatvalidationwarningsaserrors
|
|
263
|
+
*/
|
|
44
264
|
readonly treatValidationWarningsAsErrors?: boolean;
|
|
265
|
+
/**
|
|
266
|
+
* A list of types that should not produce warnings when not being exported.
|
|
267
|
+
*
|
|
268
|
+
* @see https://typedoc.org/documents/Options.Validation.html#intentionallynotexported
|
|
269
|
+
*/
|
|
45
270
|
readonly intentionallyNotExported?: string[];
|
|
271
|
+
/**
|
|
272
|
+
* Define patterns for files that should be considered external.
|
|
273
|
+
*
|
|
274
|
+
* @see https://typedoc.org/documents/Options.Input.html#externalpattern
|
|
275
|
+
*/
|
|
46
276
|
readonly externalPattern?: string[];
|
|
277
|
+
/**
|
|
278
|
+
* Define custom mappings for symbols in external packages.
|
|
279
|
+
*
|
|
280
|
+
* @see https://typedoc.org/documents/Options.Comments.html#externalsymbollinkmappings
|
|
281
|
+
*/
|
|
47
282
|
readonly externalSymbolLinkMappings?: Record<string, Record<string, string>>;
|
|
48
283
|
}
|
|
284
|
+
/**
|
|
285
|
+
* Converts TypeDocConfiguration to JSON representation
|
|
286
|
+
* @internal
|
|
287
|
+
*/
|
|
49
288
|
export declare function toJson_TypeDocConfiguration(obj: TypeDocConfiguration | undefined): Record<string, unknown> | undefined;
|
|
289
|
+
/**
|
|
290
|
+
* Specifies the strategy to be used to convert entry points into documentation
|
|
291
|
+
*
|
|
292
|
+
* @see https://typedoc.org/documents/Options.Input.html#entrypointstrategy
|
|
293
|
+
*/
|
|
50
294
|
export declare enum EntryPointStrategy {
|
|
295
|
+
/**
|
|
296
|
+
* Expects all entry points to be contained within a single package
|
|
297
|
+
*/
|
|
51
298
|
RESOLVE = "resolve",
|
|
299
|
+
/**
|
|
300
|
+
* Expects all entry points to be top-level directories
|
|
301
|
+
*/
|
|
52
302
|
EXPAND = "expand",
|
|
303
|
+
/**
|
|
304
|
+
* Expects all entry points to be individual files
|
|
305
|
+
*/
|
|
53
306
|
PACKAGES = "packages",
|
|
307
|
+
/**
|
|
308
|
+
* Merges multiple projects into a single documentation site
|
|
309
|
+
*/
|
|
54
310
|
MERGE = "merge"
|
|
55
311
|
}
|
|
312
|
+
/**
|
|
313
|
+
* Specifies the logger that should be used
|
|
314
|
+
*
|
|
315
|
+
* @see https://typedoc.org/documents/Options.Other.html#loglevel
|
|
316
|
+
*/
|
|
56
317
|
export declare enum LogLevel {
|
|
318
|
+
/**
|
|
319
|
+
* Log all messages including verbose debug information
|
|
320
|
+
*/
|
|
57
321
|
VERBOSE = "Verbose",
|
|
322
|
+
/**
|
|
323
|
+
* Log informational messages and above
|
|
324
|
+
*/
|
|
58
325
|
INFO = "Info",
|
|
326
|
+
/**
|
|
327
|
+
* Log warnings and errors only
|
|
328
|
+
*/
|
|
59
329
|
WARN = "Warn",
|
|
330
|
+
/**
|
|
331
|
+
* Log errors only
|
|
332
|
+
*/
|
|
60
333
|
ERROR = "Error",
|
|
334
|
+
/**
|
|
335
|
+
* Disable all logging
|
|
336
|
+
*/
|
|
61
337
|
NONE = "None"
|
|
62
338
|
}
|
|
339
|
+
/**
|
|
340
|
+
* Specifies the documentation mode TypeDoc should use
|
|
341
|
+
*
|
|
342
|
+
* @see https://typedoc.org/documents/Options.Comments.html#commentstyle
|
|
343
|
+
*/
|
|
63
344
|
export declare enum CommentStyle {
|
|
345
|
+
/**
|
|
346
|
+
* Parse JSDoc style comments only
|
|
347
|
+
*/
|
|
64
348
|
JSDOC = "jsdoc",
|
|
349
|
+
/**
|
|
350
|
+
* Parse block comments
|
|
351
|
+
*/
|
|
65
352
|
BLOCK = "block",
|
|
353
|
+
/**
|
|
354
|
+
* Parse line comments (//)
|
|
355
|
+
*/
|
|
66
356
|
LINE = "line",
|
|
357
|
+
/**
|
|
358
|
+
* Parse all comment styles
|
|
359
|
+
*/
|
|
67
360
|
ALL = "all"
|
|
68
361
|
}
|
|
362
|
+
/**
|
|
363
|
+
* Specifies the default visibility for members without a visibility tag
|
|
364
|
+
*
|
|
365
|
+
* @see https://typedoc.org/documents/Options.Comments.html#defaultvisibility
|
|
366
|
+
*/
|
|
69
367
|
export declare enum Visibility {
|
|
368
|
+
/**
|
|
369
|
+
* Public visibility - accessible from anywhere
|
|
370
|
+
*/
|
|
70
371
|
PUBLIC = "public",
|
|
372
|
+
/**
|
|
373
|
+
* Protected visibility - accessible from class and subclasses
|
|
374
|
+
*/
|
|
71
375
|
PROTECTED = "protected",
|
|
376
|
+
/**
|
|
377
|
+
* Private visibility - accessible only within the class
|
|
378
|
+
*/
|
|
72
379
|
PRIVATE = "private"
|
|
73
380
|
}
|
|
381
|
+
/**
|
|
382
|
+
* Validation options
|
|
383
|
+
*
|
|
384
|
+
* @see https://typedoc.org/documents/Options.Validation.html
|
|
385
|
+
*/
|
|
74
386
|
export interface ValidationOptions {
|
|
387
|
+
/**
|
|
388
|
+
* If set, TypeDoc will produce warnings when a symbol is referenced by the documentation
|
|
389
|
+
*/
|
|
75
390
|
readonly notExported?: boolean;
|
|
391
|
+
/**
|
|
392
|
+
* If set, TypeDoc will produce warnings when an exported symbol is not documented
|
|
393
|
+
*/
|
|
76
394
|
readonly notDocumented?: boolean;
|
|
395
|
+
/**
|
|
396
|
+
* If set, TypeDoc will produce warnings about \@link tags which will produce broken links
|
|
397
|
+
*/
|
|
77
398
|
readonly invalidLink?: boolean;
|
|
78
399
|
}
|
|
@@ -2,6 +2,10 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.Visibility = exports.CommentStyle = exports.LogLevel = exports.EntryPointStrategy = void 0;
|
|
4
4
|
exports.toJson_TypeDocConfiguration = toJson_TypeDocConfiguration;
|
|
5
|
+
/**
|
|
6
|
+
* Converts TypeDocConfiguration to JSON representation
|
|
7
|
+
* @internal
|
|
8
|
+
*/
|
|
5
9
|
function toJson_TypeDocConfiguration(obj) {
|
|
6
10
|
if (obj === undefined) {
|
|
7
11
|
return undefined;
|
|
@@ -62,32 +66,100 @@ function toJson_TypeDocConfiguration(obj) {
|
|
|
62
66
|
}
|
|
63
67
|
return filtered;
|
|
64
68
|
}
|
|
69
|
+
/**
|
|
70
|
+
* Specifies the strategy to be used to convert entry points into documentation
|
|
71
|
+
*
|
|
72
|
+
* @see https://typedoc.org/documents/Options.Input.html#entrypointstrategy
|
|
73
|
+
*/
|
|
65
74
|
var EntryPointStrategy;
|
|
66
75
|
(function (EntryPointStrategy) {
|
|
76
|
+
/**
|
|
77
|
+
* Expects all entry points to be contained within a single package
|
|
78
|
+
*/
|
|
67
79
|
EntryPointStrategy["RESOLVE"] = "resolve";
|
|
80
|
+
/**
|
|
81
|
+
* Expects all entry points to be top-level directories
|
|
82
|
+
*/
|
|
68
83
|
EntryPointStrategy["EXPAND"] = "expand";
|
|
84
|
+
/**
|
|
85
|
+
* Expects all entry points to be individual files
|
|
86
|
+
*/
|
|
69
87
|
EntryPointStrategy["PACKAGES"] = "packages";
|
|
88
|
+
/**
|
|
89
|
+
* Merges multiple projects into a single documentation site
|
|
90
|
+
*/
|
|
70
91
|
EntryPointStrategy["MERGE"] = "merge";
|
|
71
92
|
})(EntryPointStrategy || (exports.EntryPointStrategy = EntryPointStrategy = {}));
|
|
93
|
+
/**
|
|
94
|
+
* Specifies the logger that should be used
|
|
95
|
+
*
|
|
96
|
+
* @see https://typedoc.org/documents/Options.Other.html#loglevel
|
|
97
|
+
*/
|
|
72
98
|
var LogLevel;
|
|
73
99
|
(function (LogLevel) {
|
|
100
|
+
/**
|
|
101
|
+
* Log all messages including verbose debug information
|
|
102
|
+
*/
|
|
74
103
|
LogLevel["VERBOSE"] = "Verbose";
|
|
104
|
+
/**
|
|
105
|
+
* Log informational messages and above
|
|
106
|
+
*/
|
|
75
107
|
LogLevel["INFO"] = "Info";
|
|
108
|
+
/**
|
|
109
|
+
* Log warnings and errors only
|
|
110
|
+
*/
|
|
76
111
|
LogLevel["WARN"] = "Warn";
|
|
112
|
+
/**
|
|
113
|
+
* Log errors only
|
|
114
|
+
*/
|
|
77
115
|
LogLevel["ERROR"] = "Error";
|
|
116
|
+
/**
|
|
117
|
+
* Disable all logging
|
|
118
|
+
*/
|
|
78
119
|
LogLevel["NONE"] = "None";
|
|
79
120
|
})(LogLevel || (exports.LogLevel = LogLevel = {}));
|
|
121
|
+
/**
|
|
122
|
+
* Specifies the documentation mode TypeDoc should use
|
|
123
|
+
*
|
|
124
|
+
* @see https://typedoc.org/documents/Options.Comments.html#commentstyle
|
|
125
|
+
*/
|
|
80
126
|
var CommentStyle;
|
|
81
127
|
(function (CommentStyle) {
|
|
128
|
+
/**
|
|
129
|
+
* Parse JSDoc style comments only
|
|
130
|
+
*/
|
|
82
131
|
CommentStyle["JSDOC"] = "jsdoc";
|
|
132
|
+
/**
|
|
133
|
+
* Parse block comments
|
|
134
|
+
*/
|
|
83
135
|
CommentStyle["BLOCK"] = "block";
|
|
136
|
+
/**
|
|
137
|
+
* Parse line comments (//)
|
|
138
|
+
*/
|
|
84
139
|
CommentStyle["LINE"] = "line";
|
|
140
|
+
/**
|
|
141
|
+
* Parse all comment styles
|
|
142
|
+
*/
|
|
85
143
|
CommentStyle["ALL"] = "all";
|
|
86
144
|
})(CommentStyle || (exports.CommentStyle = CommentStyle = {}));
|
|
145
|
+
/**
|
|
146
|
+
* Specifies the default visibility for members without a visibility tag
|
|
147
|
+
*
|
|
148
|
+
* @see https://typedoc.org/documents/Options.Comments.html#defaultvisibility
|
|
149
|
+
*/
|
|
87
150
|
var Visibility;
|
|
88
151
|
(function (Visibility) {
|
|
152
|
+
/**
|
|
153
|
+
* Public visibility - accessible from anywhere
|
|
154
|
+
*/
|
|
89
155
|
Visibility["PUBLIC"] = "public";
|
|
156
|
+
/**
|
|
157
|
+
* Protected visibility - accessible from class and subclasses
|
|
158
|
+
*/
|
|
90
159
|
Visibility["PROTECTED"] = "protected";
|
|
160
|
+
/**
|
|
161
|
+
* Private visibility - accessible only within the class
|
|
162
|
+
*/
|
|
91
163
|
Visibility["PRIVATE"] = "private";
|
|
92
164
|
})(Visibility || (exports.Visibility = Visibility = {}));
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typedoc-config.js","sourceRoot":"","sources":["../../src/components/typedoc-config.ts"],"names":[],"mappings":"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","sourcesContent":["export interface TypeDocConfiguration {\n    readonly entryPoints?: string[];\n    readonly entryPointStrategy?: EntryPointStrategy;\n    readonly exclude?: string[];\n    readonly excludeExternals?: boolean;\n    readonly excludePrivate?: boolean;\n    readonly excludeProtected?: boolean;\n    readonly excludeInternal?: boolean;\n    readonly out?: string;\n    readonly json?: string;\n    readonly theme?: string;\n    readonly basePath?: string;\n    readonly name?: string;\n    readonly cleanOutputDir?: boolean;\n    readonly includes?: string;\n    readonly media?: string;\n    readonly tsBuildInfo?: string;\n    readonly tsconfig?: string;\n    readonly logLevel?: LogLevel;\n    readonly sort?: string[];\n    readonly sortEntryPoints?: boolean;\n    readonly commentStyle?: CommentStyle;\n    readonly defaultVisibility?: Visibility;\n    readonly defaultCategory?: string;\n    readonly defaultGroup?: string;\n    readonly categorizeByGroup?: boolean;\n    readonly searchGroupBoosts?: Record<string, number>;\n    readonly searchCategoryBoosts?: Record<string, number>;\n    readonly readme?: string;\n    readonly packageJson?: string;\n    readonly gitRevision?: string;\n    readonly gitRemote?: string;\n    readonly sourceLinkTemplate?: string;\n    readonly disableSources?: boolean;\n    readonly disableGit?: boolean;\n    readonly hideGenerator?: boolean;\n    readonly hideParameterTypesInTitle?: boolean;\n    readonly cacheBust?: boolean;\n    readonly searchInComments?: boolean;\n    readonly searchInDocuments?: boolean;\n    readonly validation?: ValidationOptions;\n    readonly requiredToBeDocumented?: string[];\n    readonly treatWarningsAsErrors?: boolean;\n    readonly treatValidationWarningsAsErrors?: boolean;\n    readonly intentionallyNotExported?: string[];\n    readonly externalPattern?: string[];\n    readonly externalSymbolLinkMappings?: Record<string, Record<string, string>>;\n}\n\nexport function toJson_TypeDocConfiguration(\n    obj: TypeDocConfiguration | undefined,\n): Record<string, unknown> | undefined {\n    if (obj === undefined) {\n        return undefined;\n    }\n    const result: Record<string, unknown> = {\n        entryPoints: obj.entryPoints,\n        entryPointStrategy: obj.entryPointStrategy,\n        exclude: obj.exclude,\n        excludeExternals: obj.excludeExternals,\n        excludePrivate: obj.excludePrivate,\n        excludeProtected: obj.excludeProtected,\n        excludeInternal: obj.excludeInternal,\n        out: obj.out,\n        json: obj.json,\n        theme: obj.theme,\n        basePath: obj.basePath,\n        name: obj.name,\n        cleanOutputDir: obj.cleanOutputDir,\n        includes: obj.includes,\n        media: obj.media,\n        tsBuildInfo: obj.tsBuildInfo,\n        tsconfig: obj.tsconfig,\n        logLevel: obj.logLevel,\n        sort: obj.sort,\n        sortEntryPoints: obj.sortEntryPoints,\n        commentStyle: obj.commentStyle,\n        defaultVisibility: obj.defaultVisibility,\n        defaultCategory: obj.defaultCategory,\n        defaultGroup: obj.defaultGroup,\n        categorizeByGroup: obj.categorizeByGroup,\n        searchGroupBoosts: obj.searchGroupBoosts,\n        searchCategoryBoosts: obj.searchCategoryBoosts,\n        readme: obj.readme,\n        packageJson: obj.packageJson,\n        gitRevision: obj.gitRevision,\n        gitRemote: obj.gitRemote,\n        sourceLinkTemplate: obj.sourceLinkTemplate,\n        disableSources: obj.disableSources,\n        disableGit: obj.disableGit,\n        hideGenerator: obj.hideGenerator,\n        hideParameterTypesInTitle: obj.hideParameterTypesInTitle,\n        cacheBust: obj.cacheBust,\n        searchInComments: obj.searchInComments,\n        searchInDocuments: obj.searchInDocuments,\n        validation: obj.validation,\n        requiredToBeDocumented: obj.requiredToBeDocumented,\n        treatWarningsAsErrors: obj.treatWarningsAsErrors,\n        treatValidationWarningsAsErrors: obj.treatValidationWarningsAsErrors,\n        intentionallyNotExported: obj.intentionallyNotExported,\n        externalPattern: obj.externalPattern,\n        externalSymbolLinkMappings: obj.externalSymbolLinkMappings,\n    };\n    const filtered: Record<string, unknown> = {};\n    for (const [key, value] of Object.entries(result)) {\n        if (value !== undefined) {\n            filtered[key] = value;\n        }\n    }\n    return filtered;\n}\n\nexport enum EntryPointStrategy {\n    RESOLVE = \"resolve\",\n    EXPAND = \"expand\",\n    PACKAGES = \"packages\",\n    MERGE = \"merge\",\n}\n\nexport enum LogLevel {\n    VERBOSE = \"Verbose\",\n    INFO = \"Info\",\n    WARN = \"Warn\",\n    ERROR = \"Error\",\n    NONE = \"None\",\n}\n\nexport enum CommentStyle {\n    JSDOC = \"jsdoc\",\n    BLOCK = \"block\",\n    LINE = \"line\",\n    ALL = \"all\",\n}\n\nexport enum Visibility {\n    PUBLIC = \"public\",\n    PROTECTED = \"protected\",\n    PRIVATE = \"private\",\n}\n\nexport interface ValidationOptions {\n    readonly notExported?: boolean;\n    readonly notDocumented?: boolean;\n    readonly invalidLink?: boolean;\n}\n"]}
|
|
165
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typedoc-config.js","sourceRoot":"","sources":["../../src/components/typedoc-config.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * TypeDoc configuration\n *\n * @see https://typedoc.org/options/\n */\nexport interface TypeDocConfiguration {\n    /**\n     * Specifies the entry points to be documented by TypeDoc.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#entrypoints\n     */\n    readonly entryPoints?: string[];\n\n    /**\n     * Specifies the strategy to be used to convert entry points into documentation.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#entrypointstrategy\n     */\n    readonly entryPointStrategy?: EntryPointStrategy;\n\n    /**\n     * Define patterns to be excluded when expanding directories.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#exclude\n     */\n    readonly exclude?: string[];\n\n    /**\n     * Prevent externally resolved symbols from being documented.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#excludeexternals\n     */\n    readonly excludeExternals?: boolean;\n\n    /**\n     * Prevent private members from being included in the generated documentation.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#excludeprivate\n     */\n    readonly excludePrivate?: boolean;\n\n    /**\n     * Prevent protected members from being included in the generated documentation.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#excludeprotected\n     */\n    readonly excludeProtected?: boolean;\n\n    /**\n     * Prevent symbols that are not exported from being documented.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#excludeinternal\n     */\n    readonly excludeInternal?: boolean;\n\n    /**\n     * Specifies the output directory the documentation should be written to.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#out\n     */\n    readonly out?: string;\n\n    /**\n     * Specify the location the documentation should be written to.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#json\n     */\n    readonly json?: string;\n\n    /**\n     * Specify a theme name to use.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#theme\n     */\n    readonly theme?: string;\n\n    /**\n     * Specify the base path for all urls.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#basepath\n     */\n    readonly basePath?: string;\n\n    /**\n     * Set the name of the project that will be used in the header of the template.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#name\n     */\n    readonly name?: string;\n\n    /**\n     * Prevent TypeDoc from cleaning the output directory specified with --out.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#cleanoutputdir\n     */\n    readonly cleanOutputDir?: boolean;\n\n    /**\n     * Specify the location to look for included documents.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#includes\n     */\n    readonly includes?: string;\n\n    /**\n     * Specify the location with media files that should be copied to the output directory.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#media\n     */\n    readonly media?: string;\n\n    /**\n     * Specify the location and filename a .tsbuildinfo file should be written to.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#tsbuildinfo\n     */\n    readonly tsBuildInfo?: string;\n\n    /**\n     * Specify a TypeScript config file that should be used to load TypeScript configuration.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#tsconfig\n     */\n    readonly tsconfig?: string;\n\n    /**\n     * Specify the logger that should be used.\n     *\n     * @see https://typedoc.org/documents/Options.Other.html#loglevel\n     */\n    readonly logLevel?: LogLevel;\n\n    /**\n     * Specify the sort strategy for documented values.\n     *\n     * @see https://typedoc.org/documents/Options.Organization.html#sort\n     */\n    readonly sort?: string[];\n\n    /**\n     * Specify the sort strategy for static and instance members.\n     *\n     * @see https://typedoc.org/documents/Options.Organization.html#sortentrypoints\n     */\n    readonly sortEntryPoints?: boolean;\n\n    /**\n     * Specify the documentation mode TypeDoc should use.\n     *\n     * @see https://typedoc.org/documents/Options.Comments.html#commentstyle\n     */\n    readonly commentStyle?: CommentStyle;\n\n    /**\n     * Specify the default visibility for members without a visibility tag.\n     *\n     * @see https://typedoc.org/documents/Options.Comments.html#defaultvisibility\n     */\n    readonly defaultVisibility?: Visibility;\n\n    /**\n     * Specify the default category for reflections without a category.\n     *\n     * @see https://typedoc.org/documents/Options.Organization.html#defaultcategory\n     */\n    readonly defaultCategory?: string;\n\n    /**\n     * Specify the default group for reflections without a group.\n     *\n     * @see https://typedoc.org/documents/Options.Organization.html#defaultgroup\n     */\n    readonly defaultGroup?: string;\n\n    /**\n     * Specify the categories that will be used to group reflections.\n     *\n     * @see https://typedoc.org/documents/Options.Organization.html#categorizebygroup\n     */\n    readonly categorizeByGroup?: boolean;\n\n    /**\n     * Specify the search group boosts.\n     *\n     * @see https://typedoc.org/documents/Options.Organization.html#searchgroupboosts\n     */\n    readonly searchGroupBoosts?: Record<string, number>;\n\n    /**\n     * Specify the search category boosts.\n     *\n     * @see https://typedoc.org/documents/Options.Organization.html#searchcategoryboosts\n     */\n    readonly searchCategoryBoosts?: Record<string, number>;\n\n    /**\n     * Specify the readme file that should be displayed on the index page.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#readme\n     */\n    readonly readme?: string;\n\n    /**\n     * Specify the package.json file that should be used to determine the package name.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#packagejson\n     */\n    readonly packageJson?: string;\n\n    /**\n     * Specify the git revision that should be used to link to source files.\n     *\n     * @see https://typedoc.org/documents/Options.Comments.html#gitrevision\n     */\n    readonly gitRevision?: string;\n\n    /**\n     * Specify the git remote that should be used to link to source files.\n     *\n     * @see https://typedoc.org/documents/Options.Comments.html#gitremote\n     */\n    readonly gitRemote?: string;\n\n    /**\n     * Specify a link template to be used when generating source urls.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#sourcelinktemplate\n     */\n    readonly sourceLinkTemplate?: string;\n\n    /**\n     * Disables automatically linking to source code.\n     *\n     * @see https://typedoc.org/documents/Options.Comments.html#disablesources\n     */\n    readonly disableSources?: boolean;\n\n    /**\n     * Disables setting the source of reflections when documenting projects within a Git repository.\n     *\n     * @see https://typedoc.org/documents/Options.Comments.html#disablegit\n     */\n    readonly disableGit?: boolean;\n\n    /**\n     * Do not print the TypeDoc link at the end of the page.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#hidegenerator\n     */\n    readonly hideGenerator?: boolean;\n\n    /**\n     * Hide parameter types in the signature.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#hideparametertypesintitle\n     */\n    readonly hideParameterTypesInTitle?: boolean;\n\n    /**\n     * Include the generation time in links to prevent browsers from using a cached version.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#cachebust\n     */\n    readonly cacheBust?: boolean;\n\n    /**\n     * If set, the search index will also include comments.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#searchincomments\n     */\n    readonly searchInComments?: boolean;\n\n    /**\n     * If set, the search index will also include documents.\n     *\n     * @see https://typedoc.org/documents/Options.Output.html#searchindocuments\n     */\n    readonly searchInDocuments?: boolean;\n\n    /**\n     * Specify validation options.\n     *\n     * @see https://typedoc.org/documents/Options.Validation.html\n     */\n    readonly validation?: ValidationOptions;\n\n    /**\n     * Specify the type of reflections that must be documented.\n     *\n     * @see https://typedoc.org/documents/Options.Validation.html#requiredtobedocumented\n     */\n    readonly requiredToBeDocumented?: string[];\n\n    /**\n     * If set, warnings will be treated as errors.\n     *\n     * @see https://typedoc.org/documents/Options.Validation.html#treatwarningsaserrors\n     */\n    readonly treatWarningsAsErrors?: boolean;\n\n    /**\n     * If set, validation warnings will be treated as errors.\n     *\n     * @see https://typedoc.org/documents/Options.Validation.html#treatvalidationwarningsaserrors\n     */\n    readonly treatValidationWarningsAsErrors?: boolean;\n\n    /**\n     * A list of types that should not produce warnings when not being exported.\n     *\n     * @see https://typedoc.org/documents/Options.Validation.html#intentionallynotexported\n     */\n    readonly intentionallyNotExported?: string[];\n\n    /**\n     * Define patterns for files that should be considered external.\n     *\n     * @see https://typedoc.org/documents/Options.Input.html#externalpattern\n     */\n    readonly externalPattern?: string[];\n\n    /**\n     * Define custom mappings for symbols in external packages.\n     *\n     * @see https://typedoc.org/documents/Options.Comments.html#externalsymbollinkmappings\n     */\n    readonly externalSymbolLinkMappings?: Record<string, Record<string, string>>;\n}\n\n/**\n * Converts TypeDocConfiguration to JSON representation\n * @internal\n */\nexport function toJson_TypeDocConfiguration(\n    obj: TypeDocConfiguration | undefined,\n): Record<string, unknown> | undefined {\n    if (obj === undefined) {\n        return undefined;\n    }\n    const result: Record<string, unknown> = {\n        entryPoints: obj.entryPoints,\n        entryPointStrategy: obj.entryPointStrategy,\n        exclude: obj.exclude,\n        excludeExternals: obj.excludeExternals,\n        excludePrivate: obj.excludePrivate,\n        excludeProtected: obj.excludeProtected,\n        excludeInternal: obj.excludeInternal,\n        out: obj.out,\n        json: obj.json,\n        theme: obj.theme,\n        basePath: obj.basePath,\n        name: obj.name,\n        cleanOutputDir: obj.cleanOutputDir,\n        includes: obj.includes,\n        media: obj.media,\n        tsBuildInfo: obj.tsBuildInfo,\n        tsconfig: obj.tsconfig,\n        logLevel: obj.logLevel,\n        sort: obj.sort,\n        sortEntryPoints: obj.sortEntryPoints,\n        commentStyle: obj.commentStyle,\n        defaultVisibility: obj.defaultVisibility,\n        defaultCategory: obj.defaultCategory,\n        defaultGroup: obj.defaultGroup,\n        categorizeByGroup: obj.categorizeByGroup,\n        searchGroupBoosts: obj.searchGroupBoosts,\n        searchCategoryBoosts: obj.searchCategoryBoosts,\n        readme: obj.readme,\n        packageJson: obj.packageJson,\n        gitRevision: obj.gitRevision,\n        gitRemote: obj.gitRemote,\n        sourceLinkTemplate: obj.sourceLinkTemplate,\n        disableSources: obj.disableSources,\n        disableGit: obj.disableGit,\n        hideGenerator: obj.hideGenerator,\n        hideParameterTypesInTitle: obj.hideParameterTypesInTitle,\n        cacheBust: obj.cacheBust,\n        searchInComments: obj.searchInComments,\n        searchInDocuments: obj.searchInDocuments,\n        validation: obj.validation,\n        requiredToBeDocumented: obj.requiredToBeDocumented,\n        treatWarningsAsErrors: obj.treatWarningsAsErrors,\n        treatValidationWarningsAsErrors: obj.treatValidationWarningsAsErrors,\n        intentionallyNotExported: obj.intentionallyNotExported,\n        externalPattern: obj.externalPattern,\n        externalSymbolLinkMappings: obj.externalSymbolLinkMappings,\n    };\n    const filtered: Record<string, unknown> = {};\n    for (const [key, value] of Object.entries(result)) {\n        if (value !== undefined) {\n            filtered[key] = value;\n        }\n    }\n    return filtered;\n}\n\n/**\n * Specifies the strategy to be used to convert entry points into documentation\n *\n * @see https://typedoc.org/documents/Options.Input.html#entrypointstrategy\n */\nexport enum EntryPointStrategy {\n    /**\n     * Expects all entry points to be contained within a single package\n     */\n    RESOLVE = \"resolve\",\n    /**\n     * Expects all entry points to be top-level directories\n     */\n    EXPAND = \"expand\",\n    /**\n     * Expects all entry points to be individual files\n     */\n    PACKAGES = \"packages\",\n    /**\n     * Merges multiple projects into a single documentation site\n     */\n    MERGE = \"merge\",\n}\n\n/**\n * Specifies the logger that should be used\n *\n * @see https://typedoc.org/documents/Options.Other.html#loglevel\n */\nexport enum LogLevel {\n    /**\n     * Log all messages including verbose debug information\n     */\n    VERBOSE = \"Verbose\",\n    /**\n     * Log informational messages and above\n     */\n    INFO = \"Info\",\n    /**\n     * Log warnings and errors only\n     */\n    WARN = \"Warn\",\n    /**\n     * Log errors only\n     */\n    ERROR = \"Error\",\n    /**\n     * Disable all logging\n     */\n    NONE = \"None\",\n}\n\n/**\n * Specifies the documentation mode TypeDoc should use\n *\n * @see https://typedoc.org/documents/Options.Comments.html#commentstyle\n */\nexport enum CommentStyle {\n    /**\n     * Parse JSDoc style comments only\n     */\n    JSDOC = \"jsdoc\",\n    /**\n     * Parse block comments\n     */\n    BLOCK = \"block\",\n    /**\n     * Parse line comments (//)\n     */\n    LINE = \"line\",\n    /**\n     * Parse all comment styles\n     */\n    ALL = \"all\",\n}\n\n/**\n * Specifies the default visibility for members without a visibility tag\n *\n * @see https://typedoc.org/documents/Options.Comments.html#defaultvisibility\n */\nexport enum Visibility {\n    /**\n     * Public visibility - accessible from anywhere\n     */\n    PUBLIC = \"public\",\n    /**\n     * Protected visibility - accessible from class and subclasses\n     */\n    PROTECTED = \"protected\",\n    /**\n     * Private visibility - accessible only within the class\n     */\n    PRIVATE = \"private\",\n}\n\n/**\n * Validation options\n *\n * @see https://typedoc.org/documents/Options.Validation.html\n */\nexport interface ValidationOptions {\n    /**\n     * If set, TypeDoc will produce warnings when a symbol is referenced by the documentation\n     */\n    readonly notExported?: boolean;\n    /**\n     * If set, TypeDoc will produce warnings when an exported symbol is not documented\n     */\n    readonly notDocumented?: boolean;\n    /**\n     * If set, TypeDoc will produce warnings about \\@link tags which will produce broken links\n     */\n    readonly invalidLink?: boolean;\n}\n"]}
|
|
@@ -5,13 +5,32 @@ import type { Project } from "projen/lib/project";
|
|
|
5
5
|
import type { Task } from "projen/lib/task";
|
|
6
6
|
import { type TypeDocConfiguration } from "./typedoc-config";
|
|
7
7
|
export interface TypeDocOptions {
|
|
8
|
+
/**
|
|
9
|
+
* Version of TypeDoc to use
|
|
10
|
+
*
|
|
11
|
+
* @default "^0.28"
|
|
12
|
+
*/
|
|
8
13
|
readonly version?: string;
|
|
14
|
+
/**
|
|
15
|
+
* Full TypeDoc configuration
|
|
16
|
+
*
|
|
17
|
+
* This configuration will be merged with the default configuration
|
|
18
|
+
*/
|
|
9
19
|
readonly typeDocConfig?: TypeDocConfiguration;
|
|
10
20
|
}
|
|
21
|
+
/**
|
|
22
|
+
* TypeDoc component for projen projects
|
|
23
|
+
*/
|
|
11
24
|
export declare class TypeDoc extends Component {
|
|
12
25
|
static of(project: Project): TypeDoc | undefined;
|
|
13
26
|
private readonly typeDocConfiguration;
|
|
27
|
+
/**
|
|
28
|
+
* TypeDoc task
|
|
29
|
+
*/
|
|
14
30
|
readonly task: Task;
|
|
31
|
+
/**
|
|
32
|
+
* TypeDoc configuration file
|
|
33
|
+
*/
|
|
15
34
|
readonly file: JsonFile;
|
|
16
35
|
constructor(project: NodeProject, options?: TypeDocOptions);
|
|
17
36
|
}
|