Skip to main content

An Electron-like library for Python using pywebview

Project description

Banner: pytron.png

Pytron

Pytron

Pytron is a modern framework for building desktop applications using Python for the backend and web technologies (React, Vite) for the frontend. It combines the power of Python's ecosystem with the rich user interfaces of the web.

Features

  • Type-Safe Bridge: Automatically generate TypeScript definitions (.d.ts) from your Python code.
  • Reactive State: Synchronize state seamlessly between Python and JavaScript.
  • Advanced Serialization: Built-in support for Pydantic models, PIL Images, UUIDs, and more.
  • System Integration: Native file dialogs, notifications, and shortcuts.
  • Developer Experience: Hot-reloading, automatic virtual environment management, and easy packaging.

Prerequisites

  • Python 3.7+
  • Node.js & npm (for frontend development)

Quick Start

  1. Install Pytron:

    pip install pytron-kit
    
  2. Initialize a New Project: This command scaffolds a new project, creates a virtual environment (env/), installs initial dependencies, and sets up a frontend.

    # Default (React + Vite)
    pytron init my_app
    
    # Using a specific template (vue, svelte, next, etc.)
    pytron init my_app --template next
    

    Supported templates: react (default), vue, svelte, next (Next.js), vanilla, preact, lit, solid, qwik.

  3. Install project dependencies (recommended): After cloning or when you need to install/update dependencies for the project, use the CLI-managed installer which will create/use the env/ virtual environment automatically:

    # Creates env/ if missing and installs from requirements.txt
    pytron install
    

    Notes:

    • This creates an env/ directory in the project root (if not already present) and runs pip install -r requirements.txt inside it.
    • All subsequent pytron commands (run, package, etc.) will automatically prefer the project's env/ Python when present.
  4. Run the App: Start the app in development mode (hot-reloading enabled). The CLI will use env/ Python automatically if an env/ exists in the project root.

    • Windows: run.bat
    • Linux/Mac: ./run.sh

    Or manually via the CLI:

    pytron run --dev
    

Core Concepts

1. Exposing Python Functions

Use the @app.expose decorator to make Python functions available to the frontend.

from pytron import App
from pydantic import BaseModel

app = App()

class User(BaseModel):
    name: str
    age: int

@app.expose
def get_user(user_id: int) -> User:
    return User(name="Alice", age=30)

app.generate_types() # Generates frontend/src/pytron.d.ts
app.run()

2. Calling from Frontend

Import the client and call your functions with full TypeScript support.

import pytron from 'pytron-client';

async function loadUser() {
    const user = await pytron.get_user(1);
    console.log(user.name); // Typed as string
}

3. Reactive State

Sync data automatically.

Python:

app.state.counter = 0

JavaScript:

console.log(pytron.state.counter); // 0

// Listen for changes
pytron.on('pytron:state-update', (change) => {
    console.log(change.key, change.value);
});

4. Window Management

Control the window directly from JS.

pytron.minimize();
pytron.toggle_fullscreen();
pytron.close();

Configuration (settings.json)

Pytron uses a settings.json file in your project root to manage application configuration. This keeps your code clean and separates config from logic.

Example settings.json:

{
    "title": "My Awesome App",
    "pytron_version": "0.1.5",
    "frontend_framework": "react",
    "width": 1024,
    "height": 768,
    "resizable": true,
    "frameless": false,
    "easy_drag": true,
    "url": "frontend/dist/index.html",
    "icon": "assets/icon.ico",
    "version": "1.0.0"
}
  • title: The window title and the name of your packaged executable.
  • pytron_version: The version of Pytron used to create the project (used for compatibility checks).
  • frontend_framework: The framework used (e.g., "react", "next").
  • icon: Path to your application icon (relative to project root). Supports .ico (preferred) or .png.
  • url: Entry point for the frontend (usually the built index.html).
  • width/height: Initial window dimensions.

Packaging

Distribute your app as a standalone executable. Pytron automatically reads your settings.json to determine the app name, version, and icon.

  1. Build:

    pytron package
    

    This uses PyInstaller to bundle your app. It will:

    • Use the title from settings.json for the executable name.
    • Use the icon from settings.json for the app icon.
    • Automatically exclude node_modules.
    • Include your settings.json and frontend assets.
  2. Create Installer (NSIS):

    pytron package --installer
    

CLI Reference

  • pytron init <name> [--template <name>]: Create a new project.
    • --template: Frontend framework to use (default: react). Supports next, vue, svelte, etc.
  • pytron install: Create/use project env/ and install dependencies from requirements.txt.
  • pytron run [--dev]: Run the application.
  • pytron package [--installer]: Build for distribution (uses settings.json).
  • pytron info: Show environment and project details.
  • pytron build-frontend <folder>: Build the frontend app.

Happy Coding with Pytron!

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

pytron_kit-0.2.0.tar.gz (1.7 MB view details)

Uploaded Source

Built Distribution

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

pytron_kit-0.2.0-py3-none-any.whl (1.7 MB view details)

Uploaded Python 3

File details

Details for the file pytron_kit-0.2.0.tar.gz.

File metadata

  • Download URL: pytron_kit-0.2.0.tar.gz
  • Upload date:
  • Size: 1.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pytron_kit-0.2.0.tar.gz
Algorithm Hash digest
SHA256 dea507e38f3ce72b8ba61bbab4bc1a7c66d1dfdb9200e7038435a8c4edbb9c7e
MD5 885559ef698a490ab9dc9d170716bb37
BLAKE2b-256 82a576a76c03e59ef88697c119fd1f4ea0c91d5d98d3b2021666aae93027335d

See more details on using hashes here.

File details

Details for the file pytron_kit-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: pytron_kit-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 1.7 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pytron_kit-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ce6c9435f4e9b6f0666b303fefe051e92c28e366bbd16ede29215e2bd3c3bec3
MD5 b5be5d85cbd7c4d7af7d962e24e6945a
BLAKE2b-256 bf6a76dce908835cf1949b141d2f535f2e87cc0d18c207abd885ab0ebf0dbbff

See more details on using hashes here.

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