2007-03-27 Don Allingham <don@gramps-project.org>

* src/ViewManager.py: pass dbstate to DbManager
	* src/DbManager.py: add icon, prevent deletion of open db, make buttons
	do the sensible thing



svn: r8331
This commit is contained in:
Don Allingham 2007-03-28 03:33:11 +00:00
parent 58b1e800ca
commit e5f0c18781
3 changed files with 69 additions and 23 deletions

View File

@ -1,3 +1,8 @@
2007-03-27 Don Allingham <don@gramps-project.org>
* src/ViewManager.py: pass dbstate to DbManager
* src/DbManager.py: add icon, prevent deletion of open db, make buttons
do the sensible thing
2007-03-27 Brian Matherly <brian@gramps-project.org>
* src/ReportBase/_ReportDialog.py
* src/ReportBase/_BareReportDialog.py

View File

@ -41,7 +41,7 @@ from gettext import gettext as _
#
#-------------------------------------------------------------------------
import logging
log = logging.getLogger(".Bookmarks")
log = logging.getLogger(".DbManager")
#-------------------------------------------------------------------------
#
@ -68,10 +68,11 @@ NAME_COL = 0
PATH_COL = 1
FILE_COL = 2
DATE_COL = 3
OPEN_COL = 5
class DbManager:
def __init__(self):
def __init__(self, dbstate):
self.glade = gtk.glade.XML(const.gladeFile, "dbmanager", "gramps")
self.top = self.glade.get_widget('dbmanager')
@ -82,6 +83,12 @@ class DbManager:
self.remove = self.glade.get_widget('remove')
self.dblist = self.glade.get_widget('dblist')
self.model = None
if dbstate:
self.active = dbstate.db.get_save_path()
else:
self.active = None
self.selection = self.dblist.get_selection()
self.connect_signals()
self.build_interface()
@ -90,14 +97,28 @@ class DbManager:
def connect_signals(self):
self.remove.connect('clicked', self.remove_db)
self.new.connect('clicked', self.new_db)
self.selection.connect('changed', self.selection_changed)
def selection_changed(self, selection):
store, iter = selection.get_selected()
if not iter or store.get_value(iter, OPEN_COL):
self.remove.set_sensitive(False)
self.connect.set_sensitive(False)
else:
self.remove.set_sensitive(True)
self.connect.set_sensitive(True)
def build_interface(self):
render = gtk.CellRendererPixbuf()
column = gtk.TreeViewColumn('', render, stock_id=6)
self.dblist.append_column(column)
render = gtk.CellRendererText()
render.set_property('editable',True)
render.connect('edited', self.change_name)
column = gtk.TreeViewColumn(_('Database name'), render,
text=NAME_COL)
self.dblist.append_column(column)
self.column = gtk.TreeViewColumn(_('Database name'), render,
text=NAME_COL)
self.dblist.append_column(self.column)
render = gtk.CellRendererText()
column = gtk.TreeViewColumn(_('Last modified'), render, text=DATE_COL)
@ -105,7 +126,7 @@ class DbManager:
self.dblist.set_rules_hint(True)
def populate(self):
self.model = gtk.ListStore(str, str, str, str, int)
self.model = gtk.ListStore(str, str, str, str, int, bool, str)
try:
if not os.path.isdir(DEFAULT_DIR):
@ -115,37 +136,48 @@ class DbManager:
sort_list = []
for dpath in os.listdir(DEFAULT_DIR):
path_name = os.path.join(DEFAULT_DIR, dpath, NAME_FILE)
dirpath = os.path.join(DEFAULT_DIR, dpath)
path_name = os.path.join(dirpath, NAME_FILE)
if os.path.isfile(path_name):
name = file(path_name).readline().strip()
meta = os.path.join(DEFAULT_DIR, dpath, META_NAME)
meta = os.path.join(dirpath, dpath, META_NAME)
if os.path.isfile(meta):
tval = int(time.time())
last = time.asctime(time.localtime(time.time()))
tval = os.stat(meta)[9]
last = time.asctime(time.localtime(tval))
else:
tval = 0
last = _("Never")
if dirpath == self.active:
enable = True
stock_id = gtk.STOCK_CONNECT
else:
enable = False
stock_id = ""
sort_list.append((name,
os.path.join(DEFAULT_DIR, dpath),
path_name,
last,
tval))
tval,
enable,
stock_id))
sort_list.sort()
for items in sort_list:
data = [items[0], items[1], items[2], items[3], items[4]]
data = [items[0], items[1], items[2], items[3], items[4], items[5], items[6]]
self.model.append(data)
self.dblist.set_model(self.model)
def run(self):
value = self.top.run()
if value == gtk.RESPONSE_OK:
(model, node) = self.dblist.get_selection().get_selected()
(model, node) = self.selection.get_selected()
if node:
self.top.destroy()
return self.model.get_value(node, PATH_COL)
return (self.model.get_value(node, PATH_COL),
self.model.get_value(node, NAME_COL))
else:
self.top.destroy()
return None
@ -166,9 +198,11 @@ class DbManager:
pass
def remove_db(self, obj):
store, iter = self.dblist.get_selection().get_selected()
store, iter = self.selection.get_selected()
path = store.get_path(iter)
row = store[path]
if row[OPEN_COL]:
return
self.data_to_delete = (row[0], row[1], row[2])
QuestionDialog.QuestionDialog(
@ -198,9 +232,12 @@ class DbManager:
f = open(path_name, "w")
f.write(title)
f.close()
node = self.model.append([title, new_path, path_name, _("Never"), 0])
self.dblist.get_selection().select_iter(node)
node = self.model.append([title, new_path, path_name, _("Never"), 0, False, ''])
self.selection.select_iter(node)
path = self.model.get_path(node)
self.dblist.set_cursor(path, focus_column=self.column, start_editing=True)
if __name__ == "__main__":
a = DbManager(None,None)
a = DbManager()
a.run()

View File

@ -901,15 +901,16 @@ class ViewManager:
def open_activate(self, obj):
import DbManager
dialog = DbManager.DbManager()
filename = dialog.run()
if filename:
dialog = DbManager.DbManager(self.state)
value = dialog.run()
if value:
(filename, title) = value
self.read_file(filename, 'x-directory/normal')
try:
os.chdir(os.path.dirname(filename))
except:
pass
self.post_load_newdb(filename, 'x-directory/normal')
self.post_load_newdb(filename, 'x-directory/normal', title)
def read_file(self, filename, filetype):
"""
@ -1014,7 +1015,7 @@ class ViewManager:
self.window.window.set_cursor(None)
def post_load_newdb(self, filename, filetype):
def post_load_newdb(self, filename, filetype, title=None):
if not filename:
return
@ -1030,6 +1031,9 @@ class ViewManager:
if filename[-1] == os.path.sep:
filename = filename[:-1]
name = os.path.basename(filename)
if title:
name = title
if self.state.db.readonly:
msg = "%s (%s) - GRAMPS" % (name, _('Read Only'))
self.uistate.window.set_title(msg)