2012-01-19 06:39:38 +01:00
|
|
|
/**
|
|
|
|
* This code is mostly from the old Etherpad. Please help us to comment this code.
|
|
|
|
* This helps other people to understand this code better and helps them to improve it.
|
|
|
|
* TL;DR COMMENTS ON THIS FILE ARE HIGHLY APPRECIATED
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Copyright 2009 Google Inc.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS-IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2012-01-29 00:26:39 +01:00
|
|
|
// These jQuery things should create local references, but for now `require()`
|
|
|
|
// assigns to the global `$` and augments it with plugins.
|
2012-03-07 02:27:03 +01:00
|
|
|
require('./jquery');
|
|
|
|
JSON = require('./json2');
|
2012-01-29 00:26:39 +01:00
|
|
|
|
2012-03-07 02:27:03 +01:00
|
|
|
var createCookie = require('./pad_utils').createCookie;
|
|
|
|
var readCookie = require('./pad_utils').readCookie;
|
|
|
|
var randomString = require('./pad_utils').randomString;
|
2013-02-18 23:04:58 +01:00
|
|
|
var hooks = require('./pluginfw/hooks');
|
2012-01-19 06:39:38 +01:00
|
|
|
|
2013-02-18 22:03:52 +01:00
|
|
|
var token, padId, export_links;
|
2012-01-19 06:39:38 +01:00
|
|
|
|
|
|
|
function init() {
|
|
|
|
$(document).ready(function ()
|
|
|
|
{
|
2012-02-05 00:22:25 +01:00
|
|
|
// start the custom js
|
|
|
|
if (typeof customStart == "function") customStart();
|
2012-01-19 06:39:38 +01:00
|
|
|
|
|
|
|
//get the padId out of the url
|
|
|
|
var urlParts= document.location.pathname.split("/");
|
|
|
|
padId = decodeURIComponent(urlParts[urlParts.length-2]);
|
|
|
|
|
|
|
|
//set the title
|
2012-01-31 15:15:36 +01:00
|
|
|
document.title = padId.replace(/_+/g, ' ') + " | " + document.title;
|
2012-01-19 06:39:38 +01:00
|
|
|
|
|
|
|
//ensure we have a token
|
|
|
|
token = readCookie("token");
|
|
|
|
if(token == null)
|
|
|
|
{
|
2012-01-29 02:38:23 +01:00
|
|
|
token = "t." + randomString();
|
2012-01-19 06:39:38 +01:00
|
|
|
createCookie("token", token, 60);
|
|
|
|
}
|
|
|
|
|
|
|
|
var loc = document.location;
|
|
|
|
//get the correct port
|
|
|
|
var port = loc.port == "" ? (loc.protocol == "https:" ? 443 : 80) : loc.port;
|
|
|
|
//create the url
|
|
|
|
var url = loc.protocol + "//" + loc.hostname + ":" + port + "/";
|
|
|
|
//find out in which subfolder we are
|
2012-04-29 20:04:00 +02:00
|
|
|
var resource = exports.baseURL.substring(1) + 'socket.io';
|
2019-04-16 00:34:29 +02:00
|
|
|
|
2012-01-19 06:39:38 +01:00
|
|
|
//build up the socket io connection
|
2015-01-19 04:55:06 +01:00
|
|
|
socket = io.connect(url, {path: exports.baseURL + 'socket.io', resource: resource});
|
2019-04-16 00:34:29 +02:00
|
|
|
|
2012-01-19 06:39:38 +01:00
|
|
|
//send the ready message once we're connected
|
|
|
|
socket.on('connect', function()
|
|
|
|
{
|
|
|
|
sendSocketMsg("CLIENT_READY", {});
|
|
|
|
});
|
|
|
|
|
2012-04-23 14:47:07 +02:00
|
|
|
socket.on('disconnect', function()
|
|
|
|
{
|
|
|
|
BroadcastSlider.showReconnectUI();
|
|
|
|
});
|
|
|
|
|
2012-01-19 06:39:38 +01:00
|
|
|
//route the incoming messages
|
|
|
|
socket.on('message', function(message)
|
|
|
|
{
|
|
|
|
if(window.console) console.log(message);
|
|
|
|
|
|
|
|
if(message.type == "CLIENT_VARS")
|
|
|
|
{
|
|
|
|
handleClientVars(message);
|
|
|
|
}
|
|
|
|
else if(message.accessStatus)
|
|
|
|
{
|
|
|
|
$("body").html("<h2>You have no permission to access this pad</h2>")
|
2012-04-23 12:52:30 +02:00
|
|
|
} else {
|
2012-04-23 13:29:27 +02:00
|
|
|
changesetLoader.handleMessageFromServer(message);
|
2012-01-19 06:39:38 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
//get all the export links
|
|
|
|
export_links = $('#export > .exportlink')
|
|
|
|
|
2012-04-23 14:47:07 +02:00
|
|
|
$('button#forcereconnect').click(function()
|
|
|
|
{
|
|
|
|
window.location.reload();
|
|
|
|
});
|
|
|
|
|
2013-02-18 22:03:52 +01:00
|
|
|
exports.socket = socket; // make the socket available
|
2013-04-09 16:55:14 +02:00
|
|
|
exports.BroadcastSlider = BroadcastSlider; // Make the slider available
|
2013-02-18 22:03:52 +01:00
|
|
|
|
2013-02-25 11:13:50 +01:00
|
|
|
hooks.aCallAll("postTimesliderInit");
|
2012-01-19 06:39:38 +01:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
//sends a message over the socket
|
|
|
|
function sendSocketMsg(type, data)
|
|
|
|
{
|
2013-03-31 11:30:01 +02:00
|
|
|
var sessionID = decodeURIComponent(readCookie("sessionID"));
|
2012-01-19 06:39:38 +01:00
|
|
|
var password = readCookie("password");
|
|
|
|
|
2012-04-23 12:52:30 +02:00
|
|
|
var msg = { "component" : "pad", // FIXME: Remove this stupidity!
|
2012-01-19 06:39:38 +01:00
|
|
|
"type": type,
|
|
|
|
"data": data,
|
|
|
|
"padId": padId,
|
|
|
|
"token": token,
|
|
|
|
"sessionID": sessionID,
|
|
|
|
"password": password,
|
|
|
|
"protocolVersion": 2};
|
|
|
|
|
|
|
|
socket.json.send(msg);
|
|
|
|
}
|
|
|
|
|
|
|
|
var fireWhenAllScriptsAreLoaded = [];
|
2019-04-16 00:34:29 +02:00
|
|
|
|
2013-04-09 16:55:14 +02:00
|
|
|
var changesetLoader;
|
2012-01-19 06:39:38 +01:00
|
|
|
function handleClientVars(message)
|
|
|
|
{
|
|
|
|
//save the client Vars
|
|
|
|
clientVars = message.data;
|
2019-04-16 00:34:29 +02:00
|
|
|
|
2012-01-19 06:39:38 +01:00
|
|
|
//load all script that doesn't work without the clientVars
|
2012-03-07 02:27:03 +01:00
|
|
|
BroadcastSlider = require('./broadcast_slider').loadBroadcastSliderJS(fireWhenAllScriptsAreLoaded);
|
|
|
|
require('./broadcast_revisions').loadBroadcastRevisionsJS();
|
|
|
|
changesetLoader = require('./broadcast').loadBroadcastJS(socket, sendSocketMsg, fireWhenAllScriptsAreLoaded, BroadcastSlider);
|
2012-01-19 06:39:38 +01:00
|
|
|
|
|
|
|
//initialize export ui
|
2012-03-07 02:27:03 +01:00
|
|
|
require('./pad_impexp').padimpexp.init();
|
2012-01-19 06:39:38 +01:00
|
|
|
|
|
|
|
//change export urls when the slider moves
|
|
|
|
BroadcastSlider.onSlider(function(revno)
|
|
|
|
{
|
2012-03-24 19:01:04 +01:00
|
|
|
// export_links is a jQuery Array, so .each is allowed.
|
|
|
|
export_links.each(function()
|
2012-01-19 06:39:38 +01:00
|
|
|
{
|
2015-04-29 16:39:40 +02:00
|
|
|
this.setAttribute('href', this.href.replace( /(.+?)\/[^\/]+\/(\d+\/)?export/ , '$1/' + padId + '/' + revno + '/export'));
|
2012-01-19 06:39:38 +01:00
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
//fire all start functions of these scripts, formerly fired with window.load
|
|
|
|
for(var i=0;i < fireWhenAllScriptsAreLoaded.length;i++)
|
|
|
|
{
|
|
|
|
fireWhenAllScriptsAreLoaded[i]();
|
|
|
|
}
|
2012-10-30 23:35:01 +01:00
|
|
|
$("#ui-slider-handle").css('left', $("#ui-slider-bar").width() - 2);
|
2015-04-02 01:03:34 +02:00
|
|
|
|
|
|
|
// Translate some strings where we only want to set the title not the actual values
|
|
|
|
$('#playpause_button_icon').attr("title", html10n.get("timeslider.playPause"));
|
|
|
|
$('#leftstep').attr("title", html10n.get("timeslider.backRevision"));
|
|
|
|
$('#rightstep').attr("title", html10n.get("timeslider.forwardRevision"));
|
|
|
|
|
2015-04-05 16:18:36 +02:00
|
|
|
// font family change
|
|
|
|
$("#viewfontmenu").change(function(){
|
|
|
|
var font = $("#viewfontmenu").val();
|
2018-11-08 21:56:10 +01:00
|
|
|
switch (font) {
|
|
|
|
case "monospace": setFont("Courier new");break;
|
|
|
|
case "opendyslexic": setFont("OpenDyslexic");break;
|
|
|
|
case "comicsans": setFont("Comic Sans MS");break;
|
|
|
|
case "georgia": setFont("Georgia");break;
|
|
|
|
case "impact": setFont("Impact");break;
|
|
|
|
case "lucida": setFont("Lucida");break;
|
|
|
|
case "lucidasans": setFont("Lucida Sans Unicode");break;
|
|
|
|
case "palatino": setFont("Palatino Linotype");break;
|
|
|
|
case "tahoma": setFont("Tahoma");break;
|
|
|
|
case "timesnewroman": setFont("Times New Roman");break;
|
|
|
|
case "trebuchet": setFont("Trebuchet MS");break;
|
|
|
|
case "verdana": setFont("Verdana");break;
|
|
|
|
case "symbol": setFont("Symbol");break;
|
|
|
|
case "webdings": setFont("Webdings");break;
|
|
|
|
case "wingdings": setFont("Wingdings");break;
|
|
|
|
case "sansserif": setFont("MS Sans Serif");break;
|
|
|
|
case "serif": setFont("MS Serif");break;
|
|
|
|
default: setFont("");break;
|
|
|
|
}
|
2015-04-05 16:18:36 +02:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function setFont(font){
|
|
|
|
$('#padcontent').css("font-family", font);
|
2012-01-19 06:39:38 +01:00
|
|
|
}
|
|
|
|
|
2012-04-25 10:23:58 +02:00
|
|
|
exports.baseURL = '';
|
2012-01-19 06:39:38 +01:00
|
|
|
exports.init = init;
|