szurubooru/public_html/js/Presenters/UserAccountSettingsPresenter.js

175 lines
4.8 KiB
JavaScript
Raw Normal View History

var App = App || {};
App.Presenters = App.Presenters || {};
App.Presenters.UserAccountSettingsPresenter = function(
2014-09-08 22:02:28 +02:00
_,
jQuery,
util,
promise,
api,
auth,
messagePresenter) {
var target;
2014-10-05 10:41:12 +02:00
var templates = {};
var user;
var privileges;
var avatarContent;
2014-09-25 18:47:44 +02:00
var fileDropper;
function init(params, loaded) {
user = params.user;
target = params.target;
2014-09-17 22:37:49 +02:00
privileges = {
2014-09-30 13:22:11 +02:00
canBan:
2014-10-14 22:38:02 +02:00
auth.hasPrivilege(auth.privileges.banUsers),
2014-09-17 22:37:49 +02:00
canChangeAccessRank:
auth.hasPrivilege(auth.privileges.changeAccessRank),
canChangeAvatarStyle:
auth.hasPrivilege(auth.privileges.changeAllAvatarStyles) ||
(auth.hasPrivilege(auth.privileges.changeOwnAvatarStyle) && auth.isLoggedIn(user.name)),
canChangeName:
auth.hasPrivilege(auth.privileges.changeAllNames) ||
(auth.hasPrivilege(auth.privileges.changeOwnName) && auth.isLoggedIn(user.name)),
canChangeEmailAddress:
auth.hasPrivilege(auth.privileges.changeAllEmailAddresses) ||
(auth.hasPrivilege(auth.privileges.changeOwnEmailAddress) && auth.isLoggedIn(user.name)),
canChangePassword:
auth.hasPrivilege(auth.privileges.changeAllPasswords) ||
(auth.hasPrivilege(auth.privileges.changeOwnPassword) && auth.isLoggedIn(user.name)),
};
2014-09-17 22:37:49 +02:00
promise.wait(util.promiseTemplate('account-settings'))
2014-10-05 10:41:12 +02:00
.then(function(template) {
templates.accountRemoval = template;
render();
2014-09-17 22:37:49 +02:00
loaded();
}).fail(function() {
console.log(arguments);
loaded();
});
}
function render() {
var $el = jQuery(target);
2014-10-05 10:41:12 +02:00
$el.html(templates.accountRemoval(_.extend({user: user}, privileges)));
$el.find('form').submit(accountSettingsFormSubmitted);
$el.find('form [name=avatar-style]').change(avatarStyleChanged);
avatarStyleChanged();
2014-10-05 13:25:40 +02:00
fileDropper = new App.Controls.FileDropper($el.find('[name=avatar-content]'));
2014-09-25 18:47:44 +02:00
fileDropper.onChange = avatarContentChanged;
fileDropper.setNames = true;
}
function getPrivileges() {
return privileges;
}
function avatarStyleChanged(e) {
var $el = jQuery(target);
var $target = $el.find('.avatar-content .file-handler');
2014-09-08 22:02:28 +02:00
if ($el.find('[name=avatar-style]:checked').val() === 'manual') {
$target.show();
} else {
$target.hide();
}
}
function avatarContentChanged(files) {
2014-09-08 22:02:28 +02:00
if (files.length === 1) {
2014-09-25 18:47:44 +02:00
fileDropper.readAsDataURL(files[0], function(content) {
avatarContent = content;
});
}
}
function accountSettingsFormSubmitted(e) {
e.preventDefault();
var $el = jQuery(target);
var $messages = jQuery(target).find('.messages');
messagePresenter.hideMessages($messages);
var formData = {};
if (privileges.canChangeAvatarStyle) {
formData.avatarStyle = $el.find('[name=avatar-style]:checked').val();
2014-09-08 22:02:28 +02:00
if (avatarContent) {
formData.avatarContent = avatarContent;
2014-09-08 22:02:28 +02:00
}
}
if (privileges.canChangeName) {
formData.userName = $el.find('[name=userName]').val();
}
if (privileges.canChangeEmailAddress) {
formData.email = $el.find('[name=email]').val();
}
if (privileges.canChangePassword) {
formData.password = $el.find('[name=password]').val();
formData.passwordConfirmation = $el.find('[name=passwordConfirmation]').val();
}
if (privileges.canChangeAccessRank) {
formData.accessRank = $el.find('[name=access-rank]:checked').val();
}
2014-09-30 13:22:11 +02:00
if (privileges.canBan) {
formData.banned = $el.find('[name=ban]').is(':checked') ? 1 : 0;
}
if (!validateAccountSettingsFormData(formData)) {
return;
}
if (!formData.password) {
delete formData.password;
delete formData.passwordConfirmation;
}
promise.wait(api.post('/users/' + user.name, formData))
.then(function(response) {
editSuccess(response);
}).fail(function(response) {
editFailure(response);
});
}
function editSuccess(apiResponse) {
var wasLoggedIn = auth.isLoggedIn(user.name);
user = apiResponse.json;
if (wasLoggedIn) {
auth.updateCurrentUser(user);
}
render();
var $messages = jQuery(target).find('.messages');
var message = 'Account settings updated!';
if (!apiResponse.json.confirmed) {
message += '<br/>Check your inbox for activation e-mail.<br/>If e-mail doesn\'t show up, check your spam folder.';
}
messagePresenter.showInfo($messages, message);
}
function editFailure(apiResponse) {
var $messages = jQuery(target).find('.messages');
messagePresenter.showError($messages, apiResponse.json && apiResponse.json.error || apiResponse);
}
function validateAccountSettingsFormData(formData) {
var $messages = jQuery(target).find('.messages');
2014-09-08 22:02:28 +02:00
if (formData.password !== formData.passwordConfirmation) {
messagePresenter.showError($messages, 'Passwords must be the same.');
return false;
}
return true;
}
return {
init: init,
render: render,
getPrivileges: getPrivileges,
};
2014-09-08 22:02:28 +02:00
};
App.DI.register('userAccountSettingsPresenter', ['_', 'jQuery', 'util', 'promise', 'api', 'auth', 'messagePresenter'], App.Presenters.UserAccountSettingsPresenter);