brick/programs/BorderDemo.hs

86 lines
2.1 KiB
Haskell
Raw Normal View History

2015-06-28 22:15:55 +03:00
{-# LANGUAGE OverloadedStrings #-}
module Main where
import Control.Applicative ((<$>))
2015-06-28 22:25:21 +03:00
import Data.Monoid
2015-06-28 22:15:55 +03:00
import qualified Data.Text as T
import Graphics.Vty
import Brick.Main
import Brick.Util
import Brick.AttrMap
import Brick.Widgets.Core
import Brick.Widgets.Center
import Brick.Widgets.Border
import Brick.Widgets.Border.Style
styles :: [(T.Text, BorderStyle)]
styles =
[ ("ascii", ascii)
, ("unicode", unicode)
, ("unicode bold", unicodeBold)
, ("unicode rounded", unicodeRounded)
2015-06-28 22:31:44 +03:00
, ("custom", custom)
, ("from 'x'", borderStyleFromChar 'x')
2015-06-28 22:15:55 +03:00
]
2015-06-28 22:31:44 +03:00
custom :: BorderStyle
custom =
BorderStyle { bsCornerTL = '/'
, bsCornerTR = '\\'
, bsCornerBR = '/'
, bsCornerBL = '\\'
, bsIntersectionFull = '.'
, bsIntersectionL = '.'
, bsIntersectionR = '.'
, bsIntersectionT = '.'
, bsIntersectionB = '.'
, bsHorizontal = '*'
, bsVertical = '!'
}
2015-06-28 22:15:55 +03:00
borderDemos :: [Widget]
borderDemos = mkBorderDemo <$> styles
mkBorderDemo :: (T.Text, BorderStyle) -> Widget
mkBorderDemo (styleName, sty) =
withBorderStyle sty $
2015-06-28 22:25:21 +03:00
borderWithLabel "label" $
2015-06-28 22:15:55 +03:00
vLimit 5 $
2015-06-28 22:25:21 +03:00
vCenter $
txt $ " " <> styleName <> " style "
2015-06-28 22:15:55 +03:00
borderMappings :: [(AttrName, Attr)]
borderMappings =
[ (borderAttr, yellow `on` black)
, (vBorderAttr, green `on` red)
, (hBorderAttr, white `on` green)
, (hBorderLabelAttr, fg blue)
, (tlCornerAttr, bg red)
, (trCornerAttr, bg blue)
, (blCornerAttr, bg yellow)
, (brCornerAttr, bg green)
]
colorDemo :: Widget
colorDemo =
updateAttrMap (applyAttrMappings borderMappings) $
2015-06-28 22:15:55 +03:00
borderWithLabel "title" $
hLimit 20 $
vLimit 5 $
center $
2015-06-28 22:25:21 +03:00
"colors!"
2015-06-28 22:15:55 +03:00
ui :: Widget
ui =
hBox borderDemos
<=> hBorder
<=> colorDemo
2015-06-28 22:21:44 +03:00
<=> hBorderWithLabel "horizontal border label"
2015-06-28 22:21:58 +03:00
<=> (center "Left of vertical border"
<+> vBorder
<+> center "Right of vertical border")
2015-06-28 22:15:55 +03:00
main :: IO ()
main = simpleMain ui