diff options
author | Ben Kelly <bk@ancilla.ca> | 2017-12-02 19:12:48 -0500 |
---|---|---|
committer | Ben Kelly <btk@google.com> | 2018-01-28 15:01:32 -0500 |
commit | 30b2382ee1e99c0402f23fb0f8ad09861800a91c (patch) | |
tree | 487548e73a791187cf12f2b58ff935e49a502660 /wee_slack.py | |
parent | 01a3032162e48bbb0e3a9a974f9561aaacc7f814 (diff) | |
download | wee-slack-30b2382ee1e99c0402f23fb0f8ad09861800a91c.tar.gz |
SlackUser: use profile.display_name if available
Since recent changes in Slack, usernames can no longer be set directly, and
are instead inferred from the email address. This is not particularly useful,
so the recommendation is to instead use display_name. display_name may have
spaces in it, however, which confuses tab completion.
With this change, wee-slack uses display name for both display and completion,
after first stripping all whitespace from it. Ref linking (via linkify_text)
ensures that @mentions continue to work properly even when this whitespace
removal means that the name being @mentioned locally doesn't match the "real"
username.
Diffstat (limited to 'wee_slack.py')
-rw-r--r-- | wee_slack.py | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/wee_slack.py b/wee_slack.py index c452b1b..4ccbdb6 100644 --- a/wee_slack.py +++ b/wee_slack.py @@ -826,7 +826,7 @@ def nick_completion_cb(data, completion_item, current_buffer, completion): for m in current_channel.members: u = current_channel.team.users.get(m, None) if u: - w.hook_completion_list_add(completion, "@" + u.slack_name, 1, w.WEECHAT_LIST_POS_SORT) + w.hook_completion_list_add(completion, "@" + u.name, 1, w.WEECHAT_LIST_POS_SORT) return w.WEECHAT_RC_OK @@ -885,7 +885,7 @@ def complete_next_cb(data, current_buffer, command): for m in current_channel.members: u = current_channel.team.users.get(m, None) - if u and u.slack_name == word: + if u and u.name == word: # Here, we cheat. Insert a @ in front and rely in the @ # nicks being in the completion list w.buffer_set(current_buffer, "input", line_input[:word_start] + "@" + line_input[word_start:]) @@ -1059,7 +1059,7 @@ class SlackTeam(object): return {v.slack_name: k for k, v in self.channels.iteritems()} def get_username_map(self): - return {v.slack_name: k for k, v in self.users.iteritems()} + return {v.name: k for k, v in self.users.iteritems()} def get_team_hash(self): return self.team_hash @@ -1550,7 +1550,7 @@ class SlackChannel(object): if user and len(self.members) < 1000: user = self.team.users[user] - nick = w.nicklist_search_nick(self.channel_buffer, "", user.slack_name) + nick = w.nicklist_search_nick(self.channel_buffer, "", user.name) # since this is a change just remove it regardless of where it is w.nicklist_remove_nick(self.channel_buffer, nick) # now add it back in to whichever.. @@ -1898,13 +1898,20 @@ class SlackUser(object): """ def __init__(self, **kwargs): - # We require these two things for a vaid object, + # We require these two things for a valid object, # the rest we can just learn from slack self.identifier = kwargs["id"] - self.slack_name = kwargs["name"] - self.name = kwargs["name"] + self.profile = {} # in case it's not in kwargs for key, value in kwargs.items(): setattr(self, key, value) + + if self.profile.get("display_name"): + self.slack_name = self.profile["display_name"] + self.name = self.profile["display_name"].replace(' ', '') + else: + # No display name set. Fall back to the deprecated username field. + self.slack_name = kwargs["name"] + self.name = self.slack_name self.update_color() def __repr__(self): |