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

🎶 Media Bridge, with audio sync 🎶 #48

Merged
merged 47 commits into from
Mar 15, 2024

Conversation

rtshkmr
Copy link
Member

@rtshkmr rtshkmr commented Feb 28, 2024

status: ready for review

Unpolised PR that does the following:

  1. restrict media lib to only concern itself with playback state (generic), create separate aud components

in an effort to keep PRs small, and also to get a quicker sanity-check, I'm going to publish this PR so that this can get your eyes on it @KosmonautX

how to test

exact same functionalities as before, should work the same without issues.

@rtshkmr rtshkmr self-assigned this Feb 28, 2024
@rtshkmr rtshkmr marked this pull request as draft February 28, 2024 00:27
@rtshkmr rtshkmr marked this pull request as ready for review February 28, 2024 06:21
@rtshkmr rtshkmr requested a review from ks0m1c February 28, 2024 06:21
@rtshkmr rtshkmr changed the title 🎶 [WIP] Media Bridge, with audio / video sync 🎶 🎶 Media Bridge, with audio sync 🎶 Feb 28, 2024
const {
detail,
} = e
const [key, val, extraKey] = detail?.payload
Copy link
Member Author

Choose a reason for hiding this comment

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

todo: add guard instead of doing a tuple de-structure here because if detail?.payload is null or undefined, the iterator used for destructuring will throw a type exception

rtshkmr and others added 16 commits March 1, 2024 21:06
throwback to the previous issue where we had the audio timestamp change when we
used the audio player to seek to something.

this is the cause for aud and video going out of sync

immediate next steps:
1. cleanup and ensure the data flow is happening correctly i.e. event
emitters and listeners need to have correct reponsibilities
2. Key UI changes -- let the video player be a miniplayer anchored to
the currently emphasised event...
There seems to be 2 options:
1. using sticky w.r.t vh
2. using this inset

seems like 1 won't work because different liveview components get
rendered in different parent containers, and in 1, v is w.r.t to it's
specific parent.
The joy from this is amazing...
quick rundown of how multiple theming can be done:
1. app.css defines css vars e.g. --color-brand-accent
2. tailwind config uses css vars e.g. colorBrandAccent
3. css vars can be programmatically changed

ref example tldr by phind: https://www.phind.com/search?cache=zjy65pla8499wua9on23rjof
This is not entirely complete, some quirks exist, but it is intended to
represent how a topic-specific events bridge can be used.
rtshkmr and others added 12 commits March 5, 2024 21:52
TLDR;
1. there are 2 initiators:
    - initiated when progress bar is clicked
    - initiated when verse is clicked ==> media_bridge.ex server issues seekTime
2. we can categorise events based on emitters / producers or consumers.
3. consumers generally consume events and generally only have internal
actions they carry out
4. sometimes, consumers may have external actions they carry out as
well. For example, if MediaBridge hook gets a server-initiated request
to seekTime, then it shall carry out internal actions (i.e. seekToS, as
well as pub the seekTimePayload to others via the seekTimeBridge)
This has some bugs, but the overall pattern should be correct.

Also pending cleanups
@ks0m1c ks0m1c changed the base branch from chore/player-improvements to feature/hanuman March 8, 2024 02:07
@ks0m1c
Copy link
Contributor

ks0m1c commented Mar 8, 2024

Loose ends

@rtshkmr rtshkmr merged commit 417eaf7 into feature/hanuman Mar 15, 2024
2 checks passed
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.

2 participants