From 16df764fe7021050509824e8c3d80a53cca217e3 Mon Sep 17 00:00:00 2001 From: Alex Parsons Date: Fri, 20 Dec 2024 20:12:54 +0000 Subject: [PATCH] Add annotations and whip reports to api --- src/votes/views/api.py | 35 +++++++++++++++++++++++++++++++++++ 1 file changed, 35 insertions(+) diff --git a/src/votes/views/api.py b/src/votes/views/api.py index 6123d83..69c9a58 100644 --- a/src/votes/views/api.py +++ b/src/votes/views/api.py @@ -11,8 +11,10 @@ from ..consts import PolicyStatus, RebellionPeriodType from ..models import ( Agreement, + AgreementAnnotation, Chamber, Division, + DivisionAnnotation, DivisionBreakdown, DivisionPartyBreakdown, DivisionsIsGovBreakdown, @@ -28,6 +30,7 @@ RebellionRate, Update, Vote, + VoteAnnotation, VoteDistribution, ) from .helper_models import PairedPolicy, PolicyDisplayGroup, PolicyReport @@ -128,6 +131,24 @@ class Meta: fields = "__all__" +class AgreementAnnotationSchema(ModelSchema): + class Meta: + model = AgreementAnnotation + fields = "__all__" + + +class DivisionAnnotationSchema(ModelSchema): + class Meta: + model = DivisionAnnotation + fields = "__all__" + + +class VoteAnnotationSchema(ModelSchema): + class Meta: + model = VoteAnnotation + fields = "__all__" + + class DivisionWithInfoSchema(ModelSchema): votes: list[VoteSchema] overall_breakdowns: list[DivisionBreakdownSchema] @@ -135,6 +156,18 @@ class DivisionWithInfoSchema(ModelSchema): is_gov_breakdowns: list[DivisionsIsGovBreakdownSchema] motion: MotionSchema | None voting_cluster: dict[str, str] + division_annotations: list[DivisionAnnotationSchema] + vote_annotations: list[VoteAnnotationSchema] + whip_reports: list[dict[str, Any]] + + @staticmethod + def resolve_whip_reports(obj: Division): + df = obj.whip_report_df() + if df is None: + return [] + # for columns, drop to lower case and change spaces to underscores + df.columns = [x.lower().replace(" ", "_") for x in df.columns] + return df.to_dict(orient="records") @staticmethod def resolve_voting_cluster(obj: Division): @@ -149,6 +182,8 @@ class Meta: class AgreementSchema(ModelSchema): + agreement_annotations: list[AgreementAnnotationSchema] + class Meta: model = Agreement fields = "__all__"