2024-05-12 21:07:57 +02:00
|
|
|
import string
|
2024-05-01 14:58:41 +02:00
|
|
|
|
2024-05-12 21:07:57 +02:00
|
|
|
class Converter:
|
2024-05-01 14:58:41 +02:00
|
|
|
|
|
|
|
def __init__(self) -> None:
|
|
|
|
self.__schema = None
|
|
|
|
|
|
|
|
def set_schema(self,schema = None):
|
|
|
|
self.__schema = schema
|
|
|
|
|
|
|
|
def get_template(self,field,lang='de'):
|
|
|
|
if 'template' in self.__schema[field]:
|
|
|
|
return self.__schema[field]['template'][lang]
|
|
|
|
else:
|
|
|
|
return "$value"
|
|
|
|
|
|
|
|
def is_translatable(self,field):
|
|
|
|
if 'translatable' in self.__schema[field]:
|
|
|
|
return self.__schema[field]['translatable']
|
|
|
|
else:
|
|
|
|
return True
|
|
|
|
|
|
|
|
def needs_spec(self,field):
|
|
|
|
if 'spec' in self.__schema[field]:
|
|
|
|
return self.__schema[field]
|
|
|
|
else:
|
|
|
|
return False
|
|
|
|
|
|
|
|
def process_label(self,field,lang='de'):
|
|
|
|
# processes the label of a field item
|
|
|
|
return self.__schema[field]['label'][lang]
|
|
|
|
|
|
|
|
def process_str(self,meta,field,lang='de'):
|
|
|
|
if self.is_translatable(field):
|
|
|
|
return [self.process_label(field,lang),meta[field][lang]]
|
|
|
|
else:
|
|
|
|
if not 'value' in meta[field]:
|
|
|
|
raise AssertionError(field,'incomplete')
|
|
|
|
|
|
|
|
return [self.process_label(field,lang),meta[field]['value']]
|
|
|
|
|
|
|
|
def process_enum(self,meta,field,lang='de'):
|
|
|
|
"""
|
|
|
|
enum have a specification 'specs' option
|
|
|
|
that can be forced by the scheme
|
|
|
|
"""
|
|
|
|
vv = meta[field]['value']
|
|
|
|
enum_val = self.__schema[field]['values'][vv][lang]
|
|
|
|
|
|
|
|
if self.needs_spec(field):
|
|
|
|
|
|
|
|
t = string.Template(self.get_template(field=field,lang=lang))
|
|
|
|
|
|
|
|
spec = meta[field]['spec'][lang]
|
|
|
|
|
|
|
|
return [self.process_label(field,lang),t.substitute({'value': enum_val,'spec': spec})]
|
|
|
|
else:
|
|
|
|
return [self.process_label(field,lang),enum_val]
|
|
|
|
|
|
|
|
def process_num(self,meta,field,lang='de'):
|
|
|
|
v = meta[field]['value']
|
|
|
|
t = string.Template(self.get_template(field,lang))
|
|
|
|
return [self.process_label(field,lang),t.substitute({'value' : v})]
|
|
|
|
|
|
|
|
def process_multinum(self,meta,field,lang='de'):
|
|
|
|
v = meta[field]['value']
|
|
|
|
t = string.Template(self.get_template(field,lang))
|
|
|
|
if hasattr(v, "__len__"):
|
|
|
|
vv = [t.substitute({'value' : ev}) for ev in v]
|
|
|
|
return [self.process_label(field,lang),', '.join(vv)]
|
|
|
|
else:
|
|
|
|
return self.process_num(meta=meta,field=field,lang=lang)
|
|
|
|
|
|
|
|
|
|
|
|
def process_multikey(self,meta,field,lang='de'):
|
|
|
|
"""
|
|
|
|
multikey need to assign a numeric value to a key
|
|
|
|
"""
|
|
|
|
vs = meta[field]['value']
|
|
|
|
t = string.Template(self.get_template(field,lang))
|
|
|
|
|
|
|
|
k = self.process_label(field,lang)
|
|
|
|
|
|
|
|
parts = []
|
|
|
|
|
|
|
|
for e in vs:
|
|
|
|
kk = self.__schema[field]['keys'][e][lang]
|
|
|
|
parts.append(t.substitute({'key': kk, 'value' : vs[e]}))
|
|
|
|
|
|
|
|
return [k,', '.join(parts)]
|
|
|
|
|
|
|
|
|
2024-05-09 22:57:10 +02:00
|
|
|
def process(self,meta,fields = [],lang = 'de'):
|
2024-05-01 14:58:41 +02:00
|
|
|
|
|
|
|
table_items = []
|
|
|
|
|
2024-05-01 17:14:23 +02:00
|
|
|
# iterate over requested fields
|
2024-05-01 14:58:41 +02:00
|
|
|
for field in fields:
|
2024-05-03 07:42:51 +02:00
|
|
|
try:
|
|
|
|
# correlate with schema and append
|
|
|
|
match self.__schema[field]['type']:
|
|
|
|
case 'str': table_items.append(self.process_str(meta,field,lang))
|
|
|
|
case 'enum': table_items.append(self.process_enum(meta,field,lang))
|
|
|
|
case 'int' | 'num' : table_items.append(self.process_num(meta,field,lang))
|
|
|
|
case 'multinum' : table_items.append(self.process_multinum(meta,field,lang))
|
|
|
|
case 'multikey': table_items.append(self.process_multikey(meta,field,lang))
|
|
|
|
except Exception as exp:
|
2024-05-06 16:37:34 +02:00
|
|
|
print(field,' not resolvable in ',self.__schema,exp)
|
2024-05-01 14:58:41 +02:00
|
|
|
|
|
|
|
# maybe return tableitems as np.Dataframe?
|
2024-05-09 23:38:20 +02:00
|
|
|
return table_items
|