Rio is an easy to use framework for creating websites and apps and is based entirely on Python. 🐍
You won't need a single line of HTML, CSS, or
JavaScript to create beautiful, modern apps.
Tutorial - Examples - Discord - Docs - Source Code
Rio brings React-style components to Python. Pull from a wealth of built-in
components and combine them to create your own custom components. Then combine
those into entire apps. Best of all, Rio apps can run both locally on your
machine and on the web.
Features 🧩
- Modern, declarative UI framework
- 100% Python - Zero HTML, CSS, or JavaScript required
- Over 50 Built-in components for common UI elements, such as
rio.Switch
, rio.Button
, and rio.Text
, and many more - Integrates with modern Python tooling: Thanks to being entirely Type Safe editors can give you instant suggestions and highlight problems right away
- Apps can run both locally and on the web
- Dev tools included
- Open Source & Free forever
Example ⌨️
class ButtonClicker(rio.Component):
clicks: int = 0
def _on_press(self) -> None:
self.clicks += 1
def build(self) -> rio.Component:
return rio.Column(
rio.Button('Click me', on_press=self._on_press),
rio.Text(f'You clicked the button {self.clicks} time(s)'),
)
app = rio.App(build=ButtonClicker)
app.run_in_browser()
Installation 🛠️
Rio is available on PyPI, so you can install it using pip:
pip install rio-ui
Getting Started 🎓
Rio comes with a very helpful command line utility to help you out. Create a new
project in one short command:
rio new
You can choose from a variety of built-in templates to get you started. Here's a
complete example to create a project based on the tic-tac-toe template:
rio new my-project --type website --template "Tic-Tac-Toe"
cd my-project
rio run
You'll have your first app up and running in seconds!
Status: Beta 🚧
Rio is rapidly approaching its first stable release. Version 0.10 incorporates
all planned breaking changes. Minor changes may still occur, but we are
actively trying to avoid them.
If you encounter any issues or would like to provide feedback, please let us
know on our Discord server.
1.0 is expected later this year.
Contributing 🤝
Every project thrives with a helping hand, and that's especially true for
Rio. There are lots of ways to jump in, like adding new features, fixing
bugs, or just sharing your ideas. Check out our Contributing
Guide when submitting
a Pull Request to the project. Rio keeps getting better with new features
rolling out every week. Star ⭐ and 👀 watch this repo to stay in the loop!
Unless you explicitly state otherwise, any contribution submitted for inclusion
in Rio shall be licensed under the terms of the Apache-2.0 license, without any
additional terms or conditions.
Join the Rio adventure and be part of an awesome fellowship! Here is how to get in touch:
- Discord (Level up your Rio skills! Join our Discord server to chat with other developers and discuss how to contribute.)
- GitHub (Spot a bug? Issues are the perfect place to let us know. Feeling super-helpful? Try fixing an existing issue and submit a PR!)
- Community Forum (Join our community forum on Github for asking questions and discussions)
- Feature Requests (Cleanest way to request a feature on GitHub)
For general help using Rio, please refer to the official Rio documentation.