Full overhawl of video & audio playback to make it more complete (#1432)
* Add support for capturing media attributes in rrweb-snapshot * Add loop to mediaInteractionParam * Add support for loop in RRMediaElement * Add support for recording loop attribute on media elements * Update video playback and fix bugs * Update cross-origin iframe media attributes and player state
This commit is contained in:
@@ -12,6 +12,7 @@ import {
|
||||
ICanvas,
|
||||
elementNode,
|
||||
serializedElementNodeWithId,
|
||||
type mediaAttributes,
|
||||
} from './types';
|
||||
import {
|
||||
Mirror,
|
||||
@@ -761,10 +762,15 @@ function serializeElementNode(
|
||||
}
|
||||
// media elements
|
||||
if (tagName === 'audio' || tagName === 'video') {
|
||||
attributes.rr_mediaState = (n as HTMLMediaElement).paused
|
||||
const mediaAttributes = attributes as mediaAttributes;
|
||||
mediaAttributes.rr_mediaState = (n as HTMLMediaElement).paused
|
||||
? 'paused'
|
||||
: 'played';
|
||||
attributes.rr_mediaCurrentTime = (n as HTMLMediaElement).currentTime;
|
||||
mediaAttributes.rr_mediaCurrentTime = (n as HTMLMediaElement).currentTime;
|
||||
mediaAttributes.rr_mediaPlaybackRate = (n as HTMLMediaElement).playbackRate;
|
||||
mediaAttributes.rr_mediaMuted = (n as HTMLMediaElement).muted;
|
||||
mediaAttributes.rr_mediaLoop = (n as HTMLMediaElement).loop;
|
||||
mediaAttributes.rr_mediaVolume = (n as HTMLMediaElement).volume;
|
||||
}
|
||||
// Scroll
|
||||
if (!newlyAddedElement) {
|
||||
|
||||
Reference in New Issue
Block a user