diff frontends/src/primitivus/primitivus @ 1963:a2bc5089c2eb

backend, frontends: message refactoring (huge commit): /!\ several features are temporarily disabled, like notifications in frontends next step in refactoring, with the following changes: - jp: updated jp message to follow changes in backend/bridge - jp: added --lang, --subject, --subject_lang, and --type options to jp message + fixed unicode handling for jid - quick_frontend (QuickApp, QuickChat): - follow backend changes - refactored chat, message are now handled in OrderedDict and uid are kept so they can be updated - Message and Occupant classes handle metadata, so frontend just have to display them - Primitivus (Chat): - follow backend/QuickFrontend changes - info & standard messages are handled in the same MessageWidget class - improved/simplified handling of messages, removed update() method - user joined/left messages are merged when next to each other - a separator is shown when message is received while widget is out of focus, so user can quickly see the new messages - affiliation/role are shown (in a basic way for now) in occupants panel - removed "/me" messages handling, as it will be done by a backend plugin - message language is displayed when available (only one language per message for now) - fixed :history and :search commands - core (constants): new constants for messages type, XML namespace, entity type - core: *Message methods renamed to follow new code sytle (e.g. sendMessageToBridge => messageSendToBridge) - core (messages handling): fixed handling of language - core (messages handling): mes_data['from'] and ['to'] are now jid.JID - core (core.xmpp): reorganised message methods, added getNick() method to client.roster - plugin text commands: fixed plugin and adapted to new messages behaviour. client is now used in arguments instead of profile - plugins: added information for cancellation reason in CancelError calls - plugin XEP-0045: various improvments, but this plugin still need work: - trigger is used to avoid message already handled by the plugin to be handled a second time - changed the way to handle history, the last message from DB is checked and we request only messages since this one, in seconds (thanks Poezio folks :)) - subject reception is waited before sending the roomJoined signal, this way we are sure that everything including history is ready - cmd_* method now follow the new convention with client instead of profile - roomUserJoined and roomUserLeft messages are removed, the events are now handled with info message with a "ROOM_USER_JOINED" info subtype - probably other forgotten stuffs :p
author Goffi <goffi@goffi.org>
date Mon, 20 Jun 2016 18:41:53 +0200
parents 633b5c21aefd
children d727aab9a80e
line wrap: on
line diff
--- a/frontends/src/primitivus/primitivus	Sun Jun 19 22:22:13 2016 +0200
+++ b/frontends/src/primitivus/primitivus	Mon Jun 20 18:41:53 2016 +0200
@@ -99,7 +99,7 @@
                 self.host.messageSend(
                     chat_widget.target,
                     {'': editBar.get_edit_text()}, # TODO: handle language
-                    mess_type = "groupchat" if chat_widget.type == 'group' else "chat", # TODO: put this in QuickChat
+                    mess_type = C.MESS_TYPE_GROUPCHAT if chat_widget.type == C.CHAT_GROUP else C.MESS_TYPE_CHAT, # TODO: put this in QuickChat
                     errback=lambda failure: self.host.notify(_("Error while sending message ({})").format(failure)),
                     profile_key=chat_widget.profile
                     )
@@ -139,19 +139,15 @@
                     limit = int(args[0])
                 except (IndexError, ValueError):
                     limit = 50
-                widget.clearHistory()
-                if limit > 0:
-                    widget.historyPrint(size=limit, profile=widget.profile)
+                widget.updateHistory(size=limit, profile=widget.profile)
         elif command == 'search':
             widget = self.host.selected_widget
             if isinstance(widget, quick_chat.QuickChat):
                 pattern = " ".join(args)
                 if not pattern:
                     self.host.notif_bar.addMessage(D_("Please specify the globbing pattern to search for"))
-                widget.clearHistory()
-                widget.printInfo(D_("Results for searching the globbing pattern: %s") % pattern, extra={'timestamp': 0})
-                widget.historyPrint(size=C.HISTORY_LIMIT_NONE, search=pattern, profile=widget.profile)
-                widget.printInfo(D_("Type ':history <lines>' to reset the chat history"))
+                else:
+                    widget.updateHistory(size=C.HISTORY_LIMIT_NONE, search=pattern, profile=widget.profile)
         else:
             return
         self.set_edit_text('')
@@ -540,7 +536,8 @@
         self.redraw()
 
     def newWidget(self, widget):
-        self.selectWidget(widget)
+        if self.selected_widget is None:
+            self.selectWidget(widget)
 
     def selectWidget(self, widget):
         """Display a widget if possible,
@@ -556,6 +553,12 @@
         except KeyError:
             log.debug("No menu to delete")
         self.selected_widget = widget
+        try:
+            onSelected = self.selected_widget.onSelected
+        except AttributeError:
+            pass
+        else:
+            onSelected()
         self._visible_widgets = set([widget]) # XXX: we can only have one widget visible at the time for now
         self.contact_lists.select(None)
 
@@ -722,11 +725,12 @@
             log.error (_("FIXME FIXME FIXME: type [%s] not implemented") % type_)
             raise NotImplementedError
 
-    def roomJoinedHandler(self, room_jid_s, room_nicks, user_nick, profile):
-        super(PrimitivusApp, self).roomJoinedHandler(room_jid_s, room_nicks, user_nick, profile)
-        for contact_list in self.widgets.getWidgets(ContactList):
-            if profile in contact_list.profiles:
-                contact_list.setFocus(jid.JID(room_jid_s), True)
+    def roomJoinedHandler(self, room_jid_s, room_nicks, user_nick, subject, profile):
+        super(PrimitivusApp, self).roomJoinedHandler(room_jid_s, room_nicks, user_nick, subject, profile)
+        # if self.selected_widget is None:
+        #     for contact_list in self.widgets.getWidgets(ContactList):
+        #         if profile in contact_list.profiles:
+        #             contact_list.setFocus(jid.JID(room_jid_s), True)
 
     def progressStartedHandler(self, pid, metadata, profile):
         super(PrimitivusApp, self).progressStartedHandler(pid, metadata, profile)
@@ -745,7 +749,7 @@
     def onJoinRoom(self, button, edit):
         self.removePopUp()
         room_jid = jid.JID(edit.get_edit_text())
-        self.bridge.joinMUC(room_jid, self.profiles[self.current_profile].whoami.node, {}, self.current_profile, callback=lambda dummy: None, errback=self.dialogFailure)
+        self.bridge.mucJoin(room_jid, self.profiles[self.current_profile].whoami.node, {}, self.current_profile, callback=lambda dummy: None, errback=self.dialogFailure)
 
     #MENU EVENTS#
     def onConnectRequest(self, menu):