add player, game metadata function

This commit is contained in:
Sorrel Bri 2019-08-06 15:25:58 -07:00
parent 358bfe20d4
commit 3d9aca00f9
3 changed files with 60 additions and 8 deletions

View file

@ -73,6 +73,15 @@ h4 {
flex-direction: column; flex-direction: column;
} }
#player-meta span[id$="rank"] {
margin: 0 2em;
}
#player-meta input[type="button"] {
margin: .25em;
height: 100%;
}
div[data-player-meta] { div[data-player-meta] {
width: 100%; width: 100%;
justify-self: stretch; justify-self: stretch;

View file

@ -17,7 +17,7 @@
<div> <div>
<form id="menu"> <form id="menu">
<div id="game-meta"> <div id="game-meta">
<div class="menu-subblock"><span class="menu-heading">Date:</span><input type="text" name="date"></div> <div class="menu-subblock"><span class="menu-heading">Date:</span><span id="date"></span></div>
<div class="menu-subblock"><span class="menu-heading">Komi:</span><span id="komi"></span></div> <div class="menu-subblock"><span class="menu-heading">Komi:</span><span id="komi"></span></div>
<input type="range" min="-21.5" max="7.5" step="1" value="5.5" name="komi-slider"> <input type="range" min="-21.5" max="7.5" step="1" value="5.5" name="komi-slider">
<div class="menu-subblock"><span class="menu-heading">Handicap:</span><span id="handicap"></span></div> <div class="menu-subblock"><span class="menu-heading">Handicap:</span><span id="handicap"></span></div>
@ -27,13 +27,13 @@
<div data-player-meta="black"> <div data-player-meta="black">
<h4 class="menu-heading">Black</h4> <h4 class="menu-heading">Black</h4>
<span class="menu-heading">Name:</span><input type="text" name="black-name"> <span class="menu-heading">Name:</span><input type="text" name="black-name">
<span class="menu-heading">Rank:</span><input type="number" id="black-rank" max="38" steps="1" placeholder="15" name="black-rank"> <span class="menu-heading">Rank:</span><span id="black-rank">9k</span><input type="button" id="black-rank-up" value="▲"><input type="button" id="black-rank-down" value="▼">
<input type="checkbox" name="black-rank-certain"><label for="black-rank-certain">Rank Certainty</label> <input type="checkbox" name="black-rank-certain"><label for="black-rank-certain">Rank Certainty</label>
</div> </div>
<div data-player-meta="white"> <div data-player-meta="white">
<h4 class="menu-heading">White</h4> <h4 class="menu-heading">White</h4>
<span class="menu-heading">Name:</span><input type="text" name="white-name"> <span class="menu-heading">Name:</span><input type="text" name="white-name">
<span class="menu-heading">Rank:</span><input type="number" name="white-rank"> <span class="menu-heading">Rank:</span><span id="white-rank">9k</span><input type="button" id="white-rank-up" value="▲"><input type="button" id="white-rank-down" value="▼">
<input type="checkbox" name="white-rank-certain"><label for="white-rank-certain">Rank Certainty</label> <input type="checkbox" name="white-rank-certain"><label for="white-rank-certain">Rank Certainty</label>
</div> </div>
</div> </div>

View file

@ -15,7 +15,7 @@ const DOTS_DATA = {
's': 'seki' 's': 'seki'
} }
const ranks = ['30k', '29k', '28k', '27k', '26k', '25k', '24k', '23k', '22k', '21k', '20k', const RANKS = ['30k', '29k', '28k', '27k', '26k', '25k', '24k', '23k', '22k', '21k', '20k',
'19k', '18k', '17k', '16k', '15k', '14k', '13k', '12k', '11k', '10k', '19k', '18k', '17k', '16k', '15k', '14k', '13k', '12k', '11k', '10k',
'9k', '8k', '7k', '6k', '5k', '4k', '3k', '2k', '1k', '9k', '8k', '7k', '6k', '5k', '4k', '3k', '2k', '1k',
'1d', '2d', '3d', '4d', '5d', '6d', '7d', '8d', '9d'] '1d', '2d', '3d', '4d', '5d', '6d', '7d', '8d', '9d']
@ -37,12 +37,12 @@ const gameState = {
playerMeta: { // editable during game playerMeta: { // editable during game
b: { b: {
name: null, name: null,
rank: null, rank: 21,
rankCertain: false rankCertain: false
}, },
w: { w: {
name: null, name: null,
rank: null, rank: 21,
rankCertain: false rankCertain: false
}, },
}, },
@ -157,6 +157,15 @@ const blackCapsEl = document.getElementById("black-caps");
const modalEl = document.querySelector('.modal'); const modalEl = document.querySelector('.modal');
const komiSliderEl = document.querySelector('input[name="komi-slider"]'); const komiSliderEl = document.querySelector('input[name="komi-slider"]');
const handiSliderEl = document.querySelector('input[name="handicap-slider"]'); const handiSliderEl = document.querySelector('input[name="handicap-slider"]');
const blackRankEl = document.getElementById("black-rank");
const blackRankUpEl = document.getElementById("black-rank-up");
const blackRankDownEl = document.getElementById("black-rank-down");
const whiteRankEl = document.getElementById("white-rank");
const whiteRankUpEl = document.getElementById("black-rank-up");
const whiteRankDownEl = document.getElementById("black-rank-down");
const blackNameEl = document.querySelector("input[name='black-name']")
const whiteNameEl = document.querySelector("input[name='white-name']")
// store modal #menu for displaying game info // store modal #menu for displaying game info
// store // store
@ -179,6 +188,8 @@ document.getElementById('black-caps-space').addEventListener('click', clickResig
modalEl.addEventListener('click', clickCloseMenu); modalEl.addEventListener('click', clickCloseMenu);
komiSliderEl.addEventListener('change', changeUpdateKomi); komiSliderEl.addEventListener('change', changeUpdateKomi);
handiSliderEl.addEventListener('change', changeUpdateHandicap); handiSliderEl.addEventListener('change', changeUpdateHandicap);
document.getElementById('player-meta').addEventListener('click', clickUpdatePlayerMeta);
document.getElementById('player-meta').addEventListener('change', clickUpdatePlayerMeta);
/*----- functions -----*/ /*----- functions -----*/
@ -194,6 +205,32 @@ function changeUpdateHandicap() {
document.getElementById('handicap').textContent = handiSliderEl.value; document.getElementById('handicap').textContent = handiSliderEl.value;
} }
function clickUpdatePlayerMeta(evt) {
evt.stopPropagation;
switch (evt.target.id) {
case 'black-rank-up':
gameState.playerMeta.b.rank++;
break;
case 'black-rank-down':
gameState.playerMeta.b.rank--;
break;
case 'white-rank-up':
gameState.playerMeta.w.rank++;
break;
case 'white-rank-down':
gameState.playerMeta.w.rank--;
break;
}
console.log(evt);
if (evt.target.name = 'black-rank-certain') gameState.playerMeta.b.rankCertain = !gameState.playerMeta.b.rankCertain;
if (evt.target.name = 'white-rank-certain') gameState.playerMeta.w.rankCertain = !gameState.playerMeta.w.rankCertain;
if (evt.target.name = 'black-name') gameState.playerMeta.b.name = blackNameEl.value;
if (evt.target.name = 'white-name') gameState.playerMeta.w.name = whiteNameEl.value;
blackRankEl.textContent = RANKS[gameState.playerMeta.b.rank];
whiteRankEl.textContent = RANKS[gameState.playerMeta.w.rank];
}
function clickPass(evt) { function clickPass(evt) {
if (evt.target.parentElement.id === `${STONES_DATA[gameState.turn]}-bowl`) playerPass(); if (evt.target.parentElement.id === `${STONES_DATA[gameState.turn]}-bowl`) playerPass();
} }
@ -213,6 +250,7 @@ function clickMenu() {
modalEl.style.visibility = 'visible'; modalEl.style.visibility = 'visible';
changeUpdateKomi(); changeUpdateKomi();
changeUpdateHandicap(); changeUpdateHandicap();
clickUpdatePlayerMeta();
} }
function clickCloseMenu(evt) { function clickCloseMenu(evt) {
@ -324,6 +362,11 @@ function clearCaptures() {
} }
} }
function getDate() {
let d = new Date;
return `${d.getFullYear()}-${String(d.getMonth()+1).charAt(-1)||0}${String(d.getMonth()+1).charAt(-0)}-${String(d.getDate()).charAt(-1)||0}${String(d.getDate()+1).charAt(-0)}`
}
"YYYY-MM-DD"
function init() { function init() {
gameState.winner = null; gameState.winner = null;
gameState.pass = null; gameState.pass = null;
@ -332,7 +375,7 @@ function init() {
// gameState.turn = gameState.handicap ? -1 : 1; // gameState.turn = gameState.handicap ? -1 : 1;
gameState.playerState.bCaptures = 0; gameState.playerState.bCaptures = 0;
gameState.playerState.wCaptures = 0; gameState.playerState.wCaptures = 0;
// gameState.gameMeta.date = // get from browser window gameState.gameMeta.date = getDate();
// get any future meta from player input // get any future meta from player input
// gameState.playerMeta.b // get from player input // gameState.playerMeta.b // get from player input
// gameState.playerMeta.w // get from player input // gameState.playerMeta.w // get from player input