generacion de cufe desde invoice

FossilOrigin-Name: d3494f20063452571b1e86d505f211e61fdf435aa43b870408136e3e9302bc17
This commit is contained in:
bit4bit
2021-07-31 17:09:42 +00:00
parent a1a9746353
commit 69a74c0714
8 changed files with 233 additions and 45 deletions

View File

@@ -25,7 +25,7 @@ class ModelBase(object, metaclass=ModelMeta):
obj._order_fields = []
def on_change_fields_for_function():
# se recorre arbol buscando el primero
# se recorre arbol de herencia buscando attributo on_changes
for parent_cls in type(obj).__mro__:
for parent_attr in dir(parent_cls):
parent_meth = getattr(parent_cls, parent_attr, None)
@@ -114,6 +114,10 @@ class ModelBase(object, metaclass=ModelMeta):
for name in ordered_fields.keys():
value = self._fields[name]
# al ser virtual no adicinamos al arbol xml
if hasattr(value, 'virtual') and value.virtual:
continue
if hasattr(value, 'to_xml'):
content += value.to_xml()
elif isinstance(value, str):
@@ -143,6 +147,12 @@ class Model(ModelBase):
"""
return value
def __default_get__(self, name, value):
"""
Retorno de valor por defecto
"""
return value
def __setup__(self):
"""
Inicializar modelo

View File

@@ -1,6 +1,7 @@
class Field:
def __set_name__(self, owner, name):
def __set_name__(self, owner, name, virtual=False):
self.name = name
self.virtual = virtual
def __get__(self, inst, cls):
if inst is None:

View File

@@ -1,22 +1,37 @@
from .field import Field
from collections import defaultdict
class Many2One(Field):
def __init__(self, model, name=None, setter=None, namespace=None, default=None):
def __init__(self, model, name=None, setter=None, namespace=None, default=None, virtual=False):
self.model = model
self.setter = setter
self.namespace = namespace
self.field_name = name
self.default = default
self.virtual = virtual
self.relations = defaultdict(dict)
def __get__(self, inst, cls):
if inst is None:
return self
assert self.name is not None
return self._create_model(inst, name=self.field_name)
if self.name in self.relations:
value = self.relations[inst][self.name]
else:
value = self._create_model(inst, name=self.field_name)
self.relations[inst][self.name] = value
# se puede obtener directamente un valor indicado por el modelo
if hasattr(value, '__default_get__'):
return value.__default_get__(self.name, value)
else:
return inst.__default_get__(self.name, value)
def __set__(self, inst, value):
assert self.name is not None
inst_model = self._create_model(inst, name=self.field_name, model=self.model)
self.relations[inst][self.name] = inst_model
# si hay setter manual se ejecuta
# de lo contrario se asigna como texto del elemento

View File

@@ -1,4 +1,5 @@
from .field import Field
from collections import defaultdict
# TODO(bit4bit) lograr que isinstance se aplique
# al objeto envuelto
@@ -51,7 +52,7 @@ class One2Many(Field):
self.field_name = name
self.namespace = namespace
self.default = default
self.relation = None
self.relation = {}
def __get__(self, inst, cls):
assert self.name is not None
@@ -59,8 +60,8 @@ class One2Many(Field):
def creator(attribute):
return self._create_model(inst, name=self.field_name, model=self.model, attribute=attribute)
if self.relation:
return self.relation
if inst in self.relation:
return self.relation[inst]
else:
self.relation = _Relation(creator, inst, self.name)
return self.relation
self.relation[inst] = _Relation(creator, inst, self.name)
return self.relation[inst]