SyncNote is a note-taking app built with Kotlin, where notes sync across all of the user’s devices so that their thoughts or notes are always with them.
- Organize notes by Date and Title
- Dark and Light Mode support
- Secured backup notes to SD storage
- Keep works on your phone, tablet, computer, and Android wearables. Everything you add syncs across all of your devices so your thoughts are always with you.
- Restore the deleted notes if done by mistake
- Support multiple notes deletion
- Grid View
- Search notes quickly and effortlessly
- Navigation Components
- Unit Testing, Firestore Testing and Espresso Testing
- Pagination
- RecyclerView layout state management persistence
- WorkManager
- Dagger2 Dependency Injection with Custom Scopes
- Coroutines
- Flows and Channels
- SQLite on Android with Room Persistence library
- SearchView with debounce
- Material Dialogs
- Sealed Class for state management and UI management
- Single Source of Truth Principal
- Message Handling system using STACK data structure
- Fragment Transistion Animations
- Collapsing Toolbar Layout
- ViewModels
- Handle Configuration Changes
- Handle Process Death issues
- Migrate from Dagger to Hilt
- Refactor message handling system to a Queue.
- Migrate from Shared Preferences to DataStore.
- Migrate from Koltin Synthetics to ViewBinding.
- Write Unit Test cases.
What | How |
---|---|
🎭 User Interface (Android) | Layouts |
🏗 Architecture | Clean |
💉 DI (Android) | Dagger |
🌊 Async | Coroutines + Flow |
🌐 Networking | Retrofit |
📄 Parsing | KotlinX |
👤 Rahul
- Email: [email protected]
Copyright 2021 Rahul Agarwal
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 at
https://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.