Library for genearating FastHTML user interfaces from JSON Schema configurations.
Project description
cjm-fasthtml-jsonschema
Install
pip install cjm_fasthtml_jsonschema
Demo Application
Run the demo to see the library in action:
python demo_app.py
Then visit:
- http://localhost:5001/ - Demo page with example form from `./test_files/
$ python ./demo_app.py -h
usage: demo_app.py [-h] [--schema SCHEMA] [--port PORT] [--host HOST]
JSON Schema to UI Demo Application
options:
-h, --help show this help message and exit
--schema SCHEMA Path to the JSON schema file (default: test_files/voxtral_config_schema.json)
--port PORT Port to run the server on (default: 5001)
--host HOST Host to run the server on (default: 0.0.0.0)
Project Structure
nbs/
├── components/ (1)
│ └── fields.ipynb # Field component generators for different JSON Schema types.
├── core/ (2)
│ ├── parser.ipynb # JSON Schema parsing utilities.
│ └── types.ipynb # Type definitions for JSON Schema elements.
└── generators/ (1)
└── form.ipynb # Main form generator that creates UI from JSON Schema.
Total: 4 notebooks across 3 directories
Module Dependencies
graph LR
components_fields[components.fields<br/>fields]
core_parser[core.parser<br/>parser]
core_types[core.types<br/>types]
generators_form[generators.form<br/>form]
components_fields --> core_types
core_parser --> core_types
generators_form --> components_fields
generators_form --> core_parser
4 cross-module dependencies detected
CLI Reference
No CLI commands found in this project.
Module Overview
Detailed documentation for each module in the project:
fields (fields.ipynb)
Field component generators for different JSON Schema types.
Import
from cjm_fasthtml_jsonschema.components.fields import (
create_label,
create_description,
create_string_field,
create_enum_field,
create_number_field,
create_range_field,
create_boolean_field,
create_field
)
Functions
def create_label(
prop: SchemaProperty # SchemaProperty object
) -> FT: # Label component
"Create a label for a field."
def create_description(
prop: SchemaProperty # SchemaProperty object
) -> Optional[FT]: # P component with description or None
"Create a description/help text for a field."
def create_string_field(
prop: SchemaProperty, # SchemaProperty object
value: Any = None # Current value
) -> FT: # Div containing the field
"Create a string input field."
def create_enum_field(
prop: SchemaProperty, # SchemaProperty object
value: Any = None # Current value
) -> FT: # Div containing the field
"Create an enum select dropdown field."
def create_number_field(
prop: SchemaProperty, # SchemaProperty object
value: Any = None # Current value
) -> FT: # Div containing the field
"Create a number input field."
def create_range_field(
prop: SchemaProperty, # SchemaProperty object
value: Any = None # Current value
) -> FT: # Div containing the field
"Create a range slider field."
def create_boolean_field(
prop: SchemaProperty, # SchemaProperty object
value: Any = None # Current value
) -> FT: # Div containing the field
"Create a boolean toggle field."
def create_field(
prop: SchemaProperty, # SchemaProperty object
value: Any = None # Current value
) -> FT: # Div containing the field
"Create an appropriate field based on the property type."
form (form.ipynb)
Main form generator that creates UI from JSON Schema.
Import
from cjm_fasthtml_jsonschema.generators.form import (
generate_form_ui
)
Functions
def generate_form_ui(
schema: Dict[str, Any],
values: Optional[Dict[str, Any]] = None,
show_title: bool = True, # Whether to show the schema title
show_description: bool = True, # Whether to show schema description
compact: bool = False, # Use compact layout (less spacing)
card_wrapper: bool = True # Wrap the form in a card component
) -> FT
"Generate a FastHTML form UI from a JSON Schema."
parser (parser.ipynb)
JSON Schema parsing utilities.
Import
from cjm_fasthtml_jsonschema.core.parser import (
SchemaParser
)
Classes
class SchemaParser:
def __init__(
self,
schema: Dict[str, Any] # JSON Schema dictionary
)
"Parse JSON Schema and extract property information."
def __init__(
self,
schema: Dict[str, Any] # JSON Schema dictionary
)
"Initialize parser with a JSON Schema."
def get_property(
self,
name: str # Property name
) -> Optional[SchemaProperty]: # SchemaProperty object or None if not found
"Get a specific property by name."
def get_required_properties(
self
) -> List[SchemaProperty]: # TODO: Add return description
"Get all required properties."
def get_optional_properties(
self
) -> List[SchemaProperty]: # TODO: Add return description
"Get all optional properties."
types (types.ipynb)
Type definitions for JSON Schema elements.
Import
from cjm_fasthtml_jsonschema.core.types import (
SchemaProperty
)
Classes
@dataclass
class SchemaProperty:
"Represents a single property in a JSON Schema."
name: str
schema: Dict[str, Any]
required: bool = False
value: Any
def type(
self
) -> str: # TODO: Add return description
"Get the property type."
def is_nullable(
self
) -> bool: # TODO: Add return description
"Check if property allows null values."
def default(
self
) -> Any: # TODO: Add return description
"Get default value if specified."
def description(
self
) -> Optional[str]: # TODO: Add return description
"Get property description."
def enum_values(
self
) -> Optional[List[Any]]: # TODO: Add return description
"Get enum values if property is an enum."
def examples(
self
) -> Optional[List[Any]]: # TODO: Add return description
"Get example values if provided."
def minimum(
self
) -> Optional[Union[int, float]]: # TODO: Add return description
"Get minimum value for numeric types."
def maximum(
self
) -> Optional[Union[int, float]]: # TODO: Add return description
"Get maximum value for numeric types."
def min_length(
self
) -> Optional[int]: # TODO: Add return description
"Get minimum length for string types."
def max_length(
self
) -> Optional[int]: # TODO: Add return description
"Get maximum length for string types."
def pattern(
self
) -> Optional[str]: # TODO: Add return description
"Get regex pattern for string validation."
def format(
self
) -> Optional[str]: # TODO: Add return description
"Get format hint (e.g., 'email', 'uri', 'date')."
Project details
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file cjm_fasthtml_jsonschema-0.0.2.tar.gz.
File metadata
- Download URL: cjm_fasthtml_jsonschema-0.0.2.tar.gz
- Upload date:
- Size: 16.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
12d01faf1f971ea6046c2e2aec660d383ee7ae6c3bba5d14347ab9d19e40c15e
|
|
| MD5 |
b2aa6829efc6fb39f0e97cb09711a261
|
|
| BLAKE2b-256 |
6b02065a743b6edab6f61ab13199bf9d28e2a5e2f7b8e4929f093780b8928921
|
File details
Details for the file cjm_fasthtml_jsonschema-0.0.2-py3-none-any.whl.
File metadata
- Download URL: cjm_fasthtml_jsonschema-0.0.2-py3-none-any.whl
- Upload date:
- Size: 15.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
81c95ef5f8d586a36ecb82ff4f67d76e9adf176ff9145c2b4bc22a96a4ce8318
|
|
| MD5 |
ca09cc40a4f89c1598c95f3a7a927cee
|
|
| BLAKE2b-256 |
f2eff200ddc930ff38ae47196363bb865b6a4690535993783dda97a38fc089a7
|