<?xml version="1.0" encoding="UTF-8"?>
<javascript app="forums">
<file javascript_app="forums" javascript_location="front" javascript_path="controllers/forum" javascript_name="ips.forum.flow.js" javascript_type="controller" javascript_version="103021" javascript_position="1000100"><![CDATA[/**
* Invision Community
* (c) Invision Power Services, Inc. - https://www.invisioncommunity.com
*
* ips.forum.flow.js - Flow filter controller
*
* Author: Matt Mecham, certainly not Rikki Tissier (yet)
*/
;( function($, _, undefined){
"use strict";
ips.controller.register('forums.front.forum.flow', {
_ids: [],
_button: null,
initialize: function () {
this.on( 'click', '[data-node-id]', this.toggleFilters );
this.setup();
},
/**
* Um, set up...
*/
setup: function () {
/* Populate forum IDs */
var _ids = ips.utils.url.getParam( 'forumId' );
var self = this;
if ( ! _.isUndefined( _ids ) ) {
/* Check URL */
this._ids = decodeURIComponent( _ids ).split(',');
} else if( ! _.isUndefined( ips.utils.cookie.get('forums_flowIds') ) ) {
/* Check local storage */
this._ids = ips.utils.cookie.get('forums_flowIds').split(',');
}
if( _.isObject( this._ids ) && _.size( this._ids ) ){
_.each( this._ids, function (val, key) {
if ( val ) {
self.childSelect( val, true );
}
});
}
this._button = $('body').find('[data-role="fluidForumMobileDesc"]');
this._updateButtonText();
},
/**
* Event handler for toggling a filter
*
* @param {event} e Event object
* @returns {void}
*/
toggleFilters: function (e) {
e.preventDefault();
var link = $( e.currentTarget );
var id = link.attr('data-node-id');
var parentId = link.attr('data-parent-id');
var hasChildren = link.attr('data-has-children');
if ( _.indexOf( this._ids, id ) == -1 ) {
/* Does not exist, so add it */
this.childSelect( id, false );
} else {
/* Exists, so remove it */
this.childUnselect( id );
}
this._updateButtonText();
$( document ).trigger( 'updateTableURL', { forumId: _.uniq( _.values( this._ids ) ).join(',') } );
},
/**
* Is item selected
*
*/
isSelected: function(id) {
return this.scope.find('[data-node-id="' + id + '"]').hasClass('cForumMiniList_selected') ? true : false;
},
/**
* Select a child
*
*/
childSelect: function(id, skipChildren) {
Debug.log("Select child: " + id );
this._ids.push( id );
var node = this.scope.find('[data-node-id="' + id + '"]');
node.addClass('cForumMiniList_selected');
var parentId = node.attr('data-parent-id');
/* Mark any children, but we do not need to keep individual row markings */
if ( skipChildren === false && ( node.attr('data-has-children') || id == parentId ) ) {
var self = this;
_.each( this.scope.find('[data-parent-id="' + id + '"]'), function( v, k ) {
var _cId = $(v).attr('data-node-id');
if ( _cId != id ) {
self.childSelect( _cId, false );
}
} );
}
this.updateCookie();
},
/**
* Unselect a child
*
*/
childUnselect: function(id) {
Debug.log("UNselect child: " + id );
/* Remove marking */
this.scope.find('[data-node-id="' + id + '"]').removeClass('cForumMiniList_selected');
/* Remove from local storage and id stack */
this._ids = _.without( this._ids, id );
this.updateCookie();
/* Check for children of this and unselect those too */
var self = this;
_.each( this.scope.find('[data-parent-id="' + id + '"]'), function( v, k ) {
var _cId = $(v).attr('data-node-id');
if ( _cId != id ) {
self.childUnselect( _cId );
}
} );
/* And we always need to unselect the category */
this.parentUnselect( this.scope.find('[data-node-id="' + id + '"]').closest('[data-category]').find('[data-node-id]').first().attr('data-node-id') );
},
/**
* Select a parent
*
*/
parentSelect: function(parentId) {
Debug.log("Select parent: " + parentId );
/* Mark category and children as selected */
this.scope.find('[data-node-id="' + parentId + '"]').addClass('cForumMiniList_selected');
/* Remove children from the arrays as PHP handles this */
var self = this;
_.each( this.scope.find('[data-parent-id="' + parentId + '"]'), function( v, k ) {
var _cId = $(v).attr('data-node-id');
if ( _cId != parentId ) {
self.childUnselect( _cId );
}
} );
},
/**
* Unselect a parent
*
*/
parentUnselect: function(parentId) {
Debug.log("UNselect parent: " + parentId );
/* Unselect parent as marked */
var node = this.scope.find('[data-node-id="' + parentId + '"]');
node.removeClass('cForumMiniList_selected');
this._ids = _.without( this._ids, parentId );
this.updateCookie();
/* Off up the tree we go */
Debug.log( "Looking for parent ID " + node.attr('data-parent-id') );
var self = this;
_.each( this.scope.find('[data-node-id="' + node.attr('data-parent-id') + '"]'), function( v, k ) {
var _cId = $(v).attr('data-node-id');
if ( _cId != parentId ) {
Debug.log( "Found " + _cId );
self.parentUnselect( _cId );
}
} );
},
/**
* Update the cookie
*/
updateCookie: function(id) {
var cookie = _.uniq( _.values( this._ids ) ).join(',');
Debug.log("Updating cookie: " + cookie );
ips.utils.cookie.set('forums_flowIds', cookie, true);
},
/**
* Updates the mobile button text based on selected forums
*
* @param {event} e The submit event
* @param {element} elem The element this widget is being created on
* @returns {void}
*/
_updateButtonText: function () {
var blobs = this.scope.find('.cForumMiniList_blob');
var selectedBlobRows = blobs.filter( function () {
if( $( this ).closest('.cForumMiniList_selected').length ){
return true;
}
return false;
});
var text = '';
// If the counts are the same, we know we've selected all of them
if( blobs.length == selectedBlobRows.length || selectedBlobRows.length === 0 ){
text = ips.getString('topicsFromAllForums');
} else {
text = ips.pluralize( ips.getString( 'topicsFromXForums' ), selectedBlobRows.length );
}
this._button.text( text );
}
});
}(jQuery, _));]]></file>
<file javascript_app="forums" javascript_location="front" javascript_path="controllers/forum" javascript_name="ips.forum.forumList.js" javascript_type="controller" javascript_version="103021" javascript_position="1000100"><![CDATA[/**
* Invision Community
* (c) Invision Power Services, Inc. - https://www.invisioncommunity.com
*
* ips.forum.forumList.js - Controller for a forum listing
*
* Author: Rikki Tissier
*/
;( function($, _, undefined){
"use strict";
ips.controller.register('forums.front.forum.forumList', {
initialize: function () {
this.on( 'click', '[data-action="toggleCategory"]', this.toggleCategory );
this.setup();
},
/**
* Setup method
* Hides categories the user has already hidden
*
* @returns {void}
*/
setup: function () {
var self = this;
var hiddenCategories = ips.utils.db.get( 'hiddenCategories' );
if( _.isObject( hiddenCategories ) && _.size( hiddenCategories ) ){
_.each( hiddenCategories, function (val, key) {
self.scope.find('[data-categoryID="' + key + '"]')
.addClass('cForumRow_hidden')
.attr( 'data-hidden', true )
.find( '[data-role="forums"]' )
.hide();
});
}
},
/**
* Event handler for toggling a category
* Hidden categories are stored localDB
*
* @param {event} e Event object
* @returns {void}
*/
toggleCategory: function (e) {
e.preventDefault();
var category = $( e.currentTarget ).closest('[data-categoryID]');
if( !category.attr('data-hidden') ){
ips.utils.db.set( 'hiddenCategories', category.attr('data-categoryID'), true );
category
.addClass('cForumRow_hidden')
.attr( 'data-hidden', true )
.find('[data-role="forums"]')
.hide();
} else {
ips.utils.anim.go( 'fadeIn', category.find('[data-role="forums"]') );
ips.utils.db.remove( 'hiddenCategories', category.attr('data-categoryID') );
category
.removeClass('cForumRow_hidden')
.removeAttr( 'data-hidden' );
}
}
});
}(jQuery, _));]]></file>
<file javascript_app="forums" javascript_location="front" javascript_path="controllers/forum" javascript_name="ips.forum.forumPage.js" javascript_type="controller" javascript_version="103021" javascript_position="1000100">/**
* Invision Community
* (c) Invision Power Services, Inc. - https://www.invisioncommunity.com
*
* ips.forum.forumPage.js - Forum page controller
*
* Author: Rikki Tissier
*/
;( function($, _, undefined){
"use strict";
ips.controller.register('forums.front.forum.forumPage', {
initialize: function () {
this.on( 'click', '[data-action="markForumRead"]', this.markForumRead );
},
/**
* Marks all topics in a forum table as read, triggering an event on the table
*
* @param {event} e Event object
* @returns {void}
*/
markForumRead: function (e) {
e.preventDefault();
var self = this;
ips.ui.alert.show( {
type: 'confirm',
icon: 'question',
message: ips.getString('markForumAsReadConfirm'),
subText: '',
callbacks: {
ok: function () {
var url = $( e.currentTarget ).attr('href');
ips.getAjax()( url, {
showLoading: true,
bypassRedirect: true
})
.done( function () {
// Trigger event on the table to hide unread markets
self.triggerOn( 'core.global.core.table', 'markTableRead' );
// Hide the link we've just clicked
ips.utils.anim.go( 'fadeOut', $( e.currentTarget ) );
ips.ui.flashMsg.show( ips.getString('forumMarkedRead') );
})
.fail( function (jqXHR, textStatus, errorThrown) {
window.location = url;
});
}
}
});
}
});
}(jQuery, _));</file>
<file javascript_app="forums" javascript_location="front" javascript_path="controllers/forum" javascript_name="ips.forum.hovercard.js" javascript_type="controller" javascript_version="103021" javascript_position="1000100">/**
* Invision Community
* (c) Invision Power Services, Inc. - https://www.invisioncommunity.com
*
* ips.forum.hovercard.js - Topic hovercard in forum view
*
* Author: Rikki Tissier
*/
;( function($, _, undefined){
"use strict";
ips.controller.register('forums.front.forum.hovercard', {
initialize: function () {
this.on( 'click', '[data-action="markTopicRead"]', this.markTopicRead );
},
/**
* Marks a topic read from inside a hovercard
*
* @param {event} e Event object
* @returns {void}
*/
markTopicRead: function (e) {
e.preventDefault();
// Ignore if we've already done this
if( $( e.currentTarget ).attr('data-disabled') ){
return;
}
// Trigger event for table to mark the row
this.trigger( 'markTableRowRead', {
tableID: 'topics',
rowID: this.scope.attr('data-topicID')
});
// Let the user know
ips.ui.flashMsg.show( ips.getString('topicMarkedRead') );
// And do the actual request
ips.getAjax()( $( e.currentTarget ).attr('href'), {
bypassRedirect: true
});
// Hide the link
$( e.currentTarget ).addClass('ipsFaded').attr('data-disabled');
}
});
}(jQuery, _));</file>
<file javascript_app="forums" javascript_location="admin" javascript_path="controllers/settings" javascript_name="ips.settings.archiveRules.js" javascript_type="controller" javascript_version="103021" javascript_position="1000050"><![CDATA[/**
* Invision Community
* (c) Invision Power Services, Inc. - https://www.invisioncommunity.com
*
* ips.forums.archiveRules.js - makes the progress bar increase as archive rules settings are changed
*
* Author: Mark Wade
*/
;( function($, _, undefined){
"use strict";
ips.controller.register('forums.admin.settings.archiveRules', {
initialize: function () {
this.on( 'change', 'input,select', this.changeField );
this.on( 'nodeSelectedChanged', '.ipsSelectTree', this.changeField );
this.on( 'tokenAdded', '[data-ipsAutocomplete]', this.changeField );
this.on( 'tokenDeleted', '[data-ipsAutocomplete]', this.changeField );
this.setup();
},
setup: function () {
var currentPercentage = parseInt( this.scope.find('[data-role="percentage"]').text() );
this.scope
.find('.ipsProgressBar')
.toggleClass('ipsFaded', !currentPercentage );
},
/**
* Save the keywords
*
* @param {event} e Event object
* @returns {void}
*/
changeField: function (e) {
var form = $( e.currentTarget ).closest('form');
var self = this;
ips.getAjax()( form.attr('action') + '&getCount=1', {
data: form.serialize(),
type: 'post'
}).done( function (response) {
var currentPercentage = parseInt( self.scope.find('[data-role="percentage"]').text() );
self.scope
.find('.ipsProgressBar')
.toggleClass('ipsFaded', !parseInt( response.percentage ) )
.end()
.find('[data-role="percentage"]')
.text( response.percentage )
.end()
.find('[data-role="number"]')
.text( response.count )
.end()
.find('[data-role="percentageBar"]')
.animate( { 'width': response.percentage + '%' }, 'fast' );
}).fail(function(err){
// Nothing
});
},
});
}(jQuery, _));
]]></file>
<file javascript_app="forums" javascript_location="front" javascript_path="controllers/topic" javascript_name="ips.topic.answers.js" javascript_type="controller" javascript_version="103021" javascript_position="1000050"><![CDATA[/**
* Invision Community
* (c) Invision Power Services, Inc. - https://www.invisioncommunity.com
*
* ips.topic.answers.js - Profile body controller
*
* Author: Rikki Tissier
*/
;( function($, _, undefined){
"use strict";
ips.controller.register('forums.front.topic.answers', {
ajaxObj: null,
/**
* Initialize controller events
*
* @returns {void}
*/
initialize: function () {
this.on( 'click', 'a.cAnswerRate', this.rate );
},
/**
* Rate answers
*
* @param {event} e Event object
* @returns {void}
*/
rate: function (e) {
e.preventDefault();
var self = this;
var clicked = $( e.currentTarget );
var positive = clicked.hasClass('cAnswerRate_up');
var voteCount = this.scope.find('[data-role="voteCount"]');
var currentVotes = parseInt( voteCount.attr('data-voteCount') );
this.scope.find('.cAnswerRate_up').toggleClass( 'ipsType_positive', positive );
this.scope.find('.cAnswerRate_down').toggleClass( 'ipsType_negative', !positive );
this.scope.toggleClass( 'cRatingColumn_up', positive ).toggleClass( 'cRatingColumn_down', !positive );
var newVoteCount = 0;
if( positive ){
newVoteCount = currentVotes + 1;
}
else {
newVoteCount = currentVotes - 1;
}
voteCount
.toggleClass( 'ipsType_positive', positive )
.toggleClass( 'ipsType_negative', !positive )
.text( newVoteCount )
.attr( 'data-voteCount', newVoteCount );
// Send request
if( this.ajaxObj && _.isFunction( this.ajaxObj.abort ) ){
this.ajaxObj.abort();
}
if( positive ){
this.scope.find('a.cAnswerRate_up').addClass('ipsHide');
this.scope.find('span.cAnswerRate_up').removeClass('ipsHide');
} else {
this.scope.find('a.cAnswerRate_down').addClass('ipsHide');
this.scope.find('span.cAnswerRate_down').removeClass('ipsHide');
}
this.ajaxObj = ips.getAjax()( clicked.attr('href') )
.done( function (response) {
Debug.log( response );
if( !response.canVoteUp ){
self.scope.find('a.cAnswerRate_up').addClass('ipsHide');
self.scope.find('span.cAnswerRate_up').removeClass('ipsHide');
} else {
self.scope.find('a.cAnswerRate_up').removeClass('ipsHide');
self.scope.find('span.cAnswerRate_up').addClass('ipsHide');
}
if( !response.canVoteDown ){
self.scope.find('a.cAnswerRate_down').addClass('ipsHide');
self.scope.find('span.cAnswerRate_down').removeClass('ipsHide');
} else {
self.scope.find('a.cAnswerRate_down').removeClass('ipsHide');
self.scope.find('span.cAnswerRate_down').addClass('ipsHide');
}
voteCount.text( response.votes );
self.scope.find('.ipsType_light').text( ips.pluralize( ips.getString( 'votes_no_number' ), response.votes ) );
});
}
});
}(jQuery, _));]]></file>
<file javascript_app="forums" javascript_location="front" javascript_path="controllers/topic" javascript_name="ips.topic.reply.js" javascript_type="controller" javascript_version="103021" javascript_position="1000050">/**
* Invision Community
* (c) Invision Power Services, Inc. - https://www.invisioncommunity.com
*
* ips.topic.reply.js - Topic reply controller for "Reply" button
*
* Author: Rikki Tissier
*/
;( function($, _, undefined){
"use strict";
ips.controller.register('forums.front.topic.reply', {
initialize: function () {
this.on( 'click', '[data-action="replyToTopic"]', this.replyToTopic );
},
/**
* Handles a click on the reply to topic button. Triggers an event caught by the main topic view controller.
*
* @param {event} e Event object
* @returns {void}
*/
replyToTopic: function (e) {
e.preventDefault();
$( document ).trigger( 'replyToTopic' );
}
});
}(jQuery, _));</file>
<file javascript_app="forums" javascript_location="front" javascript_path="controllers/topic" javascript_name="ips.topic.view.js" javascript_type="controller" javascript_version="103021" javascript_position="1000050">/**
* Invision Community
* (c) Invision Power Services, Inc. - https://www.invisioncommunity.com
*
* ips.topic.view.js - Topic view controller
*
* Author: Rikki Tissier
*/
;( function($, _, undefined){
"use strict";
ips.controller.register('forums.front.topic.view', {
initialize: function () {
$( document ).on( 'replyToTopic', _.bind( this.replyToTopic, this ) );
},
/**
* Triggers the initialize event on the editor
*
* @param {event} e Event object
* @returns {void}
*/
replyToTopic: function (e) {
var editorID = this.scope.find('[data-role="replyArea"] [data-role="contentEditor"]').attr('name');
if( editorID ){
this.trigger('initializeEditor', { editorID: editorID } );
}
}
});
}(jQuery, _));</file>
<order app="global" path="/dev/js//framework/">templates
common/ips.loader.js
common/ui
common/utils
common
controllers</order>
<order app="global" path="/dev/js//library/">underscore
jquery
mustache
jstz
Debug.js
app.js</order>
<order app="global" path="/dev/js//library//jquery">jquery.js
jquery.history.js
jquery.transform.js</order>
<order app="global" path="/dev/js//library//linkify">linkify.min.js
linkify-jquery.min.js</order>
</javascript>