summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKyle Gunger <kgunger12@gmail.com>2022-07-19 00:31:02 -0400
committerKyle Gunger <kgunger12@gmail.com>2022-07-19 00:31:02 -0400
commit5207f04d5b775bf4805d83c81aaad1cfcf3fe68a (patch)
tree66b31b953af2df99f2b74e296b4f77555b234642
parent1dab192a329b1ad966b0c1e0401eeaa78d5b752e (diff)
Change how card id's are held, add swapCard
-rw-r--r--scripts/cards/card.js4
-rw-r--r--scripts/cards/deck.js4
-rw-r--r--scripts/gui/table.js22
3 files changed, 22 insertions, 8 deletions
diff --git a/scripts/cards/card.js b/scripts/cards/card.js
index 3ca435c..7246db3 100644
--- a/scripts/cards/card.js
+++ b/scripts/cards/card.js
@@ -15,9 +15,7 @@ class Card {
this.e.style.top = "0px";
this.e.card = this;
- this.getID = function() {
- return id;
- }
+ this.id = id;
}
// Generate a card with basic text only
diff --git a/scripts/cards/deck.js b/scripts/cards/deck.js
index 0c88821..8d38186 100644
--- a/scripts/cards/deck.js
+++ b/scripts/cards/deck.js
@@ -144,7 +144,7 @@ class Deck {
{
for(let i in this.cards)
{
- if(this.cards[i].getID() == id)
+ if(this.cards[i].id === id)
return this.removeCard(i);
}
@@ -186,7 +186,7 @@ class Deck {
{
for(let c of this.cards)
{
- if(c.getID() === id)
+ if(c.id === id)
return c;
}
return null;
diff --git a/scripts/gui/table.js b/scripts/gui/table.js
index 5e69f3e..46a520b 100644
--- a/scripts/gui/table.js
+++ b/scripts/gui/table.js
@@ -88,7 +88,7 @@ class Table{
this.decks[id].e.remove();
for(let i in this.decks[id].cards)
{
- delete this.cards[this.decks[id].cards[i].getID()];
+ delete this.cards[this.decks[id].cards[i].id];
this.decks[id].removeCard(i);
}
delete this.deck[id];
@@ -114,6 +114,22 @@ class Table{
this.decks[data.deckID].addCardAt(this.cards[data.cardID], data.index);
}
+ // Swap card data with new data
+ // {data object} data from the server
+ // {data.cardID any} ID of the card to swap
+ // {data.newID any} New ID for the card
+ // {data.data object} visualization data
+ swapCard(data)
+ {
+ // Can't swap a card into a an id of a pre-existing card.
+ if (this.cards[data.newID] != null) {
+ return false;
+ }
+ this.cards[data.newID] = this.cards[data.cardID];
+ delete this.cards[data.cardID];
+ this.cards[data.newID].generateElements(data.data);
+ }
+
/* Internal functions */
@@ -154,8 +170,8 @@ class Table{
if(c !== null)
{
- if(d !== null)
- this.checkMove(c.getID(), d);
+ if(d !== null && !this.decks[d].hasCard(c.id))
+ this.checkMove(c.id, d);
else
c.resetPos();
}