197 lines
5.4 KiB
JavaScript
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();
|
|
};
|