politikorama/app/model/entity.py

33 lines
1001 B
Python
Raw Normal View History

2021-07-23 17:35:29 +02:00
# encoding: utf-8
from app import admin, db
from app.model.model import Model, View
class EntityModel(db.Model, Model):
__tablename__ = "entity"
id = db.Column(db.Integer, primary_key=True)
2022-05-31 07:11:49 +02:00
parent_id = db.Column(db.Integer, db.ForeignKey("entity.id"))
children = db.relationship(
"EntityModel", backref=db.backref("parent", remote_side=id)
)
name = db.Column(db.String(500))
slug = db.Column(db.String(500))
reference = db.Column(db.String(200))
source = db.Column(db.String(200))
2021-07-23 17:35:29 +02:00
type_id = db.Column(db.Integer, db.ForeignKey("type.id"))
type = db.relationship("TypeModel")
2021-07-24 10:01:50 +02:00
start = db.Column(db.Date)
end = db.Column(db.Date)
2022-05-31 07:11:49 +02:00
active = db.Column(db.Boolean)
2021-07-23 17:35:29 +02:00
def __repr__(self):
return self.name
class AdminView(View):
column_default_sort = "name"
2022-05-31 07:11:49 +02:00
column_filters = ["name", "reference", "parent.name", "start", "end", "active"]
2021-07-23 17:35:29 +02:00
admin.add_view(AdminView(EntityModel, db.session, name="Entity", category="CRUD"))