From 59c793608c8a63732a38892c716d42279b0578bf Mon Sep 17 00:00:00 2001 From: Nick Hall Date: Mon, 25 Jul 2011 22:47:57 +0000 Subject: [PATCH] Introduce experimental netbook mode for small screen sizes svn: r17965 --- po/POTFILES.skip | 1 + src/DisplayState.py | 10 +++++ src/Filters/SideBar/_EventSidebarFilter.py | 20 +++++---- src/Filters/SideBar/_FamilySidebarFilter.py | 17 ++++--- src/Filters/SideBar/_MediaSidebarFilter.py | 16 +++---- src/Filters/SideBar/_NoteSidebarFilter.py | 8 ++-- src/Filters/SideBar/_PersonSidebarFilter.py | 14 +++--- src/Filters/SideBar/_PlaceSidebarFilter.py | 27 +++++------ src/Filters/SideBar/_RepoSidebarFilter.py | 14 +++--- src/Filters/SideBar/_SidebarFilter.py | 25 +++++++---- src/Filters/SideBar/_SourceSidebarFilter.py | 13 +++--- src/gui/grampsbar.py | 6 ++- src/gui/widgets/Makefile.am | 1 + src/gui/widgets/__init__.py | 1 + src/gui/widgets/basicentry.py | 50 +++++++++++++++++++++ src/gui/widgets/photo.py | 7 ++- src/plugins/gramplet/CalendarGramplet.py | 2 + src/plugins/gramplet/Gallery.py | 2 +- src/plugins/gramplet/MediaPreview.py | 2 +- src/plugins/gramplet/PersonDetails.py | 2 +- src/plugins/gramplet/PlaceDetails.py | 2 +- 21 files changed, 167 insertions(+), 73 deletions(-) create mode 100644 src/gui/widgets/basicentry.py diff --git a/po/POTFILES.skip b/po/POTFILES.skip index ff5ab4180..62836c4a1 100644 --- a/po/POTFILES.skip +++ b/po/POTFILES.skip @@ -257,6 +257,7 @@ src/gui/views/treemodels/repomodel.py src/gui/views/treemodels/sourcemodel.py # gui/widgets - the GUI widgets package +src/gui/widgets/basicentry.py src/gui/widgets/menutoolbuttonaction.py src/gui/widgets/styledtextbuffer.py src/gui/widgets/undoablestyledbuffer.py diff --git a/src/DisplayState.py b/src/DisplayState.py index 35566bba1..85500cad2 100644 --- a/src/DisplayState.py +++ b/src/DisplayState.py @@ -402,6 +402,16 @@ class DisplayState(gen.utils.Callback): # but this connection is still made! # self.dbstate.connect('database-changed', self.db_changed) + self.__netbook_mode = False + if self.window.get_screen().get_width() <= 1024: + self.__netbook_mode = True + + def netbook_mode(self): + """ + Return True if running on a small screen, else return False. + """ + return self.__netbook_mode + def clear_history(self): """ Clear all history objects. diff --git a/src/Filters/SideBar/_EventSidebarFilter.py b/src/Filters/SideBar/_EventSidebarFilter.py index a2500de7b..a89f1f138 100644 --- a/src/Filters/SideBar/_EventSidebarFilter.py +++ b/src/Filters/SideBar/_EventSidebarFilter.py @@ -58,8 +58,8 @@ class EventSidebarFilter(SidebarFilter): def __init__(self, dbstate, uistate, clicked): self.clicked_func = clicked - self.filter_id = gtk.Entry() - self.filter_desc = gtk.Entry() + self.filter_id = widgets.BasicEntry() + self.filter_desc = widgets.BasicEntry() self.filter_event = gen.lib.Event() self.filter_event.set_type((gen.lib.EventType.CUSTOM, u'')) self.etype = gtk.ComboBoxEntry() @@ -69,11 +69,11 @@ class EventSidebarFilter(SidebarFilter): self.filter_event.set_type, self.filter_event.get_type) - self.filter_mainparts = gtk.Entry() - self.filter_date = gtk.Entry() - self.filter_place = gtk.Entry() - self.filter_note = gtk.Entry() - + self.filter_mainparts = widgets.BasicEntry() + self.filter_date = widgets.BasicEntry() + self.filter_place = widgets.BasicEntry() + self.filter_note = widgets.BasicEntry() + self.filter_regex = gtk.CheckButton(_('Use regular expressions')) self.generic = gtk.ComboBox() @@ -88,15 +88,17 @@ class EventSidebarFilter(SidebarFilter): self.generic.add_attribute(cell, 'text', 0) self.on_filters_changed('Event') + self.etype.child.set_width_chars(5) + self.add_text_entry(_('ID'), self.filter_id) self.add_text_entry(_('Description'), self.filter_desc) self.add_entry(_('Type'), self.etype) - self.add_text_entry(_('Main Participants'), self.filter_mainparts) + self.add_text_entry(_('Participants'), self.filter_mainparts) self.add_text_entry(_('Date'), self.filter_date) self.add_text_entry(_('Place'), self.filter_place) self.add_text_entry(_('Note'), self.filter_note) self.add_filter_entry(_('Custom filter'), self.generic) - self.add_entry(None, self.filter_regex) + self.add_regex_entry(self.filter_regex) def clear(self, obj): self.filter_id.set_text(u'') diff --git a/src/Filters/SideBar/_FamilySidebarFilter.py b/src/Filters/SideBar/_FamilySidebarFilter.py index da468c841..e5df9fefa 100644 --- a/src/Filters/SideBar/_FamilySidebarFilter.py +++ b/src/Filters/SideBar/_FamilySidebarFilter.py @@ -62,10 +62,10 @@ class FamilySidebarFilter(SidebarFilter): def __init__(self, dbstate, uistate, clicked): self.clicked_func = clicked - self.filter_id = gtk.Entry() - self.filter_father = gtk.Entry() - self.filter_mother = gtk.Entry() - self.filter_child = gtk.Entry() + self.filter_id = widgets.BasicEntry() + self.filter_father = widgets.BasicEntry() + self.filter_mother = widgets.BasicEntry() + self.filter_child = widgets.BasicEntry() self.filter_event = gen.lib.Event() self.filter_event.set_type((gen.lib.EventType.CUSTOM, u'')) @@ -85,8 +85,8 @@ class FamilySidebarFilter(SidebarFilter): self.family_stub.set_relationship, self.family_stub.get_relationship) - self.filter_note = gtk.Entry() - + self.filter_note = widgets.BasicEntry() + self.filter_regex = gtk.CheckButton(_('Use regular expressions')) self.tag = gtk.ComboBox() @@ -108,6 +108,9 @@ class FamilySidebarFilter(SidebarFilter): self.tag.pack_start(cell, True) self.tag.add_attribute(cell, 'text', 0) + self.etype.child.set_width_chars(5) + self.rtype.child.set_width_chars(5) + self.add_text_entry(_('ID'), self.filter_id) self.add_text_entry(_('Father'), self.filter_father) self.add_text_entry(_('Mother'), self.filter_mother) @@ -117,7 +120,7 @@ class FamilySidebarFilter(SidebarFilter): self.add_text_entry(_('Family Note'), self.filter_note) self.add_entry(_('Tag'), self.tag) self.add_filter_entry(_('Custom filter'), self.generic) - self.add_entry(None, self.filter_regex) + self.add_regex_entry(self.filter_regex) def clear(self, obj): self.filter_id.set_text(u'') diff --git a/src/Filters/SideBar/_MediaSidebarFilter.py b/src/Filters/SideBar/_MediaSidebarFilter.py index 880f0469c..bf45e3e5d 100644 --- a/src/Filters/SideBar/_MediaSidebarFilter.py +++ b/src/Filters/SideBar/_MediaSidebarFilter.py @@ -40,6 +40,7 @@ import gtk # GRAMPS modules # #------------------------------------------------------------------------- +from gui import widgets from Filters.SideBar import SidebarFilter from Filters import GenericFilterFactory, build_filter_model, Rules from Filters.Rules.MediaObject import (RegExpIdOf, HasIdOf, HasMedia, HasTag, @@ -56,13 +57,12 @@ class MediaSidebarFilter(SidebarFilter): def __init__(self, dbstate, uistate, clicked): self.clicked_func = clicked - self.filter_id = gtk.Entry() - self.filter_title = gtk.Entry() - self.filter_type = gtk.Entry() - self.filter_path = gtk.Entry() - self.filter_date = gtk.Entry() - - self.filter_note = gtk.Entry() + self.filter_id = widgets.BasicEntry() + self.filter_title = widgets.BasicEntry() + self.filter_type = widgets.BasicEntry() + self.filter_path = widgets.BasicEntry() + self.filter_date = widgets.BasicEntry() + self.filter_note = widgets.BasicEntry() self.filter_regex = gtk.CheckButton(_('Use regular expressions')) @@ -93,7 +93,7 @@ class MediaSidebarFilter(SidebarFilter): self.add_text_entry(_('Note'), self.filter_note) self.add_entry(_('Tag'), self.tag) self.add_filter_entry(_('Custom filter'), self.generic) - self.add_entry(None, self.filter_regex) + self.add_regex_entry(self.filter_regex) def clear(self, obj): self.filter_id.set_text('') diff --git a/src/Filters/SideBar/_NoteSidebarFilter.py b/src/Filters/SideBar/_NoteSidebarFilter.py index 446483e4e..9bff57b1f 100644 --- a/src/Filters/SideBar/_NoteSidebarFilter.py +++ b/src/Filters/SideBar/_NoteSidebarFilter.py @@ -58,8 +58,8 @@ class NoteSidebarFilter(SidebarFilter): def __init__(self, dbstate, uistate, clicked): self.clicked_func = clicked - self.filter_id = gtk.Entry() - self.filter_text = gtk.Entry() + self.filter_id = widgets.BasicEntry() + self.filter_text = widgets.BasicEntry() self.note = Note() self.note.set_type((NoteType.CUSTOM,'')) @@ -90,12 +90,14 @@ class NoteSidebarFilter(SidebarFilter): self.tag.pack_start(cell, True) self.tag.add_attribute(cell, 'text', 0) + self.ntype.child.set_width_chars(5) + self.add_text_entry(_('ID'), self.filter_id) self.add_text_entry(_('Text'), self.filter_text) self.add_entry(_('Type'), self.ntype) self.add_entry(_('Tag'), self.tag) self.add_filter_entry(_('Custom filter'), self.generic) - self.add_entry(None, self.filter_regex) + self.add_regex_entry(self.filter_regex) def clear(self, obj): self.filter_id.set_text('') diff --git a/src/Filters/SideBar/_PersonSidebarFilter.py b/src/Filters/SideBar/_PersonSidebarFilter.py index 23e5c6392..321806c3c 100644 --- a/src/Filters/SideBar/_PersonSidebarFilter.py +++ b/src/Filters/SideBar/_PersonSidebarFilter.py @@ -72,10 +72,10 @@ class PersonSidebarFilter(SidebarFilter): def __init__(self, dbstate, uistate, clicked): self.clicked_func = clicked - self.filter_name = gtk.Entry() - self.filter_id = gtk.Entry() - self.filter_birth = gtk.Entry() - self.filter_death = gtk.Entry() + self.filter_name = widgets.BasicEntry() + self.filter_id = widgets.BasicEntry() + self.filter_birth = widgets.BasicEntry() + self.filter_death = widgets.BasicEntry() self.filter_event = gen.lib.Event() self.filter_event.set_type((gen.lib.EventType.CUSTOM, u'')) self.etype = gtk.ComboBoxEntry() @@ -84,7 +84,7 @@ class PersonSidebarFilter(SidebarFilter): self.filter_event.set_type, self.filter_event.get_type) - self.filter_note = gtk.Entry() + self.filter_note = widgets.BasicEntry() self.filter_gender = gtk.combo_box_new_text() map(self.filter_gender.append_text, [ _('any'), _('male'), _('female'), _('unknown') ]) @@ -111,6 +111,8 @@ class PersonSidebarFilter(SidebarFilter): self.tag.pack_start(cell, True) self.tag.add_attribute(cell, 'text', 0) + self.etype.child.set_width_chars(5) + exdate1 = gen.lib.Date() exdate2 = gen.lib.Date() exdate1.set(gen.lib.Date.QUAL_NONE, gen.lib.Date.MOD_RANGE, @@ -133,7 +135,7 @@ class PersonSidebarFilter(SidebarFilter): self.add_text_entry(_('Note'), self.filter_note) self.add_entry(_('Tag'), self.tag) self.add_filter_entry(_('Custom filter'), self.generic) - self.add_entry(None, self.filter_regex) + self.add_regex_entry(self.filter_regex) def clear(self, obj): self.filter_name.set_text(u'') diff --git a/src/Filters/SideBar/_PlaceSidebarFilter.py b/src/Filters/SideBar/_PlaceSidebarFilter.py index 720bb4efb..7ce24545c 100644 --- a/src/Filters/SideBar/_PlaceSidebarFilter.py +++ b/src/Filters/SideBar/_PlaceSidebarFilter.py @@ -41,7 +41,7 @@ import gtk # GRAMPS modules # #------------------------------------------------------------------------- - +from gui import widgets from Filters.SideBar import SidebarFilter from Filters import GenericFilterFactory, build_filter_model, Rules from Filters.Rules.Place import (RegExpIdOf, HasIdOf, HasPlace, HasNoteRegexp, @@ -58,17 +58,18 @@ class PlaceSidebarFilter(SidebarFilter): def __init__(self, dbstate, uistate, clicked): self.clicked_func = clicked - self.filter_id = gtk.Entry() - self.filter_title = gtk.Entry() - self.filter_street = gtk.Entry() - self.filter_locality = gtk.Entry() - self.filter_city = gtk.Entry() - self.filter_county = gtk.Entry() - self.filter_state = gtk.Entry() - self.filter_country = gtk.Entry() - self.filter_zip = gtk.Entry() - self.filter_parish = gtk.Entry() - self.filter_note = gtk.Entry() + self.filter_id = widgets.BasicEntry() + self.filter_title = widgets.BasicEntry() + self.filter_street = widgets.BasicEntry() + self.filter_locality = widgets.BasicEntry() + self.filter_city = widgets.BasicEntry() + self.filter_county = widgets.BasicEntry() + self.filter_state = widgets.BasicEntry() + self.filter_country = widgets.BasicEntry() + self.filter_zip = widgets.BasicEntry() + self.filter_parish = widgets.BasicEntry() + self.filter_note = widgets.BasicEntry() + self.filter_regex = gtk.CheckButton(_('Use regular expressions')) self.generic = gtk.ComboBox() @@ -94,7 +95,7 @@ class PlaceSidebarFilter(SidebarFilter): self.add_text_entry(_('Church parish'), self.filter_parish) self.add_text_entry(_('Note'), self.filter_note) self.add_filter_entry(_('Custom filter'), self.generic) - self.add_entry(None, self.filter_regex) + self.add_regex_entry(self.filter_regex) def clear(self, obj): self.filter_id.set_text('') diff --git a/src/Filters/SideBar/_RepoSidebarFilter.py b/src/Filters/SideBar/_RepoSidebarFilter.py index 9c290993b..7fd32474a 100644 --- a/src/Filters/SideBar/_RepoSidebarFilter.py +++ b/src/Filters/SideBar/_RepoSidebarFilter.py @@ -58,10 +58,10 @@ class RepoSidebarFilter(SidebarFilter): def __init__(self, dbstate, uistate, clicked): self.clicked_func = clicked - self.filter_id = gtk.Entry() - self.filter_title = gtk.Entry() - self.filter_address = gtk.Entry() - self.filter_url = gtk.Entry() + self.filter_id = widgets.BasicEntry() + self.filter_title = widgets.BasicEntry() + self.filter_address = widgets.BasicEntry() + self.filter_url = widgets.BasicEntry() self.repo = Repository() self.repo.set_type((RepositoryType.CUSTOM,'')) @@ -71,7 +71,7 @@ class RepoSidebarFilter(SidebarFilter): self.repo.set_type, self.repo.get_type) - self.filter_note = gtk.Entry() + self.filter_note = widgets.BasicEntry() self.filter_regex = gtk.CheckButton(_('Use regular expressions')) @@ -87,6 +87,8 @@ class RepoSidebarFilter(SidebarFilter): self.generic.add_attribute(cell, 'text', 0) self.on_filters_changed('Repository') + self.rtype.child.set_width_chars(5) + self.add_text_entry(_('ID'), self.filter_id) self.add_text_entry(_('Name'), self.filter_title) self.add_entry(_('Type'), self.rtype) @@ -94,7 +96,7 @@ class RepoSidebarFilter(SidebarFilter): self.add_text_entry(_('URL'), self.filter_url) self.add_text_entry(_('Note'), self.filter_note) self.add_filter_entry(_('Custom filter'), self.generic) - self.add_entry(None, self.filter_regex) + self.add_regex_entry(self.filter_regex) def clear(self, obj): self.filter_id.set_text('') diff --git a/src/Filters/SideBar/_SidebarFilter.py b/src/Filters/SideBar/_SidebarFilter.py index f5a102121..41bde43c4 100644 --- a/src/Filters/SideBar/_SidebarFilter.py +++ b/src/Filters/SideBar/_SidebarFilter.py @@ -34,7 +34,7 @@ _RETURN = gtk.gdk.keyval_from_name("Return") _KP_ENTER = gtk.gdk.keyval_from_name("KP_Enter") class SidebarFilter(DbGUIElement): - _FILTER_WIDTH = 200 + _FILTER_WIDTH = 20 _FILTER_ELLIPSIZE = pango.ELLIPSIZE_END def __init__(self, dbstate, uistate, namespace): @@ -47,7 +47,9 @@ class SidebarFilter(DbGUIElement): DbGUIElement.__init__(self, dbstate.db) self.position = 1 + self.vbox = gtk.VBox() self.table = gtk.Table(4, 11) + self.vbox.pack_start(self.table, False, False) self.table.set_border_width(6) self.table.set_row_spacings(6) self.table.set_col_spacing(0, 6) @@ -83,16 +85,18 @@ class SidebarFilter(DbGUIElement): self.clear_btn.add(hbox) self.clear_btn.connect('clicked', self.clear) - hbox = gtk.HBox() + hbox = gtk.HButtonBox() + hbox.set_layout(gtk.BUTTONBOX_START) hbox.set_spacing(6) + hbox.set_border_width(12) hbox.add(self.apply_btn) hbox.add(self.clear_btn) hbox.show() - self.table.attach(hbox, 2, 4, self.position, self.position+1, - xoptions=gtk.FILL, yoptions=0) + self.vbox.pack_start(hbox, False, False) + self.vbox.show() def get_widget(self): - return self.table + return self.vbox def create_widget(self): pass @@ -111,6 +115,11 @@ class SidebarFilter(DbGUIElement): def get_filter(self): pass + def add_regex_entry(self, widget): + hbox = gtk.HBox() + hbox.pack_start(widget, False, False, 12) + self.vbox.pack_start(hbox, False, False) + def add_text_entry(self, name, widget, tooltip=None): self.add_entry(name, widget) widget.connect('key-press-event', self.key_press) @@ -129,7 +138,7 @@ class SidebarFilter(DbGUIElement): 1, 2, self.position, self.position+1, xoptions=gtk.FILL, yoptions=0) self.table.attach(widget, 2, 4, self.position, self.position+1, - xoptions=gtk.FILL, yoptions=0) + xoptions=gtk.FILL|gtk.EXPAND, yoptions=0) self.position += 1 def on_filters_changed(self, namespace): @@ -208,8 +217,8 @@ class SidebarFilter(DbGUIElement): Adds the text and widget to GUI, with an Edit button. """ hbox = gtk.HBox() - hbox.pack_start(widget) - hbox.pack_start(widgets.SimpleButton(gtk.STOCK_EDIT, self.edit_filter)) + hbox.pack_start(widget, True, True) + hbox.pack_start(widgets.SimpleButton(gtk.STOCK_EDIT, self.edit_filter), False, False) self.add_entry(text, hbox) def edit_filter(self, obj): diff --git a/src/Filters/SideBar/_SourceSidebarFilter.py b/src/Filters/SideBar/_SourceSidebarFilter.py index fe2125048..2199deab7 100644 --- a/src/Filters/SideBar/_SourceSidebarFilter.py +++ b/src/Filters/SideBar/_SourceSidebarFilter.py @@ -39,6 +39,7 @@ import gtk # GRAMPS modules # #------------------------------------------------------------------------- +from gui import widgets from Filters.SideBar import SidebarFilter from Filters import GenericFilterFactory, build_filter_model, Rules from Filters.Rules.Source import (RegExpIdOf, HasIdOf, HasSource, @@ -55,11 +56,11 @@ class SourceSidebarFilter(SidebarFilter): def __init__(self, dbstate, uistate, clicked): self.clicked_func = clicked - self.filter_id = gtk.Entry() - self.filter_title = gtk.Entry() - self.filter_author = gtk.Entry() - self.filter_pub = gtk.Entry() - self.filter_note = gtk.Entry() + self.filter_id = widgets.BasicEntry() + self.filter_title = widgets.BasicEntry() + self.filter_author = widgets.BasicEntry() + self.filter_pub = widgets.BasicEntry() + self.filter_note = widgets.BasicEntry() self.filter_regex = gtk.CheckButton(_('Use regular expressions')) @@ -81,7 +82,7 @@ class SourceSidebarFilter(SidebarFilter): self.add_text_entry(_('Publication'), self.filter_pub) self.add_text_entry(_('Note'), self.filter_note) self.add_filter_entry(_('Custom filter'), self.generic) - self.add_entry(None, self.filter_regex) + self.add_regex_entry(self.filter_regex) def clear(self, obj): self.filter_id.set_text('') diff --git a/src/gui/grampsbar.py b/src/gui/grampsbar.py index cd0b37929..550e589df 100644 --- a/src/gui/grampsbar.py +++ b/src/gui/grampsbar.py @@ -314,7 +314,11 @@ class GrampsBar(gtk.Notebook): """ Add a tab to the notebook for the given gramplet. """ - gramplet.set_size_request(gramplet.width, gramplet.height) + if self.uistate.netbook_mode(): + gramplet.set_size_request(225, 120) + else: + gramplet.set_size_request(285, 200) + page_num = self.append_page(gramplet) return page_num diff --git a/src/gui/widgets/Makefile.am b/src/gui/widgets/Makefile.am index b6a92d9eb..fadc34f90 100644 --- a/src/gui/widgets/Makefile.am +++ b/src/gui/widgets/Makefile.am @@ -7,6 +7,7 @@ pkgdatadir = $(datadir)/@PACKAGE@/gui/widgets pkgdata_PYTHON = \ __init__.py \ + basicentry.py \ buttons.py \ expandcollapsearrow.py \ grampletpane.py \ diff --git a/src/gui/widgets/__init__.py b/src/gui/widgets/__init__.py index bbc7915d5..2a2a0020c 100644 --- a/src/gui/widgets/__init__.py +++ b/src/gui/widgets/__init__.py @@ -23,6 +23,7 @@ """Custom widgets.""" +from basicentry import * from buttons import * from expandcollapsearrow import * from labels import * diff --git a/src/gui/widgets/basicentry.py b/src/gui/widgets/basicentry.py new file mode 100644 index 000000000..7d5119ca5 --- /dev/null +++ b/src/gui/widgets/basicentry.py @@ -0,0 +1,50 @@ +# +# Gramps - a GTK+/GNOME based genealogy program +# +# Copyright (C) 2011 Nick Hall +# +# This program is free software; you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation; either version 2 of the License, or +# (at your option) any later version. +# +# This program 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 General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +# + +# $Id$ + +__all__ = ["BasicEntry"] + +#------------------------------------------------------------------------- +# +# Standard python modules +# +#------------------------------------------------------------------------- +import logging +_LOG = logging.getLogger(".widgets.basicentry") + +#------------------------------------------------------------------------- +# +# GTK/Gnome modules +# +#------------------------------------------------------------------------- +import gtk + +#------------------------------------------------------------------------- +# +# BasicEntry class +# +#------------------------------------------------------------------------- +class BasicEntry(gtk.Entry): + + def __init__(self): + gtk.Entry.__init__(self) + self.set_width_chars(5) + self.show() diff --git a/src/gui/widgets/photo.py b/src/gui/widgets/photo.py index b90f33619..cd873ec0c 100644 --- a/src/gui/widgets/photo.py +++ b/src/gui/widgets/photo.py @@ -44,7 +44,7 @@ class Photo(gtk.EventBox): """ Displays an image and allows it to be viewed in an external image viewer. """ - def __init__(self): + def __init__(self, netbook_mode=False): gtk.EventBox.__init__(self) self.full_path = None self.photo = gtk.Image() @@ -53,6 +53,9 @@ class Photo(gtk.EventBox): tip = _('Double-click on the picture to view it in the default image ' 'viewer application.') self.set_tooltip_text(tip) + self.__size = ThumbNails.SIZE_LARGE + if netbook_mode: + self.__size = ThumbNails.SIZE_NORMAL def set_image(self, full_path, mime_type=None, rectangle=None): """ @@ -63,7 +66,7 @@ class Photo(gtk.EventBox): pixbuf = ThumbNails.get_thumbnail_image(full_path, mime_type, rectangle, - ThumbNails.SIZE_LARGE) + self.__size) self.photo.set_from_pixbuf(pixbuf) self.photo.show() else: diff --git a/src/plugins/gramplet/CalendarGramplet.py b/src/plugins/gramplet/CalendarGramplet.py index 45f853089..59318e02b 100644 --- a/src/plugins/gramplet/CalendarGramplet.py +++ b/src/plugins/gramplet/CalendarGramplet.py @@ -39,6 +39,8 @@ class CalendarGramplet(Gramplet): self.set_tooltip(_("Double-click a day for details")) self.gui.calendar = gtk.Calendar() self.gui.calendar.connect('day-selected-double-click', self.double_click) + if self.uistate.netbook_mode(): + self.gui.calendar.set_display_options(gtk.CALENDAR_SHOW_HEADING) self.gui.get_container_widget().remove(self.gui.textview) self.gui.get_container_widget().add_with_viewport(self.gui.calendar) self.gui.calendar.show() diff --git a/src/plugins/gramplet/Gallery.py b/src/plugins/gramplet/Gallery.py index 5f7619de5..01fa9c6a7 100644 --- a/src/plugins/gramplet/Gallery.py +++ b/src/plugins/gramplet/Gallery.py @@ -61,7 +61,7 @@ class Gallery(Gramplet): full_path = Utils.media_path_full(self.dbstate.db, media.get_path()) mime_type = media.get_mime_type() if mime_type and mime_type.startswith("image"): - photo = Photo() + photo = Photo(self.uistate.netbook_mode()) photo.set_image(full_path, mime_type, media_ref.get_rectangle()) self.image_list.append(photo) self.top.pack_start(photo, expand=False, fill=False) diff --git a/src/plugins/gramplet/MediaPreview.py b/src/plugins/gramplet/MediaPreview.py index 0c36d2923..9b15ec6ea 100644 --- a/src/plugins/gramplet/MediaPreview.py +++ b/src/plugins/gramplet/MediaPreview.py @@ -38,7 +38,7 @@ class MediaPreview(Gramplet): Build the GUI interface. """ self.top = gtk.HBox() - self.photo = Photo() + self.photo = Photo(self.uistate.netbook_mode()) self.top.pack_start(self.photo, fill=True, expand=False, padding=5) self.top.show_all() return self.top diff --git a/src/plugins/gramplet/PersonDetails.py b/src/plugins/gramplet/PersonDetails.py index 2995f6d14..42e7befae 100644 --- a/src/plugins/gramplet/PersonDetails.py +++ b/src/plugins/gramplet/PersonDetails.py @@ -45,7 +45,7 @@ class PersonDetails(Gramplet): """ self.top = gtk.HBox() vbox = gtk.VBox() - self.photo = Photo() + self.photo = Photo(self.uistate.netbook_mode()) self.photo.show() self.name = gtk.Label() self.name.set_alignment(0, 0) diff --git a/src/plugins/gramplet/PlaceDetails.py b/src/plugins/gramplet/PlaceDetails.py index 7c63a2743..8d61a63f2 100644 --- a/src/plugins/gramplet/PlaceDetails.py +++ b/src/plugins/gramplet/PlaceDetails.py @@ -42,7 +42,7 @@ class PlaceDetails(Gramplet): """ self.top = gtk.HBox() vbox = gtk.VBox() - self.photo = Photo() + self.photo = Photo(self.uistate.netbook_mode()) self.title = gtk.Label() self.title.set_alignment(0, 0) self.title.modify_font(pango.FontDescription('sans bold 12'))