Ticket #1041: gajim-message-mode.4.patch
| File gajim-message-mode.4.patch, 79.8 kB (added by David Danier <goliath.mailinglist@…>, 12 months ago) |
|---|
-
src/config.py
==== Patch <gajim-message-mode> level 7 Source: c68c8ed0-6fce-42b2-a3b7-6be8b34235d4:/local:7667 [local] Target: c4d4e39b-2f5f-9a77-1c94-36969bb79148:/trunk:8975 [mirrored] (svn://svn.gajim.org/gajim/trunk) Log: r7653@damasonium: ddanier | 2007-11-14 21:10:55 +0100 r7654@damasonium: ddanier | 2007-11-15 00:32:14 +0100 * Implemented very simple message-mode like psi: - Configuration option for default-type of new messages when clicking on an roster item - SingleMessageWindow: - Added "Next" and "Quote" button - "Next"-button to read next message waiting - "Next"-button show how many messages are waiting (by subscribing to gajim.events) - "Reply"-button does not quote, "Quote"-button does - Focus on Text by default - "RE: " only added to subject if subject is not empty - "Reply"/"Quote" does not close received message window, the parent is closed when reply window is closed and only if there are no more messages waiting r7655@damasonium: ddanier | 2007-11-15 00:33:26 +0100 * TODO for message-mode r7658@damasonium: ddanier | 2007-11-15 18:24:49 +0100 * SingleMessageWindow: - Action-menu - Username is displayed - GPG-Support, but untested * typo in src/chat_control.py r7662@damasonium: ddanier | 2007-11-15 20:33:24 +0100 * Bugfix: new chat messages are accessible * SingleMessageWindow: - RosterIcons are displayed - GPG-Button works at least for outgoing messages :) - Activated encryption is saved to config, like in normal chat window * "send_outgoing_messages" renamed to "default_message_type" (see http://trac.gajim.org/ticket/1041#comment:9) r7665@damasonium: ddanier | 2007-11-15 20:42:58 +0100 * Keep "encrypted" on Reply * Use "gpg_enabled" from config r7666@damasonium: ddanier | 2007-11-15 20:47:52 +0100 * Better place for getting "gpg_enabled" out of config * GPG-Button gets no longer disabled when dealing with incoming messages (so status is visible, toggling the button doesn't hurt) r7667@damasonium: ddanier | 2007-11-15 20:55:50 +0100 * Bugfix: Fetching contact-information with self.get_contact() to early is bad * GPG-Button only active if contact has keyID attached === src/config.py ==================================================================71 71 self.notebook = self.xml.get_widget('preferences_notebook') 72 72 self.treat_incoming_messages_combobox =\ 73 73 self.xml.get_widget('treat_incoming_messages_combobox') 74 self.default_message_type_combobox =\ 75 self.xml.get_widget('default_message_type_combobox') 74 76 self.one_window_type_combobox =\ 75 77 self.xml.get_widget('one_window_type_combobox') 76 78 self.iconset_combobox = self.xml.get_widget('iconset_combobox') … … 140 142 else: 141 143 self.treat_incoming_messages_combobox.set_active(0) 142 144 145 # Set default for send outgoing messages 146 choices = common.config.opt_default_message_type 147 type = gajim.config.get('default_message_type') 148 if type in choices: 149 self.default_message_type_combobox.set_active(choices.index(type)) 150 else: 151 self.default_message_type_combobox.set_active(0) 152 143 153 # Set default for single window type 144 154 choices = common.config.opt_one_window_types 145 155 type = gajim.config.get('one_message_window') … … 574 584 config_type = common.config.opt_treat_incoming_messages[active] 575 585 gajim.config.set('treat_incoming_messages', config_type) 576 586 587 def on_default_message_type_combobox_changed(self, widget): 588 active = widget.get_active() 589 config_type = common.config.opt_default_message_type[active] 590 gajim.config.set('default_message_type', config_type) 591 577 592 def on_one_window_type_combo_changed(self, widget): 578 593 active = widget.get_active() 579 594 config_type = common.config.opt_one_window_types[active] -
src/roster_window.py
=== src/roster_window.py ==================================================================
1969 1969 self.draw_account(account) 1970 1970 1971 1971 def on_send_single_message_menuitem_activate(self, widget, account, 1972 contact =None):1972 contact=None, resource=None): 1973 1973 if contact is None: 1974 1974 dialogs.SingleMessageWindow(account, action = 'send') 1975 1975 elif type(contact) == type([]): 1976 1976 dialogs.SingleMessageWindow(account, contact, 'send') 1977 1977 else: 1978 1978 jid = contact.jid 1979 if contact.jid == gajim.get_jid_from_account(account): 1979 if resource: 1980 jid += '/' + resource 1981 elif contact.jid == gajim.get_jid_from_account(account): 1980 1982 jid += '/' + contact.resource 1981 1983 dialogs.SingleMessageWindow(account, jid, 'send') 1982 1984 … … 4350 4352 else: 4351 4353 child_iter = model.iter_next(child_iter) 4352 4354 session = None 4355 chat_messages_waiting = False 4353 4356 if first_ev: 4354 4357 if first_ev.type_ in ('chat', 'normal'): 4355 4358 session = first_ev.parameters[8] … … 4358 4361 fjid += '/' + resource 4359 4362 if self.open_event(account, fjid, first_ev): 4360 4363 return 4364 elif first_ev.type_ == 'chat': 4365 chat_messages_waiting = True 4361 4366 c = gajim.contacts.get_contact(account, jid, resource) 4362 4367 if not c or isinstance(c, list): 4363 4368 c = gajim.contacts.get_contact_with_highest_priority(account, jid) 4364 4369 if jid == gajim.get_jid_from_account(account): 4365 4370 resource = c.resource 4366 self.on_open_chat_window(widget, c, account, resource = resource, session = session) 4371 default_message_type = gajim.config.get('default_message_type') 4372 if default_message_type == 'normal' and not chat_messages_waiting: 4373 self.on_send_single_message_menuitem_activate(widget, account, c, resource = resource) 4374 else: 4375 self.on_open_chat_window(widget, c, account, resource = resource, session = session) 4367 4376 4368 4377 def on_roster_treeview_row_activated(self, widget, path, col = 0): 4369 4378 '''When an iter is double clicked: open the first event window''' -
src/dialogs.py
=== src/dialogs.py ==================================================================
1832 1832 # Keep a reference on windows so garbage collector don't restroy them 1833 1833 instances = [] 1834 1834 def __init__(self, account, to='', action='', from_whom='', subject='', 1835 message='', resource='', session=None, form_node=None ):1835 message='', resource='', session=None, form_node=None, encrypted=None): 1836 1836 self.instances.append(self) 1837 1837 self.account = account 1838 1838 self.action = action … … 1844 1844 self.resource = resource 1845 1845 self.session = session 1846 1846 1847 if encrypted is None: 1848 jid = to # cannot use self.get_contact(), as self.to_entry does not exist yet 1849 contact = None 1850 if '@' in jid: 1851 if '/' in jid: 1852 jid, resource = jid.split('/', 1) 1853 else: 1854 resource = self.resource 1855 contact = gajim.contacts.get_contact(self.account, jid, resource) 1856 if contact: # only load if we have a valid contact 1857 encrypted = gajim.config.get_per('contacts', contact.jid, 'gpg_enabled') 1858 if encrypted is None: 1859 encrypted = False 1860 self.encrypted = encrypted 1861 self.next_count = 0 1862 1847 1863 self.xml = gtkgui_helpers.get_glade('single_message_window.glade') 1848 1864 self.window = self.xml.get_widget('single_message_window') 1849 1865 self.count_chars_label = self.xml.get_widget('count_chars_label') 1850 1866 self.from_label = self.xml.get_widget('from_label') 1851 1867 self.from_entry = self.xml.get_widget('from_entry') 1868 self.from_status_image = self.xml.get_widget('from_status_image') 1869 self.from_name = self.xml.get_widget('from_name') 1852 1870 self.to_label = self.xml.get_widget('to_label') 1853 1871 self.to_entry = self.xml.get_widget('to_entry') 1872 self.to_status_image = self.xml.get_widget('to_status_image') 1873 self.to_name = self.xml.get_widget('to_name') 1854 1874 self.subject_entry = self.xml.get_widget('subject_entry') 1855 1875 self.message_scrolledwindow = self.xml.get_widget( 1856 1876 'message_scrolledwindow') … … 1876 1896 parent_box.child_get_property(self.xml.get_widget('conversation_scrolledwindow'), 'position')) 1877 1897 self.action = 'form' 1878 1898 1899 self.gpg_togglebutton = self.xml.get_widget('gpg_togglebutton') 1900 self.gpg_togglebutton_separator = self.xml.get_widget('gpg_togglebutton_separator') 1879 1901 self.send_button = self.xml.get_widget('send_button') 1902 self.quote_button = self.xml.get_widget('quote_button') 1880 1903 self.reply_button = self.xml.get_widget('reply_button') 1904 self.next_button = self.xml.get_widget('next_button') 1905 self.next_count_label = self.xml.get_widget('next_count_label') 1881 1906 self.send_and_close_button = self.xml.get_widget('send_and_close_button') 1882 1907 self.cancel_button = self.xml.get_widget('cancel_button') 1883 1908 self.close_button = self.xml.get_widget('close_button') … … 1902 1927 1903 1928 self.prepare_widgets_for(self.action) 1904 1929 1930 gajim.events.event_added_subscribe(self.on_event_added) 1931 gajim.events.event_removed_subscribe(self.on_event_removed) 1932 if self.action == 'receive': 1933 self.update_next_count() 1934 1905 1935 # set_text(None) raises TypeError exception 1906 1936 if self.subject is None: 1907 1937 self.subject = '' … … 1924 1954 1925 1955 if gajim.config.get('saveposition'): 1926 1956 # get window position and size from config 1927 gtkgui_helpers.move_window(self.window, 1928 gajim.config.get('single-msg-x-position'), 1929 gajim.config.get('single-msg-y-position')) 1957 # Makes absolutely no sense when dealing with multiple windows 1958 # (for example when hitting "reply" the orig window stays) 1959 #gtkgui_helpers.move_window(self.window, 1960 # gajim.config.get('single-msg-x-position'), 1961 # gajim.config.get('single-msg-y-position')) 1930 1962 gtkgui_helpers.resize_window(self.window, 1931 1963 gajim.config.get('single-msg-width'), 1932 1964 gajim.config.get('single-msg-height')) … … 1968 2000 self.send_and_close_button.show() 1969 2001 self.to_label.show() 1970 2002 self.to_entry.show() 2003 self.to_status_image.show() 2004 self.to_name.show() 1971 2005 self.reply_button.hide() 2006 self.quote_button.hide() 2007 self.next_button.hide() 1972 2008 self.from_label.hide() 1973 2009 self.from_entry.hide() 2010 self.from_status_image.hide() 2011 self.from_name.hide() 1974 2012 self.conversation_scrolledwindow.hide() 1975 2013 self.message_scrolledwindow.show() 2014 self.gpg_togglebutton.show() 2015 if type(self.to) == type([]): 2016 self.gpg_togglebutton.set_property('sensitive', False) 2017 self.gpg_togglebutton.set_active(False) 2018 else: 2019 self.gpg_togglebutton.set_property('sensitive', True) 2020 self.gpg_togglebutton.set_active(self.encrypted) 2021 self.gpg_togglebutton_separator.show() 1976 2022 1977 2023 if self.message: # we come from a reply? 1978 2024 self.message_textview.grab_focus() … … 1983 2029 else: # we write a new message (not from reply) 1984 2030 self.close_button.hide() 1985 2031 if self.to: # do we already have jid? 1986 self.subject_entry.grab_focus() 2032 # Most of the time users skip the subject 2033 #self.subject_entry.grab_focus() 2034 self.message_textview.grab_focus() 2035 else: 2036 self.to_entry.grab_focus() 2037 self.update_to_information() 1987 2038 1988 2039 elif action == 'receive': # prepare UI for Receiving 1989 2040 title = _('Received %s') % title 1990 2041 self.reply_button.show() 2042 self.quote_button.show() 2043 self.next_button.show() 1991 2044 self.from_label.show() 1992 2045 self.from_entry.show() 2046 self.from_status_image.show() 2047 self.from_name.show() 1993 2048 self.send_button.hide() 1994 2049 self.send_and_close_button.hide() 1995 2050 self.to_label.hide() 1996 2051 self.to_entry.hide() 2052 self.to_status_image.hide() 2053 self.to_name.hide() 1997 2054 self.conversation_scrolledwindow.show() 1998 2055 self.message_scrolledwindow.hide() 2056 self.gpg_togglebutton.show() 2057 self.gpg_togglebutton.set_active(self.encrypted) 2058 self.gpg_togglebutton_separator.show() 1999 2059 2000 2060 if self.message: 2001 2061 self.conversation_textview.print_real_text(self.message) … … 2008 2068 self.reply_button.grab_focus() 2009 2069 self.cancel_button.hide() 2010 2070 self.close_button.show() 2071 self.update_from_information() 2072 2011 2073 elif action == 'form': # prepare UI for Receiving 2012 2074 title = _('Form %s') % title 2013 2075 self.send_button.show() 2014 2076 self.send_and_close_button.show() 2015 2077 self.to_label.show() 2016 2078 self.to_entry.show() 2079 self.to_status_image.show() 2080 self.to_name.show() 2017 2081 self.reply_button.hide() 2018 2082 self.from_label.hide() 2019 2083 self.from_entry.hide() 2084 self.from_status_image.hide() 2085 self.from_name.hide() 2020 2086 self.conversation_scrolledwindow.hide() 2021 2087 self.message_scrolledwindow.hide() 2088 self.gpg_togglebutton.hide() 2089 self.gpg_togglebutton_separator.hide() 2090 self.update_to_information() 2022 2091 2023 2092 self.window.set_title(title) 2024 2093 2094 def on_to_entry_changed(self, widget): 2095 self.update_to_information() 2096 2097 def update_to_information(self): 2098 jid, resource, contact = self.get_jid_resource_and_contact() 2099 if contact: 2100 if contact.keyID: 2101 self.gpg_togglebutton.set_property('sensitive', True) 2102 else: 2103 self.gpg_togglebutton.set_property('sensitive', False) 2104 self.to_status_image.show() 2105 roster = gajim.interface.roster 2106 show = contact.show 2107 img = roster.get_appropriate_state_images(jid, icon_name=show) 2108 status_image = img[show] 2109 if status_image.get_storage_type() == gtk.IMAGE_ANIMATION: 2110 self.to_status_image.set_from_animation(status_image.get_animation()) 2111 else: 2112 pix = status_image.get_pixbuf() 2113 if pix is not None: 2114 self.to_status_image.set_from_pixbuf(pix) 2115 self.to_name.show() 2116 self.to_name.set_text(contact.get_shown_name()) 2117 else: 2118 self.to_status_image.hide() 2119 self.to_name.hide() 2120 2121 def update_from_information(self): 2122 jid = self.from_whom 2123 contact = None 2124 if '@' in jid: 2125 if '/' in jid: 2126 jid, resource = jid.split('/', 1) 2127 else: 2128 resource = self.resource 2129 contact = gajim.contacts.get_contact(self.account, jid, resource) 2130 if contact: 2131 self.from_status_image.show() 2132 roster = gajim.interface.roster 2133 show = contact.show 2134 img = roster.get_appropriate_state_images(jid, icon_name=show) 2135 status_image = img[show] 2136 if status_image.get_storage_type() == gtk.IMAGE_ANIMATION: 2137 self.from_status_image.set_from_animation(status_image.get_animation()) 2138 else: 2139 pix = status_image.get_pixbuf() 2140 if pix is not None: 2141 self.from_status_image.set_from_pixbuf(pix) 2142 self.from_name.show() 2143 self.from_name.set_text(contact.get_shown_name()) 2144 else: 2145 self.from_status_image.hide() 2146 self.from_name.hide() 2147 2148 def on_actions_button_clicked(self, widget): 2149 '''popup action menu''' 2150 menu = self.prepare_context_menu() 2151 menu.show_all() 2152 gtkgui_helpers.popup_emoticons_under_button(menu, widget, self.window.window) 2153 2154 def get_jid_and_resource(self): 2155 if self.action == 'receive': 2156 jid = self.from_whom 2157 elif self.action == 'send': 2158 jid = self.to_entry.get_text() 2159 else: 2160 jid = self.to 2161 if '/' in jid: 2162 jid, resource = jid.split('/', 1) 2163 else: 2164 resource = self.resource 2165 return jid, resource 2166 2167 def get_contact(self): 2168 jid, resource = self.get_jid_and_resource() 2169 if '@' in jid: 2170 return gajim.contacts.get_contact(self.account, jid, self.resource) 2171 else: 2172 return None 2173 2174 def get_jid_resource_and_contact(self): 2175 jid, resource = self.get_jid_and_resource() 2176 if '@' in jid: 2177 return jid, resource, gajim.contacts.get_contact(self.account, jid, self.resource) 2178 else: 2179 return jid, resource, None 2180 2181 def prepare_context_menu(self): 2182 '''sets compact view menuitem active state 2183 sets active and sensitivity state for toggle_gpg_menuitem 2184 sets sensitivity for history_menuitem (False for transports) 2185 and file_transfer_menuitem 2186 and hide()/show() for add_to_roster_menuitem 2187 ''' 2188 xml = gtkgui_helpers.get_glade('chat_control_popup_menu.glade') 2189 menu = xml.get_widget('chat_control_popup_menu') 2190 2191 history_menuitem = xml.get_widget('history_menuitem') 2192 toggle_gpg_menuitem = xml.get_widget('toggle_gpg_menuitem') 2193 toggle_e2e_menuitem = xml.get_widget('toggle_e2e_menuitem') 2194 add_to_roster_menuitem = xml.get_widget('add_to_roster_menuitem') 2195 send_file_menuitem = xml.get_widget('send_file_menuitem') 2196 information_menuitem = xml.get_widget('information_menuitem') 2197 convert_to_gc_menuitem = xml.get_widget('convert_to_groupchat') 2198 muc_icon = gajim.interface.roster.load_icon('muc_active') 2199 if muc_icon: 2200 convert_to_gc_menuitem.set_image(muc_icon) 2201 2202 jid, resource, contact = self.get_jid_resource_and_contact() 2203 2204 # check if gpg capabitlies or else make gpg toggle insensitive 2205 gpg_btn = self.gpg_togglebutton 2206 isactive = gpg_btn.get_active() 2207 is_sensitive = gpg_btn.get_property('sensitive') 2208 toggle_gpg_menuitem.set_active(isactive) 2209 toggle_gpg_menuitem.set_property('sensitive', is_sensitive) 2210 2211 # TODO: support this, if possible 2212 toggle_e2e_menuitem.set_sensitive(False) 2213 2214 # If we don't have resource, we can't do file transfer 2215 # in transports, contact holds our info we need to disable it too 2216 if jid and resource: 2217 send_file_menuitem.set_sensitive(True) 2218 elif contact and contact.resource and contact.jid.find('@') != -1: 2219 send_file_menuitem.set_sensitive(True) 2220 else: 2221 send_file_menuitem.set_sensitive(False) 2222 2223 # check if it's possible to convert to groupchat 2224 if gajim.get_transport_name_from_jid(jid) or \ 2225 gajim.connections[self.account].is_zeroconf: 2226 convert_to_gc_menuitem.set_sensitive(False) 2227 2228 # add_to_roster_menuitem 2229 if contact and _('Not in Roster') in contact.groups: 2230 add_to_roster_menuitem.show() 2231 add_to_roster_menuitem.set_no_show_all(False) 2232 else: 2233 add_to_roster_menuitem.hide() 2234 add_to_roster_menuitem.set_no_show_all(True) 2235 2236 # connect signals 2237 history_menuitem.connect('activate', 2238 self.on_history_menuitem_activate) 2239 send_file_menuitem.connect('activate', 2240 self.on_send_file_menuitem_activate) 2241 add_to_roster_menuitem.connect('activate', 2242 self.on_add_to_roster_menuitem_activate) 2243 toggle_gpg_menuitem.connect('activate', 2244 self.on_toggle_gpg_menuitem_activate) 2245 #toggle_e2e_menuitem.connect('activate', 2246 # self.on_toggle_e2e_menuitem_activate) 2247 information_menuitem.connect('activate', 2248 self.on_contact_information_menuitem_activate) 2249 convert_to_gc_menuitem.connect('activate', 2250 self.on_convert_to_gc_menuitem_activate) 2251 menu.connect('selection-done', self.destroy_menu) 2252 return menu 2253 2254 def destroy_menu(self, menu): 2255 # destroy menu 2256 menu.destroy() 2257 2258 def on_history_menuitem_activate(self, widget): 2259 '''When history menuitem is pressed: call history window''' 2260 import history_window 2261 jid, resource = self.get_jid_and_resource() 2262 2263 if gajim.interface.instances.has_key('logs'): 2264 gajim.interface.instances['logs'].window.present() 2265 gajim.interface.instances['logs'].open_history(jid, self.account) 2266 else: 2267 gajim.interface.instances['logs'] = \ 2268 history_window.HistoryWindow(jid, self.account) 2269 2270 def on_send_file_menuitem_activate(self, widget): 2271 contact = self.get_contact() 2272 if contact: 2273 gajim.interface.instances['file_transfers'].show_file_send_request( 2274 self.account, contact) 2275 2276 def on_add_to_roster_menuitem_activate(self, widget): 2277 jid, resource = self.get_jid_and_resource() 2278 AddNewContactWindow(self.account, jid) 2279 2280 def on_toggle_gpg_menuitem_activate(self, widget): 2281 if self.gpg_togglebutton.get_active(): 2282 self.gpg_togglebutton.set_active(False) 2283 else: 2284 self.gpg_togglebutton.set_active(True) 2285 self.gpg_togglebutton.toggled() 2286 2287 def on_gpg_togglebutton_toggled(self, widget): 2288 self.encrypted = self.gpg_togglebutton.get_active() 2289 contact = self.get_contact() 2290 if contact: # only save if we have a valid contact 2291 gajim.config.set_per('contacts', contact.jid, 'gpg_enabled', 2292 self.encrypted) 2293 2294 def on_contact_information_menuitem_activate(self, widget): 2295 contact = self.get_contact() 2296 if contact: 2297 gajim.interface.roster.on_info(widget, contact, self.account) 2298 2299 def on_convert_to_gc_menuitem_activate(self, widget): 2300 '''user want to invite some friends to chat''' 2301 jid, resource = self.get_jid_and_resource() 2302 TransformChatToMUC(self.account, [jid]) 2303 2304 def on_single_message_window_destroy(self, widget): 2305 gajim.events.event_added_unsubscribe(self.on_event_added) 2306 gajim.events.event_removed_unsubscribe(self.on_event_removed) 2307 2308 def update_next_count(self): 2309 # gajim.get_jid_without_resource(self.from_jid)? 2310 self.next_count = len(gajim.events.get_events(self.account, \ 2311 self.from_whom, types=('normal',))) 2312 self.next_count_label.set_label("(%d)" % self.next_count) 2313 if self.next_count == 0: 2314 self.next_button.set_property('sensitive', False) 2315 else: 2316 self.next_button.set_property('sensitive', True) 2317 2318 def on_event_added(self, event): 2319 if event.type_ == 'normal': 2320 self.update_next_count() 2321 2322 def on_event_removed(self, event_list): 2323 for event in event_list: 2324 if event.type_ == 'normal': 2325 self.update_next_count() 2326 return 2327 2328 def on_next_button_clicked(self, widget): 2329 if self.next_count == 0: 2330 return 2331 next_event = gajim.events.get_first_event(self.account, self.from_whom, 'normal') 2332 #if not next_event: 2333 # next_event = gajim.events.get_first_event(self.account, self.from_whom, 'chat') 2334 if not next_event: 2335 return 2336 # parameters: 2337 # message, subject, kind, time, encrypted, resource, 2338 # msg_id 2339 self.action = 'receive' 2340 self.subject = next_event.parameters[1] 2341 self.message = next_event.parameters[0] 2342 self.resource = next_event.parameters[5] 2343 self.session = next_event.parameters[8] 2344 form_node = next_event.parameters[9] 2345 2346 parent_box = self.xml.get_widget('conversation_scrolledwindow').get_parent() 2347 if form_node: 2348 dataform = dataforms.ExtendForm(node = form_node) 2349 self.form_widget = dataforms_widget.DataFormWidget(dataform) 2350 self.form_widget.show_all() 2351 parent_box.add(self.form_widget) 2352 parent_box.child_set_property(self.form_widget, 'position', 2353 parent_box.child_get_property(self.xml.get_widget('conversation_scrolledwindow'), 'position')) 2354 self.action = 'form' 2355 elif self.form_widget: 2356 self.form_widget.hide() 2357 parent_box.remove(self.form_widget) 2358 self.form_widget = None 2359 2360 self.conversation_textview.clear() 2361 self.prepare_widgets_for(self.action) 2362 2363 # set_text(None) raises TypeError exception 2364 if self.subject is None: 2365 self.subject = '' 2366 self.subject_entry.set_text(self.subject) 2367 2368 gajim.interface.remove_first_event(self.account, self.from_whom, next_event.type_) 2369 self.update_next_count() 2370 2025 2371 def on_cancel_button_clicked(self, widget): 2026 2372 self.save_pos() 2027 2373 self.window.destroy() … … 2066 2412 form_node = self.form_widget.data_form 2067 2413 else: 2068 2414 form_node = None 2069 # FIXME: allow GPG message some day 2415 keyID = None 2416 if self.encrypted: 2417 contact = self.get_contact() 2418 keyID = contact.keyID 2070 2419 gajim.connections[self.account].send_message(to_whom_jid, message, 2071 keyID= None, type='normal', subject=subject, session=session,2420 keyID=keyID, type='normal', subject=subject, session=session, 2072 2421 form_node=form_node) 2073 2422 2074 2423 self.subject_entry.set_text('') # we sent ok, clear the subject … … 2076 2425 2077 2426 &nbs
