From 7b3cf1b79954a47000527dd0c3f0fc1cecb5315d Mon Sep 17 00:00:00 2001
From: Benjamin Auder <benjamin.auder@somewhere>
Date: Tue, 28 Jan 2020 17:44:06 +0100
Subject: [PATCH] Fixes

---
 client/src/components/Board.vue        | 24 +++++++++++++++++++-----
 client/src/components/ComputerGame.vue |  4 ++++
 client/src/components/Settings.vue     | 13 +++++++++++++
 3 files changed, 36 insertions(+), 5 deletions(-)

diff --git a/client/src/components/Board.vue b/client/src/components/Board.vue
index 914b3c3f..eb9e6e4c 100644
--- a/client/src/components/Board.vue
+++ b/client/src/components/Board.vue
@@ -21,7 +21,15 @@ export default {
   },
   render(h) {
     if (!this.vr)
-      return;
+    {
+      // Return empty div of class 'game' to avoid error when setting size
+      return h("div",
+        {
+          "class": {
+            "game": true,
+          },
+        });
+    }
     const [sizeX,sizeY] = [V.size.x,V.size.y];
     // Precompute hints squares to facilitate rendering
     let hintSquares = ArrayFun.init(sizeX, sizeY, false);
@@ -30,9 +38,9 @@ export default {
     let incheckSq = ArrayFun.init(sizeX, sizeY, false);
     this.incheck.forEach(sq => { incheckSq[sq[0]][sq[1]] = true; });
 
-    let firstRow = document.querySelector(".game > .row");
-    const squareWidth = (!!firstRow
-      ? document.querySelector(".game > .row").offsetWidth / sizeY
+    let boardElt = document.querySelector(".game");
+    const squareWidth = (!!boardElt
+      ? boardElt.offsetWidth / sizeY
       : 40); //arbitrary value (not relevant)
     const choices = h(
       'div',
@@ -252,6 +260,12 @@ export default {
       elementArray
     );
   },
+  mounted: function() {
+    // NOTE (TODO?): could also be dependent on page type (game, analyze, variant)
+    const boardSize = localStorage.getItem("boardSize");
+    if (!!boardSize)
+      document.querySelector(".game").style.width = boardSize + "px";
+  },
   methods: {
     mousedown: function(e) {
       e = e || window.event;
@@ -386,7 +400,7 @@ div.board11
   padding-bottom: 9.1%
 
 .game
-  width: #{'min(80vw, 500px)'}
+  //width: #{'min(80vw, 500px)'}
   margin: 0 auto
   .board
     cursor: pointer
diff --git a/client/src/components/ComputerGame.vue b/client/src/components/ComputerGame.vue
index 1506e982..52cfc5e2 100644
--- a/client/src/components/ComputerGame.vue
+++ b/client/src/components/ComputerGame.vue
@@ -48,7 +48,11 @@ export default {
     this.compWorker.onmessage = e => {
       let compMove = e.data;
       if (!compMove)
+      {
+        this.compThink = false;
+        this.$emit("game-stopped"); //no more moves: mate or stalemate
         return; //after game ends, no more moves, nothing to do
+      }
       if (!Array.isArray(compMove))
         compMove = [compMove]; //to deal with MarseilleRules
       // Small delay for the bot to appear "more human"
diff --git a/client/src/components/Settings.vue b/client/src/components/Settings.vue
index 318689c4..bae95c09 100644
--- a/client/src/components/Settings.vue
+++ b/client/src/components/Settings.vue
@@ -32,6 +32,10 @@ div
           option(value="0") {{ st.tr["None"] }}
           option(value="1") {{ st.tr["New game"] }}
           option(value="2") {{ st.tr["All"] }}
+      fieldset
+        .slidecontainer
+          input#myRange.slider(type="range" min="1" max="100" value="50"
+            @input="adjustBoard")
 </template>
 
 <script>
@@ -50,6 +54,15 @@ export default {
       localStorage[propName] = ["highlight","coords"].includes(propName)
         ? event.target.checked
         : event.target.value;
+    },
+    adjustBoard: function() {
+      const board = document.querySelector(".game");
+      if (!board)
+        return; //no board on page
+      const multiplier = document.getElementById("myRange").value;
+      const boardSize = 10 * multiplier;
+      localStorage.setItem("boardSize", boardSize);
+      board.style.width = boardSize + "px";
     },
 	},
 };
-- 
2.44.0