json-schema-to-typescript

WebJar for json-schema-to-typescript

License

License

MIT
Categories

Categories

JSON Data
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

json-schema-to-typescript
Last Version

Last Version

5.3.3
Release Date

Release Date

Type

Type

jar
Description

Description

json-schema-to-typescript
WebJar for json-schema-to-typescript
Project URL

Project URL

http://webjars.org
Source Code Management

Source Code Management

https://github.com/bcherny/json-schema-to-typescript

Download json-schema-to-typescript

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/json-schema-to-typescript/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>json-schema-to-typescript</artifactId>
    <version>5.3.3</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/json-schema-to-typescript/
implementation 'org.webjars.npm:json-schema-to-typescript:5.3.3'
// https://jarcasting.com/artifacts/org.webjars.npm/json-schema-to-typescript/
implementation ("org.webjars.npm:json-schema-to-typescript:5.3.3")
'org.webjars.npm:json-schema-to-typescript:jar:5.3.3'
<dependency org="org.webjars.npm" name="json-schema-to-typescript" rev="5.3.3">
  <artifact name="json-schema-to-typescript" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='json-schema-to-typescript', version='5.3.3')
)
libraryDependencies += "org.webjars.npm" % "json-schema-to-typescript" % "5.3.3"
[org.webjars.npm/json-schema-to-typescript "5.3.3"]

Dependencies

compile (15)

Group / Artifact Type Version
org.webjars.npm : types__lodash jar [4.14.88,5)
org.webjars.npm : json-schema-ref-parser jar [4.0.4,5)
org.webjars.npm : prettier jar [1.8.2,2)
org.webjars.npm » stdin jar 0.0.1
org.webjars.npm : cli-color jar [1.2.0,2)
org.webjars.npm : minimist jar [1.2.0,2)
org.webjars.npm : types__cli-color jar [0.3.29,0.4)
org.webjars.npm : lodash jar [4.17.4,5)
org.webjars.npm : types__json-schema jar [4.0.0,5)
org.webjars.npm : types__node jar [8.0.50,9)
org.webjars.npm : types__prettier jar [1.7.2,2)
org.webjars.npm : json-stringify-safe jar [5.0.1,6)
org.webjars.npm : types__mz jar 0.0.32
org.webjars.npm : types__minimist jar [1.2.0,2)
org.webjars.npm : mz jar [2.7.0,3)

Project Modules

There are no modules declared in this project.

json-schema-to-typescript Build Status npm mit

Compile json schema to typescript typings

Example

Input:

{
  "title": "Example Schema",
  "type": "object",
  "properties": {
    "firstName": {
      "type": "string"
    },
    "lastName": {
      "type": "string"
    },
    "age": {
      "description": "Age in years",
      "type": "integer",
      "minimum": 0
    },
    "hairColor": {
      "enum": ["black", "brown", "blue"],
      "type": "string"
    }
  },
  "additionalProperties": false,
  "required": ["firstName", "lastName"]
}

Output:

export interface ExampleSchema {
  firstName: string;
  lastName: string;
  /**
   * Age in years
   */
  age?: number;
  hairColor?: "black" | "brown" | "blue";
}

Installation

# Using Yarn:
yarn add json-schema-to-typescript

# Or, using NPM:
npm install json-schema-to-typescript --save

Usage

import { compile, compileFromFile } from 'json-schema-to-typescript'

// compile from file
compileFromFile('foo.json')
  .then(ts => fs.writeFileSync('foo.d.ts', ts))

// or, compile a JS object
let mySchema = {
  properties: [...]
}
compile(mySchema, 'MySchema')
  .then(ts => ...)

See server demo and browser demo for full examples.

Options

compileFromFile and compile accept options as their last argument (all keys are optional):

key type default description
bannerComment string "/* tslint:disable */\n/**\n* This file was automatically generated by json-schema-to-typescript.\n* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,\n* and run json-schema-to-typescript to regenerate this file.\n*/" Disclaimer comment prepended to the top of each generated file
cwd string process.cwd() Root directory for resolving $refs
declareExternallyReferenced boolean true Declare external schemas referenced via $ref?
enableConstEnums boolean true Prepend enums with const?
format boolean true Format code? Set this to false to improve performance.
ignoreMinAndMaxItems boolean false Ignore maxItems and minItems for array types, preventing tuples being generated.
style object { bracketSpacing: false, printWidth: 120, semi: true, singleQuote: false, tabWidth: 2, trailingComma: 'none', useTabs: false } A Prettier configuration
unknownAny boolean true Use unknown instead of any where possible
unreachableDefinitions boolean false Generates code for definitions that aren't referenced by the schema.
strictIndexSignatures boolean false Append all index signatures with | undefined so that they are strictly typed.
$refOptions object {} $RefParser Options, used when resolving $refs

CLI

A CLI utility is provided with this package.

cat foo.json | json2ts > foo.d.ts
# or
json2ts foo.json > foo.d.ts
# or
json2ts foo.json foo.d.ts
# or
json2ts --input foo.json --output foo.d.ts
# or
json2ts -i foo.json -o foo.d.ts
# or
json2ts -i schemas/**/*.json
# or
json2ts -i schemas/ -o types/

You can pass any of the options described above (including style options) as CLI flags. Boolean values can be set to false using the no- prefix.

# generate code for definitions that aren't referenced
json2ts -i foo.json -o foo.d.ts --unreachableDefinitions
# use single quotes and disable trailing semicolons
json2ts -i foo.json -o foo.d.ts --style.singleQuote --no-style.semi

Tests

npm test

Features

  • title => interface
  • Primitive types:
    • array
    • homogeneous array
    • boolean
    • integer
    • number
    • null
    • object
    • string
    • homogeneous enum
    • heterogeneous enum
  • Non/extensible interfaces
  • Custom JSON-schema extensions
  • Nested properties
  • Schema definitions
  • Schema references
  • Local (filesystem) schema references
  • External (network) schema references
  • Add support for running in browser
  • default interface name
  • infer unnamed interface name from filename
  • allOf ("intersection")
  • anyOf ("union")
  • oneOf (treated like anyOf)
  • maxItems (eg)
  • minItems (eg)
  • additionalProperties of type
  • patternProperties (partial support)
  • extends
  • required properties on objects (eg)
  • validateRequired (eg)
  • literal objects in enum (eg)
  • referencing schema by id (eg)
  • custom typescript types via tsType

Custom schema properties:

  • tsType: Overrides the type that's generated from the schema. Useful for forcing a type to any or when using non-standard JSON schema extensions (eg).
  • tsEnumNames: Overrides the names used for the elements in an enum. Can also be used to create string enums (eg).

Not expressible in TypeScript:

FAQ

JSON-Schema-to-TypeScript is crashing on my giant file. What can I do?

Prettier is known to run slowly on really big files. To skip formatting and improve performance, set the format option to false.

Further Reading

Who uses JSON-Schema-to-TypeScript?

Versions

Version
5.3.3