Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor(api-markdown-documenter): Allow deeper customization of output folder structure #23366

Merged
Merged
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
70 commits
Select commit Hold shift + click to select a range
db9d9f1
WIP
Josmithr Dec 16, 2024
f80e4a6
chore: Add `DeepRequired` utility type
Josmithr Dec 16, 2024
ec1242f
chore: Type aliases and helper functions
Josmithr Dec 16, 2024
410049c
[WIP]
Josmithr Dec 16, 2024
9d3ecb2
style: Prettier
Josmithr Dec 16, 2024
b8c8f83
WIP
Josmithr Dec 17, 2024
a67cf98
More WIP
Josmithr Dec 18, 2024
964e4bf
docs: Fix comments
Josmithr Dec 18, 2024
600591a
fix: Correct handling of entry-points
Josmithr Dec 18, 2024
571c170
fix: Types
Josmithr Dec 18, 2024
63f253d
refactor: Rename interface
Josmithr Dec 18, 2024
824c7f0
fix: End-to-end tests
Josmithr Dec 18, 2024
cf91dc5
fix: Config generation
Josmithr Dec 18, 2024
3019028
refactor: Rename types
Josmithr Dec 18, 2024
dad5814
refactor: Rename file
Josmithr Dec 18, 2024
81994f4
fix: Restore support for document hierarchy for packages
Josmithr Dec 18, 2024
214ae3b
fix: Test configs
Josmithr Dec 18, 2024
9786a34
fix(test): Fix configurations
Josmithr Dec 18, 2024
8bce322
refactor: Move function
Josmithr Dec 18, 2024
fda21fa
test: Remove invalid test case
Josmithr Dec 18, 2024
3071431
fix: Document and folder naming
Josmithr Dec 18, 2024
60f6e74
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Dec 19, 2024
3e67819
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Dec 19, 2024
e58de30
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Dec 19, 2024
ef12ea3
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Dec 19, 2024
7206e37
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Dec 20, 2024
289c9eb
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Dec 20, 2024
e4f184c
docs: Fix comment
Josmithr Dec 20, 2024
25162b5
refactor: Remove unneeded type alias
Josmithr Dec 20, 2024
92ecd59
docs: Remove obsolete TODO
Josmithr Dec 20, 2024
7e2dbd5
docs: Remove TODOs
Josmithr Dec 20, 2024
1c6e34a
test: Update test structure
Josmithr Dec 20, 2024
2dc2447
remove: Unused utility function
Josmithr Dec 20, 2024
77f96c8
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Dec 20, 2024
56b58e8
test: Add deep config end-to-end tests
Josmithr Dec 20, 2024
5c7d60a
refactor: More hierarchy options flexibility
Josmithr Dec 21, 2024
21b1ea9
refactor: Simplify
Josmithr Dec 21, 2024
ba59e5a
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Dec 21, 2024
0381258
refactor: More simplifying
Josmithr Dec 21, 2024
f711e86
refactor: Give more hierarchy config flexibility
Josmithr Jan 6, 2025
42c752b
WIP: Better hierarchical control over naming policy
Josmithr Jan 7, 2025
338e12a
WIP: More input flexibility progress
Josmithr Jan 7, 2025
181c0c8
refactor: Rename properties
Josmithr Jan 7, 2025
9771f71
test: Add unit tests
Josmithr Jan 7, 2025
e6b39dc
refactor: Make input options optional
Josmithr Jan 7, 2025
1db0399
refactor: Variable renames and comment
Josmithr Jan 7, 2025
8119e7f
docs: Add missing copyright notice
Josmithr Jan 7, 2025
ff8de15
test: Add unit test
Josmithr Jan 7, 2025
46364b1
docs: Update comments
Josmithr Jan 7, 2025
0b316fb
docs: Remove stale TODO
Josmithr Jan 7, 2025
05e70b6
refactor: Further simplify hierarchy setup
Josmithr Jan 8, 2025
f5e7cf1
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Jan 8, 2025
1088e92
test: Remove new test case for now
Josmithr Jan 8, 2025
8f3396e
test: Fix tests
Josmithr Jan 8, 2025
9f42ec0
docs: Add comment
Josmithr Jan 8, 2025
aa78ec4
docs: Add changelog entry
Josmithr Jan 8, 2025
3d13e68
Merge branch 'api-markdown-documenter/hierarchy-config' of https://gi…
Josmithr Jan 8, 2025
90728fc
refactor: Make enum value strings upper-case for consistency
Josmithr Jan 8, 2025
13339cc
style: Prettier
Josmithr Jan 8, 2025
a453d31
refactor: Make properties readonly
Josmithr Jan 8, 2025
d77d928
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Jan 8, 2025
1920abd
refactor: Remove export of API that should not be needed externally
Josmithr Jan 8, 2025
bb91baa
remove: Unwanted new module
Josmithr Jan 8, 2025
0f9092a
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Jan 8, 2025
c2dcc77
revert: Unwanted utility refactoring
Josmithr Jan 8, 2025
a5a704d
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Jan 8, 2025
c773644
docs: Update comment
Josmithr Jan 8, 2025
ea2a170
Merge branch 'main' into api-markdown-documenter/hierarchy-config
Josmithr Jan 14, 2025
76a3cfd
Merge branch 'api-markdown-documenter/hierarchy-config' of https://gi…
Josmithr Jan 15, 2025
9f80bf6
refactor: Simplify types
Josmithr Jan 15, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ export { ApiItem }
export { ApiItemKind }

// @public
export interface ApiItemTransformationConfiguration extends ApiItemTransformationConfigurationBase, ApiItemTransformations, Required<DocumentationSuiteOptions>, Required<LoggingConfiguration> {
export interface ApiItemTransformationConfiguration extends ApiItemTransformationConfigurationBase, ApiItemTransformations, DocumentationSuiteConfiguration, Required<LoggingConfiguration> {
}

// @public @sealed
Expand Down Expand Up @@ -83,12 +83,13 @@ export interface ApiItemTransformations {

declare namespace ApiItemUtilities {
export {
doesItemRequireOwnDocument,
doesItemKindRequireOwnDocument,
Josmithr marked this conversation as resolved.
Show resolved Hide resolved
filterItems,
getHeadingForApiItem,
getLinkForApiItem,
shouldItemBeIncluded,
ancestryHasModifierTag,
getApiItemKind,
getCustomBlockComments,
getDefaultValueBlock,
getDeprecatedBlock,
Expand All @@ -112,7 +113,7 @@ declare namespace ApiItemUtilities {
export { ApiItemUtilities }

// @public
export type ApiMemberKind = Omit<ApiItemKind, ApiItemKind.EntryPoint | ApiItemKind.Model | ApiItemKind.None | ApiItemKind.Package>;
export type ApiMemberKind = Exclude<ApiItemKind, ApiItemKind.EntryPoint | ApiItemKind.Model | ApiItemKind.None | ApiItemKind.Package>;

export { ApiModel }

Expand Down Expand Up @@ -189,16 +190,20 @@ export const defaultConsoleLogger: Logger;

// @public
export namespace DefaultDocumentationSuiteOptions {
const defaultDocumentBoundaries: ApiMemberKind[];
const defaultHierarchyBoundaries: ApiMemberKind[];
export function defaultGetAlertsForItem(apiItem: ApiItem): string[];
export function defaultGetFileNameForItem(apiItem: ApiItem): string;
export function defaultGetHeadingTextForItem(apiItem: ApiItem): string;
export function defaultGetLinkTextForItem(apiItem: ApiItem): string;
export function defaultGetUriBaseOverrideForItem(): string | undefined;
export function defaultSkipPackage(): boolean;
}

// @public
export type DocumentationHierarchyConfiguration = SectionHierarchyConfiguration | DocumentHierarchyConfiguration | FolderHierarchyConfiguration;

// @public
export interface DocumentationHierarchyConfigurationBase<THierarchyKind extends HierarchyKind> {
readonly kind: THierarchyKind;
}

// @public
export interface DocumentationLiteralNode<TValue = unknown> extends Literal<TValue>, DocumentationNode {
readonly isLiteral: true;
Expand Down Expand Up @@ -281,23 +286,31 @@ export abstract class DocumentationParentNodeBase<TDocumentationNode extends Doc
abstract type: string;
}

// @public
export type DocumentationSuiteConfiguration = Omit<Required<DocumentationSuiteOptions>, "hierarchy"> & {
readonly hierarchy: Required<HierarchyConfiguration>;
};

// @public
export interface DocumentationSuiteOptions {
readonly documentBoundaries?: DocumentBoundaries;
readonly getAlertsForItem?: (apiItem: ApiItem) => string[];
readonly getFileNameForItem?: (apiItem: ApiItem) => string;
readonly getHeadingTextForItem?: (apiItem: ApiItem) => string;
readonly getLinkTextForItem?: (apiItem: ApiItem) => string;
readonly getUriBaseOverrideForItem?: (apiItem: ApiItem) => string | undefined;
readonly hierarchyBoundaries?: HierarchyBoundaries;
readonly hierarchy?: Partial<HierarchyConfiguration>;
readonly includeBreadcrumb?: boolean;
readonly includeTopLevelDocumentHeading?: boolean;
readonly minimumReleaseLevel?: Omit<ReleaseTag, ReleaseTag.None>;
readonly minimumReleaseLevel?: Exclude<ReleaseTag, ReleaseTag.None>;
Josmithr marked this conversation as resolved.
Show resolved Hide resolved
readonly skipPackage?: (apiPackage: ApiPackage) => boolean;
}

// @public
export type DocumentBoundaries = ApiMemberKind[];
export interface DocumentHierarchyConfiguration extends DocumentationHierarchyConfigurationBase<HierarchyKind.Document>, DocumentHierarchyProperties {
}

// @public
export interface DocumentHierarchyProperties extends SectionHierarchyProperties {
readonly documentName?: string | undefined | ((apiItem: ApiItem) => string | undefined);
}

// @public
export class DocumentNode implements Parent<SectionNode>, DocumentNodeProps {
Expand Down Expand Up @@ -337,7 +350,7 @@ export namespace DocumentWriter {
}

// @public
function doesItemRequireOwnDocument(apiItem: ApiItem, documentBoundaries: DocumentBoundaries): boolean;
function doesItemKindRequireOwnDocument(apiItemKind: ValidApiItemKind, hierarchyConfig: Required<HierarchyConfiguration>): boolean;

// @public
export class FencedCodeBlockNode extends DocumentationParentNodeBase implements MultiLineDocumentationNode {
Expand All @@ -351,12 +364,31 @@ export class FencedCodeBlockNode extends DocumentationParentNodeBase implements
// @public
export interface FileSystemConfiguration {
readonly newlineKind?: NewlineKind;
outputDirectoryPath: string;
readonly outputDirectoryPath: string;
}

// @public
function filterItems(apiItems: readonly ApiItem[], config: ApiItemTransformationConfiguration): ApiItem[];

// @public
export enum FolderDocumentPlacement {
Inside = "inside",
Josmithr marked this conversation as resolved.
Show resolved Hide resolved
Outside = "outside"
}

// @public
export interface FolderHierarchyConfiguration extends DocumentationHierarchyConfigurationBase<HierarchyKind.Folder>, FolderHierarchyProperties {
}

// @public
export interface FolderHierarchyProperties extends DocumentHierarchyProperties {
readonly documentPlacement: FolderDocumentPlacement | ((apiItem: ApiItem) => FolderDocumentPlacement);
readonly folderName: string | undefined | ((apiItem: ApiItem) => string | undefined);
}

// @public
function getApiItemKind(apiItem: ApiItem): ValidApiItemKind;

// @public
export function getApiItemTransformationConfigurationWithDefaults(options: ApiItemTransformationOptions): ApiItemTransformationConfiguration;

Expand Down Expand Up @@ -426,7 +458,20 @@ export class HeadingNode extends DocumentationParentNodeBase<SingleLineDocumenta
}

// @public
export type HierarchyBoundaries = ApiMemberKind[];
export type HierarchyConfiguration = {
[Kind in Exclude<ValidApiItemKind, ApiItemKind.Model | ApiItemKind.EntryPoint | ApiItemKind.Package>]: DocumentationHierarchyConfiguration;
} & {
[ApiItemKind.Model]: DocumentHierarchyConfiguration;
[ApiItemKind.Package]: DocumentHierarchyConfiguration | FolderHierarchyConfiguration;
[ApiItemKind.EntryPoint]: DocumentHierarchyConfiguration;
};

// @public
export enum HierarchyKind {
Document = "document",
Folder = "folder",
Section = "section"
}

// @public
export class HorizontalRuleNode implements MultiLineDocumentationNode {
Expand Down Expand Up @@ -627,7 +672,7 @@ export { ReleaseTag }
// @alpha
function renderApiModelAsHtml(options: RenderApiModelAsHtmlOptions): Promise<void>;

// @public
// @alpha
Josmithr marked this conversation as resolved.
Show resolved Hide resolved
interface RenderApiModelAsHtmlOptions extends ApiItemTransformationOptions, RenderDocumentAsHtmlConfiguration, FileSystemConfiguration {
}

Expand All @@ -649,14 +694,14 @@ export interface RenderDocumentAsHtmlConfiguration extends ToHtmlConfiguration,
}

// @alpha
function renderDocumentsAsHtml(documents: DocumentNode[], options: RenderDocumentsAsHtmlOptions): Promise<void>;
function renderDocumentsAsHtml(documents: readonly DocumentNode[], options: RenderDocumentsAsHtmlOptions): Promise<void>;

// @public
// @alpha
interface RenderDocumentsAsHtmlOptions extends RenderDocumentAsHtmlConfiguration, FileSystemConfiguration {
}

// @public
function renderDocumentsAsMarkdown(documents: DocumentNode[], options: RenderDocumentsAsMarkdownOptions): Promise<void>;
function renderDocumentsAsMarkdown(documents: readonly DocumentNode[], options: RenderDocumentsAsMarkdownOptions): Promise<void>;

// @public
interface RenderDocumentsAsMarkdownOptions extends MarkdownRenderConfiguration, FileSystemConfiguration {
Expand All @@ -676,6 +721,15 @@ function renderNode(node: DocumentationNode, writer: DocumentWriter, context: Ma
// @public
function renderNodes(children: DocumentationNode[], writer: DocumentWriter, childContext: MarkdownRenderContext): void;

// @public
export interface SectionHierarchyConfiguration extends DocumentationHierarchyConfigurationBase<HierarchyKind.Section>, SectionHierarchyProperties {
}

// @public
export interface SectionHierarchyProperties {
readonly headingText: string | ((apiItem: ApiItem) => string);
}

// @public
export class SectionNode extends DocumentationParentNodeBase implements MultiLineDocumentationNode {
constructor(children: DocumentationNode[], heading?: HeadingNode);
Expand Down Expand Up @@ -825,6 +879,9 @@ export class UnorderedListNode extends DocumentationParentNodeBase<SingleLineDoc
// @public
export type UrlTarget = string;

// @public
export type ValidApiItemKind = Exclude<ApiItemKind, ApiItemKind.None>;

// @public
export const verboseConsoleLogger: Logger;

Expand Down
Loading
Loading