2011-12-04 15:33:56 +00: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
|
|
|
|
*/
|
|
|
|
|
2011-03-26 13:10:41 +00:00
|
|
|
/**
|
|
|
|
* Copyright 2009 Google Inc.
|
2011-07-07 18:59:34 +01:00
|
|
|
*
|
2011-03-26 13:10:41 +00: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 18:59:34 +01:00
|
|
|
*
|
2011-03-26 13:10:41 +00:00
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
2011-07-07 18:59:34 +01:00
|
|
|
*
|
2011-03-26 13:10:41 +00: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-02-20 23:16:25 +01:00
|
|
|
var padutils = require('/pad_utils').padutils,
|
|
|
|
padeditor = require('/pad_editor').padeditor,
|
|
|
|
padsavedrevs = require('/pad_savedrevs').padsavedrevs;
|
2012-01-15 21:37:47 -08:00
|
|
|
|
2012-02-06 12:36:45 -08:00
|
|
|
function indexOf(array, value) {
|
2012-02-20 23:16:25 +01:00
|
|
|
for (var i=0, ii=array.length; i < ii; i++) {
|
|
|
|
if (array[i] == value)
|
2012-02-06 12:36:45 -08:00
|
|
|
return i;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2012-02-20 23:16:25 +01:00
|
|
|
var padeditbar = (function() {
|
|
|
|
var syncAnimation = (function() {
|
|
|
|
var SYNCING = -100,
|
|
|
|
DONE = 100,
|
|
|
|
state = DONE,
|
|
|
|
fps = 25,
|
|
|
|
step = 1 / fps,
|
|
|
|
T_START = -0.5,
|
|
|
|
T_FADE = 1.0,
|
|
|
|
T_GONE = 1.5;
|
|
|
|
var animator = padutils.makeAnimationScheduler(function() {
|
2011-07-07 18:59:34 +01:00
|
|
|
if (state == SYNCING || state == DONE)
|
2011-03-26 13:10:41 +00:00
|
|
|
return false;
|
2012-02-20 23:16:25 +01:00
|
|
|
else if (state >= T_GONE) {
|
2011-03-26 13:10:41 +00:00
|
|
|
state = DONE;
|
2012-02-20 23:16:25 +01:00
|
|
|
$('#syncstatussyncing, #syncstatusdone').hide();
|
2011-03-26 13:10:41 +00:00
|
|
|
return false;
|
2012-02-20 23:16:25 +01:00
|
|
|
} else if (state < 0) {
|
2011-03-26 13:10:41 +00:00
|
|
|
state += step;
|
2012-02-20 23:16:25 +01:00
|
|
|
if (state >= 0) {
|
|
|
|
$('#syncstatussyncing').hide();
|
|
|
|
$('#syncstatusdone').show().css({opacity: 1});
|
2011-03-26 13:10:41 +00:00
|
|
|
}
|
|
|
|
return true;
|
2012-02-20 23:16:25 +01:00
|
|
|
} else {
|
2011-03-26 13:10:41 +00:00
|
|
|
state += step;
|
2011-07-07 18:59:34 +01:00
|
|
|
if (state >= T_FADE)
|
2012-02-20 23:16:25 +01:00
|
|
|
$('#syncstatusdone').css('opacity', (T_GONE - state) / (T_GONE - T_FADE));
|
2011-03-26 13:10:41 +00:00
|
|
|
return true;
|
|
|
|
}
|
2011-07-07 18:59:34 +01:00
|
|
|
}, step * 1000);
|
2011-03-26 13:10:41 +00:00
|
|
|
return {
|
2012-02-20 23:16:25 +01:00
|
|
|
syncing: function() {
|
2011-03-26 13:10:41 +00:00
|
|
|
state = SYNCING;
|
2012-02-20 23:16:25 +01:00
|
|
|
$('#syncstatussyncing').show();
|
|
|
|
$('#syncstatusdone').hide();
|
2011-03-26 13:10:41 +00:00
|
|
|
},
|
2012-02-20 23:16:25 +01:00
|
|
|
done: function() {
|
2011-03-26 13:10:41 +00:00
|
|
|
state = T_START;
|
|
|
|
animator.scheduleAnimation();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}());
|
|
|
|
|
|
|
|
var self = {
|
2012-02-20 23:16:25 +01:00
|
|
|
init: function() {
|
|
|
|
$('#editbar A').attr('unselectable', 'on'); // for IE
|
|
|
|
$('#editbar').removeClass('disabledtoolbar').addClass('enabledtoolbar');
|
2011-03-26 13:10:41 +00:00
|
|
|
},
|
2012-02-20 23:16:25 +01:00
|
|
|
isEnabled: function() {
|
2011-07-19 17:42:19 +01:00
|
|
|
// return !$("#editbar").hasClass('disabledtoolbar');
|
|
|
|
return true;
|
2011-03-26 13:10:41 +00:00
|
|
|
},
|
2012-02-20 23:16:25 +01:00
|
|
|
disable: function() {
|
|
|
|
$('#editbar').addClass('disabledtoolbar').removeClass('enabledtoolbar');
|
2011-03-26 13:10:41 +00:00
|
|
|
},
|
2012-02-20 23:16:25 +01:00
|
|
|
toolbarClick: function(cmd) {
|
|
|
|
if (self.isEnabled()) {
|
|
|
|
switch(cmd) {
|
|
|
|
case 'showusers':
|
|
|
|
self.toggleDropDown('usersmenu');
|
|
|
|
break;
|
|
|
|
case 'settings':
|
|
|
|
self.toggleDropDown('settingsmenu');
|
|
|
|
break;
|
|
|
|
case 'embed':
|
|
|
|
self.setEmbedLinks();
|
|
|
|
self.toggleDropDown('embedmenu');
|
|
|
|
break;
|
|
|
|
case 'import_export':
|
|
|
|
self.toggleDropDown('importexportmenu');
|
|
|
|
break;
|
|
|
|
case 'save':
|
|
|
|
padsavedrevs.saveNow();
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
padeditor.ace.callWithAce(function(ace) {
|
|
|
|
if (cmd == 'bold' || cmd == 'italic' || cmd == 'underline' || cmd == 'strikethrough')
|
|
|
|
ace.ace_toggleAttributeOnSelection(cmd);
|
|
|
|
else if (cmd == 'undo' || cmd == 'redo')
|
|
|
|
ace.ace_doUndoRedo(cmd);
|
|
|
|
else if (cmd == 'insertunorderedlist')
|
2011-07-07 18:59:34 +01:00
|
|
|
ace.ace_doInsertUnorderedList();
|
2012-02-20 23:16:25 +01:00
|
|
|
else if (cmd == 'insertorderedlist')
|
|
|
|
ace.ace_doInsertOrderedList();
|
|
|
|
else if (cmd == 'indent') {
|
|
|
|
if (!ace.ace_doIndentOutdent(false))
|
|
|
|
ace.ace_doInsertUnorderedList();
|
|
|
|
} else if (cmd == 'outdent')
|
|
|
|
ace.ace_doIndentOutdent(true);
|
|
|
|
else if (cmd == 'clearauthorship') {
|
|
|
|
if ((!(ace.ace_getRep().selStart && ace.ace_getRep().selEnd)) || ace.ace_isCaret()) {
|
|
|
|
if (window.confirm("Clear authorship colors on entire document?")) {
|
|
|
|
ace.ace_performDocumentApplyAttributesToCharRange(0, ace.ace_getRep().alltext.length, [
|
|
|
|
['author', '']
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ace.ace_setAttributeOnSelection('author', '');
|
2011-07-07 18:59:34 +01:00
|
|
|
}
|
|
|
|
}
|
2012-02-20 23:16:25 +01:00
|
|
|
}, cmd, true);
|
2011-03-26 13:10:41 +00:00
|
|
|
}
|
|
|
|
}
|
2012-02-20 23:16:25 +01:00
|
|
|
if (padeditor.ace)
|
|
|
|
padeditor.ace.focus();
|
2011-03-26 13:10:41 +00:00
|
|
|
},
|
2012-02-20 23:16:25 +01:00
|
|
|
toggleDropDown: function(moduleName) {
|
|
|
|
var modules = ['settingsmenu', 'importexportmenu', 'embedmenu', 'usersmenu'];
|
|
|
|
// hide all modules
|
|
|
|
if (moduleName == 'none') {
|
|
|
|
$('#editbar UL.right LI').removeClass('selected');
|
|
|
|
for (var i=0, l=modules.length; i < l; i++) {
|
|
|
|
// skip the userlist
|
|
|
|
if (modules[i] == 'users')
|
2011-08-21 19:07:35 +01:00
|
|
|
continue;
|
2012-02-20 23:16:25 +01:00
|
|
|
var module = $('#' + modules[i]);
|
|
|
|
if (module.is(':visible'))
|
|
|
|
module.slideUp(250);
|
2011-07-08 15:19:38 +01:00
|
|
|
}
|
2012-02-20 23:16:25 +01:00
|
|
|
} else {
|
2012-02-06 12:36:45 -08:00
|
|
|
var nth_child = indexOf(modules, moduleName) + 1;
|
2012-02-20 23:16:25 +01:00
|
|
|
if (nth_child > 0 && nth_child <= 3) {
|
|
|
|
$('#editbar UL.right LI:not(:nth-child(' + nth_child + '))').removeClass('selected');
|
|
|
|
$('#editbar UL.right LI:nth-child(' + nth_child + ')').toggleClass('selected');
|
|
|
|
}
|
|
|
|
// hide all modules that are not selected and show the selected one
|
|
|
|
for (i=0, l=modules.length; i < l; i++) {
|
|
|
|
module = $('#' + modules[i]);
|
|
|
|
if (module.is(':visible'))
|
|
|
|
module.slideUp(250);
|
|
|
|
else if (modules[i] == moduleName)
|
|
|
|
module.slideDown(250);
|
2011-07-08 15:19:38 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
2012-02-20 23:16:25 +01:00
|
|
|
setSyncStatus: function(status) {
|
|
|
|
if (status == 'syncing')
|
2011-03-26 13:10:41 +00:00
|
|
|
syncAnimation.syncing();
|
2012-02-20 23:16:25 +01:00
|
|
|
else if (status == 'done')
|
2011-03-26 13:10:41 +00:00
|
|
|
syncAnimation.done();
|
2011-11-24 16:34:28 +01:00
|
|
|
},
|
2012-02-20 23:16:25 +01:00
|
|
|
setEmbedLinks: function() {
|
|
|
|
if ($('#readonlyinput').is(':checked')) {
|
|
|
|
var basePath = document.location.href.substring(0, document.location.href.indexOf('/p/')),
|
|
|
|
readonlyLink = basePath + '/ro/' + clientVars.readOnlyId;
|
2011-11-24 16:34:28 +01:00
|
|
|
$('#embedinput').val("<iframe src='" + readonlyLink + "?showControls=true&showChat=true&showLineNumbers=true&useMonospaceFont=false' width=600 height=400>");
|
|
|
|
$('#linkinput').val(readonlyLink);
|
2012-02-20 23:16:25 +01:00
|
|
|
$('#embedreadonlyqr').attr('src', 'https://chart.googleapis.com/chart?chs=200x200&cht=qr&chld=H|0&chl=' + readonlyLink);
|
|
|
|
} else {
|
|
|
|
var padurl = window.location.href.split('?')[0];
|
2011-11-24 16:34:28 +01:00
|
|
|
$('#embedinput').val("<iframe src='" + padurl + "?showControls=true&showChat=true&showLineNumbers=true&useMonospaceFont=false' width=600 height=400>");
|
|
|
|
$('#linkinput').val(padurl);
|
2012-02-20 23:16:25 +01:00
|
|
|
$('#embedreadonlyqr').attr('src', "https://chart.googleapis.com/chart?chs=200x200&cht=qr&chld=H|0&chl=" + padurl);
|
2011-11-24 16:34:28 +01:00
|
|
|
}
|
2011-03-26 13:10:41 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
return self;
|
2011-03-26 14:50:13 +00:00
|
|
|
}());
|
2012-01-15 17:23:48 -08:00
|
|
|
|
2012-02-20 23:16:25 +01:00
|
|
|
exports.padeditbar = padeditbar;
|