From 560b5aa2fe651fc4cc649f74efc5e62cf773e250 Mon Sep 17 00:00:00 2001 From: Jonas Smedegaard Date: Tue, 9 Jul 2019 00:06:45 -0300 Subject: Add website. --- website/css/style.css | 117 +++++++ website/ext/toastr.min.css | 1 + website/ext/toastr.min.js | 2 + website/fonts/font-awesome | 1 + website/img/up_arrow.png | Bin 0 -> 2611 bytes website/js | 1 + website/mic.js | 819 +++++++++++++++++++++++++++++++++++++++++++++ website/mic/index.html | 130 +++++++ 8 files changed, 1071 insertions(+) create mode 100644 website/css/style.css create mode 100644 website/ext/toastr.min.css create mode 100644 website/ext/toastr.min.js create mode 120000 website/fonts/font-awesome create mode 100644 website/img/up_arrow.png create mode 120000 website/js create mode 100644 website/mic.js create mode 100644 website/mic/index.html (limited to 'website') diff --git a/website/css/style.css b/website/css/style.css new file mode 100644 index 0000000..6b30c30 --- /dev/null +++ b/website/css/style.css @@ -0,0 +1,117 @@ +.rounded { + border-radius: 5px; +} + +.centered { + display: block; + margin: auto; +} + +.relative { + position: relative; +} + +.navbar-brand { + margin-left: 0px !important; +} + +.navbar-default { + -webkit-box-shadow: 0px 3px 5px rgba(100, 100, 100, 0.49); + -moz-box-shadow: 0px 3px 5px rgba(100, 100, 100, 0.49); + box-shadow: 0px 3px 5px rgba(100, 100, 100, 0.49); +} + +.navbar-header { + padding-left: 40px; +} + +.margin-sm { + margin: 5px !important; +} +.margin-md { + margin: 10px !important; +} +.margin-xl { + margin: 20px !important; +} +.margin-bottom-sm { + margin-bottom: 5px !important; +} +.margin-bottom-md { + margin-bottom: 10px !important; +} +.margin-bottom-xl { + margin-bottom: 20px !important; +} + +.divider { + width: 100%; + text-align: center; +} + +.divider hr { + margin-left: auto; + margin-right: auto; + width: 45%; +} + +.fa-2 { + font-size: 2em !important; +} +.fa-3 { + font-size: 4em !important; +} +.fa-4 { + font-size: 7em !important; +} +.fa-5 { + font-size: 12em !important; +} +.fa-6 { + font-size: 20em !important; +} + +div.no-video-container { + position: relative; +} + +.no-video-icon { + width: 100%; + height: 240px; + text-align: center; +} + +.no-video-text { + text-align: center; + position: absolute; + bottom: 0px; + right: 0px; + left: 0px; + font-size: 24px; +} + +.meetecho-logo { + padding: 12px !important; +} + +.meetecho-logo > img { + height: 26px; +} + +pre { + white-space: pre-wrap; + white-space: -moz-pre-wrap; + white-space: -pre-wrap; + white-space: -o-pre-wrap; + word-wrap: break-word; +} + +.januscon { + font-weight: bold; + animation: pulsating 1s infinite; +} +@keyframes pulsating { + 30% { + color: #FFD700; + } +} diff --git a/website/ext/toastr.min.css b/website/ext/toastr.min.css new file mode 100644 index 0000000..064afd0 --- /dev/null +++ b/website/ext/toastr.min.css @@ -0,0 +1 @@ +.toast-title{font-weight:700}.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}.toast-message a,.toast-message label{color:#FFF}.toast-message a:hover{color:#CCC;text-decoration:none}.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#FFF;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80);line-height:1}.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40)}.rtl .toast-close-button{left:-.3em;float:left;right:.3em}button.toast-close-button{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}.toast-top-center{top:0;right:0;width:100%}.toast-bottom-center{bottom:0;right:0;width:100%}.toast-top-full-width{top:0;right:0;width:100%}.toast-bottom-full-width{bottom:0;right:0;width:100%}.toast-top-left{top:12px;left:12px}.toast-top-right{top:12px;right:12px}.toast-bottom-right{right:12px;bottom:12px}.toast-bottom-left{bottom:12px;left:12px}#toast-container{position:fixed;z-index:999999;pointer-events:none}#toast-container *{-moz-box-sizing:border-box;-webkit-box-sizing:border-box;box-sizing:border-box}#toast-container>div{position:relative;pointer-events:auto;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;background-position:15px center;background-repeat:no-repeat;-moz-box-shadow:0 0 12px #999;-webkit-box-shadow:0 0 12px #999;box-shadow:0 0 12px #999;color:#FFF;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80)}#toast-container>div.rtl{direction:rtl;padding:15px 50px 15px 15px;background-position:right 15px center}#toast-container>div:hover{-moz-box-shadow:0 0 12px #000;-webkit-box-shadow:0 0 12px #000;box-shadow:0 0 12px #000;opacity:1;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);filter:alpha(opacity=100);cursor:pointer}#toast-container>.toast-info{background-image:url()!important}#toast-container>.toast-error{background-image:url()!important}#toast-container>.toast-success{background-image:url()!important}#toast-container>.toast-warning{background-image:url()!important}#toast-container.toast-bottom-center>div,#toast-container.toast-top-center>div{width:300px;margin-left:auto;margin-right:auto}#toast-container.toast-bottom-full-width>div,#toast-container.toast-top-full-width>div{width:96%;margin-left:auto;margin-right:auto}.toast{background-color:#030303}.toast-success{background-color:#51A351}.toast-error{background-color:#BD362F}.toast-info{background-color:#2F96B4}.toast-warning{background-color:#F89406}.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40)}@media all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 50px;width:11em}#toast-container>div.rtl{padding:8px 50px 8px 8px}#toast-container .toast-close-button{right:-.2em;top:-.2em}#toast-container .rtl .toast-close-button{left:-.2em;right:.2em}}@media all and (min-width:241px) and (max-width:480px){#toast-container>div{padding:8px 8px 8px 50px;width:18em}#toast-container>div.rtl{padding:8px 50px 8px 8px}#toast-container .toast-close-button{right:-.2em;top:-.2em}#toast-container .rtl .toast-close-button{left:-.2em;right:.2em}}@media all and (min-width:481px) and (max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}#toast-container>div.rtl{padding:15px 50px 15px 15px}} \ No newline at end of file diff --git a/website/ext/toastr.min.js b/website/ext/toastr.min.js new file mode 100644 index 0000000..7c0c07c --- /dev/null +++ b/website/ext/toastr.min.js @@ -0,0 +1,2 @@ +!function(e){e(["jquery"],function(e){return function(){function t(e,t,n){return g({type:O.error,iconClass:m().iconClasses.error,message:e,optionsOverride:n,title:t})}function n(t,n){return t||(t=m()),v=e("#"+t.containerId),v.length?v:(n&&(v=d(t)),v)}function o(e,t,n){return g({type:O.info,iconClass:m().iconClasses.info,message:e,optionsOverride:n,title:t})}function s(e){C=e}function i(e,t,n){return g({type:O.success,iconClass:m().iconClasses.success,message:e,optionsOverride:n,title:t})}function a(e,t,n){return g({type:O.warning,iconClass:m().iconClasses.warning,message:e,optionsOverride:n,title:t})}function r(e,t){var o=m();v||n(o),u(e,o,t)||l(o)}function c(t){var o=m();return v||n(o),t&&0===e(":focus",t).length?void h(t):void(v.children().length&&v.remove())}function l(t){for(var n=v.children(),o=n.length-1;o>=0;o--)u(e(n[o]),t)}function u(t,n,o){var s=!(!o||!o.force)&&o.force;return!(!t||!s&&0!==e(":focus",t).length)&&(t[n.hideMethod]({duration:n.hideDuration,easing:n.hideEasing,complete:function(){h(t)}}),!0)}function d(t){return v=e("
").attr("id",t.containerId).addClass(t.positionClass),v.appendTo(e(t.target)),v}function p(){return{tapToDismiss:!0,toastClass:"toast",containerId:"toast-container",debug:!1,showMethod:"fadeIn",showDuration:300,showEasing:"swing",onShown:void 0,hideMethod:"fadeOut",hideDuration:1e3,hideEasing:"swing",onHidden:void 0,closeMethod:!1,closeDuration:!1,closeEasing:!1,closeOnHover:!0,extendedTimeOut:1e3,iconClasses:{error:"toast-error",info:"toast-info",success:"toast-success",warning:"toast-warning"},iconClass:"toast-info",positionClass:"toast-top-right",timeOut:5e3,titleClass:"toast-title",messageClass:"toast-message",escapeHtml:!1,target:"body",closeHtml:'',closeClass:"toast-close-button",newestOnTop:!0,preventDuplicates:!1,progressBar:!1,progressClass:"toast-progress",rtl:!1}}function f(e){C&&C(e)}function g(t){function o(e){return null==e&&(e=""),e.replace(/&/g,"&").replace(/"/g,""").replace(/'/g,"'").replace(//g,">")}function s(){c(),u(),d(),p(),g(),C(),l(),i()}function i(){var e="";switch(t.iconClass){case"toast-success":case"toast-info":e="polite";break;default:e="assertive"}I.attr("aria-live",e)}function a(){E.closeOnHover&&I.hover(H,D),!E.onclick&&E.tapToDismiss&&I.click(b),E.closeButton&&j&&j.click(function(e){e.stopPropagation?e.stopPropagation():void 0!==e.cancelBubble&&e.cancelBubble!==!0&&(e.cancelBubble=!0),E.onCloseClick&&E.onCloseClick(e),b(!0)}),E.onclick&&I.click(function(e){E.onclick(e),b()})}function r(){I.hide(),I[E.showMethod]({duration:E.showDuration,easing:E.showEasing,complete:E.onShown}),E.timeOut>0&&(k=setTimeout(b,E.timeOut),F.maxHideTime=parseFloat(E.timeOut),F.hideEta=(new Date).getTime()+F.maxHideTime,E.progressBar&&(F.intervalId=setInterval(x,10)))}function c(){t.iconClass&&I.addClass(E.toastClass).addClass(y)}function l(){E.newestOnTop?v.prepend(I):v.append(I)}function u(){if(t.title){var e=t.title;E.escapeHtml&&(e=o(t.title)),M.append(e).addClass(E.titleClass),I.append(M)}}function d(){if(t.message){var e=t.message;E.escapeHtml&&(e=o(t.message)),B.append(e).addClass(E.messageClass),I.append(B)}}function p(){E.closeButton&&(j.addClass(E.closeClass).attr("role","button"),I.prepend(j))}function g(){E.progressBar&&(q.addClass(E.progressClass),I.prepend(q))}function C(){E.rtl&&I.addClass("rtl")}function O(e,t){if(e.preventDuplicates){if(t.message===w)return!0;w=t.message}return!1}function b(t){var n=t&&E.closeMethod!==!1?E.closeMethod:E.hideMethod,o=t&&E.closeDuration!==!1?E.closeDuration:E.hideDuration,s=t&&E.closeEasing!==!1?E.closeEasing:E.hideEasing;if(!e(":focus",I).length||t)return clearTimeout(F.intervalId),I[n]({duration:o,easing:s,complete:function(){h(I),clearTimeout(k),E.onHidden&&"hidden"!==P.state&&E.onHidden(),P.state="hidden",P.endTime=new Date,f(P)}})}function D(){(E.timeOut>0||E.extendedTimeOut>0)&&(k=setTimeout(b,E.extendedTimeOut),F.maxHideTime=parseFloat(E.extendedTimeOut),F.hideEta=(new Date).getTime()+F.maxHideTime)}function H(){clearTimeout(k),F.hideEta=0,I.stop(!0,!0)[E.showMethod]({duration:E.showDuration,easing:E.showEasing})}function x(){var e=(F.hideEta-(new Date).getTime())/F.maxHideTime*100;q.width(e+"%")}var E=m(),y=t.iconClass||E.iconClass;if("undefined"!=typeof t.optionsOverride&&(E=e.extend(E,t.optionsOverride),y=t.optionsOverride.iconClass||y),!O(E,t)){T++,v=n(E,!0);var k=null,I=e("
"),M=e("
"),B=e("
"),q=e("
"),j=e(E.closeHtml),F={intervalId:null,hideEta:null,maxHideTime:null},P={toastId:T,state:"visible",startTime:new Date,options:E,map:t};return s(),r(),a(),f(P),E.debug&&console&&console.log(P),I}}function m(){return e.extend({},p(),b.options)}function h(e){v||(v=n()),e.is(":visible")||(e.remove(),e=null,0===v.children().length&&(v.remove(),w=void 0))}var v,C,w,T=0,O={error:"error",info:"info",success:"success",warning:"warning"},b={clear:r,remove:c,error:t,getContainer:n,info:o,options:{},subscribe:s,success:i,version:"2.1.3",warning:a};return b}()})}("function"==typeof define&&define.amd?define:function(e,t){"undefined"!=typeof module&&module.exports?module.exports=t(require("jquery")):window.toastr=t(window.jQuery)}); +//# sourceMappingURL=toastr.js.map diff --git a/website/fonts/font-awesome b/website/fonts/font-awesome new file mode 120000 index 0000000..3437336 --- /dev/null +++ b/website/fonts/font-awesome @@ -0,0 +1 @@ +/usr/share/fonts-font-awesome \ No newline at end of file diff --git a/website/img/up_arrow.png b/website/img/up_arrow.png new file mode 100644 index 0000000..51b8a87 Binary files /dev/null and b/website/img/up_arrow.png differ diff --git a/website/js b/website/js new file mode 120000 index 0000000..e3b95b4 --- /dev/null +++ b/website/js @@ -0,0 +1 @@ +/usr/share/javascript \ No newline at end of file diff --git a/website/mic.js b/website/mic.js new file mode 100644 index 0000000..ecbd682 --- /dev/null +++ b/website/mic.js @@ -0,0 +1,819 @@ +var websocket_server = null; +if(window.location.protocol === 'http:') + websocket_server = "ws://" + window.location.hostname + "/janus-ws/janus"; +else + websocket_server = "wss://" + window.location.hostname + "/janus-ws/janus"; + +var janus = null; +var streaming = null; +var mixertest = null; +var opaqueId = "streamingwithfeedback-"+Janus.randomString(12); + +var bitrateTimer = null; +var spinner = null; + +var simulcastStarted = false, svcStarted = false; + +var selectedStream = null; + +var myroom = 1234; // Demo room +var myusername = null; +var myid = null; +var webrtcUp = false; +var audioenabled = false; + + +$(document).ready(function() { + // Initialize the library (all console debuggers enabled) + Janus.init({debug: "all", callback: function() { + // Use a button to start the demo + $('#start').one('click', function() { + $(this).attr('disabled', true).unbind('click'); + // Make sure the browser supports WebRTC + if(!Janus.isWebrtcSupported()) { + bootbox.alert("No WebRTC support... "); + return; + } + // Create session + janus = new Janus( + { + server: [websocket_server, "/janus"], + iceServers: [{url: "turn:morla.jones.dk", username: "myturn", credential: "notsecure"}, + {url: "turn:jawa.homebase.dk", username: "myturn", credential: "notsecure"}], + success: function() { + // Attach to streaming plugin + janus.attach( + { + plugin: "janus.plugin.streaming", + opaqueId: opaqueId, + success: function(pluginHandle) { + $('#details').remove(); + streaming = pluginHandle; + Janus.log("Plugin attached! (" + streaming.getPlugin() + ", id=" + streaming.getId() + ")"); + // Setup streaming session + $('#update-streams').click(updateStreamsList); + updateStreamsList(); + $('#start').removeAttr('disabled').html("Stop") + .click(function() { + $(this).attr('disabled', true); + clearInterval(bitrateTimer); + janus.destroy(); + $('#streamslist').attr('disabled', true); + $('#watch').attr('disabled', true).unbind('click'); + $('#start').attr('disabled', true).html("Bye").unbind('click'); + }); + }, + error: function(error) { + Janus.error(" -- Error attaching plugin... ", error); + bootbox.alert("Error attaching plugin... " + error); + }, + onmessage: function(msg, jsep) { + Janus.debug(" ::: Got a message :::"); + Janus.debug(msg); + var result = msg["result"]; + if(result !== null && result !== undefined) { + if(result["status"] !== undefined && result["status"] !== null) { + var status = result["status"]; + if(status === 'starting') + $('#status').removeClass('hide').text("Starting, please wait...").show(); + else if(status === 'started') + $('#status').removeClass('hide').text("Started").show(); + else if(status === 'stopped') + stopStream(); + } else if(msg["streaming"] === "event") { + // Is simulcast in place? + var substream = result["substream"]; + var temporal = result["temporal"]; + if((substream !== null && substream !== undefined) || (temporal !== null && temporal !== undefined)) { + if(!simulcastStarted) { + simulcastStarted = true; + addSimulcastButtons(temporal !== null && temporal !== undefined); + } + // We just received notice that there's been a switch, update the buttons + updateSimulcastButtons(substream, temporal); + } + // Is VP9/SVC in place? + var spatial = result["spatial_layer"]; + temporal = result["temporal_layer"]; + if((spatial !== null && spatial !== undefined) || (temporal !== null && temporal !== undefined)) { + if(!svcStarted) { + svcStarted = true; + addSvcButtons(); + } + // We just received notice that there's been a switch, update the buttons + updateSvcButtons(spatial, temporal); + } + } + } else if(msg["error"] !== undefined && msg["error"] !== null) { + bootbox.alert(msg["error"]); + stopStream(); + return; + } + if(jsep !== undefined && jsep !== null) { + Janus.debug("Handling SDP as well..."); + Janus.debug(jsep); + // Offer from the plugin, let's answer + streaming.createAnswer( + { + jsep: jsep, + // We want recvonly audio/video and, if negotiated, datachannels + media: { audioSend: false, videoSend: false, data: true }, + success: function(jsep) { + Janus.debug("Got SDP!"); + Janus.debug(jsep); + var body = { "request": "start" }; + streaming.send({"message": body, "jsep": jsep}); + $('#watch').html("Stop").removeAttr('disabled').click(stopStream); + }, + error: function(error) { + Janus.error("WebRTC error:", error); + bootbox.alert("WebRTC error... " + JSON.stringify(error)); + } + }); + } + }, + onremotestream: function(stream) { + Janus.debug(" ::: Got a remote stream :::"); + Janus.debug(stream); + var addButtons = false; + if($('#remotevideo').length === 0) { + addButtons = true; + $('#stream').append('