Player.usePlayer
Hook to access the player store from within a Player.Provider
Player.usePlayer gives you access to the player store from any component within a Player.Provider. It has two overloads — without arguments for direct store access, or with a selector for reactive state subscriptions. Player.usePlayer is typed to the features you passed to createPlayer. It’s also available as a standalone import (import { usePlayer } from '@videojs/react'), but the standalone version returns an untyped store.
Examples
Store Access
Call Player.usePlayer() without arguments to get the store instance. Use this for imperative actions like play, pause, and volume changes. The component does not re-render on state changes.
import { createPlayer } from '@videojs/react';
import { Video, videoFeatures } from '@videojs/react/video';
import './StoreAccess.css';
const Player = createPlayer({
features: videoFeatures,
});
function Controls() {
const store = Player.usePlayer();
return (
<div className="react-use-player-store__controls">
<button type="button" onClick={() => store.play()}>
Play
</button>
<button type="button" onClick={() => store.pause()}>
Pause
</button>
</div>
);
}
export default function StoreAccess() {
return (
<Player.Provider>
<Player.Container className="react-use-player-store">
<Video
src="https://stream.mux.com/BV3YZtogl89mg9VcNBhhnHm02Y34zI1nlMuMQfAbl3dM/highest.mp4"
autoPlay
muted
playsInline
loop
/>
<Controls />
</Player.Container>
</Player.Provider>
);
}
.react-use-player-store {
position: relative;
}
.react-use-player-store video {
width: 100%;
}
.react-use-player-store__controls {
display: flex;
gap: 6px;
padding: 12px;
background: rgba(0, 0, 0, 0.05);
border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.react-use-player-store__controls button {
padding: 4px 12px;
border-radius: 6px;
border: 1px solid #ccc;
background: white;
cursor: pointer;
font-size: 0.8125rem;
}
Selector Subscription
Pass a selector function to subscribe to specific state. The component re-renders when the selected value changes, using shallow equality by default.
- Paused
- true
- Time
- 0.0s / 0.0s
import { createPlayer } from '@videojs/react';
import { Video, videoFeatures } from '@videojs/react/video';
import './Selector.css';
const Player = createPlayer({
features: videoFeatures,
});
function StateDisplay() {
const state = Player.usePlayer((s) => ({
paused: s.paused,
currentTime: s.currentTime,
duration: s.duration,
}));
return (
<dl className="react-use-player-selector__state">
<div>
<dt>Paused</dt>
<dd>{String(state.paused)}</dd>
</div>
<div>
<dt>Time</dt>
<dd>
{state.currentTime.toFixed(1)}s / {state.duration.toFixed(1)}s
</dd>
</div>
</dl>
);
}
export default function Selector() {
return (
<Player.Provider>
<Player.Container className="react-use-player-selector">
<Video
src="https://stream.mux.com/BV3YZtogl89mg9VcNBhhnHm02Y34zI1nlMuMQfAbl3dM/highest.mp4"
autoPlay
muted
playsInline
loop
/>
<StateDisplay />
</Player.Container>
</Player.Provider>
);
}
.react-use-player-selector {
position: relative;
}
.react-use-player-selector video {
width: 100%;
}
.react-use-player-selector__state {
display: flex;
gap: 16px;
padding: 12px;
margin: 0;
font-size: 0.8125rem;
background: rgba(0, 0, 0, 0.05);
border-top: 1px solid rgba(0, 0, 0, 0.1);
}
.react-use-player-selector__state div {
display: flex;
gap: 8px;
}
.react-use-player-selector__state dt {
color: #6b7280;
}
.react-use-player-selector__state dd {
margin: 0;
font-variant-numeric: tabular-nums;
}
API Reference
Without Selector
Access the player store from within a Player Provider.
Return Value
BaseStore & UnknownState
With Selector
Select a value from the player store. Re-renders when the selected value changes.
Parameters
| Parameter | Type | Default | |
|---|---|---|---|
selector* | function | — | |
| |||
Return Value
R