module System.Taffybar.Widget.SimpleCommandButton (
simpleCommandButtonNew)
where
import Control.Monad (void)
import Control.Monad.IO.Class
import GI.Gtk
import System.Process
import qualified Data.Text as T
simpleCommandButtonNew
:: MonadIO m
=> T.Text
-> T.Text
-> m Widget
simpleCommandButtonNew :: forall (m :: * -> *). MonadIO m => Text -> Text -> m Widget
simpleCommandButtonNew Text
txt Text
cmd = do
Button
button <- Text -> m Button
forall (m :: * -> *). (HasCallStack, MonadIO m) => Text -> m Button
buttonNewWithLabel Text
txt
m SignalHandlerId -> m ()
forall (f :: * -> *) a. Functor f => f a -> f ()
void (m SignalHandlerId -> m ()) -> m SignalHandlerId -> m ()
forall a b. (a -> b) -> a -> b
$ Button
-> ((?self::Button) => ButtonClickedCallback) -> m SignalHandlerId
forall a (m :: * -> *).
(IsButton a, MonadIO m) =>
a -> ((?self::a) => ButtonClickedCallback) -> m SignalHandlerId
onButtonClicked Button
button (((?self::Button) => ButtonClickedCallback) -> m SignalHandlerId)
-> ((?self::Button) => ButtonClickedCallback) -> m SignalHandlerId
forall a b. (a -> b) -> a -> b
$ IO ProcessHandle -> ButtonClickedCallback
forall (f :: * -> *) a. Functor f => f a -> f ()
void (IO ProcessHandle -> ButtonClickedCallback)
-> IO ProcessHandle -> ButtonClickedCallback
forall a b. (a -> b) -> a -> b
$ String -> IO ProcessHandle
spawnCommand (String -> IO ProcessHandle) -> String -> IO ProcessHandle
forall a b. (a -> b) -> a -> b
$ Text -> String
T.unpack Text
cmd
Button -> m Widget
forall (m :: * -> *) o. (MonadIO m, IsWidget o) => o -> m Widget
toWidget Button
button