React Integration
BlendVision Web Player SDK UI is built with React and provides component exports, integration is just like any other React component, just compose it into your app, and program declearatively with props.
Quick Start
There is a sample project to start with.
Install latest version from npm into your project:
yarn add @blendvision/player@latest
Import the player component from React sub-bundle:
import { PremiumPlayer } from "@blendvision/player/react";
import { useState, useEffect } from 'react';
Compose player component into your app:
const MyVideoApp = () => {
    const [source, setSource] = useState(
        [
            {
                type: "dash",
                src: "https://your.content.url/dash.mpd",
            },
            {
                type: "hls",
                src: "https://your.content.url/hls.m3u8",
            },
        ]
    );
    return (
        <div>
            <PremiumPlayer source={source} />
        </div>
    );
};
Source
An object or an array of objects contains {type, src}.
Type: 'dash' | 'hls' type of manifests
Src: manifest URL of video
Important: Avoid defining the source directly inside components as it may cause unnecessary re-renders and other side effects. Instead, define sources outside the component or use appropriate state management.
// Bad - defining source inside component
const MyVideoApp = () => {
    const source = [
        // This will be recreated on every render
        {
            type: "dash",
            src: "...",
        },
    ];
    return <PremiumPlayer source={source} />;
};
// Good - using useState or defining outside
const videoSource = [
    {
        type: "dash",
        src: "...",
    },
];
const MyVideoApp = () => {
    return <PremiumPlayer source={videoSource} />;
};
DRM
To play videos with content protection, you should specify license server URLs and options with drm:
let playbackToken = "YOUR_PLAYBACK_TOKEN"
let drmHeader = {
  "x-custom-data": `token_type=upfront&token_value=${playbackToken}`
}
const MyVideoApp = () => {
    const [source, setSource] = useState(
        [
            {
                type: "dash",
                src: "https://your.content.url/dash.mpd",
                drm: {
                widevine: {
                        licenseUri: "https://drm.platform.blendvision.com/api/v3/drm/license",
                        headers: drmHeader
                    }
                },
            },
            {
                type: 'hls',
                src: "https://your.content.url/hls.m3u8",
                drm: {
                fairplay: {
                        licenseUri: "https://drm.platform.blendvision.com/api/v3/drm/license",
                        certificateUri: "https://drm.platform.blendvision.com/api/v3/drm/license/fairplay_cert",
                        headers: drmHeader,
                        certificateHeaders: drmHeader
                    }
                }
            },
        ]
    );
}
Video Status & Control
Declarative playback control & play / pause
<PremiumPlayer> & <Video> let you control playback declaratively, in a React way.
This is how you can tell our video component to start playback in JSX:
<PremiumPlayer playbackState="playing" />
playbackState defines final desired state of the video, if you want the video paused, just use playbackState='paused'
Changes to props are converted into sequence of imperative API calls, under the hood, so no need to worry about consecutive changes of state.
Unlike <input value="xyz" />, playbackState doesn’t lock play / pause of the video.
For example, <PremiumPlayer> comes with built-in UI, and its play/paused also controls the video. The play / pause button updates with video state, and if pause button is tapped after passed prop is updated to playbackState='playing' , the video will result paused, it follow whichever latest updated.
Current playback time & Seek
Seek can also be done declaratively, to let the video play from 17 seconds, use prop currentTime:
<PremiumPlayer currentTime={17} />
And current playback time can be obtained from onTimeUpdate, just like how you use the video element:
<PremiumPlayer
    onTimeUpdate={(event) =>
        console.log("current playback time", event?.target.currentTime)
    }
/>
Caveats
In case playbackState='playing' is passed, the video is paused by the user, and you want to make it play again, just clear the state with playbackState={undefined} then pass playbackState='playing', changes is needed to trigger.
const [playbackState, setPlaybackState] = useState()
useEffect(() => {
  on('some-event', () => setPlaybackState('playing'))
}, [])
<PremiumPlayer
    playbackState={playbackState}
    onPlaybackStateChange={(event, state) => {
        setPlaybackState(undefined)
        // console.log(event, state)
    }}
/>