mirror of
https://github.com/jtdaugherty/brick.git
synced 2024-12-29 08:55:13 +03:00
69 lines
1.7 KiB
Haskell
69 lines
1.7 KiB
Haskell
{-# LANGUAGE OverloadedStrings #-}
|
|
{-# LANGUAGE CPP #-}
|
|
module Main where
|
|
|
|
#if !(MIN_VERSION_base(4,11,0))
|
|
import Data.Monoid
|
|
#endif
|
|
import qualified Graphics.Vty as V
|
|
|
|
import qualified Brick.Main as M
|
|
import Brick.Types
|
|
( Widget
|
|
, BrickEvent(..)
|
|
)
|
|
import Brick.Widgets.Core
|
|
( padAll
|
|
, str
|
|
)
|
|
import qualified Brick.Widgets.Dialog as D
|
|
import qualified Brick.Widgets.Center as C
|
|
import qualified Brick.AttrMap as A
|
|
import Brick.Util (on, bg)
|
|
import qualified Brick.Types as T
|
|
|
|
data Choice = Red | Blue | Green
|
|
deriving Show
|
|
|
|
drawUI :: D.Dialog Choice -> [Widget ()]
|
|
drawUI d = [ui]
|
|
where
|
|
ui = D.renderDialog d $ C.hCenter $ padAll 1 $ str "This is the dialog body."
|
|
|
|
appEvent :: BrickEvent () e -> T.EventM () (D.Dialog Choice) ()
|
|
appEvent (VtyEvent ev) =
|
|
case ev of
|
|
V.EvKey V.KEsc [] -> M.halt
|
|
V.EvKey V.KEnter [] -> M.halt
|
|
_ -> D.handleDialogEvent ev
|
|
appEvent _ = return ()
|
|
|
|
initialState :: D.Dialog Choice
|
|
initialState = D.dialog (Just "Title") (Just (0, choices)) 50
|
|
where
|
|
choices = [ ("Red", Red)
|
|
, ("Blue", Blue)
|
|
, ("Green", Green)
|
|
]
|
|
|
|
theMap :: A.AttrMap
|
|
theMap = A.attrMap V.defAttr
|
|
[ (D.dialogAttr, V.white `on` V.blue)
|
|
, (D.buttonAttr, V.black `on` V.white)
|
|
, (D.buttonSelectedAttr, bg V.yellow)
|
|
]
|
|
|
|
theApp :: M.App (D.Dialog Choice) e ()
|
|
theApp =
|
|
M.App { M.appDraw = drawUI
|
|
, M.appChooseCursor = M.showFirstCursor
|
|
, M.appHandleEvent = appEvent
|
|
, M.appStartEvent = return ()
|
|
, M.appAttrMap = const theMap
|
|
}
|
|
|
|
main :: IO ()
|
|
main = do
|
|
d <- M.defaultMain theApp initialState
|
|
putStrLn $ "You chose: " <> show (D.dialogSelection d)
|