| 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)  | 


