Modify srctemplatetab to use new Template data model

svn: r22698
This commit is contained in:
Tim G L Lyons 2013-07-20 18:15:58 +00:00
parent 94fe287886
commit 2430607b63
5 changed files with 261 additions and 134 deletions

View File

@ -230,7 +230,6 @@ class SrcTemplate(TableObject):
self.template_element_list = template_element_list
def add_template_element(self, template_element):
if template_element not in self.template_element_list:
self.template_element_list.append(template_element)
def add_structure_element(self, cite_type, slist):
@ -553,6 +552,13 @@ class TemplateElement(SecondaryObject):
Names & SecondAuthorSurname, Given Names'. Like this Gramps can parse the
name and shorten as needed."
- citation - True if this element appears in a citation (false for a source
element)
- short - True if this element is an optional short element
- short_alg - algorithm to shorten the field.
- list of Mappings - there would always be a GEDCOM mapping. Also we would
expect a CSL mapping
@ -567,12 +573,18 @@ class TemplateElement(SecondaryObject):
self.display = source.display
self.hint = source.hint
self.tooltip = source.tooltip
self.citation = source.citation
self.short - source.short
self.short_alg = source.short_alg
self.template_mapping_list = source.template_mapping_list
else:
self.name = ""
self.display = ""
self.hint = ""
self.tooltip = ""
self.citation = False
self.short = False
self.short_alg = ""
self.template_mapping_list = []
def serialize(self):
@ -668,6 +680,42 @@ class TemplateElement(SecondaryObject):
"""
self.tooltip = tooltip
def get_citation(self):
"""
Return the citation for the Template element.
"""
return self.citation
def set_citation(self, citation):
"""
Set the citation for the Template element according to the given argument.
"""
self.citation = citation
def get_short(self):
"""
Return the short for the Template element.
"""
return self.short
def set_short(self, short):
"""
Set the short for the Template element according to the given argument.
"""
self.short = short
def get_short_alg(self):
"""
Return the short_alg for the Template element.
"""
return self.short_alg
def set_short_alg(self, short_alg):
"""
Set the short_alg for the Template element according to the given argument.
"""
self.short_alg = short_alg
def get_template_mapping_list(self):
return self.template_mapping_list

View File

@ -54,7 +54,6 @@ class Singleton(type):
def __call__(cls, *args, **kwargs):
if cls not in cls._instances:
cls._instances[cls] = super(Singleton, cls).__call__(*args, **kwargs)
LOG.debug("**** Singleton metaclass initialised")
return cls._instances[cls]
class SrcTemplateList(object):

View File

@ -208,6 +208,7 @@ class TemplateFields(object):
if SrcTemplateList().template_defined(key):
#a predefined template,
template = SrcTemplateList().get_template_from_name(key).get_structure()
telist = SrcTemplateList().get_template_from_name(key).get_template_element_list()
else:
return
@ -226,24 +227,24 @@ class TemplateFields(object):
self.btns = []
row = 1
# now add new fields
fieldsL = []
for fielddef in template[REF_TYPE_L]:
hint = fielddef[9] or SrcAttributeType.get_default_hint(fielddef[1])
long_source_fields = [x for x in telist
if not x.get_short() and not x.get_citation()]
short_source_fields = [x for x in telist
if x.get_short() and not x.get_citation()]
long_citation_fields = [x for x in telist
if not x.get_short() and x.get_citation()]
short_citation_fields = [x for x in telist
if x.get_short() and x.get_citation()]
fieldsL.append(fielddef[1])
if self.cite is None:
#these are source fields
self._add_entry(row, fielddef[1], fielddef[2],
fielddef[9] or SrcAttributeType.get_default_hint(fielddef[1]),
fielddef[10] or SrcAttributeType.get_default_tooltip(fielddef[1]))
# source long fileds
for te in long_source_fields:
self._add_entry(row, te.get_name(), _(te.get_display()),
_(te.get_hint()), _(te.get_tooltip()))
row += 1
tempsattrt = SrcAttributeType()
# now add optional short citation values
if self.cite is None:
fieldsS = [fielddef for fielddef in template[REF_TYPE_S]
if fielddef[1] in fieldsL and fielddef[7]==EMPTY]
if fieldsS:
# now add short source fields (if any)
if short_source_fields:
self.gridfields.insert_row(row)
lbl = Gtk.Label('')
lbl.set_markup(_("<b>Optional Short Versions:</b>"))
@ -251,18 +252,14 @@ class TemplateFields(object):
self.gridfields.attach(lbl, 0, row-1, 2, 1)
self.lbls.append(lbl)
row += 1
for fielddef in fieldsS:
lblval = fielddef[2]
if lblval:
lblval = _('%(normal_version_label)s (Short)') % {
'normal_version_label': lblval}
self._add_entry(row, tempsattrt.short_version(fielddef[1]), lblval)
for te in short_source_fields:
self._add_entry(row, te.get_name(), _(te.get_display()),
_(te.get_hint()), _(te.get_tooltip()))
row += 1
# now add citation values (optional on source level)
fieldsF = [fielddef for fielddef in template[REF_TYPE_F]
if fielddef[1] not in fieldsL]
if fieldsF and show_default_cite_fields and self.cite is None:
# At source level add a header for the default citation values
if (long_citation_fields+short_citation_fields) and \
show_default_cite_fields:
self.gridfields.insert_row(row)
lbl = Gtk.Label('')
lbl.set_markup(_("<b>Optional Default Citation Fields:</b>"))
@ -270,17 +267,18 @@ class TemplateFields(object):
self.gridfields.attach(lbl, 0, row-1, 2, 1)
self.lbls.append(lbl)
row += 1
# Either show citation fields or at source level the default values
if show_default_cite_fields or (not self.cite is None):
for fielddef in fieldsF:
self._add_entry(row, fielddef[1], fielddef[2],
fielddef[9] or SrcAttributeType.get_default_hint(fielddef[1]),
fielddef[10] or SrcAttributeType.get_default_tooltip(fielddef[1]))
for te in long_citation_fields:
self._add_entry(row, te.get_name(), _(te.get_display()),
_(te.get_hint()), _(te.get_tooltip()))
row += 1
fieldsS = [fielddef for fielddef in template[REF_TYPE_S]
if fielddef[1] not in fieldsL and fielddef[7]==EMPTY]
# Finally the short citation fields (if any)
if not self.cite is None:
#we indicate with a text these are the short versions
if fieldsS:
if short_citation_fields:
self.gridfields.insert_row(row)
lbl = Gtk.Label('')
lbl.set_markup(_("<b>Optional Short Versions:</b>"))
@ -289,12 +287,9 @@ class TemplateFields(object):
self.lbls.append(lbl)
row += 1
if show_default_cite_fields or (not self.cite is None):
for fielddef in fieldsS:
lblval = fielddef[2]
if lblval:
lblval = _('%(normal_version_label)s (Short)') % {
'normal_version_label': lblval}
self._add_entry(row, tempsattrt.short_version(fielddef[1]), lblval)
for te in short_citation_fields:
self._add_entry(row, te.get_name(), _(te.get_display()),
_(te.get_hint()), _(te.get_tooltip()))
row += 1
self.gridfields.show_all()

View File

@ -86,10 +86,8 @@ class EditSource(EditPrimary):
# FIXME: Is there a cleaner place to initially load the template data?
global FIRST
if FIRST:
LOG.debug("**** load csv data")
from gramps.plugins.srctemplates.importcsv import load_srctemplates_data
load_srctemplates_data()
LOG.debug("**** csv data loaded\n\n")
FIRST = False
self.srctemp = None
self.citation = citation

View File

@ -36,6 +36,7 @@ from __future__ import print_function
from gramps.gen.const import GRAMPS_LOCALE as glocale
_ = glocale.translation.gettext
import csv
import collections
#-------------------------------------------------------------------------
#
@ -79,9 +80,34 @@ TOOLTIPCOL = 17
UNKNOWN = 'UNKNOWN'
DESCR = -10
# the GEDCOM type is predefined and always present. Other templates will be
# loaded via plugins
TEMPLATES = {
def load_srctemplates_data():
"""
Loads the srctemplates defined, and returns a dict with template data
"""
LOG.debug("**** load_srctemplate_data. Starting")
load_srctemplate_gedcom()
LOG.debug("**** load_srctemplate_data. GEDCOM and UNKNOWN loaded")
from gramps.gen.plug import BasePluginManager
bpmgr = BasePluginManager.get_instance()
pdatas = bpmgr.get_reg_srctemplates()
for plugin in pdatas:
mod = bpmgr.load_plugin(plugin)
if mod:
csvfilename = mod.csvfile
LOG.debug("**** load_srctemplate_data. Loading csv from %s" % csvfilename)
with open(csvfilename, 'rb') as csvfile:
load_srctemplate_csv(csvfile)
LOG.debug("**** load_srctemplate_data. csv data loaded")
def load_srctemplate_gedcom():
"""
Loads the GEDCOM and UNKNOWN templates which are always pre-defined
"""
TEMPLATES = {
'GEDCOM': {
REF_TYPE_L: [
('', SrcAttributeType.AUTHOR, _(''), '.', EMPTY, False, False, EMPTY, GED_AUTHOR,
@ -124,54 +150,28 @@ TEMPLATES = {
},
}
def load_srctemplates_data():
"""
Loads the srctemplates defined, and returns a dict with template data
"""
from gramps.gen.plug import BasePluginManager
bpmgr = BasePluginManager.get_instance()
pdatas = bpmgr.get_reg_srctemplates()
templatemap = {}
for plugin in pdatas:
mod = bpmgr.load_plugin(plugin)
if mod:
csvfilename = mod.csvfile
with open(csvfilename, 'rb') as csvfile:
templatemap.update(load_srctemplate_csv(csvfile))
return templatemap
def load_srctemplate_csv(csvfile):
"""
Loads a template csvfile, and returns a dict with template data
Note: csvfile could be a list containing strings!
"""
LOG.debug("**** importcsv.load_srctemplate_cvs called")
first = True
TYPE2CITEMAP = {}
TYPE2TEMPLATEMAP = {}
tlist = SrcTemplateList()
CITE_TYPES = {'F': REF_TYPE_F, 'L': REF_TYPE_L, 'S': REF_TYPE_S}
GEDCOMFIELDS = {'A': GED_AUTHOR, 'T': GED_TITLE,
'P': GED_PUBINF, 'D': GED_DATE}
SHORTERALG = {'LOC': SHORTERALG_LOC, 'YEAR': SHORTERALG_YEAR,
'ETAL': SHORTERALG_ETAL, 'REV.': SHORTERALG_REVERT_TO_DOT}
STYLES = {'Quoted': STYLE_QUOTE, 'Italics': STYLE_EMPH,
'QuotedCont': STYLE_QUOTECONT, 'Bold': STYLE_BOLD}
template = SrcTemplate()
template.set_name('GEDCOM')
template.set_descr('%(first)s - %(sec)s - %(third)s' % { 'first': _('Basic'), 'sec': _('GEDCOM Style'), 'third': _('')})
handle = create_id()
template.set_handle(handle)
TYPE2TEMPLATEMAP['GEDCOM'] = template
tlist = SrcTemplateList()
tlist.add_template(handle, template)
for (cite_type, slist) in TEMPLATES['GEDCOM'].iteritems():
if cite_type != DESCR:
for struct in slist:
LOG.debug(struct)
if cite_type == REF_TYPE_L or cite_type == REF_TYPE_F:
elem = [x for x in template.get_template_element_list()
if x.get_name()==struct[1] and x.get_short()==False]
if elem:
te = elem[0]
else:
te = TemplateElement()
template.add_template_element(te)
elif cite_type == REF_TYPE_S:
te = TemplateElement()
template.add_template_element(te)
ldel = struct[0]
field_type = struct[1]
field_label = struct[2]
@ -183,28 +183,62 @@ def load_srctemplate_csv(csvfile):
gedcommap = struct[8]
hint = struct[9]
tooltip = struct[10]
te = TemplateElement()
te.set_name(field_type)
te.set_display(field_label)
te.set_hint(hint or SrcAttributeType.get_default_hint(field_type))
te.set_tooltip(tooltip or SrcAttributeType.get_default_tooltip(field_type))
template.add_template_element(te)
if cite_type == REF_TYPE_S:
te.set_short(True)
te.set_name(int(SrcAttributeType().short_version(te.get_name())))
if field_type == SrcAttributeType.PAGE or \
field_type == SrcAttributeType.DATE:
te.set_citation(True)
template.add_structure_element(cite_type, [(ldel, field_type,
field_label, rdel, style, private, optional,
shorteralg, gedcommap, hint, tooltip)])
for handle in SrcTemplateList().get_template_list():
template = SrcTemplateList().get_template_from_handle(handle)
LOG.debug("source_type: %s" % template.get_name())
for te in template.get_template_element_list():
LOG.debug(" name: %s; display: %s; hint: %s; tooltip: %s; citation %s; "
"short %s; short_alg %s" %
(SrcAttributeType(te.get_name()).xml_str(),
te.get_display(), te.get_hint(),
te.get_tooltip(), te.get_citation(),
te.get_short(), te.get_short_alg()
))
# Now load the UNKNOWN template
template = SrcTemplate()
template.set_name(UNKNOWN)
template.set_descr(_("Unrecognized Template. Download it's definition."))
handle = create_id()
template.set_handle(handle)
TYPE2TEMPLATEMAP[UNKNOWN] = template
tlist = SrcTemplateList()
tlist.add_template(handle, template)
for cite_type in (REF_TYPE_F, REF_TYPE_L, REF_TYPE_S):
template.add_structure_element(cite_type, [])
def load_srctemplate_csv(csvfile):
"""
Loads a template csvfile, and returns a dict with template data
Note: csvfile could be a list containing strings!
"""
first = True
TYPE2CITEMAP = {}
TYPE2TEMPLATEMAP = {}
TYPE2FIELDS = collections.defaultdict(lambda: collections.defaultdict(list))
tlist = SrcTemplateList()
CITE_TYPES = {'F': REF_TYPE_F, 'L': REF_TYPE_L, 'S': REF_TYPE_S}
GEDCOMFIELDS = {'A': GED_AUTHOR, 'T': GED_TITLE,
'P': GED_PUBINF, 'D': GED_DATE}
SHORTERALG = {'LOC': SHORTERALG_LOC, 'YEAR': SHORTERALG_YEAR,
'ETAL': SHORTERALG_ETAL, 'REV.': SHORTERALG_REVERT_TO_DOT}
STYLES = {'Quoted': STYLE_QUOTE, 'Italics': STYLE_EMPH,
'QuotedCont': STYLE_QUOTECONT, 'Bold': STYLE_BOLD}
reader = csv.reader(csvfile, delimiter=';')
prevtempl = ''
@ -286,13 +320,6 @@ def load_srctemplate_csv(csvfile):
shorteralg = SHORTERALG.get(row[SHORTERCOL].strip()) or EMPTY
gedcommap = GEDCOMFIELDS.get(row[GEDCOMCOL].strip()) or EMPTY
style = STYLES.get(row[STYLECOL].strip()) or EMPTY
hint = row[HINTCOL]
tooltip = row[TOOLTIPCOL]
te = TemplateElement()
te.set_name(field_type)
te.set_display(_(field_label))
te.set_hint(_(hint) or SrcAttributeType.get_default_hint(field_type))
te.set_tooltip(_(tooltip) or SrcAttributeType.get_default_tooltip(field_type))
if source_type in TYPE2TEMPLATEMAP:
template = TYPE2TEMPLATEMAP[source_type]
@ -302,13 +329,73 @@ def load_srctemplate_csv(csvfile):
template.set_handle(handle)
TYPE2TEMPLATEMAP[source_type] = template
tlist.add_template(handle, template)
# FIXME: If the template element is already present, don't add it again
if cite_type == REF_TYPE_L or REF_TYPE_F:
elem = [x for x in template.get_template_element_list()
if x.get_name()==field_type and x.get_short()==False]
if elem:
te = elem[0]
else:
te = TemplateElement()
template.add_template_element(te)
hint = row[HINTCOL]
tooltip = row[TOOLTIPCOL]
te.set_name(field_type)
te.set_display(field_label)
te.set_hint(hint or te.get_hint())
te.set_tooltip(tooltip or te.get_tooltip())
te.set_short_alg(shorteralg)
if cite_type == REF_TYPE_S:
te = TemplateElement()
# field_type = int(SrcAttributeType().short_version(field_type))
te.set_name(field_type)
te.set_short_alg(shorteralg)
te.set_short(True)
lblval = field_label
if lblval:
te.set_display(_('%(normal_version_label)s (Short)') % {
'normal_version_label': lblval})
template.add_template_element(te)
TYPE2FIELDS[source_type][cite_type].append(field_type)
template.add_structure_element(cite_type, [(row[LDELCOL], field_type,
_(field_label), row[RDELCOL], style, private, optional,
shorteralg, gedcommap, _(hint), _(tooltip))])
LOG.debug(tlist.get_template_list())
for handle in tlist.get_template_list():
LOG.debug(tlist.get_template_from_handle(handle).to_struct())
return TYPE2CITEMAP
# Now we adjust some fields that could not be changed till all the data had
# been read in
for source_type in TYPE2FIELDS:
template = TYPE2TEMPLATEMAP[source_type]
LOG.debug("source_type: %s" % source_type)
# First we determine which are citation fields
cite_fields = [field for field in
TYPE2FIELDS[source_type][REF_TYPE_F] +
TYPE2FIELDS[source_type][REF_TYPE_S]
if field not in TYPE2FIELDS[source_type][REF_TYPE_L]]
for te in template.get_template_element_list():
# Set the boolean if this is a citation field
if te.get_name() in cite_fields:
te.set_citation(True)
# Set the hint and tooltip to default if not already set
if not te.get_hint():
te.set_hint(SrcAttributeType.get_default_hint(te.get_name()))
if not te.get_tooltip():
te.set_tooltip(SrcAttributeType.get_default_tooltip(te.get_name()))
# If this is a short version, set the name accordingly. This could
# not be done earlier because we needed to keep the old 'non-short'
# name to find which fields belonged to citations as opposed to
# sources
if te.get_short() == True:
te.set_name(int(SrcAttributeType().short_version(te.get_name())))
LOG.debug(" name: %s; display: %s; hint: %s; tooltip: %s; "
"citation %s; short %s; short_alg %s" %
(SrcAttributeType(te.get_name()).xml_str(),
te.get_display(), te.get_hint(),
te.get_tooltip(), te.get_citation(),
te.get_short(), te.get_short_alg()
))
# LOG.debug(tlist.get_template_list())
# for handle in tlist.get_template_list():
# LOG.debug(tlist.get_template_from_handle(handle).to_struct())