Rework JoinGroupchat Dialog
This commit is contained in:
		
							parent
							
								
									15bcd80e19
								
							
						
					
					
						commit
						4fa4484dfd
					
				
					 4 changed files with 508 additions and 369 deletions
				
			
		|  | @ -389,6 +389,19 @@ def get_connected_accounts(): | ||||||
|             account_list.append(account) |             account_list.append(account) | ||||||
|     return account_list |     return account_list | ||||||
| 
 | 
 | ||||||
|  | def get_enabled_accounts_with_labels(exclude_local=True): | ||||||
|  |     """ | ||||||
|  |     Returns a list with [account, account_label] entries. | ||||||
|  |     Order by account_label | ||||||
|  |     """ | ||||||
|  |     accounts = [] | ||||||
|  |     for acc in connections: | ||||||
|  |         if not exclude_local or acc != 'Local': | ||||||
|  |             acc_label = config.get_per('accounts', acc, 'account_label') | ||||||
|  |             accounts.append([acc, acc_label]) | ||||||
|  |     accounts.sort(key=lambda xs: str.lower(xs[1])) | ||||||
|  |     return accounts | ||||||
|  | 
 | ||||||
| def account_is_connected(account): | def account_is_connected(account): | ||||||
|     if account not in connections: |     if account not in connections: | ||||||
|         return False |         return False | ||||||
|  |  | ||||||
|  | @ -1,102 +1,189 @@ | ||||||
| <?xml version="1.0" encoding="UTF-8"?> | <?xml version="1.0" encoding="UTF-8"?> | ||||||
| <!-- Generated with glade 3.20.1 --> | <!-- Generated with glade 3.22.0 --> | ||||||
| <interface> | <interface> | ||||||
|   <requires lib="gtk+" version="3.20"/> |   <requires lib="gtk+" version="3.20"/> | ||||||
|   <object class="GtkGrid" id="grid"> |   <object class="GtkListStore" id="account_liststore"> | ||||||
|  |     <columns> | ||||||
|  |       <!-- column-name id --> | ||||||
|  |       <column type="gchararray"/> | ||||||
|  |       <!-- column-name label --> | ||||||
|  |       <column type="gchararray"/> | ||||||
|  |     </columns> | ||||||
|  |   </object> | ||||||
|  |   <object class="GtkListStore" id="recently_liststorex"> | ||||||
|  |     <columns> | ||||||
|  |       <!-- column-name server --> | ||||||
|  |       <column type="gchararray"/> | ||||||
|  |       <!-- column-name room --> | ||||||
|  |       <column type="gchararray"/> | ||||||
|  |       <!-- column-name nickname --> | ||||||
|  |       <column type="gchararray"/> | ||||||
|  |       <!-- column-name label --> | ||||||
|  |       <column type="gchararray"/> | ||||||
|  |     </columns> | ||||||
|  |   </object> | ||||||
|  |   <object class="GtkPopoverMenu" id="recently_popover"> | ||||||
|  |     <property name="can_focus">False</property> | ||||||
|  |     <child> | ||||||
|  |       <object class="GtkScrolledWindow"> | ||||||
|  |         <property name="visible">True</property> | ||||||
|  |         <property name="can_focus">True</property> | ||||||
|  |         <property name="margin_left">6</property> | ||||||
|  |         <property name="margin_right">6</property> | ||||||
|  |         <property name="margin_top">6</property> | ||||||
|  |         <property name="margin_bottom">6</property> | ||||||
|  |         <property name="max_content_width">300</property> | ||||||
|  |         <property name="max_content_height">300</property> | ||||||
|  |         <property name="propagate_natural_width">True</property> | ||||||
|  |         <property name="propagate_natural_height">True</property> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkTreeView" id="recently_treeview"> | ||||||
|  |             <property name="name">recently_treeview</property> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">False</property> | ||||||
|  |             <property name="model">recently_liststorex</property> | ||||||
|  |             <property name="headers_visible">False</property> | ||||||
|  |             <property name="enable_search">False</property> | ||||||
|  |             <property name="hover_selection">True</property> | ||||||
|  |             <property name="show_expanders">False</property> | ||||||
|  |             <property name="activate_on_single_click">True</property> | ||||||
|  |             <signal name="row-activated" handler="_on_recent_selected" swapped="no"/> | ||||||
|  |             <child internal-child="selection"> | ||||||
|  |               <object class="GtkTreeSelection"/> | ||||||
|  |             </child> | ||||||
|  |             <child> | ||||||
|  |               <object class="GtkTreeViewColumn"> | ||||||
|  |                 <property name="title" translatable="yes">column</property> | ||||||
|  |                 <child> | ||||||
|  |                   <object class="GtkCellRendererText"/> | ||||||
|  |                   <attributes> | ||||||
|  |                     <attribute name="text">3</attribute> | ||||||
|  |                   </attributes> | ||||||
|  |                 </child> | ||||||
|  |               </object> | ||||||
|  |             </child> | ||||||
|  |             <style> | ||||||
|  |               <class name="popover_treeview"/> | ||||||
|  |             </style> | ||||||
|  |           </object> | ||||||
|  |         </child> | ||||||
|  |       </object> | ||||||
|  |       <packing> | ||||||
|  |         <property name="submenu">main</property> | ||||||
|  |         <property name="position">1</property> | ||||||
|  |       </packing> | ||||||
|  |     </child> | ||||||
|  |   </object> | ||||||
|  |   <object class="GtkBox" id="main_box"> | ||||||
|  |     <property name="width_request">400</property> | ||||||
|     <property name="visible">True</property> |     <property name="visible">True</property> | ||||||
|     <property name="can_focus">False</property> |     <property name="can_focus">False</property> | ||||||
|     <property name="margin_left">18</property> |     <property name="margin_left">18</property> | ||||||
|     <property name="margin_right">18</property> |     <property name="margin_right">18</property> | ||||||
|     <property name="margin_top">18</property> |     <property name="margin_top">18</property> | ||||||
|     <property name="margin_bottom">18</property> |     <property name="margin_bottom">18</property> | ||||||
|  |     <property name="orientation">vertical</property> | ||||||
|  |     <property name="spacing">18</property> | ||||||
|  |     <child> | ||||||
|  |       <object class="GtkGrid" id="grid"> | ||||||
|  |         <property name="visible">True</property> | ||||||
|  |         <property name="can_focus">False</property> | ||||||
|         <property name="row_spacing">6</property> |         <property name="row_spacing">6</property> | ||||||
|         <property name="column_spacing">12</property> |         <property name="column_spacing">12</property> | ||||||
|         <child> |         <child> | ||||||
|       <object class="GtkLabel" id="jid_label"> |           <object class="GtkSwitch" id="autojoin_switch"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">True</property> | ||||||
|  |             <property name="tooltip_text" translatable="yes">Join group chat every time Gajim is started</property> | ||||||
|  |             <property name="halign">start</property> | ||||||
|  |             <property name="valign">center</property> | ||||||
|  |             <property name="active">True</property> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">1</property> | ||||||
|  |             <property name="top_attach">9</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkLabel"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|             <property name="can_focus">False</property> |             <property name="can_focus">False</property> | ||||||
|         <property name="no_show_all">True</property> |             <property name="halign">end</property> | ||||||
|         <property name="halign">center</property> |             <property name="valign">center</property> | ||||||
|         <property name="margin_bottom">12</property> |             <property name="label" translatable="yes">Autojoin</property> | ||||||
|  |             <property name="justify">right</property> | ||||||
|             <style> |             <style> | ||||||
|           <class name="bold16"/> |               <class name="dim-label"/> | ||||||
|  |             </style> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">0</property> | ||||||
|  |             <property name="top_attach">9</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkLabel" id="account_label"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">False</property> | ||||||
|  |             <property name="halign">end</property> | ||||||
|  |             <property name="label" translatable="yes">Account</property> | ||||||
|  |             <property name="justify">right</property> | ||||||
|  |             <style> | ||||||
|  |               <class name="dim-label"/> | ||||||
|             </style> |             </style> | ||||||
|           </object> |           </object> | ||||||
|           <packing> |           <packing> | ||||||
|             <property name="left_attach">0</property> |             <property name="left_attach">0</property> | ||||||
|             <property name="top_attach">0</property> |             <property name="top_attach">0</property> | ||||||
|         <property name="width">3</property> |  | ||||||
|           </packing> |           </packing> | ||||||
|         </child> |         </child> | ||||||
|         <child> |         <child> | ||||||
|       <object class="GtkSwitch" id="bookmark_switch"> |           <object class="GtkLabel" id="room_label"> | ||||||
|         <property name="visible">True</property> |  | ||||||
|         <property name="can_focus">True</property> |  | ||||||
|         <property name="tooltip_text" translatable="yes">Bookmark this Groupchat</property> |  | ||||||
|         <property name="halign">start</property> |  | ||||||
|         <property name="valign">center</property> |  | ||||||
|         <property name="margin_top">6</property> |  | ||||||
|         <property name="active">True</property> |  | ||||||
|         <signal name="notify::active" handler="_on_bookmark_activate" swapped="no"/> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">1</property> |  | ||||||
|         <property name="top_attach">7</property> |  | ||||||
|         <property name="width">2</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkSwitch" id="autojoin_switch"> |  | ||||||
|         <property name="visible">True</property> |  | ||||||
|         <property name="can_focus">True</property> |  | ||||||
|         <property name="tooltip_text" translatable="yes">Join this Groupchat every time Gajim is started</property> |  | ||||||
|         <property name="halign">start</property> |  | ||||||
|         <property name="valign">center</property> |  | ||||||
|         <property name="active">True</property> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">1</property> |  | ||||||
|         <property name="top_attach">8</property> |  | ||||||
|         <property name="width">2</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkLabel"> |  | ||||||
|             <property name="visible">True</property> |             <property name="visible">True</property> | ||||||
|             <property name="can_focus">False</property> |             <property name="can_focus">False</property> | ||||||
|         <property name="halign">start</property> |             <property name="halign">end</property> | ||||||
|         <property name="valign">center</property> |             <property name="label" translatable="yes">Room</property> | ||||||
|         <property name="margin_top">6</property> |             <property name="justify">right</property> | ||||||
|         <property name="label" translatable="yes">Bookmark</property> |             <style> | ||||||
|  |               <class name="dim-label"/> | ||||||
|  |             </style> | ||||||
|           </object> |           </object> | ||||||
|           <packing> |           <packing> | ||||||
|             <property name="left_attach">0</property> |             <property name="left_attach">0</property> | ||||||
|         <property name="top_attach">7</property> |             <property name="top_attach">3</property> | ||||||
|           </packing> |           </packing> | ||||||
|         </child> |         </child> | ||||||
|         <child> |         <child> | ||||||
|       <object class="GtkLabel"> |           <object class="GtkLabel" id="server_label"> | ||||||
|             <property name="visible">True</property> |             <property name="visible">True</property> | ||||||
|             <property name="can_focus">False</property> |             <property name="can_focus">False</property> | ||||||
|         <property name="halign">start</property> |             <property name="halign">end</property> | ||||||
|         <property name="valign">center</property> |             <property name="label" translatable="yes">Server</property> | ||||||
|         <property name="label" translatable="yes">Autojoin</property> |             <property name="justify">right</property> | ||||||
|  |             <style> | ||||||
|  |               <class name="dim-label"/> | ||||||
|  |             </style> | ||||||
|           </object> |           </object> | ||||||
|           <packing> |           <packing> | ||||||
|             <property name="left_attach">0</property> |             <property name="left_attach">0</property> | ||||||
|         <property name="top_attach">8</property> |             <property name="top_attach">2</property> | ||||||
|           </packing> |           </packing> | ||||||
|         </child> |         </child> | ||||||
|         <child> |         <child> | ||||||
|       <object class="GtkComboBoxText" id="account_combo"> |           <object class="GtkLabel" id="password_label"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|             <property name="can_focus">False</property> |             <property name="can_focus">False</property> | ||||||
|             <property name="no_show_all">True</property> |             <property name="no_show_all">True</property> | ||||||
|         <property name="valign">center</property> |             <property name="halign">end</property> | ||||||
|         <signal name="changed" handler="_on_account_combo_changed" swapped="no"/> |             <property name="label" translatable="yes">Password</property> | ||||||
|  |             <property name="justify">right</property> | ||||||
|  |             <style> | ||||||
|  |               <class name="dim-label"/> | ||||||
|  |             </style> | ||||||
|           </object> |           </object> | ||||||
|           <packing> |           <packing> | ||||||
|         <property name="left_attach">1</property> |             <property name="left_attach">0</property> | ||||||
|         <property name="top_attach">1</property> |             <property name="top_attach">4</property> | ||||||
|         <property name="width">2</property> |  | ||||||
|           </packing> |           </packing> | ||||||
|         </child> |         </child> | ||||||
|         <child> |         <child> | ||||||
|  | @ -104,19 +191,100 @@ | ||||||
|             <property name="visible">True</property> |             <property name="visible">True</property> | ||||||
|             <property name="can_focus">True</property> |             <property name="can_focus">True</property> | ||||||
|             <property name="valign">center</property> |             <property name="valign">center</property> | ||||||
|  |             <property name="activates_default">True</property> | ||||||
|           </object> |           </object> | ||||||
|           <packing> |           <packing> | ||||||
|             <property name="left_attach">1</property> |             <property name="left_attach">1</property> | ||||||
|         <property name="top_attach">3</property> |             <property name="top_attach">6</property> | ||||||
|         <property name="width">2</property> |  | ||||||
|           </packing> |           </packing> | ||||||
|         </child> |         </child> | ||||||
|         <child> |         <child> | ||||||
|       <object class="GtkLabel" id="account_label"> |           <object class="GtkLabel"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|             <property name="can_focus">False</property> |             <property name="can_focus">False</property> | ||||||
|         <property name="no_show_all">True</property> |             <property name="halign">end</property> | ||||||
|  |             <property name="label" translatable="yes">Nickname</property> | ||||||
|  |             <property name="justify">right</property> | ||||||
|  |             <style> | ||||||
|  |               <class name="dim-label"/> | ||||||
|  |             </style> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">0</property> | ||||||
|  |             <property name="top_attach">6</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkBox"> | ||||||
|  |             <property name="height_request">6</property> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">False</property> | ||||||
|  |             <property name="orientation">vertical</property> | ||||||
|  |             <child> | ||||||
|  |               <placeholder/> | ||||||
|  |             </child> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">0</property> | ||||||
|  |             <property name="top_attach">5</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkBox"> | ||||||
|  |             <property name="height_request">6</property> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">False</property> | ||||||
|  |             <property name="orientation">vertical</property> | ||||||
|  |             <child> | ||||||
|  |               <placeholder/> | ||||||
|  |             </child> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">0</property> | ||||||
|  |             <property name="top_attach">7</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkSwitch" id="bookmark_switch"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">True</property> | ||||||
|  |             <property name="tooltip_text" translatable="yes">Bookmark group chat</property> | ||||||
|             <property name="halign">start</property> |             <property name="halign">start</property> | ||||||
|         <property name="label" translatable="yes">Account</property> |             <property name="valign">center</property> | ||||||
|  |             <property name="active">True</property> | ||||||
|  |             <signal name="notify::active" handler="_on_bookmark_activate" swapped="no"/> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">1</property> | ||||||
|  |             <property name="top_attach">8</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkLabel"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">False</property> | ||||||
|  |             <property name="halign">end</property> | ||||||
|  |             <property name="valign">center</property> | ||||||
|  |             <property name="label" translatable="yes">Bookmark</property> | ||||||
|  |             <property name="justify">right</property> | ||||||
|  |             <style> | ||||||
|  |               <class name="dim-label"/> | ||||||
|  |             </style> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">0</property> | ||||||
|  |             <property name="top_attach">8</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkBox"> | ||||||
|  |             <property name="height_request">6</property> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">False</property> | ||||||
|  |             <property name="orientation">vertical</property> | ||||||
|  |             <child> | ||||||
|  |               <placeholder/> | ||||||
|  |             </child> | ||||||
|           </object> |           </object> | ||||||
|           <packing> |           <packing> | ||||||
|             <property name="left_attach">0</property> |             <property name="left_attach">0</property> | ||||||
|  | @ -124,47 +292,142 @@ | ||||||
|           </packing> |           </packing> | ||||||
|         </child> |         </child> | ||||||
|         <child> |         <child> | ||||||
|       <object class="GtkLabel"> |           <object class="GtkComboBox" id="account_combo"> | ||||||
|             <property name="visible">True</property> |             <property name="visible">True</property> | ||||||
|             <property name="can_focus">False</property> |             <property name="can_focus">False</property> | ||||||
|         <property name="halign">start</property> |             <property name="model">account_liststore</property> | ||||||
|         <property name="label" translatable="yes">Nickname</property> |             <property name="id_column">0</property> | ||||||
|       </object> |             <signal name="changed" handler="_on_account_combo_changed" swapped="no"/> | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">0</property> |  | ||||||
|         <property name="top_attach">3</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|             <child> |             <child> | ||||||
|       <object class="GtkLabel" id="password_label"> |               <object class="GtkCellRendererText"/> | ||||||
|         <property name="can_focus">False</property> |               <attributes> | ||||||
|         <property name="no_show_all">True</property> |                 <attribute name="text">1</attribute> | ||||||
|         <property name="halign">start</property> |               </attributes> | ||||||
|         <property name="label" translatable="yes">Password</property> |             </child> | ||||||
|           </object> |           </object> | ||||||
|           <packing> |           <packing> | ||||||
|         <property name="left_attach">0</property> |             <property name="left_attach">1</property> | ||||||
|         <property name="top_attach">6</property> |             <property name="top_attach">0</property> | ||||||
|           </packing> |           </packing> | ||||||
|         </child> |         </child> | ||||||
|         <child> |         <child> | ||||||
|           <object class="GtkEntry" id="password_entry"> |           <object class="GtkEntry" id="password_entry"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|             <property name="can_focus">True</property> |             <property name="can_focus">True</property> | ||||||
|             <property name="no_show_all">True</property> |             <property name="no_show_all">True</property> | ||||||
|  |             <property name="activates_default">True</property> | ||||||
|             <property name="input_purpose">password</property> |             <property name="input_purpose">password</property> | ||||||
|           </object> |           </object> | ||||||
|           <packing> |           <packing> | ||||||
|             <property name="left_attach">1</property> |             <property name="left_attach">1</property> | ||||||
|         <property name="top_attach">6</property> |             <property name="top_attach">4</property> | ||||||
|         <property name="width">2</property> |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkBox"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">False</property> | ||||||
|  |             <property name="spacing">12</property> | ||||||
|  |             <child> | ||||||
|  |               <object class="GtkEntry" id="room_entry"> | ||||||
|  |                 <property name="visible">True</property> | ||||||
|  |                 <property name="can_focus">True</property> | ||||||
|  |                 <property name="hexpand">True</property> | ||||||
|  |                 <property name="activates_default">True</property> | ||||||
|  |               </object> | ||||||
|  |               <packing> | ||||||
|  |                 <property name="expand">False</property> | ||||||
|  |                 <property name="fill">True</property> | ||||||
|  |                 <property name="position">0</property> | ||||||
|  |               </packing> | ||||||
|  |             </child> | ||||||
|  |             <child> | ||||||
|  |               <object class="GtkMenuButton" id="recently_button"> | ||||||
|  |                 <property name="can_focus">True</property> | ||||||
|  |                 <property name="receives_default">True</property> | ||||||
|  |                 <property name="no_show_all">True</property> | ||||||
|  |                 <property name="tooltip_text" translatable="yes">Recently used channels</property> | ||||||
|  |                 <property name="popover">recently_popover</property> | ||||||
|  |                 <child> | ||||||
|  |                   <object class="GtkImage"> | ||||||
|  |                     <property name="visible">True</property> | ||||||
|  |                     <property name="can_focus">False</property> | ||||||
|  |                     <property name="icon_name">document-open-recent-symbolic</property> | ||||||
|  |                   </object> | ||||||
|  |                 </child> | ||||||
|  |               </object> | ||||||
|  |               <packing> | ||||||
|  |                 <property name="expand">False</property> | ||||||
|  |                 <property name="fill">True</property> | ||||||
|  |                 <property name="position">1</property> | ||||||
|  |               </packing> | ||||||
|  |             </child> | ||||||
|  |             <child> | ||||||
|  |               <object class="GtkButton" id="search_button"> | ||||||
|  |                 <property name="can_focus">True</property> | ||||||
|  |                 <property name="receives_default">True</property> | ||||||
|  |                 <property name="no_show_all">True</property> | ||||||
|  |                 <property name="tooltip_text" translatable="yes">Search the rooms on this server</property> | ||||||
|  |                 <signal name="clicked" handler="_on_search_clicked" swapped="no"/> | ||||||
|  |                 <child> | ||||||
|  |                   <object class="GtkImage"> | ||||||
|  |                     <property name="visible">True</property> | ||||||
|  |                     <property name="can_focus">False</property> | ||||||
|  |                     <property name="icon_name">system-search-symbolic</property> | ||||||
|  |                   </object> | ||||||
|  |                 </child> | ||||||
|  |               </object> | ||||||
|  |               <packing> | ||||||
|  |                 <property name="expand">False</property> | ||||||
|  |                 <property name="fill">True</property> | ||||||
|  |                 <property name="position">2</property> | ||||||
|  |               </packing> | ||||||
|  |             </child> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">1</property> | ||||||
|  |             <property name="top_attach">3</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <object class="GtkComboBoxText" id="server_combo"> | ||||||
|  |             <property name="visible">True</property> | ||||||
|  |             <property name="can_focus">False</property> | ||||||
|  |             <property name="hexpand">True</property> | ||||||
|  |             <property name="has_entry">True</property> | ||||||
|  |             <child internal-child="entry"> | ||||||
|  |               <object class="GtkEntry"> | ||||||
|  |                 <property name="can_focus">True</property> | ||||||
|  |                 <property name="caps_lock_warning">False</property> | ||||||
|  |               </object> | ||||||
|  |             </child> | ||||||
|  |           </object> | ||||||
|  |           <packing> | ||||||
|  |             <property name="left_attach">1</property> | ||||||
|  |             <property name="top_attach">2</property> | ||||||
|  |           </packing> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <placeholder/> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <placeholder/> | ||||||
|  |         </child> | ||||||
|  |         <child> | ||||||
|  |           <placeholder/> | ||||||
|  |         </child> | ||||||
|  |       </object> | ||||||
|  |       <packing> | ||||||
|  |         <property name="expand">False</property> | ||||||
|  |         <property name="fill">True</property> | ||||||
|  |         <property name="position">0</property> | ||||||
|       </packing> |       </packing> | ||||||
|     </child> |     </child> | ||||||
|     <child> |     <child> | ||||||
|       <object class="GtkButtonBox" id="button_box"> |       <object class="GtkButtonBox" id="button_box"> | ||||||
|  |         <property name="visible">True</property> | ||||||
|         <property name="can_focus">False</property> |         <property name="can_focus">False</property> | ||||||
|         <property name="no_show_all">True</property> |         <property name="spacing">12</property> | ||||||
|         <property name="margin_top">18</property> |  | ||||||
|         <property name="spacing">6</property> |  | ||||||
|         <property name="layout_style">end</property> |         <property name="layout_style">end</property> | ||||||
|         <child> |         <child> | ||||||
|           <object class="GtkButton"> |           <object class="GtkButton"> | ||||||
|  | @ -201,140 +464,9 @@ | ||||||
|         </child> |         </child> | ||||||
|       </object> |       </object> | ||||||
|       <packing> |       <packing> | ||||||
|         <property name="left_attach">1</property> |         <property name="expand">False</property> | ||||||
|         <property name="top_attach">9</property> |         <property name="fill">True</property> | ||||||
|         <property name="width">2</property> |         <property name="position">2</property> | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkLabel" id="server_label"> |  | ||||||
|         <property name="can_focus">False</property> |  | ||||||
|         <property name="no_show_all">True</property> |  | ||||||
|         <property name="halign">start</property> |  | ||||||
|         <property name="label" translatable="yes">Server</property> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">0</property> |  | ||||||
|         <property name="top_attach">5</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkLabel" id="room_label"> |  | ||||||
|         <property name="can_focus">False</property> |  | ||||||
|         <property name="no_show_all">True</property> |  | ||||||
|         <property name="halign">start</property> |  | ||||||
|         <property name="label" translatable="yes">Room</property> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">0</property> |  | ||||||
|         <property name="top_attach">4</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkLabel" id="recent_label"> |  | ||||||
|         <property name="can_focus">False</property> |  | ||||||
|         <property name="no_show_all">True</property> |  | ||||||
|         <property name="halign">start</property> |  | ||||||
|         <property name="label" translatable="yes">Recently</property> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">0</property> |  | ||||||
|         <property name="top_attach">2</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkEntry" id="room_entry"> |  | ||||||
|         <property name="can_focus">True</property> |  | ||||||
|         <property name="no_show_all">True</property> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">1</property> |  | ||||||
|         <property name="top_attach">4</property> |  | ||||||
|         <property name="width">2</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkComboBoxText" id="recent_combo"> |  | ||||||
|         <property name="can_focus">False</property> |  | ||||||
|         <property name="no_show_all">True</property> |  | ||||||
|         <signal name="changed" handler="_on_recent_changed" swapped="no"/> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">1</property> |  | ||||||
|         <property name="top_attach">2</property> |  | ||||||
|         <property name="width">2</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkComboBoxText" id="server_combo"> |  | ||||||
|         <property name="can_focus">False</property> |  | ||||||
|         <property name="no_show_all">True</property> |  | ||||||
|         <property name="has_entry">True</property> |  | ||||||
|         <child internal-child="entry"> |  | ||||||
|           <object class="GtkEntry"> |  | ||||||
|             <property name="can_focus">True</property> |  | ||||||
|             <property name="caps_lock_warning">False</property> |  | ||||||
|           </object> |  | ||||||
|         </child> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">1</property> |  | ||||||
|         <property name="top_attach">5</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkButton" id="search_button"> |  | ||||||
|         <property name="can_focus">True</property> |  | ||||||
|         <property name="receives_default">True</property> |  | ||||||
|         <property name="no_show_all">True</property> |  | ||||||
|         <property name="tooltip_text" translatable="yes">Search the rooms on this server</property> |  | ||||||
|         <signal name="clicked" handler="_on_search_clicked" swapped="no"/> |  | ||||||
|         <child> |  | ||||||
|           <object class="GtkImage"> |  | ||||||
|             <property name="visible">True</property> |  | ||||||
|             <property name="can_focus">False</property> |  | ||||||
|             <property name="icon_name">system-search-symbolic</property> |  | ||||||
|           </object> |  | ||||||
|         </child> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="left_attach">2</property> |  | ||||||
|         <property name="top_attach">5</property> |  | ||||||
|       </packing> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <placeholder/> |  | ||||||
|     </child> |  | ||||||
|   </object> |  | ||||||
|   <object class="GtkHeaderBar" id="headerbar"> |  | ||||||
|     <property name="visible">True</property> |  | ||||||
|     <property name="can_focus">False</property> |  | ||||||
|     <property name="title" translatable="yes">Join Groupchat</property> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkButton"> |  | ||||||
|         <property name="label">gtk-cancel</property> |  | ||||||
|         <property name="visible">True</property> |  | ||||||
|         <property name="can_focus">True</property> |  | ||||||
|         <property name="receives_default">True</property> |  | ||||||
|         <property name="use_stock">True</property> |  | ||||||
|         <signal name="clicked" handler="_on_cancel_clicked" swapped="no"/> |  | ||||||
|       </object> |  | ||||||
|     </child> |  | ||||||
|     <child> |  | ||||||
|       <object class="GtkButton"> |  | ||||||
|         <property name="label" translatable="yes">_Join</property> |  | ||||||
|         <property name="visible">True</property> |  | ||||||
|         <property name="can_focus">True</property> |  | ||||||
|         <property name="use_underline">True</property> |  | ||||||
|         <property name="receives_default">True</property> |  | ||||||
|         <signal name="clicked" handler="_on_join_clicked" swapped="no"/> |  | ||||||
|         <style> |  | ||||||
|           <class name="suggested-action"/> |  | ||||||
|         </style> |  | ||||||
|       </object> |  | ||||||
|       <packing> |  | ||||||
|         <property name="pack_type">end</property> |  | ||||||
|         <property name="position">1</property> |  | ||||||
|       </packing> |       </packing> | ||||||
|     </child> |     </child> | ||||||
|   </object> |   </object> | ||||||
|  |  | ||||||
|  | @ -90,6 +90,11 @@ popover#EmoticonPopover flowboxchild { padding-top: 5px; padding-bottom: 5px; } | ||||||
| #StartChatListBox > row { padding: 10px 20px 10px 10px; } | #StartChatListBox > row { padding: 10px 20px 10px 10px; } | ||||||
| #StartChatListBox > row:not(.activatable) label { color: @insensitive_fg_color } | #StartChatListBox > row:not(.activatable) label { color: @insensitive_fg_color } | ||||||
| 
 | 
 | ||||||
|  | /* Popover Treeview */ | ||||||
|  | .popover_treeview { border-radius: 3px; background-color: @theme_bg_color; } | ||||||
|  | .popover_treeview { padding: 6px; } | ||||||
|  | .popover_treeview :hover { background-color: @theme_selected_bg_color; } | ||||||
|  | 
 | ||||||
| /* Text style */ | /* Text style */ | ||||||
| 
 | 
 | ||||||
| .bold16 { font-size: 16px; font-weight: bold; } | .bold16 { font-size: 16px; font-weight: bold; } | ||||||
|  |  | ||||||
							
								
								
									
										149
									
								
								gajim/dialogs.py
									
										
									
									
									
								
							
							
						
						
									
										149
									
								
								gajim/dialogs.py
									
										
									
									
									
								
							|  | @ -2300,7 +2300,7 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow): | ||||||
|         self.set_show_menubar(False) |         self.set_show_menubar(False) | ||||||
|         self.set_resizable(False) |         self.set_resizable(False) | ||||||
|         self.set_position(Gtk.WindowPosition.CENTER) |         self.set_position(Gtk.WindowPosition.CENTER) | ||||||
|         self.set_title(_('Join Groupchat')) |         self.set_title(_('Join Group Chat')) | ||||||
|         if transient_for: |         if transient_for: | ||||||
|             self.set_transient_for(transient_for) |             self.set_transient_for(transient_for) | ||||||
| 
 | 
 | ||||||
|  | @ -2309,93 +2309,86 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow): | ||||||
|         self.requested_jid = None |         self.requested_jid = None | ||||||
|         self.room_jid = room_jid |         self.room_jid = room_jid | ||||||
|         self.account = account |         self.account = account | ||||||
|         self.minimal_mode = 0 # 2: very mini, 1: with room, 0: show all | 
 | ||||||
|         if room_jid is not None: |         if self.room_jid is None: | ||||||
|             if '@' in room_jid: |             self.minimal_mode = False | ||||||
|                 self.minimal_mode = 2 |  | ||||||
|         else: |         else: | ||||||
|                 self.minimal_mode = 1 |             self.minimal_mode = True | ||||||
| 
 | 
 | ||||||
|         glade_objects = ['grid', 'nick_entry', 'account_combo', 'jid_label', |         glade_objects = ['main_box', 'account_label', 'account_combo', | ||||||
|                          'bookmark_switch', 'autojoin_switch', 'headerbar', |                          'server_label', 'server_combo', 'room_entry', | ||||||
|                          'account_label', 'password_entry', 'password_label', |                          'recently_button', 'recently_popover', | ||||||
|                          'join_button', 'button_box', 'server_label', |                          'recently_treeview', 'search_button', 'password_label', | ||||||
|                          'server_combo', 'recent_label', 'recent_combo', |                          'password_entry', 'nick_entry', 'bookmark_switch', | ||||||
|                          'room_label', 'room_entry', 'search_button'] |                          'autojoin_switch'] | ||||||
| 
 | 
 | ||||||
|         minimal_widgets = ['jid_label'] |  | ||||||
|         room_widgets = ['room_label', 'room_entry'] |  | ||||||
| 
 |  | ||||||
|         extended_widgets = ['server_label', 'server_combo', 'recent_label', |  | ||||||
|                             'recent_combo', 'room_label', 'room_entry', |  | ||||||
|                             'search_button'] |  | ||||||
|         self.builder = gtkgui_helpers.get_gtk_builder( |         self.builder = gtkgui_helpers.get_gtk_builder( | ||||||
|             'join_groupchat_window.ui') |             'join_groupchat_window.ui') | ||||||
|         for obj in glade_objects: |         for obj in glade_objects: | ||||||
|             setattr(self, obj, self.builder.get_object(obj)) |             setattr(self, obj, self.builder.get_object(obj)) | ||||||
| 
 | 
 | ||||||
|         self.add(self.grid) |         self.add(self.main_box) | ||||||
| 
 |  | ||||||
|         if os.environ.get('GTK_CSD', '1') == '1': |  | ||||||
|             self.set_titlebar(self.headerbar) |  | ||||||
|         else: |  | ||||||
|             self.button_box.show() |  | ||||||
| 
 | 
 | ||||||
|         # Show widgets depending on the mode the window is in |         # Show widgets depending on the mode the window is in | ||||||
|         if self.minimal_mode > 0: |         if not self.minimal_mode: | ||||||
|             for widget in minimal_widgets: |             self.recently_button.show() | ||||||
|                 getattr(self, widget).show() |             self.search_button.show() | ||||||
|             if self.minimal_mode == 1: |  | ||||||
|                 for widget in room_widgets: |  | ||||||
|                     getattr(self, widget).show() |  | ||||||
|             self.jid_label.set_text(room_jid) |  | ||||||
|         else: |  | ||||||
|             for widget in extended_widgets: |  | ||||||
|                 getattr(self, widget).show() |  | ||||||
| 
 | 
 | ||||||
|         if account is None: |         accounts = app.get_enabled_accounts_with_labels() | ||||||
|             connected_accounts = app.get_connected_accounts() |         account_liststore  = self.account_combo.get_model() | ||||||
|             account = connected_accounts[0] |         for acc in accounts: | ||||||
|             for acc in connected_accounts: |             account_liststore.append(acc) | ||||||
|                 self.account_combo.append_text(acc) | 
 | ||||||
|         else: |         if not accounts: | ||||||
|             connected_accounts = [account] |             return | ||||||
|             self.account_combo.append_text(account) | 
 | ||||||
|  |         if not self.account: | ||||||
|  |             self.account = accounts[0][0] | ||||||
| 
 | 
 | ||||||
|         self.builder.connect_signals(self) |         self.builder.connect_signals(self) | ||||||
|         self.connect('key-press-event', self._on_key_press_event) |         self.connect('key-press-event', self._on_key_press_event) | ||||||
|         self.connect('destroy', self._on_destroy) |         self.connect('destroy', self._on_destroy) | ||||||
| 
 | 
 | ||||||
|         if self.minimal_mode == 0: |         if not self.minimal_mode: | ||||||
|             app.ged.register_event_handler('agent-info-received', ged.GUI1, |             app.ged.register_event_handler('agent-info-received', ged.GUI1, | ||||||
|                                            self._nec_agent_info_received) |                                            self._nec_agent_info_received) | ||||||
|             app.ged.register_event_handler('agent-info-error-received', ged.GUI1, |             app.ged.register_event_handler('agent-info-error-received', ged.GUI1, | ||||||
|                                            self._nec_agent_info_error_received) |                                            self._nec_agent_info_error_received) | ||||||
| 
 | 
 | ||||||
|         # Show account combobox if there is more than one account |         # Show account combobox if there is more than one account | ||||||
|         if len(connected_accounts) > 1: |         if len(accounts) > 1: | ||||||
|             self.account_combo.show() |             self.account_combo.show() | ||||||
|             self.account_label.show() |             self.account_label.show() | ||||||
| 
 | 
 | ||||||
|         # Select first account |         self.account_combo.set_active_id(self.account) | ||||||
|         self.account_combo.set_active(0) | 
 | ||||||
|  |         if self.minimal_mode: | ||||||
|  |             if '@' in self.room_jid: | ||||||
|  |                 (room, server) = self.room_jid.split('@') | ||||||
|  |                 self.room_entry.set_text(room) | ||||||
|  |                 if not muc_caps_cache.supports( | ||||||
|  |                         self.room_jid, 'muc_passwordprotected'): | ||||||
|  |                     self.password_entry.hide() | ||||||
|  |                     self.password_label.hide() | ||||||
|  |                     self.nick_entry.grab_focus() | ||||||
|  |                 else: | ||||||
|  |                     self.password_entry.grab_focus() | ||||||
|  |             else: | ||||||
|  |                 server = self.room_jid | ||||||
|  |                 self.room_entry.grab_focus() | ||||||
|  | 
 | ||||||
|  |             self.server_combo.insert_text(0, server) | ||||||
|  |             self.server_combo.set_active(0) | ||||||
| 
 | 
 | ||||||
|         if self.password is not None: |         if self.password is not None: | ||||||
|             self.password_entry.set_text(self.password) |             self.password_entry.set_text(self.password) | ||||||
| 
 | 
 | ||||||
|         # Set bookmark switch sensitive if server supports bookmarks |         # Set bookmark switch sensitive if server supports bookmarks | ||||||
|         acc = self.account_combo.get_active_text() |         acc = self.account_combo.get_active_id() | ||||||
|         if not app.connections[acc].private_storage_supported: |         if not app.connections[acc].private_storage_supported: | ||||||
|             self.bookmark_switch.set_sensitive(False) |             self.bookmark_switch.set_sensitive(False) | ||||||
|             self.autojoin_switch.set_sensitive(False) |             self.autojoin_switch.set_sensitive(False) | ||||||
| 
 | 
 | ||||||
|         # Show password field if we are in extended mode or |  | ||||||
|         # The MUC is passwordprotected |  | ||||||
|         if self.minimal_mode == 0 or muc_caps_cache.supports( |  | ||||||
|                 room_jid, 'muc_passwordprotected'): |  | ||||||
|             self.password_entry.show() |  | ||||||
|             self.password_label.show() |  | ||||||
| 
 |  | ||||||
|         self.show_all() |         self.show_all() | ||||||
| 
 | 
 | ||||||
|     def set_room(self, room_jid): |     def set_room(self, room_jid): | ||||||
|  | @ -2404,16 +2397,18 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow): | ||||||
|         self.server_combo.get_child().set_text(server) |         self.server_combo.get_child().set_text(server) | ||||||
| 
 | 
 | ||||||
|     def _fill_recent_and_servers(self, account): |     def _fill_recent_and_servers(self, account): | ||||||
|         self.recent_combo.remove_all() |         recently_liststore = self.recently_treeview.get_model() | ||||||
|  |         recently_liststore.clear() | ||||||
|         self.server_combo.remove_all() |         self.server_combo.remove_all() | ||||||
|         recent = app.get_recent_groupchats(account) |         recent = app.get_recent_groupchats(account) | ||||||
|         servers = [] |         servers = [] | ||||||
|         for groupchat in recent: |         for groupchat in recent: | ||||||
|             text = '%s on %s@%s' % (groupchat.nickname, |             label = '%s@%s' % (groupchat.room, groupchat.server) | ||||||
|                                     groupchat.room, |  | ||||||
|                                     groupchat.server) |  | ||||||
| 
 | 
 | ||||||
|             self.recent_combo.append_text(text) |             recently_liststore.append([groupchat.server, | ||||||
|  |                                        groupchat.room, | ||||||
|  |                                        groupchat.nickname, | ||||||
|  |                                        label]) | ||||||
|             servers.append(groupchat.server) |             servers.append(groupchat.server) | ||||||
| 
 | 
 | ||||||
|         for server in set(servers): |         for server in set(servers): | ||||||
|  | @ -2424,24 +2419,18 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow): | ||||||
|         if muc_domain is not None: |         if muc_domain is not None: | ||||||
|             self.server_combo.insert_text(0, muc_domain) |             self.server_combo.insert_text(0, muc_domain) | ||||||
| 
 | 
 | ||||||
|     def _on_recent_changed(self, combo): |     def _on_recent_selected(self, treeview, *args): | ||||||
|         text = combo.get_active_text() |         (model, iter_) = treeview.get_selection().get_selected() | ||||||
|         if text is None: |         self.server_combo.get_child().set_text(model[iter_][0]) | ||||||
|             self.server_combo.set_active(0) |         self.room_entry.set_text(model[iter_][1]) | ||||||
|             return |         self.nick_entry.set_text(model[iter_][2]) | ||||||
|         nickname, _, room_jid = text.split() |         self.recently_popover.popdown() | ||||||
|         room, server = app.get_name_and_server_from_jid(room_jid) |  | ||||||
|         self.room_entry.set_text(room) |  | ||||||
|         self.nick_entry.set_text(nickname) |  | ||||||
|         self.server_combo.get_child().set_text(server) |  | ||||||
| 
 | 
 | ||||||
|     def _on_account_combo_changed(self, combo): |     def _on_account_combo_changed(self, combo): | ||||||
|         account = combo.get_active_text() |         account = combo.get_active_id() | ||||||
|         self.account = account |         self.account = account | ||||||
|         self.nick_entry.set_text(app.nicks[account]) |         self.nick_entry.set_text(app.nicks[account]) | ||||||
|         if self.minimal_mode == 0: |  | ||||||
|         self._fill_recent_and_servers(account) |         self._fill_recent_and_servers(account) | ||||||
|             self.recent_combo.set_active(0) |  | ||||||
| 
 | 
 | ||||||
|     def _on_key_press_event(self, widget, event): |     def _on_key_press_event(self, widget, event): | ||||||
|         if event.keyval == Gdk.KEY_Escape: |         if event.keyval == Gdk.KEY_Escape: | ||||||
|  | @ -2451,7 +2440,7 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow): | ||||||
|             return True |             return True | ||||||
| 
 | 
 | ||||||
|     def _on_join_clicked(self, *args): |     def _on_join_clicked(self, *args): | ||||||
|         account = self.account_combo.get_active_text() |         account = self.account_combo.get_active_id() | ||||||
|         nickname = self.nick_entry.get_text() |         nickname = self.nick_entry.get_text() | ||||||
| 
 | 
 | ||||||
|         invisible_show = app.SHOW_LIST.index('invisible') |         invisible_show = app.SHOW_LIST.index('invisible') | ||||||
|  | @ -2459,18 +2448,15 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow): | ||||||
|             app.interface.raise_dialog('join-while-invisible') |             app.interface.raise_dialog('join-while-invisible') | ||||||
|             return |             return | ||||||
| 
 | 
 | ||||||
|         if self.minimal_mode < 2: |  | ||||||
|             if self.minimal_mode == 0: |  | ||||||
|         server = self.server_combo.get_active_text() |         server = self.server_combo.get_active_text() | ||||||
|             else: # mode 1 |  | ||||||
|                 server = self.room_jid |  | ||||||
|         room = self.room_entry.get_text() |         room = self.room_entry.get_text() | ||||||
|  | 
 | ||||||
|         if room == '': |         if room == '': | ||||||
|             ErrorDialog(_('Invalid Room'), |             ErrorDialog(_('Invalid Room'), | ||||||
|                         _('Please choose a room'), transient_for=self) |                         _('Please choose a room'), transient_for=self) | ||||||
|             return |             return | ||||||
|             self.room_jid = '%s@%s' % (room, server) |  | ||||||
| 
 | 
 | ||||||
|  |         self.room_jid = '%s@%s' % (room, server) | ||||||
|         self.room_jid = self.room_jid.lower() |         self.room_jid = self.room_jid.lower() | ||||||
| 
 | 
 | ||||||
|         if app.in_groupchat(account, self.room_jid): |         if app.in_groupchat(account, self.room_jid): | ||||||
|  | @ -2518,7 +2504,10 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow): | ||||||
|         self.destroy() |         self.destroy() | ||||||
| 
 | 
 | ||||||
|     def _on_bookmark_activate(self, switch, param): |     def _on_bookmark_activate(self, switch, param): | ||||||
|         self.autojoin_switch.set_sensitive(switch.get_active()) |         bookmark_state = switch.get_active() | ||||||
|  |         self.autojoin_switch.set_sensitive(bookmark_state) | ||||||
|  |         if not bookmark_state: | ||||||
|  |             self.autojoin_switch.set_active(False) | ||||||
| 
 | 
 | ||||||
|     def _add_bookmark(self, account, nickname, password): |     def _add_bookmark(self, account, nickname, password): | ||||||
|         con = app.connections[account] |         con = app.connections[account] | ||||||
|  | @ -2537,7 +2526,7 @@ class JoinGroupchatWindow(Gtk.ApplicationWindow): | ||||||
|             name, self.room_jid, autojoin, 1, password, nickname) |             name, self.room_jid, autojoin, 1, password, nickname) | ||||||
| 
 | 
 | ||||||
|     def _on_destroy(self, *args): |     def _on_destroy(self, *args): | ||||||
|         if self.minimal_mode == 0: |         if not self.minimal_mode: | ||||||
|             app.ged.remove_event_handler('agent-info-received', ged.GUI1, |             app.ged.remove_event_handler('agent-info-received', ged.GUI1, | ||||||
|                                          self._nec_agent_info_received) |                                          self._nec_agent_info_received) | ||||||
|             app.ged.remove_event_handler('agent-info-error-received', ged.GUI1, |             app.ged.remove_event_handler('agent-info-error-received', ged.GUI1, | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue