pad.libre-service.eu-etherpad/src/static/js/timeslider.js

170 lines
5.2 KiB
JavaScript
Raw Normal View History

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.
*/
// 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-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 ()
{
// 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
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)
{
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';
2012-01-19 06:39:38 +01:00
//build up the socket io connection
socket = io.connect(url, {path: exports.baseURL + 'socket.io', resource: resource});
2012-01-19 06:39:38 +01:00
//send the ready message once we're connected
socket.on('connect', function()
{
sendSocketMsg("CLIENT_READY", {});
});
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>")
} 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')
$('button#forcereconnect').click(function()
{
window.location.reload();
});
2013-02-18 22:03:52 +01:00
exports.socket = socket; // make the socket available
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)
{
var sessionID = decodeURIComponent(readCookie("sessionID"));
2012-01-19 06:39:38 +01:00
var password = readCookie("password");
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 = [];
var changesetLoader;
2012-01-19 06:39:38 +01:00
function handleClientVars(message)
{
//save the client Vars
clientVars = message.data;
//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)
{
// export_links is a jQuery Array, so .each is allowed.
export_links.each(function()
2012-01-19 06:39:38 +01:00
{
this.setAttribute('href', this.href.replace( /(.+?)\/\w+\/(\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]();
}
$("#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"));
2012-01-19 06:39:38 +01:00
}
exports.baseURL = '';
2012-01-19 06:39:38 +01:00
exports.init = init;