var App = App || {}; App.Presenters = App.Presenters || {}; App.Presenters.RegistrationPresenter = function( jQuery, util, promise, api, topNavigationPresenter, messagePresenter) { var $el = jQuery('#content'); var template; function init() { topNavigationPresenter.select('register'); promise.wait(util.promiseTemplate('registration-form')).then(function(html) { template = _.template(html); render(); }); } function render() { $el.html(template()); $el.find('form').submit(registrationFormSubmitted); $messages = $el.find('.messages'); $messages.width($el.find('form').width()); } function registrationFormSubmitted(e) { e.preventDefault(); messagePresenter.hideMessages($messages); formData = { userName: $el.find('[name=userName]').val(), password: $el.find('[name=password]').val(), passwordConfirmation: $el.find('[name=passwordConfirmation]').val(), email: $el.find('[name=email]').val(), }; if (!validateRegistrationFormData(formData)) return; api.post('/users', formData) .then(function(response) { registrationSuccess(response); }).fail(function(response) { registrationFailure(response); }); } function registrationSuccess(apiResponse) { //todo: tell user if it turned out that he needs to confirm his e-mail $el.find('form').slideUp(function() { var message = 'Registration complete! '; message += 'Click here to login.'; messagePresenter.showInfo($messages, message); }); } function registrationFailure(apiResponse) { messagePresenter.showError($messages, apiResponse.json && apiResponse.json.error || apiResponse); } function validateRegistrationFormData(formData) { if (formData.userName.length == 0) { messagePresenter.showError($messages, 'User name cannot be empty.'); return false; } if (formData.password.length == 0) { messagePresenter.showError($messages, 'Password cannot be empty.'); return false; } if (formData.password != formData.passwordConfirmation) { messagePresenter.showError($messages, 'Passwords must be the same.'); return false; } return true; }; return { init: init, render: render, }; }; App.DI.register('registrationPresenter', App.Presenters.RegistrationPresenter);