mirror of
https://github.com/jtdaugherty/brick.git
synced 2025-01-07 14:36:59 +03:00
Add support for easier focus management
This commit is contained in:
parent
a991cdc789
commit
a699e172ba
@ -2,7 +2,6 @@
|
||||
module Main where
|
||||
|
||||
import Data.Maybe
|
||||
import Data.Monoid
|
||||
import Graphics.Vty
|
||||
import System.Exit
|
||||
|
||||
@ -10,13 +9,36 @@ import Brick
|
||||
|
||||
data St =
|
||||
St { msg :: String
|
||||
, cursorName :: Name
|
||||
, focus :: FocusRing
|
||||
}
|
||||
|
||||
data FocusRing = FocusRingEmpty
|
||||
| FocusRingNonemtpy [Name] Int
|
||||
|
||||
focusRing :: [Name] -> FocusRing
|
||||
focusRing [] = FocusRingEmpty
|
||||
focusRing names = FocusRingNonemtpy names 0
|
||||
|
||||
focusNext :: FocusRing -> FocusRing
|
||||
focusNext FocusRingEmpty = FocusRingEmpty
|
||||
focusNext (FocusRingNonemtpy ns i) = FocusRingNonemtpy ns i'
|
||||
where
|
||||
i' = (i + 1) `mod` (length ns)
|
||||
|
||||
focusPrev :: FocusRing -> FocusRing
|
||||
focusPrev FocusRingEmpty = FocusRingEmpty
|
||||
focusPrev (FocusRingNonemtpy ns i) = FocusRingNonemtpy ns i'
|
||||
where
|
||||
i' = (i + (length ns) - 1) `mod` (length ns)
|
||||
|
||||
focusGetCurrent :: FocusRing -> Maybe Name
|
||||
focusGetCurrent FocusRingEmpty = Nothing
|
||||
focusGetCurrent (FocusRingNonemtpy ns i) = Just $ ns !! i
|
||||
|
||||
drawUI :: St -> Widget
|
||||
drawUI st =
|
||||
hBox [ vBox [ "-- header --" `withNamedCursor` (Name "bar", Location (0, 0))
|
||||
, txt $ "-- " <> msg st <> " --"
|
||||
hBox [ hLimit 25 $ vBox [ "-- header --"
|
||||
, (txt (msg st)) `withNamedCursor` (Name "bar", Location (length $ msg st, 0))
|
||||
] `withAttr` (fg red)
|
||||
, vBorder '|'
|
||||
, "stuff things" `withNamedCursor` (Name "foo", Location (0, 0))
|
||||
@ -26,21 +48,18 @@ handleEvent :: Event -> St -> Either ExitCode St
|
||||
handleEvent e st =
|
||||
case e of
|
||||
EvKey KEsc [] -> Left ExitSuccess
|
||||
EvKey (KChar '\t') [] -> Right $ st { cursorName = case cursorName st of
|
||||
Name "foo" -> Name "bar"
|
||||
_ -> Name "foo"
|
||||
}
|
||||
EvKey (KChar '\t') [] -> Right $ st { focus = focusNext $ focus st }
|
||||
EvKey (KChar c) [] -> Right $ st { msg = msg st ++ [c] }
|
||||
_ -> Right st
|
||||
|
||||
pickCursor :: St -> [CursorLocation] -> Maybe CursorLocation
|
||||
pickCursor st ls =
|
||||
listToMaybe $ filter (\cl -> cursorLocationName cl == Just (cursorName st)) ls
|
||||
listToMaybe $ filter (\cl -> cursorLocationName cl == (focusGetCurrent $ focus st)) ls
|
||||
|
||||
initialState :: St
|
||||
initialState =
|
||||
St { msg = ""
|
||||
, cursorName = Name "foo"
|
||||
, focus = focusRing [Name "foo", Name "bar"]
|
||||
}
|
||||
|
||||
main :: IO ()
|
||||
|
Loading…
Reference in New Issue
Block a user