diff options
-rw-r--r-- | poezio/windows/roster_win.py | 61 |
1 files changed, 32 insertions, 29 deletions
diff --git a/poezio/windows/roster_win.py b/poezio/windows/roster_win.py index f1490709..3497e342 100644 --- a/poezio/windows/roster_win.py +++ b/poezio/windows/roster_win.py @@ -6,29 +6,32 @@ import logging log = logging.getLogger(__name__) from datetime import datetime +from typing import Optional, List, Union, Dict from poezio.windows.base_wins import Win from poezio import common from poezio.config import config from poezio.contact import Contact, Resource -from poezio.roster import RosterGroup +from poezio.roster import Roster, RosterGroup from poezio.theming import get_theme, to_curses_attr +Row = Union[RosterGroup, Contact] + class RosterWin(Win): - def __init__(self): + def __init__(self) -> None: Win.__init__(self) self.pos = 0 # cursor position in the contact list self.start_pos = 1 # position of the start of the display - self.selected_row = None - self.roster_cache = [] + self.selected_row = None # type: Optional[Row] + self.roster_cache = [] # type: List[Row] @property - def roster_len(self): + def roster_len(self) -> int: return len(self.roster_cache) - def move_cursor_down(self, number=1): + def move_cursor_down(self, number: int = 1) -> bool: """ Return True if we scrolled, False otherwise """ @@ -45,7 +48,7 @@ class RosterWin(Win): self.update_pos() return pos != self.pos - def move_cursor_up(self, number=1): + def move_cursor_up(self, number: int = 1) -> bool: """ Return True if we scrolled, False otherwise """ @@ -62,13 +65,13 @@ class RosterWin(Win): self.update_pos() return pos != self.pos - def update_pos(self): + def update_pos(self) -> None: if len(self.roster_cache) > self.pos and self.pos >= 0: self.selected_row = self.roster_cache[self.pos] elif self.roster_cache: self.selected_row = self.roster_cache[-1] - def scroll_down(self, number=8): + def scroll_down(self, number: int = 8): pos = self.start_pos if self.start_pos + number <= self.roster_len - 1: self.start_pos += number @@ -76,7 +79,7 @@ class RosterWin(Win): self.start_pos = self.roster_len - 1 return self.start_pos != pos - def scroll_up(self, number=8): + def scroll_up(self, number: int = 8): pos = self.start_pos if self.start_pos - number > 0: self.start_pos -= number @@ -84,7 +87,7 @@ class RosterWin(Win): self.start_pos = 1 return self.start_pos != pos - def build_roster_cache(self, roster): + def build_roster_cache(self, roster: Roster) -> None: """ Regenerates the roster cache if needed """ @@ -124,7 +127,7 @@ class RosterWin(Win): pos] != self.selected_row: self.pos = self.roster_cache.index(self.selected_row) - def refresh(self, roster): + def refresh(self, roster: Roster) -> None: """ We display a number of lines from the roster cache (and rebuild it if needed) @@ -178,7 +181,7 @@ class RosterWin(Win): self.draw_plus(self.height - 1) self._refresh() - def draw_plus(self, y): + def draw_plus(self, y: int) -> None: """ Draw the indicator that shows that the list is longer than what is displayed @@ -186,7 +189,7 @@ class RosterWin(Win): self.addstr(y, self.width - 5, '++++', to_curses_attr(get_theme().COLOR_MORE_INDICATOR)) - def draw_roster_information(self, roster): + def draw_roster_information(self, roster: Roster) -> None: """ The header at the top """ @@ -196,7 +199,7 @@ class RosterWin(Win): to_curses_attr(get_theme().COLOR_INFORMATION_BAR)) self.finish_line(get_theme().COLOR_INFORMATION_BAR) - def draw_group(self, y, group, colored): + def draw_group(self, y: int, group: RosterGroup, colored: bool) -> None: """ Draw a groupname on a line """ @@ -221,13 +224,13 @@ class RosterWin(Win): return name[:self.width - added - 1] + '…' def draw_contact_line(self, - y, - contact, - colored, - group, - show_roster_sub=False, - show_s2s_errors=True, - show_roster_jids=False): + y: int, + contact: Contact, + colored: bool, + group: str, + show_roster_sub: Optional[str] = None, + show_s2s_errors: bool = True, + show_roster_jids: bool = False) -> None: """ Draw on a line all information about one contact. This is basically the highest priority resource's information @@ -316,7 +319,7 @@ class RosterWin(Win): to_curses_attr(get_theme().COLOR_ROSTER_GAMING)) self.finish_line() - def draw_resource_line(self, y, resource, colored): + def draw_resource_line(self, y: int, resource: Resource, colored: bool) -> None: """ Draw a specific resource line """ @@ -329,7 +332,7 @@ class RosterWin(Win): self.addstr(y, 8, self.truncate_name(str(resource.jid), 6)) self.finish_line() - def get_selected_row(self): + def get_selected_row(self) -> Optional[Row]: if self.pos >= len(self.roster_cache): return self.selected_row if len(self.roster_cache) > 0: @@ -339,15 +342,15 @@ class RosterWin(Win): class ContactInfoWin(Win): - def draw_contact_info(self, contact): + def draw_contact_info(self, contact: Contact) -> None: """ draw the contact information """ resource = contact.get_highest_priority_resource() if contact: - jid = contact.bare_jid + jid = str(contact.bare_jid) elif resource: - jid = resource.jid + jid = str(resource.jid) else: jid = 'example@example.com' # should never happen if resource: @@ -409,7 +412,7 @@ class ContactInfoWin(Win): self.finish_line() i += 1 - def draw_group_info(self, group): + def draw_group_info(self, group: RosterGroup) -> None: """ draw the group information """ @@ -417,7 +420,7 @@ class ContactInfoWin(Win): to_curses_attr(get_theme().COLOR_INFORMATION_BAR)) self.finish_line(get_theme().COLOR_INFORMATION_BAR) - def refresh(self, selected_row): + def refresh(self, selected_row: Row) -> None: log.debug('Refresh: %s', self.__class__.__name__) self._win.erase() if isinstance(selected_row, RosterGroup): |