2007-04-30 19:00:34 +02:00
|
|
|
# Copyright (C) 2007, Red Hat, Inc.
|
2012-08-07 10:04:47 +02:00
|
|
|
# Copyright (C) 2012, Daniel Francis
|
2007-04-30 19:00:34 +02:00
|
|
|
#
|
|
|
|
# This library is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU Lesser General Public
|
|
|
|
# License as published by the Free Software Foundation; either
|
|
|
|
# version 2 of the License, or (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This library is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
# Lesser General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU Lesser General Public
|
|
|
|
# License along with this library; if not, write to the
|
|
|
|
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
|
|
# Boston, MA 02111-1307, USA.
|
|
|
|
|
2008-10-28 14:19:01 +01:00
|
|
|
"""
|
|
|
|
STABLE.
|
|
|
|
"""
|
|
|
|
|
2012-08-07 10:04:47 +02:00
|
|
|
import logging
|
|
|
|
|
2011-11-15 19:29:07 +01:00
|
|
|
from gi.repository import GObject
|
|
|
|
from gi.repository import Gtk
|
2007-04-30 19:00:34 +02:00
|
|
|
|
2011-10-29 10:44:18 +02:00
|
|
|
from sugar3.graphics.icon import Icon
|
|
|
|
from sugar3.graphics.palette import Palette, ToolInvoker
|
2007-04-30 19:00:34 +02:00
|
|
|
|
2009-08-25 21:12:40 +02:00
|
|
|
|
2012-08-07 10:04:47 +02:00
|
|
|
def _add_accelerator(tool_button):
|
|
|
|
if not tool_button.props.accelerator or not tool_button.get_toplevel() or \
|
|
|
|
not tool_button.get_child():
|
|
|
|
return
|
|
|
|
|
|
|
|
# TODO: should we remove the accelerator from the prev top level?
|
|
|
|
if not hasattr(tool_button.get_toplevel(), 'sugar_accel_group'):
|
2015-12-08 05:11:17 +01:00
|
|
|
logging.debug('No Gtk.AccelGroup in the top level window.')
|
2012-08-07 10:04:47 +02:00
|
|
|
return
|
|
|
|
|
|
|
|
accel_group = tool_button.get_toplevel().sugar_accel_group
|
|
|
|
keyval, mask = Gtk.accelerator_parse(tool_button.props.accelerator)
|
|
|
|
# the accelerator needs to be set at the child, so the Gtk.AccelLabel
|
|
|
|
# in the palette can pick it up.
|
|
|
|
accel_flags = Gtk.AccelFlags.LOCKED | Gtk.AccelFlags.VISIBLE
|
|
|
|
tool_button.get_child().add_accelerator('clicked', accel_group,
|
|
|
|
keyval, mask, accel_flags)
|
|
|
|
|
|
|
|
|
|
|
|
def _hierarchy_changed_cb(tool_button, previous_toplevel):
|
|
|
|
_add_accelerator(tool_button)
|
|
|
|
|
|
|
|
|
|
|
|
def setup_accelerator(tool_button):
|
|
|
|
_add_accelerator(tool_button)
|
|
|
|
tool_button.connect('hierarchy-changed', _hierarchy_changed_cb)
|
|
|
|
|
|
|
|
|
2011-11-15 19:29:07 +01:00
|
|
|
class ToggleToolButton(Gtk.ToggleToolButton):
|
2016-12-30 10:35:25 +01:00
|
|
|
'''
|
|
|
|
UI for toggletoolbutton.
|
|
|
|
A ToggleToolButton is a ToolItem that contains a toggle button,
|
|
|
|
having an icon, a tooltip palette, and an accelerator.
|
|
|
|
Use ToggleToolButton.new() to create a new ToggleToolButton.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
accelerator (string): keyboard shortcut to be used to
|
|
|
|
activate this button.
|
|
|
|
Find about format here :
|
|
|
|
https://developer.gnome.org/gtk3/stable/gtk3-Keyboard-Accelerators.html#gtk-accelerator-parse
|
|
|
|
|
|
|
|
tooltip (string): tooltip to be displayed when user
|
|
|
|
hovers over toggle button.
|
|
|
|
|
|
|
|
Keyword Args:
|
|
|
|
icon_name(string): name of themed icon which is to be used.
|
|
|
|
'''
|
2009-08-25 21:12:40 +02:00
|
|
|
|
2010-10-15 21:14:59 +02:00
|
|
|
__gtype_name__ = 'SugarToggleToolButton'
|
2007-08-10 18:29:28 +02:00
|
|
|
|
2012-09-19 22:25:30 +02:00
|
|
|
def __init__(self, icon_name=None):
|
2011-11-15 19:29:07 +01:00
|
|
|
GObject.GObject.__init__(self)
|
2008-05-23 17:37:04 +02:00
|
|
|
|
|
|
|
self._palette_invoker = ToolInvoker(self)
|
2012-09-19 22:25:30 +02:00
|
|
|
|
|
|
|
if icon_name:
|
|
|
|
self.set_icon_name(icon_name)
|
2007-05-04 14:47:30 +02:00
|
|
|
|
2008-09-18 14:12:18 +02:00
|
|
|
self.connect('destroy', self.__destroy_cb)
|
|
|
|
|
|
|
|
def __destroy_cb(self, icon):
|
|
|
|
if self._palette_invoker is not None:
|
|
|
|
self._palette_invoker.detach()
|
|
|
|
|
2012-09-19 22:25:30 +02:00
|
|
|
def set_icon_name(self, icon_name):
|
2016-12-30 10:35:25 +01:00
|
|
|
'''
|
|
|
|
Sets the icon for the tool button from a named themed icon.
|
|
|
|
If it is none then no icon will be shown.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
icon_name(string): The name for a themed icon.
|
|
|
|
It can be set as 'None' too.
|
|
|
|
|
|
|
|
Example:
|
|
|
|
set_icon_name('view-radial')
|
|
|
|
'''
|
2012-09-19 22:25:30 +02:00
|
|
|
icon = Icon(icon_name=icon_name)
|
2007-04-30 19:00:34 +02:00
|
|
|
self.set_icon_widget(icon)
|
|
|
|
icon.show()
|
2007-06-27 11:36:28 +02:00
|
|
|
|
2012-09-20 09:38:39 +02:00
|
|
|
def get_icon_name(self):
|
2016-12-30 10:35:25 +01:00
|
|
|
'''
|
|
|
|
The get_icon_name() method returns the value of the icon_name
|
|
|
|
property that contains the name of a themed icon or None.
|
|
|
|
'''
|
2012-09-20 09:38:39 +02:00
|
|
|
if self.props.icon_widget is not None:
|
|
|
|
return self.props.icon_widget.props.icon_name
|
|
|
|
else:
|
|
|
|
return None
|
|
|
|
|
|
|
|
icon_name = GObject.property(type=str, setter=set_icon_name,
|
|
|
|
getter=get_icon_name)
|
2012-09-19 22:25:30 +02:00
|
|
|
|
2008-05-23 17:37:04 +02:00
|
|
|
def create_palette(self):
|
|
|
|
return None
|
|
|
|
|
2007-06-27 11:36:28 +02:00
|
|
|
def get_palette(self):
|
2008-05-23 17:37:04 +02:00
|
|
|
return self._palette_invoker.palette
|
|
|
|
|
2007-06-27 11:36:28 +02:00
|
|
|
def set_palette(self, palette):
|
2008-05-23 17:37:04 +02:00
|
|
|
self._palette_invoker.palette = palette
|
|
|
|
|
2011-11-15 19:29:07 +01:00
|
|
|
palette = GObject.property(
|
2008-05-23 17:37:04 +02:00
|
|
|
type=object, setter=set_palette, getter=get_palette)
|
|
|
|
|
|
|
|
def get_palette_invoker(self):
|
|
|
|
return self._palette_invoker
|
2009-08-25 19:55:48 +02:00
|
|
|
|
2008-05-23 17:37:04 +02:00
|
|
|
def set_palette_invoker(self, palette_invoker):
|
|
|
|
self._palette_invoker.detach()
|
|
|
|
self._palette_invoker = palette_invoker
|
|
|
|
|
2011-11-15 19:29:07 +01:00
|
|
|
palette_invoker = GObject.property(
|
2008-05-23 17:37:04 +02:00
|
|
|
type=object, setter=set_palette_invoker, getter=get_palette_invoker)
|
2007-06-27 11:36:28 +02:00
|
|
|
|
|
|
|
def set_tooltip(self, text):
|
2016-12-30 10:35:25 +01:00
|
|
|
'''
|
|
|
|
Sets the tooltip of the toogle tool button. Displays when
|
|
|
|
user hovers over the button with cursor.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
tooltip (string): tooltip to be added to the button
|
|
|
|
'''
|
2007-08-21 18:35:20 +02:00
|
|
|
self.set_palette(Palette(text))
|
2009-08-25 19:55:48 +02:00
|
|
|
|
2012-08-07 10:04:47 +02:00
|
|
|
def set_accelerator(self, accelerator):
|
2016-12-30 10:35:25 +01:00
|
|
|
'''
|
|
|
|
Sets keyboard shortcut that activates this button.
|
|
|
|
|
|
|
|
Args:
|
|
|
|
accelerator(string): accelerator to be set. Should be in
|
|
|
|
form <modifier>Letter
|
|
|
|
Find about format here :
|
|
|
|
https://developer.gnome.org/gtk3/stable/gtk3-Keyboard-Accelerators.html#gtk-accelerator-parse
|
|
|
|
|
|
|
|
Example:
|
|
|
|
set_accelerator(self, 'accel')
|
|
|
|
'''
|
2012-08-07 10:04:47 +02:00
|
|
|
self._accelerator = accelerator
|
|
|
|
setup_accelerator(self)
|
|
|
|
|
|
|
|
def get_accelerator(self):
|
2016-12-30 10:35:25 +01:00
|
|
|
'''
|
|
|
|
Returns above accelerator string.
|
|
|
|
'''
|
2012-08-07 10:04:47 +02:00
|
|
|
return self._accelerator
|
|
|
|
|
|
|
|
accelerator = GObject.property(type=str, setter=set_accelerator,
|
|
|
|
getter=get_accelerator)
|
|
|
|
|
2012-08-24 02:08:24 +02:00
|
|
|
def do_draw(self, cr):
|
2016-12-30 10:35:25 +01:00
|
|
|
'''
|
|
|
|
Implementation method for drawing the toogle tool button
|
|
|
|
'''
|
2008-05-23 18:00:47 +02:00
|
|
|
if self.palette and self.palette.is_up():
|
2012-08-24 02:08:24 +02:00
|
|
|
allocation = self.get_allocation()
|
|
|
|
# draw a black background, has been done by the engine before
|
|
|
|
cr.set_source_rgb(0, 0, 0)
|
|
|
|
cr.rectangle(0, 0, allocation.width, allocation.height)
|
|
|
|
cr.paint()
|
|
|
|
|
|
|
|
Gtk.ToggleToolButton.do_draw(self, cr)
|
2009-08-25 19:55:48 +02:00
|
|
|
|
2012-12-11 05:19:12 +01:00
|
|
|
if self.palette and self.palette.is_up():
|
|
|
|
invoker = self.palette.props.invoker
|
|
|
|
invoker.draw_rectangle(cr, self.palette)
|
|
|
|
|
|
|
|
return False
|
|
|
|
|
2013-02-15 13:58:58 +01:00
|
|
|
def do_clicked(self):
|
2016-12-30 10:35:25 +01:00
|
|
|
'''
|
|
|
|
Implementation method for hiding the tooltip when the
|
|
|
|
toggle button is clicked
|
|
|
|
'''
|
2013-02-15 13:58:58 +01:00
|
|
|
if self.palette:
|
|
|
|
self.palette.popdown(True)
|
|
|
|
|
2007-06-27 11:36:28 +02:00
|
|
|
palette = property(get_palette, set_palette)
|