module Matterhorn.Events.ThemeListOverlay where
import Prelude ()
import Matterhorn.Prelude
import qualified Graphics.Vty as Vty
import Matterhorn.Events.Keybindings
import Matterhorn.State.ThemeListOverlay
import Matterhorn.State.ListOverlay
import Matterhorn.Types
onEventThemeListOverlay :: Vty.Event -> MH ()
onEventThemeListOverlay :: Event -> MH ()
onEventThemeListOverlay =
MH Bool -> MH ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (MH Bool -> MH ()) -> (Event -> MH Bool) -> Event -> MH ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Lens' ChatState (ListOverlayState InternalTheme ())
-> (KeyConfig -> KeyHandlerMap) -> Event -> MH Bool
forall a b.
Lens' ChatState (ListOverlayState a b)
-> (KeyConfig -> KeyHandlerMap) -> Event -> MH Bool
onEventListOverlay ((TeamState -> f TeamState) -> ChatState -> f ChatState
Lens' ChatState TeamState
csCurrentTeam((TeamState -> f TeamState) -> ChatState -> f ChatState)
-> ((ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> TeamState -> f TeamState)
-> (ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> ChatState
-> f ChatState
forall b c a. (b -> c) -> (a -> b) -> a -> c
.(ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> TeamState -> f TeamState
Lens' TeamState (ListOverlayState InternalTheme ())
tsThemeListOverlay)
KeyConfig -> KeyHandlerMap
themeListOverlayKeybindings
themeListOverlayKeybindings :: KeyConfig -> KeyHandlerMap
themeListOverlayKeybindings :: KeyConfig -> KeyHandlerMap
themeListOverlayKeybindings = [KeyEventHandler] -> KeyConfig -> KeyHandlerMap
mkKeybindings [KeyEventHandler]
themeListOverlayKeyHandlers
themeListOverlayKeyHandlers :: [KeyEventHandler]
themeListOverlayKeyHandlers :: [KeyEventHandler]
themeListOverlayKeyHandlers =
[ KeyEvent -> Text -> MH () -> KeyEventHandler
mkKb KeyEvent
CancelEvent Text
"Close the theme list"
(Lens' ChatState (ListOverlayState InternalTheme ()) -> MH ()
forall a b. Lens' ChatState (ListOverlayState a b) -> MH ()
exitListOverlay ((TeamState -> f TeamState) -> ChatState -> f ChatState
Lens' ChatState TeamState
csCurrentTeam((TeamState -> f TeamState) -> ChatState -> f ChatState)
-> ((ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> TeamState -> f TeamState)
-> (ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> ChatState
-> f ChatState
forall b c a. (b -> c) -> (a -> b) -> a -> c
.(ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> TeamState -> f TeamState
Lens' TeamState (ListOverlayState InternalTheme ())
tsThemeListOverlay))
, KeyEvent -> Text -> MH () -> KeyEventHandler
mkKb KeyEvent
SearchSelectUpEvent Text
"Select the previous theme"
MH ()
themeListSelectUp
, KeyEvent -> Text -> MH () -> KeyEventHandler
mkKb KeyEvent
SearchSelectDownEvent Text
"Select the next theme"
MH ()
themeListSelectDown
, KeyEvent -> Text -> MH () -> KeyEventHandler
mkKb KeyEvent
PageDownEvent Text
"Page down in the theme list"
MH ()
themeListPageDown
, KeyEvent -> Text -> MH () -> KeyEventHandler
mkKb KeyEvent
PageUpEvent Text
"Page up in the theme list"
MH ()
themeListPageUp
, KeyEvent -> Text -> MH () -> KeyEventHandler
mkKb KeyEvent
ActivateListItemEvent Text
"Switch to the selected color theme"
(Lens' ChatState (ListOverlayState InternalTheme ()) -> MH ()
forall a b. Lens' ChatState (ListOverlayState a b) -> MH ()
listOverlayActivateCurrent ((TeamState -> f TeamState) -> ChatState -> f ChatState
Lens' ChatState TeamState
csCurrentTeam((TeamState -> f TeamState) -> ChatState -> f ChatState)
-> ((ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> TeamState -> f TeamState)
-> (ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> ChatState
-> f ChatState
forall b c a. (b -> c) -> (a -> b) -> a -> c
.(ListOverlayState InternalTheme ()
-> f (ListOverlayState InternalTheme ()))
-> TeamState -> f TeamState
Lens' TeamState (ListOverlayState InternalTheme ())
tsThemeListOverlay))
]