2016-02-12 23:52:43 +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.
|
|
|
|
*/
|
|
|
|
function toggleFormVisibility(form, edit) {
|
|
|
|
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
|
2016-08-11 22:05:23 +08:00
|
|
|
form.clearFormErrors();
|
2016-02-12 23:52:43 +08:00
|
|
|
|
|
|
|
// Clear any neccesary fields
|
|
|
|
form.find("input[data-role='clear']").val("");
|
|
|
|
|
|
|
|
// Copy field data
|
|
|
|
var val = form.find("input[data-role='src']").val();
|
|
|
|
form.find("input[data-role='edit']").val(val);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var forms = $("form[data-for]");
|
|
|
|
|
|
|
|
// Add "edit form" listeners
|
|
|
|
forms
|
|
|
|
.find("[data-action='edit']").click(function() {
|
2016-08-05 23:00:29 +08:00
|
|
|
var $form = $(this).closest("form");
|
2016-02-12 23:52:43 +08:00
|
|
|
|
|
|
|
// First, hide all form edits
|
|
|
|
_.each(forms, function(form) {
|
2016-08-05 23:00:29 +08:00
|
|
|
toggleFormVisibility($form, false);
|
2016-02-12 23:52:43 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
// Then, edit the current form
|
2016-08-05 23:00:29 +08:00
|
|
|
toggleFormVisibility($form, true);
|
2016-02-12 23:52:43 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
// Add "cancel form" listeners
|
|
|
|
forms
|
|
|
|
.find("[data-action='cancel']").click(function() {
|
2016-08-05 23:00:29 +08:00
|
|
|
var $form = $(this).closest("form");
|
2016-02-12 23:52:43 +08:00
|
|
|
|
|
|
|
// Hide the edit portion of the form
|
2016-08-05 23:00:29 +08:00
|
|
|
toggleFormVisibility($form, false);
|
2016-02-12 23:52:43 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
// Add form submit listeners
|
|
|
|
forms
|
2016-08-05 23:00:29 +08:00
|
|
|
.not("[data-for='avatar']")
|
2016-02-12 23:52:43 +08:00
|
|
|
.on("ajax:success", function(ev, data, status) {
|
|
|
|
// Simply reload the page
|
|
|
|
location.reload();
|
|
|
|
})
|
|
|
|
.on("ajax:error", function(ev, data, status) {
|
|
|
|
// Render form errors
|
2016-08-11 22:05:23 +08:00
|
|
|
$(this).renderFormErrors("user", data.responseJSON);
|
2016-02-12 23:52:43 +08:00
|
|
|
});
|
|
|
|
|
2016-08-05 23:00:29 +08:00
|
|
|
function processFile(ev, forS3) {
|
|
|
|
var $form = $(ev.target.form);
|
2016-08-11 22:05:23 +08:00
|
|
|
$form.clearFormErrors();
|
2016-02-12 23:52:43 +08:00
|
|
|
|
2016-08-05 23:00:29 +08:00
|
|
|
var $fileInput = $form.find("input[type=file]");
|
2016-10-06 22:39:54 +08:00
|
|
|
if(filesValidator(ev, $fileInput, FileTypeEnum.AVATAR)) {
|
2016-08-05 23:00:29 +08:00
|
|
|
if(forS3) {
|
|
|
|
// Redirects file uploading to S3
|
2016-08-17 15:44:53 +08:00
|
|
|
var url = "/avatar_signature.json";
|
2016-08-31 22:42:00 +08:00
|
|
|
directUpload(ev, url, true);
|
2016-08-05 23:00:29 +08:00
|
|
|
} else {
|
|
|
|
// Local file uploading
|
2016-08-11 22:05:23 +08:00
|
|
|
animateSpinner();
|
2016-02-12 23:52:43 +08:00
|
|
|
}
|
2016-08-05 23:00:29 +08:00
|
|
|
}
|
2016-02-12 23:52:43 +08:00
|
|
|
}
|