* src/DataViews/MediaView.py:
* src/DataViews/RepositoryView.py: * src/DataViews/SourceView.py: * src/DataViews/EventView.py: * src/DataViews/PlaceView.py: * src/PageView.py: Remove unused double click procedure * src/plugins/SimpleBookTitle.py: remove use of AddMedia * src/Editors/AddMedia.py: added * src/AddMedia.py: removed * src/Editors/Makefile.am: * src/Makefile.am: * po/POTFILES.in: Move AddMedia to the editors directory * src/Editors/_EditMedia.py: Edit Media now works as other editors, spawning AddMedia when select is clicked. * src/ManagedWindow.py: typo in comment * src/Config/_GrampsConfigKeys.py: Two new keys, rerun ./autogen.sh Still todo: make relative path work 2008-01-06 Benny Malengier <benny.malengier@gramps-project.org> svn: r9722
This commit is contained in:
parent
aabef20651
commit
9664842702
22
ChangeLog
22
ChangeLog
@ -1,3 +1,25 @@
|
|||||||
|
2008-01-06 Benny Malengier <benny.malengier@gramps-project.org>
|
||||||
|
* src/DataViews/MediaView.py:
|
||||||
|
* src/DataViews/RepositoryView.py:
|
||||||
|
* src/DataViews/SourceView.py:
|
||||||
|
* src/DataViews/EventView.py:
|
||||||
|
* src/DataViews/PlaceView.py:
|
||||||
|
* src/PageView.py:
|
||||||
|
Remove unused double click procedure
|
||||||
|
* src/plugins/SimpleBookTitle.py: remove use of AddMedia
|
||||||
|
* src/Editors/AddMedia.py: added
|
||||||
|
* src/AddMedia.py: removed
|
||||||
|
* src/Editors/Makefile.am:
|
||||||
|
* src/Makefile.am:
|
||||||
|
* po/POTFILES.in:
|
||||||
|
Move AddMedia to the editors directory
|
||||||
|
* src/Editors/_EditMedia.py:
|
||||||
|
Edit Media now works as other editors, spawning AddMedia when
|
||||||
|
select is clicked.
|
||||||
|
* src/ManagedWindow.py: typo in comment
|
||||||
|
* src/Config/_GrampsConfigKeys.py: Two new keys, rerun ./autogen.sh
|
||||||
|
Still todo: make relative path work
|
||||||
|
|
||||||
2008-01-06 Benny Malengier <benny.malengier@gramps-project.org>
|
2008-01-06 Benny Malengier <benny.malengier@gramps-project.org>
|
||||||
* src/plugins/DefaultGadgets.py: handle long text in standard way for
|
* src/plugins/DefaultGadgets.py: handle long text in standard way for
|
||||||
translation
|
translation
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
#
|
#
|
||||||
# Python files
|
# Python files
|
||||||
#
|
#
|
||||||
src/AddMedia.py
|
|
||||||
src/ansel_utf8.py
|
src/ansel_utf8.py
|
||||||
src/ArgHandler.py
|
src/ArgHandler.py
|
||||||
src/Assistant.py
|
src/Assistant.py
|
||||||
@ -169,6 +168,7 @@ src/DisplayTabs/_WebModel.py
|
|||||||
src/DisplayTabs/__init__.py
|
src/DisplayTabs/__init__.py
|
||||||
|
|
||||||
# Editors package
|
# Editors package
|
||||||
|
src/Editors/AddMedia.py
|
||||||
src/Editors/_EditAddress.py
|
src/Editors/_EditAddress.py
|
||||||
src/Editors/_EditAttribute.py
|
src/Editors/_EditAttribute.py
|
||||||
src/Editors/_EditChildRef.py
|
src/Editors/_EditChildRef.py
|
||||||
|
@ -164,6 +164,8 @@ MIN_GENERATION_YEARS = ('behavior', 'min-generation-years', 1)
|
|||||||
AVG_GENERATION_GAP = ('behavior', 'avg-generation-gap', 1)
|
AVG_GENERATION_GAP = ('behavior', 'avg-generation-gap', 1)
|
||||||
GENERATION_DEPTH = ('behavior', 'generation-depth', 1)
|
GENERATION_DEPTH = ('behavior', 'generation-depth', 1)
|
||||||
DATA_VIEWS = ('interface','data-views', 2)
|
DATA_VIEWS = ('interface','data-views', 2)
|
||||||
|
ADDMEDIA_IMGDIR = ('behavior', 'addmedia-image-dir', 2)
|
||||||
|
ADDMEDIA_RELPATH = ('behavior', 'addmedia-relative-path', 0)
|
||||||
|
|
||||||
default_value = {
|
default_value = {
|
||||||
DEFAULT_SOURCE : False,
|
DEFAULT_SOURCE : False,
|
||||||
@ -283,4 +285,6 @@ default_value = {
|
|||||||
DATA_VIEWS: ('MyGrampsView,PersonView,RelationshipView,FamilyListView,'
|
DATA_VIEWS: ('MyGrampsView,PersonView,RelationshipView,FamilyListView,'
|
||||||
'PedigreeView,EventView,SourceView,PlaceView,MediaView,'
|
'PedigreeView,EventView,SourceView,PlaceView,MediaView,'
|
||||||
'RepositoryView,NoteView'),
|
'RepositoryView,NoteView'),
|
||||||
|
ADDMEDIA_IMGDIR : '',
|
||||||
|
ADDMEDIA_RELPATH : False,
|
||||||
}
|
}
|
||||||
|
@ -214,14 +214,6 @@ class EventView(PageView.ListView):
|
|||||||
self.dbstate.db.set_event_column_order(clist)
|
self.dbstate.db.set_event_column_order(clist)
|
||||||
self.build_columns()
|
self.build_columns()
|
||||||
|
|
||||||
def on_double_click(self, obj, event):
|
|
||||||
handle = self.first_selected()
|
|
||||||
the_event = self.dbstate.db.get_event_from_handle(handle)
|
|
||||||
try:
|
|
||||||
EditEvent(self.dbstate, self.uistate, [], the_event)
|
|
||||||
except Errors.WindowActiveError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def add(self, obj):
|
def add(self, obj):
|
||||||
try:
|
try:
|
||||||
EditEvent(self.dbstate, self.uistate, [], gen.lib.Event())
|
EditEvent(self.dbstate, self.uistate, [], gen.lib.Event())
|
||||||
|
@ -378,9 +378,10 @@ class MediaView(PageView.ListView):
|
|||||||
|
|
||||||
def add(self, obj):
|
def add(self, obj):
|
||||||
"""Add a new media object to the media list"""
|
"""Add a new media object to the media list"""
|
||||||
import AddMedia
|
try:
|
||||||
am = AddMedia.AddMediaObject(self.dbstate, self.uistate, [])
|
EditMedia(self.dbstate, self.uistate, [], gen.lib.MediaObject())
|
||||||
am.run()
|
except Errors.WindowActiveError:
|
||||||
|
pass
|
||||||
|
|
||||||
def remove(self, obj):
|
def remove(self, obj):
|
||||||
"""
|
"""
|
||||||
|
@ -217,14 +217,6 @@ class PlaceView(PageView.ListView):
|
|||||||
</popup>
|
</popup>
|
||||||
</ui>'''
|
</ui>'''
|
||||||
|
|
||||||
def on_double_click(self, obj, event):
|
|
||||||
handle = self.first_selected()
|
|
||||||
place = self.dbstate.db.get_place_from_handle(handle)
|
|
||||||
try:
|
|
||||||
EditPlace(self.dbstate, self.uistate, [], place)
|
|
||||||
except Errors.WindowActiveError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def add(self, obj):
|
def add(self, obj):
|
||||||
try:
|
try:
|
||||||
EditPlace(self.dbstate, self.uistate, [], gen.lib.Place())
|
EditPlace(self.dbstate, self.uistate, [], gen.lib.Place())
|
||||||
|
@ -182,14 +182,6 @@ class RepositoryView(PageView.ListView):
|
|||||||
</popup>
|
</popup>
|
||||||
</ui>'''
|
</ui>'''
|
||||||
|
|
||||||
def on_double_click(self, obj, event):
|
|
||||||
handle = self.first_selected()
|
|
||||||
repos = self.dbstate.db.get_repository_from_handle(handle)
|
|
||||||
try:
|
|
||||||
EditRepository(self.dbstate, self.uistate, [], repos)
|
|
||||||
except Errors.WindowActiveError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def add(self, obj):
|
def add(self, obj):
|
||||||
EditRepository(self.dbstate, self.uistate, [], gen.lib.Repository())
|
EditRepository(self.dbstate, self.uistate, [], gen.lib.Repository())
|
||||||
|
|
||||||
|
@ -180,14 +180,6 @@ class SourceView(PageView.ListView):
|
|||||||
</popup>
|
</popup>
|
||||||
</ui>'''
|
</ui>'''
|
||||||
|
|
||||||
def on_double_click(self, obj, event):
|
|
||||||
handle = self.first_selected()
|
|
||||||
source = self.dbstate.db.get_source_from_handle(handle)
|
|
||||||
try:
|
|
||||||
EditSource(self.dbstate, self.uistate, [], source)
|
|
||||||
except Errors.WindowActiveError:
|
|
||||||
pass
|
|
||||||
|
|
||||||
def add(self, obj):
|
def add(self, obj):
|
||||||
EditSource(self.dbstate, self.uistate, [], gen.lib.Source())
|
EditSource(self.dbstate, self.uistate, [], gen.lib.Source())
|
||||||
|
|
||||||
|
@ -53,6 +53,7 @@ import gtk.glade
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
import const
|
import const
|
||||||
|
import Config
|
||||||
import Utils
|
import Utils
|
||||||
import gen.lib
|
import gen.lib
|
||||||
import Mime
|
import Mime
|
||||||
@ -65,8 +66,7 @@ import ManagedWindow
|
|||||||
#
|
#
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
|
|
||||||
_last_directory = None
|
|
||||||
_relative_path = False
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
||||||
@ -76,19 +76,26 @@ _relative_path = False
|
|||||||
class AddMediaObject(ManagedWindow.ManagedWindow):
|
class AddMediaObject(ManagedWindow.ManagedWindow):
|
||||||
"""
|
"""
|
||||||
Displays the Add Media Dialog window, allowing the user to select
|
Displays the Add Media Dialog window, allowing the user to select
|
||||||
a media object from the file system, while providing a description.
|
a file from the file system, while providing a description.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
def __init__(self, dbstate, uistate, track):
|
def __init__(self, dbstate, uistate, track, mediaobj, callback=None):
|
||||||
"""
|
"""
|
||||||
Creates and displays the dialog box
|
Creates and displays the dialog box
|
||||||
|
|
||||||
db - the database in which the new object is to be stored
|
db - the database in which the new object is to be stored
|
||||||
|
The mediaobject is updated with the information, and on save, the
|
||||||
|
callback function is called
|
||||||
"""
|
"""
|
||||||
|
|
||||||
ManagedWindow.ManagedWindow.__init__(self, uistate, track, self)
|
ManagedWindow.ManagedWindow.__init__(self, uistate, track, self)
|
||||||
|
|
||||||
self.dbase = dbstate.db
|
self.dbase = dbstate.db
|
||||||
|
self.obj = mediaobj
|
||||||
|
self.callback = callback
|
||||||
|
|
||||||
|
self.last_directory = Config.get(Config.ADDMEDIA_IMGDIR)
|
||||||
|
self.relative_path = Config.get(Config.ADDMEDIA_RELPATH)
|
||||||
|
|
||||||
self.glade = gtk.glade.XML(const.GLADE_FILE, "imageSelect", "gramps")
|
self.glade = gtk.glade.XML(const.GLADE_FILE, "imageSelect", "gramps")
|
||||||
|
|
||||||
self.set_window(
|
self.set_window(
|
||||||
@ -99,37 +106,40 @@ class AddMediaObject(ManagedWindow.ManagedWindow):
|
|||||||
self.description = self.glade.get_widget("photoDescription")
|
self.description = self.glade.get_widget("photoDescription")
|
||||||
self.image = self.glade.get_widget("image")
|
self.image = self.glade.get_widget("image")
|
||||||
self.file_text = self.glade.get_widget("fname")
|
self.file_text = self.glade.get_widget("fname")
|
||||||
if _last_directory and os.path.isdir(_last_directory):
|
if not(self.last_directory and os.path.isdir(self.last_directory)):
|
||||||
self.file_text.set_current_folder(_last_directory)
|
self.last_directory = const.HOME_DIR
|
||||||
|
print 'test', self.last_directory
|
||||||
|
self.file_text.set_current_folder(self.last_directory)
|
||||||
|
|
||||||
self.relpath = self.glade.get_widget('relpath')
|
self.relpath = self.glade.get_widget('relpath')
|
||||||
self.relpath.set_active(_relative_path)
|
self.relpath.set_active(self.relative_path)
|
||||||
self.temp_name = ""
|
self.temp_name = ""
|
||||||
self.object = None
|
self.object = None
|
||||||
|
|
||||||
self.glade.get_widget('fname').connect('update_preview',
|
self.glade.get_widget('fname').connect('update_preview',
|
||||||
self.on_name_changed)
|
self.on_name_changed)
|
||||||
|
self.ok_button = self.glade.get_widget('button79')
|
||||||
|
self.help_button = self.glade.get_widget('button103')
|
||||||
|
self.cancel_button = self.glade.get_widget('button81')
|
||||||
|
self.ok_button.connect('clicked',self.save)
|
||||||
|
self.ok_button.set_sensitive(not self.dbase.readonly)
|
||||||
|
self.help_button.connect('clicked', lambda x: GrampsDisplay.help(
|
||||||
|
'gramps-edit-quick'))
|
||||||
|
self.cancel_button.connect('clicked', self.close)
|
||||||
self.show()
|
self.show()
|
||||||
|
self.modal_call()
|
||||||
|
|
||||||
def build_menu_names(self, obj):
|
def build_menu_names(self, obj):
|
||||||
"""
|
"""
|
||||||
Build the menu name for the window manager
|
Build the menu name for the window manager
|
||||||
"""
|
"""
|
||||||
return(_('Select media object'), None)
|
return(_('Select media object'), None)
|
||||||
|
|
||||||
def on_help_imagesel_clicked(self, obj):
|
|
||||||
"""Display the relevant portion of GRAMPS manual"""
|
|
||||||
GrampsDisplay.help('gramps-edit-quick')
|
|
||||||
self.window.run()
|
|
||||||
|
|
||||||
def save(self):
|
def save(self, *obj):
|
||||||
"""
|
"""
|
||||||
Callback function called with the save button is pressed.
|
Callback function called with the save button is pressed.
|
||||||
A new media object is created, and added to the database.
|
The media object is updated, and callback called
|
||||||
"""
|
"""
|
||||||
|
|
||||||
global _last_directory, _relative_path
|
|
||||||
|
|
||||||
description = unicode(self.description.get_text())
|
description = unicode(self.description.get_text())
|
||||||
|
|
||||||
if self.file_text.get_filename() is None:
|
if self.file_text.get_filename() is None:
|
||||||
@ -141,13 +151,14 @@ class AddMediaObject(ManagedWindow.ManagedWindow):
|
|||||||
filename = Utils.get_unicode_path(self.file_text.get_filename())
|
filename = Utils.get_unicode_path(self.file_text.get_filename())
|
||||||
full_file = filename
|
full_file = filename
|
||||||
|
|
||||||
|
pname = self.dbase.get_save_path()
|
||||||
|
if not os.path.isdir(pname):
|
||||||
|
pname = os.path.dirname(pname)
|
||||||
|
|
||||||
if self.relpath.get_active():
|
if self.relpath.get_active():
|
||||||
pname = self.dbase.get_save_path()
|
|
||||||
if not os.path.isdir(pname):
|
|
||||||
pname = os.path.dirname(pname)
|
|
||||||
filename = Utils.relative_path(filename, pname)
|
filename = Utils.relative_path(filename, pname)
|
||||||
|
|
||||||
if os.path.exists(filename) == 0:
|
if os.path.exists(pname) == 0:
|
||||||
msgstr = _("Cannot import %s")
|
msgstr = _("Cannot import %s")
|
||||||
msgstr2 = _("The filename supplied could not be found.")
|
msgstr2 = _("The filename supplied could not be found.")
|
||||||
ErrorDialog(msgstr % filename, msgstr2)
|
ErrorDialog(msgstr % filename, msgstr2)
|
||||||
@ -157,21 +168,17 @@ class AddMediaObject(ManagedWindow.ManagedWindow):
|
|||||||
if description == "":
|
if description == "":
|
||||||
description = os.path.basename(filename)
|
description = os.path.basename(filename)
|
||||||
|
|
||||||
mobj = gen.lib.MediaObject()
|
self.obj.set_description(description)
|
||||||
mobj.set_description(description)
|
self.obj.set_mime_type(mtype)
|
||||||
mobj.set_mime_type(mtype)
|
|
||||||
name = filename
|
name = filename
|
||||||
mobj.set_path(name)
|
self.obj.set_path(name)
|
||||||
_last_directory = os.path.dirname(full_file)
|
|
||||||
_relative_path = self.relpath.get_active()
|
self.last_directory = os.path.dirname(full_file)
|
||||||
|
self.relative_path = self.relpath.get_active()
|
||||||
|
|
||||||
mobj.set_handle(Utils.create_id())
|
self._cleanup_on_exit()
|
||||||
if not mobj.get_gramps_id():
|
if self.callback:
|
||||||
mobj.set_gramps_id(self.dbase.find_next_object_gramps_id())
|
self.callback(self.obj)
|
||||||
trans = self.dbase.transaction_begin()
|
|
||||||
self.object = mobj
|
|
||||||
self.dbase.commit_media_object(mobj, trans)
|
|
||||||
self.dbase.transaction_commit(trans, _("Add Media Object"))
|
|
||||||
|
|
||||||
def on_name_changed(self, *obj):
|
def on_name_changed(self, *obj):
|
||||||
"""
|
"""
|
||||||
@ -200,23 +207,10 @@ class AddMediaObject(ManagedWindow.ManagedWindow):
|
|||||||
image = Mime.find_mime_type_pixbuf(mtype)
|
image = Mime.find_mime_type_pixbuf(mtype)
|
||||||
self.image.set_from_pixbuf(image)
|
self.image.set_from_pixbuf(image)
|
||||||
|
|
||||||
def run(self):
|
def _cleanup_on_exit(self):
|
||||||
"""
|
Config.set(Config.ADDMEDIA_IMGDIR, self.last_directory)
|
||||||
Run the dialog, returning the selected object.
|
Config.set(Config.ADDMEDIA_RELPATH, self.relative_path)
|
||||||
"""
|
Config.sync()
|
||||||
while True:
|
|
||||||
val = self.window.run()
|
|
||||||
|
|
||||||
if val == gtk.RESPONSE_OK:
|
|
||||||
self.save()
|
|
||||||
self.close()
|
|
||||||
return self.object
|
|
||||||
elif val == gtk.RESPONSE_HELP:
|
|
||||||
self.on_help_imagesel_clicked(None)
|
|
||||||
else:
|
|
||||||
self.close()
|
|
||||||
return None
|
|
||||||
return None
|
|
||||||
|
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
#
|
#
|
@ -6,6 +6,7 @@
|
|||||||
pkgdatadir = $(datadir)/@PACKAGE@/Editors
|
pkgdatadir = $(datadir)/@PACKAGE@/Editors
|
||||||
|
|
||||||
pkgdata_PYTHON = \
|
pkgdata_PYTHON = \
|
||||||
|
AddMedia.py\
|
||||||
__init__.py\
|
__init__.py\
|
||||||
_EditAddress.py \
|
_EditAddress.py \
|
||||||
_EditAttribute.py \
|
_EditAttribute.py \
|
||||||
|
@ -48,6 +48,7 @@ import Mime
|
|||||||
import ThumbNails
|
import ThumbNails
|
||||||
import Utils
|
import Utils
|
||||||
from _EditPrimary import EditPrimary
|
from _EditPrimary import EditPrimary
|
||||||
|
from AddMedia import AddMediaObject
|
||||||
|
|
||||||
from GrampsWidgets import *
|
from GrampsWidgets import *
|
||||||
from DisplayTabs import SourceEmbedList,AttrEmbedList,NoteTab,MediaBackRefList
|
from DisplayTabs import SourceEmbedList,AttrEmbedList,NoteTab,MediaBackRefList
|
||||||
@ -59,10 +60,14 @@ from DisplayTabs import SourceEmbedList,AttrEmbedList,NoteTab,MediaBackRefList
|
|||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
class EditMedia(EditPrimary):
|
class EditMedia(EditPrimary):
|
||||||
|
|
||||||
def __init__(self,state,uistate,track,obj):
|
def __init__(self, state, uistate, track, obj, callback=None):
|
||||||
|
|
||||||
EditPrimary.__init__(self, state, uistate, track, obj,
|
EditPrimary.__init__(self, state, uistate, track, obj,
|
||||||
state.db.get_object_from_handle)
|
state.db.get_object_from_handle, callback)
|
||||||
|
if not self.obj.get_handle():
|
||||||
|
#show the addmedia dialog immediately, with track of parent.
|
||||||
|
AddMediaObject(state, self.uistate, self.track, self.obj,
|
||||||
|
self._update_addmedia)
|
||||||
|
|
||||||
def empty_object(self):
|
def empty_object(self):
|
||||||
return gen.lib.MediaObject()
|
return gen.lib.MediaObject()
|
||||||
@ -94,8 +99,9 @@ class EditMedia(EditPrimary):
|
|||||||
|
|
||||||
def _connect_signals(self):
|
def _connect_signals(self):
|
||||||
self.define_cancel_button(self.glade.get_widget('button91'))
|
self.define_cancel_button(self.glade.get_widget('button91'))
|
||||||
self.define_ok_button(self.glade.get_widget('ok'),self.save)
|
self.define_ok_button(self.glade.get_widget('ok'), self.save)
|
||||||
self.define_help_button(self.glade.get_widget('button102'),'adv-media')
|
self.define_help_button(self.glade.get_widget('button102'),
|
||||||
|
'adv-media')
|
||||||
|
|
||||||
def _setup_fields(self):
|
def _setup_fields(self):
|
||||||
self.date_field = MonitoredDate(
|
self.date_field = MonitoredDate(
|
||||||
@ -122,25 +128,36 @@ class EditMedia(EditPrimary):
|
|||||||
self.glade.get_widget("private"),
|
self.glade.get_widget("private"),
|
||||||
self.obj, self.db.readonly)
|
self.obj, self.db.readonly)
|
||||||
|
|
||||||
pixmap = self.glade.get_widget("pixmap")
|
self.pixmap = self.glade.get_widget("pixmap")
|
||||||
ebox = self.glade.get_widget('eventbox')
|
ebox = self.glade.get_widget('eventbox')
|
||||||
ebox.connect('button-press-event', self.button_press_event)
|
ebox.connect('button-press-event', self.button_press_event)
|
||||||
|
|
||||||
|
self.mimetext = self.glade.get_widget("type")
|
||||||
|
self.draw_preview()
|
||||||
|
self.setup_filepath()
|
||||||
|
|
||||||
|
def draw_preview(self):
|
||||||
mtype = self.obj.get_mime_type()
|
mtype = self.obj.get_mime_type()
|
||||||
if mtype:
|
if mtype:
|
||||||
pb = ThumbNails.get_thumbnail_image(
|
pb = ThumbNails.get_thumbnail_image(
|
||||||
Utils.find_file(self.obj.get_path()),mtype)
|
Utils.find_file(self.obj.get_path()), mtype)
|
||||||
pixmap.set_from_pixbuf(pb)
|
self.pixmap.set_from_pixbuf(pb)
|
||||||
descr = Mime.get_description(mtype)
|
descr = Mime.get_description(mtype)
|
||||||
if descr:
|
if descr:
|
||||||
self.glade.get_widget("type").set_text(descr)
|
self.mimetext.set_text(descr)
|
||||||
else:
|
else:
|
||||||
pb = Mime.find_mime_type_pixbuf('text/plain')
|
pb = Mime.find_mime_type_pixbuf('text/plain')
|
||||||
pixmap.set_from_pixbuf(pb)
|
self.pixmap.set_from_pixbuf(pb)
|
||||||
self.glade.get_widget("type").set_text(_('Note'))
|
self.mimetext.set_text(_('Note'))
|
||||||
|
|
||||||
|
def setup_filepath(self):
|
||||||
|
self.select = self.glade.get_widget('file_select')
|
||||||
|
self.file_path = self.glade.get_widget("path")
|
||||||
|
|
||||||
|
fname = self.obj.get_path()
|
||||||
|
self.file_path.set_text(fname)
|
||||||
|
self.select.connect('clicked', self.select_file)
|
||||||
|
|
||||||
self.setup_filepath()
|
|
||||||
|
|
||||||
def _create_tabbed_pages(self):
|
def _create_tabbed_pages(self):
|
||||||
notebook = gtk.Notebook()
|
notebook = gtk.Notebook()
|
||||||
|
|
||||||
@ -176,7 +193,6 @@ class EditMedia(EditPrimary):
|
|||||||
self.view_media(obj)
|
self.view_media(obj)
|
||||||
|
|
||||||
def view_media(self, obj):
|
def view_media(self, obj):
|
||||||
|
|
||||||
ref_obj = self.dbstate.db.get_object_from_handle(self.obj.handle)
|
ref_obj = self.dbstate.db.get_object_from_handle(self.obj.handle)
|
||||||
mime_type = ref_obj.get_mime_type()
|
mime_type = ref_obj.get_mime_type()
|
||||||
app = Mime.get_application(mime_type)
|
app = Mime.get_application(mime_type)
|
||||||
@ -184,34 +200,24 @@ class EditMedia(EditPrimary):
|
|||||||
import Utils
|
import Utils
|
||||||
Utils.launch(app[0],ref_obj.get_path())
|
Utils.launch(app[0],ref_obj.get_path())
|
||||||
|
|
||||||
def select_file(self,obj):
|
def select_file(self, val):
|
||||||
f = gtk.FileChooserDialog(
|
AddMediaObject(self.dbstate, self.uistate, self.track, self.obj,
|
||||||
_('Select Media Object'),
|
self._update_addmedia)
|
||||||
action=gtk.FILE_CHOOSER_ACTION_OPEN,
|
|
||||||
buttons=(gtk.STOCK_CANCEL,
|
|
||||||
gtk.RESPONSE_CANCEL,
|
|
||||||
gtk.STOCK_OPEN,
|
|
||||||
gtk.RESPONSE_OK))
|
|
||||||
|
|
||||||
text = self.file_path.get_text()
|
def _update_addmedia(self, obj):
|
||||||
path = os.path.dirname(text)
|
"""
|
||||||
|
Called when the add media dialog has been called.
|
||||||
f.set_filename(path)
|
This allows us to update the main form in response to
|
||||||
|
any changes: Redraw relevant fields: description, mimetype and path
|
||||||
status = f.run()
|
"""
|
||||||
if status == gtk.RESPONSE_OK:
|
for obj in (self.descr_window, ):
|
||||||
self.file_path.set_text(Utils.get_unicode_path(f.get_filename()))
|
obj.update()
|
||||||
f.destroy()
|
|
||||||
|
|
||||||
def setup_filepath(self):
|
|
||||||
self.select = self.glade.get_widget('file_select')
|
|
||||||
self.file_path = self.glade.get_widget("path")
|
|
||||||
|
|
||||||
fname = self.obj.get_path()
|
fname = self.obj.get_path()
|
||||||
self.file_path.set_text(fname)
|
self.file_path.set_text(fname)
|
||||||
self.select.connect('clicked', self.select_file)
|
self.draw_preview()
|
||||||
|
|
||||||
def save(self, *obj):
|
def save(self, *obj):
|
||||||
|
self.ok_button.set_sensitive(False)
|
||||||
path = self.glade.get_widget('path').get_text()
|
path = self.glade.get_widget('path').get_text()
|
||||||
|
|
||||||
if path != self.obj.get_path():
|
if path != self.obj.get_path():
|
||||||
@ -221,8 +227,15 @@ class EditMedia(EditPrimary):
|
|||||||
self.obj.set_path(Utils.get_unicode_path(path))
|
self.obj.set_path(Utils.get_unicode_path(path))
|
||||||
|
|
||||||
trans = self.db.transaction_begin()
|
trans = self.db.transaction_begin()
|
||||||
self.db.commit_media_object(self.obj,trans)
|
if self.obj.get_handle():
|
||||||
self.db.transaction_commit(trans,_("Edit Media Object"))
|
self.db.commit_media_object(self.obj, trans)
|
||||||
|
else:
|
||||||
|
self.db.add_object(self.obj, trans)
|
||||||
|
self.db.transaction_commit(trans, _("Edit Media Object (%s)"
|
||||||
|
) % self.obj.get_description())
|
||||||
|
|
||||||
|
if self.callback:
|
||||||
|
self.callback(self.obj)
|
||||||
self.close()
|
self.close()
|
||||||
|
|
||||||
def _cleanup_on_exit(self):
|
def _cleanup_on_exit(self):
|
||||||
|
@ -30,7 +30,6 @@ SUBDIRS = \
|
|||||||
gdirdir=$(prefix)/share/gramps
|
gdirdir=$(prefix)/share/gramps
|
||||||
|
|
||||||
gdir_PYTHON = \
|
gdir_PYTHON = \
|
||||||
AddMedia.py\
|
|
||||||
ansel_utf8.py\
|
ansel_utf8.py\
|
||||||
ArgHandler.py\
|
ArgHandler.py\
|
||||||
Assistant.py\
|
Assistant.py\
|
||||||
|
@ -437,7 +437,7 @@ class ManagedWindow:
|
|||||||
while True:
|
while True:
|
||||||
response = self.window.run()
|
response = self.window.run()
|
||||||
if response == gtk.RESPONSE_OK:
|
if response == gtk.RESPONSE_OK:
|
||||||
# dialog will be close by connect, now continue work while
|
# dialog will be closed by connect, now continue work while
|
||||||
# rest of dialog is unresponsive, release when finished
|
# rest of dialog is unresponsive, release when finished
|
||||||
self.close()
|
self.close()
|
||||||
if after_ok_func is not None:
|
if after_ok_func is not None:
|
||||||
|
@ -993,9 +993,6 @@ class ListView(BookMarkView):
|
|||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
|
||||||
def double_click(self, obj, event):
|
|
||||||
return False
|
|
||||||
|
|
||||||
def change_page(self):
|
def change_page(self):
|
||||||
if self.model:
|
if self.model:
|
||||||
self.uistate.show_filter_results(self.dbstate,
|
self.uistate.show_filter_results(self.dbstate,
|
||||||
|
@ -45,7 +45,7 @@ from ReportBase import Report, ReportOptions, CATEGORY_TEXT, MODE_BKI
|
|||||||
import BaseDoc
|
import BaseDoc
|
||||||
from Selectors import selector_factory
|
from Selectors import selector_factory
|
||||||
SelectObject = selector_factory('MediaObject')
|
SelectObject = selector_factory('MediaObject')
|
||||||
import AddMedia
|
#import AddMedia
|
||||||
import ThumbNails
|
import ThumbNails
|
||||||
|
|
||||||
#------------------------------------------------------------------------
|
#------------------------------------------------------------------------
|
||||||
@ -241,10 +241,12 @@ class SimpleBookTitleOptions(ReportOptions):
|
|||||||
self.setup_object(dialog.db,the_object)
|
self.setup_object(dialog.db,the_object)
|
||||||
|
|
||||||
def select_file(self,obj,dialog):
|
def select_file(self,obj,dialog):
|
||||||
a_o = AddMedia.AddMediaObject(dialog.dbstate,dialog.uistate,
|
print 'Deprecated use, this must be removed'
|
||||||
dialog.track)
|
|
||||||
a_o.run()
|
#a_o = AddMedia.AddMediaObject(dialog.dbstate,dialog.uistate,
|
||||||
self.setup_object(dialog.db,a_o.object)
|
# dialog.track)
|
||||||
|
#a_o.run()
|
||||||
|
#self.setup_object(dialog.db,a_o.object)
|
||||||
|
|
||||||
def setup_object(self,database,the_object):
|
def setup_object(self,database,the_object):
|
||||||
if not the_object:
|
if not the_object:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user