summaryrefslogtreecommitdiff |
diff options
author | Nathanael Sensfelder <SpamShield0@MultiAgentSystems.org> | 2017-09-22 14:35:25 +0200 |
---|---|---|
committer | Nathanael Sensfelder <SpamShield0@MultiAgentSystems.org> | 2017-09-22 14:35:25 +0200 |
commit | 16abf2b1e598cb89a1d4251c2313e6f2e165f7da (patch) | |
tree | 403fcc9802772a54fe006f883addd4a8b3b49d16 /client/elm/battlemap/src/Update/EndTurn.elm | |
parent | 2d20dc042a386bc9f66bc5f535403227f9acf1b1 (diff) |
Clears up Update.elm a bit.
Diffstat (limited to 'client/elm/battlemap/src/Update/EndTurn.elm')
-rw-r--r-- | client/elm/battlemap/src/Update/EndTurn.elm | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/client/elm/battlemap/src/Update/EndTurn.elm b/client/elm/battlemap/src/Update/EndTurn.elm new file mode 100644 index 0000000..3fb479b --- /dev/null +++ b/client/elm/battlemap/src/Update/EndTurn.elm @@ -0,0 +1,48 @@ +module Update.EndTurn exposing (apply_to) + +import Dict + +import Battlemap +import Battlemap.Navigator + +import Model + +update_model : Model.Type -> Battlemap.Navigator.Type -> String -> Model.Type +update_model model nav char_id = + case (Dict.get char_id model.characters) of + Nothing -> model + (Just char) -> + {model | + navigator = Nothing, + battlemap = + (Battlemap.apply_to_all_tiles + (Battlemap.apply_to_tile_unsafe + (Battlemap.apply_to_tile_unsafe + model.battlemap + char.location + (\t -> {t | char_level = Nothing}) + ) + nav.current_location + (\t -> {t | char_level = (Just char_id)}) + ) + (Battlemap.Navigator.reset_navigation) + ), + characters = + (Dict.update + char_id + (\mc -> + case mc of + Nothing -> Nothing + (Just c) -> + (Just {c | location = nav.current_location}) + ) + model.characters + ) + } + +apply_to : Model.Type -> Model.Type +apply_to model = + case (model.navigator, model.selection) of + (_, Nothing) -> model + (Nothing, _) -> model + ((Just nav), (Just char_id)) -> (update_model model nav char_id) |