parent
							
								
									5af7967127
								
							
						
					
					
						commit
						2a8d5739d3
					
				
					 4 changed files with 13 additions and 14 deletions
				
			
		| 
						 | 
				
			
			@ -432,15 +432,6 @@ class GcMessageReceivedEvent(nec.NetworkIncomingEvent):
 | 
			
		|||
            # message from server
 | 
			
		||||
            self.nick = ''
 | 
			
		||||
 | 
			
		||||
        self.subject = self.stanza.getSubject()
 | 
			
		||||
 | 
			
		||||
        if self.subject is not None:
 | 
			
		||||
            app.nec.push_incoming_event(
 | 
			
		||||
                nec.NetworkEvent('gc-subject-received',
 | 
			
		||||
                                 nickname=self.msg_obj.resource,
 | 
			
		||||
                                 **vars(self.msg_obj)))
 | 
			
		||||
            return
 | 
			
		||||
 | 
			
		||||
        conditions = self.stanza.getStatusConditions()
 | 
			
		||||
        if conditions:
 | 
			
		||||
            self.status_code = []
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -227,7 +227,10 @@ class Message:
 | 
			
		|||
 | 
			
		||||
        subject = event.stanza.getSubject()
 | 
			
		||||
        groupchat = event.mtype == 'groupchat'
 | 
			
		||||
        muc_subject = subject and groupchat
 | 
			
		||||
 | 
			
		||||
        # XEP-0045: only a message that contains a <subject/> but no <body/>
 | 
			
		||||
        # element shall be considered a subject change for MUC purposes.
 | 
			
		||||
        muc_subject = subject and groupchat and not event.msgtxt
 | 
			
		||||
 | 
			
		||||
        # Determine timestamps
 | 
			
		||||
        if groupchat:
 | 
			
		||||
| 
						 | 
				
			
			@ -284,6 +287,11 @@ class Message:
 | 
			
		|||
                    event.session, event.fjid, timestamp)
 | 
			
		||||
            return
 | 
			
		||||
 | 
			
		||||
        if muc_subject:
 | 
			
		||||
            app.nec.push_incoming_event(NetworkEvent('gc-subject-received',
 | 
			
		||||
                                                     **vars(event)))
 | 
			
		||||
            return
 | 
			
		||||
 | 
			
		||||
        if groupchat:
 | 
			
		||||
            app.nec.push_incoming_event(GcMessageReceivedEvent(
 | 
			
		||||
                None,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -1535,7 +1535,7 @@ class GroupchatControl(ChatControlBase):
 | 
			
		|||
        self.draw_banner_text()
 | 
			
		||||
 | 
			
		||||
    def _nec_gc_subject_received(self, event):
 | 
			
		||||
        if event.conn.name != self.account:
 | 
			
		||||
        if event.account != self.account:
 | 
			
		||||
            return
 | 
			
		||||
        if event.jid != self.room_jid:
 | 
			
		||||
            return
 | 
			
		||||
| 
						 | 
				
			
			@ -1544,7 +1544,7 @@ class GroupchatControl(ChatControlBase):
 | 
			
		|||
            return
 | 
			
		||||
        self.set_subject(event.subject)
 | 
			
		||||
        text = _('%(nick)s has set the subject to %(subject)s') % {
 | 
			
		||||
            'nick': event.nickname, 'subject': event.subject}
 | 
			
		||||
            'nick': event.resource, 'subject': event.subject}
 | 
			
		||||
 | 
			
		||||
        if event.delayed:
 | 
			
		||||
            date = time.strftime('%d-%m-%Y %H:%M:%S',
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
| 
						 | 
				
			
			@ -2700,10 +2700,10 @@ class RosterWindow:
 | 
			
		|||
 | 
			
		||||
    def _nec_gc_subject_received(self, obj):
 | 
			
		||||
        contact = app.contacts.get_contact_with_highest_priority(
 | 
			
		||||
            obj.conn.name, obj.jid)
 | 
			
		||||
            obj.account, obj.jid)
 | 
			
		||||
        if contact:
 | 
			
		||||
            contact.status = obj.subject
 | 
			
		||||
            self.draw_contact(obj.jid, obj.conn.name)
 | 
			
		||||
            self.draw_contact(obj.jid, obj.account)
 | 
			
		||||
 | 
			
		||||
    def _nec_metacontacts_received(self, obj):
 | 
			
		||||
        self.redraw_metacontacts(obj.conn.name)
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		
		Reference in a new issue