Skip to content

Tv-Maniac is a personalized entertainment tracking and recommendation Multiplatform app (Android & iOS) for tracking TV Shows using Trakt.

License

Notifications You must be signed in to change notification settings

misshannah/tv-maniac

 
 

Repository files navigation

TvManiac

Check android ios TvManiac Debug

TvManiac is a personalized entertainment tracking and recommendation Multiplatform app. By utilizing Trakt, we can view shows, create a watchlist get statistics, and much more. This project aims to demonstrate KMP development capabilities. This is currently running on:

  • Android: Compose
  • iOS: SwiftUI

🚧 Under Heavy Development 🚧

This is my playground for learning Kotlin Multiplatform. With that said, I'm sure it's filled with bugs crawling everywhere, and I'm probably doing a couple of things wrong. So a lot is changing, but that shouldn't stop you from checking it out.

Android iOS
screen-20230308-001558.mp4
iOSTvManiacDemo.mp4

🖥 Project Setup & Environment

Requirements

API Keys

To use the Trakt API, you'll need to create a new API app. & for TMDb, create an account and generate an API key if you don't have one. Once you have your keys, add them to config.yaml. If the file is unavailable, navigate to the root dir and create a symlink.

ln -s core/util/src/commonMain/resources/config.yaml config.yaml

tmdbApiKey: "PUT_API_KEY_HERE"
traktClientId: "PUT_CLIENT_ID_HERE"
traktClientSecret: "PUT_CLIENT_SECRET_HERE"
traktRedirectUri: "PUT_CALLBACK_URI_HERE"

Opening iOS Project

  • Navigate to the ios directory & open .xcodeproj

Android Screenshots

Home Screen Light

Home Screen Light

Episodes List Light

Show Details Dark

Show Details Dark

Episodes List Dark

🔆 iOS Screenshots

Home Screen Light

Home Screen Light

Home Screen Dark

Show Details Dark

Libraries Used

Android

Kmp - Common

iOS

Roadmap

Android

  • Implement Watchlist
  • Add More screen. Shows GridView
  • Recommended Shows
  • Implement pagination.
  • Add Settings panel.
    • Dynamic theme change.
  • Add Seasons UI
  • Implement trakt auth & sign in
  • Migrate to Material3
  • Add Episode detail screen
  • Add Watchlist
  • Implement Search

iOS

  • Add HomeScreen: Tabs & Empty UI
  • Implement Discover UI
  • Show Detail Screen
  • Add Settings panel.
  • Implement trakt auth & sign in
  • Add Seasons UI
  • Implement Search UI
  • Implement Watchlist UI

Shared

  • Use SQLDelight extensions to consume queries as Flow
  • Refactor interactor implementation.
  • Use koin for injection
  • Modularize shared module
  • Try out Flow-Redux
  • Improve error handling.
  • Fix paging
  • Add test cases.

References

License

Copyright 2021 Thomas Kioko

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.

About

Tv-Maniac is a personalized entertainment tracking and recommendation Multiplatform app (Android & iOS) for tracking TV Shows using Trakt.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Kotlin 88.3%
  • Swift 11.7%