summaryrefslogtreecommitdiff
path: root/play.js
diff options
context:
space:
mode:
Diffstat (limited to 'play.js')
-rw-r--r--play.js28
1 files changed, 23 insertions, 5 deletions
diff --git a/play.js b/play.js
index c1ffde0..df535e0 100644
--- a/play.js
+++ b/play.js
@@ -36,14 +36,23 @@ const region_index = {
"Punjab": Punjab,
};
-const region_names = {
+const space_names = {
[Persia]: "Persia",
[Transcaspia]: "Transcaspia",
[Herat]: "Herat",
[Kabul]: "Kabul",
[Kandahar]: "Kandahar",
[Punjab]: "Punjab",
-};
+ [Persia_Transcaspia]: "Persia/Transcaspia",
+ [Persia_Herat]: "Persia/Herat",
+ [Transcaspia_Herat]: "Transcaspia/Herat",
+ [Transcaspia_Kabul]: "Transcaspia/Kabul",
+ [Herat_Kabul]: "Herat/Kabul",
+ [Herat_Kandahar]: "Herat/Kandahar",
+ [Kabul_Kandahar]: "Kabul/Kandahar",
+ [Kabul_Punjab]: "Kabul/Punjab",
+ [Kandahar_Punjab]: "Kandahar/Punjab",
+}
cards.forEach(card => {
if (card) {
@@ -278,6 +287,10 @@ function on_focus_card(evt) {
}
}
+function on_focus_space(evt) {
+ ui.status.textContent = space_names[evt.target.space];
+}
+
function on_click_space(evt) {
send_action('space', evt.target.space);
evt.stopPropagation();
@@ -653,7 +666,10 @@ function on_update() {
else if (s <= 100)
ui.spyrows[s].appendChild(ui.pieces[x]);
else
- ui.board.appendChild(ui.pieces[x]);
+ {
+ if (ui.pieces[x].parentElement !== ui.board)
+ ui.board.appendChild(ui.pieces[x]);
+ }
ui.pieces[x].classList.toggle('action', is_piece_action(x));
ui.pieces[x].classList.toggle('selected', view.selected === x);
ui.pieces[x].style = "";
@@ -662,9 +678,9 @@ function on_update() {
for (let i = 0; i < 6; ++i)
if (ruler[i] === -1)
- ui.rule[i].classList = `rule ${region_names[i+Persia]} hide`;
+ ui.rule[i].classList = `rule ${space_names[i+Persia]} hide`;
else
- ui.rule[i].classList = `rule ${region_names[i+Persia]} ${player_names[ruler[i]]}`;
+ ui.rule[i].classList = `rule ${space_names[i+Persia]} ${player_names[ruler[i]]}`;
ui.suit_political.classList.toggle('action', is_suit_action('Political'));
ui.suit_intelligence.classList.toggle('action', is_suit_action('Intelligence'));
@@ -746,6 +762,8 @@ function build_ui() {
ui.spaces[i] = document.getElementById("svgmap").getElementById(n);
ui.spaces[i].space = i;
ui.spaces[i].addEventListener("click", on_click_space);
+ ui.spaces[i].addEventListener("mouseenter", on_focus_space);
+ ui.spaces[i].addEventListener("mouseleave", on_blur);
}
for (let c = 1; c < cards.length; ++c) {