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

230 lines
8.4 KiB
JavaScript
Raw Normal View History

/**
* 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
*/
2011-03-26 14:10:41 +01:00
/**
* Copyright 2009 Google Inc.
2011-07-07 19:59:34 +02:00
*
2011-03-26 14:10:41 +01:00
* 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
2011-07-07 19:59:34 +02:00
*
2011-03-26 14:10:41 +01:00
* http://www.apache.org/licenses/LICENSE-2.0
2011-07-07 19:59:34 +02:00
*
2011-03-26 14:10:41 +01:00
* 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-03-07 02:27:03 +01:00
var padcookie = require('./pad_cookie').padcookie;
var padutils = require('./pad_utils').padutils;
2011-03-26 14:10:41 +01:00
2011-07-07 19:59:34 +02:00
var padeditor = (function()
{
var Ace2Editor = undefined;
var pad = undefined;
var settings = undefined;
// Array of available fonts
var fonts = ['useMonospaceFont', 'useMontserratFont', 'useOpenDyslexicFont', 'useComicSansFont', 'useCourierNewFont',
'useGeorgiaFont', 'useImpactFont', 'useLucidaFont', 'useLucidaSansFont', 'usePalatinoFont', 'useRobotoMonoFont',
'useTahomaFont', 'useTimesNewRomanFont', 'useTrebuchetFont', 'useVerdanaFont', 'useSymbolFont', 'useWebdingsFont',
'useWingDingsFont', 'useSansSerifFont', 'useSerifFont'];
2011-03-26 14:10:41 +01:00
var self = {
2011-07-07 19:59:34 +02:00
ace: null,
// this is accessed directly from other files
2011-03-26 14:10:41 +01:00
viewZoom: 100,
init: function(readyFunc, initialViewOptions, _pad)
2011-07-07 19:59:34 +02:00
{
2012-03-07 02:27:03 +01:00
Ace2Editor = require('./ace').Ace2Editor;
pad = _pad;
settings = pad.settings;
2011-03-26 14:10:41 +01:00
2011-07-07 19:59:34 +02:00
function aceReady()
{
2011-03-26 14:10:41 +01:00
$("#editorloadingbox").hide();
2011-07-07 19:59:34 +02:00
if (readyFunc)
{
2011-03-26 14:10:41 +01:00
readyFunc();
}
}
self.ace = new Ace2Editor();
self.ace.init("editorcontainer", "", aceReady);
self.ace.setProperty("wraps", true);
2011-07-07 19:59:34 +02:00
if (pad.getIsDebugEnabled())
{
2011-03-26 14:10:41 +01:00
self.ace.setProperty("dmesg", pad.dmesg);
}
self.initViewOptions();
self.setViewOptions(initialViewOptions);
// view bar
$("#viewbarcontents").show();
},
2011-07-07 19:59:34 +02:00
initViewOptions: function()
{
// Line numbers
2011-07-07 19:59:34 +02:00
padutils.bindCheckboxChange($("#options-linenoscheck"), function()
{
pad.changeViewOption('showLineNumbers', padutils.getCheckbox($("#options-linenoscheck")));
2011-03-26 14:10:41 +01:00
});
// Author colors
2011-07-07 19:59:34 +02:00
padutils.bindCheckboxChange($("#options-colorscheck"), function()
{
padcookie.setPref('showAuthorshipColors', padutils.getCheckbox("#options-colorscheck"));
2011-07-07 19:59:34 +02:00
pad.changeViewOption('showAuthorColors', padutils.getCheckbox("#options-colorscheck"));
2011-03-26 14:10:41 +01:00
});
// Right to left
padutils.bindCheckboxChange($("#options-rtlcheck"), function()
{
pad.changeViewOption('rtlIsTrue', padutils.getCheckbox($("#options-rtlcheck")))
});
html10n.bind('localized', function() {
pad.changeViewOption('rtlIsTrue', ('rtl' == html10n.getDirection()));
padutils.setCheckbox($("#options-rtlcheck"), ('rtl' == html10n.getDirection()));
})
// font family change
2011-07-07 19:59:34 +02:00
$("#viewfontmenu").change(function()
{
$.each(fonts, function(i, font){
var sfont = font.replace("use","");
sfont = sfont.replace("Font","");
sfont = sfont.toLowerCase();
pad.changeViewOption(font, $("#viewfontmenu").val() == sfont);
});
2011-03-26 14:10:41 +01:00
});
// Language
html10n.bind('localized', function() {
$("#languagemenu").val(html10n.getLanguage());
// translate the value of 'unnamed' and 'Enter your name' textboxes in the userlist
// this does not interfere with html10n's normal value-setting because html10n just ingores <input>s
// also, a value which has been set by the user will be not overwritten since a user-edited <input>
// does *not* have the editempty-class
$('input[data-l10n-id]').each(function(key, input){
input = $(input);
if(input.hasClass("editempty")){
input.val(html10n.get(input.attr("data-l10n-id")));
}
});
})
$("#languagemenu").val(html10n.getLanguage());
2012-11-12 16:49:15 +01:00
$("#languagemenu").change(function() {
pad.createCookie("language",$("#languagemenu").val(),null,'/');
2012-12-19 17:21:22 +01:00
window.html10n.localize([$("#languagemenu").val(), 'en']);
2012-11-12 16:49:15 +01:00
});
2011-03-26 14:10:41 +01:00
},
2011-07-07 19:59:34 +02:00
setViewOptions: function(newOptions)
{
function getOption(key, defaultValue)
{
2011-03-26 14:10:41 +01:00
var value = String(newOptions[key]);
if (value == "true") return true;
if (value == "false") return false;
return defaultValue;
}
2011-03-26 14:10:41 +01:00
var v;
v = getOption('rtlIsTrue', ('rtl' == html10n.getDirection()));
2012-10-29 22:55:57 +01:00
self.ace.setProperty("rtlIsTrue", v);
padutils.setCheckbox($("#options-rtlcheck"), v);
2012-10-29 22:55:57 +01:00
2011-03-26 14:10:41 +01:00
v = getOption('showLineNumbers', true);
self.ace.setProperty("showslinenumbers", v);
padutils.setCheckbox($("#options-linenoscheck"), v);
v = getOption('showAuthorColors', true);
self.ace.setProperty("showsauthorcolors", v);
padutils.setCheckbox($("#options-colorscheck"), v);
// Override from parameters if true
if (settings.noColors !== false){
self.ace.setProperty("showsauthorcolors", !settings.noColors);
}
var normalFont = true;
// Go through each font and see if the option is set..
$.each(fonts, function(i, font){
var isEnabled = getOption(font, false);
if(isEnabled){
font = font.replace("use","");
font = font.replace("Font","");
font = font.toLowerCase();
if(font === "monospace") self.ace.setProperty("textface", "monospace");
if(font === "montserrat") self.ace.setProperty("textface", "Montserrat");
2015-04-05 15:03:09 +02:00
if(font === "opendyslexic") self.ace.setProperty("textface", "OpenDyslexic");
if(font === "comicsans") self.ace.setProperty("textface", "'Comic Sans MS','Comic Sans',cursive");
if(font === "georgia") self.ace.setProperty("textface", "Georgia,'Bitstream Charter',serif");
if(font === "impact") self.ace.setProperty("textface", "Impact,Haettenschweiler,'Arial Black',sans-serif");
if(font === "lucida") self.ace.setProperty("textface", "Lucida,'Lucida Serif','Lucida Bright',serif");
if(font === "lucidasans") self.ace.setProperty("textface", "'Lucida Sans','Lucida Grande','Lucida Sans Unicode','Luxi Sans',sans-serif");
if(font === "palatino") self.ace.setProperty("textface", "Palatino,'Palatino Linotype','URW Palladio L',Georgia,serif");
if(font === "robotomono") self.ace.setProperty("textface", "RobotoMono");
if(font === "tahoma") self.ace.setProperty("textface", "Tahoma,sans-serif");
if(font === "timesnewroman") self.ace.setProperty("textface", "'Times New Roman',Times,serif");
if(font === "trebuchet") self.ace.setProperty("textface", "'Trebuchet MS',sans-serif");
if(font === "verdana") self.ace.setProperty("textface", "Verdana,'DejaVu Sans',sans-serif");
if(font === "symbol") self.ace.setProperty("textface", "Symbol");
if(font === "webdings") self.ace.setProperty("textface", "Webdings");
if(font === "wingdings") self.ace.setProperty("textface", "Wingdings");
if(font === "sansserif") self.ace.setProperty("textface", "sans-serif");
if(font === "serif") self.ace.setProperty("textface", "serif");
// $("#viewfontmenu").val(font);
normalFont = false;
}
});
// No font has been previously selected so use the Normal font
if(normalFont){
self.ace.setProperty("textface", "'Helvetica Neue',Arial, sans-serif");
// $("#viewfontmenu").val("normal");
}
2011-03-26 14:10:41 +01:00
},
2011-07-07 19:59:34 +02:00
dispose: function()
{
if (self.ace)
{
2011-03-26 14:10:41 +01:00
self.ace.destroy();
self.ace = null;
2011-03-26 14:10:41 +01:00
}
},
enable: function()
{
if (self.ace)
{
self.ace.setEditable(true);
}
},
2011-07-07 19:59:34 +02:00
disable: function()
{
if (self.ace)
{
2011-03-26 14:10:41 +01:00
self.ace.setProperty("grayedOut", true);
self.ace.setEditable(false);
}
},
2011-07-07 19:59:34 +02:00
restoreRevisionText: function(dataFromServer)
{
2011-03-26 14:10:41 +01:00
pad.addHistoricalAuthors(dataFromServer.historicalAuthorData);
self.ace.importAText(dataFromServer.atext, dataFromServer.apool, true);
}
};
return self;
}());
exports.padeditor = padeditor;