diff --git a/src/ImageSelect.py b/src/ImageSelect.py index c932aa7b3..d6f99e223 100644 --- a/src/ImageSelect.py +++ b/src/ImageSelect.py @@ -130,25 +130,37 @@ class ImageSelect: GnomeErrorDialog(_("That is not a valid file name.")); return - type = utils.get_mime_type(filename) - mobj = Photo() - if description == "": - description = os.path.basename(filename) - mobj.setDescription(description) - mobj.setMimeType(type) - self.savephoto(mobj) + already_imported = None + for o in self.db.getObjectMap().values(): + if o.getPath() == filename: + already_imported = o + break - if type[0:5] == "image": - if self.external.get_active() == 0: - name = RelImage.import_media_object(filename,self.path,mobj.getId()) + if (already_imported): + oref = ObjectRef() + oref.setReference(already_imported) + self.dataobj.addPhoto(oref) + self.add_thumbnail(oref) else: - if self.external.get_active() == 1: - name = filename - RelImage.mk_thumb(filename,self.path,mobj.getId()) - else: - name = RelImage.import_media_object(filename,self.path,mobj.getId()) + type = utils.get_mime_type(filename) + mobj = Photo() + if description == "": + description = os.path.basename(filename) + mobj.setDescription(description) + mobj.setMimeType(type) + self.savephoto(mobj) - mobj.setPath(name) + if type[0:5] == "image": + if self.external.get_active() == 0: + name = RelImage.import_media_object(filename,self.path,mobj.getId()) + else: + if self.external.get_active() == 1: + name = filename + RelImage.mk_thumb(filename,self.path,mobj.getId()) + else: + name = RelImage.import_media_object(filename,self.path,mobj.getId()) + + mobj.setPath(name) utils.modified() utils.destroy_passed_object(obj) @@ -211,8 +223,6 @@ class Gallery(ImageSelect): oref = ObjectRef() oref.setReference(photo) self.dataobj.addPhoto(oref) - dest = "%s/.thumb/%s.jpg" % (self.db.getSavePath(),photo.getId()) - RelImage.mk_thumb(photo.getPath(),dest,const.thumbScale) self.add_thumbnail(oref) #------------------------------------------------------------------------- diff --git a/src/PlaceView.py b/src/PlaceView.py index e12bf2e8c..8144535e9 100644 --- a/src/PlaceView.py +++ b/src/PlaceView.py @@ -55,17 +55,17 @@ class PlaceView: self.place_list.set_column_visibility(10,0) self.place_list.set_column_visibility(11,0) self.place_list.set_column_visibility(12,0) - self.place_list.set_column_visibility(13,0) self.place_list.connect('button-press-event',self.on_button_press_event) self.place_list.connect('select-row',self.select_row) self.active = None + self.sort_map = [7,1,8,9,10,11,12] # Restore the previous sort column self.sort_col,self.sort_dir = Config.get_sort_cols("place",0,GTK.SORT_ASCENDING) - self.place_list.set_sort_column(self.sort_col+7) - self.place_list.set_sort_type(self.sort_dir) self.set_arrow(self.sort_col) + self.place_list.set_sort_column(self.sort_map[self.sort_col]) + self.place_list.set_sort_type(self.sort_dir) def load_places(self): if len(self.place_list.selection) == 0: @@ -92,7 +92,7 @@ class PlaceView: parish = mloc.get_parish() country = mloc.get_country() self.place_list.append([title,id,parish,city,county,state,country, - u(title), u(id), u(parish), u(city), + u(title), u(parish), u(city), u(county),u(state), u(country)]) self.place_list.set_row_data(index,src) index = index + 1 @@ -159,7 +159,7 @@ class PlaceView: self.sort_col = column self.set_arrow(column) self.place_list.set_sort_type(self.sort_direct) - self.place_list.set_sort_column(self.sort_col + 7) + self.place_list.set_sort_column(self.sort_map[self.sort_col]) Config.save_sort_cols("place",self.sort_col,self.sort_direct) self.place_list.sort() diff --git a/src/RelImage.py b/src/RelImage.py index 20d3c7590..10fdb2e56 100644 --- a/src/RelImage.py +++ b/src/RelImage.py @@ -80,6 +80,7 @@ def import_media_object(filename,path,base): try: path = "%s/%s" % (thumb,base) + print filename,path,const.thumbScale mk_thumb(filename,path,const.thumbScale) shutil.copy(filename,name) except: diff --git a/src/SourceView.py b/src/SourceView.py index 8737a9d3d..d58020b5b 100644 --- a/src/SourceView.py +++ b/src/SourceView.py @@ -69,16 +69,20 @@ class SourceView: self.sort_arrow = [self.title_arrow, self.id_arrow, self.author_arrow] self.source_list.connect('click-column',self.click_column) - self.sort_col,self.sort_dir = Config.get_sort_cols("source",3,GTK.SORT_ASCENDING) + if self.sort_col >= len(self.sort_arrow): + self.sort_col = 0 + self.source_list.set_sort_type(self.sort_dir) self.source_list.set_sort_column(self.sort_map[self.sort_col]) self.set_arrow(self.sort_col) def set_arrow(self,column): + for a in self.sort_arrow: a.hide() + print column a = self.sort_arrow[column] a.show() if self.sort_dir == GTK.SORT_ASCENDING: diff --git a/src/gramps.glade b/src/gramps.glade index e0b37eaf7..dedfd452f 100644 --- a/src/gramps.glade +++ b/src/gramps.glade @@ -1275,6 +1275,45 @@ 0 + + GtkScrolledWindow + scrolledwindow28 + GTK_POLICY_AUTOMATIC + GTK_POLICY_AUTOMATIC + GTK_UPDATE_CONTINUOUS + GTK_UPDATE_CONTINUOUS + + + GnomeCanvas + canvas1 + True + + event + on_canvas1_event + Sun, 02 Sep 2001 21:58:31 GMT + + False + 0 + 0 + 100 + 100 + 1 + + + + + GtkLabel + Notebook:tab + label237 + + GTK_JUSTIFY_CENTER + False + 0.5 + 0.5 + 0 + 0 + + GtkVBox vbox2 @@ -2306,45 +2345,6 @@ 0 - - GtkScrolledWindow - scrolledwindow28 - GTK_POLICY_AUTOMATIC - GTK_POLICY_AUTOMATIC - GTK_UPDATE_CONTINUOUS - GTK_UPDATE_CONTINUOUS - - - GnomeCanvas - canvas1 - True - - event - on_canvas1_event - Sun, 02 Sep 2001 21:58:31 GMT - - False - 0 - 0 - 100 - 100 - 1 - - - - - GtkLabel - Notebook:tab - label237 - - GTK_JUSTIFY_CENTER - False - 0.5 - 0.5 - 0 - 0 - - GtkVBox vbox33 @@ -2379,7 +2379,7 @@ Thu, 31 May 2001 17:22:45 GMT 5 - 293,60,344,5,5 + 293,61,306,5,5 GTK_SELECTION_SINGLE True GTK_SHADOW_IN @@ -2683,8 +2683,8 @@ on_place_list_click_column Tue, 30 Oct 2001 18:18:53 GMT - 14 - 222,47,102,88,77,80,5,5,5,5,5,5,5,5 + 13 + 213,47,107,88,77,80,29,1,1,1,1,1,1 GTK_SELECTION_EXTENDED True GTK_SHADOW_IN @@ -3087,19 +3087,6 @@ - - GtkLabel - CList:title - label276 - - GTK_JUSTIFY_CENTER - False - 0.5 - 0.5 - 0 - 0 - - GtkLabel CList:title @@ -3628,7 +3615,7 @@ GtkLabel label266 - + GTK_JUSTIFY_CENTER False 1 diff --git a/src/plugins/ReadGedcom.py b/src/plugins/ReadGedcom.py index e18a3e957..a30a95bab 100644 --- a/src/plugins/ReadGedcom.py +++ b/src/plugins/ReadGedcom.py @@ -184,6 +184,12 @@ class GedcomParser: self.error_count = 0 self.error_text_obj.set_point(0) self.error_text_obj.set_word_wrap(0) + + map = const.personalConstantAttributes + self.attrs = map.values() + self.gedattr = {} + for val in map.keys(): + self.gedattr[map[val]] = val self.update(self.file_obj,file) self.code = 0 @@ -563,23 +569,33 @@ class GedcomParser: elif matches[1] == "EVEN": event = Event() self.parse_person_event(event,2) - if string.strip(event.getName()) == "SSN": + n = string.strip(event.getName()) + if n in self.attrs: attr = Attribute() - attr.setType("Social Security Number") + attr.setType(self.gedattr[n]) attr.setValue(event.getDescription()) self.person.addAttribute(attr) else: self.person.addEvent(event) else: event = Event() - try: - event.setName(ged2gramps[matches[1]]) - except: + n = string.strip(matches[1]) + if ged2gramps.has_key(n): + event.setName(ged2gramps[n]) + elif self.gedattr.has_key(n): + attr = Attribute() + attr.setType(self.gedattr[n]) + attr.setValue(event.getDescription()) + self.person.addAttribute(attr) + self.parse_person_attr(attr,2) + continue + else: event.setName(matches[1]) + + self.parse_person_event(event,2) if matches[2] != None: event.setDescription(matches[2]) self.person.addEvent(event) - self.parse_person_event(event,2) def parse_optional_note(self,level): note = "" @@ -882,6 +898,54 @@ class GedcomParser: else: self.barf(level+1) + def parse_person_attr(self,attr,level): + note = "" + while 1: + matches = self.get_next() + if int(matches[0]) < level: + self.backup() + break + elif matches[1] == "TYPE": + if attr.getType() == "": + if ged2gramps.has_key(matches[2]): + name = ged2gramps[matches[2]] + else: + name = matches[2] + attr.setName(name) + elif matches[1] == ["CAUS", "DATE","TIME","ADDR","AGE","AGNC","STAT","TEMP","OBJE"]: + self.ignore_sub_junk(level+1) + elif matches[1] == "SOUR": + source_ref = SourceRef() + if matches[2] and matches[2][0] != "@": + self.localref = self.localref + 1 + ref = "gsr%d" % self.localref + s = self.db.findSource(ref,self.smap) + source_ref.setBase(s) + s.setTitle('Imported Source #%d' % self.localref) + s.setNote(matches[2] + self.parse_continue_data(1)) + self.ignore_sub_junk(2) + else: + source_ref.setBase(self.db.findSource(matches[2],self.smap)) + self.parse_source_reference(source_ref,level+1) + attr.addSourceRef(source_ref) + elif matches[1] == "PLAC": + val = matches[2] + if attr.getValue() == "": + attr.setValue(val) + self.ignore_sub_junk(level+1) + elif matches[1] == "NOTE": + info = matches[2] + self.parse_continue_data(level+1) + if note == "": + note = info + else: + note = "\n%s" % info + elif matches[1] == "CONC": + attr.setValue( "%s %s" % (attr.getValue(), matches[2])) + elif matches[1] == "CONT": + attr.setValue("%s\n%s" % (attr.getValue(),matches[2])) + else: + self.barf(level+1) + def parse_family_event(self,event,level): global ged2fam global ged2gramps