Skip to content

Commit

Permalink
boxes: Disable stream change during edit.
Browse files Browse the repository at this point in the history
Partial fix for #774, for stream message edits.

Tidying and simplification of state handling by neiljp.

Co-authored-by: Abhirup-99 <[email protected]>
  • Loading branch information
neiljp and Abhirup-99 committed Mar 13, 2022
1 parent 014cff3 commit eddd0ef
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 13 deletions.
2 changes: 1 addition & 1 deletion tests/ui_tools/test_boxes.py
Original file line number Diff line number Diff line change
Expand Up @@ -1412,7 +1412,7 @@ def test_keypress_typeahead_mode_autocomplete_key(
True,
True,
"CONTAINER_HEADER",
"HEADER_BOX_STREAM",
"HEADER_BOX_TOPIC",
id="edit_box-message_to_stream_name_box",
),
case(
Expand Down
30 changes: 18 additions & 12 deletions zulipterminal/ui_tools/boxes.py
Original file line number Diff line number Diff line change
Expand Up @@ -355,16 +355,6 @@ def _setup_common_stream_compose(
)
self.msg_write_box.set_completer_delims(DELIMS_MESSAGE_COMPOSE)

self.stream_write_box = ReadlineEdit(
edit_text=caption, max_char=self.model.max_stream_name_length
)
self.stream_write_box.enable_autocomplete(
func=self._stream_box_autocomplete,
key=primary_key_for_command("AUTOCOMPLETE"),
key_reverse=primary_key_for_command("AUTOCOMPLETE_REVERSE"),
)
self.stream_write_box.set_completer_delims("")

self.title_write_box = ReadlineEdit(
edit_text=title, max_char=self.model.max_topic_length
)
Expand Down Expand Up @@ -410,6 +400,15 @@ def _setup_common_stream_compose(
def stream_box_view(
self, stream_id: int, caption: str = "", title: str = ""
) -> None:
self.stream_write_box = ReadlineEdit(
edit_text=caption, max_char=self.model.max_stream_name_length
)
self.stream_write_box.enable_autocomplete(
func=self._stream_box_autocomplete,
key=primary_key_for_command("AUTOCOMPLETE"),
key_reverse=primary_key_for_command("AUTOCOMPLETE_REVERSE"),
)
self.stream_write_box.set_completer_delims("")
self._setup_common_stream_compose(stream_id, caption, title)

# Use and set a callback to set the stream marker
Expand All @@ -421,6 +420,7 @@ def stream_box_view(
def stream_box_edit_view(
self, stream_id: int, caption: str = "", title: str = ""
) -> None:
self.stream_write_box = urwid.Text(caption)
self._setup_common_stream_compose(stream_id, caption, title)

self.edit_mode_button = EditModeButton(
Expand Down Expand Up @@ -823,7 +823,10 @@ def keypress(self, size: urwid_Size, key: str) -> Optional[str]:
if self.focus_position == self.FOCUS_CONTAINER_HEADER:
if self.compose_box_status == "open_with_stream":
if header.focus_col == self.FOCUS_HEADER_BOX_STREAM:
stream_name = header[self.FOCUS_HEADER_BOX_STREAM].edit_text
if self.msg_edit_state is None:
stream_name = header[self.FOCUS_HEADER_BOX_STREAM].edit_text
else:
stream_name = header[self.FOCUS_HEADER_BOX_STREAM].text
if not self.model.is_valid_stream(stream_name):
invalid_stream_error = (
"Invalid stream name."
Expand Down Expand Up @@ -875,7 +878,10 @@ def keypress(self, size: urwid_Size, key: str) -> Optional[str]:
else:
self.focus_position = self.FOCUS_CONTAINER_HEADER
if self.compose_box_status == "open_with_stream":
header.focus_col = self.FOCUS_HEADER_BOX_STREAM
if self.msg_edit_state is not None:
header.focus_col = self.FOCUS_HEADER_BOX_TOPIC
else:
header.focus_col = self.FOCUS_HEADER_BOX_STREAM
else:
header.focus_col = self.FOCUS_HEADER_BOX_RECIPIENT

Expand Down

0 comments on commit eddd0ef

Please sign in to comment.