music-kraken-core/music_kraken/download/results.py

95 lines
3.1 KiB
Python
Raw Normal View History

2023-06-12 12:56:14 +00:00
from typing import Tuple, Type, Dict, List, Generator, Union
from dataclasses import dataclass
2023-05-26 08:11:36 +00:00
from ..objects import DatabaseObject
from ..utils.enums.source import SourcePages
from ..pages import Page, EncyclopaediaMetallum, Musify
@dataclass
class Option:
index: int
music_object: DatabaseObject
class Results:
def __init__(self) -> None:
2023-06-12 12:56:14 +00:00
self._by_index: Dict[int, DatabaseObject] = dict()
self._page_by_index: Dict[int: Type[Page]] = dict()
2023-06-12 12:56:14 +00:00
def __iter__(self) -> Generator[DatabaseObject, None, None]:
for option in self.formated_generator():
if isinstance(option, Option):
yield option.music_object
2023-06-12 12:56:14 +00:00
def formated_generator(self, max_items_per_page: int = 10) -> Generator[Union[Type[Page], Option], None, None]:
self._by_index = dict()
2023-06-12 12:56:14 +00:00
self._page_by_index = dict()
2023-06-12 12:56:14 +00:00
def get_music_object_by_index(self, index: int) -> Tuple[Type[Page], DatabaseObject]:
2023-09-13 14:01:01 +00:00
# if this throws a key error, either the formatted generator needs to be iterated, or the option doesn't exist.
2023-06-12 12:56:14 +00:00
return self._page_by_index[index], self._by_index[index]
2023-12-29 15:15:54 +00:00
class SearchResults(Results):
2023-05-26 08:11:36 +00:00
def __init__(
self,
2023-06-12 12:56:14 +00:00
pages: Tuple[Type[Page], ...] = None
2023-05-26 08:11:36 +00:00
) -> None:
2023-06-12 12:56:14 +00:00
super().__init__()
2023-06-12 12:56:14 +00:00
self.pages = pages or []
2023-05-26 08:11:36 +00:00
# this would initialize a list for every page, which I don't think I want
# self.results = Dict[Type[Page], List[DatabaseObject]] = {page: [] for page in self.pages}
2023-06-12 12:56:14 +00:00
self.results: Dict[Type[Page], List[DatabaseObject]] = {}
2023-05-26 08:11:36 +00:00
def add(self, page: Type[Page], search_result: List[DatabaseObject]):
"""
adds a list of found music objects to the according page
WARNING: if a page already has search results, they are just gonna be overwritten
"""
2023-05-26 08:11:36 +00:00
self.results[page] = search_result
def get_page_results(self, page: Type[Page]) -> "PageResults":
return PageResults(page, self.results.get(page, []))
def formated_generator(self, max_items_per_page: int = 10):
super().formated_generator()
i = 0
for page in self.results:
yield page
j = 0
for option in self.results[page]:
yield Option(i, option)
self._by_index[i] = option
2023-06-12 12:56:14 +00:00
self._page_by_index[i] = page
i += 1
j += 1
if j >= max_items_per_page:
break
class PageResults(Results):
def __init__(self, page: Type[Page], results: List[DatabaseObject]) -> None:
2023-06-12 12:56:14 +00:00
super().__init__()
self.page: Type[Page] = page
self.results: List[DatabaseObject] = results
def formated_generator(self, max_items_per_page: int = 10):
super().formated_generator()
i = 0
yield self.page
2023-05-26 08:11:36 +00:00
for option in self.results:
yield Option(i, option)
self._by_index[i] = option
2023-06-12 12:56:14 +00:00
self._page_by_index[i] = self.page
i += 1