ts-json-schema-generator
Version:
Generate JSON schema from your Typescript sources
57 lines (46 loc) • 2.08 kB
text/typescript
import ts from "typescript";
import { Context } from "./NodeParser";
import { SubNodeParser } from "./SubNodeParser";
import { BaseType } from "./Type/BaseType";
import { DefinitionType } from "./Type/DefinitionType";
import { ReferenceType } from "./Type/ReferenceType";
import { hasJsDocTag } from "./Utils/hasJsDocTag";
import { symbolAtNode } from "./Utils/symbolAtNode";
export class ExposeNodeParser implements SubNodeParser {
public constructor(
private typeChecker: ts.TypeChecker,
private subNodeParser: SubNodeParser,
private expose: "all" | "none" | "export",
private jsDoc: "none" | "extended" | "basic"
) {}
public supportsNode(node: ts.Node): boolean {
return this.subNodeParser.supportsNode(node);
}
public createType(node: ts.Node, context: Context, reference?: ReferenceType): BaseType | undefined {
const baseType = this.subNodeParser.createType(node, context, reference);
if (baseType === undefined) {
return undefined;
}
if (!this.isExportNode(node)) {
return baseType;
}
return new DefinitionType(this.getDefinitionName(node, context), baseType);
}
private isExportNode(node: ts.Node): boolean {
if (this.expose === "all") {
return node.kind !== ts.SyntaxKind.TypeLiteral;
} else if (this.expose === "none") {
return false;
} else if (this.jsDoc !== "none" && hasJsDocTag(node, "internal")) {
return false;
}
const localSymbol: ts.Symbol = (node as any).localSymbol;
return localSymbol ? "exportSymbol" in localSymbol : false;
}
private getDefinitionName(node: ts.Node, context: Context): string {
const symbol = symbolAtNode(node)!;
const fullName = this.typeChecker.getFullyQualifiedName(symbol).replace(/^".*"\./, "");
const argumentIds = context.getArguments().map((arg) => arg?.getName());
return argumentIds.length ? `${fullName}<${argumentIds.join(",")}>` : fullName;
}
}