* src/AttrEdit.py: Make non-modal, use Windows menu.

* src/AddrEdit.py: Make non-modal, use Windows menu.
* src/UrlEdit.py: Make non-modal, use Windows menu.
* src/EventEdit.py: Properly add new event, add its id to the list.
Make non-modal, use Windows menu.
* src/NoteEdit.py: Make non-modal, use Windows menu.
* src/ImageSelect.py: Make non-modal, use Windows menu.
* src/imagesel.glade: Add handler.


svn: r2883
This commit is contained in:
Alex Roitman 2004-02-20 04:25:22 +00:00
parent 6d1afa704d
commit eceb502954
3 changed files with 59 additions and 9 deletions

View File

@ -8,6 +8,14 @@
* src/dialog.glade: Add handler. * src/dialog.glade: Add handler.
* src/srcsel.glade: Add handlers. * src/srcsel.glade: Add handlers.
* src/Sources.py: Make SourceInfo non-modal, use Windows menu. * src/Sources.py: Make SourceInfo non-modal, use Windows menu.
* src/AttrEdit.py: Make non-modal, use Windows menu.
* src/AddrEdit.py: Make non-modal, use Windows menu.
* src/UrlEdit.py: Make non-modal, use Windows menu.
* src/EventEdit.py: Properly add new event, add its id to the list.
Make non-modal, use Windows menu.
* src/NoteEdit.py: Make non-modal, use Windows menu.
* src/ImageSelect.py: Make non-modal, use Windows menu.
* src/imagesel.glade: Add handler.
2004-02-16 Alex Roitman <shura@alex.neuro.umn.edu> 2004-02-16 Alex Roitman <shura@alex.neuro.umn.edu>
* src/Relationship.py: Factor out relationship distance computation. * src/Relationship.py: Factor out relationship distance computation.

View File

@ -52,6 +52,7 @@ class SourceSelector:
self.parent = parent self.parent = parent
self.orig = srclist self.orig = srclist
self.list = [] self.list = []
self.child_windows = []
for s in self.orig: for s in self.orig:
self.list.append(RelLib.SourceRef(s)) self.list.append(RelLib.SourceRef(s))
self.update=update self.update=update
@ -66,6 +67,9 @@ class SourceSelector:
"on_del_src_clicked" : self.del_src_clicked, "on_del_src_clicked" : self.del_src_clicked,
"on_edit_src_clicked" : self.edit_src_clicked, "on_edit_src_clicked" : self.edit_src_clicked,
"on_help_srcsel_clicked" : self.on_help_clicked, "on_help_srcsel_clicked" : self.on_help_clicked,
"on_cancel_srcsel_clicked" : self.close,
"on_ok_srcsel_clicked" : self.src_ok_clicked,
"on_srcsel_delete_event" : self.on_delete_event,
}) })
self.slist = self.top.get_widget("slist") self.slist = self.top.get_widget("slist")
@ -94,17 +98,47 @@ class SourceSelector:
self.redraw() self.redraw()
if self.parent: if self.parent:
self.window.set_transient_for(self.parent.window) self.window.set_transient_for(self.parent.window)
self.parent.child_windows.append(self)
self.add_itself_to_menu()
self.window.show() self.window.show()
self.val = self.window.run()
if self.val == gtk.RESPONSE_OK: def on_delete_event(self,obj,b):
self.src_ok_clicked() self.close_child_windows()
self.remove_itself_from_menu()
def close(self,obj):
self.close_child_windows()
self.remove_itself_from_menu()
self.window.destroy() self.window.destroy()
def close_child_windows(self):
for child_window in self.child_windows:
child_window.close(None)
self.child_windows = []
def add_itself_to_menu(self):
label = _('Source Reference')
self.parent_menu_item = gtk.MenuItem(label)
self.parent_menu_item.set_submenu(gtk.Menu())
self.parent_menu_item.show()
self.parent.menu.append(self.parent_menu_item)
self.menu = self.parent_menu_item.get_submenu()
self.menu_item = gtk.MenuItem(_('Reference Selector'))
self.menu_item.connect("activate",self.present)
self.menu_item.show()
self.menu.append(self.menu_item)
def remove_itself_from_menu(self):
self.menu_item.destroy()
self.menu.destroy()
self.parent_menu_item.destroy()
def present(self,obj):
self.window.present()
def on_help_clicked(self,obj): def on_help_clicked(self,obj):
"""Display the relevant portion of GRAMPS manual""" """Display the relevant portion of GRAMPS manual"""
gnome.help_display('gramps-manual','gramps-edit-complete') gnome.help_display('gramps-manual','gramps-edit-complete')
self.val = self.window.run()
def selection_changed(self,obj): def selection_changed(self,obj):
(store,iter) = self.selection.get_selected() (store,iter) = self.selection.get_selected()
@ -123,12 +157,13 @@ class SourceSelector:
iter = self.model.append() iter = self.model.append()
self.model.set(iter,0,base_id,1,base.get_title()) self.model.set(iter,0,base_id,1,base.get_title())
def src_ok_clicked(self): def src_ok_clicked(self,obj):
del self.orig[:] del self.orig[:]
for s in self.list: for s in self.list:
self.orig.append(s) self.orig.append(s)
if self.update: if self.update:
self.update(self.orig) self.update(self.orig)
self.close(obj)
def edit_src_clicked(self,obj): def edit_src_clicked(self,obj):
store,iter = self.selection.get_selected() store,iter = self.selection.get_selected()
@ -248,6 +283,10 @@ class SourceEditor:
self.update = update self.update = update
self.source_ref = srcref self.source_ref = srcref
self.child_windows = [] self.child_windows = []
if self.parent.__dict__.has_key('child_windows'):
self.win_parent = self.parent
else:
self.win_parent = self.parent.parent
self.showSource = gtk.glade.XML(const.srcselFile, "sourceDisplay","gramps") self.showSource = gtk.glade.XML(const.srcselFile, "sourceDisplay","gramps")
self.sourceDisplay = self.get_widget("sourceDisplay") self.sourceDisplay = self.get_widget("sourceDisplay")
@ -286,13 +325,13 @@ class SourceEditor:
self.set_button() self.set_button()
if self.parent: if self.parent:
self.sourceDisplay.set_transient_for(self.parent.window) self.sourceDisplay.set_transient_for(self.parent.window)
self.parent.parent.child_windows.append(self) self.win_parent.child_windows.append(self)
self.add_itself_to_menu() self.add_itself_to_menu()
self.sourceDisplay.show() self.sourceDisplay.show()
def on_delete_event(self,obj,b): def on_delete_event(self,obj,b):
self.close_child_windows() self.close_child_windows()
self.parent.parent.child_windows.remove(self) self.win_parent.child_windows.remove(self)
self.remove_itself_from_menu() self.remove_itself_from_menu()
def close(self,obj): def close(self,obj):
@ -316,7 +355,7 @@ class SourceEditor:
self.parent_menu_item = gtk.MenuItem(label) self.parent_menu_item = gtk.MenuItem(label)
self.parent_menu_item.set_submenu(gtk.Menu()) self.parent_menu_item.set_submenu(gtk.Menu())
self.parent_menu_item.show() self.parent_menu_item.show()
self.parent.parent.menu.append(self.parent_menu_item) self.win_parent.menu.append(self.parent_menu_item)
self.menu = self.parent_menu_item.get_submenu() self.menu = self.parent_menu_item.get_submenu()
self.menu_item = gtk.MenuItem(_('Source Information')) self.menu_item = gtk.MenuItem(_('Source Information'))
self.menu_item.connect("activate",self.present) self.menu_item.connect("activate",self.present)

View File

@ -738,6 +738,7 @@
<property name="destroy_with_parent">False</property> <property name="destroy_with_parent">False</property>
<property name="icon">gramps.png</property> <property name="icon">gramps.png</property>
<property name="has_separator">False</property> <property name="has_separator">False</property>
<signal name="delete_event" handler="on_srcsel_delete_event" last_modification_time="Fri, 20 Feb 2004 04:09:31 GMT"/>
<child internal-child="vbox"> <child internal-child="vbox">
<widget class="GtkVBox" id="dialog-vbox18"> <widget class="GtkVBox" id="dialog-vbox18">
@ -759,6 +760,7 @@
<property name="use_stock">True</property> <property name="use_stock">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property> <property name="relief">GTK_RELIEF_NORMAL</property>
<property name="response_id">-6</property> <property name="response_id">-6</property>
<signal name="clicked" handler="on_cancel_srcsel_clicked" last_modification_time="Fri, 20 Feb 2004 04:09:00 GMT"/>
</widget> </widget>
</child> </child>
@ -771,6 +773,7 @@
<property name="use_stock">True</property> <property name="use_stock">True</property>
<property name="relief">GTK_RELIEF_NORMAL</property> <property name="relief">GTK_RELIEF_NORMAL</property>
<property name="response_id">-5</property> <property name="response_id">-5</property>
<signal name="clicked" handler="on_ok_srcsel_clicked" last_modification_time="Fri, 20 Feb 2004 04:09:14 GMT"/>
</widget> </widget>
</child> </child>