Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/birkankervan/todo-app
Todo app for your jobs
https://github.com/birkankervan/todo-app
mongodb nextjs react reactjs styled-components todo-app
Last synced: 13 days ago
JSON representation
Todo app for your jobs
- Host: GitHub
- URL: https://github.com/birkankervan/todo-app
- Owner: birkankervan
- Created: 2022-07-14T13:54:48.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-08-03T06:55:36.000Z (over 2 years ago)
- Last Synced: 2024-11-15T02:13:47.864Z (2 months ago)
- Topics: mongodb, nextjs, react, reactjs, styled-components, todo-app
- Language: TypeScript
- Homepage: https://todo-app-birk4n.vercel.app/
- Size: 84 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# ToDo App
### Purpose
Bu uygulama ile yapılacak işlerinizi kolaylıkla takip edebilirsiniz.
ToDo'larınızı `✅ Done` ve `❌ Not Yet` sekmelerinden takip edebilirsiniz. Yaptığınız Görevi işaretleyip günlük rutinlerinize devam edebilirsiniz.
MongoDB Bağlantısı sayesinde tüm cihazlarınızdan Chrome yardımı ile Görevlerinizi takip edebilirsiniz. Görevlerin yanında bulunan `🖍 (Kalem) ikonuna` tılayarak Görevi Düzenleyip Enter buttonu ile kayıt altına alabilirsiniz. `🗑 (Çöp Kutusu) ikonuna` tıklayarak da görevi silebilirsiniz.
Sağ üstte bulunan `Gece Modu` sayesinde karanlık ortamlarda rahatsız etmeden kullanabilirsiniz.### ⚡️ [Demo](https://todo-app-six-pearl.vercel.app/)
### Technical Explanation for App
### Used Libraries
Görevlerin DB ye kayıt edilmesinde [MongoDB](https://www.mongodb.com/) kullanılmıştır. MongoDB nin kullanılma sebebi hızlı ve kullanım kolaylığıdır. MongoDB ile verilerimize tüm alanlardan anlık olarak erişip üzerinde düzenlemeler yapabilmekteyiz.
Servis Tarafında [NextJS'in servisleri](https://nextjs.org/docs/api-routes/introduction) kullanılmıştır. Bundaki amaç tüm alanları tek bir yerden yönetip NextJS ekosistemini tam olarak kullanmaktır. Bu sayede verimli bir api ve DB bağlanma sistemi kurulabilmektedir. Express ile yapılabilecek çoğu şey NextJS in servis tarafıyla da yapılabilmektedir.
SSR tarafında [NextJS](https://nextjs.org/) kullanılmıştır. Fetch işlemleri client side da SWR kütüphanesi ile yapılmıştır. Bu sayede sayfa daha hızlı ekrana gelmektedir. Fetch işleminin server tarafında yapılmamasının sebebi SEO açısından önemi olmayan bir uygulama olduğu içindir. Ayrıca MongoDB nin ücretsiz versiyonunu kullandığım için sistem özellikleri yeterince güçlü değildir ve bazen DB sorguları geç gelebilmektedir.
Javascript Framework olarak [React](https://tr.reactjs.org/) kullanılmıştır. Yazım dili olarak da [Typescript](https://www.typescriptlang.org/) kullanılmıştır.
Fetch işlemleri için [SWR](https://swr.vercel.app/) ile birlikte [axios](https://github.com/axios/axios) kullanılmıştır. Bunun sebebi SWR nin çok tutarlı bir hook oluşudur. Bu hook sayesinde yapılan Fetch işleminde gelen response cache'e alınıp oradan componentlere servis edilebilmektedir. Bu sayede tekrar tekrar sorgu yapılamamktadır. Ayrıca yapılan sorgu sonucunu global bir state gibi tüm componentlere dağıtabilmekteyiz.
CSS tarafında [Styled-Components](https://styled-components.com/) kullanılmıştır. Styled Component ile kompenetlermize kolayca css yazabilmekteyiz. CSS ler komponentin içinde durduğu için daha düzenli bir kod yapısı bulunmaktadır. ayrıca tema özelliği sayesinde gece modu veya kullanıcıya özel temalar oluşturup projelerimizde çeşitlilik sağlayabiliriz. Styled-Components sayesinde kullanılmayan CSS minimuma iner ve tarayıcı uyumsuzluğunu büyük ölçüde çözer. Kendisi build anında diğer tarayıcılara göre düzenlemeler yapar. SSR tarafındada rahatlıkla kullanılabilir.
Gece Modu kullanımında global state olarak [local-storage](https://www.npmjs.com/package/use-local-storage-state) kullanılmıştır. Bir değişiklik olduğunda Styled-Components temada buna uygun değişiklik yapmaktadır.
Animasyon olarak [@formkit/auto-animate](https://auto-animate.formkit.com/) kullanılmıştır. Silinen görevlere veya eklenen görevlere animasyon eklenmiştir. Çok basit bir kullanımı vardır. Parent Elemana ref ekleyerek tüm componentlerde kullanabilmekteyiz.
### Contact Me 👨🏻💻