diff --git a/src/routes/Player/ControlBar/ControlBar.js b/src/routes/Player/ControlBar/ControlBar.js
index f97a19cea..a2662d197 100644
--- a/src/routes/Player/ControlBar/ControlBar.js
+++ b/src/routes/Player/ControlBar/ControlBar.js
@@ -12,7 +12,7 @@ const styles = require('./styles');
const { useBinaryState } = require('stremio/common');
const { t } = require('i18next');
-const ControlBar = ({
+const ControlBar = React.forwardRef(({
className,
paused,
time,
@@ -41,7 +41,7 @@ const ControlBar = ({
onToggleOptionsMenu,
onToggleStatisticsMenu,
...props
-}) => {
+}, ref) => {
const { chromecast } = useServices();
const [chromecastServiceActive, setChromecastServiceActive] = React.useState(() => chromecast.active);
const [buttonsMenuOpen, , , toogleButtonsMenu] = useBinaryState(false);
@@ -133,7 +133,7 @@ const ControlBar = ({
};
}, []);
return (
-
+
);
-};
+});
+
+ControlBar.displayName = 'ControlBar';
ControlBar.propTypes = {
className: PropTypes.string,
diff --git a/src/routes/Player/Player.js b/src/routes/Player/Player.js
index 3f8d5930d..2cd177b96 100644
--- a/src/routes/Player/Player.js
+++ b/src/routes/Player/Player.js
@@ -51,7 +51,7 @@ const Player = ({ urlParams, queryParams }) => {
const nextVideoPopupDismissed = React.useRef(false);
const defaultSubtitlesSelected = React.useRef(false);
const defaultAudioTrackSelected = React.useRef(false);
- const controlBar = React.useRef(null);
+ const controlBarRef = React.useRef(null);
const [controlBarHeight, setControlBarHeight] = React.useState(0);
const [error, setError] = React.useState(null);
@@ -267,10 +267,11 @@ const Player = ({ urlParams, queryParams }) => {
}, []);
React.useEffect(() => {
- if(controlBarHeight.current) {
- setControlBarHeight(controlBarHeight.current.clientHeight);
+ if(controlBarRef.current.clientHeight) {
+ const height = controlBarRef.current.clientHeight;
+ setControlBarHeight(height);
}
- }, []);
+ }, [controlBarRef?.current]);
React.useEffect(() => {
setError(null);
if (player.selected === null) {
@@ -478,6 +479,7 @@ const Player = ({ urlParams, queryParams }) => {
}
};
}, []);
+ console.log(controlBarHeight)
React.useLayoutEffect(() => {
const onKeyDown = (event) => {
switch (event.code) {
@@ -688,7 +690,6 @@ const Player = ({ urlParams, queryParams }) => {
onMouseMove={onBarMouseMove}
onMouseOver={onBarMouseMove}
/>
-
{
onToggleStatisticsMenu={toggleStatisticsMenu}
onMouseMove={onBarMouseMove}
onMouseOver={onBarMouseMove}
+ ref={controlBarRef}
/>
-
{
nextVideoPopupOpen ?