🎨 tidy up the summarization logic

This commit is contained in:
Tessa Kelly 2019-04-08 17:07:46 -07:00
parent df7f333b17
commit f86e907317

View File

@ -95,28 +95,16 @@ summarize (State state) panels =
in
case state of
Just current ->
case List.drop (current - 1) panels of
first :: second :: rest ->
if current > 0 then
case List.drop current panels of
currentPanel :: rest ->
Just
{ current = second
, previousPanel = Just first
, upcoming = List.drop (current + 1) indexedPanels
, previous = List.take current indexedPanels
}
{ current = currentPanel
, previousPanel =
if current > 0 then
List.head (List.drop (current - 1) panels)
else
Just
{ current = first
, previousPanel = Nothing
, upcoming = List.drop (current + 1) indexedPanels
, previous = List.take current indexedPanels
}
first :: [] ->
Just
{ current = first
, previousPanel = Nothing
Nothing
, upcoming = List.drop (current + 1) indexedPanels
, previous = List.take current indexedPanels
}