X-Git-Url: https://git.sesse.net/?p=remoteglot;a=blobdiff_plain;f=www%2Fjs%2Fremoteglot.js;h=43b2e1ddbb7c304b2450349fbaef79e23e355d92;hp=5d12c43709dcda3da8f56d5de9774fd40054bf5c;hb=ab94a7c05a495c1d8f9ea30e2268bbc72f17b303;hpb=35725006988891aae7234a39c4f7c603c8b17bd9 diff --git a/www/js/remoteglot.js b/www/js/remoteglot.js index 5d12c43..43b2e1d 100644 --- a/www/js/remoteglot.js +++ b/www/js/remoteglot.js @@ -137,12 +137,15 @@ var request_update = function() { sync_server_clock(xhr.getResponseHeader('Date')); ims = xhr.getResponseHeader('X-RGLM'); var num_viewers = xhr.getResponseHeader('X-RGNV'); - possibly_play_sound(current_analysis_data, data); + var new_data; if (Array.isArray(data)) { - current_analysis_data = JSON_delta.patch(current_analysis_data, data); + new_data = JSON.parse(JSON.stringify(current_analysis_data)); + JSON_delta.patch(new_data, data); } else { - current_analysis_data = data; + new_data = data; } + possibly_play_sound(current_analysis_data, new_data); + current_analysis_data = new_data; update_board(current_analysis_data, displayed_analysis_data); update_num_viewers(num_viewers); @@ -1099,6 +1102,41 @@ var update_historic_analysis = function() { }); } +/** + * @param {string} fen + */ +var update_imbalance = function(fen) { + var hiddenboard = new Chess(fen); + var imbalance = {'k': 0, 'q': 0, 'r': 0, 'b': 0, 'n': 0, 'p': 0}; + for (var row = 0; row < 8; ++row) { + for (var col = 0; col < 8; ++col) { + var col_text = String.fromCharCode('a1'.charCodeAt(0) + col); + var row_text = String.fromCharCode('a1'.charCodeAt(1) + row); + var square = col_text + row_text; + var contents = hiddenboard.get(square); + if (contents !== null) { + if (contents.color === 'w') { + ++imbalance[contents.type]; + } else { + --imbalance[contents.type]; + } + } + } + } + var white_imbalance = ''; + var black_imbalance = ''; + for (var piece in imbalance) { + for (var i = 0; i < imbalance[piece]; ++i) { + white_imbalance += ''; + } + for (var i = 0; i < -imbalance[piece]; ++i) { + black_imbalance += ''; + } + } + $('#whiteimbalance').html(white_imbalance); + $('#blackimbalance').html(black_imbalance); +} + var update_displayed_line = function() { if (highlighted_move !== null) { highlighted_move.removeClass('highlight'); @@ -1107,6 +1145,7 @@ var update_displayed_line = function() { $("#linenav").hide(); $("#linemsg").show(); board.position(fen); + update_imbalance(fen); return; } @@ -1129,6 +1168,7 @@ var update_displayed_line = function() { var hiddenboard = chess_from(current_display_line.start_fen, current_display_line.pretty_pv, current_display_move); board.position(hiddenboard.fen()); + update_imbalance(hiddenboard.fen()); } /**