mirror of
https://github.com/ether/etherpad-lite.git
synced 2025-01-22 15:26:14 +01:00
160 lines
5.3 KiB
JavaScript
160 lines
5.3 KiB
JavaScript
/**
|
|
* 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.
|
|
require('./jquery');
|
|
|
|
const Cookies = require('./pad_utils').Cookies;
|
|
const randomString = require('./pad_utils').randomString;
|
|
const hooks = require('./pluginfw/hooks');
|
|
|
|
let token, padId, export_links;
|
|
|
|
function init() {
|
|
$(document).ready(() => {
|
|
// start the custom js
|
|
if (typeof customStart === 'function') customStart();
|
|
|
|
// get the padId out of the url
|
|
const urlParts = document.location.pathname.split('/');
|
|
padId = decodeURIComponent(urlParts[urlParts.length - 2]);
|
|
|
|
// set the title
|
|
document.title = `${padId.replace(/_+/g, ' ')} | ${document.title}`;
|
|
|
|
// ensure we have a token
|
|
token = Cookies.get('token');
|
|
if (token == null) {
|
|
token = `t.${randomString()}`;
|
|
Cookies.set('token', token, {expires: 60});
|
|
}
|
|
|
|
const loc = document.location;
|
|
// get the correct port
|
|
const port = loc.port == '' ? (loc.protocol == 'https:' ? 443 : 80) : loc.port;
|
|
// create the url
|
|
const url = `${loc.protocol}//${loc.hostname}:${port}/`;
|
|
// find out in which subfolder we are
|
|
const resource = `${exports.baseURL.substring(1)}socket.io`;
|
|
|
|
// build up the socket io connection
|
|
socket = io.connect(url, {path: `${exports.baseURL}socket.io`, resource});
|
|
|
|
// send the ready message once we're connected
|
|
socket.on('connect', () => {
|
|
sendSocketMsg('CLIENT_READY', {});
|
|
});
|
|
|
|
socket.on('disconnect', () => {
|
|
BroadcastSlider.showReconnectUI();
|
|
});
|
|
|
|
// route the incoming messages
|
|
socket.on('message', (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 if (message.type === 'CHANGESET_REQ') { changesetLoader.handleMessageFromServer(message); }
|
|
});
|
|
|
|
// get all the export links
|
|
export_links = $('#export > .exportlink');
|
|
|
|
$('button#forcereconnect').click(() => {
|
|
window.location.reload();
|
|
});
|
|
|
|
exports.socket = socket; // make the socket available
|
|
exports.BroadcastSlider = BroadcastSlider; // Make the slider available
|
|
|
|
hooks.aCallAll('postTimesliderInit');
|
|
});
|
|
}
|
|
|
|
// sends a message over the socket
|
|
function sendSocketMsg(type, data) {
|
|
socket.json.send({
|
|
component: 'pad', // FIXME: Remove this stupidity!
|
|
type,
|
|
data,
|
|
padId,
|
|
token,
|
|
sessionID: Cookies.get('sessionID'),
|
|
protocolVersion: 2,
|
|
});
|
|
}
|
|
|
|
const fireWhenAllScriptsAreLoaded = [];
|
|
|
|
let changesetLoader;
|
|
function handleClientVars(message) {
|
|
// save the client Vars
|
|
clientVars = message.data;
|
|
|
|
// load all script that doesn't work without the clientVars
|
|
BroadcastSlider = require('./broadcast_slider').loadBroadcastSliderJS(fireWhenAllScriptsAreLoaded);
|
|
require('./broadcast_revisions').loadBroadcastRevisionsJS();
|
|
changesetLoader = require('./broadcast').loadBroadcastJS(socket, sendSocketMsg, fireWhenAllScriptsAreLoaded, BroadcastSlider);
|
|
|
|
// initialize export ui
|
|
require('./pad_impexp').padimpexp.init();
|
|
|
|
// Create a base URI used for timeslider exports
|
|
const baseURI = document.location.pathname;
|
|
|
|
// change export urls when the slider moves
|
|
BroadcastSlider.onSlider((revno) => {
|
|
// export_links is a jQuery Array, so .each is allowed.
|
|
export_links.each(function () {
|
|
// Modified from regular expression to fix:
|
|
// https://github.com/ether/etherpad-lite/issues/4071
|
|
// Where a padId that was numeric would create the wrong export link
|
|
if (this.href) {
|
|
const type = this.href.split('export/')[1];
|
|
let href = baseURI.split('timeslider')[0];
|
|
href += `${revno}/export/${type}`;
|
|
this.setAttribute('href', href);
|
|
}
|
|
});
|
|
});
|
|
|
|
// fire all start functions of these scripts, formerly fired with window.load
|
|
for (let i = 0; i < fireWhenAllScriptsAreLoaded.length; i++) {
|
|
fireWhenAllScriptsAreLoaded[i]();
|
|
}
|
|
$('#ui-slider-handle').css('left', $('#ui-slider-bar').width() - 2);
|
|
|
|
// 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'));
|
|
|
|
// font family change
|
|
$('#viewfontmenu').change(function () {
|
|
$('#innerdocbody').css('font-family', $(this).val() || '');
|
|
});
|
|
}
|
|
|
|
exports.baseURL = '';
|
|
exports.init = init;
|