107 lines
3.7 KiB
JavaScript
107 lines
3.7 KiB
JavaScript
var App = App || {};
|
|
App.Presenters = App.Presenters || {};
|
|
|
|
App.Presenters.UserPresenter = function(
|
|
_,
|
|
jQuery,
|
|
util,
|
|
promise,
|
|
api,
|
|
auth,
|
|
topNavigationPresenter,
|
|
presenterManager,
|
|
userBrowsingSettingsPresenter,
|
|
userAccountSettingsPresenter,
|
|
userAccountRemovalPresenter,
|
|
messagePresenter) {
|
|
|
|
var $el = jQuery('#content');
|
|
var $messages = $el;
|
|
var templates = {};
|
|
var user;
|
|
var userName = null;
|
|
var activeTab;
|
|
|
|
function init(params, loaded) {
|
|
promise.wait(util.promiseTemplate('user'))
|
|
.then(function(template) {
|
|
templates.user = template;
|
|
reinit(params, loaded);
|
|
}).fail(function() {
|
|
console.log(arguments);
|
|
loaded();
|
|
});
|
|
}
|
|
|
|
function reinit(params, loaded) {
|
|
if (params.userName !== userName) {
|
|
userName = params.userName;
|
|
topNavigationPresenter.select(auth.isLoggedIn(userName) ? 'my-account' : 'users');
|
|
topNavigationPresenter.changeTitle(userName);
|
|
|
|
promise.wait(api.get('/users/' + userName))
|
|
.then(function(response) {
|
|
user = response.json;
|
|
var extendedContext = _.extend(params, {user: user});
|
|
|
|
presenterManager.initPresenters([
|
|
[userBrowsingSettingsPresenter, _.extend({}, extendedContext, {target: '#browsing-settings-target'})],
|
|
[userAccountSettingsPresenter, _.extend({}, extendedContext, {target: '#account-settings-target'})],
|
|
[userAccountRemovalPresenter, _.extend({}, extendedContext, {target: '#account-removal-target'})]],
|
|
function() {
|
|
initTabs(params);
|
|
loaded();
|
|
});
|
|
|
|
}).fail(function(response) {
|
|
$el.empty();
|
|
messagePresenter.showError($messages, response.json && response.json.error || response);
|
|
loaded();
|
|
});
|
|
|
|
} else {
|
|
initTabs(params);
|
|
loaded();
|
|
}
|
|
}
|
|
|
|
function initTabs(params) {
|
|
activeTab = params.tab || 'basic-info';
|
|
render();
|
|
}
|
|
|
|
function render() {
|
|
$el.html(templates.user({
|
|
user: user,
|
|
isLoggedIn: auth.isLoggedIn(user.name),
|
|
util: util,
|
|
canChangeBrowsingSettings: userBrowsingSettingsPresenter.getPrivileges().canChangeBrowsingSettings,
|
|
canChangeAccountSettings: _.any(userAccountSettingsPresenter.getPrivileges()),
|
|
canDeleteAccount: userAccountRemovalPresenter.getPrivileges().canDeleteAccount}));
|
|
$messages = $el.find('.messages');
|
|
util.loadImagesNicely($el.find('img'));
|
|
userBrowsingSettingsPresenter.render();
|
|
userAccountSettingsPresenter.render();
|
|
userAccountRemovalPresenter.render();
|
|
changeTab(activeTab);
|
|
}
|
|
|
|
function changeTab(targetTab) {
|
|
var $link = $el.find('a[data-tab=' + targetTab + ']');
|
|
var $links = $link.closest('ul').find('a[data-tab]');
|
|
var $tabs = $el.find('.tab-wrapper').find('.tab');
|
|
$links.removeClass('active');
|
|
$link.addClass('active');
|
|
$tabs.removeClass('active');
|
|
$tabs.filter('[data-tab=' + targetTab + ']').addClass('active');
|
|
}
|
|
|
|
return {
|
|
init: init,
|
|
reinit: reinit,
|
|
render: render
|
|
};
|
|
|
|
};
|
|
|
|
App.DI.register('userPresenter', ['_', 'jQuery', 'util', 'promise', 'api', 'auth', 'topNavigationPresenter', 'presenterManager', 'userBrowsingSettingsPresenter', 'userAccountSettingsPresenter', 'userAccountRemovalPresenter', 'messagePresenter'], App.Presenters.UserPresenter);
|