Merge pull request #7 from ethanrusz/creatures

Add creature list
This commit is contained in:
Em (Ethan) Ruszanowski 2024-02-15 18:27:27 -06:00 committed by GitHub
commit 9da4481750
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

21
app.py
View file

@ -25,13 +25,16 @@ class Run:
self.outside_power = moon.outside_max_power self.outside_power = moon.outside_max_power
def find_spawnlist(run: Run, creatures: list[Creature]) -> list[str]: def find_spawnlist(remaining_power: int, creatures: list[Creature]) -> list[str]:
""" """
Given a run, return all possible spwns for location. Given a run, return all possible spwns for location.
:param run: The current run object. :param remaining_power: The remaining power in the current location.
:return: A list of all creatures that could still spawn. :return: A list of all creatures that may still spawn.
""" """
return sorted(
[creature.name for creature in creatures if creature.power <= remaining_power]
)
def main(): def main():
@ -74,7 +77,7 @@ def main():
Creature("Spore Lizard", None, 1, 2, None), Creature("Spore Lizard", None, 1, 2, None),
Creature("Thumper", None, 2, 4, 4), Creature("Thumper", None, 2, 4, 4),
# Hybrid # Hybrid
Creature("Inside Ghost Girl ", None, 2, 1, None), Creature("Inside Ghost Girl", None, 2, 1, None),
Creature("Inside Masked", None, 1, 10, 4), Creature("Inside Masked", None, 1, 10, 4),
] ]
@ -97,7 +100,6 @@ def main():
with left_column: with left_column:
st.markdown("### Outside") st.markdown("### Outside")
st.info(f"Maximum power: {run.moon.outside_max_power}")
with st.form("outside"): with st.form("outside"):
for creature in outside_creatures: for creature in outside_creatures:
@ -126,8 +128,10 @@ def main():
outside_submit = st.form_submit_button("Calculate") outside_submit = st.form_submit_button("Calculate")
if outside_submit: if outside_submit:
st.info(f"Maximum power: {run.moon.outside_max_power}")
if run.outside_power >= 0: if run.outside_power >= 0:
st.toast(f"🌳 Outside power remaining: {run.outside_power}") st.warning(f"🌳 Outside power remaining: {run.outside_power}")
st.write(find_spawnlist(run.outside_power, outside_creatures))
else: else:
st.error( st.error(
f"Power level exceedes maximum possible for {run.moon.name}." f"Power level exceedes maximum possible for {run.moon.name}."
@ -135,7 +139,6 @@ def main():
with right_column: with right_column:
st.markdown("### Inside") st.markdown("### Inside")
st.info(f"Maximum power: {run.moon.inside_max_power}")
with st.form("inside"): with st.form("inside"):
for creature in inside_creatures: for creature in inside_creatures:
@ -164,8 +167,10 @@ def main():
inside_submit = st.form_submit_button("Calculate") inside_submit = st.form_submit_button("Calculate")
if inside_submit: if inside_submit:
st.info(f"Maximum power: {run.moon.inside_max_power}")
if run.inside_power >= 0: if run.inside_power >= 0:
st.toast(f"🏭 Inside power remaining: {run.inside_power}") st.warning(f"🏭 Inside power remaining: {run.inside_power}")
st.write(find_spawnlist(run.inside_power, inside_creatures))
else: else:
st.error( st.error(
f"Power level exceedes maximum possible for {run.moon.name}." f"Power level exceedes maximum possible for {run.moon.name}."