Skip to main content

Serve React components from Python backends

Project description

wilco

Server-defined React components for Python backends.

PyPI version Python versions CI Documentation License

Documentation: FastAPI Guide | Django Guide | Starlette Guide

Features

  • Co-locate components with backend logic — Keep UI components next to the Python code that powers them
  • No frontend build pipeline — Components bundled on-the-fly with esbuild when requested
  • Full source map support — Debug TypeScript directly in browser devtools
  • Component composition — Components can dynamically load other components
  • Framework agnostic — Works with FastAPI, Django, Starlette, or any ASGI-compatible framework

Quick Start

pip install wilco[fastapi]  # or wilco[django] or wilco[starlette]

Create a component

my_components/
└── greeting/
    ├── __init__.py
    ├── index.tsx
    └── schema.json
// index.tsx
interface GreetingProps {
  name: string;
  formal?: boolean;
}

export default function Greeting({ name, formal = false }: GreetingProps) {
  const message = formal ? `Good day, ${name}.` : `Hey ${name}!`;
  return <p>{message}</p>;
}

Mount the API

from pathlib import Path
from fastapi import FastAPI
from wilco import ComponentRegistry
from wilco.bridges.fastapi import create_router

app = FastAPI()
registry = ComponentRegistry(Path("./my_components"))
app.include_router(create_router(registry), prefix="/api")

Load in React

import { useComponent } from '@wilcojs/react';

function App() {
  const Greeting = useComponent('greeting');
  return <Greeting name="World" />;
}

For component schemas, composition patterns, and framework-specific guides, see the documentation.

API Endpoints

Endpoint Description
GET /api/bundles List available components
GET /api/bundles/{name}.js Get bundled JavaScript
GET /api/bundles/{name}/metadata Get component metadata

Requirements

  • Python 3.10+
  • Node.js (for esbuild bundling)
  • React 18+ on the frontend

Development

This project follows strict TDD methodology.

make test    # Run all tests
make docs    # Build documentation
make help    # Show all available commands

License

Makersquad Source License 1.0 — see LICENSE.md for details.

Free for non-commercial use. Commercial use requires a license. Contact licensing@makersquad.fr for inquiries.

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

wilco-0.3.0.tar.gz (1.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

wilco-0.3.0-py3-none-any.whl (102.6 kB view details)

Uploaded Python 3

File details

Details for the file wilco-0.3.0.tar.gz.

File metadata

  • Download URL: wilco-0.3.0.tar.gz
  • Upload date:
  • Size: 1.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for wilco-0.3.0.tar.gz
Algorithm Hash digest
SHA256 53c382ae9538fa1b2200cbb95352527d9a59501fc2f3fcc5aa16591304cfa586
MD5 0ddc06095926412da241daf5388332f7
BLAKE2b-256 90f19c5481d1418277bef3fee0834ca469064b3fd966a453747f5ae139361ef8

See more details on using hashes here.

Provenance

The following attestation bundles were made for wilco-0.3.0.tar.gz:

Publisher: cicd.yml on msqd/wilco

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file wilco-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: wilco-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 102.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for wilco-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e5e85302b738a6c44476f1b263f839d5919453238df3e226452ac15c26984a56
MD5 1a3809bdd35f76d053052adfeff7f07d
BLAKE2b-256 e2fffcbd3b86d698e40a30f16d2ebeaf06020fd9b00b01677332d35c781a9ca8

See more details on using hashes here.

Provenance

The following attestation bundles were made for wilco-0.3.0-py3-none-any.whl:

Publisher: cicd.yml on msqd/wilco

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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