Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

https://github.com/rio-labs/rio

WebApps in pure Python. No JavaScript, HTML and CSS needed
https://github.com/rio-labs/rio

data-analysis data-science data-visualization deep-learning machine-learning python ui webapp

Last synced: 11 days ago
JSON representation

WebApps in pure Python. No JavaScript, HTML and CSS needed

Lists

README

        


Rio Logo


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.


Rio
Version

Python Version
License
GitHub Stars
Downloads

![Image Generation Example](https://github.com/rio-labs/rio/assets/41641225/44279406-0c2d-47e2-98b5-4582722054b2)

## 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 ⌨️

```python
# Define a component that counts button clicks
class ButtonClicker(rio.Component):
# Define the attributes of the component. Rio will watch these
# for changes and automatically update the GUI.
clicks: int = 0

# Define a method that increments the click count. We'll later
# make a button that calls this method whenever it is pressed.
def _on_press(self) -> None:
self.clicks += 1

# Define the `build` method. This method essentially tells rio
# what a ButtonClicker component looks like. Whenever the state
# of the ButtonClicker component changes, rio will call its
# `build` method and update the GUI according to the output.
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)'),
)

# Create an App and tell it to display a ButtonClicker when it starts
app = rio.App(build=ButtonClicker)
app.run_in_browser() # Or `app.run_in_window()` to run as local app!
```

## Installation 🛠️

Rio is available on PyPI, so you can install it using pip:

```bash
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:

```bash
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:

```bash
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: In Development 🚧

Rio is still in development. We're working hard to bring you the best possible
experience. If you have any feedback, please let us know on [our Discord server](https://discord.gg/7ejXaPwhyH).

## 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](https://github.com/rio-labs/rio/blob/dev/CONTRIBUTING.md) 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!**

## Community Support 🫶

**Join the Rio adventure and be part of an awesome fellowship! Here is how to get in touch:**

- [Discord](https://discord.gg/7ejXaPwhyH) (Level up your Rio skills! **Join our Discord server** to chat with other developers and discuss how to contribute.)
- [GitHub](https://github.com/rio-labs/rio) (**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](https://github.com/rio-labs/rio/discussions) (**Join our community forum on Github** for asking questions and discussions)
- [Feature Requests](https://github.com/rio-labs/rio/discussions/categories/feature-requests) (Cleanest way to **request a feature** on GitHub)

For general help using Rio, please refer to the [official Rio documentation](https://rio.dev/docs?s=t9s).