Skip to main content

LazyFast = FastAPI + HTMX + Component-based approach + State management

Project description

LazyFast

LazyFast

PyPI - Version PyPI - Python Version PyPI - Downloads

LazyFast is a lightweight Python library for building modern, component-based web interfaces using FastAPI. It handles server-side logic in Python, with interactive elements like inputs and buttons triggering server-side component reloads for dynamic state updates.

Ideal for Python developers who:

  • Have basic HTML and CSS knowledge and want to build web interfaces without learning complex frontend frameworks like React, Angular, or Vue.

Suitable for projects that:

  • Have low to medium traffic and can benefit from server-side rendering to offload work from the client's machine. (Note: High traffic may increase server costs due to backend load.)
  • Require quick prototyping and demos without involving frontend developers. LazyFast offers more flexibility than tools like Streamlit, which can be limiting and produce similar-looking applications.

Key Features

  1. Component-Based Server Rendering
    • Build interfaces with lazy-loaded components that encapsulate logic, state, and presentation.
  2. Server-Side Logic
    • Manage interactions and state on the server, reducing client-side complexity.
  3. FastAPI Integration
    • Components and pages are FastAPI endpoints, supporting dependency injection and other features.
  4. Lightweight
    • Dependencies: FastAPI for Python and HTMX for JavaScript (included via CDN).
  5. State Management
    • Use a state manager to trigger component reloads for a reactive user experience.

Installation

To install LazyFast, use pip:

pip install lazyfast

or

poetry add lazyfast

Quick Start

Here's an example application to demonstrate how LazyFast works:

from fastapi import FastAPI, Request
from lazyfast import LazyFastRouter, Component, tags


# LazyFastRouter inherits from FastAPI's APIRouter
router = LazyFastRouter()

# Define a lazy-loaded HTML component powered by HTMX
@router.component()
class MyComponent(Component):
    title: str

    async def view(self, request: Request) -> None:
        tags.h1(self.title, class_="my-class")

        with tags.div(style="border: 1px solid black"):
            tags.span(request.headers)

# Initialize the page dependencies for component rendering
# The page endpoint is also a FastAPI endpoint
@router.page("/{name}")
def root(name: str):
    with tags.div(class_="container mt-6"):
        MyComponent(title=f"Hello, World from {name}")

# Embed the router in a FastAPI app
app = FastAPI()
app.include_router(router)

If you use uvicorn instead as a server and want to reload on changes, use the following command:

uvicorn app:app --reload --timeout-graceful-shutdown 1

Documentation

Documentation can be found here.

Examples

You can find examples in examples.

License

LazyFast is licensed under the MIT License.

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

lazyfast-0.1.29.tar.gz (18.1 kB view details)

Uploaded Source

Built Distribution

lazyfast-0.1.29-py3-none-any.whl (19.2 kB view details)

Uploaded Python 3

File details

Details for the file lazyfast-0.1.29.tar.gz.

File metadata

  • Download URL: lazyfast-0.1.29.tar.gz
  • Upload date:
  • Size: 18.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.6 Linux/5.15.153.1-microsoft-standard-WSL2

File hashes

Hashes for lazyfast-0.1.29.tar.gz
Algorithm Hash digest
SHA256 c16011b2ab0ad248cd9ebcbecc757cf363cc09d6bfa1630ce6dfeea6b5303aa8
MD5 9da2427f7a90cd962224568306a0bbc6
BLAKE2b-256 062640a449e9c8e1f78d04f4bbe2f6a8e65bb37bdb13fb62c340eda9b0d6ccff

See more details on using hashes here.

File details

Details for the file lazyfast-0.1.29-py3-none-any.whl.

File metadata

  • Download URL: lazyfast-0.1.29-py3-none-any.whl
  • Upload date:
  • Size: 19.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.3.2 CPython/3.10.6 Linux/5.15.153.1-microsoft-standard-WSL2

File hashes

Hashes for lazyfast-0.1.29-py3-none-any.whl
Algorithm Hash digest
SHA256 956aba1e1fa471e98b4968ba861c9ad4fef0b38f8a4b167bdb3b94e19b5f4740
MD5 e81f57043f91a1c3ab713500b58854a2
BLAKE2b-256 a9030fa076df06ceea35dc9dfc52eca7d71eff6adcc6a8ed87dc747ffb9a4fa7

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page