2023-01-25 21:44:15 +01:00
|
|
|
/// <reference types="chromecast-caf-sender"/>
|
|
|
|
|
|
|
|
import { useEffect, useRef, useState } from "react";
|
|
|
|
|
2023-04-24 18:41:54 +03:00
|
|
|
import { isChromecastAvailable } from "@/setup/chromecast";
|
|
|
|
|
2023-01-25 21:44:15 +01:00
|
|
|
export function useChromecastAvailable() {
|
|
|
|
const [available, setAvailable] = useState<boolean | null>(null);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
isChromecastAvailable((bool) => setAvailable(bool));
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
return available;
|
|
|
|
}
|
|
|
|
|
|
|
|
export function useChromecast() {
|
|
|
|
const available = useChromecastAvailable();
|
|
|
|
const instance = useRef<cast.framework.CastContext | null>(null);
|
|
|
|
const remotePlayerController =
|
|
|
|
useRef<cast.framework.RemotePlayerController | null>(null);
|
|
|
|
|
|
|
|
function startCast() {
|
|
|
|
const movieMeta = new chrome.cast.media.MovieMediaMetadata();
|
|
|
|
movieMeta.title = "Big Buck Bunny";
|
|
|
|
|
|
|
|
const mediaInfo = new chrome.cast.media.MediaInfo("hello", "video/mp4");
|
|
|
|
(mediaInfo as any).contentUrl =
|
|
|
|
"http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4";
|
|
|
|
mediaInfo.streamType = chrome.cast.media.StreamType.BUFFERED;
|
|
|
|
mediaInfo.metadata = movieMeta;
|
|
|
|
|
|
|
|
const request = new chrome.cast.media.LoadRequest(mediaInfo);
|
|
|
|
request.autoplay = true;
|
|
|
|
|
|
|
|
const session = instance.current?.getCurrentSession();
|
|
|
|
if (!session) return;
|
|
|
|
|
2023-10-22 22:07:45 +02:00
|
|
|
session.loadMedia(request).catch((e: any) => {
|
|
|
|
console.error(e);
|
|
|
|
});
|
2023-01-25 21:44:15 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function stopCast() {
|
|
|
|
const session = instance.current?.getCurrentSession();
|
|
|
|
if (!session) return;
|
|
|
|
|
|
|
|
const controller = remotePlayerController.current;
|
|
|
|
if (!controller) return;
|
|
|
|
controller.stop();
|
|
|
|
}
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (!available) return;
|
|
|
|
|
|
|
|
// setup instance if not already
|
|
|
|
if (!instance.current) {
|
|
|
|
const ins = cast.framework.CastContext.getInstance();
|
|
|
|
ins.setOptions({
|
|
|
|
receiverApplicationId: chrome.cast.media.DEFAULT_MEDIA_RECEIVER_APP_ID,
|
|
|
|
autoJoinPolicy: chrome.cast.AutoJoinPolicy.ORIGIN_SCOPED,
|
|
|
|
});
|
|
|
|
instance.current = ins;
|
|
|
|
}
|
|
|
|
|
|
|
|
// setup player if not already
|
|
|
|
if (!remotePlayerController.current) {
|
|
|
|
const player = new cast.framework.RemotePlayer();
|
|
|
|
const controller = new cast.framework.RemotePlayerController(player);
|
|
|
|
remotePlayerController.current = controller;
|
|
|
|
}
|
|
|
|
|
|
|
|
// setup event listener
|
|
|
|
function listenToEvents(e: cast.framework.RemotePlayerChangedEvent) {
|
2023-11-24 18:39:40 +01:00
|
|
|
console.debug("chromecast event", e);
|
2023-01-25 21:44:15 +01:00
|
|
|
}
|
|
|
|
function connectionChanged(e: cast.framework.RemotePlayerChangedEvent) {
|
2023-11-24 18:39:40 +01:00
|
|
|
console.info("chromecast event connection changed", e);
|
2023-01-25 21:44:15 +01:00
|
|
|
}
|
|
|
|
remotePlayerController.current.addEventListener(
|
|
|
|
cast.framework.RemotePlayerEventType.PLAYER_STATE_CHANGED,
|
|
|
|
listenToEvents
|
|
|
|
);
|
|
|
|
remotePlayerController.current.addEventListener(
|
|
|
|
cast.framework.RemotePlayerEventType.IS_CONNECTED_CHANGED,
|
|
|
|
connectionChanged
|
|
|
|
);
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
remotePlayerController.current?.removeEventListener(
|
|
|
|
cast.framework.RemotePlayerEventType.PLAYER_STATE_CHANGED,
|
|
|
|
listenToEvents
|
|
|
|
);
|
|
|
|
remotePlayerController.current?.removeEventListener(
|
|
|
|
cast.framework.RemotePlayerEventType.IS_CONNECTED_CHANGED,
|
|
|
|
connectionChanged
|
|
|
|
);
|
|
|
|
};
|
|
|
|
}, [available]);
|
|
|
|
|
|
|
|
return {
|
|
|
|
startCast,
|
|
|
|
stopCast,
|
|
|
|
};
|
|
|
|
}
|