mirror of
https://github.com/IHaskell/IHaskell.git
synced 2025-04-15 19:06:06 +00:00
69 lines
2.0 KiB
Haskell
69 lines
2.0 KiB
Haskell
{-# LANGUAGE FlexibleInstances #-}
|
|
{-# LANGUAGE OverloadedStrings #-}
|
|
{-# LANGUAGE DataKinds #-}
|
|
{-# LANGUAGE TypeApplications #-}
|
|
|
|
{-# OPTIONS_GHC -fno-warn-orphans #-}
|
|
|
|
module IHaskell.Display.Widgets.String.TextArea
|
|
( -- * The TextArea Widget
|
|
TextArea
|
|
-- * Constructor
|
|
, mkTextArea
|
|
) where
|
|
|
|
-- To keep `cabal repl` happy when running from the ihaskell repo
|
|
import Prelude
|
|
|
|
import Control.Monad (void)
|
|
import Data.Aeson
|
|
import Data.IORef (newIORef)
|
|
import Data.Vinyl (Rec(..), (<+>))
|
|
|
|
import IHaskell.Display
|
|
import IHaskell.Eval.Widgets
|
|
import IHaskell.IPython.Message.UUID as U
|
|
|
|
import IHaskell.Display.Widgets.Types
|
|
import IHaskell.Display.Widgets.Common
|
|
import IHaskell.Display.Widgets.Layout.LayoutWidget
|
|
import IHaskell.Display.Widgets.Style.DescriptionStyle
|
|
|
|
-- | A 'TextArea' represents a Textarea widget from IPython.html.widgets.
|
|
type TextArea = IPythonWidget TextAreaType
|
|
|
|
-- | Create a new TextArea widget
|
|
mkTextArea :: IO TextArea
|
|
mkTextArea = do
|
|
-- Default properties, with a random uuid
|
|
wid <- U.random
|
|
layout <- mkLayout
|
|
dstyle <- mkDescriptionStyle
|
|
|
|
let strAttrs = defaultStringWidget "TextareaView" "TextareaModel" layout $ StyleWidget dstyle
|
|
wgtAttrs = (F @Rows =:: Nothing)
|
|
:& (F @Disabled =:: False)
|
|
:& (F @ContinuousUpdate =:: True)
|
|
:& (F @ChangeHandler =:: return ())
|
|
:& RNil
|
|
widgetState = WidgetState $ strAttrs <+> wgtAttrs
|
|
|
|
stateIO <- newIORef widgetState
|
|
|
|
let widget = IPythonWidget wid stateIO
|
|
|
|
-- Open a comm for this widget, and store it in the kernel state
|
|
widgetSendOpen widget $ toJSON widgetState
|
|
|
|
-- Return the widget
|
|
return widget
|
|
|
|
instance IHaskellWidget TextArea where
|
|
getCommUUID = uuid
|
|
comm widget val _ =
|
|
case nestedObjectLookup val ["state", "value"] of
|
|
Just (String value) -> do
|
|
void $ setField' @StringValue widget value
|
|
triggerChange widget
|
|
_ -> pure ()
|