mirror of
https://github.com/rr-/szurubooru.git
synced 2025-07-17 08:26:24 +00:00
Added account removal
This commit is contained in:
@ -14,6 +14,7 @@ App.Presenters.UserPresenter = function(
|
||||
var $messages = $el;
|
||||
var template;
|
||||
var accountSettingsTemplate;
|
||||
var accountRemovalTemplate;
|
||||
var browsingSettingsTemplate;
|
||||
var user;
|
||||
var userName;
|
||||
@ -25,11 +26,18 @@ App.Presenters.UserPresenter = function(
|
||||
promise.waitAll(
|
||||
util.promiseTemplate('user'),
|
||||
util.promiseTemplate('account-settings'),
|
||||
util.promiseTemplate('account-removal'),
|
||||
util.promiseTemplate('browsing-settings'),
|
||||
api.get('/users/' + userName))
|
||||
.then(function(userHtml, accountSettingsHtml, browsingSettingsHtml, response) {
|
||||
.then(function(
|
||||
userHtml,
|
||||
accountSettingsHtml,
|
||||
accountRemovalHtml,
|
||||
browsingSettingsHtml,
|
||||
response) {
|
||||
template = _.template(userHtml);
|
||||
accountSettingsTemplate = _.template(accountSettingsHtml);
|
||||
accountRemovalTemplate = _.template(accountRemovalHtml);
|
||||
browsingSettingsTemplate = _.template(browsingSettingsHtml);
|
||||
|
||||
user = response.json;
|
||||
@ -41,12 +49,37 @@ App.Presenters.UserPresenter = function(
|
||||
}
|
||||
|
||||
function render() {
|
||||
$el.html(template({user: user}));
|
||||
$el.find('.browsing-settings').html(browsingSettingsTemplate({user: user}));
|
||||
$el.find('.account-settings').html(accountSettingsTemplate({user: user}));
|
||||
var context = {
|
||||
user: user,
|
||||
canDeleteAccount: auth.hasPrivilege('deleteAccounts') ||
|
||||
(auth.hasPrivilege('deleteOwnAccount') && auth.getCurrentUser().name == userName),
|
||||
};
|
||||
$el.html(template(context));
|
||||
$el.find('.browsing-settings').html(browsingSettingsTemplate(context));
|
||||
$el.find('.account-settings').html(accountSettingsTemplate(context));
|
||||
$el.find('.account-removal').html(accountRemovalTemplate(context));
|
||||
$el.find('.account-removal form').submit(accountRemovalFormSubmitted);
|
||||
$messages = $el.find('.messages');
|
||||
};
|
||||
|
||||
function accountRemovalFormSubmitted(e) {
|
||||
e.preventDefault();
|
||||
$messages = $el.find('.account-removal .messages');
|
||||
messagePresenter.hideMessages($messages);
|
||||
if (!$el.find('.account-removal input[name=confirmation]:visible').prop('checked')) {
|
||||
messagePresenter.showError($messages, 'Must confirm to proceed.');
|
||||
return;
|
||||
}
|
||||
api.delete('/users/' + user.name)
|
||||
.then(function() {
|
||||
auth.logout();
|
||||
var $messageDiv = messagePresenter.showInfo($messages, 'Account deleted. <a href="">Back to main page</a>');
|
||||
$messageDiv.find('a').click(mainPageLinkClicked);
|
||||
}).fail(function(response) {
|
||||
messagePresenter.showError($messages, response.json && response.json.error || response);
|
||||
});
|
||||
}
|
||||
|
||||
return {
|
||||
init: init,
|
||||
render: render
|
||||
|
Reference in New Issue
Block a user