Ticket #1592: new-view-separators.patch

File new-view-separators.patch, 9.0 KB (added by walter, 14 years ago)

diff against latest version in git

  • extensions/cpsection/aboutme/view.py

    diff --git a/extensions/cpsection/aboutme/view.py b/extensions/cpsection/aboutme/view.py
    index cabd66a..5e429d2 100644
    a b from sugar.graphics.xocolor import XoColor 
    2525from jarabe.controlpanel.sectionview import SectionView
    2626from jarabe.controlpanel.inlinealert import InlineAlert
    2727
     28_DIRECTION_LEFT = 0
     29_DIRECTION_TOP = 1
     30_DIRECTION_CENTER = 2
     31_DIRECTION_BOTTOM = 3
     32_DIRECTION_RIGHT = 4
     33
    2834class EventIcon(gtk.EventBox):
    2935    __gtype_name__ = "SugarEventIcon"   
    3036    def __init__(self, **kwargs):         
    class ColorPicker(EventIcon): 
    4349    __gsignals__ = {
    4450        'color-changed': (gobject.SIGNAL_RUN_FIRST,
    4551                          gobject.TYPE_NONE,
    46                           ([str]))
     52                          ([object]))
    4753    }
    48     def __init__(self, xocolor=None):
     54    def __init__(self, direction):
    4955        EventIcon.__init__(self)
    50         self.icon.props.xo_color = xocolor
     56
    5157        self.icon.props.icon_name = 'computer-xo'
     58        self._direction = direction
     59        self._color = None
     60
    5261        self.icon.props.pixel_size = style.XLARGE_ICON_SIZE
    53         self.connect('button_press_event', self.__pressed_cb)
    5462
    55     def __pressed_cb(self, button, event):
    56         self._set_random_colors()
     63        self.connect('button_press_event', self.__pressed_cb, direction)
    5764
    58     def _set_random_colors(self):
    59         xocolor = XoColor()
    60         self.icon.props.xo_color = xocolor
    61         self.emit('color-changed', xocolor.to_string())
     65    def update(self, color):
     66        if self._direction == _DIRECTION_CENTER:
     67            self._color = color
     68        elif self._direction == _DIRECTION_LEFT:
     69            self._color = XoColor(color.get_prev_fill_color())
     70        elif self._direction == _DIRECTION_RIGHT:
     71            self._color = XoColor(color.get_prev_stroke_color())
     72        elif self._direction == _DIRECTION_TOP:
     73            self._color = XoColor(color.get_next_fill_color())
     74        else:
     75            self._color = XoColor(color.get_next_stroke_color())
     76        self.icon.props.xo_color = self._color
     77
     78    def __pressed_cb(self, button, event, direction):
     79        if direction != _DIRECTION_CENTER:
     80            self.emit('color-changed', self._color)
    6281
    6382class AboutMe(SectionView):
    6483    def __init__(self, model, alerts):
    class AboutMe(SectionView): 
    6988        self._nick_sid = 0
    7089        self._color_valid = True
    7190        self._nick_valid = True
    72         self._color_change_handler = None
    73         self._nick_change_handler = None
     91        self._handlers = []
    7492
    7593        self.set_border_width(style.DEFAULT_SPACING * 2)
    7694        self.set_spacing(style.DEFAULT_SPACING)
    7795        self._group = gtk.SizeGroup(gtk.SIZE_GROUP_HORIZONTAL)
    7896
    79         self._nick_box = gtk.HBox(spacing=style.DEFAULT_SPACING)
    80         self._nick_alert_box = gtk.HBox(spacing=style.DEFAULT_SPACING)
    81         self._nick_entry = None
    82         self._nick_alert = None
    83         self._setup_nick()
    84 
     97        self._color_label = gtk.HBox(spacing=style.DEFAULT_SPACING)
    8598        self._color_box = gtk.HBox(spacing=style.DEFAULT_SPACING)
    8699        self._color_alert_box = gtk.HBox(spacing=style.DEFAULT_SPACING)
    87         self._color_picker = None
    88100        self._color_alert = None
    89         self._setup_color()       
    90101
     102        self._pickers = {
     103                _DIRECTION_CENTER: ColorPicker(_DIRECTION_CENTER),
     104                _DIRECTION_LEFT: ColorPicker(_DIRECTION_LEFT),
     105                _DIRECTION_RIGHT: ColorPicker(_DIRECTION_RIGHT),
     106                _DIRECTION_TOP: ColorPicker(_DIRECTION_TOP),
     107                _DIRECTION_BOTTOM: ColorPicker(_DIRECTION_BOTTOM)}
     108
     109        self._setup_color()
     110        initial_color = XoColor(self._model.get_color_xo())
     111        self._update_pickers(initial_color)
     112
     113        self._nick_box = gtk.HBox(spacing=style.DEFAULT_SPACING)
     114        self._nick_alert_box = gtk.HBox(spacing=style.DEFAULT_SPACING)
     115        self._nick_entry = None
     116        self._nick_alert = None
     117        self._setup_nick()
    91118        self.setup()
    92119
    93120    def _setup_nick(self):
    94         label_entry = gtk.Label(_('Name:'))
    95         label_entry.modify_fg(gtk.STATE_NORMAL,
    96                               style.COLOR_SELECTION_GREY.get_gdk_color())
    97         self._group.add_widget(label_entry)
    98         label_entry.set_alignment(1, 0.5)
    99         self._nick_box.pack_start(label_entry, expand=False)
    100         label_entry.show()
    101 
    102121        self._nick_entry = gtk.Entry()               
    103122        self._nick_entry.modify_bg(gtk.STATE_INSENSITIVE,
    104123                                   style.COLOR_WHITE.get_gdk_color())
    class AboutMe(SectionView): 
    119138            self._nick_alert.props.msg = self.restart_msg
    120139            self._nick_alert.show()
    121140
    122         self.pack_start(self._nick_box, False)
     141        self._center_in_panel = gtk.Alignment(0.5)
     142        self._center_in_panel.add(self._nick_box)
     143        self.pack_start(self._center_in_panel, False)
    123144        self.pack_start(self._nick_alert_box, False)
    124145        self._nick_box.show()
    125146        self._nick_alert_box.show()
     147        self._center_in_panel.show()
    126148   
    127149    def _setup_color(self):               
    128150        label_color = gtk.Label(_('Click to change your color:'))
    129151        label_color.modify_fg(gtk.STATE_NORMAL,
    130152                              style.COLOR_SELECTION_GREY.get_gdk_color())
    131153        self._group.add_widget(label_color)
    132         self._color_box.pack_start(label_color, expand=False)
     154        self._color_label.pack_start(label_color, expand=False)
    133155        label_color.show()
    134        
    135         self._color_picker = ColorPicker()
    136         self._color_box.pack_start(self._color_picker, expand=False)
    137         self._color_picker.show()
     156
     157        for direction in sorted(self._pickers.keys()):
     158            if direction == _DIRECTION_CENTER:
     159                left_separator = gtk.SeparatorToolItem()
     160                left_separator.show()
     161                self._color_box.pack_start(left_separator, expand=False)
     162
     163            picker = self._pickers[direction]
     164            picker.show()
     165            self._color_box.pack_start(picker, expand=False)
     166
     167            if direction == _DIRECTION_CENTER:
     168                right_separator = gtk.SeparatorToolItem()
     169                right_separator.show()
     170                self._color_box.pack_start(right_separator, expand=False)
    138171
    139172        label_color_error = gtk.Label()
    140173        self._group.add_widget(label_color_error)
    class AboutMe(SectionView): 
    147180            self._color_alert.props.msg = self.restart_msg
    148181            self._color_alert.show()
    149182
    150         self.pack_start(self._color_box, False)
     183        self._center_in_panel = gtk.Alignment(0.5)
     184        self._center_in_panel.add(self._color_box)
     185        self.pack_start(self._color_label, False)
     186        self.pack_start(self._center_in_panel, False)
    151187        self.pack_start(self._color_alert_box, False)       
     188        self._color_label.show()
    152189        self._color_box.show()
    153190        self._color_alert_box.show()
     191        self._center_in_panel.show()
    154192   
    155193    def setup(self):
    156194        self._nick_entry.set_text(self._model.get_nick())
    157         color = XoColor(self._model.get_color_xo())
    158         self._color_picker.icon.props.xo_color = color
    159 
    160195        self._color_valid = True
    161196        self._nick_valid = True
    162197        self.needs_restart = False
    163         self._nick_change_handler = self._nick_entry.connect( \
    164                 'changed', self.__nick_changed_cb)
    165         self._color_change_handler = self._color_picker.connect( \
    166                 'color-changed', self.__color_changed_cb)
     198
     199        def connect(widget, signal, cb):
     200            self._handlers.append((widget, widget.connect(signal, cb)))
     201
     202        connect(self._nick_entry, 'changed', self.__nick_changed_cb)
     203        for picker in self._pickers.values():
     204            connect(picker, 'color-changed', self.__color_changed_cb)
    167205
    168206    def undo(self):
    169         self._color_picker.disconnect(self._color_change_handler)
    170         self._nick_entry.disconnect(self._nick_change_handler)
     207        for widget, handler in self._handlers:
     208            widget.disconnect(handler)
    171209        self._model.undo()
    172210        self._nick_alert.hide()
    173211        self._color_alert.hide()       
    174212
     213    def _update_pickers(self, color):
     214        for picker in self._pickers.values():
     215            picker.update(color)
     216
    175217    def _validate(self):
    176218        if self._nick_valid and self._color_valid:
    177219            self.props.is_valid = True
    class AboutMe(SectionView): 
    203245        self._nick_alert.show()
    204246        return False
    205247
    206     def __color_changed_cb(self, colorpicker, xocolor):       
    207         self._model.set_color_xo(xocolor)
     248    def __color_changed_cb(self, colorpicker, color):
     249        self._model.set_color_xo(color.to_string())
    208250        self.needs_restart = True
    209251        self._color_alert.props.msg = self.restart_msg
    210252        self._color_valid = True
    class AboutMe(SectionView): 
    212254
    213255        self._validate()
    214256        self._color_alert.show()
     257
     258        self._update_pickers(color)
     259
    215260        return False