mirror of
https://github.com/ldericher/fftcgtool
synced 2025-01-15 15:02:59 +00:00
Create elemental decks
This commit is contained in:
parent
66d0979192
commit
0bf27770b3
3 changed files with 102 additions and 16 deletions
|
@ -1,5 +1,7 @@
|
||||||
import yaml
|
import yaml
|
||||||
|
|
||||||
|
from .ttsdeck import TTSDeck
|
||||||
|
|
||||||
_DictOfDicts = dict[str, dict[str, any]]
|
_DictOfDicts = dict[str, dict[str, any]]
|
||||||
|
|
||||||
|
|
||||||
|
@ -36,8 +38,9 @@ class CardDB(_DictOfDicts):
|
||||||
def make_deck(self, filters):
|
def make_deck(self, filters):
|
||||||
# filter codes by card criteria
|
# filter codes by card criteria
|
||||||
codes = [
|
codes = [
|
||||||
code
|
content["card"].code
|
||||||
for code, content in self.items()
|
for content in self.values()
|
||||||
if all([f(content["card"]) for f in filters])
|
if all([f(content["card"]) for f in filters])
|
||||||
]
|
]
|
||||||
return codes
|
|
||||||
|
return TTSDeck(codes, self)
|
||||||
|
|
77
fftcg/ttsdeck.py
Normal file
77
fftcg/ttsdeck.py
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
import json
|
||||||
|
|
||||||
|
from .carddb import CardDB
|
||||||
|
from .code import Code
|
||||||
|
|
||||||
|
|
||||||
|
class TTSDeck(list[dict[str, any]]):
|
||||||
|
def __init__(self, codes: list[Code], carddb: CardDB):
|
||||||
|
super().__init__([carddb[str(code)] for code in codes])
|
||||||
|
|
||||||
|
def __str__(self) -> str:
|
||||||
|
face_urls = list(set([entry["file"] for entry in self]))
|
||||||
|
|
||||||
|
custom_deck = {
|
||||||
|
str(i + 1): {
|
||||||
|
"NumWidth": "10",
|
||||||
|
"NumHeight": "7",
|
||||||
|
"FaceURL": url,
|
||||||
|
"BackURL": "http://cloud-3.steamusercontent.com/ugc/948455238665576576/85063172B8C340602E8D6C783A457122F53F7843/",
|
||||||
|
} for i, url in enumerate(face_urls)
|
||||||
|
}
|
||||||
|
|
||||||
|
custom_deck_inv = {
|
||||||
|
url: i + 1
|
||||||
|
for i, url in enumerate(face_urls)
|
||||||
|
}
|
||||||
|
|
||||||
|
common_dict = {
|
||||||
|
"Transform": {
|
||||||
|
"scaleX": 2.17822933,
|
||||||
|
"scaleY": 1.0,
|
||||||
|
"scaleZ": 2.17822933
|
||||||
|
},
|
||||||
|
|
||||||
|
"Locked": False,
|
||||||
|
"Grid": True,
|
||||||
|
"Snap": True,
|
||||||
|
"Autoraise": True,
|
||||||
|
"Sticky": True,
|
||||||
|
"Tooltip": True,
|
||||||
|
"GridProjection": False,
|
||||||
|
}
|
||||||
|
|
||||||
|
contained_objects = [
|
||||||
|
{
|
||||||
|
"Name": "Card",
|
||||||
|
"Nickname": entry["card"].name,
|
||||||
|
"Description": entry["card"].text,
|
||||||
|
|
||||||
|
"CardID": 100 * custom_deck_inv[entry["file"]] + entry["index"],
|
||||||
|
|
||||||
|
"Hands": True,
|
||||||
|
"SidewaysCard": False,
|
||||||
|
} | common_dict for entry in self
|
||||||
|
]
|
||||||
|
|
||||||
|
deck_ids = [
|
||||||
|
contained_object["CardID"]
|
||||||
|
for contained_object in contained_objects
|
||||||
|
]
|
||||||
|
|
||||||
|
jsondict = {"ObjectStates": [
|
||||||
|
{
|
||||||
|
"Name": "Deck",
|
||||||
|
"Nickname": "TODO Deck Name",
|
||||||
|
"Description": "TODO Deck Description",
|
||||||
|
|
||||||
|
"Hands": False,
|
||||||
|
"SidewaysCard": False,
|
||||||
|
|
||||||
|
"DeckIDs": deck_ids,
|
||||||
|
"CustomDeck": custom_deck,
|
||||||
|
"ContainedObjects": contained_objects,
|
||||||
|
} | common_dict
|
||||||
|
]}
|
||||||
|
|
||||||
|
return json.dumps(jsondict, indent=2)
|
6
main.py
6
main.py
|
@ -54,6 +54,12 @@ def main() -> None:
|
||||||
def opus_filter(card: fftcg.Card):
|
def opus_filter(card: fftcg.Card):
|
||||||
return card.code.opus == opus.number
|
return card.code.opus == opus.number
|
||||||
|
|
||||||
|
filters: list
|
||||||
|
if opus.number == "PR":
|
||||||
|
filters = [[opus_filter]]
|
||||||
|
|
||||||
|
else:
|
||||||
|
|
||||||
def element_filter(element: str):
|
def element_filter(element: str):
|
||||||
return lambda card: card.elements == [element]
|
return lambda card: card.elements == [element]
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue