scinote-web/app/assets/javascripts/users/registrations/edit.js

116 lines
3.9 KiB
JavaScript
Raw Normal View History

2018-07-23 17:26:09 +08:00
(function() {
'use strict';
2016-02-12 23:52:43 +08:00
2018-07-23 17:26:09 +08:00
/**
* Toggle the view/edit form visibility.
* @param form - The jQuery form selector.
* @param edit - True to set form to edit mode;
* false to set form to view mode.
*/
2016-02-12 23:52:43 +08:00
2018-07-23 17:26:09 +08:00
/* global _ filesValidator animateSpinner FileTypeEnum */
2016-02-12 23:52:43 +08:00
2018-07-23 17:26:09 +08:00
var forms = $('form[data-for]');
function toggleFormVisibility(form, edit) {
2016-02-12 23:52:43 +08:00
var val = form.find("input[data-role='src']").val();
2018-07-23 17:26:09 +08:00
if (edit) {
form.find("[data-part='view']").hide();
form.find("[data-part='edit']").show();
form.find("[data-part='edit'] input:not([type='file']):not([type='submit']):first").focus();
} else {
form.find("[data-part='view']").show();
form.find("[data-part='edit'] input").blur();
form.find("[data-part='edit']").hide();
// Clear all errors on the parent form
form.clearFormErrors();
// Clear any neccesary fields
form.find("input[data-role='clear']").val('');
// Copy field data
form.find("input[data-role='edit']").val(val);
}
2016-02-12 23:52:43 +08:00
}
2018-07-23 17:26:09 +08:00
// Add "edit form" listeners
forms.find("[data-action='edit']").click(function(ev) {
var $form = $(this).closest('form');
ev.preventDefault();
// First, hide all form edits
_.each(forms, function() {
toggleFormVisibility($form, false);
});
2016-02-12 23:52:43 +08:00
2018-07-23 17:26:09 +08:00
// Then, edit the current form
toggleFormVisibility($form, true);
2016-02-12 23:52:43 +08:00
});
2018-07-23 17:26:09 +08:00
// Add "cancel form" listeners
forms.find("[data-action='cancel']").click(function(ev) {
var $form = $(this).closest('form');
ev.preventDefault();
2016-02-12 23:52:43 +08:00
2018-07-23 17:26:09 +08:00
// Hide the edit portion of the form
toggleFormVisibility($form, false);
});
2016-02-12 23:52:43 +08:00
2018-07-23 17:26:09 +08:00
// Add form submit listeners
forms.not("[data-for='avatar']")
.on('ajax:success', function() {
// Simply reload the page
location.reload();
})
.on('ajax:error', function(ev, data) {
// Render form errors
$(this).renderFormErrors('user', data.responseJSON);
});
2016-02-12 23:52:43 +08:00
$('#user-avatar-field :submit').click(function(ev) {
2018-07-23 17:26:09 +08:00
var $form = $(ev.target.form);
var $fileInput = $form.find('input[type=file]');
$form.clearFormErrors();
2016-02-12 23:52:43 +08:00
2018-07-23 17:26:09 +08:00
if (filesValidator(ev, $fileInput, FileTypeEnum.AVATAR)) {
// Local file uploading
animateSpinner();
}
$fileInput[0].value = '';
});
2020-06-29 16:56:06 +08:00
2020-07-01 17:07:33 +08:00
$('#twoFactorAuthenticationDisable').click(function() {
2020-06-29 16:56:06 +08:00
$('#twoFactorAuthenticationModal').modal('show');
});
2020-07-01 17:07:33 +08:00
$('#twoFactorAuthenticationEnable').click(function() {
$.get(this.dataset.qrCodeUrl, function(result) {
$('#twoFactorAuthenticationModal .qr-code').html(result.qr_code);
2020-07-07 18:59:48 +08:00
$('#twoFactorAuthenticationModal').find('[href="#2fa-step-1"]').tab('show');
2020-07-01 17:07:33 +08:00
$('#twoFactorAuthenticationModal').modal('show');
2020-07-27 19:42:51 +08:00
$('#twoFactorAuthenticationModal').find('.submit-code-field').removeClass('error').find('#submit_code').val('');
2020-07-01 17:07:33 +08:00
});
});
$('#twoFactorAuthenticationModal .2fa-enable-form').on('ajax:error', function(e, data) {
$(this).find('.submit-code-field').addClass('error').attr('data-error-text', data.responseJSON.error);
2020-07-09 23:01:00 +08:00
}).on('ajax:success', function(e, data) {
var blob = new Blob([data.recovery_codes.join('\r\n')], { type: 'text/plain;charset=utf-8' });
$('#twoFactorAuthenticationModal').find('.recovery-codes').html(data.recovery_codes.join('<br>'));
$('#twoFactorAuthenticationModal').find('[href="#2fa-step-4"]').tab('show');
$('.download-recovery-codes').attr('href', window.URL.createObjectURL(blob));
$('#twoFactorAuthenticationModal').one('hide.bs.modal', function() {
location.reload();
});
2020-07-01 17:07:33 +08:00
});
$('#twoFactorAuthenticationModal .2fa-disable-form').on('ajax:error', function(e, data) {
$(this).find('.password-field').addClass('error').attr('data-error-text', data.responseJSON.error);
});
2020-07-07 18:59:48 +08:00
$('#twoFactorAuthenticationModal').on('click', '.btn-next-step', function() {
$('#twoFactorAuthenticationModal').find(`[href="${$(this).data('step')}"]`).tab('show');
2020-07-07 21:59:02 +08:00
});
2018-07-23 17:26:09 +08:00
}());