Autosave and thumbnail improvements

svn: r672
This commit is contained in:
Don Allingham 2002-01-01 05:25:08 +00:00
parent 6d1524ef3e
commit cf826fdeb4
6 changed files with 125 additions and 117 deletions

View File

@ -151,10 +151,10 @@ class AddressEditor:
self.addr.setDate(date) self.addr.setDate(date)
self.parent.lists_changed = 1 self.parent.lists_changed = 1
self.check(self.addr.getDate,self.addr.setDate,state)
self.check(self.addr.getStreet,self.addr.setStreet,street) self.check(self.addr.getStreet,self.addr.setStreet,street)
self.check(self.addr.getCountry,self.addr.setCountry,country) self.check(self.addr.getCountry,self.addr.setCountry,country)
self.check(self.addr.getCity,self.addr.setCity,city) self.check(self.addr.getCity,self.addr.setCity,city)
self.check(self.addr.getState,self.addr.setState,state)
self.check(self.addr.getPostal,self.addr.setPostal,postal) self.check(self.addr.getPostal,self.addr.setPostal,postal)
self.check(self.addr.getNote,self.addr.setNote,note) self.check(self.addr.getNote,self.addr.setNote,note)
self.check(self.addr.getPrivacy,self.addr.setPrivacy,priv) self.check(self.addr.getPrivacy,self.addr.setPrivacy,priv)

View File

@ -94,8 +94,7 @@ sprefix = "S"
pprefix = "P" pprefix = "P"
fprefix = "F" fprefix = "F"
autoload = 0 autoload = 0
autosave = 0 autosave_int = 0
autosave_int = 5
usetabs = 0 usetabs = 0
uselds = 0 uselds = 0
autocomp = 1 autocomp = 1
@ -164,7 +163,6 @@ def make_path(path):
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def loadConfig(call): def loadConfig(call):
global autoload global autoload
global autosave
global autosave_int global autosave_int
global owner global owner
global usetabs global usetabs
@ -225,7 +223,6 @@ def loadConfig(call):
hide_altnames = get_bool("/gramps/config/DisplayAltNames") hide_altnames = get_bool("/gramps/config/DisplayAltNames")
autoload = get_bool("/gramps/config/autoLoad") autoload = get_bool("/gramps/config/autoLoad")
autosave = get_bool("/gramps/config/autoSave")
autosave_int = get_int("/gramps/config/autoSaveInterval") autosave_int = get_int("/gramps/config/autoSaveInterval")
dateFormat = get_int("/gramps/config/dateFormat") dateFormat = get_int("/gramps/config/dateFormat")
dateEntry = get_int("/gramps/config/dateEntry") dateEntry = get_int("/gramps/config/dateEntry")
@ -304,10 +301,8 @@ def loadConfig(call):
if autoload == None: if autoload == None:
autoload = 1 autoload = 1
if autosave == None:
autosave = 0
if autosave_int == None: if autosave_int == None:
autosave = 5 autosave_int = 0
if mediaref == None: if mediaref == None:
mediaref = 1 mediaref = 1
if globalprop == None: if globalprop == None:
@ -469,10 +464,9 @@ def on_propertybox_apply(obj,page):
if page != -1: if page != -1:
return return
show_detail = prefsTop.get_widget("showdetail").get_active() show_detail = prefsTop.get_widget("showdetail").get_active()
autoload = prefsTop.get_widget("autoload").get_active() autoload = prefsTop.get_widget("autoload").get_active()
autosave = prefsTop.get_widget("save_enable").get_active()
autosave_int = prefsTop.get_widget("save_interval").get_value_as_int() autosave_int = prefsTop.get_widget("save_interval").get_value_as_int()
display_attr = prefsTop.get_widget("attr_display").get_active() display_attr = prefsTop.get_widget("attr_display").get_active()
attr_name = string.strip(prefsTop.get_widget("attr_name").get_text()) attr_name = string.strip(prefsTop.get_widget("attr_name").get_text())
@ -559,9 +553,9 @@ def on_propertybox_apply(obj,page):
set_string("/gramps/config/paperPreference",paper_preference) set_string("/gramps/config/paperPreference",paper_preference)
set_string("/gramps/config/outputPreference",output_preference) set_string("/gramps/config/outputPreference",output_preference)
set_bool("/gramps/config/autoLoad",autoload) set_bool("/gramps/config/autoLoad",autoload)
set_bool("/gramps/config/autoSave",autosave)
set_int("/gramps/config/autoSaveInterval",autosave_int) set_int("/gramps/config/autoSaveInterval",autosave_int)
if autosave and autosave_int != 0:
if autosave_int != 0:
utils.enable_autosave(None,autosave_int) utils.enable_autosave(None,autosave_int)
else: else:
utils.disable_autosave() utils.disable_autosave()
@ -711,7 +705,6 @@ def display_preferences_box(db):
pbox = prefsTop.get_widget("propertybox") pbox = prefsTop.get_widget("propertybox")
pbox.set_data("db",db) pbox.set_data("db",db)
auto = prefsTop.get_widget("autoload") auto = prefsTop.get_widget("autoload")
asave = prefsTop.get_widget("save_enable")
asave_int = prefsTop.get_widget("save_interval") asave_int = prefsTop.get_widget("save_interval")
vis = prefsTop.get_widget("gid_visible") vis = prefsTop.get_widget("gid_visible")
idedit = prefsTop.get_widget("gid_edit") idedit = prefsTop.get_widget("gid_edit")
@ -731,7 +724,6 @@ def display_preferences_box(db):
display_attr_obj = prefsTop.get_widget("attr_display") display_attr_obj = prefsTop.get_widget("attr_display")
display_altnames = prefsTop.get_widget("display_altnames") display_altnames = prefsTop.get_widget("display_altnames")
auto.set_active(autoload) auto.set_active(autoload)
asave.set_active(autosave)
asave_int.set_value(autosave_int) asave_int.set_value(autosave_int)
detail.set_active(show_detail) detail.set_active(show_detail)
tabs.set_active(usetabs) tabs.set_active(usetabs)

View File

@ -34,6 +34,7 @@ import string
import GDK import GDK
import GTK import GTK
import gtk import gtk
import GdkImlib
import gnome.ui import gnome.ui
import libglade import libglade
@ -73,11 +74,16 @@ class ImageSelect:
self.path = path; self.path = path;
self.db = db self.db = db
self.dataobj = None self.dataobj = None
self.icon_cache = []
def add_thumbnail(self, photo): def add_thumbnail(self, photo):
"should be overrridden" "should be overrridden"
pass pass
def load_images(self):
"should be overrridden"
pass
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# create_add_dialog - Create the gnome dialog for selecting a new # create_add_dialog - Create the gnome dialog for selecting a new
@ -156,7 +162,7 @@ class ImageSelect:
mobj = Photo() mobj = Photo()
if description == "": if description == "":
description = os.path.basename(filename) description = os.path.basename(filename)
mobj.setDescription(description) mobj.setDescription(description)
mobj.setMimeType(type) mobj.setMimeType(type)
self.savephoto(mobj) self.savephoto(mobj)
@ -166,14 +172,13 @@ class ImageSelect:
else: else:
if self.external.get_active() == 1: if self.external.get_active() == 1:
name = filename name = filename
RelImage.mk_thumb(filename,self.path,mobj.getId())
else: else:
name = RelImage.import_media_object(filename,self.path,mobj.getId()) name = RelImage.import_media_object(filename,self.path,mobj.getId())
mobj.setPath(name) mobj.setPath(name)
utils.modified() utils.modified()
utils.destroy_passed_object(obj) utils.destroy_passed_object(obj)
self.load_images()
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -241,8 +246,10 @@ class Gallery(ImageSelect):
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def add_thumbnail(self, photo): def add_thumbnail(self, photo):
object = photo.getReference() object = photo.getReference()
thumb = utils.thumb_path(self.db.getSavePath(),object) name = utils.thumb_path(self.db.getSavePath(),object)
self.icon_list.append(thumb,object.getDescription()) thumb = GdkImlib.Image(name)
self.icon_cache.append(thumb)
self.icon_list.append_imlib(thumb,object.getDescription())
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -254,6 +261,7 @@ class Gallery(ImageSelect):
def load_images(self): def load_images(self):
self.icon_list.freeze() self.icon_list.freeze()
self.icon_list.clear() self.icon_list.clear()
self.icon_cache = []
for photo in self.dataobj.getPhotoList(): for photo in self.dataobj.getPhotoList():
self.add_thumbnail(photo) self.add_thumbnail(photo)
self.icon_list.thaw() self.icon_list.thaw()

View File

@ -82,6 +82,7 @@ def import_media_object(filename,path,base):
try: try:
path = "%s/%s" % (thumb,base) path = "%s/%s" % (thumb,base)
print "Making",path,"from",filename
mk_thumb(filename,path,const.thumbScale) mk_thumb(filename,path,const.thumbScale)
shutil.copy(filename,name) shutil.copy(filename,name)
except: except:
@ -122,6 +123,8 @@ def scale_image(path,size):
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def mk_thumb(source,dest,size): def mk_thumb(source,dest,size):
print "making a thumbnail",source,dest
dir = os.path.dirname(dest) dir = os.path.dirname(dest)
try: try:
if not os.path.exists(dir): if not os.path.exists(dir):
@ -133,8 +136,12 @@ def mk_thumb(source,dest,size):
GnomeErrorDialog(_("Could not create %s") % dir) GnomeErrorDialog(_("Could not create %s") % dir)
return return
if os.path.exists(dest):
os.remove(dest)
if no_pil: if no_pil:
cmd = "%s -geometry %dx%d '%s' '%s'" % (const.convert,size,size,source,dest) cmd = "%s -geometry %dx%d '%s' '%s'" % (const.convert,size,size,source,dest)
print cmd
os.system(cmd) os.system(cmd)
else: else:
try: try:
@ -144,7 +151,9 @@ def mk_thumb(source,dest,size):
im.draft('RGB',im.size) im.draft('RGB',im.size)
im = im.convert("RGB") im = im.convert("RGB")
im.save(dest,"JPEG") im.save(dest,"JPEG")
print "saving",dest
except: except:
print "save failed"
pass pass
#------------------------------------------------------------------------- #-------------------------------------------------------------------------

View File

@ -152,99 +152,6 @@
</widget> </widget>
</widget> </widget>
<widget>
<class>GtkLabel</class>
<name>label217</name>
<label>Autosave interval (minutes)</label>
<justify>GTK_JUSTIFY_CENTER</justify>
<wrap>False</wrap>
<xalign>1</xalign>
<yalign>0.5</yalign>
<xpad>0</xpad>
<ypad>0</ypad>
<child>
<left_attach>1</left_attach>
<right_attach>2</right_attach>
<top_attach>2</top_attach>
<bottom_attach>3</bottom_attach>
<xpad>0</xpad>
<ypad>0</ypad>
<xexpand>False</xexpand>
<yexpand>False</yexpand>
<xshrink>False</xshrink>
<yshrink>False</yshrink>
<xfill>True</xfill>
<yfill>False</yfill>
</child>
</widget>
<widget>
<class>GtkCheckButton</class>
<name>save_enable</name>
<can_focus>True</can_focus>
<signal>
<name>toggled</name>
<handler>on_object_toggled</handler>
<object>propertybox</object>
<last_modification_time>Mon, 24 Dec 2001 23:25:36 GMT</last_modification_time>
</signal>
<label>Enable Autosaving</label>
<active>False</active>
<draw_indicator>True</draw_indicator>
<child>
<left_attach>0</left_attach>
<right_attach>1</right_attach>
<top_attach>2</top_attach>
<bottom_attach>3</bottom_attach>
<xpad>3</xpad>
<ypad>3</ypad>
<xexpand>False</xexpand>
<yexpand>False</yexpand>
<xshrink>False</xshrink>
<yshrink>False</yshrink>
<xfill>True</xfill>
<yfill>False</yfill>
</child>
</widget>
<widget>
<class>GtkSpinButton</class>
<name>save_interval</name>
<can_focus>True</can_focus>
<signal>
<name>changed</name>
<handler>on_object_changed</handler>
<object>propertybox</object>
<last_modification_time>Mon, 24 Dec 2001 23:25:52 GMT</last_modification_time>
</signal>
<climb_rate>1</climb_rate>
<digits>0</digits>
<numeric>True</numeric>
<update_policy>GTK_UPDATE_IF_VALID</update_policy>
<snap>True</snap>
<wrap>False</wrap>
<value>5</value>
<lower>0</lower>
<upper>100</upper>
<step>1</step>
<page>10</page>
<page_size>10</page_size>
<child>
<left_attach>2</left_attach>
<right_attach>3</right_attach>
<top_attach>2</top_attach>
<bottom_attach>3</bottom_attach>
<xpad>3</xpad>
<ypad>3</ypad>
<xexpand>False</xexpand>
<yexpand>False</yexpand>
<xshrink>False</xshrink>
<yshrink>False</yshrink>
<xfill>True</xfill>
<yfill>False</yfill>
</child>
</widget>
<widget> <widget>
<class>GtkCheckButton</class> <class>GtkCheckButton</class>
<name>autoload</name> <name>autoload</name>
@ -302,6 +209,70 @@
<yfill>False</yfill> <yfill>False</yfill>
</child> </child>
</widget> </widget>
<widget>
<class>GtkLabel</class>
<name>label217</name>
<label>Autosave interval (minutes)</label>
<justify>GTK_JUSTIFY_CENTER</justify>
<wrap>False</wrap>
<xalign>1</xalign>
<yalign>0.5</yalign>
<xpad>0</xpad>
<ypad>0</ypad>
<child>
<left_attach>0</left_attach>
<right_attach>1</right_attach>
<top_attach>2</top_attach>
<bottom_attach>3</bottom_attach>
<xpad>0</xpad>
<ypad>0</ypad>
<xexpand>False</xexpand>
<yexpand>False</yexpand>
<xshrink>False</xshrink>
<yshrink>False</yshrink>
<xfill>True</xfill>
<yfill>False</yfill>
</child>
</widget>
<widget>
<class>GtkSpinButton</class>
<name>save_interval</name>
<can_focus>True</can_focus>
<signal>
<name>changed</name>
<handler>on_object_toggled</handler>
<object>propertybox</object>
<last_modification_time>Mon, 31 Dec 2001 16:51:59 GMT</last_modification_time>
</signal>
<climb_rate>1</climb_rate>
<digits>0</digits>
<numeric>True</numeric>
<update_policy>GTK_UPDATE_IF_VALID</update_policy>
<snap>True</snap>
<wrap>False</wrap>
<value>0</value>
<lower>0</lower>
<upper>100</upper>
<step>1</step>
<page>10</page>
<page_size>10</page_size>
<child>
<left_attach>1</left_attach>
<right_attach>2</right_attach>
<top_attach>2</top_attach>
<bottom_attach>3</bottom_attach>
<xpad>3</xpad>
<ypad>3</ypad>
<xexpand>False</xexpand>
<yexpand>False</yexpand>
<xshrink>False</xshrink>
<yshrink>False</yshrink>
<xfill>True</xfill>
<yfill>False</yfill>
</child>
</widget>
</widget> </widget>
</widget> </widget>

View File

@ -504,6 +504,9 @@ def on_reports_clicked(obj):
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
def on_ok_button1_clicked(obj): def on_ok_button1_clicked(obj):
global yname
global nname
dbname = obj.get_data("dbname") dbname = obj.get_data("dbname")
getoldrev = obj.get_data("getoldrev") getoldrev = obj.get_data("getoldrev")
filename = dbname.get_full_path(0) filename = dbname.get_full_path(0)
@ -517,9 +520,32 @@ def on_ok_button1_clicked(obj):
if getoldrev.get_active(): if getoldrev.get_active():
vc = VersionControl.RcsVersionControl(filename) vc = VersionControl.RcsVersionControl(filename)
VersionControl.RevisionSelect(database,filename,vc,load_revision) VersionControl.RevisionSelect(database,filename,vc,load_revision)
else:
auto_save_load(filename)
def auto_save_load(filename):
global yname, nname
if os.path.isdir(filename):
dirname = filename
else:
dirname = os.path.dirname(filename)
autosave = "%s/autosave.gramps" % dirname
if os.path.isfile(autosave):
q = _("An autosave file exists. Should this be loaded instead of the last saved version?")
yname = autosave
nname = filename
gnome.ui.GnomeQuestionDialog(q,autosave_query)
else: else:
read_file(filename) read_file(filename)
def autosave_query(value):
if value == 0:
read_file(yname)
else:
read_file(nname)
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# #
@ -529,6 +555,8 @@ def read_file(filename):
base = os.path.basename(filename) base = os.path.basename(filename)
if base == const.indexFile: if base == const.indexFile:
filename = os.path.dirname(filename) filename = os.path.dirname(filename)
elif base == "autosave.gramps":
filename = os.path.dirname(filename)
elif not os.path.isdir(filename): elif not os.path.isdir(filename):
displayError(_("%s is not a directory") % filename) displayError(_("%s is not a directory") % filename)
return return
@ -628,7 +656,7 @@ def autosave_database():
path = database.getSavePath() path = database.getSavePath()
filename = os.path.normpath(path) filename = os.path.normpath(path)
utils.clearModified() utils.clear_timer()
filename = "%s/autosave.gramps" % (database.getSavePath()) filename = "%s/autosave.gramps" % (database.getSavePath())
@ -2111,11 +2139,11 @@ def main(arg):
if arg != None: if arg != None:
read_file(arg) read_file(arg)
elif Config.lastfile != None and Config.lastfile != "" and Config.autoload: elif Config.lastfile != None and Config.lastfile != "" and Config.autoload:
read_file(Config.lastfile) auto_save_load(Config.lastfile)
else: else:
DbPrompter(database,0) DbPrompter(database,0)
if Config.autosave and Config.autosave_int != 0: if Config.autosave_int != 0:
utils.enable_autosave(autosave_database,Config.autosave_int) utils.enable_autosave(autosave_database,Config.autosave_int)
database.setResearcher(Config.owner) database.setResearcher(Config.owner)