ts-json-schema-generator
Advanced tools
Comparing version 2.1.1-next.0 to 2.1.1
{ | ||
"name": "ts-json-schema-generator", | ||
"version": "2.1.1-next.0", | ||
"version": "2.1.1", | ||
"description": "Generate JSON schema from your Typescript sources", | ||
@@ -9,3 +9,3 @@ "main": "dist/index.js", | ||
"bin": { | ||
"ts-json-schema-generator": "./bin/ts-json-schema-generator" | ||
"ts-json-schema-generator": "./bin/ts-json-schema-generator.js" | ||
}, | ||
@@ -63,4 +63,4 @@ "files": [ | ||
"@babel/preset-typescript": "^7.24.1", | ||
"@eslint/js": "^9.0.0", | ||
"@types/eslint": "^8.56.9", | ||
"@eslint/js": "^9.1.1", | ||
"@types/eslint": "^8.56.10", | ||
"@types/glob": "^8.1.0", | ||
@@ -75,3 +75,3 @@ "@types/jest": "^29.5.12", | ||
"cross-env": "^7.0.3", | ||
"eslint": "^9.0.0", | ||
"eslint": "^9.1.0", | ||
"eslint-config-prettier": "^9.1.0", | ||
@@ -83,3 +83,3 @@ "eslint-plugin-prettier": "^5.1.3", | ||
"tsx": "^4.7.2", | ||
"typescript-eslint": "^7.7.0", | ||
"typescript-eslint": "^7.7.1", | ||
"vega": "^5.28.0", | ||
@@ -86,0 +86,0 @@ "vega-lite": "^5.18.0" |
@@ -19,2 +19,3 @@ import ts from "typescript"; | ||
import { removeUndefined } from "../Utils/removeUndefined.js"; | ||
import { uniqueTypeArray } from "../Utils/uniqueTypeArray.js"; | ||
export class MappedTypeNodeParser { | ||
@@ -80,8 +81,6 @@ childNodeParser; | ||
} | ||
const key = derefType(this.childNodeParser.createType(node.nameType, this.createSubContext(node, rawKey, context))); | ||
return key; | ||
return derefType(this.childNodeParser.createType(node.nameType, this.createSubContext(node, rawKey, context))); | ||
} | ||
getProperties(node, keyListType, context) { | ||
return keyListType | ||
.getTypes() | ||
return uniqueTypeArray(keyListType.getFlattenedTypes(derefType)) | ||
.filter((type) => type instanceof LiteralType) | ||
@@ -88,0 +87,0 @@ .map((type) => [type, this.mapKey(node, type, context)]) |
@@ -12,2 +12,3 @@ import { BaseType } from "./BaseType.js"; | ||
normalize(): BaseType; | ||
getFlattenedTypes(deref?: (type: BaseType) => BaseType): BaseType[]; | ||
} |
import { BaseType } from "./BaseType.js"; | ||
import { uniqueTypeArray } from "../Utils/uniqueTypeArray.js"; | ||
import { NeverType } from "./NeverType.js"; | ||
import { derefType } from "../Utils/derefType.js"; | ||
import { derefAliasedType, derefType, isHiddenType } from "../Utils/derefType.js"; | ||
export class UnionType extends BaseType { | ||
@@ -52,3 +52,14 @@ types; | ||
} | ||
getFlattenedTypes(deref = derefAliasedType) { | ||
return this.getTypes() | ||
.filter((t) => !isHiddenType(t)) | ||
.map(deref) | ||
.flatMap((t) => { | ||
if (t instanceof UnionType) { | ||
return t.getFlattenedTypes(deref); | ||
} | ||
return t; | ||
}); | ||
} | ||
} | ||
//# sourceMappingURL=UnionType.js.map |
@@ -5,3 +5,2 @@ import { LiteralType } from "../Type/LiteralType.js"; | ||
import { UnionType } from "../Type/UnionType.js"; | ||
import { derefAliasedType, isHiddenType } from "../Utils/derefType.js"; | ||
import { typeName } from "../Utils/typeName.js"; | ||
@@ -18,4 +17,4 @@ import { uniqueArray } from "../Utils/uniqueArray.js"; | ||
let hasNull = false; | ||
const flattenedTypes = flattenTypes(type); | ||
const types = flattenedTypes.filter((t) => { | ||
const literals = type.getFlattenedTypes(); | ||
const types = literals.filter((t) => { | ||
if (t instanceof StringType) { | ||
@@ -62,17 +61,7 @@ hasString = true; | ||
} | ||
function flattenTypes(type) { | ||
export function isLiteralUnion(type) { | ||
return type | ||
.getTypes() | ||
.filter((t) => !isHiddenType(t)) | ||
.map(derefAliasedType) | ||
.flatMap((t) => { | ||
if (t instanceof UnionType) { | ||
return flattenTypes(t); | ||
} | ||
return t; | ||
}); | ||
.getFlattenedTypes() | ||
.every((item) => item instanceof LiteralType || item instanceof NullType || item instanceof StringType); | ||
} | ||
export function isLiteralUnion(type) { | ||
return flattenTypes(type).every((item) => item instanceof LiteralType || item instanceof NullType || item instanceof StringType); | ||
} | ||
function getLiteralValue(value) { | ||
@@ -79,0 +68,0 @@ return value instanceof LiteralType ? value.getValue() : null; |
{ | ||
"name": "ts-json-schema-generator", | ||
"version": "2.1.1-next.0", | ||
"version": "2.1.1", | ||
"description": "Generate JSON schema from your Typescript sources", | ||
@@ -9,3 +9,3 @@ "main": "dist/index.js", | ||
"bin": { | ||
"ts-json-schema-generator": "./bin/ts-json-schema-generator" | ||
"ts-json-schema-generator": "./bin/ts-json-schema-generator.js" | ||
}, | ||
@@ -63,4 +63,4 @@ "files": [ | ||
"@babel/preset-typescript": "^7.24.1", | ||
"@eslint/js": "^9.0.0", | ||
"@types/eslint": "^8.56.9", | ||
"@eslint/js": "^9.1.1", | ||
"@types/eslint": "^8.56.10", | ||
"@types/glob": "^8.1.0", | ||
@@ -75,3 +75,3 @@ "@types/jest": "^29.5.12", | ||
"cross-env": "^7.0.3", | ||
"eslint": "^9.0.0", | ||
"eslint": "^9.1.0", | ||
"eslint-config-prettier": "^9.1.0", | ||
@@ -83,3 +83,3 @@ "eslint-plugin-prettier": "^5.1.3", | ||
"tsx": "^4.7.2", | ||
"typescript-eslint": "^7.7.0", | ||
"typescript-eslint": "^7.7.1", | ||
"vega": "^5.28.0", | ||
@@ -86,0 +86,0 @@ "vega-lite": "^5.18.0" |
@@ -21,2 +21,3 @@ import ts from "typescript"; | ||
import { removeUndefined } from "../Utils/removeUndefined.js"; | ||
import { uniqueTypeArray } from "../Utils/uniqueTypeArray.js"; | ||
@@ -98,12 +99,7 @@ export class MappedTypeNodeParser implements SubNodeParser { | ||
} | ||
const key = derefType( | ||
this.childNodeParser.createType(node.nameType, this.createSubContext(node, rawKey, context)), | ||
); | ||
return key; | ||
return derefType(this.childNodeParser.createType(node.nameType, this.createSubContext(node, rawKey, context))); | ||
} | ||
protected getProperties(node: ts.MappedTypeNode, keyListType: UnionType, context: Context): ObjectProperty[] { | ||
return keyListType | ||
.getTypes() | ||
return uniqueTypeArray(keyListType.getFlattenedTypes(derefType)) | ||
.filter((type): type is LiteralType => type instanceof LiteralType) | ||
@@ -110,0 +106,0 @@ .map((type) => [type, this.mapKey(node, type, context)]) |
import { BaseType } from "./BaseType.js"; | ||
import { uniqueTypeArray } from "../Utils/uniqueTypeArray.js"; | ||
import { NeverType } from "./NeverType.js"; | ||
import { derefType } from "../Utils/derefType.js"; | ||
import { derefAliasedType, derefType, isHiddenType } from "../Utils/derefType.js"; | ||
@@ -59,2 +59,17 @@ export class UnionType extends BaseType { | ||
} | ||
/** | ||
* Get the types in this union as a flat list. | ||
*/ | ||
public getFlattenedTypes(deref: (type: BaseType) => BaseType = derefAliasedType): BaseType[] { | ||
return this.getTypes() | ||
.filter((t) => !isHiddenType(t)) | ||
.map(deref) | ||
.flatMap((t) => { | ||
if (t instanceof UnionType) { | ||
return t.getFlattenedTypes(deref); | ||
} | ||
return t; | ||
}); | ||
} | ||
} |
@@ -9,3 +9,2 @@ import { Definition } from "../Schema/Definition.js"; | ||
import { UnionType } from "../Type/UnionType.js"; | ||
import { derefAliasedType, isHiddenType } from "../Utils/derefType.js"; | ||
import { typeName } from "../Utils/typeName.js"; | ||
@@ -24,6 +23,6 @@ import { uniqueArray } from "../Utils/uniqueArray.js"; | ||
const flattenedTypes = flattenTypes(type); | ||
const literals = type.getFlattenedTypes(); | ||
// filter out String types since we need to be more careful about them | ||
const types = flattenedTypes.filter((t) => { | ||
const types = literals.filter((t) => { | ||
if (t instanceof StringType) { | ||
@@ -75,21 +74,8 @@ hasString = true; | ||
function flattenTypes(type: UnionType): (StringType | LiteralType | NullType)[] { | ||
export function isLiteralUnion(type: UnionType): boolean { | ||
return type | ||
.getTypes() | ||
.filter((t) => !isHiddenType(t)) | ||
.map(derefAliasedType) | ||
.flatMap((t) => { | ||
if (t instanceof UnionType) { | ||
return flattenTypes(t); | ||
} | ||
return t as StringType | LiteralType | NullType; | ||
}); | ||
.getFlattenedTypes() | ||
.every((item) => item instanceof LiteralType || item instanceof NullType || item instanceof StringType); | ||
} | ||
export function isLiteralUnion(type: UnionType): boolean { | ||
return flattenTypes(type).every( | ||
(item) => item instanceof LiteralType || item instanceof NullType || item instanceof StringType, | ||
); | ||
} | ||
function getLiteralValue(value: LiteralType | NullType): LiteralValue | null { | ||
@@ -96,0 +82,0 @@ return value instanceof LiteralType ? value.getValue() : null; |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
No v1
QualityPackage is not semver >=1. This means it is not stable and does not support ^ ranges.
Found 1 instance in 1 package
811269
1