made single page options extend
This commit is contained in:
parent
8c01ee4198
commit
82e3146780
@ -9,7 +9,12 @@ def search_pages():
|
|||||||
print()
|
print()
|
||||||
print(search)
|
print(search)
|
||||||
|
|
||||||
search.choose(1)
|
search.choose(pages.Musify)
|
||||||
|
|
||||||
|
print()
|
||||||
|
print(search)
|
||||||
|
|
||||||
|
search.choose(0)
|
||||||
print(search)
|
print(search)
|
||||||
|
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@ class MultiPageOptions:
|
|||||||
self.max_displayed_options = max_displayed_options
|
self.max_displayed_options = max_displayed_options
|
||||||
self.option_digits: int = option_digits
|
self.option_digits: int = option_digits
|
||||||
|
|
||||||
|
self._length = 0
|
||||||
self._current_option_dict: Dict[Type[Page], Options] = defaultdict(lambda: Options())
|
self._current_option_dict: Dict[Type[Page], Options] = defaultdict(lambda: Options())
|
||||||
|
|
||||||
def __getitem__(self, key: Type[Page]):
|
def __getitem__(self, key: Type[Page]):
|
||||||
@ -24,7 +25,18 @@ class MultiPageOptions:
|
|||||||
def __setitem__(self, key: Type[Page], value: Options):
|
def __setitem__(self, key: Type[Page], value: Options):
|
||||||
self._current_option_dict[key] = value
|
self._current_option_dict[key] = value
|
||||||
|
|
||||||
|
self._length = 0
|
||||||
|
for key in self._current_option_dict:
|
||||||
|
self._length += 1
|
||||||
|
|
||||||
|
def __len__(self) -> int:
|
||||||
|
return self._length
|
||||||
|
|
||||||
def string_from_all_pages(self) -> str:
|
def string_from_all_pages(self) -> str:
|
||||||
|
if self._length == 1:
|
||||||
|
for key in self._current_option_dict:
|
||||||
|
return self.string_from_single_page(key)
|
||||||
|
|
||||||
lines: List[str] = []
|
lines: List[str] = []
|
||||||
|
|
||||||
page_name_fill = "-"
|
page_name_fill = "-"
|
||||||
@ -47,6 +59,10 @@ class MultiPageOptions:
|
|||||||
return "\n".join(lines)
|
return "\n".join(lines)
|
||||||
|
|
||||||
def choose_from_all_pages(self, index: int) -> Tuple[DatabaseObject, Type[Page]]:
|
def choose_from_all_pages(self, index: int) -> Tuple[DatabaseObject, Type[Page]]:
|
||||||
|
if self._length == 1:
|
||||||
|
for key in self._current_option_dict:
|
||||||
|
return self.choose_from_single_page(key, index), key
|
||||||
|
|
||||||
j = 0
|
j = 0
|
||||||
for page, options in self._current_option_dict.items():
|
for page, options in self._current_option_dict.items():
|
||||||
option_len = len(options)
|
option_len = len(options)
|
||||||
|
Loading…
Reference in New Issue
Block a user