annotate libervia/web/pages/chat/_browser/__init__.py @ 1619:a2cd4222c702

browser: Updates for new design: This patch add code to handle the new design for chat. New bridge method are used to invite users to MUC or get list of occupants. A new modules is used for components, with a first one for collapsible cards. rel 457
author Goffi <goffi@goffi.org>
date Sat, 12 Apr 2025 00:21:45 +0200
parents c4407befc52a
children 3a60bf3762ef
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
1 import json
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
2 import re
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
3 from typing import Callable
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
4 import errors
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
5
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
6 from bridge import AsyncBridge as Bridge
1585
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
7 from browser import DOMNode, aio, console as log, document, window
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
8 from cache import cache, identities, roster
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
9 import dialog
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
10 from file_uploader import FileUploader
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
11 import jid
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
12 from javascript import pyobj2jsobj
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
13 from js_modules import emoji_picker_element
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
14 from js_modules.tippy_js import tippy as tippy_ori
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
15 import popup
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
16 from template import Template, safe
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
17 from tools import is_touch_device
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
18 from loading import remove_loading_screen
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
19 from jid_search import JidSearch
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
20 from interpreter import Inspector
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
21 from components import init_collapsible_cards
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
22
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
23 log.warning = log.warn
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
24 profile = window.profile or ""
1595
7941444c1671 pages: set `own_local_jid` to avoid confusion with `own_jid`:
Goffi <goffi@goffi.org>
parents: 1585
diff changeset
25 # JID used in the local chat (real JID for one2one, room JID otherwise)
7941444c1671 pages: set `own_local_jid` to avoid confusion with `own_jid`:
Goffi <goffi@goffi.org>
parents: 1585
diff changeset
26 own_local_jid = jid.JID(window.own_local_jid)
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
27 target_jid = jid.JID(window.target_jid)
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
28 chat_type = window.chat_type
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
29 chat_url = window.chat_url
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
30 bridge = Bridge()
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
31
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
32 # Sensible value to consider that user is at the bottom
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
33 SCROLL_SENSITIVITY = 200
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
34
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
35 INPUT_MODES = {"normal", "edit", "quote"}
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
36 MODE_CLASS = "mode_{}"
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
37
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
38
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
39 # FIXME: workaround for https://github.com/brython-dev/brython/issues/2542
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
40 def tippy(target, data):
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
41 return tippy_ori(target, pyobj2jsobj(data))
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
42
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
43
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
44 class NewChatDialog:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
45
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
46 def __init__(self, on_select: Callable[[str], None]|None = None) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
47 self.on_select = on_select
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
48 self.new_chat_dialog_tpl = Template("chat/new_chat_dialog.html")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
49 self.dialog_elt = self.new_chat_dialog_tpl.get_elt()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
50 self.modal = dialog.Modal(self.dialog_elt, is_card=True)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
51
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
52 # direct chat
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
53 self.direct_search_input_elt = self.dialog_elt.select_one(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
54 "div.direct-content input.search-input"
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
55 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
56 self.direct_items_container = self.dialog_elt.select_one(".direct-items")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
57 self.direct_count_elt = self.dialog_elt.select_one(".direct-count")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
58 self.start_chat_btn = self.dialog_elt.select_one(".action_ok")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
59 assert self.start_chat_btn is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
60 self.start_chat_btn.bind("click", self.on_start_chat_btn)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
61 if not self.direct_count_elt or not self.start_chat_btn:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
62 log.error('"direct-count" or "action_ok" element is missing.')
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
63 self.selected_entities = set()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
64 self.jid_search = JidSearch(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
65 self.direct_search_input_elt,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
66 self.direct_items_container,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
67 click_cb = self.on_search_item_click,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
68 template = "chat/search_item.html",
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
69 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
70 for elt in self.dialog_elt.select(".action_close"):
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
71 elt.bind("click", lambda __: self.close())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
72 for elt in self.dialog_elt.select("div.direct-content .action_clear_search"):
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
73 elt.bind("click", lambda __: self.clear_search_input())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
74
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
75 # groups
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
76 self.groups_search_input_elt = self.dialog_elt.select_one(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
77 "div.groups-content input.search-input"
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
78 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
79 self.groups_items_container = self.dialog_elt.select_one(".groups-items")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
80
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
81 self.selected_entities = set()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
82
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
83 self.groups_jid_search = JidSearch(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
84 self.groups_search_input_elt,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
85 self.groups_items_container,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
86 click_cb = self.on_group_search_item_click,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
87 options={"type": "group"},
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
88 template = "chat/groups_search_item.html",
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
89 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
90 for elt in self.dialog_elt.select(".action_close"):
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
91 elt.bind("click", lambda __: self.close())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
92 for elt in self.dialog_elt.select("div.groups-content .action_clear_search"):
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
93 elt.bind("click", lambda __: self.clear_groups_search_input())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
94
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
95 self.new_room_btn = self.dialog_elt.select_one(".action_new_room")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
96 assert self.new_room_btn is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
97 self.new_room_btn.bind("click", self.on_new_room_btn)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
98 self.panel_new_room = self.dialog_elt.select_one(".panel_new_room")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
99 assert self.panel_new_room is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
100 self.create_room_btn = self.dialog_elt.select_one(".action_create_room")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
101 assert self.create_room_btn is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
102 self.create_room_btn.bind("click", self._on_create_room_btn)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
103
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
104 self.error_message_elt = self.dialog_elt.select_one("div.error-message")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
105 assert self.error_message_elt is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
106 self.error_message_elt.select_one("button.delete").bind(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
107 "click",
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
108 lambda __: self.error_message_elt.classList.add("is-hidden")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
109 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
110
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
111 # tabs
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
112 self.tabs = {}
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
113 self.selected_tab_elt = None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
114 for tab_elt in self.dialog_elt.select('div.tabs>ul>li'):
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
115 if tab_elt.classList.contains("is-active"):
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
116 self.selected_tab_elt = tab_elt
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
117 tab_name = tab_elt.dataset.tab
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
118 tab_content_elt = self.dialog_elt.select_one(f".{tab_name}-content")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
119 assert tab_content_elt is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
120 self.tabs[tab_elt] = tab_content_elt
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
121 tab_elt.bind(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
122 'click',
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
123 lambda __, tab_elt=tab_elt: self.set_active_tab(tab_elt)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
124 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
125
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
126 def set_active_tab(self, selected_tab_elt) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
127 """Display a tab."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
128 self.selected_tab_elt = selected_tab_elt
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
129 for tab_elt, tab_content_elt in self.tabs.items():
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
130 if tab_elt == selected_tab_elt:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
131 tab_elt.classList.add("is-active")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
132 tab_content_elt.classList.remove("is-hidden")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
133 else:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
134 tab_elt.classList.remove("is-active")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
135 tab_content_elt.classList.add("is-hidden")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
136 self.update()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
137
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
138 def clear_search_input(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
139 """Clear search input, and update dialog."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
140 self.direct_search_input_elt.value = ""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
141 self.direct_search_input_elt.dispatchEvent(window.Event.new("input"))
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
142 self.update()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
143
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
144 def clear_groups_search_input(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
145 """Clear search input, and update dialog."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
146 self.groups_search_input_elt.value = ""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
147 self.groups_search_input_elt.dispatchEvent(window.Event.new("input"))
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
148 self.groups_update()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
149
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
150 def on_search_item_click(self, event, item) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
151 """A search item has been clicked"""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
152 search_item_elt = event.currentTarget
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
153 search_item_elt.classList.toggle("is-selected")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
154 self.update()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
155
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
156 def on_group_search_item_click(self, event, item) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
157 """A search item has been clicked"""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
158 for item_elt in self.groups_items_container.select(".search-item"):
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
159 if item_elt == event.currentTarget:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
160 item_elt.classList.add("is-selected")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
161 else:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
162 item_elt.classList.remove("is-selected")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
163 self.update()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
164
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
165 def update(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
166 """Update dialog elements (counter, button) when search items change."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
167 assert self.selected_tab_elt is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
168 current_tab = self.selected_tab_elt.dataset.tab
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
169 match current_tab:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
170 case "direct":
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
171 self.selected_entities = {
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
172 item_elt.dataset.entity for item_elt in
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
173 self.direct_items_container.select(".search-item.is-selected")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
174 }
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
175 self.direct_count_elt.text = str(len(self.selected_entities))
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
176 case "groups":
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
177 self.selected_entities = {
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
178 item_elt.dataset.entity for item_elt in
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
179 self.groups_items_container.select(".search-item.is-selected")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
180 }
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
181 case _:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
182 raise ValueError(f"Unknown tab: {current_tab!r}.")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
183
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
184 self.start_chat_btn.disabled = not bool(self.selected_entities)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
185
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
186 def groups_update(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
187 """Update dialog elements when groups search items change."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
188 self.selected_entities = {
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
189 item_elt.dataset.entity for item_elt in
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
190 self.direct_items_container.select(".search-item.is-selected")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
191 }
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
192 self.start_chat_btn.disabled = not bool(self.selected_entities)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
193
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
194 def on_new_room_btn(self, evt) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
195 self.panel_new_room.classList.toggle("is-hidden")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
196
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
197 def _on_create_room_btn(self, evt) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
198 aio.run(self.on_create_room_btn())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
199
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
200 async def on_create_room_btn(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
201 assert self.on_select is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
202 input_elt = self.dialog_elt.select_one(".input-room-name")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
203 assert input_elt is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
204 try:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
205 joined_data = await bridge.muc_join(input_elt.value.strip(), "", {})
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
206 except Exception as e:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
207 msg = f"Can't create room: {e}"
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
208 log.error(msg)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
209 self.error_message_elt.select_one("p").text = msg
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
210 self.error_message_elt.classList.remove("is-hidden")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
211 return
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
212
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
213 joined, room_jid_s, occupants, user_nick, subject, statuses, profile = joined_data
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
214 self.on_select(room_jid_s)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
215
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
216 def on_start_chat_btn(self, evt) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
217 evt.stopPropagation()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
218 if self.on_select is None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
219 return
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
220 if not self.selected_entities:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
221 raise errors.InternalError(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
222 "Start button should never be called when no entity is selected."
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
223 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
224 if len(self.selected_entities) == 1:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
225 selected_entity = next(iter(self.selected_entities))
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
226 self.on_select(selected_entity)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
227 else:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
228 aio.run(self.create_room_selected_jids())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
229
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
230 async def create_room_selected_jids(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
231 assert self.on_select is not None
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
232 joined_data = await bridge.muc_join("", "", {})
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
233 joined, room_jid_s, occupants, user_nick, subject, statuses, profile = joined_data
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
234 if not self.selected_entities:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
235 Inspector()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
236 for entity_jid in self.selected_entities:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
237 print(f"inviting {entity_jid=}")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
238 await bridge.muc_invite(entity_jid, room_jid_s, {})
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
239 self.on_select(room_jid_s)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
240
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
241
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
242 def show(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
243 """Show the dialog."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
244 # We want ot be sure to have the elements correctly set when dialog is shown
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
245 self.update()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
246 self.modal.show()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
247
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
248 def close(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
249 """Close the dialog."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
250 self.modal.close()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
251
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
252
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
253 class LiberviaWebChat:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
254 def __init__(self):
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
255 self._input_mode = "normal"
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
256 self.input_data = {}
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
257 self.direct_messages_tpl = Template("chat/direct_messages.html")
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
258 self.message_tpl = Template("chat/message.html")
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
259 self.extra_menu_tpl = Template("chat/extra_menu.html")
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
260 self.reactions_tpl = Template("chat/reactions.html")
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
261 self.reactions_details_tpl = Template("chat/reactions_details.html")
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
262 self.url_preview_control_tpl = Template("components/url_preview_control.html")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
263 self.url_preview_tpl = Template("components/url_preview.html")
1542
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
264 self.new_messages_marker_elt = Template("chat/new_messages_marker.html").get_elt()
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
265 self.editions_tpl = Template("chat/editions.html")
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
266 self.occupant_item_tpl = Template("chat/occupant_item.html")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
267
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
268 # panels and their toggle buttons
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
269
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
270 self.left_panel = document["left_panel"]
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
271 self.left_toggle = document["left_panel-toggle"]
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
272 self.left_toggle.bind("click", self.on_left_panel_toggle_click)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
273 self.main_panel = document["main_panel"]
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
274 self.right_panel = document["right_panel"]
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
275 self.right_toggle = document["right_panel-toggle"]
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
276 self.right_toggle.bind("click", self.on_right_panel_toggle_click)
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
277
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
278 self.messages_elt = document["messages"]
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
279
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
280 # right-panel internal buttons
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
281 init_collapsible_cards(self.right_panel)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
282
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
283 # attachments
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
284 self.file_uploader = FileUploader(
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
285 "", "chat/attachment_preview.html", on_delete_cb=self.on_attachment_delete
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
286 )
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
287 self.attachments_elt = document["attachments"]
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
288 self.message_input = document["message_input_area"]
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
289
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
290 # close_button = document.select_one(".modal-close")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
291 # close_button.bind("click", self.close_modal)
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
292
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
293 # hide/show attachments
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
294 MutationObserver = window.MutationObserver
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
295 observer = MutationObserver.new(lambda *__: self.update_attachments_visibility())
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
296 observer.observe(self.attachments_elt, {"childList": True})
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
297
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
298 # we want the message scroll to be initially at the bottom
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
299 self.messages_elt.scrollTop = self.messages_elt.scrollHeight
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
300
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
301 # listeners/dynamic updates
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
302 self.add_message_event_listeners()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
303 self.handle_url_previews()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
304 self.add_reactions_listeners()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
305
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
306 # input
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
307 self.auto_resize_message_input()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
308 self.message_input.focus()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
309
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
310 # direct messages
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
311 direct_messages_elt = self.direct_messages_tpl.get_elt(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
312 {
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
313 "roster": roster,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
314 "identities": identities,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
315 "chat_url": chat_url
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
316 }
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
317 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
318 document["direct-messages"] <= direct_messages_elt
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
319
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
320 async def post_init(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
321 if chat_type == "group":
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
322 occupants = await bridge.muc_occupants_get(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
323 str(target_jid)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
324 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
325 document["occupants-count"].text = str(len(occupants))
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
326 for occupant, occupant_data in occupants.items():
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
327 occupant_elt = self.occupant_item_tpl.get_elt({
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
328 "nick": occupant,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
329 "item": occupant_data,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
330 "identities": identities,
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
331 })
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
332 document["group-occupants"] <= occupant_elt
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
333
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
334 @property
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
335 def input_mode(self) -> str:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
336 return self._input_mode
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
337
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
338 @input_mode.setter
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
339 def input_mode(self, new_mode: str) -> None:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
340 if new_mode == self.input_mode:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
341 return
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
342 if new_mode not in INPUT_MODES:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
343 raise ValueError(f"Invalid input mode: {new_mode!r}")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
344 target_elt = self.message_input
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
345 target_elt.classList.remove(MODE_CLASS.format(self._input_mode))
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
346 self._input_mode = new_mode
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
347 target_elt.classList.add(MODE_CLASS.format(new_mode))
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
348 self.input_data.clear()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
349
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
350 @property
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
351 def is_at_bottom(self):
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
352 return (
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
353 self.messages_elt.scrollHeight
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
354 - self.messages_elt.scrollTop
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
355 - self.messages_elt.clientHeight
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
356 <= SCROLL_SENSITIVITY
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
357 )
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
358
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
359 def open_chat(self, entity_jid: str) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
360 """Change the current chat for the given one."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
361 # For now we keep it simple and just load the new location.
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
362 window.location = f"{chat_url}/{entity_jid}"
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
363
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
364 async def on_new_chat(self) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
365 new_chat_dialog = NewChatDialog(on_select = self.open_chat)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
366 new_chat_dialog.show()
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
367
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
368 async def send_message(self):
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
369 """Send message currently in input area
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
370
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
371 The message and corresponding attachment will be sent
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
372 """
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
373 message = self.message_input.value.rstrip()
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
374 log.info(f"{message=}")
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
375
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
376 # attachments
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
377 attachments = []
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
378 for attachment_elt in self.attachments_elt.children:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
379 file_data = json.loads(attachment_elt.getAttribute("data-file"))
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
380 attachments.append(file_data)
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
381
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
382 if message or attachments:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
383 extra = {}
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
384
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
385 if attachments:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
386 extra["attachments"] = attachments
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
387
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
388 # now we send the message
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
389 try:
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
390 if self.input_mode == "edit":
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
391 message_id = self.input_data["id"]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
392 edit_data = {
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
393 "message": {"": message},
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
394 "extra": extra
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
395 }
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
396 await bridge.message_edit(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
397 message_id, json.dumps(edit_data, ensure_ascii=False)
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
398 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
399 else:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
400 await bridge.message_send(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
401 str(target_jid),
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
402 {"": message}, {}, "auto", json.dumps(extra, ensure_ascii=False)
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
403 )
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
404 except Exception as e:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
405 dialog.notification.show(f"Can't send message: {e}", "error")
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
406 else:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
407 self.message_input.value = ""
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
408 self.attachments_elt.clear()
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
409 self.auto_resize_message_input()
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
410 self.input_mode = "normal"
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
411
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
412 def _on_message_new(
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
413 self,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
414 uid: str,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
415 timestamp: float,
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
416 from_jid_s: str,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
417 to_jid_s: str,
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
418 message: dict,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
419 subject: dict,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
420 mess_type: str,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
421 extra_s: str,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
422 profile: str,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
423 ) -> None:
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
424 from_jid = jid.JID(from_jid_s)
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
425 to_jid = jid.JID(to_jid_s)
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
426 if (
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
427 from_jid.bare == window.target_jid
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
428 or to_jid.bare == window.target_jid
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
429 ):
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
430 aio.run(
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
431 self.on_message_new(
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
432 uid,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
433 timestamp,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
434 from_jid,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
435 to_jid,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
436 message,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
437 subject,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
438 mess_type,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
439 json.loads(extra_s),
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
440 profile,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
441 )
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
442 )
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
443
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
444 def _on_message_update(
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
445 self, uid: str, type_: str, update_data_s: str, profile: str
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
446 ) -> None:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
447 aio.run(self.on_message_update(uid, type_, update_data_s, profile))
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
448
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
449 async def on_message_update(
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
450 self, uid: str, type_: str, update_data_s: str, profile: str
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
451 ) -> None:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
452 update_data = json.loads(update_data_s)
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
453 is_at_bottom = self.is_at_bottom
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
454 if type_ == "REACTION":
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
455 reactions = update_data["reactions"]
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
456 log.debug(f"new reactions: {reactions}")
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
457 try:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
458 reactions_wrapper_elt = document[f"msg_reactions_{uid}"]
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
459 except KeyError:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
460 log.debug(f"Message {uid} not found, no reactions to update")
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
461 else:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
462 log.debug(f"Message {uid} found, new reactions: {reactions}")
1596
52098b5bab8d browser (chat): add data for reactions
Goffi <goffi@goffi.org>
parents: 1595
diff changeset
463 reactions_elt = self.reactions_tpl.get_elt(
52098b5bab8d browser (chat): add data for reactions
Goffi <goffi@goffi.org>
parents: 1595
diff changeset
464 {
52098b5bab8d browser (chat): add data for reactions
Goffi <goffi@goffi.org>
parents: 1595
diff changeset
465 "chat_type": chat_type,
52098b5bab8d browser (chat): add data for reactions
Goffi <goffi@goffi.org>
parents: 1595
diff changeset
466 "own_local_jid": str(own_local_jid),
52098b5bab8d browser (chat): add data for reactions
Goffi <goffi@goffi.org>
parents: 1595
diff changeset
467 "reactions": reactions
52098b5bab8d browser (chat): add data for reactions
Goffi <goffi@goffi.org>
parents: 1595
diff changeset
468 })
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
469 reactions_wrapper_elt.clear()
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
470 reactions_wrapper_elt <= reactions_elt
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
471 self.add_reactions_listeners(reactions_elt)
1585
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
472 elif type_ in ("EDIT", "RETRACT"):
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
473 try:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
474 old_message_elt = document[uid]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
475 except KeyError:
1585
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
476 log.debug(f"Message {uid} not found, no {type_.lower()}ion to apply")
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
477 else:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
478 template_data = await self.message_to_template_data(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
479 uid,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
480 update_data["timestamp"],
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
481 jid.JID(update_data["from"]),
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
482 jid.JID(update_data["to"]),
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
483 update_data["message"],
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
484 update_data["subject"],
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
485 update_data["type"],
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
486 update_data["extra"]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
487 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
488
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
489 new_message_elt = self.message_tpl.get_elt(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
490 template_data
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
491 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
492 old_message_elt.replaceWith(new_message_elt)
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
493 self.add_message_event_listeners(new_message_elt)
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
494 self.handle_url_previews(new_message_elt)
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
495 else:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
496 log.warning(f"Unsupported update type: {type_!r}")
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
497
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
498 # If user was at the bottom, keep the scroll at the bottom
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
499 if is_at_bottom:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
500 self.messages_elt.scrollTop = self.messages_elt.scrollHeight
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
501
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
502 async def message_to_template_data(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
503 self,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
504 uid: str,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
505 timestamp: float,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
506 from_jid: jid.JID,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
507 to_jid: jid.JID,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
508 message_data: dict,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
509 subject_data: dict,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
510 mess_type: str,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
511 extra: dict,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
512 ) -> dict:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
513 """Generate template data to use with [message_tpl]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
514
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
515 @return: template data
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
516 """
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
517 xhtml_data = extra.get("xhtml")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
518 if not xhtml_data:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
519 xhtml = None
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
520 else:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
521 try:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
522 xhtml = xhtml_data[""]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
523 except KeyError:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
524 xhtml = next(iter(xhtml_data.values()))
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
525
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
526 if chat_type == "group":
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
527 await cache.fill_identities([str(from_jid)])
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
528 else:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
529 await cache.fill_identities([str(jid.JID(from_jid).bare)])
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
530 from_jid = from_jid.bare
1613
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
531 attachments = extra.get("attachments", [])
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
532 for attachment in attachments:
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
533 if "url" not in attachment:
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
534 try:
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
535 attachment["url"] = next(
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
536 s['url'] for s in attachment["sources"] if 'url' in s
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
537 )
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
538 except (StopIteration, KeyError):
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
539 log.warning(
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
540 f"An attachment has no URL: {attachment}"
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
541 )
1610
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
542 msg_data = {
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
543 "id": uid,
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
544 "timestamp": extra.get("updated", timestamp),
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
545 "type": mess_type,
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
546 "from_": str(from_jid),
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
547 "text": message_data.get("") or next(iter(message_data.values()), ""),
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
548 "subject": subject_data.get("") or next(iter(subject_data.values()), ""),
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
549 "type": mess_type,
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
550 "reeceived": extra.get("received_timestamp") or timestamp,
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
551 "encrypted": extra.get("encrypted", False),
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
552 "received": extra.get("received", False),
1613
c4407befc52a browser (chat): fix attachments URL for messages.
Goffi <goffi@goffi.org>
parents: 1610
diff changeset
553 "attachments": attachments,
1610
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
554 "extra": extra
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
555 }
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
556 for key in ("thread", "thread_parent", "delay_sender", "info_type"):
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
557 value = extra.get(key)
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
558 if value is not None:
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
559 msg_data[key] = value
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
560
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
561 if xhtml:
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
562 msg_data["html"] = safe(xhtml)
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
563
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
564 return {
1595
7941444c1671 pages: set `own_local_jid` to avoid confusion with `own_jid`:
Goffi <goffi@goffi.org>
parents: 1585
diff changeset
565 "own_local_jid": str(own_local_jid),
7941444c1671 pages: set `own_local_jid` to avoid confusion with `own_jid`:
Goffi <goffi@goffi.org>
parents: 1585
diff changeset
566 "chat_type": chat_type,
1610
19c83dd943df browser (chat): don't set `None` value in message data used in template:
Goffi <goffi@goffi.org>
parents: 1596
diff changeset
567 "msg": msg_data,
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
568 "identities": identities,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
569 }
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
570
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
571 async def on_message_new(
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
572 self,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
573 uid: str,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
574 timestamp: float,
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
575 from_jid: jid.JID,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
576 to_jid: jid.JID,
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
577 message_data: dict,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
578 subject_data: dict,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
579 mess_type: str,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
580 extra: dict,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
581 profile: str,
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
582 ) -> None:
1542
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
583 # FIXME: visibilityState doesn't detect OS events such as `Alt + Tab`, using focus
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
584 # event may help to get those use cases, but it gives false positives.
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
585 if (
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
586 document.visibilityState == "hidden"
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
587 and self.new_messages_marker_elt.parent is None
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
588 ):
1542
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
589 # the page is not visible, and we have no new messages marker yet, so we add
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
590 # it
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
591 self.messages_elt <= self.new_messages_marker_elt
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
592
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
593 template_data = await self.message_to_template_data(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
594 uid,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
595 timestamp,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
596 from_jid,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
597 to_jid,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
598 message_data,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
599 subject_data,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
600 mess_type,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
601 extra
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
602 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
603
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
604 message_elt = self.message_tpl.get_elt(
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
605 template_data
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
606 )
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
607
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
608 # Check if user is viewing older messages or is at the bottom
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
609 is_at_bottom = self.is_at_bottom
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
610
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
611 self.messages_elt <= message_elt
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
612 self.add_message_event_listeners(message_elt)
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
613 # we add preview in parallel on purpose, as they can be slow to get
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
614 self.handle_url_previews(message_elt)
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
615
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
616 # If user was at the bottom, keep the scroll at the bottom
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
617 if is_at_bottom:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
618 self.messages_elt.scrollTop = self.messages_elt.scrollHeight
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
619
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
620 def auto_resize_message_input(self):
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
621 """Resize the message input field according to content."""
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
622 is_at_bottom = self.is_at_bottom
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
623
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
624 # The textarea's height is first reset to 'auto' to ensure it's not influenced by
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
625 # the previous content.
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
626 self.message_input.style.height = "auto"
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
627
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
628 # Then the height is set to the scrollHeight of the textarea (which is the height
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
629 # of the content), plus the vertical border, resulting in a textarea that grows as
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
630 # more lines of text are added.
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
631 self.message_input.style.height = f"{self.message_input.scrollHeight + 2}px"
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
632
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
633 if is_at_bottom:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
634 # we want the message are to still display the last message
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
635 self.messages_elt.scrollTop = self.messages_elt.scrollHeight
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
636
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
637 def on_left_panel_toggle_click(self, evt) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
638 """Show/Hide side bar."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
639 self.left_panel.classList.toggle("is-collapsed")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
640 self.main_panel.classList.toggle("is-expanded-left")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
641
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
642 def on_right_panel_toggle_click(self, evt) -> None:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
643 """Show/Hide side bar."""
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
644 self.right_panel.classList.toggle("is-collapsed")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
645 self.main_panel.classList.toggle("is-expanded-right")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
646
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
647 def on_message_keydown(self, evt):
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
648 """Handle the 'keydown' event of the message input field
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
649
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
650 @param evt: The event object. 'target' refers to the textarea element.
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
651 """
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
652 if evt.keyCode == 13: # <Enter> key
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
653 if not window.navigator.maxTouchPoints:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
654 # we have a non touch device, we send message on <Enter>
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
655 if not evt.shiftKey:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
656 evt.preventDefault() # Prevents line break
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
657 aio.run(self.send_message())
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
658 elif evt.keyCode == 27: # <ESC> key
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
659 evt.preventDefault()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
660 self.message_input.value = ''
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
661 self.input_mode = 'normal'
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
662 self.auto_resize_message_input()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
663 elif evt.keyCode == 38: # <Up> arrow key
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
664 if self.input_mode == "normal" and self.message_input.value.strip() == "":
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
665 evt.preventDefault()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
666 own_msgs = document.getElementsByClassName('own_msg')
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
667 if own_msgs.length > 0:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
668 last_msg = own_msgs[own_msgs.length - 1]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
669 aio.run(self.on_action_edit(None, last_msg))
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
670
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
671 def update_attachments_visibility(self):
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
672 if len(self.attachments_elt.children):
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
673 self.attachments_elt.classList.remove("is-contracted")
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
674 else:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
675 self.attachments_elt.classList.add("is-contracted")
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
676
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
677 def on_file_selected(self, evt):
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
678 """Handle file selection"""
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
679 log.info("file selected")
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
680 files = evt.currentTarget.files
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
681 self.file_uploader.upload_files(files, self.attachments_elt)
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
682 self.message_input.focus()
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
683
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
684 def on_attachment_delete(self, evt):
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
685 evt.stopPropagation()
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
686 target = evt.currentTarget
1540
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
687 item_elt = DOMNode(target.closest(".attachment-preview"))
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
688 item_elt.remove()
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
689
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
690 def on_attach_button_click(self, evt):
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
691 document["file-input"].click()
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
692
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
693 def on_extra_btn_click(self, evt):
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
694 message_elt = evt.target.closest("div.chat-message")
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
695 message_core_elt = evt.target.closest("div.message-core")
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
696 is_own = message_elt.classList.contains("own_msg")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
697 if is_own:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
698 own_messages = document.select('.own_msg')
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
699 # with XMPP, we can currently only edit our last message
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
700 can_edit = own_messages and message_elt is own_messages[-1]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
701 else:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
702 can_edit = False
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
703
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
704 content_elt = self.extra_menu_tpl.get_elt({
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
705 "edit": can_edit,
1585
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
706 "retract": is_own,
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
707 })
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
708 extra_popup = popup.create_popup(evt.target, content_elt, focus_elt=message_core_elt)
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
709
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
710 def on_action_click(evt, callback):
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
711 extra_popup.hide()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
712 aio.run(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
713 callback(evt, message_elt)
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
714 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
715
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
716 for cls_name, callback in (
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
717 ("action_quote", self.on_action_quote),
1585
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
718 ("action_edit", self.on_action_edit),
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
719 ("action_retract", self.on_action_retract),
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
720 ):
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
721 for elt in content_elt.select(f".{cls_name}"):
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
722 elt.bind("click", lambda evt, callback=callback: on_action_click(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
723 evt, callback
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
724 ))
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
725
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
726 def on_reaction_click(self, evt, message_elt):
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
727 window.evt = evt
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
728 aio.run(
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
729 bridge.message_reactions_set(
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
730 message_elt["id"], [evt.detail["unicode"]], "toggle"
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
731 )
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
732 )
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
733 # if evt.deltaY != 0:
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
734 # document["attachments"].scrollLeft += evt.deltaY * 0.8
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
735 # evt.preventDefault()
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
736
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
737 async def get_message_tuple(self, message_elt) -> tuple|None:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
738 """Retrieve message tuple from as sent by [message_new]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
739
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
740 If not corresponding message data is found, an error will shown, and None is
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
741 returned.
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
742 @param message_elt: message element, it's "id" attribute will be use to retrieve
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
743 message data
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
744 @return: message data as a tuple, or None if not message with this ID is found.
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
745 """
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
746 print(f"{message_elt=}")
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
747 message_id = message_elt['id']
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
748 history_data = await bridge.history_get(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
749 "", "", -2, True, {"id": message_elt['id']}
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
750 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
751 if not history_data:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
752 dialog.notification.show(f"Can't find message {message_id}", "error")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
753 return None
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
754 return history_data[0]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
755
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
756 async def on_action_quote(self, __, message_elt) -> None:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
757 message_data = await self.get_message_tuple(message_elt)
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
758 if message_data is not None:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
759 messages = message_data[4]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
760 body = next(iter(messages.values()), "")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
761 quote = "\n".join(f"> {l}" for l in body.split("\n"))
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
762 self.message_input.value = f"{quote}\n{self.message_input.value}"
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
763 self.input_mode = "quote"
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
764 self.input_data["id"] = message_elt["id"]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
765 self.auto_resize_message_input()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
766 self.message_input.focus()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
767
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
768 async def on_action_edit(self, __, message_elt) -> None:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
769 message_data = await self.get_message_tuple(message_elt)
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
770 if message_data is not None:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
771 messages = message_data[4]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
772 body = next(iter(messages.values()), "")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
773 if not body:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
774 dialog.notification.show("No content found in message, nothing to edit")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
775 return
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
776
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
777 self.message_input.value = body
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
778 self.input_mode = "edit"
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
779 self.input_data["id"] = message_elt["id"]
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
780 self.auto_resize_message_input()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
781 self.message_input.focus()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
782
1585
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
783 async def on_action_retract(self, __, message_elt) -> None:
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
784 confirmed = await dialog.Confirm(safe(
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
785 "This message will be permanently removed. Are you sure?<br><br>"
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
786 "WARNING: It is impossible to guarantee that other participants in the "
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
787 "discussion will delete this message as well. You must assume it has been "
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
788 "seen. If a password or other sensitive information has been accidentally "
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
789 "shared, please ensure to take appropriate measures to change it and "
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
790 "mitigate the risks."
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
791 )).ashow()
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
792 if confirmed:
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
793 await bridge.message_retract(message_elt["id"])
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
794 else:
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
795 log.info(f"Retraction of message {message_elt['id']} cancelled by user.")
9fc4120888be browser (chat): message retraction implementation
Goffi <goffi@goffi.org>
parents: 1584
diff changeset
796
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
797 def get_reaction_panel(self, source_elt):
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
798 emoji_picker_elt = document.createElement("emoji-picker")
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
799 message_elt = source_elt.closest("div.chat-message")
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
800 emoji_picker_elt.bind(
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
801 "emoji-click", lambda evt: self.on_reaction_click(evt, message_elt)
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
802 )
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
803
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
804 return emoji_picker_elt
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
805
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
806 def add_message_event_listeners(self, parent_elt=None):
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
807 """Prepare a message to be dynamic
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
808
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
809 - make attachments dynamically clickable
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
810 - make the extra button clickable
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
811 """
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
812 ## attachments
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
813 # FIXME: only handle images for now, and display them in a modal
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
814 if parent_elt is None:
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
815 parent_elt = document
1540
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
816 img_elts = parent_elt.select(".message-attachment img")
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
817 for img_elt in img_elts:
1540
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
818 img_elt.bind("click", self.open_modal)
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
819 img_elt.style.cursor = "pointer"
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
820
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
821 ## reaction button
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
822 i = 0
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
823 for reaction_btn in parent_elt.select(".reaction-button"):
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
824 i+=1
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
825 message_elt = reaction_btn.closest("div.message-core")
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
826 tippy(
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
827 reaction_btn,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
828 {
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
829 "trigger": "click",
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
830 "content": self.get_reaction_panel,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
831 "appendTo": document.body,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
832 "placement": "bottom",
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
833 "interactive": True,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
834 "theme": "light",
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
835 "onShow": lambda __, message_elt=message_elt: (
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
836 message_elt.classList.add("has-popup-focus")
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
837 ),
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
838 "onHide": lambda __, message_elt=message_elt: (
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
839 message_elt.classList.remove("has-popup-focus")
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
840 ),
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
841 }
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
842 )
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
843
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
844 ## extra button
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
845 for extra_btn in parent_elt.select(".extra-button"):
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
846 extra_btn.bind("click", self.on_extra_btn_click)
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
847
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
848 ## editions
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
849 for edition_icon_elt in parent_elt.select(".message-editions"):
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
850 message_elt = edition_icon_elt.closest("div.chat-message")
1584
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
851 dataset = message_elt.dataset.to_dict()
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
852 try:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
853 editions = json.loads(dataset["editions"])
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
854 except (ValueError, KeyError):
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
855 log.error(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
856 f"Internal Error: invalid or missing editions data: {message_elt['id']}"
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
857 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
858 else:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
859 for edition in editions:
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
860 edition["text"] = (
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
861 edition["message"].get("")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
862 or next(iter(edition["message"].values()), "")
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
863 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
864 editions_elt = self.editions_tpl.get_elt({"editions": editions})
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
865 tippy(
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
866 edition_icon_elt,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
867 {
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
868 "content": editions_elt,
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
869 "theme": "light",
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
870 "appendTo": document.body
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
871 }
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
872
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
873 )
eab815e48795 browser (chat): message edition + extra menu:
Goffi <goffi@goffi.org>
parents: 1577
diff changeset
874
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
875 def add_reactions_listeners(self, parent_elt=None) -> None:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
876 """Add listener on reactions to handle details and reaction toggle"""
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
877 if parent_elt is None:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
878 parent_elt = document
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
879
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
880 is_touch = is_touch_device()
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
881
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
882 for reaction_elt in parent_elt.select(".reaction"):
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
883 # Reaction details
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
884 dataset = reaction_elt.dataset.to_dict()
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
885 reacting_jids = sorted(json.loads(dataset.get("jids", "[]")))
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
886 reaction_details_elt = self.reactions_details_tpl.get_elt(
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
887 {"reacting_jids": reacting_jids, "identities": identities}
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
888 )
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
889
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
890 # Configure tippy based on device type
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
891 tippy_config = {
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
892 "content": reaction_details_elt,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
893 "placement": "bottom",
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
894 "theme": "light",
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
895 "touch": ["hold", 500] if is_touch else True,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
896 "trigger": "click" if is_touch else "mouseenter focus",
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
897 "delay": [0, 800] if is_touch else 0,
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
898 }
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
899 tippy(reaction_elt, tippy_config)
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
900
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
901 # Toggle reaction when clicked/touched
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
902 emoji_elt = reaction_elt.select_one(".emoji")
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
903 emoji = emoji_elt.html.strip()
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
904 message_elt = reaction_elt.closest("div.chat-message")
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
905 msg_id = message_elt["id"]
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
906
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
907 def toggle_reaction(event, msg_id=msg_id, emoji=emoji):
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
908 # Prevent default if it's a touch device to distinguish from long press
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
909 if is_touch:
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
910 event.preventDefault()
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
911 aio.run(bridge.message_reactions_set(msg_id, [emoji], "toggle"))
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
912
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
913 reaction_elt.bind("click", toggle_reaction)
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
914
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
915 def find_links(self, message_elt):
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
916 """Find all http and https links within the body of a message."""
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
917 msg_body_elt = message_elt.select_one(".msg_body")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
918 if not msg_body_elt:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
919 return
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
920
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
921 # Extracting links from text content
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
922 text = msg_body_elt.text
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
923 raw_urls = re.findall(
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
924 r"http[s]?://(?:[a-zA-Z]|[0-9]|[$-_@.&+]|[!*\\(\\),]|(?:%[0-9a-fA-F][0-9a-fA-F])|#)+",
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
925 text,
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
926 )
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
927
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
928 # Extracting links from <a> elements
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
929 a_elements = msg_body_elt.select("a")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
930 for a_elt in a_elements:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
931 href = a_elt.attrs.get("href", "")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
932 if href.startswith("http://") or href.startswith("https://"):
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
933 raw_urls.append(href)
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
934
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
935 # we remove duplicates
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
936 urls = list(dict.fromkeys(raw_urls))
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
937
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
938 return urls
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
939
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
940 async def add_url_previews(self, url_previews_elt, urls) -> None:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
941 """Add URL previews to the .url-previews element of a message."""
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
942 url_previews_elt.clear()
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
943 for url in urls:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
944 try:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
945 url_preview_data_s = await bridge.url_preview_get(url, "")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
946 except Exception as e:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
947 log.warning(f"Couldn't get URL preview for {url}: {e}")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
948 continue
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
949
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
950 if not url_preview_data_s:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
951 log.warning(f"No preview could be found for URL: {url}")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
952 continue
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
953
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
954 url_preview_data = json.loads(url_preview_data_s)
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
955
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
956 url_preview_elt = self.url_preview_tpl.get_elt(
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
957 {"url_preview": url_preview_data}
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
958 )
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
959 url_previews_elt <= url_preview_elt
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
960
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
961 def handle_url_previews(self, parent_elt=None):
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
962 """Check if URL are presents in a message and show appropriate element
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
963
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
964 According to settings, either a preview control panel will be shown to wait for
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
965 user click, or directly the previews, or nothing at all.
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
966 """
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
967
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
968 if parent_elt is None:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
969 parent_elt = document
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
970 chat_message_elts = parent_elt.select(".chat-message")
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
971 else:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
972 chat_message_elts = [parent_elt]
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
973 for message_elt in chat_message_elts:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
974 urls = self.find_links(message_elt)
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
975 if urls:
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
976 url_previews_elt = message_elt.select_one(".url-previews")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
977 url_previews_elt.classList.remove("is-hidden")
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
978 preview_control_elt = self.url_preview_control_tpl.get_elt()
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
979 fetch_preview_btn = preview_control_elt.select_one(
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
980 ".action_fetch_preview"
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
981 )
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
982 fetch_preview_btn.bind(
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
983 "click",
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
984 lambda __, previews_elt=url_previews_elt, preview_urls=urls: aio.run(
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
985 self.add_url_previews(previews_elt, preview_urls)
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
986 ),
1541
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
987 )
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
988 url_previews_elt <= preview_control_elt
3c384b51b2a1 browser (chat): URL previews implementation
Goffi <goffi@goffi.org>
parents: 1540
diff changeset
989
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
990 def open_modal(self, evt):
1540
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
991 modal_image = document.select_one("#modal-image")
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
992 modal_image.src = evt.target.src
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
993 modal_image.alt = evt.target.alt
1540
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
994 modal = document.select_one("#modal")
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
995 modal.classList.add("is-active")
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
996
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
997 def close_modal(self, evt):
1540
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
998 modal = document.select_one("#modal")
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
999 modal.classList.remove("is-active")
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
1000
1542
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1001 def handle_visibility_change(self, evt):
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1002 if (
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1003 document.visibilityState == "hidden"
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1004 and self.new_messages_marker_elt.parent is not None
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1005 ):
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1006 # if there is a new messages marker, we remove it
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1007 self.new_messages_marker_elt.remove()
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1008
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1009
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
1010 libervia_web_chat = LiberviaWebChat()
1540
b4342176fa0a browser (chat): minor reformatting
Goffi <goffi@goffi.org>
parents: 1536
diff changeset
1011
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1012 document["new_chat_btn"].bind(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1013 "click", lambda __: aio.run(libervia_web_chat.on_new_chat())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1014 )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1015
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
1016 document["message_input"].bind(
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
1017 "input", lambda __: libervia_web_chat.auto_resize_message_input()
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
1018 )
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
1019 document["message_input"].bind("keydown", libervia_web_chat.on_message_keydown)
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1020 # document["send_button"].bind(
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1021 # "click",
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1022 # lambda __: aio.run(libervia_web_chat.send_message())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1023 # )
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1024 document["attach-button"].bind("click", libervia_web_chat.on_attach_button_click)
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1025 document["file-input"].bind("change", libervia_web_chat.on_file_selected)
1542
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1026
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1027 document.bind("visibilitychange", libervia_web_chat.handle_visibility_change)
fb31d3dba0c3 browser (chat): add marker for new messages when page is not visible
Goffi <goffi@goffi.org>
parents: 1541
diff changeset
1028
1536
dc81403a5b2f browser: chat page:
Goffi <goffi@goffi.org>
parents:
diff changeset
1029 bridge.register_signal("message_new", libervia_web_chat._on_message_new)
1577
9ba532041a8e browser (chat): implement message reactions.
Goffi <goffi@goffi.org>
parents: 1542
diff changeset
1030 bridge.register_signal("message_update", libervia_web_chat._on_message_update)
1619
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1031 aio.run(libervia_web_chat.post_init())
a2cd4222c702 browser: Updates for new design:
Goffi <goffi@goffi.org>
parents: 1613
diff changeset
1032 remove_loading_screen()