diff --git a/src/EditPerson.py b/src/EditPerson.py
index f01ad0118..e8a3ad6a0 100644
--- a/src/EditPerson.py
+++ b/src/EditPerson.py
@@ -1626,7 +1626,7 @@ class EditPerson:
def on_name_note_clicked(self,obj):
import NoteEdit
- NoteEdit.NoteEditor(self.pname,self.window)
+ NoteEdit.NoteEditor(self.pname,self,self.window)
def on_ldsbap_source_clicked(self,obj):
Sources.SourceSelector(self.lds_baptism.get_source_references(),
@@ -1638,7 +1638,7 @@ class EditPerson:
def on_ldsbap_note_clicked(self,obj):
import NoteEdit
- NoteEdit.NoteEditor(self.lds_baptism,self.window)
+ NoteEdit.NoteEditor(self.lds_baptism,self,self.window)
def on_ldsendow_source_clicked(self,obj):
Sources.SourceSelector(self.lds_endowment.get_source_references(),
@@ -1650,7 +1650,7 @@ class EditPerson:
def on_ldsendow_note_clicked(self,obj):
import NoteEdit
- NoteEdit.NoteEditor(self.lds_endowment,self.window)
+ NoteEdit.NoteEditor(self.lds_endowment,self,self.window)
def on_ldsseal_source_clicked(self,obj):
Sources.SourceSelector(self.lds_sealing.get_source_references(),
@@ -1662,7 +1662,7 @@ class EditPerson:
def on_ldsseal_note_clicked(self,obj):
import NoteEdit
- NoteEdit.NoteEditor(self.lds_sealing,self.window)
+ NoteEdit.NoteEditor(self.lds_sealing,self,self.window)
def load_person_image(self):
photo_list = self.person.get_photo_list()
diff --git a/src/NoteEdit.py b/src/NoteEdit.py
index e7cd3fb46..168c04b1f 100644
--- a/src/NoteEdit.py
+++ b/src/NoteEdit.py
@@ -1,7 +1,7 @@
#
# Gramps - a GTK+/GNOME based genealogy program
#
-# Copyright (C) 2000-2003 Donald N. Allingham
+# Copyright (C) 2000-2004 Donald N. Allingham
#
# 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
@@ -42,10 +42,12 @@ from gettext import gettext as _
#-------------------------------------------------------------------------
class NoteEditor:
"""Displays a simple text editor that allows a person to edit a note"""
- def __init__(self,data,parent_window=None):
+ def __init__(self,data,parent,parent_window=None):
self.data = data
self.parent_window = parent_window
+ self.child_windows = []
+ self.parent = parent
self.draw()
def draw(self):
@@ -57,8 +59,8 @@ class NoteEditor:
vbox = gtk.VBox()
self.top.vbox.pack_start(vbox,gtk.TRUE,gtk.TRUE,0)
- label = gtk.Label('%s' % _('Edit Note'))
- label.set_use_markup(gtk.TRUE)
+ label = gtk.Label('%s' % _('Edit Note'))
+ label.set_use_markup(gtk.TRUE)
vbox.pack_start(label, gtk.FALSE, gtk.FALSE, 10)
self.entry = gtk.TextView()
@@ -74,17 +76,39 @@ class NoteEditor:
self.entry.get_buffer().set_text(self.data.get_note())
- self.top.add_button(gtk.STOCK_CANCEL,1)
- self.top.add_button(gtk.STOCK_OK,0)
+ cancel_button = self.top.add_button(gtk.STOCK_CANCEL,1)
+ ok_button = self.top.add_button(gtk.STOCK_OK,0)
+ cancel_button.connect("clicked",self.close)
+ ok_button.connect("clicked",self.on_save_note_clicked)
+ self.top.connect("delete_event",self.on_delete_event)
self.top.show_all()
if self.parent_window:
self.top.set_transient_for(self.parent_window)
- if self.top.run() == 0:
- self.on_save_note_clicked()
- self.top.destroy()
+ self.parent.child_windows.append(self)
+ self.add_itself_to_menu()
+ self.top.show()
- def on_save_note_clicked(self):
+ def on_delete_event(self,obj,b):
+ self.remove_itself_from_menu()
+
+ def close(self,obj):
+ self.remove_itself_from_menu()
+ self.top.destroy()
+
+ def add_itself_to_menu(self):
+ self.parent_menu_item = gtk.MenuItem(_('Note'))
+ self.parent_menu_item.connect("activate",self.present)
+ self.parent_menu_item.show()
+ self.parent.menu.append(self.parent_menu_item)
+
+ def remove_itself_from_menu(self):
+ self.parent_menu_item.destroy()
+
+ def present(self,obj):
+ self.top.present()
+
+ def on_save_note_clicked(self,obj):
"""Saves the note and closes the window"""
buffer = self.entry.get_buffer()
text = unicode(buffer.get_text(buffer.get_start_iter(),
@@ -92,3 +116,4 @@ class NoteEditor:
if text != self.data.get_note():
self.data.set_note(text)
Utils.modified()
+ self.close(obj)