X-Git-Url: https://plomlompom.com/repos/processes?a=blobdiff_plain;ds=inline;f=new2%2Frogue_chat_nocanvas_monochrome.html;h=bb1ecdaeedb13de65bb93ff2b2bf9dd950bf40f9;hb=77f28624afa28d4ab929b8865e1dfc2e441b7747;hp=a4aa85deddf6059fc362303531ee3a7400773969;hpb=1115fdca9304abdf8a4cb15df30f9015b32e572b;p=plomrogue2-experiments diff --git a/new2/rogue_chat_nocanvas_monochrome.html b/new2/rogue_chat_nocanvas_monochrome.html index a4aa85d..bb1ecda 100644 --- a/new2/rogue_chat_nocanvas_monochrome.html +++ b/new2/rogue_chat_nocanvas_monochrome.html @@ -10,6 +10,10 @@ movement: rows: cols: +command character:
@@ -20,6 +24,7 @@ let websocket_location = "ws://localhost:8000"; let wasd_selector = document.getElementById("WASD_selector"); let rows_selector = document.getElementById("n_rows"); let cols_selector = document.getElementById("n_cols"); +let command_char_selector = document.getElementById("command_char"); let terminal = { foreground: 'white', @@ -150,7 +155,7 @@ let server = { }; this.websocket.onclose = function(event) { tui.log_msg("@ server disconnected :("); - tui.log_msg("@ hint: try the ':reconnect' command"); + tui.log_msg("@ hint: try the '" + command_char_selector.value + "reconnect' command"); }; this.websocket.onmessage = this.handle_event; }, @@ -350,7 +355,7 @@ let tui = { }, log_msg: function(msg) { this.log.push(msg); - while (this.log.length > terminal.rows * 4) { + while (this.log.length > 100) { this.log.shift(); }; this.full_refresh(); @@ -358,11 +363,11 @@ let tui = { log_help: function() { this.log_msg("HELP:"); this.log_msg("chat mode commands:"); - this.log_msg(" :nick NAME - re-name yourself to NAME"); - this.log_msg(" :msg USER TEXT - send TEXT to USER"); - this.log_msg(" :help - show this help"); - this.log_msg(" :p or :play - switch to play mode"); - this.log_msg(" :? or :study - switch to study mode"); + this.log_msg(" " + command_char_selector.value + "nick NAME - re-name yourself to NAME"); + this.log_msg(" " + command_char_selector.value + "msg USER TEXT - send TEXT to USER"); + this.log_msg(" " + command_char_selector.value + "help - show this help"); + this.log_msg(" " + command_char_selector.value + "p or " + command_char_selector.value + "play - switch to play mode"); + this.log_msg(" " + command_char_selector.value + "? or " + command_char_selector.value + "study - switch to study mode"); this.log_msg("commands common to study and play mode:"); this.log_msg(" " + this.movement_keys_desc + " - move"); this.log_msg(" c - switch to chat mode"); @@ -436,7 +441,7 @@ let tui = { }, draw_input: function() { if (this.mode.has_input_prompt) { - for (let y = terminal.rows - this.height_input, i = 0; y < terminal.rows && i < this.input_lines.length; y++, i++) { + for (let y = terminal.rows - this.height_input, i = 0; i < this.input_lines.length; y++, i++) { terminal.write(y, this.window_width, this.input_lines[i]); } } @@ -566,7 +571,7 @@ let explorer = { tui.inputEl.addEventListener('input', (event) => { if (tui.mode.has_input_prompt) { - let max_length = tui.window_width * terminal.rows - tui.input_prompt.length; + let max_length = tui.window_width * terminal.rows - tui.input_prompt.length; if (tui.inputEl.value.length > max_length) { tui.inputEl.value = tui.inputEl.value.slice(0, max_length); }; @@ -600,27 +605,27 @@ tui.inputEl.addEventListener('keydown', (event) => { } else if (tui.mode == mode_chat && event.key == 'Enter') { let [tokens, token_starts] = parser.tokenize(tui.inputEl.value); if (tokens.length > 0 && tokens[0].length > 0) { - if (tokens[0][0] == ':') { - if (tokens[0] == ':play' || tokens[0] == ':p') { + if (tui.inputEl.value[0][0] == command_char_selector.value) { + if (tokens[0].slice(1) == 'play' || tokens[0].slice(1) == 'p') { tui.switch_mode(mode_play); - } else if (tokens[0] == ':study' || tokens[0] == ':?') { + } else if (tokens[0].slice(1) == 'study' || tokens[0].slice(1) == '?') { tui.switch_mode(mode_study); - } else if (tokens[0] == ':help') { + } else if (tokens[0].slice(1) == 'help') { tui.log_help(); - } else if (tokens[0] == ':nick') { + } else if (tokens[0].slice(1) == 'nick') { if (tokens.length > 1) { server.send(['LOGIN', tokens[1]]); } else { tui.log_msg('? need login name'); } - } else if (tokens[0] == ':msg') { + } else if (tokens[0].slice(1) == 'msg') { if (tokens.length > 2) { let msg = tui.inputEl.value.slice(token_starts[2]); server.send(['QUERY', tokens[1], msg]); } else { tui.log_msg('? need message target and message'); } - } else if (tokens[0] == ':reconnect') { + } else if (tokens[0].slice(1) == 'reconnect') { if (tokens.length > 1) { server.reconnect_to(tokens[1]); } else { @@ -661,6 +666,7 @@ tui.inputEl.addEventListener('keydown', (event) => { }; } else if (tui.mode == mode_study) { if (event.key === 'c') { + event.preventDefault(); tui.switch_mode(mode_chat); } else if (event.key == 'p') { tui.switch_mode(mode_play); @@ -701,7 +707,7 @@ cols_selector.addEventListener('input', function() { tui.full_refresh(); }, false); window.setInterval(function() { - if (!(['input', 'n_cols', 'n_rows', 'WASD_selector'].includes(document.activeElement.id))) { + if (!(['input', 'n_cols', 'n_rows', 'WASD_selector', 'command_char'].includes(document.activeElement.id))) { tui.inputEl.focus(); } }, 100);