Skip to content

Commit

Permalink
fix(player): start recording when tab is open (#1024)
Browse files Browse the repository at this point in the history
Issue: RDMW-16402
  • Loading branch information
irvingoujAtDevolution authored Sep 26, 2024
1 parent 3bb6717 commit 6506b08
Showing 1 changed file with 15 additions and 8 deletions.
23 changes: 15 additions & 8 deletions webapp/player/js/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@ var videoSrcInfo = `${gatewayAccessUrl}/jet/jrec/pull/${sessionId}/recording.jso
var request = new XMLHttpRequest();

request.onreadystatechange = function () {

if (request.readyState !== XMLHttpRequest.DONE) {
return false;
}
Expand All @@ -22,7 +21,7 @@ request.onreadystatechange = function () {
var fileType = recordingInfo.files[0].fileName.split(".")[1];

var terminalDiv = document.createElement("div");
terminalDiv.setAttribute("id", "terminal")
terminalDiv.setAttribute("id", "terminal");

switch (fileType) {
case "webm":
Expand All @@ -35,6 +34,8 @@ request.onreadystatechange = function () {

var videoSrcElement = document.createElement("source");
videoSrcElement.id = "videoSrcElement";
videoSrcElement.type = "video/webm";
videoPlayer.muted = true;

videoPlayer.appendChild(videoSrcElement);
document.body.appendChild(videoPlayer);
Expand All @@ -47,6 +48,8 @@ request.onreadystatechange = function () {
var currentIndex = 0;
var maxIndex = recordingInfo.files.length - 1;

videoPlayer.play();

videoPlayer.onended = function () {
currentIndex++;
if (currentIndex > maxIndex) {
Expand All @@ -68,19 +71,21 @@ request.onreadystatechange = function () {

loadFile(trpSrc, (trpFileContent) => {
const castFileContent = convertTRPtoCast(trpFileContent);
const objectUrl = URL.createObjectURL(new Blob([castFileContent], { type: 'text/plain' }));
const objectUrl = URL.createObjectURL(
new Blob([castFileContent], { type: "text/plain" })
);
const originalFetch = window.fetch;
// HACK: override fetch to return the cast file content, we should definately update the XtermPlayer to avoid this
window.fetch = (url, options) => {
if (url === objectUrl){
if (url === objectUrl) {
return Promise.resolve({
text: () => {
return Promise.resolve(castFileContent);
},
});
}
return originalFetch(url, options);
}
};
const player = new XtermPlayer.XtermPlayer(objectUrl, terminalDiv);
window.fetch = originalFetch;

Expand All @@ -95,10 +100,12 @@ request.onreadystatechange = function () {
// create the Div
document.body.appendChild(terminalDiv);
let castSrc = `${gatewayAccessUrl}/jet/jrec/pull/${sessionId}/${recordingInfo.files[0].fileName}?token=${token}`;
const player = new XtermPlayer.XtermPlayer(castSrc, terminalDiv , {
fontSize: 12
const player = new XtermPlayer.XtermPlayer(castSrc, terminalDiv, {
fontSize: 12,
});
player.play();
setTimeout(() => {
player.play();
}, 500);

break;
}
Expand Down

0 comments on commit 6506b08

Please sign in to comment.