Guidelines#
Thank you for your interest in contributing to Flet!
Clone repo#
Python SDK#
Install uv#
Windows#
Be sure to add %USERPROFILE%\AppData\Roaming\Python\Scripts to PATH.
macOS/Linux#
Open worker directory#
Install dependencies#
To install all Flet dependencies and enable the project as editable package run:
Check the installation#
Create hello.py file with a minimal Flet program:
import flet
from flet import Page, Text
def main(page: Page):
page.add(Text("Hello, world!"))
flet.app(target=main)
and then run it:
During the first run Flet Client (flet) executable will be downloaded from Flet GitHub releases to a user temp directory and then started from there. The version of release to download from is taken from flet/version.py file.
You should see a new native OS window opened with "Hello, world!" in it.
Running tests#
Pytest should be run with uv run:
Code formatting#
The project uses Black formatting style. All .py files in a PR must be black-formatted.
Install black extension for Visualtudio Code: https://marketplace.visualstudio.com/items?itemName=ms-python.black-formatter
IDE-specific Black integration guides:
Type checking#
Enable "pylance" type checking in VS Code.
Open user settings, search by "pylance", scroll down to Python > Analysis: Type checking mode section. Enable basic mode.
Sort imports on Save#
Install isort extension for imports formatting: https://marketplace.visualstudio.com/items?itemName=ms-python.isort
pre-commit#
pre-commit is a dev dependency of Flet and is automatically installed by uv sync.
To install the pre-commit hooks run: uv run pre-commit install.
Once installed, every time you commit, pre-commit will run the configured hooks against changed files.
Flutter client#
Add the FLET_VIEW_PATH and FLET_WEB_PATH variables to the environment variables or profile scripts for your respective OS, making sure to modify the path accordingly:
-
On macOS (in
~/.zprofileor any other profile script)*: -
On Windows (open "System Properties" > "Environment Variables", then add a new environment variable):
- as "Variable name", enter
FLET_VIEW_PATH, and as "Value",{path-to-flet}\flet\client\build\windows\x64\runner\Release -
as "Variable name", enter
FLET_WEB_PATH, and as "Value",{path-to-flet}\flet\client\build\web -
On Linux (in
~/.bash_profileor any other profile script)*:
If you have Microsoft Edge installed and want to use it for debugging Flutter apps:
If you added these through the terminal, close that terminal session and create a new one.
* if continuing in the same shell run source ~/.zprofile to activate variables in current session
Building the Flutter client#
Open an instance of your IDE (preferably VS Code) at the flet-dev/flet/client directory.
First, run printenv | grep FLET (or gci env:* | findstr FLET on Windows) in the built-in terminal to make sure everything is set. You should see the above environment variables you set (FLET_VIEW_PATH, FLET_WEB_PATH) printed out.
- To build the Flutter client for MacOS, run:
When the build is complete, you should see the Flet bundle in the
FLET_VIEW_PATH. (Running it will open a blank window.) - To build the Flutter client for Web, run the below command:
When the build is complete, a directory
client/build/webwill be created.
Running the Flutter client#
Now open another instance of VS Code at flet-dev/flet/sdk/python directory.
Create a new folder preferably named playground (it has been added to the gitignore) in which you will test your additions.
Try running the below command, where <your-main.py> is the file to test your additions:
<your-main.py> will automatically trigger a hot reload.
Now, switch to your flutter vscode instance and run the below command to start/connect the flet client:
then choose your device from the shown options. You will be able to see the debugging outputs of the flet client in this terminal.Restarting/Rebuilding#
- When you make changes to the flet dart files, you will need to restart/rerun the Flutter client for the changes to take effect in your playground. There are two ways to do this:
- fastest: press the keyboard button
Rwhile in the client's terminal (presshto see all other possible options); -
slowest: use
flutter runas seen previously. -
When you make changes to the flet python files, you will need to restart/rerun the Python client for the changes to take effect in the opened flutter applications. This is done with the same command:
Releasing Flet#
- Create a new
prepare-{version}branch in flet-dev/flet repository. - For every package in
packages/flet*directory: - Update package version to
{version}inpubspec.yaml. - Add
# {version}with new/changed/fixed items intoCHANGELOG.md. Onlypackages/flet/CHANGELOG.mdshould contain real items; other packages could have just a stub. - Copy
# {version}section frompackages/flet/CHANGELOG.mdto the rootCHANGELOG.md. - Open terminal in
clientdirectory and runflutter pub getto update Flet dependency versions inclient/pubspec.lock. - Create a new
{version}branch in flet-dev/flet-app-templates repository from a previously released{current-version}branch. - Create a new
{version}branch in flet-dev/flet-build-template repository from a previously released{current-version}branch. - Create
Prepare Flet {version}PR to merge intomainbranch. - In
Build Flet package for Flutterjob of Flet CI build make sure analysis report of everyflet*Flutter package has only 1 issue "Publishable packages can't have 'path' dependencies.". - Merge
Prepare Flet {version}PR. - Create and push new
v{version}tag (withvprefix). - Update release notes at
https://github.com/flet-dev/flet/releases/tag/v{version}.
New macOS environment for Flet developer#
- Homebrew: https://brew.sh/
After installing homebrew, install xz libraries with it:
- Pyenv. Install with
brew: https://github.com/pyenv/pyenv?tab=readme-ov-file#unixmacos - Install and switch to the latest Python 3.12:
Setup your shell environment: https://github.com/pyenv/pyenv#set-up-your-shell-environment-for-pyenv
echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.zprofile
echo '[[ -d $PYENV_ROOT/bin ]] && export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.zprofile
echo 'eval "$(pyenv init -)"' >> ~/.zprofile
Ensure Python version is 3.12.6 and location is /Users/{user}/.pyenv/shims/python:
- Rbenv. Install with
brew: https://github.com/rbenv/rbenv?tab=readme-ov-file#homebrew - Install and switch to the latest Ruby:
Ensure Ruby version is 3.3.5 and location is /Users/{user}/.rbenv/shims/ruby:
-
VS Code. Install "Apple silicon" release: https://code.visualstudio.com/download
-
GitHub Desktop: https://desktop.github.com/download/ Open GitHub Desktop app, install Rosetta.
After installing uv, set PATH:
Check uv version and make sure it's in PATH:
- Android Studio for Android SDK required by Flutter: https://developer.android.com/studio
- XCode for macOS and iOS SDKs: https://apps.apple.com/ca/app/xcode/id497799835?mt=12
- FVM - Flutter Version Manager: https://fvm.app/documentation/getting-started/installation Install flutter with fvm:
Set PATH: