Metadata-Version: 2.1
Name: flask-vite
Version: 0.6.1
Summary: Flask+Vite integration.
Author-Email: Abilian SAS <contact@abilian.com>
Classifier: Development Status :: 3 - Alpha
Classifier: Intended Audience :: Developers
Classifier: Natural Language :: English
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Project-URL: homepage, https://github.com/abilian/flask-vite
Requires-Python: <4.0,>=3.9
Requires-Dist: flask>2
Description-Content-Type: text/markdown

# Flask-Vite

[![image](https://img.shields.io/pypi/v/flask-tailwind.svg)](https://pypi.python.org/pypi/flask-tailwind)

A Flask extension that simplifies integration with Vite (a modern frontend build tool).

-   Status: Bêta.
-   Free software: MIT license

Flask-Vite bridges the gap between Flask's backend capabilities and modern frontend development tools. It allows you to:

- **Use Modern Tools**: Leverage Vite's fast development server and optimized builds
- **Keep It Simple**: Maintain Flask's simplicity while using cutting-edge frontend tools  
- **Seamless Integration**: Automatic asset injection and serving with minimal configuration
- **Development & Production**: Different behaviors for development (hot reload) and production (optimized assets)

## Key Features

### 🚀 **Fast Development**
- Hot module replacement via Vite dev server
- Instant feedback on frontend changes
- TypeScript, JSX, and modern CSS support

### 🔧 **Simple Configuration**
- Minimal setup required
- Automatic asset discovery and injection
- Flask CLI integration for common tasks

### 🏗️ **Production Ready**  
- Optimized builds with code splitting
- Asset fingerprinting for caching
- CDN-friendly asset serving

### 🌐 **Framework Agnostic**
- Works with vanilla JavaScript, React, Vue, Svelte
- Supports any Vite-compatible framework
- TailwindCSS integration example included


## Usage

Instantiate the Flask extension as you do for other Flask extensions:

```python
from flask_vite import Vite

app = Flask(...)
vite = Vite(app)

# or
vite = Vite()
vite.init_app(app)
```

Then you can use the following commands:

```text
$ flask vite
Usage: flask vite [OPTIONS] COMMAND [ARGS]...

Perform Vite operations.

Options:
--help  Show this message and exit.

Commands:
build          Build the Vite assets.
check-updates  Check outdated Vite dependencies.
init           Init the vite/ directory (if it doesn't exist)
install        Install the dependencies using npm.
start          Start watching source changes for dev.
update         Update Vite and its dependencies, if needed.
```

## Example Workflow
This section assumes you have already added Flask-Vite to your Flask app with the steps above.

### Step 1: Initialize your /vite subdirectory
```text
# First, create the /vite subdirectory in your Flask app's root folder
$ flask vite init

# Install any dependencies
$ flask vite install
```

### Step 2: Now you are ready to begin development
```text
# Start a local Vite dev server.
# This will hot-reload any changes in the /vite subdirectory, so it's suited for local development.
$ flask vite start

# Make any changes in vite/main.js, such as importing React/Vue components.
# Flask-Vite assumes you have a single entry point at vite/main.js, such as a React SPA (single page application).
```

**You should now be able to see any changes you have made in your Flask app. If not, try [Troubleshooting](#troubleshooting).**

### Step 3: Ready for production
Once you are ready for production, you need to build your assets.
```text
# Build assets based on /vite/vite.config.js
$ flask vite build
```

You should now see files like `/vite/dist/assets/index-f16ca036.js`.

**If you are running your Flask app in production mode (ie _without_ app.debug), you should see these asset files included in your Flask Jinja templates automatically. If not, try [Troubleshooting](#troubleshooting).**

## Features

- Manages a `vite` directory where you put your front-end source code.
- Auto-injects vite-generated assets into your HTML pages (if `VITE_AUTO_INSERT` is set in the Flask config).
- Use `{{ vite_tags() }}` in your Jinja templates otherwise.
- If you run Flask in `host_matching` mode, you can tell Vite which host to mount its own views on. You can configure this when instantiating Vite or when calling `init_app`:
  - Pass `vite_routes_host` the specific single host to serve its assets from.
  - Pass `vite_routes_host` as the wildcard value `*` to serve vite assets from the same domain as the current request.


## Configuration

The following (Flask) configuration variables are available:

- `VITE_AUTO_INSERT`: if set, the extension will auto-insert the Vite assets into your HTML pages.
- `VITE_NPM_BIN_PATH`: path to the `npm` binary. Defaults to `npm`.
- `VITE_FOLDER_PATH`: path for the vite project. Defaults to `vite` locally.


## Demo

See the `demo/` directory for a working demo using TailwindCSS.

## Architecture

Flask-Vite works differently in development and production:

### Development Mode
```
┌─────────────┐    ┌─────────────┐
│ Flask App   │    │ Vite Server │
│ :5000       │    │ :3000       │
│             │    │             │
│ {{ vite_    │───▶│ Hot Reload  │
│    tags() }}│    │ Assets      │
└─────────────┘    └─────────────┘
```

### Production Mode  
```
┌─────────────┐
│ Flask App   │
│ :5000       │
│             │
│ {{ vite_    │───▶ Built Assets
│    tags() }}│    in /dist
└─────────────┘
```

## Project Structure

A typical Flask-Vite project looks like:

```
my-flask-app/
├── app.py                 # Flask application
├── templates/             # Jinja2 templates
│   └── index.html         # Uses {{ vite_tags() }}
├── vite/                  # Frontend source
│   ├── package.json       # Node dependencies
│   ├── vite.config.js     # Vite configuration
│   ├── main.js            # Entry point
│   ├── src/               # Source files
│   └── dist/              # Built assets (production)
└── requirements.txt       # Python dependencies
```

## Documentation

### 📖 [User Guide](docs/user-guide.md)
Complete guide for using Flask-Vite in your applications, including installation, configuration, development workflow, and troubleshooting.

### 🔧 [Developer Guide](docs/developer-guide.md) 
In-depth guide for contributing to Flask-Vite development, including architecture overview, testing, and contribution guidelines.

### 📚 [API Reference](docs/api-reference.md)
Complete API documentation with all classes, methods, configuration options, and CLI commands.

## Quick Links

### Getting Started
- [Installation](docs/user-guide.md#installation)
- [Quick Start](docs/user-guide.md#quick-start)
- [Configuration](docs/user-guide.md#configuration)

### Examples
- [TailwindCSS Integration](docs/user-guide.md#example-1-tailwindcss-integration)
- [Vue.js SPA](docs/user-guide.md#example-2-vuejs-single-page-application)
- [Demo Application](demo/)

## Troubleshooting

### I can't see my vite output files (eg React/Vue components) in my Jinja templates
- Flask-Vite will automatically add these files to your templates if you either:
  - set `VITE_AUTO_INSERT=True` in your Flask config
  - OR, explicitly include `{{ vite_tags() }}` somewhere in your Jinja templates

Either of these options will insert &lt;script&gt; tags into your Jinja templates, which will be the output of your vite config.

### Script tags are included in my Jinja templates, but they're not loading
- If your Flask app is running in debug mode (ie app.debug):
  - your HTML should have a line like `<script type="module" src="http://localhost:3000/main.js"></script>`
  - If this file isn't loading it's because your local Vite dev server isn't running. Start it by using `flask vite start`
- If your Flask app is running in production mode (ie _not_ app.debug):
  - your HTML should have a line like `<script type="module" src="/_vite/index-f16ca036.js"></script>` (the hash in `index-[hash].js` will change every time)
  - you should find this file in `/vite/dist/assets/index-f16ca036.js`. If not, you can build for production again using `flask vite build`


## Support and Community

- **GitHub Repository**: [abilian/flask-vite](https://github.com/abilian/flask-vite)
- **Issues**: Report bugs and request features on GitHub
- **License**: MIT License

## Contributing

We welcome contributions! See the [Developer Guide](docs/developer-guide.md) for:

- Development setup instructions
- Code style guidelines  
- Testing procedures
- Pull request process

## Credits

This project is inspired by the
[Django-Tailwind](https://github.com/timonweb/django-tailwind) project and was previously known as `Flask-Tailwind`.

This package was created with
[Cookiecutter](https://github.com/audreyr/cookiecutter), using the
[abilian/cookiecutter-abilian-python](https://github.com/abilian/cookiecutter-abilian-python)
project template.
