define(['composer', 'forum/pagination'], function(composer, pagination) { var Topic = {}, infiniteLoaderActive = false; function showBottomPostBar() { if($('#post-container .post-row').length > 1 || !$('#post-container li[data-index="0"]').length) { $('.bottom-post-bar').removeClass('hide'); } } $(window).on('action:ajaxify.start', function(ev, data) { if(data.url.indexOf('topic') !== 0) { $('.pagination-block').addClass('hide'); $('#header-topic-title').html('').hide(); } }); Topic.init = function() { var expose_tools = templates.get('expose_tools'), tid = templates.get('topic_id'), thread_state = { locked: templates.get('locked'), deleted: templates.get('deleted'), pinned: templates.get('pinned') }, topic_name = templates.get('topic_name'), currentPage = parseInt(templates.get('currentPage'), 10), pageCount = parseInt(templates.get('pageCount'), 10); Topic.postCount = templates.get('postcount'); $(window).trigger('action:topic.loading'); function fixDeleteStateForPosts() { var postEls = document.querySelectorAll('#post-container li[data-deleted]'); for (var x = 0, numPosts = postEls.length; x < numPosts; x++) { if (postEls[x].getAttribute('data-deleted') === '1') { toggle_post_delete_state(postEls[x].getAttribute('data-pid')); } postEls[x].removeAttribute('data-deleted'); } } jQuery('document').ready(function() { app.addCommasToNumbers(); app.enterRoom('topic_' + tid); showBottomPostBar(); if (thread_state.locked === '1') set_locked_state(true); if (thread_state.deleted === '1') set_delete_state(true); if (thread_state.pinned === '1') set_pinned_state(true); if (expose_tools === '1') { var moveThreadModal = $('#move_thread_modal'); $('.thread-tools').removeClass('hide'); // Add events to the thread tools $('.delete_thread').on('click', function(e) { if (thread_state.deleted !== '1') { bootbox.confirm('Are you sure you want to delete this thread?', function(confirm) { if (confirm) { socket.emit('topics.delete', tid); } }); } else { bootbox.confirm('Are you sure you want to restore this thread?', function(confirm) { if (confirm) { socket.emit('topics.restore', tid); } }); } return false; }); $('.lock_thread').on('click', function(e) { if (thread_state.locked !== '1') { socket.emit('topics.lock', tid); } else { socket.emit('topics.unlock', tid); } return false; }); $('.pin_thread').on('click', function(e) { if (thread_state.pinned !== '1') { socket.emit('topics.pin', tid); } else { socket.emit('topics.unpin', tid); } return false; }); $('.move_thread').on('click', function(e) { moveThreadModal.modal('show'); return false; }); $('.markAsUnreadForAll').on('click', function() { var btn = $(this); socket.emit('topics.markAsUnreadForAll', tid, function(err) { if(err) { return app.alertError(err.message); } btn.parents('.thread-tools.open').find('.dropdown-toggle').trigger('click'); }); return false; }) moveThreadModal.on('shown.bs.modal', function() { var loadingEl = document.getElementById('categories-loading'); if (loadingEl) { socket.emit('categories.get', function(err, data) { // Render categories var categoriesFrag = document.createDocumentFragment(), categoryEl = document.createElement('li'), numCategories = data.categories.length, modalBody = moveThreadModal.find('.modal-body'), categoriesEl = modalBody[0].getElementsByTagName('ul')[0], confirmDiv = document.getElementById('move-confirm'), confirmCat = confirmDiv.getElementsByTagName('span')[0], commitEl = document.getElementById('move_thread_commit'), cancelEl = document.getElementById('move_thread_cancel'), x, info, targetCid, targetCatLabel; categoriesEl.className = 'category-list'; for (x = 0; x < numCategories; x++) { info = data.categories[x]; categoryEl.style.background = info.bgColor; categoryEl.style.color = info.color || '#fff'; categoryEl.className = info.disabled === '1' ? ' disabled' : ''; categoryEl.innerHTML = ' ' + info.name; categoryEl.setAttribute('data-cid', info.cid); categoriesFrag.appendChild(categoryEl.cloneNode(true)); } categoriesEl.appendChild(categoriesFrag); modalBody[0].removeChild(loadingEl); categoriesEl.addEventListener('click', function(e) { if (e.target.nodeName === 'LI') { confirmCat.innerHTML = e.target.innerHTML; confirmDiv.style.display = 'block'; targetCid = e.target.getAttribute('data-cid'); targetCatLabel = e.target.innerHTML; commitEl.disabled = false; } }, false); commitEl.addEventListener('click', function() { if (!commitEl.disabled && targetCid) { commitEl.disabled = true; $(cancelEl).fadeOut(250); $(moveThreadModal).find('.modal-header button').fadeOut(250); commitEl.innerHTML = 'Moving '; socket.emit('topics.move', { tid: tid, cid: targetCid }, function(err) { moveThreadModal.modal('hide'); if(err) { return app.alert({ 'alert_id': 'thread_move', type: 'danger', title: 'Unable to Move Topic', message: 'This topic could not be moved to ' + targetCatLabel + '.
Please try again later', timeout: 5000 }); } app.alert({ 'alert_id': 'thread_move', type: 'success', title: 'Topic Successfully Moved', message: 'This topic has been successfully moved to ' + targetCatLabel, timeout: 5000 }); }); } }); }); } }); $('.fork_thread').on('click', function() { var pids = []; var forkModal = $('#fork-thread-modal'), forkCommit = forkModal.find('#fork_thread_commit'); forkModal.removeClass('hide'); forkModal.css("position", "fixed") .css("left", Math.max(0, (($(window).width() - $(forkModal).outerWidth()) / 2) + $(window).scrollLeft()) + "px") .css("top", "0px") .css("z-index", "2000"); showNoPostsSelected(); forkModal.find('.close,#fork_thread_cancel').on('click', closeForkModal); forkModal.find('#fork-title').on('change', checkForkButtonEnable); $('#post-container').on('click', 'li', togglePostSelection); forkCommit.on('click', createTopicFromPosts); function createTopicFromPosts() { socket.emit('topics.createTopicFromPosts', { title: forkModal.find('#fork-title').val(), pids: pids }, function(err) { if(err) { return app.alertError(err.message); } translator.get('topic:fork_success', function(translated) { app.alertSuccess(translated); }); for(var i=0; i 0) { el = $('#post-container .post-row.infiniteloaded').last(); after = parseInt(el.attr('data-index'), 10) + 1; } else { el = $('#post-container .post-row.infiniteloaded').first(); after = parseInt(el.attr('data-index'), 10); after -= config.postsPerPage; if(after < 0) { after = 0; } } var offset = el.offset().top - $('#header-menu').offset().top + $('#header-menu').height(); loadMorePosts(tid, after, function() { fixDeleteStateForPosts(); if(direction < 0 && el) { Topic.scrollToPost(el.attr('data-pid'), false, 0, offset); } }); } }); } else { $('.pagination-block').addClass('hide'); pagination.init(currentPage, pageCount); } } $('.topic').on('click', '.post_reply', function() { var selectionText = '', selection = window.getSelection() || document.getSelection(); if ($(selection.baseNode).parents('.post-content').length > 0) { var snippet = selection.toString(); if (snippet.length > 0) { selectionText = '> ' + snippet.replace(/\n/g, '\n> '); } } var username = '', post = $(this).parents('li[data-pid]'), pid = $(this).parents('.post-row').attr('data-pid'); if (post.length) { username = '@' + post.attr('data-username').replace(/\s/g, '-') + ' '; } if (thread_state.locked !== '1') { composer.newReply(tid, pid, topic_name, selectionText.length > 0 ? selectionText + '\n\n' + username : '' + username); } }); $('#post-container').on('click', '.quote', function() { if (thread_state.locked !== '1') { var username = '', post = $(this).parents('li[data-pid]'), pid = $(this).parents('.post-row').attr('data-pid'); if (post.length) { username = '@' + post.attr('data-username').replace(/\s/g, '-'); } socket.emit('posts.getRawPost', pid, function(err, post) { if(err) { return app.alertError(err.message); } var quoted = ''; if(post) { quoted = '> ' + post.replace(/\n/g, '\n> ') + '\n\n'; } if($('.composer').length) { composer.addQuote(tid, pid, topic_name, username, quoted); }else { composer.newReply(tid, pid, topic_name, username + ' said:\n' + quoted); } }); } }); $('#post-container').on('click', '.favourite', function() { var pid = $(this).parents('.post-row').attr('data-pid'); var method = $(this).attr('data-favourited') == 'false' ? 'posts.favourite' : 'posts.unfavourite'; socket.emit(method, { pid: pid, room_id: app.currentRoom }); return false; }); $('#post-container').on('click', '.upvote', function() { var post = $(this).parents('.post-row'), pid = post.attr('data-pid'), upvoted = post.find('.upvoted').length; if (upvoted) { socket.emit('posts.unvote', { pid: pid, room_id: app.currentRoom }); } else { socket.emit('posts.upvote', { pid: pid, room_id: app.currentRoom }); } return false; }); $('#post-container').on('click', '.downvote', function() { var post = $(this).parents('.post-row'), pid = post.attr('data-pid'), downvoted = post.find('.downvoted').length; if (downvoted) { socket.emit('posts.unvote', { pid: pid, room_id: app.currentRoom }); } else { socket.emit('posts.downvote', { pid: pid, room_id: app.currentRoom }); } return false; }); $('#post-container').on('click', '.flag', function() { var btn = $(this); bootbox.confirm('Are you sure you want to flag this post?', function(confirm) { if (confirm) { var pid = btn.parents('.post-row').attr('data-pid'); socket.emit('posts.flag', pid, function(err) { if(err) { return app.alertError(err.message); } app.alertSuccess('This post has been flagged for moderation.'); }); } }); }); $('#post-container').on('shown.bs.dropdown', '.share-dropdown', function() { var pid = $(this).parents('.post-row').attr('data-pid'); $('#post_' + pid + '_link').val(window.location.protocol + '//' + window.location.host + window.location.pathname + '#' + pid); // without the setTimeout can't select the text in the input setTimeout(function() { $('#post_' + pid + '_link').putCursorAtEnd().select(); }, 50); }); $('#post-container').on('click', '.post-link', function(e) { e.preventDefault(); return false; }); $('#post-container').on('click', '.twitter-share', function () { var pid = $(this).parents('.post-row').attr('data-pid'); window.open('https://twitter.com/intent/tweet?url=' + encodeURIComponent(window.location.href + '#' + pid) + '&text=' + topic_name, '_blank', 'width=550,height=420,scrollbars=no,status=no'); return false; }); $('#post-container').on('click', '.facebook-share', function () { var pid = $(this).parents('.post-row').attr('data-pid'); window.open('https://www.facebook.com/sharer/sharer.php?u=' + encodeURIComponent(window.location.href + '#' + pid), '_blank', 'width=626,height=436,scrollbars=no,status=no'); return false; }); $('#post-container').on('click', '.google-share', function () { var pid = $(this).parents('.post-row').attr('data-pid'); window.open('https://plus.google.com/share?url=' + encodeURIComponent(window.location.href + '#' + pid), '_blank', 'width=500,height=570,scrollbars=no,status=no'); return false; }); $('#post-container').on('click', '.edit', function(e) { var pid = $(this).parents('.post-row').attr('data-pid'); composer.editPost(pid); }); $('#post-container').on('click', '.delete', function(e) { var pid = $(this).parents('.post-row').attr('data-pid'), postEl = $(document.querySelector('#post-container li[data-pid="' + pid + '"]')), action = !postEl.hasClass('deleted') ? 'delete' : 'restore'; bootbox.confirm('Are you sure you want to ' + action + ' this post?', function(confirm) { if (confirm) { socket.emit('posts.' + action, { pid: pid, tid: tid }, function(err) { if(err) { return app.alertError('Can\'t ' + action + ' post!'); } }); } }); }); $('#post-container').on('click', '.move', function(e) { var moveModal = $('#move-post-modal'), moveBtn = moveModal.find('#move_post_commit'), topicId = moveModal.find('#topicId'), post = $(this).parents('.post-row'), pid = $(this).parents('.post-row').attr('data-pid'); moveModal.removeClass('hide'); moveModal.css("position", "fixed") .css("left", Math.max(0, (($(window).width() - $(moveModal).outerWidth()) / 2) + $(window).scrollLeft()) + "px") .css("top", "0px") .css("z-index", "2000"); moveModal.find('.close,#move_post_cancel').on('click', function() { moveModal.addClass('hide'); }); topicId.on('change', function() { if(topicId.val().length) { moveBtn.removeAttr('disabled'); } else { moveBtn.attr('disabled', true); } }); moveBtn.on('click', function() { socket.emit('topics.movePost', {pid: pid, tid: topicId.val()}, function(err) { if(err) { $('#topicId').val(''); moveModal.addClass('hide'); return app.alertError(err.message); } post.fadeOut(500, function() { post.remove(); }); moveModal.addClass('hide'); $('#topicId').val(''); app.alertSuccess('Post moved!'); }); }); }); $('#post-container').on('click', '.chat', function(e) { var post = $(this).parents('li.post-row'), username = post.attr('data-username'), touid = post.attr('data-uid'); app.openChat(username, touid); $(this).parents('.btn-group').find('.dropdown-toggle').click(); return false; }); ajaxify.register_events([ 'event:rep_up', 'event:rep_down', 'event:favourited', 'event:unfavourited', 'event:new_post', 'get_users_in_room', 'event:topic_deleted', 'event:topic_restored', 'event:topic:locked', 'event:topic_unlocked', 'event:topic_pinned', 'event:topic_unpinned', 'event:topic_moved', 'event:post_edited', 'event:post_deleted', 'event:post_restored', 'posts.favourite', 'user.isOnline', 'posts.upvote', 'posts.downvote' ]); socket.on('get_users_in_room', function(data) { if(data && data.room.indexOf('topic') !== -1) { var activeEl = $('.thread_active_users'); function createUserIcon(uid, picture, userslug, username) { if(!activeEl.find('[href="'+ RELATIVE_PATH +'/user/' + data.users[i].userslug + '"]').length) { var userIcon = $(''); var userLink = $('').append(userIcon); userLink.attr('data-uid', uid); var div = $('
'); div.append(userLink); userLink.tooltip({ placement: 'top', title: username }); return div; } } // remove users that are no longer here activeEl.children().each(function(index, element) { if(element) { var uid = $(element).attr('data-uid'); for(var i=0; i 8) { break; } } var remainingUsers = data.users.length - 9; remainingUsers = remainingUsers < 0 ? 0 : remainingUsers; var anonymousCount = parseInt(data.anonymousCount, 10); activeEl.find('.anonymous-box').remove(); if(anonymousCount || remainingUsers) { var anonLink = $('
'); activeEl.append(anonLink); var title = ''; if(remainingUsers && anonymousCount) title = remainingUsers + ' more user(s) and ' + anonymousCount + ' guest(s)'; else if(remainingUsers) title = remainingUsers + ' more user(s)'; else title = anonymousCount + ' guest(s)'; anonLink.tooltip({ placement: 'top', title: title }); } } app.populateOnlineUsers(); }); socket.on('user.isOnline', function(err, data) { app.populateOnlineUsers(); }); socket.on('event:rep_up', function(data) { adjust_rep(1, data.pid, data.uid); }); socket.on('event:rep_down', function(data) { adjust_rep(-1, data.pid, data.uid); }); socket.on('event:favourited', function(data) { adjust_favourites(1, data.pid, data.uid); }); socket.on('event:unfavourited', function(data) { adjust_favourites(-1, data.pid, data.uid); }); socket.on('event:new_post', function(data) { if(config.usePagination) { onNewPostPagination(data); return; } var posts = data.posts; for (var p in posts) { if (posts.hasOwnProperty(p)) { var post = posts[p], postcount = jQuery('.user_postcount_' + post.uid), ptotal = parseInt(postcount.html(), 10); ptotal += 1; postcount.html(ptotal); } } socket.emit('topics.markAsRead', {tid: tid, uid: app.uid}); createNewPosts(data); }); socket.on('event:topic_deleted', function(data) { if (data && data.tid === tid) { set_locked_state(true); set_delete_state(true); } }); socket.on('event:topic_restored', function(data) { if (data && data.tid === tid) { set_locked_state(false); set_delete_state(false); } }); socket.on('event:topic_locked', function(data) { if (data && data.tid === tid) { set_locked_state(true, 1); } }); socket.on('event:topic_unlocked', function(data) { if (data && data.tid === tid) { set_locked_state(false, 1); } }); socket.on('event:topic_pinned', function(data) { if (data && data.tid === tid) { set_pinned_state(true, 1); } }); socket.on('event:topic_unpinned', function(data) { if (data && data.tid === tid) { set_pinned_state(false, 1); } }); socket.on('event:topic_moved', function(data) { if (data && data.tid > 0) { ajaxify.go('topic/' + data.tid); } }); socket.on('event:post_edited', function(data) { var editedPostEl = $('#content_' + data.pid), editedPostTitle = $('#topic_title_' + data.pid); if (editedPostTitle.length) { editedPostTitle.fadeOut(250, function() { editedPostTitle.html(data.title); editedPostTitle.fadeIn(250); }); } editedPostEl.fadeOut(250, function() { editedPostEl.html(data.content); editedPostEl.find('img').addClass('img-responsive'); editedPostEl.fadeIn(250); }); }); socket.on('posts.upvote', function(data) { if (data && data.pid) { var post = $('li[data-pid="' + data.pid + '"]'), upvote = post.find('.upvote'); upvote.addClass('btn-primary upvoted'); } }); socket.on('posts.downvote', function(data) { if (data && data.pid) { var post = $('li[data-pid="' + data.pid + '"]'), downvote = post.find('.downvote'); downvote.addClass('btn-primary downvoted'); } }); socket.on('posts.unvote', function(data) { if (data && data.pid) { var post = $('li[data-pid="' + data.pid + '"]'), upvote = post.find('.upvote'), downvote = post.find('.downvote'); upvote.removeClass('btn-primary upvoted'); downvote.removeClass('btn-primary downvoted'); } }); socket.on('posts.favourite', function(data) { if (data && data.pid) { var favBtn = $('li[data-pid="' + data.pid + '"] .favourite'); if(favBtn.length) { favBtn.addClass('btn-warning') .attr('data-favourited', true); var icon = favBtn.find('i'); var className = icon.attr('class'); if (className.indexOf('-o') !== -1) { icon.attr('class', className.replace('-o', '')); } } } }); socket.on('posts.unfavourite', function(data) { if (data && data.pid) { var favBtn = $('li[data-pid="' + data.pid + '"] .favourite'); if(favBtn.length) { favBtn.removeClass('btn-warning') .attr('data-favourited', false); var icon = favBtn.find('i'); var className = icon.attr('class'); if (className.indexOf('-o') === -1) { icon.attr('class', className + '-o'); } } } }); socket.on('event:post_deleted', function(data) { if (data.pid) { toggle_post_delete_state(data.pid); } }); socket.on('event:post_restored', function(data) { if (data.pid) { toggle_post_delete_state(data.pid); } }); function adjust_rep(value, pid, uid) { var votes = $('li[data-pid="' + pid + '"] .votes'), reputationElements = $('.reputation[data-uid="' + uid + '"]'), currentVotes = parseInt(votes.attr('data-votes'), 10), reputation = parseInt(reputationElements.attr('data-reputation'), 10); currentVotes += value; reputation += value; votes.html(currentVotes).attr('data-votes', currentVotes); reputationElements.html(reputation).attr('data-reputation', reputation); } function adjust_favourites(value, pid, uid) { var favourites = $('li[data-pid="' + pid + '"] .favouriteCount'), currentFavourites = parseInt(favourites.attr('data-favourites'), 10); currentFavourites += value; favourites.html(currentFavourites).attr('data-favourites', currentFavourites); } function set_follow_state(state, alert) { $('.posts .follow').toggleClass('btn-success', state).attr('title', state ? 'You are currently receiving updates to this topic' : 'Be notified of new replies in this topic'); if(alert) { app.alert({ alert_id: 'topic_follow', timeout: 2500, title: state ? '[[topic:following_topic.title]]' : '[[topic:not_following_topic.title]]', message: state ? '[[topic:following_topic.message]]' : '[[topic:not_following_topic.message]]', type: 'success' }); } } function set_locked_state(locked, alert) { translator.translate(' [[topic:thread_tools.' + (locked ? 'un': '') + 'lock]]', function(translated) { $('.lock_thread').html(translated); }); $('.topic-main-buttons .post_reply').attr('disabled', locked).html(locked ? 'Locked ' : 'Reply'); $('#post-container .post_reply').html(locked ? 'Locked ' : 'Reply '); $('#post-container').find('.quote, .edit, .delete').toggleClass('none', locked); if (alert) { app.alert({ 'alert_id': 'thread_lock', type: 'success', title: 'Thread ' + (locked ? 'Locked' : 'Unlocked'), message: 'Thread has been successfully ' + (locked ? 'locked' : 'unlocked'), timeout: 5000 }); } thread_state.locked = locked ? '1' : '0'; } function set_delete_state(deleted) { var threadEl = $('#post-container'); translator.translate(' [[topic:thread_tools.' + (deleted ? 'restore' : 'delete') + ']]', function(translated) { $('.delete_thread span').html(translated); }); threadEl.toggleClass('deleted', deleted); thread_state.deleted = deleted ? '1' : '0'; if(deleted) { $('
This thread has been deleted. Only users with thread management privileges can see it.
').insertBefore(threadEl); } else { $('#thread-deleted').remove(); } } function set_pinned_state(pinned, alert) { translator.translate(' [[topic:thread_tools.' + (pinned ? 'unpin' : 'pin') + ']]', function(translated) { $('.pin_thread').html(translated); if (alert) { app.alert({ 'alert_id': 'thread_pin', type: 'success', title: 'Thread ' + (pinned ? 'Pinned' : 'Unpinned'), message: 'Thread has been successfully ' + (pinned ? 'pinned' : 'unpinned'), timeout: 5000 }); } thread_state.pinned = pinned ? '1' : '0'; }); } function toggle_post_delete_state(pid) { var postEl = $('#post-container li[data-pid="' + pid + '"]'); if (postEl.length) { postEl.toggleClass('deleted'); toggle_post_tools(pid, postEl.hasClass('deleted')); updatePostCount(); } } function toggle_post_tools(pid, isDeleted) { var postEl = $('#post-container li[data-pid="' + pid + '"]'); postEl.find('.quote, .favourite, .post_reply, .chat').toggleClass('none', isDeleted); translator.translate(isDeleted ? ' [[topic:restore]]' : ' [[topic:delete]]', function(translated) { postEl.find('.delete').find('span').html(translated); }); } $(window).on('scroll', updateHeader); $(window).trigger('action:topic.loaded'); }; function updateHeader() { $('.pagination-block a').off('click').on('click', function() { return false; }); $('.pagination-block i:first').off('click').on('click', function() { app.scrollToTop(); }); $('.pagination-block i:last').off('click').on('click', function() { app.scrollToBottom(); }); if($(window).scrollTop() > 50) { $('#header-topic-title').text(templates.get('topic_name')).show(); } else { $('#header-topic-title').text('').hide(); } $($('.posts > .post-row').get().reverse()).each(function() { var el = $(this); if (elementInView(el)) { var index = parseInt(el.attr('data-index'), 10) + 1; if(index > Topic.postCount) { index = Topic.postCount; } $('#pagination').html(index + ' out of ' + Topic.postCount); $('.progress-bar').width((index / Topic.postCount * 100) + '%'); return false; } }); $('.posts > .post-row').each(function() { var el = $(this); if (elementInView(el)) { var index = parseInt(el.attr('data-index'), 10) + 1; if(index === 0) { localStorage.removeItem("topic:" + templates.get('topic_id') + ":bookmark"); } else { localStorage.setItem("topic:" + templates.get('topic_id') + ":bookmark", el.attr('data-pid')); if(history.replaceState) { history.replaceState(null, window.location.protocol + '//' + window.location.host + window.location.pathname, '#' + el.attr('data-pid')); } else { location.hash = '#' + el.attr('data-pid'); } } return false; } }); } function elementInView(el) { var scrollTop = $(window).scrollTop(); var scrollBottom = scrollTop + $(window).height(); var elTop = el.offset().top; var elBottom = elTop + Math.floor(el.height()); return !(elTop > scrollBottom || elBottom < scrollTop); } Topic.scrollToPost = function(pid, highlight, duration, offset) { if (!pid) { return; } if(!offset) { offset = 0; } if($('#post_anchor_' + pid).length) { return scrollToPid(pid); } if(config.usePagination) { socket.emit('posts.getPidPage', pid, function(err, page) { if(err) { return; } if(parseInt(page, 10) !== pagination.currentPage) { pagination.loadPage(page); } else { scrollToPid(pid); } }); } else { socket.emit('posts.getPidIndex', pid, function(err, index) { if(err) { return; } var tid = $('#post-container').attr('data-tid'); $('#post-container').empty(); var after = index - config.postsPerPage + 1; if(after < 0) { after = 0; } loadMorePosts(tid, after, function() { scrollToPid(pid); }); }); } function scrollToPid(pid) { var scrollTo = $('#post_anchor_' + pid), tid = $('#post-container').attr('data-tid'); function animateScroll() { $("html, body").animate({ scrollTop: (scrollTo.offset().top - $('#header-menu').height() - offset) + "px" }, duration !== undefined ? duration : 400, function() { updateHeader(); if (highlight) { scrollTo.parent().addClass('highlight'); setTimeout(function() { scrollTo.parent().removeClass('highlight'); }, 5000); } }); } if (tid && scrollTo.length) { if($('#post-container li.post-row[data-pid="' + pid + '"]').attr('data-index') !== '0') { animateScroll(); } else { updateHeader(); } } } } function onNewPostPagination(data) { var posts = data.posts; socket.emit('topics.getPageCount', templates.get('topic_id'), function(err, newPageCount) { pagination.recreatePaginationLinks(newPageCount); if(pagination.currentPage === pagination.pageCount) { createNewPosts(data); } else if(data.posts && data.posts.length && parseInt(data.posts[0].uid, 10) === parseInt(app.uid, 10)) { pagination.loadPage(pagination.pageCount); } }); } function createNewPosts(data, infiniteLoaded, callback) { if(!data || (data.posts && !data.posts.length)) { return; } function removeAlreadyAddedPosts() { data.posts = data.posts.filter(function(post) { return $('#post-container li[data-pid="' + post.pid +'"]').length === 0; }); } var after = null, before = null; function findInsertionPoint() { var firstPid = parseInt(data.posts[0].pid, 10); $('#post-container li[data-pid]').each(function() { if(firstPid > parseInt($(this).attr('data-pid'), 10)) { after = $(this); if(after.next().length && after.next().hasClass('post-bar')) { after = after.next(); } } else { return false; } }); if(!after) { var firstPost = $('#post-container .post-row').first(); if(firstPid < parseInt(firstPost.attr('data-pid'), 10)) { before = firstPost; } } } removeAlreadyAddedPosts(); if(!data.posts.length) { return; } findInsertionPoint(); parseAndTranslatePosts(data, function(translatedHTML) { var translated = $(translatedHTML); if(!infiniteLoaded) { translated.removeClass('infiniteloaded'); } if(after) { translated.insertAfter(after) } else if(before) { translated.insertBefore(before); } else { $('#post-container').append(translated); } translated.hide().fadeIn('slow'); onNewPostsLoaded(translated, data.posts); if(typeof callback === 'function') { callback(); } }); } function parseAndTranslatePosts(data, callback) { var html = templates.prepare(templates['topic'].blocks['posts']).parse(data); translator.translate(html, callback); } function onNewPostsLoaded(html, posts) { for (var x = 0, numPosts = posts.length; x < numPosts; x++) { socket.emit('posts.getPrivileges', posts[x].pid, function(err, privileges) { if(err) { return app.alertError(err.message); } toggle_mod_tools(privileges.pid, privileges.editable); }); } infiniteLoaderActive = false; app.populateOnlineUsers(); app.createUserTooltips(); app.addCommasToNumbers(); app.makeNumbersHumanReadable($('.human-readable-number')); html.find('span.timeago').timeago(); html.find('.post-content img').addClass('img-responsive'); updatePostCount(); showBottomPostBar(); } function toggle_mod_tools(pid, editable) { $('#post-container li[data-pid="' + pid + '"]').find('.edit, .delete').toggleClass('none', !editable); } function updatePostCount() { socket.emit('topics.postcount', templates.get('topic_id'), function(err, postcount) { if(!err) { Topic.postCount = postcount; $('#topic-post-count').html(Topic.postCount); updateHeader(); } }); } function loadMorePosts(tid, after, callback) { var indicatorEl = $('.loading-indicator'); if (infiniteLoaderActive || !$('#post-container').length) { return; } if(after === 0 && $('#post-container li.post-row[data-index="0"]').length) { return; } infiniteLoaderActive = true; indicatorEl.fadeIn(); socket.emit('topics.loadMore', { tid: tid, after: after }, function (err, data) { infiniteLoaderActive = false; indicatorEl.fadeOut(); if(err) { return app.alertError(err.message); } if (data && data.posts && data.posts.length) { createNewPosts(data, true, callback); } else { updateHeader(); if (typeof callback === 'function') { callback(data.posts); } } }); } return Topic; });