schon/evibes/pagination.py
Egor fureunoir Gorbunov a81f734e23 Features: (1) None;
Fixes: (1) Removed all `# type: ignore` annotations across the codebase; (2) Fixed usage of Django Model methods by eliminating unnecessary `# type: ignore` directives; (3) Adjusted usage of functions like `get()` to align with method expectations, removing incorrect comments;

Extra: (1) Deleted `pyrightconfig.json` as part of migration to a stricter type-checked environment; (2) Minor code cleanup, including formatting changes and refactoring import statements in adherence to PEP8 recommendations.
2025-12-18 15:55:43 +03:00

68 lines
2.3 KiB
Python

from typing import Any
from rest_framework.pagination import PageNumberPagination
from rest_framework.response import Response
class CustomPagination(PageNumberPagination):
page_size_query_param: str = (
"page_size" # name of the query parameter, you can use any
)
def get_paginated_response(self, data: dict[str, Any]) -> Response:
return Response(
{
"links": {
"forward": self.get_next_link(),
"backward": self.get_previous_link(),
},
"counts": {
"total_pages": None or self.page.paginator.num_pages,
"page_size": None or self.page_size,
"total_items": None or self.page.paginator.count,
},
"data": data,
}
)
def get_paginated_response_schema(
self, data_schema: dict[str, Any]
) -> dict[str, Any]:
return {
"type": "object",
"properties": {
"links": {
"type": "object",
"properties": {
"forward": {
"type": "string",
"nullable": True,
"format": "uri",
"description": "URL to the next page",
},
"backward": {
"type": "string",
"nullable": True,
"format": "uri",
"description": "URL to the previous page",
},
},
},
"total_pages": {
"type": "integer",
"example": 10,
"description": "Total number of pages",
},
"page_size": {
"type": "integer",
"example": 10,
"description": "Number of items per page",
},
"total_items": {
"type": "integer",
"example": 100,
"description": "Total number of items",
},
"data": data_schema,
},
}