Generate static HTML documentation from JSON schemas
Project description
JSON Schema for Humans
Quickly generate a beautiful HTML static page documenting a JSON schema
Documentation (with visual examples)
Installation
pip install json-schema-for-humans
Usage
generate-schema-doc [OPTIONS] SCHEMA_FILE [RESULT_FILE]
SCHEMA_FILE
must be a valid JSON Schema
The default value for RESULT_FILE
is schema_doc.html
Options
--expand-buttons
Off by default
Add an Expand all
and a Collapse all
button at the top of the generated documentation
--minify/--no-minify
On by default
Minify the output HTML document
--deprecated-from-description
Off by default
Mark a property as deprecated (with a big red badge) if the description contains the string [Deprecated
--default-from-description
Off by default
Extract the default value of a property from the description like this: [Default `the_default_value`]
The default value from the "default" attribute will be used in priority
--copy-css/--no-copy-css
On by default
Copy schema_doc.css
to the same directory as RESULT_FILE
.
--copy-js/--no-copy-js
On by default.
Copy schema_doc.min.js
to the same directory as RESULT_FILE
.
This file contains the logic for the anchor links
What's supported
See the excellent Understanding JSON Schema to understand what are those checks
The following are supported:
- Types
- Regular expressions
- Numeric types multiples and range
- Constant and enumerated values
- Required properties
- Default values
- Array
minItems
,maxItems
,uniqueItems
,items
(schema that must apply to all of the array items), andcontains
- Combining schema with
oneOf
,allOf
,anyOf
, andnot
These are not supported at the moment (PRs welcome!):
- String length and format
- Property names, size, and pattern
- Array items at specific index (for example, first item must be a string and second must be an integer)
- Property dependencies
- Examples
- Media
- Conditional subschemas
References from inside a schema and to schemas in other files are supported (for example { $ref: "#/definitions/something" }
will be replaced by the
content of schema["definitions"]["something"]
).
Anchor links
Clicking on a property or tab in the output documentation will set the hash of the current window. Opening this anchor link will expand all needed properties and scroll to this section of the schema. Useful for pointing your users to a specific setting.
For this feature to work, you need to include the Javascript file (schema_doc.js
) that is automatically copied next to the output HTML file (schema_doc.html
by default).
Development
Testing
Just run tox
tox
Modifying Javascript
schema_doc.js
is not minified automatically, you are responsible for doing it yourself
Generating doc
The documentation is generated using jekyll and hosted on GitHub Pages
- Change your current working directory to
docs
- Run
python generate_examples.py
. This will get all examples fromtests/cases
, render the resulting HTML and include it in the appropriate folders in the jekyll site. - If you have added an example, add the file name (without
.json
), the display name and description in_data/examples.yaml
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file json-schema-for-humans-0.6.0.tar.gz
.
File metadata
- Download URL: json-schema-for-humans-0.6.0.tar.gz
- Upload date:
- Size: 26.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fdc087f74ef26322e98752c4a95121dabb8fea0191c6fe69b1fbd5786cb394f6 |
|
MD5 | dd77ad364ff2bb2f19d021f3a612989b |
|
BLAKE2b-256 | d272a43e64548f484637530b3d24ae79fec46af1f189442aab127e6e0833a7d6 |
File details
Details for the file json_schema_for_humans-0.6.0-py3-none-any.whl
.
File metadata
- Download URL: json_schema_for_humans-0.6.0-py3-none-any.whl
- Upload date:
- Size: 14.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.23.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.45.0 CPython/3.7.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5f309dd5c5b529669c6abf191866f8e36d8ba8adbdef16c185e2a069dc8c8062 |
|
MD5 | ea455611b56af57fd5a756ad446dda30 |
|
BLAKE2b-256 | e7d89de44ad1fc75999b588db47e2e33e148d817b89e77ac6428540afbd7338f |