Remove redundant imports and fix typos (#275)

* remove redundant imports

* fix dodgy imports and exports

* fix LANGUAGE

* import combinator instances to SizeReq

* fix typos

* fix resizeFactor typos

* fix converter typos

* fix typos in handleSystemEvents and defaultWindowSize descriptions

* fix typo in SetOverlay description
This commit is contained in:
Ruslan Gadeev 2023-05-17 03:32:22 +03:00 committed by GitHub
parent ed81c987de
commit 67f747a61f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
67 changed files with 97 additions and 206 deletions

View File

@ -4,13 +4,9 @@
module Main where module Main where
import Control.Lens import Control.Lens
import Data.Maybe
import Data.Text (Text)
import Monomer import Monomer
import TextShow import TextShow
import qualified Monomer.Lens as L
newtype AppModel = AppModel { newtype AppModel = AppModel {
_clickCount :: Int _clickCount :: Int
} deriving (Eq, Show) } deriving (Eq, Show)

View File

@ -1,6 +1,6 @@
cabal-version: 1.12 cabal-version: 1.12
-- This file has been generated from package.yaml by hpack version 0.34.4. -- This file has been generated from package.yaml by hpack version 0.35.1.
-- --
-- see: https://github.com/sol/hpack -- see: https://github.com/sol/hpack

View File

@ -14,7 +14,7 @@ Lenses for the Common types.
module Monomer.Common.Lens where module Monomer.Common.Lens where
import Control.Lens.TH (abbreviatedFields, makeLensesWith, makePrisms) import Control.Lens.TH (abbreviatedFields, makeLensesWith)
import Monomer.Common.BasicTypes import Monomer.Common.BasicTypes

View File

@ -11,7 +11,7 @@ Helper functions creating, validating and merging size requirements.
{-# LANGUAGE Strict #-} {-# LANGUAGE Strict #-}
module Monomer.Core.SizeReq ( module Monomer.Core.SizeReq (
SizeReqUpdater(..), SizeReqUpdater,
clearExtra, clearExtra,
clearExtraW, clearExtraW,
clearExtraH, clearExtraH,
@ -41,9 +41,8 @@ import Data.Default
import Data.Maybe import Data.Maybe
import Monomer.Common import Monomer.Common
import Monomer.Core.StyleTypes import Monomer.Core.Style
import Monomer.Core.StyleUtil import Monomer.Core.StyleUtil
import Monomer.Core.Util
import Monomer.Helper import Monomer.Helper
import qualified Monomer.Core.Lens as L import qualified Monomer.Core.Lens as L

View File

@ -19,7 +19,6 @@ import GHC.Generics
import Monomer.Common import Monomer.Common
import Monomer.Graphics.Types import Monomer.Graphics.Types
import Monomer.Graphics.Util
{-| {-|
Represents a size requirement for a specific axis. Mainly used by stack and box, Represents a size requirement for a specific axis. Mainly used by stack and box,

View File

@ -22,7 +22,6 @@ import qualified Data.Map.Strict as M
import Monomer.Core.StyleTypes import Monomer.Core.StyleTypes
import Monomer.Graphics.ColorTable import Monomer.Graphics.ColorTable
import Monomer.Graphics.Types import Monomer.Graphics.Types
import Monomer.Graphics.Util
-- | Theme configuration for each state, plus clear/base color. -- | Theme configuration for each state, plus clear/base color.
data Theme = Theme { data Theme = Theme {

View File

@ -16,7 +16,7 @@ module Monomer.Core.Themes.BaseTheme (
baseTheme baseTheme
) where ) where
import Control.Lens ((&), (^.), (.~), (?~), non) import Control.Lens ((&), (.~), (?~), non)
import Data.Default import Data.Default
import Monomer.Core.Combinators import Monomer.Core.Combinators

View File

@ -15,7 +15,7 @@ module Monomer.Core.Themes.SampleThemes (
darkThemeColors darkThemeColors
) where ) where
import Control.Lens ((&), (^.), (.~), (?~), non) import Control.Lens ((&), (.~))
import Monomer.Core.ThemeTypes import Monomer.Core.ThemeTypes
import Monomer.Core.Themes.BaseTheme import Monomer.Core.Themes.BaseTheme
@ -284,4 +284,4 @@ gray07 = rgbHex "#9AA5B1"
gray08 = rgbHex "#CBD2D9" gray08 = rgbHex "#CBD2D9"
gray09 = rgbHex "#E4E7EB" gray09 = rgbHex "#E4E7EB"
gray10 = rgbHex "#F5F7FA" gray10 = rgbHex "#F5F7FA"
-} -}

View File

@ -13,18 +13,15 @@ Helper functions for Core types.
module Monomer.Core.Util where module Monomer.Core.Util where
import Control.Lens ((&), (^.), (^?), (.~), (?~), _Just) import Control.Lens ((^.), (^?), _Just)
import Data.Maybe import Data.Maybe
import Data.Text (Text)
import Data.Typeable (cast) import Data.Typeable (cast)
import Data.Sequence (Seq(..)) import Data.Sequence (Seq(..))
import qualified Data.Map.Strict as Map import qualified Data.Map.Strict as Map
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq
import qualified Data.Text as T
import Monomer.Common import Monomer.Common
import Monomer.Core.Style
import Monomer.Core.WidgetTypes import Monomer.Core.WidgetTypes
import Monomer.Helper import Monomer.Helper

View File

@ -12,7 +12,7 @@ Basic types and definitions for Widgets.
{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DeriveGeneric #-}
{-# LANGUAGE DerivingStrategies #-} {-# LANGUAGE DerivingStrategies #-}
{-# LANGUAGE ExistentialQuantification #-} {-# LANGUAGE ExistentialQuantification #-}
{-# Language GeneralizedNewtypeDeriving #-} {-# LANGUAGE GeneralizedNewtypeDeriving #-}
{-# LANGUAGE RankNTypes #-} {-# LANGUAGE RankNTypes #-}
{-# LANGUAGE Strict #-} {-# LANGUAGE Strict #-}
@ -182,8 +182,7 @@ data WidgetRequest s e
| StopTextInput | StopTextInput
-- | Sets a widget as the base target of future events. This is used by the -- | Sets a widget as the base target of future events. This is used by the
-- dropdown component to handle list events; this list, acting as an -- dropdown component to handle list events; this list, acting as an
-- overlay, is displayed on top of all other widgets. Tooltip uses it too. -- overlay, is displayed on top of all other widgets. Popup uses it too.
-- every other widget).
| SetOverlay WidgetId Path | SetOverlay WidgetId Path
-- | Removes the existing overlay. -- | Removes the existing overlay.
| ResetOverlay WidgetId | ResetOverlay WidgetId

View File

@ -16,14 +16,12 @@ module Monomer.Event.Core (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Data.Maybe (catMaybes, fromMaybe) import Data.Maybe (catMaybes)
import Data.Text (Text) import Data.Text (Text)
import qualified Data.Map.Strict as M
import qualified SDL import qualified SDL
import Monomer.Common import Monomer.Common
import Monomer.Event.Keyboard
import Monomer.Event.Types import Monomer.Event.Types
{-| {-|

View File

@ -16,7 +16,6 @@ module Monomer.Event.Lens where
import Control.Lens.TH (abbreviatedFields, makeLensesWith) import Control.Lens.TH (abbreviatedFields, makeLensesWith)
import Monomer.Common.Lens
import Monomer.Event.Types import Monomer.Event.Types
makeLensesWith abbreviatedFields ''InputStatus makeLensesWith abbreviatedFields ''InputStatus

View File

@ -29,12 +29,6 @@ module Monomer.Event.Util (
checkKeyboard checkKeyboard
) where ) where
import Data.Maybe (fromMaybe)
import qualified Data.Map as M
import Monomer.Event.Core
import Monomer.Event.Keyboard
import Monomer.Event.Types import Monomer.Event.Types
-- | Checks if Windows/Cmd key is pressed. -- | Checks if Windows/Cmd key is pressed.

View File

@ -19,7 +19,6 @@ import Control.Monad (foldM, when)
import Control.Lens ((^.)) import Control.Lens ((^.))
import Data.Default import Data.Default
import Data.Sequence (Seq)
import Data.Text (Text) import Data.Text (Text)
import System.IO.Unsafe import System.IO.Unsafe

View File

@ -16,27 +16,22 @@ Renderer based on the nanovg library.
module Monomer.Graphics.NanoVGRenderer (makeRenderer) where module Monomer.Graphics.NanoVGRenderer (makeRenderer) where
import Control.Lens ((&), (^.), (.~)) import Control.Lens ((^.))
import Control.Monad (foldM, forM_, unless, when) import Control.Monad (foldM, forM_, when)
import Data.Default import Data.Default
import Data.Functor ((<&>)) import Data.Functor ((<&>))
import Data.IORef import Data.IORef
import Data.List (foldl')
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (<|), (|>)) import Data.Sequence (Seq(..), (|>))
import Data.Set (Set(..)) import Data.Set (Set)
import Data.Text (Text) import Data.Text (Text)
import Data.Text.Foreign (withCStringLen)
import Foreign.C.Types (CFloat) import Foreign.C.Types (CFloat)
import Foreign.Ptr
import System.IO.Unsafe
import qualified Data.ByteString as BS import qualified Data.ByteString as BS
import qualified Data.Map as M import qualified Data.Map as M
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq
import qualified Data.Set as Set import qualified Data.Set as Set
import qualified Data.Text as T import qualified Data.Text as T
import qualified Data.Vector as V
import qualified NanoVG as VG import qualified NanoVG as VG
import qualified NanoVG.Internal.Image as VGI import qualified NanoVG.Internal.Image as VGI

View File

@ -29,7 +29,7 @@ import Control.Lens ((&), (^.), (^?), (+~), ix, non)
import Data.Default import Data.Default
import Data.List (foldl') import Data.List (foldl')
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (<|), (|>)) import Data.Sequence (Seq(..), (<|))
import Data.Text (Text) import Data.Text (Text)
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq

View File

@ -14,9 +14,9 @@ Core glue for running an application.
{-# LANGUAGE Strict #-} {-# LANGUAGE Strict #-}
module Monomer.Main.Core ( module Monomer.Main.Core (
AppEventResponse(..), AppEventResponse,
AppEventHandler(..), AppEventHandler,
AppUIBuilder(..), AppUIBuilder,
startApp startApp
) where ) where
@ -24,7 +24,6 @@ import Control.Concurrent
import Control.Concurrent.STM.TChan (TChan, newTChanIO, readTChan, writeTChan) import Control.Concurrent.STM.TChan (TChan, newTChanIO, readTChan, writeTChan)
import Control.Exception import Control.Exception
import Control.Lens ((&), (^.), (.=), (.~), _2, use) import Control.Lens ((&), (^.), (.=), (.~), _2, use)
import Control.Monad (unless, void, when)
import Control.Monad.Extra import Control.Monad.Extra
import Control.Monad.State import Control.Monad.State
import Control.Monad.STM (atomically) import Control.Monad.STM (atomically)
@ -32,7 +31,6 @@ import Data.Default
import Data.Either (isLeft) import Data.Either (isLeft)
import Data.Maybe (fromMaybe, fromJust, isJust) import Data.Maybe (fromMaybe, fromJust, isJust)
import Data.Map (Map) import Data.Map (Map)
import Data.List (foldl')
import Data.Text (Text) import Data.Text (Text)
import Data.Time import Data.Time
import Data.Time.Clock.POSIX (utcTimeToPOSIXSeconds) import Data.Time.Clock.POSIX (utcTimeToPOSIXSeconds)

View File

@ -27,18 +27,18 @@ module Monomer.Main.Handlers (
import Control.Concurrent.Async (async) import Control.Concurrent.Async (async)
import Control.Lens import Control.Lens
((&), (^.), (^?), (.~), (?~), (%~), (.=), (?=), (%=), (%%~), _Just, _1, _2, ix, at, use) ((&), (^.), (.~), (?~), (%~), (.=), (?=), (%=), (%%~), _Just, _1, at, use)
import Control.Monad.STM (atomically) import Control.Monad.STM (atomically)
import Control.Concurrent.STM.TChan (TChan, newTChanIO, readTChan, writeTChan) import Control.Concurrent.STM.TChan (TChan, newTChanIO, readTChan, writeTChan)
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Monad import Control.Monad
import Control.Monad.IO.Class import Control.Monad.IO.Class
import Data.Default import Data.Default
import Data.Foldable (fold, toList) import Data.Foldable (toList)
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (|>)) import Data.Sequence (Seq(..), (|>))
import Data.Text (Text) import Data.Text (Text)
import Data.Typeable (Typeable, typeOf) import Data.Typeable (Typeable)
import SDL (($=)) import SDL (($=))
import qualified Data.Map as Map import qualified Data.Map as Map
@ -66,7 +66,7 @@ for unit testing purposes.
type HandlerStep s e = (WidgetEnv s e, WidgetNode s e, Seq (WidgetRequest s e)) type HandlerStep s e = (WidgetEnv s e, WidgetNode s e, Seq (WidgetRequest s e))
{-| {-|
Processes a list of SystemEvents dispatching each of the to the corresponding Processes a list of SystemEvents dispatching each to the corresponding
widget based on the current root. At each step the root may change, new events widget based on the current root. At each step the root may change, new events
may be generated (which will be processed interleaved with the list of events) may be generated (which will be processed interleaved with the list of events)
and this is handled before returning the latest "HandlerStep". and this is handled before returning the latest "HandlerStep".
@ -76,7 +76,7 @@ handleSystemEvents
=> WidgetEnv s e -- ^ The initial widget environment. => WidgetEnv s e -- ^ The initial widget environment.
-> WidgetNode s e -- ^ The initial widget root. -> WidgetNode s e -- ^ The initial widget root.
-> [SystemEvent] -- ^ The starting list of events. -> [SystemEvent] -- ^ The starting list of events.
-> m (HandlerStep s e) -- ^ The resulting "HandlerStep." -> m (HandlerStep s e) -- ^ The resulting "HandlerStep".
handleSystemEvents wenv widgetRoot baseEvents = nextStep where handleSystemEvents wenv widgetRoot baseEvents = nextStep where
mainBtn = wenv ^. L.mainButton mainBtn = wenv ^. L.mainButton
reduceEvt curStep evt = do reduceEvt curStep evt = do

View File

@ -23,12 +23,10 @@ module Monomer.Main.Platform (
) where ) where
import Control.Exception (finally) import Control.Exception (finally)
import Control.Monad (void)
import Control.Monad.Extra (whenJust) import Control.Monad.Extra (whenJust)
import Control.Monad.State import Control.Monad.State
import Data.Maybe import Data.Maybe
import Data.Text (Text) import Data.Text (Text)
import Data.Word
import Foreign (alloca, peek) import Foreign (alloca, peek)
import Foreign.C (peekCString, withCString) import Foreign.C (peekCString, withCString)
import Foreign.C.Types import Foreign.C.Types
@ -52,7 +50,7 @@ import Monomer.Main.Types
foreign import ccall unsafe "initGlew" glewInit :: IO CInt foreign import ccall unsafe "initGlew" glewInit :: IO CInt
foreign import ccall unsafe "initDpiAwareness" initDpiAwareness :: IO CInt foreign import ccall unsafe "initDpiAwareness" initDpiAwareness :: IO CInt
-- | Default window size if not is specified. -- | Default window size if not specified.
defaultWindowSize :: (Int, Int) defaultWindowSize :: (Int, Int)
defaultWindowSize = (800, 600) defaultWindowSize = (800, 600)

View File

@ -30,7 +30,6 @@ import Data.Typeable (Typeable)
import Data.Sequence (Seq) import Data.Sequence (Seq)
import GHC.Generics import GHC.Generics
import qualified Data.Map as M
import qualified SDL import qualified SDL
import qualified SDL.Raw.Types as SDLR import qualified SDL.Raw.Types as SDLR

View File

@ -13,17 +13,14 @@ change and clipboard requests.
module Monomer.Main.UserUtil where module Monomer.Main.UserUtil where
import Control.Applicative ((<|>))
import Control.Lens import Control.Lens
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text)
import Monomer.Widgets.Composite import Monomer.Widgets.Composite
import Monomer.Widgets.Singles.Spacer import Monomer.Widgets.Singles.Spacer
import qualified Monomer.Core.Lens as L import qualified Monomer.Core.Lens as L
import qualified Monomer.Main.Lens as L
{-# DEPRECATED setFocusOnKey "Use SetFocusOnKey instead (wenv argument should be removed)." #-} {-# DEPRECATED setFocusOnKey "Use SetFocusOnKey instead (wenv argument should be removed)." #-}
{-| {-|

View File

@ -14,13 +14,9 @@ Helper functions for the Main module.
module Monomer.Main.Util where module Monomer.Main.Util where
import Control.Applicative ((<|>))
import Control.Concurrent.STM.TChan import Control.Concurrent.STM.TChan
import Control.Lens ((&), (^.), (.=), (%=), ix, at, non, use, _1) import Control.Lens ((^.), (.=), at, non, use)
import Control.Monad.Extra
import Control.Monad.State
import Data.Default import Data.Default
import Data.Maybe
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq
import qualified Data.Map as Map import qualified Data.Map as Map
@ -29,9 +25,7 @@ import qualified SDL
import Monomer.Core import Monomer.Core
import Monomer.Event import Monomer.Event
import Monomer.Helper (headMay) import Monomer.Helper (headMay)
import Monomer.Main.Platform
import Monomer.Main.Types import Monomer.Main.Types
import Monomer.Widgets.Util.Widget
import qualified Monomer.Core.Lens as L import qualified Monomer.Core.Lens as L
import qualified Monomer.Main.Lens as L import qualified Monomer.Main.Lens as L

View File

@ -17,7 +17,7 @@ module Monomer.Main.WidgetTask (handleWidgetTasks) where
import Control.Concurrent.Async (poll) import Control.Concurrent.Async (poll)
import Control.Concurrent.STM.TChan (tryReadTChan) import Control.Concurrent.STM.TChan (tryReadTChan)
import Control.Exception.Base import Control.Exception.Base
import Control.Lens ((&), (^.), (.=), use) import Control.Lens ((^.), (.=), use)
import Control.Monad.Extra import Control.Monad.Extra
import Control.Monad.IO.Class import Control.Monad.IO.Class
import Control.Monad.STM (atomically) import Control.Monad.STM (atomically)

View File

@ -30,11 +30,10 @@ module Monomer.Widgets.Animation.Fade (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (.~), (%~), at) import Control.Lens ((&), (^.), (.~))
import Control.Monad (when) import Control.Monad (when)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text)
import Data.Typeable (cast) import Data.Typeable (cast)
import GHC.Generics import GHC.Generics

View File

@ -33,7 +33,7 @@ module Monomer.Widgets.Animation.Slide (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (.~), (%~), at) import Control.Lens ((&), (^.), (.~))
import Control.Monad (when) import Control.Monad (when)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
@ -156,7 +156,7 @@ animSlideOut
-> WidgetNode s e -- ^ The created animation container. -> WidgetNode s e -- ^ The created animation container.
animSlideOut managed = animSlideOut_ def managed animSlideOut managed = animSlideOut_ def managed
-- | Animates a widget to the the provided direction from visible to not -- | Animates a widget to the provided direction from visible to not
-- visible (defaults to left). Accepts config. -- visible (defaults to left). Accepts config.
animSlideOut_ animSlideOut_
:: WidgetEvent e :: WidgetEvent e

View File

@ -66,14 +66,13 @@ module Monomer.Widgets.Composite (
import Debug.Trace import Debug.Trace
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Exception (AssertionFailed(..), throw) import Control.Lens (ALens', (&), (^.), (.~), (%~), (<>~))
import Control.Lens (ALens', (&), (^.), (^?), (.~), (%~), (<>~), at, ix, non)
import Control.Monad (when) import Control.Monad (when)
import Data.Default import Data.Default
import Data.List (foldl') import Data.List (foldl')
import Data.Map.Strict (Map) import Data.Map.Strict (Map)
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (|>), (<|), fromList) import Data.Sequence (Seq(..), (|>), (<|))
import Data.Typeable (Typeable, cast, typeOf) import Data.Typeable (Typeable, cast, typeOf)
import qualified Data.Map.Strict as M import qualified Data.Map.Strict as M

View File

@ -49,11 +49,10 @@ module Monomer.Widgets.Container (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Exception (AssertionFailed(..), throw) import Control.Lens ((&), (^.), (.~), (%~), (<>~))
import Control.Lens ((&), (^.), (^?), (.~), (%~), (<>~), _Just)
import Control.Monad import Control.Monad
import Data.Default import Data.Default
import Data.Foldable (fold, foldl') import Data.Foldable (foldl')
import Data.Maybe import Data.Maybe
import Data.Map.Strict (Map) import Data.Map.Strict (Map)
import Data.Typeable (Typeable) import Data.Typeable (Typeable)

View File

@ -40,18 +40,15 @@ module Monomer.Widgets.Containers.Alert (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (.~), (%~)) import Control.Lens ((&), (.~))
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text) import Data.Text (Text)
import qualified Data.Sequence as Seq
import Monomer.Core import Monomer.Core
import Monomer.Core.Combinators import Monomer.Core.Combinators
import Monomer.Widgets.Composite import Monomer.Widgets.Composite
import Monomer.Widgets.Container
import Monomer.Widgets.Containers.Box import Monomer.Widgets.Containers.Box
import Monomer.Widgets.Containers.BoxShadow import Monomer.Widgets.Containers.BoxShadow
import Monomer.Widgets.Containers.Keystroke import Monomer.Widgets.Containers.Keystroke

View File

@ -21,10 +21,8 @@ module Monomer.Widgets.Containers.Base.LabeledItem (
labeledItem labeledItem
) where ) where
import Control.Applicative ((<|>))
import Data.Default import Data.Default
import Control.Lens ((&), (^.), (^?), (^?!), (.~), (<>~), ix) import Control.Lens ((&), (^.), (^?!), (.~), (<>~), ix)
import Data.Maybe
import Data.Sequence ((|>)) import Data.Sequence ((|>))
import Data.Text (Text) import Data.Text (Text)
@ -36,7 +34,6 @@ import Monomer.Core.Combinators as Cmb
import Monomer.Widgets.Container import Monomer.Widgets.Container
import Monomer.Widgets.Containers.Stack import Monomer.Widgets.Containers.Stack
import Monomer.Widgets.Singles.Label import Monomer.Widgets.Singles.Label
import Monomer.Widgets.Singles.Spacer
import qualified Monomer.Lens as L import qualified Monomer.Lens as L

View File

@ -39,7 +39,7 @@ module Monomer.Widgets.Containers.Draggable (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (^?!), (.~), _Just, _1, _2, at, ix) import Control.Lens ((&), (^.), (^?!), (.~), _Just, _2)
import Control.Monad (forM_, when) import Control.Monad (forM_, when)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe

View File

@ -36,7 +36,6 @@ module Monomer.Widgets.Containers.DropTarget (
) where ) where
import Control.Lens ((&), (^.), (.~)) import Control.Lens ((&), (^.), (.~))
import Control.Monad (when)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Typeable (cast) import Data.Typeable (cast)

View File

@ -51,14 +51,13 @@ module Monomer.Widgets.Containers.Dropdown (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens (ALens', (&), (^.), (^?), (^?!), (.~), (%~), (<>~), _Just, ix, non) import Control.Lens (ALens', (&), (^.), (^?!), (.~), (%~), (<>~), ix, non)
import Control.Monad import Control.Monad
import Data.Default import Data.Default
import Data.List (foldl') import Data.List (foldl')
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (<|), (|>)) import Data.Sequence (Seq(..), (|>))
import Data.Text (Text) import Data.Typeable (Proxy, cast, typeRep)
import Data.Typeable (Typeable, Proxy, cast, typeRep)
import GHC.Generics import GHC.Generics
import TextShow import TextShow
@ -67,7 +66,6 @@ import qualified Data.Sequence as Seq
import Monomer.Helper import Monomer.Helper
import Monomer.Widgets.Container import Monomer.Widgets.Container
import Monomer.Widgets.Containers.SelectList import Monomer.Widgets.Containers.SelectList
import Monomer.Widgets.Singles.Label
import qualified Monomer.Lens as L import qualified Monomer.Lens as L

View File

@ -79,10 +79,10 @@ module Monomer.Widgets.Containers.Keystroke (
import Debug.Trace (traceShow) import Debug.Trace (traceShow)
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (^..), (.~), (%~), _1, at, folded) import Control.Lens ((&), (^.), (^..), (.~), (%~), _1, folded)
import Control.Lens.TH (abbreviatedFields, makeLensesWith) import Control.Lens.TH (abbreviatedFields, makeLensesWith)
import Data.Bifunctor (first) import Data.Bifunctor (first)
import Data.Char (chr, isAscii, isPrint, ord) import Data.Char (isAscii, isPrint, ord)
import Data.Default import Data.Default
import Data.List (foldl') import Data.List (foldl')
import Data.Set (Set) import Data.Set (Set)

View File

@ -52,7 +52,7 @@ module Monomer.Widgets.Containers.Scroll (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens (ALens', (&), (^.), (.~), (^?), (^?!), (<>~), (%~), _Just, cloneLens, ix) import Control.Lens (ALens', (&), (^.), (.~), (^?), (^?!), (<>~), _Just, cloneLens, ix)
import Control.Monad import Control.Monad
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe

View File

@ -46,25 +46,20 @@ module Monomer.Widgets.Containers.SelectList (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens (ALens', (&), (^.), (^?), (^?!), (.~), (%~), (?~), (<>~), at, ix, non, _Just) import Control.Lens (ALens', (&), (^.), (.~), (%~), at, ix)
import Control.Monad (when)
import Data.Default import Data.Default
import Data.List (foldl') import Data.List (foldl')
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (<|), (|>)) import Data.Sequence (Seq(..), (|>))
import Data.Text (Text)
import Data.Typeable (Typeable, Proxy, cast, typeRep) import Data.Typeable (Typeable, Proxy, cast, typeRep)
import TextShow import TextShow
import qualified Data.Map as Map
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq
import Monomer.Widgets.Container import Monomer.Widgets.Container
import Monomer.Widgets.Containers.Box import Monomer.Widgets.Containers.Box
import Monomer.Widgets.Containers.Scroll import Monomer.Widgets.Containers.Scroll
import Monomer.Widgets.Containers.Stack import Monomer.Widgets.Containers.Stack
import Monomer.Widgets.Singles.Label
import Monomer.Widgets.Singles.Spacer
import qualified Monomer.Lens as L import qualified Monomer.Lens as L

View File

@ -45,7 +45,6 @@ import Control.Applicative ((<|>))
import Control.Lens (ALens', (&), (^.), (.~), (<>~)) import Control.Lens (ALens', (&), (^.), (.~), (<>~))
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Tuple (swap)
import GHC.Generics import GHC.Generics
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq

View File

@ -51,12 +51,11 @@ module Monomer.Widgets.Containers.Stack (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (.~), (%~)) import Control.Lens ((&), (.~), (%~))
import Data.Default import Data.Default
import Data.Foldable (toList)
import Data.List (foldl') import Data.List (foldl')
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (<|), (|>)) import Data.Sequence (Seq(..), (|>))
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq

View File

@ -40,10 +40,8 @@ module Monomer.Widgets.Containers.ThemeSwitch (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Monad (when) import Control.Lens ((&), (^.), (.~))
import Control.Lens ((&), (^.), (.~), (%~), at)
import Data.Default import Data.Default
import Data.Maybe
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq

View File

@ -34,7 +34,7 @@ module Monomer.Widgets.Containers.Tooltip (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (.~), (%~), at) import Control.Lens ((&), (^.), (.~))
import Control.Monad (forM_, when) import Control.Monad (forM_, when)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe

View File

@ -38,12 +38,12 @@ module Monomer.Widgets.Containers.ZStack (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (^?), (.~), (%~), (?~), at, ix) import Control.Lens ((&), (^.), (^?), (.~), (%~), at, ix)
import Control.Monad (forM_, void, when) import Control.Monad (void, when)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.List (foldl', any) import Data.List (foldl')
import Data.Sequence (Seq(..), (<|), (|>)) import Data.Sequence (Seq(..), (|>))
import GHC.Generics import GHC.Generics
import qualified Data.Map.Strict as M import qualified Data.Map.Strict as M

View File

@ -39,13 +39,12 @@ module Monomer.Widgets.Single (
createSingle createSingle
) where ) where
import Control.Exception (AssertionFailed(..), throw) import Control.Lens ((&), (^.), (.~), (%~))
import Control.Lens ((&), (^.), (^?), (.~), (%~), _Just)
import Control.Monad (when) import Control.Monad (when)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (|>)) import Data.Sequence (Seq(..), (|>))
import Data.Typeable (Typeable, cast) import Data.Typeable (Typeable)
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq

View File

@ -60,9 +60,9 @@ Configuration options for button:
- 'multiline': if text may be split in multiple lines. - 'multiline': if text may be split in multiple lines.
- 'maxLines': maximum number of text lines to show. - 'maxLines': maximum number of text lines to show.
- 'ignoreTheme': whether to load default style from theme or start empty. - 'ignoreTheme': whether to load default style from theme or start empty.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
- 'resizeFactorW': flexibility to have more or less horizontal spaced assigned. - 'resizeFactorW': flexibility to have more or less horizontal space assigned.
- 'resizeFactorH': flexibility to have more or less vertical spaced assigned. - 'resizeFactorH': flexibility to have more or less vertical space assigned.
- 'onFocus': event to raise when focus is received. - 'onFocus': event to raise when focus is received.
- 'onFocusReq': 'WidgetRequest' to generate when focus is received. - 'onFocusReq': 'WidgetRequest' to generate when focus is received.
- 'onBlur': event to raise when focus is lost. - 'onBlur': event to raise when focus is lost.

View File

@ -43,8 +43,6 @@ import Control.Monad
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import qualified Data.Sequence as Seq
import Monomer.Widgets.Single import Monomer.Widgets.Single
import qualified Monomer.Lens as L import qualified Monomer.Lens as L

View File

@ -39,12 +39,10 @@ module Monomer.Widgets.Singles.ColorPicker (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (.~), ALens', abbreviatedFields, makeLensesWith) import Control.Lens (ALens')
import Data.ByteString (ByteString)
import Data.ByteString.Builder (Builder, toLazyByteString) import Data.ByteString.Builder (Builder, toLazyByteString)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text)
import qualified Data.ByteString.Lazy as BL import qualified Data.ByteString.Lazy as BL
import qualified Data.ByteString.Builder as B import qualified Data.ByteString.Builder as B

View File

@ -35,10 +35,8 @@ module Monomer.Widgets.Singles.ColorPopup (
colorPopupV_ colorPopupV_
) where ) where
import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (.~), (?~), ALens', abbreviatedFields, makeLensesWith, non) import Control.Lens ((&), (^.), (.~), (?~), ALens', abbreviatedFields, makeLensesWith, non)
import Data.Default import Data.Default
import Data.Text (Text)
import Monomer.Core.Combinators import Monomer.Core.Combinators
import Monomer.Graphics.Types import Monomer.Graphics.Types
@ -46,7 +44,6 @@ import Monomer.Graphics.Types
import Monomer.Widgets.Composite import Monomer.Widgets.Composite
import Monomer.Widgets.Containers.BoxShadow import Monomer.Widgets.Containers.BoxShadow
import Monomer.Widgets.Containers.Popup import Monomer.Widgets.Containers.Popup
import Monomer.Widgets.Containers.Stack
import Monomer.Widgets.Singles.ColorPicker import Monomer.Widgets.Singles.ColorPicker
import Monomer.Widgets.Singles.ToggleButton import Monomer.Widgets.Singles.ToggleButton

View File

@ -86,7 +86,7 @@ defaultDateDelim :: Char
defaultDateDelim = '/' defaultDateDelim = '/'
{-| {-|
Converter to and form the Day type of the time library. To use types other than Converter to and from the Day type of the time library. To use types other than
Day of said library, this typeclass needs to be implemented. Day of said library, this typeclass needs to be implemented.
--} --}
class (Eq a, Ord a, Show a, Typeable a) => DayConverter a where class (Eq a, Ord a, Show a, Typeable a) => DayConverter a where

View File

@ -39,10 +39,8 @@ module Monomer.Widgets.Singles.Dial (
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens (ALens', (&), (^.), (.~), (<>~)) import Control.Lens (ALens', (&), (^.), (.~), (<>~))
import Control.Monad
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text)
import Data.Typeable (Typeable, typeOf) import Data.Typeable (Typeable, typeOf)
import GHC.Generics import GHC.Generics
import TextShow import TextShow

View File

@ -27,10 +27,8 @@ module Monomer.Widgets.Singles.ExternalLink (
externalLink_ externalLink_
) where ) where
import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (.~)) import Control.Lens ((&), (^.), (.~))
import Data.Default import Data.Default
import Data.Maybe
import Data.Text (Text) import Data.Text (Text)
import System.Process (callCommand) import System.Process (callCommand)
@ -50,9 +48,9 @@ Configuration options for externalLink:
- 'ellipsis': if ellipsis should be used for overflown text. - 'ellipsis': if ellipsis should be used for overflown text.
- 'multiline': if text may be split in multiple lines. - 'multiline': if text may be split in multiple lines.
- 'maxLines': maximum number of text lines to show. - 'maxLines': maximum number of text lines to show.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
- 'resizeFactorW': flexibility to have more or less horizontal spaced assigned. - 'resizeFactorW': flexibility to have more or less horizontal space assigned.
- 'resizeFactorH': flexibility to have more or less vertical spaced assigned. - 'resizeFactorH': flexibility to have more or less vertical space assigned.
- 'onFocus': event to raise when focus is received. - 'onFocus': event to raise when focus is received.
- 'onFocusReq': 'WidgetRequest' to generate when focus is received. - 'onFocusReq': 'WidgetRequest' to generate when focus is received.
- 'onBlur': event to raise when focus is lost. - 'onBlur': event to raise when focus is lost.

View File

@ -43,14 +43,12 @@ import Codec.Picture (DynamicImage, Image(..))
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Concurrent import Control.Concurrent
import Control.Exception (try) import Control.Exception (try)
import Control.Lens ((&), (^.), (.~), (%~), (?~), at) import Control.Lens ((&), (^.), (.~), (?~), at)
import Control.Monad (when) import Control.Monad (when)
import Data.ByteString (ByteString) import Data.ByteString (ByteString)
import Data.Char (toLower)
import Data.Default import Data.Default
import Data.Map.Strict (Map) import Data.Map.Strict (Map)
import Data.Maybe import Data.Maybe
import Data.List (isPrefixOf)
import Data.Text (Text) import Data.Text (Text)
import Data.Typeable (cast) import Data.Typeable (cast)
import Data.Vector.Storable.ByteString (vectorToByteString) import Data.Vector.Storable.ByteString (vectorToByteString)

View File

@ -58,9 +58,9 @@ Configuration options for label.
- 'multiline': if text may be split in multiple lines. - 'multiline': if text may be split in multiple lines.
- 'maxLines': maximum number of text lines to show. - 'maxLines': maximum number of text lines to show.
- 'ignoreTheme': whether to load default style from theme or start empty. - 'ignoreTheme': whether to load default style from theme or start empty.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
- 'resizeFactorW': flexibility to have more or less horizontal spaced assigned. - 'resizeFactorW': flexibility to have more or less horizontal space assigned.
- 'resizeFactorH': flexibility to have more or less vertical spaced assigned. - 'resizeFactorH': flexibility to have more or less vertical space assigned.
-} -}
data LabelCfg s e = LabelCfg { data LabelCfg s e = LabelCfg {
_lscIgnoreTheme :: Maybe Bool, _lscIgnoreTheme :: Maybe Bool,

View File

@ -35,21 +35,16 @@ module Monomer.Widgets.Singles.LabeledCheckbox (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens (ALens', (&), (^.), (.~)) import Control.Lens (ALens')
import Control.Monad
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text) import Data.Text (Text)
import qualified Data.Sequence as Seq
import Monomer.Widgets.Containers.Base.LabeledItem import Monomer.Widgets.Containers.Base.LabeledItem
import Monomer.Widgets.Single import Monomer.Widgets.Single
import Monomer.Widgets.Singles.Checkbox import Monomer.Widgets.Singles.Checkbox
import Monomer.Widgets.Singles.Label import Monomer.Widgets.Singles.Label
import qualified Monomer.Lens as L
{-| {-|
Configuration options for labeledCheckbox: Configuration options for labeledCheckbox:
@ -67,9 +62,9 @@ Configuration options for labeledCheckbox:
- 'ellipsis': if ellipsis should be used for overflown text. - 'ellipsis': if ellipsis should be used for overflown text.
- 'multiline': if text may be split in multiple lines. - 'multiline': if text may be split in multiple lines.
- 'maxLines': maximum number of text lines to show. - 'maxLines': maximum number of text lines to show.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
- 'resizeFactorW': flexibility for more or less horizontal spaced assigned. - 'resizeFactorW': flexibility for more or less horizontal space assigned.
- 'resizeFactorH': flexibility for more or less vertical spaced assigned. - 'resizeFactorH': flexibility for more or less vertical space assigned.
- Checkbox related - Checkbox related

View File

@ -37,22 +37,18 @@ module Monomer.Widgets.Singles.LabeledRadio (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens (ALens', (&), (^.), (.~)) import Control.Lens (ALens')
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text) import Data.Text (Text)
import Data.Typeable (typeOf) import Data.Typeable (typeOf)
import TextShow import TextShow
import qualified Data.Sequence as Seq
import Monomer.Widgets.Containers.Base.LabeledItem import Monomer.Widgets.Containers.Base.LabeledItem
import Monomer.Widgets.Single import Monomer.Widgets.Single
import Monomer.Widgets.Singles.Label import Monomer.Widgets.Singles.Label
import Monomer.Widgets.Singles.Radio import Monomer.Widgets.Singles.Radio
import qualified Monomer.Lens as L
{-| {-|
Configuration options for labeledRadio: Configuration options for labeledRadio:
@ -70,9 +66,9 @@ Configuration options for labeledRadio:
- 'ellipsis': if ellipsis should be used for overflown text. - 'ellipsis': if ellipsis should be used for overflown text.
- 'multiline': if text may be split in multiple lines. - 'multiline': if text may be split in multiple lines.
- 'maxLines': maximum number of text lines to show. - 'maxLines': maximum number of text lines to show.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
- 'resizeFactorW': flexibility for more or less horizontal spaced assigned. - 'resizeFactorW': flexibility for more or less horizontal space assigned.
- 'resizeFactorH': flexibility for more or less vertical spaced assigned. - 'resizeFactorH': flexibility for more or less vertical space assigned.
- Radio related - Radio related

View File

@ -18,7 +18,7 @@ Its behavior is equivalent to "Monomer.Widgets.Singles.Radio" and
This widget, and the associated "Monomer.Widgets.Singles.ToggleButton", uses two This widget, and the associated "Monomer.Widgets.Singles.ToggleButton", uses two
separate styles for the On and Off states which can be modified individually for separate styles for the On and Off states which can be modified individually for
the theme. If you use any of the the standard style functions (styleBasic, the theme. If you use any of the standard style functions (styleBasic,
styleHover, etc) in an optionButton/toggleButton these changes will apply to styleHover, etc) in an optionButton/toggleButton these changes will apply to
both On and Off states, except for the color related styles. The reason is that, both On and Off states, except for the color related styles. The reason is that,
in general, the font and padding will be the same for both states, but the in general, the font and padding will be the same for both states, but the
@ -59,8 +59,7 @@ module Monomer.Widgets.Singles.OptionButton (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens (ALens', Lens', (&), (^.), (^?), (.~), (?~), _Just) import Control.Lens (ALens', Lens', (&), (^.), (.~), _Just)
import Control.Monad
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text) import Data.Text (Text)
@ -86,9 +85,9 @@ Configuration options for optionButton:
- 'ellipsis': if ellipsis should be used for overflown text. - 'ellipsis': if ellipsis should be used for overflown text.
- 'multiline': if text may be split in multiple lines. - 'multiline': if text may be split in multiple lines.
- 'maxLines': maximum number of text lines to show. - 'maxLines': maximum number of text lines to show.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
- 'resizeFactorW': flexibility to have more or less horizontal spaced assigned. - 'resizeFactorW': flexibility to have more or less horizontal space assigned.
- 'resizeFactorH': flexibility to have more or less vertical spaced assigned. - 'resizeFactorH': flexibility to have more or less vertical space assigned.
- 'onFocus': event to raise when focus is received. - 'onFocus': event to raise when focus is received.
- 'onFocusReq': 'WidgetRequest' to generate when focus is received. - 'onFocusReq': 'WidgetRequest' to generate when focus is received.
- 'onBlur': event to raise when focus is lost. - 'onBlur': event to raise when focus is lost.

View File

@ -43,7 +43,6 @@ import Control.Lens (ALens', (&), (^.), (.~))
import Control.Monad import Control.Monad
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text)
import Data.Typeable (Typeable, typeOf) import Data.Typeable (Typeable, typeOf)
import TextShow import TextShow

View File

@ -38,7 +38,6 @@ import Control.Applicative ((<|>))
import Control.Lens ((^.)) import Control.Lens ((^.))
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Tuple
import Monomer.Widgets.Single import Monomer.Widgets.Single
@ -48,7 +47,7 @@ import qualified Monomer.Core.Lens as L
Configuration options for separatorLine: Configuration options for separatorLine:
- 'width': the max width of the line. - 'width': the max width of the line.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
-} -}
data SeparatorLineCfg = SeparatorLineCfg { data SeparatorLineCfg = SeparatorLineCfg {
_slcWidth :: Maybe Double, _slcWidth :: Maybe Double,

View File

@ -46,7 +46,6 @@ import Control.Lens (ALens', (&), (^.), (.~), (%~), (<>~))
import Control.Monad import Control.Monad
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text)
import Data.Typeable (Typeable, typeOf) import Data.Typeable (Typeable, typeOf)
import GHC.Generics import GHC.Generics
import TextShow import TextShow

View File

@ -45,7 +45,6 @@ import Control.Applicative ((<|>))
import Control.Lens ((^.)) import Control.Lens ((^.))
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Tuple
import Monomer.Widgets.Single import Monomer.Widgets.Single
@ -55,7 +54,7 @@ import qualified Monomer.Core.Lens as L
Configuration options for spacer widget: Configuration options for spacer widget:
- 'width': the max width for spacer, the reference for filler. - 'width': the max width for spacer, the reference for filler.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
-} -}
data SpacerCfg = SpacerCfg { data SpacerCfg = SpacerCfg {
_spcWidth :: Maybe Double, _spcWidth :: Maybe Double,

View File

@ -82,7 +82,7 @@ defaultTimeDelim :: Char
defaultTimeDelim = ':' defaultTimeDelim = ':'
{-| {-|
Converter to and form the 'TimeOfDay' type of the time library. To use types Converter to and from the 'TimeOfDay' type of the time library. To use types
other than 'TimeOfDay' of said library, this typeclass needs to be implemented. other than 'TimeOfDay' of said library, this typeclass needs to be implemented.
--} --}
class (Eq a, Ord a, Show a, Typeable a) => TimeOfDayConverter a where class (Eq a, Ord a, Show a, Typeable a) => TimeOfDayConverter a where

View File

@ -34,13 +34,10 @@ module Monomer.Widgets.Singles.ToggleButton (
toggleButtonD_ toggleButtonD_
) where ) where
import Control.Applicative ((<|>)) import Control.Lens (ALens', (&), (.~))
import Control.Lens (ALens', (&), (^.), (^?), (.~), (?~), _Just)
import Data.Default import Data.Default
import Data.Text (Text) import Data.Text (Text)
import qualified Data.Sequence as Seq
import Monomer.Widgets.Single import Monomer.Widgets.Single
import Monomer.Widgets.Singles.OptionButton import Monomer.Widgets.Singles.OptionButton
@ -55,9 +52,9 @@ Configuration options for toggleButton:
- 'ellipsis': if ellipsis should be used for overflown text. - 'ellipsis': if ellipsis should be used for overflown text.
- 'multiline': if text may be split in multiple lines. - 'multiline': if text may be split in multiple lines.
- 'maxLines': maximum number of text lines to show. - 'maxLines': maximum number of text lines to show.
- 'resizeFactor': flexibility to have more or less spaced assigned. - 'resizeFactor': flexibility to have more or less space assigned.
- 'resizeFactorW': flexibility to have more or less horizontal spaced assigned. - 'resizeFactorW': flexibility to have more or less horizontal space assigned.
- 'resizeFactorH': flexibility to have more or less vertical spaced assigned. - 'resizeFactorH': flexibility to have more or less vertical space assigned.
- 'onFocus': event to raise when focus is received. - 'onFocus': event to raise when focus is received.
- 'onFocusReq': 'WidgetRequest' to generate when focus is received. - 'onFocusReq': 'WidgetRequest' to generate when focus is received.
- 'onBlur': event to raise when focus is lost. - 'onBlur': event to raise when focus is lost.

View File

@ -39,18 +39,16 @@ module Monomer.Widgets.Util.Drawing (
) where ) where
import Control.Applicative ((<|>)) import Control.Applicative ((<|>))
import Control.Lens ((&), (^.), (^?), (^?!), (.~), non) import Control.Lens ((^.), (^?!), non)
import Control.Monad (forM_, void, when) import Control.Monad (forM_, when)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Text (Text)
import Monomer.Core import Monomer.Core
import Monomer.Graphics.Types import Monomer.Graphics.Types
import qualified Monomer.Common.Lens as L import qualified Monomer.Common.Lens as L
import qualified Monomer.Core.Lens as L import qualified Monomer.Core.Lens as L
import qualified Monomer.Graphics.Lens as L
-- | Performs the provided drawing operations with an active scissor, and then -- | Performs the provided drawing operations with an active scissor, and then
-- | disables it. -- | disables it.

View File

@ -26,10 +26,7 @@ module Monomer.Widgets.Util.Focus (
handleFocusChange handleFocusChange
) where ) where
import Control.Lens ((&), (^.), (.~), (%~)) import Control.Lens ((^.))
import Data.Maybe
import Data.Sequence (Seq(..), (|>))
import Data.Typeable (Typeable)
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq

View File

@ -30,7 +30,7 @@ module Monomer.Widgets.Util.Hover (
isNodeInfoInOverlay isNodeInfoInOverlay
) where ) where
import Control.Lens ((&), (^.), (^?), _1, _Just) import Control.Lens ((^.), (^?), _1, _Just)
import Data.Maybe import Data.Maybe
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq

View File

@ -19,10 +19,6 @@ module Monomer.Widgets.Util.Keyboard (
isKeyboardRedo isKeyboardRedo
) where ) where
import Data.Maybe (fromMaybe)
import qualified Data.Map as M
import Monomer.Core import Monomer.Core
import Monomer.Event.Keyboard import Monomer.Event.Keyboard
import Monomer.Event.Types import Monomer.Event.Types

View File

@ -28,13 +28,11 @@ module Monomer.Widgets.Util.Style (
childOfFocusedStyle childOfFocusedStyle
) where ) where
import Control.Applicative ((<|>))
import Control.Lens hiding ((<|), (|>)) import Control.Lens hiding ((<|), (|>))
import Data.Bits (xor)
import Data.Default import Data.Default
import Data.Maybe import Data.Maybe
import Data.Sequence (Seq(..), (<|), (|>)) import Data.Sequence ((<|), (|>))
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq

View File

@ -18,9 +18,8 @@ module Monomer.Widgets.Util.Text (
getTextGlyphs getTextGlyphs
) where ) where
import Control.Lens ((&), (^.), (+~)) import Control.Lens ((^.))
import Data.Default import Data.Sequence (Seq(..))
import Data.Sequence (Seq(..), (<|), (|>))
import Data.Text (Text) import Data.Text (Text)
import Monomer.Core import Monomer.Core

View File

@ -14,9 +14,8 @@ Helper functions for loading theme values.
module Monomer.Widgets.Util.Theme where module Monomer.Widgets.Util.Theme where
import Control.Lens (Lens', (&), (^.), (^?), (.~), (?~), (<>~), at, non) import Control.Lens (Lens', (&), (^.), (.~), (<>~), at, non)
import Data.Default import Data.Default
import Data.Maybe
import Monomer.Core.StyleTypes import Monomer.Core.StyleTypes
import Monomer.Core.ThemeTypes import Monomer.Core.ThemeTypes

View File

@ -39,15 +39,11 @@ module Monomer.Widgets.Util.Widget (
) where ) where
import Control.Concurrent (threadDelay) import Control.Concurrent (threadDelay)
import Control.Lens ((&), (^#), (#~), (^.), (^?), (.~), (%~), _Just) import Control.Lens ((&), (^#), (#~), (^.), (.~), (%~))
import Data.Default import Data.Default
import Data.Maybe import Data.Sequence ((<|))
import Data.Map.Strict (Map)
import Data.Sequence (Seq(..), (<|))
import Data.Text (Text)
import Data.Typeable (Typeable, cast) import Data.Typeable (Typeable, cast)
import qualified Data.Map.Strict as M
import qualified Data.Sequence as Seq import qualified Data.Sequence as Seq
import Monomer.Common import Monomer.Common