-
Notifications
You must be signed in to change notification settings - Fork 5
IIIFPlayer Component
IIIFPlayer is the main component of this component library, while the others are supporting components. All the other components needs to be wrapped by the parent IIIFPlayer component, with the exception of Transcript component (more details in the Transcript component documentation).
The following props are accepted by the IIIFPlayer
component, while some are required and others not;
- manifestUrl (URL): URL of a manifest in the wild to be fetched
-
manifest (JSON) : local manifest data in a JSON format
manifest
: accepts a JSON object representing data in a IIIF Manifest
** Either manifestUrl
or manifest
is REQUIRED. If both props are given then manifest
takes precedence over manifestUrl
. At least one of the props should be provided when initializing the component
-
customErrorMessage
: accepts a messagge to display to the user in the unlikely event of the component crashing, this has a default error message and it is not required. The message can include HTML markup. -
startCanvasId
: accepts a valid Canvas ID that exists within the given Manifest, this can specify the Canvas to show in Ramp on initialization. This can be mapped to thestart
property in a IIIF Manifest. -
startCanvasTime
: accepts a valid number for a time in seconds to start playback in the Canvas shown in Ramp on initialization.
** startCanvasId
and startCanvasTime
props takes precedence over the start
property in a given IIIF Manifest. Defining either prop in the IIIFPlayer component overrides the start
property in the IIIF Manifest.
import { IIIFPlayer, MediaPlayer } from '@samvera/ramp';
import 'video.js/dist/video-js.css';
import '@samvera/ramp/dist/ramp.css';
<IIIFPlayer manifestUrl="http://example.com/manifest.json" manifest={manifest}>
<MediaPlayer />
</IIIFPlayer>
The IIIFPlayer component uses Video.js a HTML5 player framework underneath it and it has a couple of custom Video.js component implementations to add some extra functionality to the player. Please read more on these custom components here.