Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(VideoManager): add "Continue watching" dialog #4389

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

kinhelm
Copy link

@kinhelm kinhelm commented Jan 7, 2025

First draft, feel free to suggest modifications

Changes
Adding a WatchTracker singleton to track watch time and watched episodes. It resets counts on user interaction

Issues
Request of #1327

@kinhelm kinhelm force-pushed the feature-still-watching branch from ca10a51 to 68a4669 Compare January 7, 2025 19:18
Copy link
Member

@nielsvanvelzen nielsvanvelzen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think this is a good start but some major changes would need to be made before I'll start reviewing it properly:

  • Don't modify translation files via GitHub, that should ALWAYS be done via our Weblate instance at translate.jellyfin.org
  • Don't use an object for the "WatchTracker", use dependency injection instead
  • Separate UI and logic
    • Preferably using a ViewModel
  • Don't use handlers, use proper coroutines instead

@kinhelm
Copy link
Author

kinhelm commented Jan 10, 2025

Hi Niels,
thanks for your review, I'll make those changes :)

@jellyfin-bot jellyfin-bot added the merge conflict Conflicts prevent merging label Jan 19, 2025
@ConnorS1110
Copy link
Contributor

@kinhelm Hi there. I realized that I have been working on implementing a similar feature as what you have here. Is this something you still plan on working on/want to work on? If not, your approach is much better organizationally that what I have so if you didn't want to continue working on it and are ok with me building on what you have, I don't mind trying to take it to the finish line.

@kinhelm
Copy link
Author

kinhelm commented Mar 16, 2025

Hi @ConnorS1110 I was in the process of addressing @nielsvanvelzen comments. I haven't finished yet, but I'm going to push my progress. It's no longer 100% functional, but of course, feel free to build on top of my code to complete this feature, like reset time on user actions :) Since I have a job on the side, I often lack time to make progress on it, but I'm always available to discuss it. :)
I'll rebase and fix conflict and push today

@kinhelm kinhelm force-pushed the feature-still-watching branch 2 times, most recently from e5e417f to 6af836f Compare March 16, 2025 11:30
@jellyfin-bot jellyfin-bot removed the merge conflict Conflicts prevent merging label Mar 16, 2025
@kinhelm kinhelm force-pushed the feature-still-watching branch from 6af836f to c08b05c Compare March 16, 2025 14:58
Adding a WatchTracker singleton to track watch time and watched episodes. It resets counts on user interaction
@kinhelm kinhelm force-pushed the feature-still-watching branch from c08b05c to 7b13da9 Compare March 16, 2025 15:10
@ConnorS1110
Copy link
Contributor

I managed to get this finished in my PR that is mentioned in the thread of this PR

Copy link
Member

@nielsvanvelzen nielsvanvelzen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We already have interaction tracking for our screensaver so I'd rather add a new "InteractionTracker" that will be used by both the screensaver and this feature.

We will not be adding popups during video playback, that's an anti-pattern. Instead, this feature should be implemented in the next-up screen: when a video item ends and we want to know if a user is still watching it will show a different screen that will behave similarly to the popup you currently have.

All new UI must be written in Compose.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants