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)
|
2015-06-29 07:28:55 +03:00
|
|
|
, ("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 =
|
2015-06-29 08:08:54 +03:00
|
|
|
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
|
|
|
|
2015-06-28 22:20:40 +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 ()
|
2015-06-28 22:48:39 +03:00
|
|
|
main = simpleMain ui
|