cryptpad/www/register/main.js

165 lines
5.8 KiB
JavaScript
Raw Normal View History

define([
'jquery',
'/customize/login.js',
'/common/cryptpad-common.js',
2017-06-01 08:23:50 +00:00
'/common/test.js',
'/common/common-credential.js',
'/common/common-interface.js',
2017-11-13 15:32:40 +00:00
'/common/common-util.js',
'/common/common-realtime.js',
2017-11-21 15:46:19 +00:00
'/common/common-constants.js',
2017-11-23 11:28:49 +00:00
'/common/common-feedback.js',
'/common/outer/local-store.js',
2018-03-21 17:31:53 +00:00
'css!/bower_components/components-font-awesome/css/font-awesome.min.css',
2017-11-23 11:28:49 +00:00
], function ($, Login, Cryptpad, Test, Cred, UI, Util, Realtime, Constants, Feedback, LocalStore) {
var Messages = Cryptpad.Messages;
$(function () {
var $main = $('#mainBlock');
// main block is hidden in case javascript is disabled
$main.removeClass('hidden');
// Make sure we don't display non-translated content (empty button)
$main.find('#data').removeClass('hidden');
2017-11-23 11:28:49 +00:00
if (LocalStore.isLoggedIn()) {
// already logged in, redirect to drive
document.location.href = '/drive/';
return;
} else {
$main.find('#userForm').removeClass('hidden');
}
2017-02-17 14:16:03 +00:00
// text and password input fields
var $uname = $('#username');
var $passwd = $('#password');
var $confirm = $('#password-confirm');
2020-10-30 14:13:22 +00:00
if (localStorage.login_user) {
$uname.val(localStorage.login_user);
delete localStorage.login_user;
2017-02-17 14:16:03 +00:00
}
2017-02-17 14:16:03 +00:00
[ $uname, $passwd, $confirm]
.some(function ($el) { if (!$el.val()) { $el.focus(); return true; } });
2017-02-17 14:16:03 +00:00
// checkboxes
var $checkImport = $('#import-recent');
var $checkAcceptTerms = $('#accept-terms');
2017-02-17 14:16:03 +00:00
var $register = $('button#register');
2017-06-19 12:18:10 +00:00
var registering = false;
2018-01-11 17:11:06 +00:00
var test;
var I_REALLY_WANT_TO_USE_MY_EMAIL_FOR_MY_USERNAME = false;
var registerClick = function () {
2017-02-17 14:16:03 +00:00
var uname = $uname.val();
var passwd = $passwd.val();
var confirmPassword = $confirm.val();
2017-02-17 14:16:03 +00:00
var shouldImport = $checkImport[0].checked;
var doesAccept = $checkAcceptTerms[0].checked;
if (Cred.isEmail(uname) && !I_REALLY_WANT_TO_USE_MY_EMAIL_FOR_MY_USERNAME) {
2019-08-30 14:09:38 +00:00
var emailWarning = [
Messages.register_emailWarning0,
Messages.register_emailWarning1,
Messages.register_emailWarning2,
Messages.register_emailWarning3,
].join('<br><br>');
Feedback.send("EMAIL_USERNAME_WARNING", true);
2019-08-30 14:09:38 +00:00
return void UI.confirm(emailWarning, function (yes) {
if (!yes) { return; }
I_REALLY_WANT_TO_USE_MY_EMAIL_FOR_MY_USERNAME = true;
registerClick();
}, {}, true);
}
2017-02-17 14:16:03 +00:00
/* basic validation */
if (!Cred.isLongEnoughPassword(passwd)) {
var warning = Messages._getKey('register_passwordTooShort', [
Cred.MINIMUM_PASSWORD_LENGTH
]);
return void UI.alert(warning, function () {
registering = false;
});
}
2017-02-17 14:16:03 +00:00
if (passwd !== confirmPassword) { // do their passwords match?
return void UI.alert(Messages.register_passwordsDontMatch);
2017-02-17 14:16:03 +00:00
}
2017-02-17 14:16:03 +00:00
if (!doesAccept) { // do they accept the terms of service?
return void UI.alert(Messages.register_mustAcceptTerms);
2017-02-17 14:16:03 +00:00
}
2020-10-27 16:32:26 +00:00
// XXX
Messages.register_warning = "<i class='fa fa-warning'></i> Warning"; // existing key
Messages.register_warning_note = "Due to the encrypted nature of CrytpPad even the the service administrators will not be able to recover data in case the username and/or password are forgotten. Please save them in a safe place.";
2020-10-27 16:36:04 +00:00
Messages.register_cancel = "Cancel"; // existing key
2020-10-27 16:32:26 +00:00
2017-07-04 12:56:03 +00:00
setTimeout(function () {
2020-10-27 16:32:26 +00:00
UI.confirm("<h2 class='msg'>" + Messages.register_warning + "</h2>" + Messages.register_warning_note,
2017-03-14 11:00:23 +00:00
function (yes) {
if (!yes) { return; }
Login.loginOrRegisterUI(uname, passwd, true, shouldImport, Test.testing, function () {
if (test) {
localStorage.clear();
test.pass();
return true;
}
});
2017-06-19 12:18:10 +00:00
registering = true;
2017-03-14 11:00:23 +00:00
}, {
ok: Messages.register_writtenPassword,
cancel: Messages.register_cancel,
/* If we're certain that we aren't using these "*Class" APIs
anywhere else then we can deprecate them and make this a
custom modal in common-interface (or here). */
2020-10-27 16:32:26 +00:00
cancelClass: 'btn.cancel',
okClass: 'btn.btn-danger.btn-register-confirm',
2017-03-14 11:00:23 +00:00
reverseOrder: true,
2017-09-11 14:24:43 +00:00
done: function ($dialog) {
$dialog.find('> div').addClass('half');
},
}, true);
2017-07-04 12:56:03 +00:00
}, 150);
};
$register.click(registerClick);
2017-07-04 12:56:03 +00:00
2017-11-13 15:32:40 +00:00
var clickRegister = Util.notAgainForAnother(function () {
2017-07-04 12:56:03 +00:00
$register.click();
}, 500);
$register.on('keypress', function (e) {
if (e.which === 13) {
e.preventDefault();
e.stopPropagation();
return clickRegister();
2017-07-04 12:56:03 +00:00
}
});
2017-06-01 08:23:50 +00:00
2018-01-11 17:11:06 +00:00
Test(function (t) {
test = t;
$uname.val('testuser');
2017-09-13 12:00:48 +00:00
$passwd.val('testtest');
$confirm.val('testtest');
2017-06-01 08:23:50 +00:00
$checkImport[0].checked = true;
$checkAcceptTerms[0].checked = true;
$register.click();
window.setTimeout(function () {
UI.findOKButton().click();
2017-06-01 08:23:50 +00:00
}, 1000);
});
});
});