----------------------------------------------------------------------------- -- | -- Module : XMonad.Prompt.Email -- Description : A prompt for sending quick, one-line emails, via GNU \'mail\'. -- Copyright : (c) 2007 Brent Yorgey -- License : BSD-style (see LICENSE) -- -- Maintainer : <byorgey@gmail.com> -- Stability : stable -- Portability : unportable -- -- A prompt for sending quick, one-line emails, via the standard GNU -- \'mail\' utility (which must be in your $PATH). This module is -- intended mostly as an example of using "XMonad.Prompt.Input" to -- build an action requiring user input. -- ----------------------------------------------------------------------------- module XMonad.Prompt.Email ( -- * Usage -- $usage emailPrompt ) where import XMonad.Core import XMonad.Util.Run import XMonad.Prelude (void) import XMonad.Prompt import XMonad.Prompt.Input -- $usage -- -- You can use this module by importing it, along with -- "XMonad.Prompt", into your @xmonad.hs@ file: -- -- > import XMonad.Prompt -- > import XMonad.Prompt.Email -- -- and adding an appropriate keybinding, for example: -- -- > , ((modm .|. controlMask, xK_e), emailPrompt def addresses) -- -- where @addresses@ is a list of email addresses that should -- autocomplete, for example: -- -- > addresses = ["me@me.com", "mr@big.com", "tom.jones@foo.bar"] -- -- You can still send email to any address, but sending to these -- addresses will be faster since you only have to type a few -- characters and then hit \'tab\'. -- -- For detailed instructions on editing your key bindings, see -- <https://xmonad.org/TUTORIAL.html#customizing-xmonad the tutorial>. -- | Prompt the user for a recipient, subject, and body, and send an -- email via the GNU \'mail\' utility. The second argument is a list -- of addresses for autocompletion. emailPrompt :: XPConfig -> [String] -> X () emailPrompt :: XPConfig -> [String] -> X () emailPrompt XPConfig c [String] addrs = XPConfig -> String -> ComplFunction -> X (Maybe String) inputPromptWithCompl XPConfig c String "To" (XPConfig -> [String] -> ComplFunction mkComplFunFromList XPConfig c [String] addrs) X (Maybe String) -> (String -> X ()) -> X () forall (m :: * -> *) a. Monad m => m (Maybe a) -> (a -> m ()) -> m () ?+ \String to -> XPConfig -> String -> X (Maybe String) inputPrompt XPConfig c String "Subject" X (Maybe String) -> (String -> X ()) -> X () forall (m :: * -> *) a. Monad m => m (Maybe a) -> (a -> m ()) -> m () ?+ \String subj -> XPConfig -> String -> X (Maybe String) inputPrompt XPConfig c String "Body" X (Maybe String) -> (String -> X ()) -> X () forall (m :: * -> *) a. Monad m => m (Maybe a) -> (a -> m ()) -> m () ?+ \String body -> X String -> X () forall (f :: * -> *) a. Functor f => f a -> f () void (String -> [String] -> String -> X String forall (m :: * -> *). MonadIO m => String -> [String] -> String -> m String runProcessWithInput String "mail" [String "-s", String subj, String to] (String body String -> String -> String forall a. [a] -> [a] -> [a] ++ String "\n"))