mirror of
https://github.com/mealie-recipes/mealie.git
synced 2025-07-19 13:19:41 +02:00
rewrite get_all routes to use a pagination pattern to allow for better implementations of search, filter, and sorting on the frontend or by any client without fetching all the data. Additionally we added a CI check for running the Nuxt built to confirm that no TS errors were present. Finally, I had to remove the header support for the Shopping lists as the browser caching based off last_updated header was not allowing it to read recent updates due to how we're handling the updated_at property in the database with nested fields. This will have to be looked at in the future to reimplement. I'm unsure how many other routes have a similar issue. Co-authored-by: Hayden <64056131+hay-kot@users.noreply.github.com>
65 lines
2.5 KiB
Python
65 lines
2.5 KiB
Python
from functools import cached_property
|
|
|
|
from fastapi import APIRouter, Depends
|
|
from pydantic import UUID4
|
|
|
|
from mealie.routes._base.base_controllers import BaseUserController
|
|
from mealie.routes._base.controller import controller
|
|
from mealie.routes._base.mixins import HttpRepo
|
|
from mealie.routes._base.routers import MealieCrudRoute
|
|
from mealie.schema.labels import (
|
|
MultiPurposeLabelCreate,
|
|
MultiPurposeLabelOut,
|
|
MultiPurposeLabelSave,
|
|
MultiPurposeLabelSummary,
|
|
MultiPurposeLabelUpdate,
|
|
)
|
|
from mealie.schema.labels.multi_purpose_label import MultiPurposeLabelPagination
|
|
from mealie.schema.mapper import cast
|
|
from mealie.schema.response.pagination import PaginationQuery
|
|
|
|
router = APIRouter(prefix="/groups/labels", tags=["Group: Multi Purpose Labels"], route_class=MealieCrudRoute)
|
|
|
|
|
|
@controller(router)
|
|
class MultiPurposeLabelsController(BaseUserController):
|
|
@cached_property
|
|
def repo(self):
|
|
if not self.deps.acting_user:
|
|
raise Exception("No user is logged in.")
|
|
|
|
return self.deps.repos.group_multi_purpose_labels.by_group(self.deps.acting_user.group_id)
|
|
|
|
# =======================================================================
|
|
# CRUD Operations
|
|
|
|
@property
|
|
def mixins(self) -> HttpRepo:
|
|
return HttpRepo(self.repo, self.deps.logger, self.registered_exceptions, "An unexpected error occurred.")
|
|
|
|
@router.get("", response_model=MultiPurposeLabelPagination)
|
|
def get_all(self, q: PaginationQuery = Depends(PaginationQuery)):
|
|
response = self.repo.page_all(
|
|
pagination=q,
|
|
override=MultiPurposeLabelSummary,
|
|
)
|
|
|
|
response.set_pagination_guides(router.url_path_for("get_all"), q.dict())
|
|
return response
|
|
|
|
@router.post("", response_model=MultiPurposeLabelOut)
|
|
def create_one(self, data: MultiPurposeLabelCreate):
|
|
save_data = cast(data, MultiPurposeLabelSave, group_id=self.deps.acting_user.group_id)
|
|
return self.mixins.create_one(save_data)
|
|
|
|
@router.get("/{item_id}", response_model=MultiPurposeLabelOut)
|
|
def get_one(self, item_id: UUID4):
|
|
return self.repo.get_one(item_id)
|
|
|
|
@router.put("/{item_id}", response_model=MultiPurposeLabelOut)
|
|
def update_one(self, item_id: UUID4, data: MultiPurposeLabelUpdate):
|
|
return self.mixins.update_one(data, item_id)
|
|
|
|
@router.delete("/{item_id}", response_model=MultiPurposeLabelOut)
|
|
def delete_one(self, item_id: UUID4):
|
|
return self.mixins.delete_one(item_id) # type: ignore
|