$(function() { if ($('#organization-accounts')) new OrganizationDashboardController().init(); }); (function(){ function OrganizationDashboardController() {} OrganizationDashboardController.prototype.init = function(debugMode) { this.debugMode = debugMode !== null ? debugMode : false; this.setupListeners(); this.log('initialize'); }; OrganizationDashboardController.prototype.setupListeners = function() { this.log('setup listeners'); this.mobileSetup(); this.bindReminderButtons(); }; OrganizationDashboardController.prototype.mobileSetup = function() { if (this.isPhone()) { $('#organization-accounts button').addClass('btn-large'); } else { this.createPopover(); } }; OrganizationDashboardController.prototype.createPopover = function() { $('#organization-accounts').popover({ selector: '.status-alert', placement: 'top', template: '

' }); }; OrganizationDashboardController.prototype.bindReminderButtons = function() { this.log('bind reminder button events'); var reminderClick = function(reminderPath, button) { this.log('fire reminder callback'); this.sendReminder(reminderPath, button); }; var clickBinder = function(button){ var reminderPath = $(button).data('reminder-path'); var debouncedClickHandler = _.debounce(reminderClick, 300); // avoid button click spamming. var boundClickHandler = _.bind(debouncedClickHandler, this, reminderPath, button); $(button).click(boundClickHandler); }; var buttons = $('#organization-accounts .remind-column .btn'); _.each(buttons, clickBinder , this); }; OrganizationDashboardController.prototype.sendReminder = function(reminderPath, button) { $(button).prop('disabled', true); $.ajax({ type : 'POST', url : reminderPath, context : button, success : this.changeButton, error : this.remindError }); }; OrganizationDashboardController.prototype.changeButton = function(data, textStatus, jqXHR) { $(this).addClass('btn-success sent'); }; OrganizationDashboardController.prototype.remindError = function(jqXHR, textStatus, errorThrown) { alert($(this).data('errorMessage')); $(this).prop('disabled', false); }; OrganizationDashboardController.prototype.log = function(message) { if (!this.debugMode) return; console.log("[OrganizationDashboardController]", message); }; OrganizationDashboardController.prototype.isPhone = function() { return this.windowWidth() <= 480 ? true : false; }; OrganizationDashboardController.prototype.windowWidth = function() { return $(window).width(); }; this.OrganizationDashboardController = OrganizationDashboardController; })(this);