mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-27 20:21:24 +00:00
sendrecv/js: Make error statuses more prominent
Colour errors in red, and ensure that later status updates don't overwrite existing error statuses.
This commit is contained in:
parent
bd6deaca46
commit
3eabe5cb0b
2 changed files with 27 additions and 11 deletions
|
@ -11,6 +11,9 @@
|
|||
-->
|
||||
<html>
|
||||
<head>
|
||||
<style>
|
||||
.error { color: red; }
|
||||
</style>
|
||||
<script src="https://webrtc.github.io/adapter/adapter-latest.js"></script>
|
||||
<script src="webrtc.js"></script>
|
||||
<script>
|
||||
|
|
|
@ -27,7 +27,7 @@ function resetState() {
|
|||
}
|
||||
|
||||
function handleIncomingError(error) {
|
||||
setStatus("ERROR: " + error);
|
||||
setError("ERROR: " + error);
|
||||
resetState();
|
||||
}
|
||||
|
||||
|
@ -37,7 +37,17 @@ function getVideoElement() {
|
|||
|
||||
function setStatus(text) {
|
||||
console.log(text);
|
||||
document.getElementById("status").textContent = text;
|
||||
span = document.getElementById("status")
|
||||
// Don't set the status if it already contains an error
|
||||
if (!span.classList.contains('error'))
|
||||
span.textContent = text;
|
||||
}
|
||||
|
||||
function setError(text) {
|
||||
console.log(text);
|
||||
span = document.getElementById("status")
|
||||
span.textContent = text;
|
||||
span.classList.add('error');
|
||||
}
|
||||
|
||||
function resetVideoElement() {
|
||||
|
@ -54,12 +64,13 @@ function onIncomingSDP(sdp) {
|
|||
setStatus("Remote SDP set");
|
||||
if (sdp.type != "offer")
|
||||
return;
|
||||
setStatus("Got SDP offer, creating answer");
|
||||
setStatus("Got SDP offer");
|
||||
local_stream.then((stream) => {
|
||||
setStatus("Got local stream, creating answer");
|
||||
peer_connection.createAnswer()
|
||||
.then(onLocalDescription).catch(setStatus);
|
||||
}).catch(errorUserMediaHandler);
|
||||
}).catch(setStatus);
|
||||
.then(onLocalDescription).catch(setError);
|
||||
}).catch(setError);
|
||||
}).catch(setError);
|
||||
}
|
||||
|
||||
// Local description was set, send it to peer
|
||||
|
@ -76,7 +87,7 @@ function onLocalDescription(desc) {
|
|||
function onIncomingICE(ice) {
|
||||
console.log("Incoming ICE: " + JSON.stringify(ice));
|
||||
var candidate = new RTCIceCandidate(ice);
|
||||
peer_connection.addIceCandidate(candidate).catch(setStatus);
|
||||
peer_connection.addIceCandidate(candidate).catch(setError);
|
||||
}
|
||||
|
||||
function onServerMessage(event) {
|
||||
|
@ -129,7 +140,7 @@ function onServerClose(event) {
|
|||
}
|
||||
|
||||
function onServerError(event) {
|
||||
setStatus("Unable to connect to server, did you add an exception for the certificate?")
|
||||
setError("Unable to connect to server, did you add an exception for the certificate?")
|
||||
// Retry after 3 seconds
|
||||
window.setTimeout(websocketServerConnect, 3000);
|
||||
}
|
||||
|
@ -148,7 +159,7 @@ function getLocalStream() {
|
|||
function websocketServerConnect() {
|
||||
connect_attempts++;
|
||||
if (connect_attempts > 3) {
|
||||
setStatus("Too many connection attempts, aborting. Refresh page to try again");
|
||||
setError("Too many connection attempts, aborting. Refresh page to try again");
|
||||
return;
|
||||
}
|
||||
peer_id = getOurId();
|
||||
|
@ -186,20 +197,22 @@ function onRemoteStreamAdded(event) {
|
|||
}
|
||||
|
||||
function errorUserMediaHandler() {
|
||||
setStatus("Browser doesn't support getUserMedia!");
|
||||
setError("Browser doesn't support getUserMedia!");
|
||||
}
|
||||
|
||||
function createCall(msg) {
|
||||
// Reset connection attempts because we connected successfully
|
||||
connect_attempts = 0;
|
||||
|
||||
console.log('Creating RTCPeerConnection');
|
||||
|
||||
peer_connection = new RTCPeerConnection(rtc_configuration);
|
||||
peer_connection.onaddstream = onRemoteStreamAdded;
|
||||
/* Send our video/audio to the other peer */
|
||||
local_stream = getLocalStream().then((stream) => {
|
||||
console.log('Adding local stream');
|
||||
peer_connection.addStream(stream);
|
||||
}).catch(errorUserMediaHandler);
|
||||
}).catch(setError);
|
||||
|
||||
if (!msg.sdp) {
|
||||
console.log("WARNING: First message wasn't an SDP message!?");
|
||||
|
|
Loading…
Reference in a new issue