Merge branch 'mam-onetoone-nick-fix' into 'master'
Fix mam own nick in one to one tabs See merge request poezio/poezio!122
This commit is contained in:
commit
5b8e46c9a7
1 changed files with 12 additions and 7 deletions
|
@ -46,8 +46,9 @@ def make_line(
|
||||||
tab: tabs.ChatTab,
|
tab: tabs.ChatTab,
|
||||||
text: str,
|
text: str,
|
||||||
time: datetime,
|
time: datetime,
|
||||||
nick: str,
|
jid: JID,
|
||||||
identifier: str = '',
|
identifier: str = '',
|
||||||
|
deterministic: bool = True,
|
||||||
) -> Message:
|
) -> Message:
|
||||||
"""Adds a textual entry in the TextBuffer"""
|
"""Adds a textual entry in the TextBuffer"""
|
||||||
|
|
||||||
|
@ -55,9 +56,8 @@ def make_line(
|
||||||
time = time.replace(tzinfo=timezone.utc).astimezone(tz=None)
|
time = time.replace(tzinfo=timezone.utc).astimezone(tz=None)
|
||||||
time = time.replace(tzinfo=None)
|
time = time.replace(tzinfo=None)
|
||||||
|
|
||||||
deterministic = config.get_by_tabname('deterministic_nick_colors', tab.jid.bare)
|
|
||||||
if isinstance(tab, tabs.MucTab):
|
if isinstance(tab, tabs.MucTab):
|
||||||
nick = nick.split('/')[1]
|
nick = jid.resource
|
||||||
user = tab.get_user_by_name(nick)
|
user = tab.get_user_by_name(nick)
|
||||||
if deterministic:
|
if deterministic:
|
||||||
if user:
|
if user:
|
||||||
|
@ -76,11 +76,12 @@ def make_line(
|
||||||
color = xhtml.colors.get(color)
|
color = xhtml.colors.get(color)
|
||||||
color = (color, -1)
|
color = (color, -1)
|
||||||
else:
|
else:
|
||||||
if nick.split('/')[0] == tab.core.xmpp.boundjid.bare:
|
if jid.bare == tab.core.xmpp.boundjid.bare:
|
||||||
|
nick = tab.core.own_nick
|
||||||
color = get_theme().COLOR_OWN_NICK
|
color = get_theme().COLOR_OWN_NICK
|
||||||
else:
|
else:
|
||||||
color = get_theme().COLOR_REMOTE_USER
|
color = get_theme().COLOR_REMOTE_USER
|
||||||
nick = tab.get_nick()
|
nick = tab.get_nick()
|
||||||
return Message(
|
return Message(
|
||||||
txt=text,
|
txt=text,
|
||||||
identifier=identifier,
|
identifier=identifier,
|
||||||
|
@ -133,7 +134,7 @@ def _parse_message(msg: SMessage) -> Dict:
|
||||||
message = forwarded['stanza']
|
message = forwarded['stanza']
|
||||||
return {
|
return {
|
||||||
'time': forwarded['delay']['stamp'],
|
'time': forwarded['delay']['stamp'],
|
||||||
'nick': str(message['from']),
|
'jid': message['from'],
|
||||||
'text': message['body'],
|
'text': message['body'],
|
||||||
'identifier': message['origin-id']
|
'identifier': message['origin-id']
|
||||||
}
|
}
|
||||||
|
@ -147,13 +148,17 @@ async def retrieve_messages(tab: tabs.ChatTab,
|
||||||
msg_count = 0
|
msg_count = 0
|
||||||
msgs = []
|
msgs = []
|
||||||
to_add = []
|
to_add = []
|
||||||
|
deterministic = config.get_by_tabname(
|
||||||
|
'deterministic_nick_colors',
|
||||||
|
tab.jid.bare
|
||||||
|
)
|
||||||
try:
|
try:
|
||||||
async for rsm in results:
|
async for rsm in results:
|
||||||
for msg in rsm['mam']['results']:
|
for msg in rsm['mam']['results']:
|
||||||
if msg['mam_result']['forwarded']['stanza'] \
|
if msg['mam_result']['forwarded']['stanza'] \
|
||||||
.xml.find('{%s}%s' % ('jabber:client', 'body')) is not None:
|
.xml.find('{%s}%s' % ('jabber:client', 'body')) is not None:
|
||||||
args = _parse_message(msg)
|
args = _parse_message(msg)
|
||||||
msgs.append(make_line(tab, **args))
|
msgs.append(make_line(tab, deterministic=deterministic, **args))
|
||||||
for msg in reversed(msgs):
|
for msg in reversed(msgs):
|
||||||
to_add.append(msg)
|
to_add.append(msg)
|
||||||
msg_count += 1
|
msg_count += 1
|
||||||
|
|
Loading…
Reference in a new issue