9795: remember the last location of windows [bookmarks]
This commit is contained in:
parent
1b01e9d74e
commit
16f56fbbea
@ -50,6 +50,7 @@ from gi.repository import Gtk
|
|||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
from ..display import display_help
|
from ..display import display_help
|
||||||
from ..listmodel import ListModel
|
from ..listmodel import ListModel
|
||||||
|
from ..managedwindow import ManagedWindow
|
||||||
from gramps.gen.utils.db import navigation_label
|
from gramps.gen.utils.db import navigation_label
|
||||||
from gramps.gen.const import URL_MANUAL_PAGE
|
from gramps.gen.const import URL_MANUAL_PAGE
|
||||||
from gramps.gen.const import GRAMPS_LOCALE as glocale
|
from gramps.gen.const import GRAMPS_LOCALE as glocale
|
||||||
@ -98,14 +99,6 @@ class Bookmarks(metaclass=ABCMeta):
|
|||||||
self.dbstate.connect('database-changed', self.db_changed)
|
self.dbstate.connect('database-changed', self.db_changed)
|
||||||
self.dbstate.connect("no-database", self.undisplay)
|
self.dbstate.connect("no-database", self.undisplay)
|
||||||
|
|
||||||
# initialise attributes
|
|
||||||
self.namemodel = None
|
|
||||||
self.namemodel_cols = None
|
|
||||||
self.top = None
|
|
||||||
self.modified = None
|
|
||||||
self.response = None
|
|
||||||
self.namelist = None
|
|
||||||
|
|
||||||
def db_changed(self, data):
|
def db_changed(self, data):
|
||||||
"""
|
"""
|
||||||
Reconnect the signals on a database changed.
|
Reconnect the signals on a database changed.
|
||||||
@ -222,13 +215,50 @@ class Bookmarks(metaclass=ABCMeta):
|
|||||||
if modified:
|
if modified:
|
||||||
self.redraw_and_report_change()
|
self.redraw_and_report_change()
|
||||||
|
|
||||||
|
def edit(self):
|
||||||
|
"""
|
||||||
|
Display the bookmark editor.
|
||||||
|
|
||||||
|
The current bookmarked people are inserted into the namelist,
|
||||||
|
attaching the person object to the corresponding row. The currently
|
||||||
|
selected row is attached to the name list. This is either 0 if the
|
||||||
|
list is not empty, or -1 if it is.
|
||||||
|
"""
|
||||||
|
BookmarksDialog(self)
|
||||||
|
|
||||||
|
class BookmarksDialog(ManagedWindow):
|
||||||
|
"""
|
||||||
|
A dialog to enable the user to organize bookmarks.
|
||||||
|
"""
|
||||||
|
|
||||||
|
def __init__(self, bm_class):
|
||||||
|
|
||||||
|
self.bm_class = bm_class
|
||||||
|
self.bookmarks = bm_class.bookmarks
|
||||||
|
self.dbstate = bm_class.dbstate
|
||||||
|
self.make_label = bm_class.make_label
|
||||||
|
uistate = bm_class.uistate
|
||||||
|
|
||||||
|
self.namemodel = None
|
||||||
|
self.top = None
|
||||||
|
self.modified = None
|
||||||
|
self.response = None
|
||||||
|
self.namelist = None
|
||||||
|
|
||||||
|
ManagedWindow.__init__(self, uistate, [], self.__class__, modal=True)
|
||||||
|
# the self.top.run() below makes Gtk make it modal, so any change to
|
||||||
|
# the previous line's "modal" would require that line to be changed
|
||||||
|
|
||||||
|
self.draw_window()
|
||||||
|
self.set_window(self.top, None, _("Organize Bookmarks"))
|
||||||
|
self.setup_configs('interface.bookmarksdialog', 400, 350)
|
||||||
|
self.show()
|
||||||
|
self.edit()
|
||||||
|
self.close()
|
||||||
|
|
||||||
def draw_window(self):
|
def draw_window(self):
|
||||||
"""Draw the bookmark dialog box."""
|
"""Draw the bookmark dialog box."""
|
||||||
title = _("%(title)s - Gramps") % {'title': _("Organize Bookmarks")}
|
self.top = Gtk.Dialog(parent=self.parent_window)
|
||||||
self.top = Gtk.Dialog(title)
|
|
||||||
self.top.set_default_size(400, 350)
|
|
||||||
self.top.set_modal(True)
|
|
||||||
self.top.set_transient_for(self.uistate.window)
|
|
||||||
self.top.vbox.set_spacing(5)
|
self.top.vbox.set_spacing(5)
|
||||||
label = Gtk.Label(label='<span size="larger" weight="bold">%s</span>'
|
label = Gtk.Label(label='<span size="larger" weight="bold">%s</span>'
|
||||||
% _("Organize Bookmarks"))
|
% _("Organize Bookmarks"))
|
||||||
@ -240,7 +270,6 @@ class Bookmarks(metaclass=ABCMeta):
|
|||||||
name_titles = [(_('Name'), -1, 200), (_('ID'), -1, 50), ('', -1, 0)]
|
name_titles = [(_('Name'), -1, 200), (_('ID'), -1, 50), ('', -1, 0)]
|
||||||
self.namelist = Gtk.TreeView()
|
self.namelist = Gtk.TreeView()
|
||||||
self.namemodel = ListModel(self.namelist, name_titles)
|
self.namemodel = ListModel(self.namelist, name_titles)
|
||||||
self.namemodel_cols = len(name_titles)
|
|
||||||
|
|
||||||
slist = Gtk.ScrolledWindow()
|
slist = Gtk.ScrolledWindow()
|
||||||
slist.add(self.namelist)
|
slist.add(self.namelist)
|
||||||
@ -262,11 +291,6 @@ class Bookmarks(metaclass=ABCMeta):
|
|||||||
bbox.add(down)
|
bbox.add(down)
|
||||||
bbox.add(delete)
|
bbox.add(delete)
|
||||||
box.pack_start(bbox, 0, 0, 5)
|
box.pack_start(bbox, 0, 0, 5)
|
||||||
self.top.show_all()
|
|
||||||
|
|
||||||
def close(self, widget, event):
|
|
||||||
"""Stop the bookmark organizer"""
|
|
||||||
self.top.response(Gtk.ResponseType.CLOSE)
|
|
||||||
|
|
||||||
def edit(self):
|
def edit(self):
|
||||||
"""
|
"""
|
||||||
@ -277,7 +301,6 @@ class Bookmarks(metaclass=ABCMeta):
|
|||||||
selected row is attached to the name list. This is either 0 if the
|
selected row is attached to the name list. This is either 0 if the
|
||||||
list is not empty, or -1 if it is.
|
list is not empty, or -1 if it is.
|
||||||
"""
|
"""
|
||||||
self.draw_window()
|
|
||||||
for handle in self.bookmarks.get():
|
for handle in self.bookmarks.get():
|
||||||
name, obj = self.make_label(handle)
|
name, obj = self.make_label(handle)
|
||||||
if obj:
|
if obj:
|
||||||
@ -287,13 +310,14 @@ class Bookmarks(metaclass=ABCMeta):
|
|||||||
|
|
||||||
self.modified = False
|
self.modified = False
|
||||||
while True:
|
while True:
|
||||||
|
# the self.top.run() makes Gtk make it modal, so any change to that
|
||||||
|
# line would require the ManagedWindow.__init__ to be changed also
|
||||||
self.response = self.top.run()
|
self.response = self.top.run()
|
||||||
if self.response == Gtk.ResponseType.HELP:
|
if self.response == Gtk.ResponseType.HELP:
|
||||||
self.help_clicked()
|
self.help_clicked()
|
||||||
elif self.response == Gtk.ResponseType.CLOSE:
|
elif self.response == Gtk.ResponseType.CLOSE:
|
||||||
if self.modified:
|
if self.modified:
|
||||||
self.redraw_and_report_change()
|
self.bm_class.redraw_and_report_change()
|
||||||
self.top.destroy()
|
|
||||||
break
|
break
|
||||||
|
|
||||||
def delete_clicked(self, obj):
|
def delete_clicked(self, obj):
|
||||||
@ -329,6 +353,9 @@ class Bookmarks(metaclass=ABCMeta):
|
|||||||
"""Display the relevant portion of GRAMPS manual."""
|
"""Display the relevant portion of GRAMPS manual."""
|
||||||
display_help(webpage=WIKI_HELP_PAGE, section=WIKI_HELP_SEC)
|
display_help(webpage=WIKI_HELP_PAGE, section=WIKI_HELP_SEC)
|
||||||
|
|
||||||
|
def build_menu_names(self, obj): # this is meaningless while it's modal
|
||||||
|
return (_('Organize Bookmarks'), None)
|
||||||
|
|
||||||
class ListBookmarks(Bookmarks):
|
class ListBookmarks(Bookmarks):
|
||||||
""" Derived class from which all the specific type bookmark handlers are in
|
""" Derived class from which all the specific type bookmark handlers are in
|
||||||
turn derived"""
|
turn derived"""
|
||||||
|
Loading…
Reference in New Issue
Block a user