X-Git-Url: https://git.cworth.org/git?p=lmno.games;a=blobdiff_plain;f=tictactoe%2Ftictactoe.jsx;h=579526b7dcb401e0310027da092f47c8fead5691;hp=17c966dc9453a2ffebdb2581b7a696be9ba691b0;hb=868ec74bb12cbae18d2bd666d67f9e82ba38ee96;hpb=0edb467eb1b8922d885ef6a756fca68c9d2d0a08;ds=sidebyside
diff --git a/tictactoe/tictactoe.jsx b/tictactoe/tictactoe.jsx
index 17c966d..579526b 100644
--- a/tictactoe/tictactoe.jsx
+++ b/tictactoe/tictactoe.jsx
@@ -1,3 +1,12 @@
+const Team = {
+ X: 0,
+ O: 1,
+ properties: {
+ 0: {name: "X"},
+ 1: {name: "O"}
+ }
+};
+
function undisplay(element) {
element.style.display="none";
}
@@ -11,6 +20,10 @@ ${message}
message_area.insertAdjacentHTML('beforeend', message);
}
+/*********************************************************
+ * Handling server-sent event stream *
+ *********************************************************/
+
const events = new EventSource("events");
events.onerror = function(event) {
@@ -19,35 +32,96 @@ events.onerror = function(event) {
}
};
+events.addEventListener("game-info", event => {
+ const info = JSON.parse(event.data);
+
+ window.game.set_game_info(info);
+});
+
+events.addEventListener("player-info", event => {
+ const info = JSON.parse(event.data);
+
+ window.game.set_player_info(info);
+});
+
+events.addEventListener("player-update", event => {
+ const info = JSON.parse(event.data);
+
+ if (info.id === window.game.state.player_info.id)
+ window.game.set_player_info(info);
+});
+
events.addEventListener("move", event => {
- const square = JSON.parse(event.data);
+ const move = JSON.parse(event.data);
- window.game.receiveMove(square);
+ window.game.receive_move(move);
});
events.addEventListener("game-state", event => {
const state = JSON.parse(event.data);
- window.game.resetState();
+ window.game.reset_board();
for (let square of state.moves) {
- window.game.receiveMove(square);
+ window.game.receive_move(square);
}
});
+/*********************************************************
+ * Game and supporting classes *
+ *********************************************************/
+
+function GameInfo(props) {
+ if (! props.id)
+ return null;
+
+ return (
+
+
{props.id}
+ Invite a friend to play by sending this URL: {props.url}
+
+ );
+}
+
+function PlayerInfo(props) {
+ if (! props.player.id)
+ return null;
+
+ return (
+
+
Player
+ {props.player.name}
+ {props.player.team ? ` (${props.player.team})` : ""}
+
+ );
+}
+
function Square(props) {
+ let className = "square";
+
+ if (props.value) {
+ className += " occupied";
+ } else if (props.active) {
+ className += " open";
+ }
+
+ const onClick = props.active ? props.onClick : null;
+
return (
-