-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
70 lines (57 loc) · 1.95 KB
/
main.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
let suits = ['\u2665', '\u2663', '\u2666', '\u2660'];
let values = ['K', 'Q', 'J', '10', '9', '8', '7', '6', '5', '4', '3', '2', 'A'];
let shuffleDeckButton = document.getElementById('shuffle-deck-button')
let playerHand1 = [];
let playerHand2 = [];
let playerHand3 = [];
let playerHand4 = [];
let template = document.getElementById("blank");
let stack = document.getElementById("stack")
let cleanDeck = createDeck();
let shuffledDeck = createDeck();
shuffleDeck(shuffledDeck)
function createDeck() {
let deck = [];
for (let suitIdx = 0; suitIdx < suits.length; suitIdx++) {
for (let valueIdx = 0; valueIdx< values.length; valueIdx ++) {
let card = {
suit: suits[suitIdx],
value: values[valueIdx]
};
deck.push(card);
}
}
return deck;
}
function shuffleDeck(deck) {
for (let i = 0; i < deck.length; i ++){
let swapIdx = Math.trunc(Math.random() * deck.length);
let tmp = deck[swapIdx];
deck[swapIdx] = deck[i];
deck[i] = tmp;
}
console.log(shuffledDeck)
}
function dealCards(shuffledDeck) {
for (let i = shuffledDeck.length; i > 0; i-=4){
playerHand1.push(shuffledDeck.shift());
playerHand2.push(shuffledDeck.shift());
playerHand3.push(shuffledDeck.shift());
playerHand4.push(shuffledDeck.shift());
console.log(playerHand1)
console.log(playerHand2)
console.log(playerHand3)
console.log(playerHand4)
};
}
function renderCard(card) {
let newCard = template.cloneNode(true);
newCard.id = card.suit + card.value;
newCard.getElementsByTagName("div")[0].innerHTML = card.value ;
newCard.getElementsByTagName("div")[1].innerHTML = card.suit;
newCard.style.display = 'inline-block';
if (card.suitLetter == "\u2665" || card.suitLetter == "\u2666") {
newCard.className = newCard.className + " red";
}
stack.appendChild(newCard);
}