PretendYoureXyzzy/WebContent/js/cah.cardset.js

197 lines
5.4 KiB
JavaScript

/*
* Copyright (c) 2012-2018, Andy Janata
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without modification, are permitted
* provided that the following conditions are met:
*
* * Redistributions of source code must retain the above copyright notice, this list of conditions
* and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright notice, this list of
* conditions and the following disclaimer in the documentation and/or other materials provided
* with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY
* WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/**
* CardSet class and static list.
*
* @author Andy Janata (ajanata@socialgamer.net)
*/
cah.CardSet = {};
/**
* @type {Object} Key-value map of CardSets. Key is ID, value is the object.
*/
cah.CardSet.list = {};
/**
* @type {Object} Key-value map of CardSets. Key is sort weight, value is the same object as the
* by-id map object.
*/
cah.CardSet.byWeight = {};
/**
* Class containing information about a CardSet. Should only be used by utility function in this
* file that populates cah.CardSet.list during initial load of the game.
*
* @param {Number}
* id CardSet's database/wire ID.
* @param {String}
* name CardSet's name.
* @param {String}
* description CardSet's description.
* @param {Boolean}
* baseDeck Whether this CardSet can be used as a base deck. At least one base deck must be
* used per game.
* @param {Number}
* blackCardCount The number of black cards in this CardSet
* @param {Number}
* whiteCardCount The number of white cards in this CardSet.
* @param {Number}
* weight The sort weight of this CardSet.
* @constructor
* @private
*/
cah.CardSet = function(id, name, description, baseDeck, blackCardCount, whiteCardCount, weight) {
/**
* CardSet's database/wire ID.
*
* @type {Number}
* @private
*/
this.id_ = id;
/**
* CardSet's name.
*
* @type {String}
* @private
*/
this.name_ = name;
/**
* CardSet's description.
*
* @type {String}
* @private
*/
this.description_ = description;
/**
* Whether this CardSet can be used as a base deck. At least one base deck must be used per game.
*
* @type {Boolean}
* @private
*/
this.baseDeck_ = baseDeck;
/**
* The number of black cards in this CardSet.
*
* @type {Number}
* @private
*/
this.blackCardCount_ = blackCardCount;
/**
* The number of white cards in this CardSet.
*
* @type {Number}
* @private
*/
this.whiteCardCount_ = whiteCardCount;
/**
* The sort weight of this CardSet.
*
* @type {Number}
* @private
*/
this.weight_ = weight;
};
/**
* @returns {number} This CardSet's database/wire ID.
*/
cah.CardSet.prototype.getId = function() {
return this.id_;
};
/**
* @returns {String} This CardSet's name.
*/
cah.CardSet.prototype.getName = function() {
return this.name_;
};
/**
* @returns {String} This CardSet's description.
*/
cah.CardSet.prototype.getDescription = function() {
return this.description_;
};
/**
* @returns {Boolean} Whether this CardSet can be used as the base deck in a game.
*/
cah.CardSet.prototype.isBaseDeck = function() {
return this.baseDeck_;
};
/**
* @returns {Number} The number of black cards in this CardSet.
*/
cah.CardSet.prototype.getBlackCardCount = function() {
return this.blackCardCount_;
};
/**
* @returns {Number} The number of white cards in this CardSet.
*/
cah.CardSet.prototype.getWhiteCardCount = function() {
return this.whiteCardCount_;
};
/**
* @returns {Number} The sort weight of this CardSet.
*/
cah.CardSet.prototype.getWeight = function() {
return this.weight_;
};
/**
* Populate the internal list of CardSets from data provided by the server.
*
* @param {Array}
* cardSets Array of CardSet data from server.
*/
cah.CardSet.populateCardSets = function(cardSets) {
cah.CardSet.list = {};
cah.CardSet.byWeight = {};
// the server already sends us an ordered list, so let's just use that ordering
var i = 0;
for ( var key in cardSets) {
var cardSetData = cardSets[key];
var cardSet = new cah.CardSet(cardSetData[cah.$.CardSetData.ID],
cardSetData[cah.$.CardSetData.CARD_SET_NAME],
cardSetData[cah.$.CardSetData.CARD_SET_DESCRIPTION],
cardSetData[cah.$.CardSetData.BASE_DECK],
cardSetData[cah.$.CardSetData.BLACK_CARDS_IN_DECK],
cardSetData[cah.$.CardSetData.WHITE_CARDS_IN_DECK], cardSetData[cah.$.CardSetData.WEIGHT]);
cah.CardSet.list[cardSet.getId()] = cardSet;
cah.CardSet.byWeight[i++] = cardSet;
}
// not sure if there's a better way to call this...
cah.Preferences.updateCardSetFilters();
};