Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Spikeysanju/Einsen
π― Einsen is a prioritization app that uses Eisenhower matrix technique as workflow to prioritize a list of tasks & built to Demonstrate use of Jetpack Compose with Modern Android Architecture Components & MVVM Architecture.
https://github.com/Spikeysanju/Einsen
android android-architecture android-development android-ui coroutines-flow datastore-android declarative-ui hacktoberfest hilt-android jetpack-android jetpack-compose kotlin kotlin-coroutines mvvm-android room-database room-persistence-library stateflow ui-components ui-toolkit
Last synced: 3 months ago
JSON representation
π― Einsen is a prioritization app that uses Eisenhower matrix technique as workflow to prioritize a list of tasks & built to Demonstrate use of Jetpack Compose with Modern Android Architecture Components & MVVM Architecture.
- Host: GitHub
- URL: https://github.com/Spikeysanju/Einsen
- Owner: Spikeysanju
- License: apache-2.0
- Created: 2021-05-16T08:00:22.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2022-01-03T20:59:31.000Z (about 3 years ago)
- Last Synced: 2024-10-30T04:50:13.574Z (3 months ago)
- Topics: android, android-architecture, android-development, android-ui, coroutines-flow, datastore-android, declarative-ui, hacktoberfest, hilt-android, jetpack-android, jetpack-compose, kotlin, kotlin-coroutines, mvvm-android, room-database, room-persistence-library, stateflow, ui-components, ui-toolkit
- Language: Kotlin
- Homepage:
- Size: 4.33 MB
- Stars: 910
- Watchers: 9
- Forks: 78
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
![GitHub Cards Preview](https://github.com/Spikeysanju/Einsen/blob/master/art/einsen_cover.png?raw=true)
![Build (Android)](https://github.com/Spikeysanju/Einsen/workflows/Android%20CI/badge.svg)
[![GitHub license](https://img.shields.io/badge/License-Apache2.0-blue.svg)](LICENSE)
[![ktlint](https://img.shields.io/badge/code%20style-%E2%9D%A4-FF4081.svg)](https://ktlint.github.io/)![GitHub stars](https://img.shields.io/github/stars/SpikeySanju/Einsen?style=social)
![GitHub stars](https://img.shields.io/github/forks/SpikeySanju/Einsen?style=social)
![GitHub stars](https://img.shields.io/github/watchers/SpikeySanju/Einsen?style=social)
![GitHub follow](https://img.shields.io/github/followers/SpikeySanju?label=Follow&style=social)
![Twitter Follow](https://img.shields.io/twitter/follow/sanjay_spikey?label=Twitter&style=social)# π― Einsen
Einsen is a prioritization app that uses Eisenhower matrix technique as workflow to prioritize a list of tasks & built to Demonstrate use of Jetpack Compose with Modern Android Architecture Components & MVVM Architecture.
***Try latest Einsen app apk from below π***
[![Einsen](https://img.shields.io/badge/Einsen-APK-black.svg?style=for-the-badge&logo=android)](https://github.com/Spikeysanju/Einsen/releases/download/v1.0.0-alpha04/Einsen.apk)
## π¨ UI Design
***Click to View `Einsen` app Design from below π***
[![Einsen Figma Design](https://img.shields.io/badge/Einsen-FIGMA-black.svg?style=for-the-badge&logo=figma)](https://www.figma.com/file/s0jhjixtXtOZmmIyHIN3Yy/Einsen?node-id=0%3A1)
[![Einsen FigJam Design](https://img.shields.io/badge/Einsen-FIJAM-black.svg?style=for-the-badge&logo=figma)](https://www.figma.com/file/dbEZWjbmog9vYtsZx08fFM/Einsen)
## π Day Mode
| Dashboard | All Tasks | Task Details
|--- |--- |---
| ![](https://github.com/Spikeysanju/Einsen/blob/master/art/dashboard_day.png) | ![](https://github.com/Spikeysanju/Einsen/blob/master/art/all_task_day.png) | ![](https://github.com/Spikeysanju/Einsen/blob/master/art/task_details_day_v2.png)| Add Task | Emoji | Empty State |
|--- |--- |--- |
| ![](https://github.com/Spikeysanju/Einsen/blob/master/art/add_task_day.png) | ![](https://github.com/Spikeysanju/Einsen/blob/master/art/choose_emoji_day.png) | ![](https://github.com/Spikeysanju/Einsen/blob/master/art/empty_state_day.png)
## π We Support Dark Mode Too
| Dashboard | All Tasks | Task Details
|--- |--- |---
| ![](https://github.com/Spikeysanju/Einsen/blob/master/art/dashboard_night.png) | ![](https://github.com/Spikeysanju/Einsen/blob/master/art/all_task_night.png) | ![](https://github.com/Spikeysanju/Einsen/blob/master/art/task_details_night.png)| Add Task | Emoji | Empty State |
|--- |--- |--- |
| ![](https://github.com/Spikeysanju/Einsen/blob/master/art/add_task_night.png) | ![](https://github.com/Spikeysanju/Einsen/blob/master/art/choose_emoji_night.png) | ![](https://github.com/Spikeysanju/Einsen/blob/master/art/empty_state_night.png)
## π Built With
- [Kotlin](https://kotlinlang.org/) - First class and official programming language for Android
development.
- [Jetpack Compose](https://developer.android.com/jetpack/compose) - Jetpack Compose is Androidβs
modern toolkit for building native UI.
- [Coroutines](https://kotlinlang.org/docs/reference/coroutines-overview.html) - A coroutine is a
concurrency design pattern that you can use on Android to simplify code that executes
asynchronously.
- [Flow](https://kotlinlang.org/docs/reference/coroutines/flow.html) - A flow is an asynchronous
version of a Sequence, a type of collection whose values are lazily produced.
- [Jetpack DataStore](https://developer.android.com/topic/libraries/architecture/datastore) -
Jetpack DataStore is a data storage solution that allows you to store key-value pairs or typed
objects with protocol buffers. DataStore uses Kotlin coroutines and Flow to store data
asynchronously, consistently, and transactionally.
- [Android Architecture Components](https://developer.android.com/topic/libraries/architecture) -
Collection of libraries that help you design robust, testable, and maintainable apps.
- [Stateflow](https://developer.android.com/kotlin/flow/stateflow-and-sharedflow) - StateFlow is
a state-holder observable flow that emits the current and new state updates to its collectors.
- [Flow](https://kotlinlang.org/docs/reference/coroutines/flow.html) - A flow is an asynchronous
version of a Sequence, a type of collection whose values are lazily produced.
- [ViewModel](https://developer.android.com/topic/libraries/architecture/viewmodel) - Stores
UI-related data that isn"t destroyed on UI changes.
- [Jetpack Compose Navigation](https://developer.android.com/jetpack/compose/navigation) - The
Navigation component provides support for Jetpack Compose applications.
- [DataStore](https://developer.android.com/topic/libraries/architecture/datastore) - Jetpack
DataStore is a data storage solution that allows you to store key-value pairs or typed objects
with protocol buffers. DataStore uses Kotlin coroutines and Flow to store data asynchronously,
consistently, and transactionally.
- [Material Components for Android](https://github.com/material-components/material-components-android)
- Modular and customizable Material Design UI components for Android.
- [Accompanist](https://github.com/google/accompanist)
- A collection of extension libraries for Jetpack Compose.
- [Figma](https://figma.com/) - Figma is a vector graphics editor and prototyping tool which is
primarily web-based.
## π¦ Package Structure
```
dev.spikeysanju.einsen
βββ app # Application class
βββ components # All resuable components for this app
βββ data # For data handling
β βββ local # Local Persistence Database. Room (SQLite) database
β β βββ Dao # Data Access Object for Room
β β βββ Database # Database Instance
β βββ datastore
β βββ ThemePref # Datastore Theme Preference
βββ di # Hilt DI Modules
βββ model # Model class for [Task] & [Emoji]
βββ navigation # For navigation handling
β βββ Routes # All unique navigation routes of this app
β βββ NavGraph # Single source for Navigation Routes of this app
βββ repository # Used to handle all data operations
βββ ui.theme # Theme setup for this app
βββ utils # Extension functions
βββ view # All composables screens root folder
β βββ add # Add Task Screen
β βββ edit_task # Edit Task Screen
β βββ dashboard # Dashboard Screen
β βββ all_task # All Task Screen
β βββ task_details # Task Details Screen
β βββ emoji # Choose Emoji Screen
β βββ webview # WebView Screen
β βββ animation # Animation Placeholders for State handling(Loading, Error, Empty etc.)
β βββ about # About Screen
β βββ viewmodel # ViewModel
βββ MainActivity.kt # MainActivity```
## πΌ Architecture
This app uses [***MVVM (Model View
View-Model)***](https://developer.android.com/jetpack/docs/guide#recommended-app-arch) architecture.![](https://github.com/TheCodeMonks/Notes-App/blob/master/screenshots/ANDROID%20ROOM%20DB%20DIAGRAM.jpg)
## π§° Build-tool
You need to
have [Android Studio Beta 3 (BumbleBee) or above](https://developer.android.com/studio/preview) to
build this project.
## π¬ Frequently Asked Questions
When was project Einsen started?
> π― I started working on this idea 6 months before founding `Einsen app` (April 2021). The idea was exploring `mental models` + `productivity tips` to achieve your `goals`. I tried to test the idea with `Productivity` & `Time Management Trackers` . So I built `initial MVP`..
Where can I find the research process for Einsen app?
> π The biggest lesson I learned while designing this was that, I need to be `focused` & `working relentlessly` on the same project, to get the right flow of thought & complete it. Each `iteration` led to more `insights` on improving the design, `solving problems` for users. You can find the link for π Design Process [here](https://www.figma.com/file/dbEZWjbmog9vYtsZx08fFM/Einsen) & π¨ Figma Designs [here](https://www.figma.com/file/s0jhjixtXtOZmmIyHIN3Yy/Einsen?node-id=0%3A1)
What is the future goals of this project Einsen?
> π¦ For each week I will be implementing some new cool features for this application. Here are some of the amazing features you will come to expect from this platform :point_down:
- `Due Date` for each task
- `Recurring task`
- `Pomodoro timer` for each task
- `Task Template` as per user preference
- `Calendar` based task management
- `Project management`
- `Statistics` for completed task
- Introducing new `mental model templates` like Eisenhower
## π€ Contribute
If you want to contribute to this app, you're always welcome!
See [Contributing Guidelines](https://github.com/Spikeysanju/Einsen/blob/master/CONTRIBUTING.md).
## π© Contact
I know that first and foremost you are looking for a tool to solve your problems, but if you enjoy
it that much, why not tell us? We would love to hear from you πDM me at π
* Twitter: @spikeysanju
* Email: [email protected]
## β€οΈ Show your Support
I love it when people use my tool and weβd love to make it even better. If you like this tool and
want to support me in developing more free tools for you, Iβd really appreciate a donation. Feel
free to `buy me a cup of coffee` π. Thanks!
## π€ Credits
- π€ Icons are from [tablericons.com](https://tablericons.com)
## π License
```
Apache 2.0 LicenseCopyright 2021 Spikey sanju
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License athttp://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.```