diff --git a/ChangeLog.md b/ChangeLog.md index 7603d9e..e5673a8 100644 --- a/ChangeLog.md +++ b/ChangeLog.md @@ -4,6 +4,7 @@ - Bugfix: Display lifetime stats in report, not YTD - Force expected capitalization on player/goalie names - Don't show lifetime totals in report +- Sort players in YTD and lifetime reports by points ## 0.8.0 - Bugfix: removed quotation marks from goalie names in report diff --git a/src/Mtlstats/Report.hs b/src/Mtlstats/Report.hs index 323ae92..4f4684f 100644 --- a/src/Mtlstats/Report.hs +++ b/src/Mtlstats/Report.hs @@ -21,6 +21,7 @@ along with this program. If not, see . module Mtlstats.Report (report, gameDate) where +import Data.List (sortOn) import qualified Data.Map as M import Data.Maybe (fromMaybe, mapMaybe) import Lens.Micro ((^.)) @@ -135,7 +136,9 @@ yearToDateStatsReport :: Int -> ProgState -> [String] yearToDateStatsReport width s = let db = s^.database - playerStats = map (\p -> (p, p^.pYtd)) + playerStats = reverse + $ sortOn (psPoints . snd) + $ map (\p -> (p, p^.pYtd)) $ filter playerIsActive $ db^.dbPlayers @@ -151,7 +154,9 @@ lifetimeStatsReport :: Int -> ProgState -> [String] lifetimeStatsReport width s = let db = s^.database - playerStats = map (\p -> (p, p^.pLifetime)) + playerStats = reverse + $ sortOn (psPoints . snd) + $ map (\p -> (p, p^.pLifetime)) $ db^.dbPlayers goalieStats = map (\g -> (g, g^.gLifetime))