-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.js
84 lines (83 loc) · 2.89 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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
let turnCount = 0;
function startGame() {
turnCount = 0;
for(let i = 1; i <= 9; i += 1) {
clearBox(i);
document.getElementById('refreshBtn').style.visibility = 'hidden';
}
document.turn = 'X';
document.tur='Player 1';
document.winner = null;
document.cat = false;
setTurnMessage(document.tur + '\'s start first!');
document.getElementById('turnMessage').style.color = '#6c757d';
}
function setTurnMessage(message) {
document.getElementById('turnMessage').innerText = message;
}
function switchTurn() {
if (checkWinner(document.turn) && document.cat === false) {
document.winner = document.turn;
setTurnMessage('Congratulations ' + document.tur + '\'s, you win!');
document.getElementById('turnMessage').style.color = '#28a745';
document.getElementById('refreshBtn').style.visibility = 'visible';
} else if (document.cat === true) {
setTurnMessage('Draw! Play again?');
document.getElementById('turnMessage').style.color = '#16a2b8';
document.getElementById('refreshBtn').style.visibility = 'visible';
}
else if (document.turn == 'X') {
document.turn = 'O';
document.tur = 'Player 2';
setTurnMessage('It is ' + document.tur + '\'s turn');
document.getElementById('turnMessage').style.color = '#0586ff';
} else {
document.turn = 'X';
document.tur='Player 1'
setTurnMessage('It is ' + document.tur + '\'s turn.');
document.getElementById('turnMessage').style.color = '#de3241';
}
}
function nextMove(square) {
if (document.winner != null) {
setTurnMessage(document.tur + '\'s already won!');
document.getElementById('turnMessage').style.color = '#ffc904';
} else if (square.innerText == '') {
square.innerText = document.turn;
switchTurn();
} else {
setTurnMessage('Oops, pick a different square!');
document.getElementById('turnMessage').style.color = '#ffc904';
}
}
function checkWinner(move) {
turnCount += 1;
let result = false;
if (
checkRow(1, 2, 3, move) ||
checkRow(4, 5, 6, move) ||
checkRow(7, 8, 9, move) ||
checkRow(1, 4, 7, move) ||
checkRow(2, 5, 8, move) ||
checkRow(3, 6, 9, move) ||
checkRow(1, 5, 9, move) ||
checkRow(3, 5, 7, move)) {
result = true;
} else if(turnCount > 8 && result === false) {
document.cat = true;
}
return result;
}
function checkRow(a, b, c, move) {
let result = false;
if (getBox(a) == move && getBox(b) == move && getBox(c) == move) {
result = true;
}
return result;
}
function getBox(number) {
return document.getElementById('square' + number).innerText;
}
function clearBox(number) {
document.getElementById('square' + number).innerText = '';
}