diff --git a/README.md b/README.md index 4d750f36..99c1a4ef 100644 --- a/README.md +++ b/README.md @@ -9,12 +9,17 @@ It shows today's and this week's menu, opening hours, contacts, announcements an Core parts are written in Kotlin Multiplatform, support for JVM target can be added right away. Other targets require more work (non-JVM web scraping library required), but it still may be manageable for somebody to port this codebase to native or js platforms. +See **contributing** below. + ##### What does 'Menza' mean? Menza is the Czech word for school cafeteria. [Now on Google Play](https://play.google.com/store/apps/details?id=cz.lastaapps.menza&utm_source=github)[Get it on F-Droid](https://f-droid.org/packages/cz.lastaapps.menza) +## Related projects +- [Menza CLI (LastaApps)](https://github.com/Lastaapps/menza-cli) +- [Menza BE (LastaApps)](https://github.com/Lastaapps/menza-backend) ## Libraries @@ -46,10 +51,6 @@ The core of the all in written in Kotlin Multiplatform! - No private data collection - Proper landscape mode and large screen device support -## Future plans -- [ ] Rating support -- [ ] User account balance support - ## Screenshots @@ -67,9 +68,51 @@ The core of the all in written in Kotlin Multiplatform! -#### Contributing - -Feel free to contribute, but ask me before so we don't do the same thing twice. +#### Contributing and project structure + +Feel free to contribute, but **contact me before please**, so we don't do the same thing twice. +If you are new to Kotlin/Android, you can write the code yourself, +and I'll adjust it to the rules below. +So it's fine to write it *wrong* (different), +but don't be surprised when I rewrite it. + +Most of the modules are multiplatform, and you should respect it. +That means write as much code as possible into the common code and +if there is no (nice) way to implement feature in a multiplatform manner, +this is the time when you can use platform specific package. +Even in that case put at least an interface into the common code +and tie it using DI (preferred over `expected`/`actual` keywords). + +The whole app tries to respect clean architecture principles +and MVVM architecture. There is also domain layer presented (use cases). +The whole app is tied together using DI. + +##### Structure +- `api/core` - core classes for network communication, store, synchronization, ... +- `api/agata`, `api/buffet` - implementation for individual canteen provider +- `api/main` - packs all the providers into one interface, contains related business logic +- `app` - only UI related code, purely Android (for now) + - `features` - stores all the UI code + - `root` - decides if the user is already logged in + - `starting` - stores setup related code + - `main` - holds main user interface (after login), drawer, top/bottom bar, core navigation + - `today` - the main screen, shows today canteen offering + - `week` - shows week canteen offering + - `info` - shows canteen info + - `panels` - panels for the today screen (rate us, report a crash, what's new, ...) + - `settings` - self-explanatory, includes about screen + - `others` - privacy policy, library notices, ošťurák, ... +- `core` - holds main shared domain logic and templates + - `Outcome` - like Rust's `Result`, success or `DomainError`. + all the functions that can fail should return `Outcome`. + - `UseCase` - base usecase class + - `BaseViewmodel` - parent of all the ViewModels +- `lastaapps` - my legacy common shared code (+ crash reporting) + +##### Other modules are **deprecated** and should **not** be used/edited +Namely, modules `entity`, `html-parser`, `scraping` and `storage`. +They were used by the first version of menza and are kept for future in case +I lost access to the API. #### Data sources