comparison frontends/primitivus/custom_widgets.py @ 8:ec01505ec109

primitivus chat window - management of one 2 one / group chat - timestamp displayed - added shortcuts for showing/hiding panels - color used - fixed vcard bug (contact displayed even if not from current profile if vcard changed/not in cache) - added VerticalSeparator widget - *List widgets can now use an other widget than SelectableText - new UnselectableText widget
author Goffi <goffi@goffi.org>
date Thu, 08 Jul 2010 19:47:54 +0800
parents 94868f58850b
children 6650747dfdcb
comparison
equal deleted inserted replaced
7:94868f58850b 8:ec01505ec109
135 attr = 'selected' if self.__selected else 'default' 135 attr = 'selected' if self.__selected else 'default'
136 if focus: 136 if focus:
137 attr+="_focus" 137 attr+="_focus"
138 return urwid.Text((attr,self.text), align=self.align) 138 return urwid.Text((attr,self.text), align=self.align)
139 139
140 class UnselectableText(SelectableText):
141
142 def setState(self, selected, invisible=False):
143 pass
144
140 class GenericList(urwid.WidgetWrap): 145 class GenericList(urwid.WidgetWrap):
141 signals = ['click','change'] 146 signals = ['click','change']
142 147
143 def __init__(self, options, style=[], align='left', on_click=None, on_change=None, user_data=None): 148 def __init__(self, options, style=[], align='left', option_type = SelectableText, on_click=None, on_change=None, user_data=None):
144 """ 149 """
145 Widget managing list of string and their selection 150 Widget managing list of string and their selection
146 @param options: list of strings used for options 151 @param options: list of strings used for options
147 @param style: list of string: 152 @param style: list of string:
148 - 'single' if only one must be selected 153 - 'single' if only one must be selected
154 """ 159 """
155 self.single = 'single' in style 160 self.single = 'single' in style
156 self.no_first_select = 'no_first_select' in style 161 self.no_first_select = 'no_first_select' in style
157 self.can_select_none = 'can_select_none' in style 162 self.can_select_none = 'can_select_none' in style
158 self.align = align 163 self.align = align
164 self.option_type = option_type
159 self.first_display = True 165 self.first_display = True
160 166
161 if on_click: 167 if on_click:
162 urwid.connect_signal(self, 'click', on_click, user_data) 168 urwid.connect_signal(self, 'click', on_click, user_data)
163 169
220 """Change all value in one shot""" 226 """Change all value in one shot"""
221 if not self.first_display: 227 if not self.first_display:
222 old_selected = self.getSelectedValues() 228 old_selected = self.getSelectedValues()
223 widgets = [] 229 widgets = []
224 for option in new_values: 230 for option in new_values:
225 widget = SelectableText(option, self.align) 231 widget = self.option_type(option, self.align)
226 if not self.first_display and option in old_selected: 232 if not self.first_display and option in old_selected:
227 widget.setState(True) 233 widget.setState(True)
228 widgets.append(widget) 234 widgets.append(widget)
229 urwid.connect_signal(widget, 'change', self.__onStateChange) 235 try:
236 urwid.connect_signal(widget, 'change', self.__onStateChange)
237 except NameError:
238 pass #the widget given doesn't support 'change' signal
230 self.content[:] = widgets 239 self.content[:] = widgets
231 if self.first_display and self.single and new_values and not self.no_first_select: 240 if self.first_display and self.single and new_values and not self.no_first_select:
232 self.content[0].setState(True) 241 self.content[0].setState(True)
233 display_widget = self.getDisplayWidget() 242 display_widget = self.getDisplayWidget()
234 self._set_w(display_widget) 243 self._set_w(display_widget)
247 256
248 class List(urwid.FlowWidget): 257 class List(urwid.FlowWidget):
249 """FlowWidget list, same arguments as GenericList, with an additional one 'max_height'""" 258 """FlowWidget list, same arguments as GenericList, with an additional one 'max_height'"""
250 signals = ['click','change'] 259 signals = ['click','change']
251 260
252 def __init__(self, options, style=[], max_height=5, align='left', on_click=None, on_change=None, user_data=None): 261 def __init__(self, options, style=[], max_height=5, align='left', option_type = SelectableText, on_click=None, on_change=None, user_data=None):
253 self.genericList = GenericList(options, style, align, on_click, on_change, user_data) 262 self.genericList = GenericList(options, style, align, option_type, on_click, on_change, user_data)
254 self.max_height = max_height 263 self.max_height = max_height
255 264
256 def selectable(self): 265 def selectable(self):
257 return True 266 return True
258 267
363 372
364 def __init__(self, original_widget, label_widget): 373 def __init__(self, original_widget, label_widget):
365 urwid.LineBox.__init__(self, original_widget) 374 urwid.LineBox.__init__(self, original_widget)
366 top_columns = self._w.widget_list[0] 375 top_columns = self._w.widget_list[0]
367 top_columns.widget_list[1] = label_widget 376 top_columns.widget_list[1] = label_widget
368 377
378 class VerticalSeparator(urwid.WidgetDecoration, urwid.WidgetWrap):
379 def __init__(self, original_widget, left_char = utf8decode("│"), right_char = ''):
380 """Draw a separator on left and/or of original_widget."""
381
382 widgets = [original_widget]
383 if left_char:
384 widgets.insert(0, ('fixed', 1, urwid.SolidFill(left_char)))
385 if right_char:
386 widgets.append(('fixed', 1, urwid.SolidFill(right_char)))
387 columns = urwid.Columns(widgets, box_columns = [0,2], focus_column = 1)
388 urwid.WidgetDecoration.__init__(self, original_widget)
389 urwid.WidgetWrap.__init__(self, columns)
390
391