mtlstats/src/Mtlstats/Helpers/Player.hs

61 lines
1.7 KiB
Haskell
Raw Normal View History

2019-11-18 21:36:36 -05:00
{- |
mtlstats
Copyright (C) 1984, 1985, 2019, 2020, 2021 Rhéal Lamothe
2019-11-18 21:36:36 -05:00
<rheal.lamothe@gmail.com>
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or (at
your option) any later version.
This program is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <https://www.gnu.org/licenses/>.
-}
2020-01-03 22:01:09 -05:00
module Mtlstats.Helpers.Player (playerDetails, playerName) where
2019-11-18 21:36:36 -05:00
import Lens.Micro ((^.))
import Mtlstats.Format
import Mtlstats.Types
-- | Provides a detailed string describing a 'Player'
playerDetails :: Player -> String
playerDetails p = unlines $ top ++ [""] ++ table
where
top = labelTable
[ ( "Number", show $ p^.pNumber )
2020-01-04 12:10:19 -05:00
, ( "Name", playerName p )
2019-11-18 21:36:36 -05:00
, ( "Position", p^.pPosition )
]
table = numTable ["YTD", "Lifetime"] $ map
(\(label, lens) ->
(label, [p^.pYtd.lens, p^.pLifetime.lens]))
[ ( "Goals", psGoals )
, ( "Assists", psAssists )
, ( "Penalty mins", psPMin )
]
2020-01-03 22:01:09 -05:00
-- | Presents a modified version of the player's name indicating
-- whether or not they're a rookie
playerName :: Player -> String
playerName p = let
2020-01-11 01:27:01 -05:00
prefix = if p^.pActive
then ""
else "*"
2020-01-03 22:01:09 -05:00
suffix = if p^.pRookie
then "*"
else ""
2020-01-11 01:27:01 -05:00
in prefix ++ p^.pName ++ suffix