From 907f50cf649f955a8388f4d5d6275ab3d8622ff0 Mon Sep 17 00:00:00 2001 From: kraanzu Date: Tue, 24 Sep 2024 14:52:02 +0530 Subject: [PATCH] add classmethod `comparable_fields` --- dooit/api/model.py | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/dooit/api/model.py b/dooit/api/model.py index 00aca3be..12a3352d 100644 --- a/dooit/api/model.py +++ b/dooit/api/model.py @@ -1,8 +1,11 @@ from typing import Any, List, Literal, TypeVar, Self from sqlalchemy.orm import DeclarativeBase, Mapped, mapped_column from sqlalchemy.ext.declarative import declared_attr +from sqlalchemy import Integer, Float, String, Date, DateTime, inspect from .manager import manager + +comparable_types = (Integer, Float, String, Date, DateTime) SortMethodType = Literal["description", "status", "due", "urgency", "effort"] T = TypeVar("T") @@ -27,6 +30,20 @@ class DooitModel(BaseModel, BaseModelMixin): id: Mapped[int] = mapped_column(primary_key=True, autoincrement=True) order_index: Mapped[int] = mapped_column(default=-1) + @classmethod + def comparable_fields(cls): + to_ignore = ["id", "order_index"] + + comparable_fields = [ + column.name + for column in inspect(cls).columns + if isinstance(column.type, comparable_types) + and not column.name.endswith("_id") + and column.name not in to_ignore + ] + + return comparable_fields + @property def uuid(self) -> str: return f"{self.__class__.__name__}_{self.id}"