X-Git-Url: https://plomlompom.com/repos/%7B%7B%20web_path%20%7D%7D/decks/%7B%7Bdeck_id%7D%7D/cards/%7B%7B%20card_id%20%7D%7D/delete?a=blobdiff_plain;f=rogue_chat.html;h=9d5eddf47c8a44e3147185daefa322d582bd1435;hb=028871514fd40755055facc5883a4f8076dcebad;hp=2e37e7f3376b2ed24f0600f6a63c1564833e90ba;hpb=ba09978e0179406218f052ed29690f1f7c508920;p=plomrogue2 diff --git a/rogue_chat.html b/rogue_chat.html index 2e37e7f..9d5eddf 100644 --- a/rogue_chat.html +++ b/rogue_chat.html @@ -52,7 +52,7 @@ keyboard input/control: - + @@ -99,11 +99,11 @@ keyboard input/control:
  • help:
  • flatten surroundings:
  • teleport: -
  • drop thing:
  • open/close:
  • consume:
  • install:
  • (un-)wear: +
  • @@ -159,6 +159,11 @@ let mode_helps = { 'intro': 'Pick up a thing in reach by entering its index number. Enter nothing to abort.', 'long': 'You see a list of things which you could pick up. Enter the target thing\'s index, or, to leave, nothing.' }, + 'drop_thing': { + 'short': 'drop thing', + 'intro': 'Enter number of direction to which you want to drop thing.', + 'long': 'Drop currently carried thing by entering the target direction index. Enter nothing to return to play mode..' + }, 'admin_thing_protect': { 'short': 'change thing protection', 'intro': '@ enter thing protection character:', @@ -244,7 +249,6 @@ let key_descriptions = { 'help': 'help', 'flatten': 'flatten surroundings', 'teleport': 'teleport', - 'drop_thing': 'drop thing', 'door': 'open/close', 'consume': 'consume', 'install': '(un-)install', @@ -503,6 +507,7 @@ let server = { tui.mode_write.legal = game.tasks.includes('WRITE'); tui.mode_command_thing.legal = game.tasks.includes('WRITE'); tui.mode_take_thing.legal = game.tasks.includes('PICK_UP'); + tui.mode_drop_thing.legal = game.tasks.includes('DROP'); } else if (tokens[0] === 'THING_TYPE') { game.thing_types[tokens[1]] = tokens[2] } else if (tokens[0] === 'THING_CARRYING') { @@ -671,6 +676,7 @@ let tui = { mode_name_thing: new Mode('name_thing', true, true), mode_command_thing: new Mode('command_thing', true), mode_take_thing: new Mode('take_thing', true), + mode_drop_thing: new Mode('drop_thing', true), mode_enter_face: new Mode('enter_face', true), mode_admin_enter: new Mode('admin_enter', true), mode_admin: new Mode('admin'), @@ -693,9 +699,9 @@ let tui = { selectables: [], init: function() { this.mode_play.available_modes = ["chat", "study", "edit", "admin_enter", - "command_thing", "take_thing"] - this.mode_play.available_actions = ["move", "drop_thing", "teleport", - "door", "consume", "install", "wear"]; + "command_thing", "take_thing", "drop_thing"] + this.mode_play.available_actions = ["move", "teleport", "door", "consume", + "install", "wear"]; this.mode_study.available_modes = ["chat", "play", "admin_enter", "edit"] this.mode_study.available_actions = ["toggle_map_mode", "move_explorer"]; this.mode_admin.available_modes = ["admin_thing_protect", "control_pw_type", @@ -857,7 +863,7 @@ let tui = { if (select_range.includes(t.position[0].toString() + ':' + t.position[1].toString()) && t.portable) { - this.selectables.push([t_id, t]); + this.selectables.push(t_id); } }; if (this.selectables.length == 0) { @@ -866,10 +872,17 @@ let tui = { this.switch_mode('play'); return; } else { - for (let [i, t] of this.selectables.entries()) { - this.log_msg(i + ': ' + explorer.get_thing_info(t[1])); + for (let [i, t_id] of this.selectables.entries()) { + const t = game.things[t_id]; + this.log_msg(i + ': ' + explorer.get_thing_info(t)); } } + } else if (this.mode.name == 'drop_thing') { + this.log_msg('Direction to drop thing to:'); + this.selectables = ['HERE'].concat(Object.values(this.movement_keys)); + for (let [i, direction] of this.selectables.entries()) { + this.log_msg(i + ': ' + direction); + }; } else if (this.mode.name == 'command_thing') { server.send(['TASK:COMMAND', 'HELP']); } else if (this.mode.name == 'control_pw_pw') { @@ -990,6 +1003,16 @@ let tui = { }; this.full_refresh(); }, + pick_selectable: function(task_name) { + const i = parseInt(this.inputEl.value); + if (isNaN(i) || i < 0 || i >= this.selectables.length) { + tui.log_msg('? invalid index, aborted'); + } else { + server.send(['TASK:' + task_name, tui.selectables[i]]); + } + this.inputEl.value = ""; + this.switch_mode('play'); + }, draw_map: function() { if (!game.turn_complete && this.map_lines.length == 0) { return; @@ -1441,7 +1464,7 @@ tui.inputEl.addEventListener('keydown', (event) => { } if (tui.mode.has_input_prompt && event.key == 'Enter' && tui.inputEl.value.length == 0 - && ['chat', 'command_thing', 'take_thing', + && ['chat', 'command_thing', 'take_thing', 'drop_thing', 'admin_enter'].includes(tui.mode.name)) { if (tui.mode.name != 'chat') { tui.log_msg('@ aborted'); @@ -1470,14 +1493,9 @@ tui.inputEl.addEventListener('keydown', (event) => { server.send(['TASK:COMMAND', tui.inputEl.value]); tui.inputEl.value = ""; } else if (tui.mode.name == 'take_thing' && event.key == 'Enter') { - const i = parseInt(tui.inputEl.value); - if (isNaN(i) || i < 0 || i >= tui.selectables.length) { - tui.log_msg('? invalid index, aborted'); - } else { - server.send(['TASK:PICK_UP', tui.selectables[i][0]]); - } - tui.inputEl.value = ""; - tui.switch_mode('play'); + tui.pick_selectable('PICK_UP'); + } else if (tui.mode.name == 'drop_thing' && event.key == 'Enter') { + tui.pick_selectable('DROP'); } else if (tui.mode.name == 'control_pw_pw' && event.key == 'Enter') { if (tui.inputEl.value.length == 0) { tui.log_msg('@ aborted'); @@ -1556,8 +1574,6 @@ tui.inputEl.addEventListener('keydown', (event) => { } else if (tui.mode.name == 'play') { if (tui.mode.mode_switch_on_key(event)) { null; - } else if (event.key === tui.keys.drop_thing && tui.task_action_on('drop_thing')) { - server.send(["TASK:DROP"]); } else if (event.key === tui.keys.consume && tui.task_action_on('consume')) { server.send(["TASK:INTOXICATE"]); } else if (event.key === tui.keys.door && tui.task_action_on('door')) { @@ -1673,9 +1689,6 @@ document.getElementById("toggle_map_mode").onclick = function() { tui.toggle_map_mode(); tui.full_refresh(); }; -document.getElementById("drop_thing").onclick = function() { - server.send(['TASK:DROP']); -}; document.getElementById("flatten").onclick = function() { server.send(['TASK:FLATTEN_SURROUNDINGS', tui.password]); };