Modify srctemplatetab to use new Template data model
svn: r22698
This commit is contained in:
parent
94fe287886
commit
2430607b63
@ -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
|
||||
|
||||
|
@ -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):
|
||||
|
@ -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()
|
||||
|
@ -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
|
||||
|
@ -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())
|
||||
|
Loading…
x
Reference in New Issue
Block a user