A simple and robust way to play video content from the Eluvio Content Fabric.
Install from npm:
npm install --save @eluvio/elv-player-js
Import the library and load the player:
// Import the player and player parameter options (ES Module)
import {InitializeEluvioPlayer, EluvioPlayerParameters} from "@eluvio/elv-player-js";
// Or import the player and player parameter options as CommonJS
import {InitializeEluvioPlayer, EluvioPlayerParameters} from "@eluvio/elv-player-js/dist/elv-player-js.cjs.js";
// Or import the player and player parameter options from source (recommended if using @eluvio/elv-client-js in your project)
import {InitializeEluvioPlayer, EluvioPlayerParameters} from "@eluvio/elv-player-js/lib/index.js";
// Import CSS (if not importing from source)
import "@eluvio/elv-player-js/dist/elv-player-js.css";
const player = await InitializeEluvioPlayer(
targetContainerElement,
{
clientOptions: {
// Specify the fabric network
network: EluvioPlayerParameters.networks.main,
// or if you already have an instance of ElvClient, just pass it in
client: myElvClient
},
sourceOptions: {
playoutParameters: {
// Specify object ID (always latest version)
objectId: "iq__...",
// Or specify version hash (specific version)
versionHash: "hq__...."
}
},
playerOptions: {
// Specify player behavior and UI options
autoplay: EluvioPlayerParameters.autoplay.ON
}
}
);
Destroy the player when you're done with it
player.Destroy();
Note: If you are using @eluvio/elv-client-js
elsewhere in your project, importing both the player and the client from source can result in significant size reduction as the client, which is a dependency of the player, can be de-duped
The player library has a number of options to configure what content should be played and how it's authorized, display options for the player, and callbacks for events.
The library includes a helpful collection of configuration options in EluvioPlayerParameters
.
clientOptions: {
network: EluvioPlayerParameters.networks.MAIN,
client: undefined,
staticToken: undefined
}
network
- Which Fabric network to use. Defaults to the main production network.EluvioPlayerParameters.networks["MAIN" | "DEMO]
client
- If you already have an instance of @eluvio/elv-client-js, you can provide it to the player to avoid initializing a new client. This will improve initial load performance. This will also handle any necessary authorization your client is already set up for.staticToken
- If you have a static auth token to use, you can provide it
sourceOptions: {
protocols: [
EluvioPlayerParameters.protocols.HLS,
EluvioPlayerParameters.protocols.DASH
],
drms: [
EluvioPlayerParameters.drms.FAIRPLAY,
EluvioPlayerParameters.drms.SAMPLE_AES,
EluvioPlayerParameters.drms.AES128,
EluvioPlayerParameters.drms.WIDEVINE,
EluvioPlayerParameters.drms.CLEAR,
EluvioPlayerParameters.drms.PLAYREADY
],
playoutOptions: undefined,
playoutParameters: {
objectId: undefined,
versionHash: undefined,
writeToken: undefined,
linkPath: undefined,
signedLink: false,
handler: "playout",
offering: "default",
playoutType: undefined,
context: undefined,
hlsjsProfile: true,
authorizationToken: undefined,
clipStart: undefined,
clipEnd: undefined
},
contentInfo: {
title: undefined,
subtitle: undefined,
description: undefined,
image: undefined,
posterImage: undefined,
headers: []
}
},
protocols
- The ABR protocols you want the player to usedrms
- The DRMs options you want the player to useplayoutOptions
- If you already have the results ofclient.PlayoutOptions
, you can provide itplayoutParameters
- These parameters directly correspond to what is provided to the PlayoutOptions method in @eluvio/elv-client-js. Typically you will only need to specify a versionHash or object IDcontentInfo
: Specify information about the content, such as title, description, icon and poster images, and header text such as ratings, release year, etc.mediaCollectionOptions
: To play a collection, specify the media catalog object by ID or version hash, as well as the collection to play
// All player options and their defaults
playerOptions: {
ui: EluvioPlayerParameters.ui.WEB,
backgroundColor: undefined,
controls: EluvioPlayerParameters.controls.AUTO_HIDE,
autoplay: EluvioPlayerParameters.autoplay.OFF,
muted: EluvioPlayerParameters.muted.OFF,
loop: EluvioPlayerParameters.loop.OFF,
watermark: EluvioPlayerParameters.watermark.ON,
capLevelToPlayerSize: EluvioPlayerParameters.capLevelToPlayerSize.OFF,
collectVideoAnalytics: EluvioPlayerParameters.collectVideoAnalytics.ON,
startTime: undefined,
startProgress: undefined,
posterUrl: undefined,
hlsjsOptions: undefined,
dashjsOptions: undefined,
maxBitrate: undefined,
playerCallback: ({player, videoElement, hlsPlayer, dashPlayer, posterUrl}) => {},
errorCallback: (error, player) => {},
restartCallback: async (error) => {}
}
ui
- Switch between the default web UI and the TV optimized UIWEB (default)
- The default browser style playerTV
- A player UI optimized for usage on TVs and similar devices
controls
- How the controls should be displayedAUTOHIDE (default)
: Player controls will be shown. Will automatically hide when not in useON
: Player controls will be shownDEFAULT
: Default HTML video controls will be shownOFF
: No controls will be shownOFF_WITH_VOLUME_TOGGLE
: No controls will be shown except a volume on/off toggle
autoplay
- Whether or not the video should autoplay. NOTE: Browsers may block autoplay video with audioOFF (default)
: Video will not autoplayON
: Video will autoplayWHEN_VISIBLE
: Video will autoplay only when the video element is visible, and will stop when the element is no longer visible
muted
- Whether or not the video will be muted.OFF (default)
: Video will not be mutedON
: Video will be mutedWHEN_NOT_VISIBLE
: Video will be muted when the video element is not visibleOFF_IF_POSSIBLE
: Video will not be muted unless playback is blocked due to audio (useful for autoplay)
loop
- Whether or not the video will loop.OFF (default)
- Video will not loopON
- Video will loop
keyboardControls
- Whether or not the player's keyboard controls will be activeON (default)
- Keyboard controls activeOFF
- Keyboard controls disabledARROW_KEYS_DISABLED
- Keyboard controls active except for arrow keys (useful if supporting directional navigation)
watermark
: Whether or not the Eluvio watermark will be shown.ON (default)
- Watermark will be shownOFF
- Watermark will not be shown
capLevelToPlayerSize
: Whether or not the playback quality should be limited by the size of the video element. Useful for reducing bandwidth usage for smaller video elements where a higher quality would not be beneficial.OFF (default)
- Playback quality will not be affected by the size of the video element (default)ON
- Playback quality will be limited by the size of the video element
collectVideoAnalytics
- By default, the player will collect anonymized playback analytics to help improve the performance of the Eluvio Content Fabric.ON (default)
- Player performance analytics will be collectedDISABLE_COOKIES
- Player performance analytics will be collected, but browser cookies will not be usedOFF
- Player performance analytics will not be collected
startTime
- Start the video at the specified time, in secondsstartProgress
- Start the video at the specified progress amount, from 0.0 for the start of the video to 1.0 for the end of the video.backgroundColor
- Specify the background color of the player. Must be a valid option for cssbackground-color
maxBitrate
- Maximum bitrate that the player will automatically use, in bits/second.posterUrl
- Specify a URL for the poster image for the playerhlsjsOptions
- Additional options to provide to hls.js on initializationdashjsOptions
- Additional options to provide to dashjs on initializationplayerCallback
- Callback function invoked after initialization has completed. Returns references to the player, the html video element, the dashjs or hls.js player instance, and the URL of the poster imageerrorCallback
- Callback function invoked when an error occurs. Includes the error as well as a reference to the player.restartCallback
- Callback function invoked when the player has restarted to attempt to recover from an error. Includes the error.
For an even simpler experience, you can use the Eluvio Embed application to generate embeddable and sharable links to content on the fabric.
- Go to https://embed.v3.contentfabric.io/
- Specify your content and player configuration
- Generate the embed URL
- Embed the provided frame code in your webpage or share the embed link
Embeddable Frame:
<iframe
width=854 height=480 scrolling="no" marginheight="0"
marginwidth="0" frameborder="0" type="text/html"
src="https://embed.v3.contentfabric.io/?net=main&p&ct=h&vid=hq__CcdV4wnCNq9wv6jXpYeCQ2GE4FLQBFtVSSSt2XKfBJMrH89DFDGsfkpWWvBy16QBGGYeF5mLGo&mt=v"
allowtransparency="true"
></iframe>
Link: