mirror of
https://github.com/revanced/revanced-manager.git
synced 2025-05-01 14:34:24 +02:00
39 lines
1.8 KiB
Markdown
39 lines
1.8 KiB
Markdown
# 💁 Overview
|
|
Take a quick peak of how ReVanced Compose work.
|
|
|
|
## ⚙️ Technology
|
|
We use [Jetpack Compose](https://developer.android.com/jetpack/compose) to
|
|
build beautiful and performant user interfaces using declarative programming.
|
|
It provides a unified and efficient way of building UI that is well-integrated with the Android framework.
|
|
|
|
## 📂 Structure
|
|
We structure our code to use [MVVM architecture](https://developer.android.com/topic/libraries/architecture/viewmodel) for easier maintenance of the code.
|
|
|
|
* **Model**: responsible for retrieving & storing data as well as performing calculations and other operations
|
|
* **View**: responsible for displaying the UI to the user, and send inputs to **ViewModel**
|
|
* **ViewModel**: responsible for receiving inputs from **View** and send it to **Model** then update the result
|
|
|
|
## 🧑💻 Code readability
|
|
In order to maintain readability of the code, It's highly recommend that you follow
|
|
https://developer.android.com/jetpack/compose/api-guidelines style guide to maintain
|
|
consistent style through out the codebase.
|
|
|
|
## 🎨 Design language
|
|
We adopt the [Material Design 3](https://m3.material.io) as our design language to
|
|
bring friendly, intuitive and colourful UI to our application ensuring that the
|
|
app's user interface is consistent, customizable, accessible, and engaging for our users.
|
|
|
|
## 📃 Commit message
|
|
At ReVanced, we follow the [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0)
|
|
format for our commit message.
|
|
|
|
`type`(**optional: scope**): message
|
|
|
|
Example:
|
|
* `feat`: translation settings
|
|
* `fix`(**settings**): NullPointerException when exporting logs
|
|
* `refactor`: optimize sub-optimal code
|
|
* `perf`(**api**): reduces network latency
|
|
* `docs`(**developer**): correct grammatical mistak
|
|
* `build`: bump version to v1.9.3
|