Hot-keys on this page
r m x p toggle line displays
j k next/prev highlighted chunk
0 (zero) top of page
1 (one) first highlighted chunk
1"""LICENSE
2Copyright 2015 Hermann Krumrey <hermann@krumreyh.com>
4This file is part of toktokkie.
6toktokkie is free software: you can redistribute it and/or modify
7it under the terms of the GNU General Public License as published by
8the Free Software Foundation, either version 3 of the License, or
9(at your option) any later version.
11toktokkie is distributed in the hope that it will be useful,
12but WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
16You should have received a copy of the GNU General Public License
17along with toktokkie. If not, see <http://www.gnu.org/licenses/>.
18LICENSE"""
20from abc import ABC
21from typing import Dict
22from puffotter.os import listdir
23from toktokkie.metadata.book_series.components.BookVolume import BookVolume
24from toktokkie.metadata.base.MetadataBase import MetadataBase
27class BookSeriesExtras(MetadataBase, ABC):
28 """
29 Additional methods and attributes for book series metadata objects
30 """
32 @property
33 def volumes(self) -> Dict[int, BookVolume]:
34 """
35 :return: A list of book volumes for this book series
36 """
37 volumes = {} # type: Dict[int, BookVolume]
38 volume_files = listdir(self.directory_path, no_dirs=True)
40 for i, (_, volume_path) in enumerate(volume_files):
41 volume_num = i + 1
42 json_data = self.json["volumes"].get(str(volume_num), {"ids": {}})
43 volumes[i + 1] = BookVolume.from_json(
44 volume_num, volume_path, self.ids, json_data
45 )
46 return volumes
48 @volumes.setter
49 def volumes(self, volumes: Dict[int, BookVolume]):
50 """
51 Setter method for the volumes
52 :param volumes: The volumes to set
53 :return: None
54 """
55 self.json["volumes"] = {}
56 for i, volume in volumes.items():
57 self.json["volumes"][str(i)] = volume.json