""" Project: PARTS Website Author: Edward Middleton-Smith Precision And Research Technology Systems Limited Technology: Business Objects Feature: Obedience Level Business Object """ # internal from business_objects.base import Base from business_objects.db_base import SQLAlchemy_ABC, Get_Many_Parameters_Base import lib.argument_validation as av from extensions import db from helpers.helper_app import Helper_App # external from dataclasses import dataclass from typing import ClassVar class Obedience_Level(SQLAlchemy_ABC, Base): ATTR_ID_OBEDIENCE_LEVEL: ClassVar[str] = "id_obedience_level" FLAG_OBEDIENCE_LEVEL: ClassVar[str] = 'obedience-level' NAME_ATTR_OPTION_VALUE: ClassVar[str] = ATTR_ID_OBEDIENCE_LEVEL NAME_ATTR_OPTION_TEXT: ClassVar[str] = Base.FLAG_NAME __tablename__ = 'DOG_Obedience_Level' __table_args__ = { 'extend_existing': True } id_obedience_level = db.Column(db.Integer, primary_key=True) code = db.Column(db.String(250)) name = db.Column(db.String(250)) active = db.Column(db.Boolean) def __init__(self): self.id_obedience_level = 0 self.is_new = False super().__init__() @classmethod def from_db_obedience_level(cls, query_row): _m = f'{cls.__qualname__}.from_db_obedience_level' level = cls() level.id_obedience_level = query_row[0] level.code = query_row[1] level.name = query_row[2] level.active = av.input_bool(query_row[3], "active", _m) return level @classmethod def from_db_assessment_response(cls, query_row): _m = f'{cls.__qualname__}.from_db_assessment_response' level = cls() level.id_obedience_level = query_row[5] level.name = query_row[6] level.active = True return level @classmethod def from_json(cls, json): _m = f'{cls.__qualname__}.from_json' obedience_level = cls() if json is None: return Obedience_Level obedience_level.id_obedience_level = json.get(Obedience_Level.ATTR_ID_OBEDIENCE_LEVEL, -1) obedience_level.code = json[cls.FLAG_CODE] obedience_level.name = json[cls.FLAG_NAME] obedience_level.active = av.input_bool(json[cls.FLAG_ACTIVE], cls.FLAG_ACTIVE, _m) return obedience_level def to_json(self): as_json = { **self.get_shared_json_attributes(self) , self.ATTR_ID_OBEDIENCE_LEVEL: self.id_obedience_level , self.FLAG_CODE: self.code , self.FLAG_NAME: self.name , self.FLAG_ACTIVE: self.active } return as_json def __repr__(self): return f''' {self.__class__.__name__}( {self.FLAG_OBEDIENCE_LEVEL}: {self.id_obedience_level} {self.FLAG_CODE}: {self.code} {self.FLAG_NAME}: {self.name} {self.FLAG_ACTIVE}: {self.active} ) ''' class Obedience_Level_Temp(db.Model, Base): __tablename__ = 'DOG_Obedience_Level_Temp' __table_args__ = { 'extend_existing': True } id_temp = db.Column(db.Integer, primary_key=True) id_obedience_level = db.Column(db.Integer) code = db.Column(db.String(250)) name = db.Column(db.String(250)) active = db.Column(db.Boolean) guid: str = db.Column(db.String(36)) def __init__(self): super().__init__() @classmethod def from_obedience_level(cls, obedience_level): _m = 'Obedience_Level_Temp.from_Obedience_Level' temp = cls() temp.id_obedience_level = obedience_level.id_obedience_level temp.code = obedience_level.code temp.name = obedience_level.name temp.active = obedience_level.active return temp class Parameters_Obedience_Level(Get_Many_Parameters_Base): get_all_obedience_level: bool get_inactive_obedience_level: bool ids_obedience_level: str names_obedience_level: str require_all_id_search_filters_met: bool require_any_id_search_filters_met: bool require_all_non_id_search_filters_met: bool require_any_non_id_search_filters_met: bool @classmethod def get_default(cls): return cls( get_all_obedience_level = True , get_inactive_obedience_level = False , ids_obedience_level = '' , names_obedience_level = '' , require_all_id_search_filters_met = True , require_any_id_search_filters_met = True , require_all_non_id_search_filters_met = False , require_any_non_id_search_filters_met = True ) @classmethod def from_json(cls, json): return cls( get_all_obedience_level = json.get('a_get_all_obedience_level', False) , get_inactive_obedience_level = json.get('a_get_inactive_obedience_level', False) , ids_obedience_level = json.get('a_ids_obedience_level', '') , names_obedience_level = json.get('a_names_obedience_level', '') , require_all_id_search_filters_met = json.get('a_require_all_id_search_filters_met', True) , require_any_id_search_filters_met = json.get('a_require_any_id_search_filters_met', True) , require_all_non_id_search_filters_met = json.get('a_require_all_non_id_search_filters_met', False) , require_any_non_id_search_filters_met = json.get('a_require_any_non_id_search_filters_met', True) ) """ @classmethod def from_form_filters_obedience_level(cls, form): av.val_instance(form, 'form', 'Parameters_Obedience_Level.from_form_filters_obedience_level', Filters_Obedience_Level) has_filter_search_text = not (form.search.data == '' or form.search.data is None) active_only = av.input_bool(form.active_only.data, "active", "Parameters_Obedience_Level.from_form_filters_obedience_level") filters = cls.get_default() filters.get_all_obedience_level = True filters.get_inactive_obedience_level = not active_only filters.ids_obedience_level = '' filters.names_obedience_level = form.search.data if has_filter_search_text else '' filters.notes_obedience_level = form.search.data if has_filter_search_text else '' return filters """ def to_json(self): return { 'a_get_all_obedience_level': self.get_all_obedience_level , 'a_get_inactive_obedience_level': self.get_inactive_obedience_level , 'a_ids_obedience_level': self.ids_obedience_level , 'a_names_obedience_level': self.names_obedience_level , 'a_require_all_id_search_filters_met': self.require_all_id_search_filters_met , 'a_require_any_id_search_filters_met': self.require_any_id_search_filters_met , 'a_require_all_non_id_search_filters_met': self.require_all_non_id_search_filters_met , 'a_require_any_non_id_search_filters_met': self.require_any_non_id_search_filters_met }