| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194 | 
							- /* global $, config, dockToolbar,
 -    setLargeVideoVisible, Util */
 - 
 - var VideoLayout = require("../videolayout/VideoLayout");
 - var Prezi = require("../prezi/Prezi");
 - var UIUtil = require("../util/UIUtil");
 - 
 - var etherpadName = null;
 - var etherpadIFrame = null;
 - var domain = null;
 - var options = "?showControls=true&showChat=false&showLineNumbers=true&useMonospaceFont=false";
 - 
 - 
 - /**
 -  * Resizes the etherpad.
 -  */
 - function resize() {
 -     if ($('#etherpad>iframe').length) {
 -         var remoteVideos = $('#remoteVideos');
 -         var availableHeight
 -             = window.innerHeight - remoteVideos.outerHeight();
 -         var availableWidth = UIUtil.getAvailableVideoWidth();
 - 
 -         $('#etherpad>iframe').width(availableWidth);
 -         $('#etherpad>iframe').height(availableHeight);
 -     }
 - }
 - 
 - /**
 -  * Shares the Etherpad name with other participants.
 -  */
 - function shareEtherpad() {
 -     xmpp.addToPresence("etherpad", etherpadName);
 - }
 - 
 - /**
 -  * Creates the Etherpad button and adds it to the toolbar.
 -  */
 - function enableEtherpadButton() {
 -     if (!$('#etherpadButton').is(":visible"))
 -         $('#etherpadButton').css({display: 'inline-block'});
 - }
 - 
 - /**
 -  * Creates the IFrame for the etherpad.
 -  */
 - function createIFrame() {
 -     etherpadIFrame = document.createElement('iframe');
 -     etherpadIFrame.src = domain + etherpadName + options;
 -     etherpadIFrame.frameBorder = 0;
 -     etherpadIFrame.scrolling = "no";
 -     etherpadIFrame.width = $('#largeVideoContainer').width() || 640;
 -     etherpadIFrame.height = $('#largeVideoContainer').height() || 480;
 -     etherpadIFrame.setAttribute('style', 'visibility: hidden;');
 - 
 -     document.getElementById('etherpad').appendChild(etherpadIFrame);
 - 
 -     etherpadIFrame.onload = function() {
 - 
 -         document.domain = document.domain;
 -         bubbleIframeMouseMove(etherpadIFrame);
 -         setTimeout(function() {
 -             // the iframes inside of the etherpad are
 -             // not yet loaded when the etherpad iframe is loaded
 -             var outer = etherpadIFrame.
 -                 contentDocument.getElementsByName("ace_outer")[0];
 -             bubbleIframeMouseMove(outer);
 -             var inner = outer.
 -                 contentDocument.getElementsByName("ace_inner")[0];
 -             bubbleIframeMouseMove(inner);
 -         }, 2000);
 -     };
 - }
 - 
 - function bubbleIframeMouseMove(iframe){
 -     var existingOnMouseMove = iframe.contentWindow.onmousemove;
 -     iframe.contentWindow.onmousemove = function(e){
 -         if(existingOnMouseMove) existingOnMouseMove(e);
 -         var evt = document.createEvent("MouseEvents");
 -         var boundingClientRect = iframe.getBoundingClientRect();
 -         evt.initMouseEvent(
 -             "mousemove",
 -             true, // bubbles
 -             false, // not cancelable
 -             window,
 -             e.detail,
 -             e.screenX,
 -             e.screenY,
 -                 e.clientX + boundingClientRect.left,
 -                 e.clientY + boundingClientRect.top,
 -             e.ctrlKey,
 -             e.altKey,
 -             e.shiftKey,
 -             e.metaKey,
 -             e.button,
 -             null // no related element
 -         );
 -         iframe.dispatchEvent(evt);
 -     };
 - }
 - 
 - 
 - /**
 -  * On video selected event.
 -  */
 - $(document).bind('video.selected', function (event, isPresentation) {
 -     if (config.etherpad_base && etherpadIFrame && etherpadIFrame.style.visibility !== 'hidden')
 -         Etherpad.toggleEtherpad(isPresentation);
 - });
 - 
 - 
 - var Etherpad = {
 -     /**
 -      * Initializes the etherpad.
 -      */
 -     init: function (name) {
 - 
 -         if (config.etherpad_base && !etherpadName) {
 - 
 -             domain = config.etherpad_base;
 - 
 -             if (!name) {
 -                 // In case we're the focus we generate the name.
 -                 etherpadName = Math.random().toString(36).substring(7) +
 -                                 '_' + (new Date().getTime()).toString();
 -                 shareEtherpad();
 -             }
 -             else
 -                 etherpadName = name;
 - 
 -             enableEtherpadButton();
 - 
 -             /**
 -              * Resizes the etherpad, when the window is resized.
 -              */
 -             $(window).resize(function () {
 -                 resize();
 -             });
 -         }
 -     },
 - 
 -     /**
 -      * Opens/hides the Etherpad.
 -      */
 -     toggleEtherpad: function (isPresentation) {
 -         if (!etherpadIFrame)
 -             createIFrame();
 - 
 -         var largeVideo = null;
 -         if (Prezi.isPresentationVisible())
 -             largeVideo = $('#presentation>iframe');
 -         else
 -             largeVideo = $('#largeVideo');
 - 
 -         if ($('#etherpad>iframe').css('visibility') === 'hidden') {
 -             $('#activeSpeaker').css('visibility', 'hidden');
 -             largeVideo.fadeOut(300, function () {
 -                 if (Prezi.isPresentationVisible()) {
 -                     largeVideo.css({opacity: '0'});
 -                 } else {
 -                     VideoLayout.setLargeVideoVisible(false);
 -                 }
 -             });
 - 
 -             $('#etherpad>iframe').fadeIn(300, function () {
 -                 document.body.style.background = '#eeeeee';
 -                 $('#etherpad>iframe').css({visibility: 'visible'});
 -                 $('#etherpad').css({zIndex: 2});
 -             });
 -         }
 -         else if ($('#etherpad>iframe')) {
 -             $('#etherpad>iframe').fadeOut(300, function () {
 -                 $('#etherpad>iframe').css({visibility: 'hidden'});
 -                 $('#etherpad').css({zIndex: 0});
 -                 document.body.style.background = 'black';
 -             });
 - 
 -             if (!isPresentation) {
 -                 $('#largeVideo').fadeIn(300, function () {
 -                     VideoLayout.setLargeVideoVisible(true);
 -                 });
 -             }
 -         }
 -         resize();
 -     },
 - 
 -     isVisible: function() {
 -         var etherpadIframe = $('#etherpad>iframe');
 -         return etherpadIframe && etherpadIframe.is(':visible');
 -     }
 - 
 - };
 - 
 - module.exports = Etherpad;
 
 
  |