2016-07-04 21:21:23 +08:00
|
|
|
define([
|
2016-07-12 21:53:58 +08:00
|
|
|
'/customize/messages.js',
|
2016-09-13 17:01:10 +08:00
|
|
|
'/customize/application_config.js',
|
2016-07-04 21:21:23 +08:00
|
|
|
'/common/cryptpad-common.js',
|
|
|
|
'/bower_components/lil-uri/uri.min.js',
|
2016-12-30 22:33:28 +08:00
|
|
|
'/customize/languageSelector.js',
|
2016-07-06 21:14:41 +08:00
|
|
|
'/bower_components/jquery/dist/jquery.min.js',
|
2016-12-30 22:33:28 +08:00
|
|
|
], function (Messages, Config, Cryptpad, LilUri, LS) {
|
2016-07-04 21:21:23 +08:00
|
|
|
var $ = window.$;
|
2017-02-03 01:09:27 +08:00
|
|
|
var $main = $('#mainBlock');
|
2017-01-03 19:17:17 +08:00
|
|
|
|
2016-08-31 00:15:43 +08:00
|
|
|
var APP = window.APP = {
|
|
|
|
Cryptpad: Cryptpad,
|
|
|
|
};
|
|
|
|
|
2017-02-03 01:09:27 +08:00
|
|
|
// Language selector
|
|
|
|
var $sel = $('#language-selector');
|
|
|
|
Cryptpad.createLanguageSelector(undefined, $sel);
|
|
|
|
$sel.find('button').addClass('btn').addClass('btn-secondary');
|
|
|
|
$sel.show();
|
|
|
|
|
|
|
|
$(window).click(function () {
|
|
|
|
$('.cryptpad-dropdown').hide();
|
|
|
|
});
|
|
|
|
|
2017-01-31 19:43:28 +08:00
|
|
|
// main block is hidden in case javascript is disabled
|
2017-02-03 01:09:27 +08:00
|
|
|
$main.removeClass('hidden');
|
2017-01-31 19:43:28 +08:00
|
|
|
|
2017-02-03 01:09:27 +08:00
|
|
|
// Make sure we don't display non-translated content (empty button)
|
|
|
|
$main.find('#data').removeClass('hidden');
|
|
|
|
|
|
|
|
if (Cryptpad.isLoggedIn()) {
|
|
|
|
var name = localStorage[Cryptpad.userNameKey] || sessionStorage[Cryptpad.userNameKey];
|
|
|
|
var $loggedInBlock = $main.find('#loggedIn');
|
|
|
|
var $hello = $loggedInBlock.find('#loggedInHello');
|
|
|
|
var $logout = $loggedInBlock.find('#loggedInLogOut');
|
2016-07-04 21:21:23 +08:00
|
|
|
|
2017-02-03 01:09:27 +08:00
|
|
|
$hello.text(Messages._getKey('login_hello', [name]));
|
|
|
|
$('#buttons').find('.nologin').hide();
|
|
|
|
|
|
|
|
$logout.click(function () {
|
|
|
|
Cryptpad.logout(function () {
|
|
|
|
window.location.reload();
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
$loggedInBlock.removeClass('hidden');
|
|
|
|
//return;
|
|
|
|
} else {
|
|
|
|
$main.find('#userForm').removeClass('hidden');
|
|
|
|
}
|
2016-07-04 21:21:23 +08:00
|
|
|
|
2016-09-13 17:01:10 +08:00
|
|
|
var displayCreateButtons = function () {
|
2016-11-07 18:43:49 +08:00
|
|
|
var $parent = $('#buttons');
|
2017-02-01 01:16:35 +08:00
|
|
|
var options = [];
|
2016-09-13 17:01:10 +08:00
|
|
|
Config.availablePadTypes.forEach(function (el) {
|
2017-02-03 01:40:39 +08:00
|
|
|
if (el === 'drive') { return; }
|
2017-02-01 01:16:35 +08:00
|
|
|
options.push({
|
|
|
|
tag: 'a',
|
|
|
|
attributes: {
|
|
|
|
'class': 'newdoc',
|
|
|
|
'href': '/' + el,
|
|
|
|
'target': '_blank'
|
|
|
|
},
|
|
|
|
content: Messages['button_new' + el] // Pretty name of the language value
|
|
|
|
});
|
2016-09-13 17:01:10 +08:00
|
|
|
});
|
2017-02-01 01:16:35 +08:00
|
|
|
var dropdownConfig = {
|
|
|
|
text: Messages.makeAPad, // Button initial text
|
|
|
|
options: options, // Entries displayed in the menu
|
|
|
|
};
|
|
|
|
var $block = Cryptpad.createDropdown(dropdownConfig);
|
|
|
|
$block.find('button').addClass('btn').addClass('btn-success');
|
|
|
|
$block.appendTo($parent);
|
2016-09-13 17:01:10 +08:00
|
|
|
};
|
2017-01-17 18:52:44 +08:00
|
|
|
var addButtonHandlers = function () {
|
|
|
|
$('button.login').click(function (e) {
|
|
|
|
var username = $('#name').val();
|
|
|
|
var passwd = $('#password').val();
|
|
|
|
var remember = $('#rememberme').is(':checked');
|
|
|
|
sessionStorage.login_user = username;
|
|
|
|
sessionStorage.login_pass = passwd;
|
|
|
|
sessionStorage.login_rmb = remember;
|
|
|
|
sessionStorage.login = 1;
|
|
|
|
document.location.href = '/user';
|
|
|
|
});
|
|
|
|
$('button.register').click(function (e) {
|
|
|
|
var username = $('#name').val();
|
|
|
|
var passwd = $('#password').val();
|
|
|
|
var remember = $('#rememberme').is(':checked');
|
|
|
|
sessionStorage.login_user = username;
|
|
|
|
sessionStorage.login_pass = passwd;
|
|
|
|
sessionStorage.login_rmb = remember;
|
|
|
|
sessionStorage.register = 1;
|
|
|
|
document.location.href = '/user';
|
|
|
|
});
|
|
|
|
$('button.nologin').click(function (e) {
|
|
|
|
document.location.href = '/drive';
|
|
|
|
});
|
2017-01-19 01:02:32 +08:00
|
|
|
$('button.knowmore').click(function (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
|
|
|
|
$('html, body').animate({
|
|
|
|
scrollTop: $('#knowmore').offset().top
|
|
|
|
}, 500);
|
|
|
|
});
|
|
|
|
$('button.tryit').click(function (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
|
|
|
|
$('html, body').animate({
|
|
|
|
scrollTop: $('#tryit').offset().top
|
|
|
|
}, 500);
|
|
|
|
});
|
2017-02-01 00:29:32 +08:00
|
|
|
|
|
|
|
var $passwd = $('#password');
|
|
|
|
$passwd.on('keyup', function (e) {
|
|
|
|
if (e.which !== 13) { return; } // enter
|
|
|
|
$('button.login').click();
|
|
|
|
});
|
2017-01-17 18:52:44 +08:00
|
|
|
};
|
|
|
|
|
2016-12-22 18:02:12 +08:00
|
|
|
displayCreateButtons();
|
2016-08-31 00:15:43 +08:00
|
|
|
|
2017-02-01 00:29:32 +08:00
|
|
|
addButtonHandlers();
|
|
|
|
console.log("ready");
|
2016-07-04 21:21:23 +08:00
|
|
|
});
|
|
|
|
|