'use strict'; define('postSelect', ['components'], function (components) { var PostSelect = {}; PostSelect.pids = []; PostSelect.init = function (onSelect) { PostSelect.pids.length = 0; components.get('topic').on('click', '[data-pid]', function () { PostSelect.togglePostSelection($(this), onSelect); }); disableClicksOnPosts(); }; PostSelect.disable = function () { PostSelect.pids.forEach(function (pid) { components.get('post', 'pid', pid).toggleClass('bg-success', false); }); components.get('topic').off('click', '[data-pid]'); enableClicksOnPosts(); }; PostSelect.togglePostSelection = function (post, callback) { var newPid = post.attr('data-pid'); if (parseInt(post.attr('data-index'), 10) === 0) { return; } if (newPid) { var index = PostSelect.pids.indexOf(newPid); if (index === -1) { PostSelect.pids.push(newPid); post.toggleClass('bg-success', true); } else { PostSelect.pids.splice(index, 1); post.toggleClass('bg-success', false); } if (PostSelect.pids.length) { PostSelect.pids.sort(function (a, b) { return a - b; }); } callback(); } }; function disableClicks() { return false; } function disableClicksOnPosts() { components.get('post').on('click', 'button,a', disableClicks); } function enableClicksOnPosts() { components.get('post').off('click', 'button,a', disableClicks); }; return PostSelect; });