diff options
author | Raúl Benencia <rul@kalgan.cc> | 2013-08-29 23:03:58 -0300 |
---|---|---|
committer | Raúl Benencia <rul@kalgan.cc> | 2013-08-29 23:03:58 -0300 |
commit | 6532d2b357160fe6a41ac4ec3aeb1283027d116e (patch) | |
tree | e1d12b8d75b0924f4499cee155164014bd763f27 | |
parent | e4cc85a6fbf1eb3dcdc8304404183ea8db0a39ff (diff) |
Filled email state
-rw-r--r-- | Handlers.hs | 30 | ||||
-rw-r--r-- | Screen.hs | 6 | ||||
-rw-r--r-- | State.hs | 4 |
3 files changed, 22 insertions, 18 deletions
diff --git a/Handlers.hs b/Handlers.hs index 3d0b787..e01d51a 100644 --- a/Handlers.hs +++ b/Handlers.hs @@ -11,7 +11,7 @@ import Control.Monad.State import Data.List(stripPrefix) import System.FilePath(FilePath, takeFileName, dropTrailingPathSeparator) -import Email(parseEmail, getFields, getSubject, getFrom) +import Email(parseEmail, getFields, getSubject, getFrom, getBody, formatBody) import Maildir import Print import State @@ -23,7 +23,7 @@ previousMode MaildirMode = (=<<) put $ get >>= \st -> return st { exitRequested previousMode EmailMode = (=<<) put $ get >>= \st -> return st { mode = IndexMode } previousMode IndexMode = do st <- get - let ist = (indexState st) { selectedRowIn = 0, scrollRowIn = 0 } + let ist = (indexState st) { selectedRowIn = 0, scrollRowIn = 0 } put $ st { mode = MaildirMode, indexState = ist } changeMode :: Mode -> LazymailCurses () @@ -31,9 +31,13 @@ changeMode EmailMode = return () changeMode IndexMode = do st <- get msg <- liftIO $ UTF8.readFile . selectedEmailPath . indexState $ st - let ist = (indexState st) { selectedEmail = (parseEmail msg) } - put $ st { mode = EmailMode, indexState = ist } - + let email = parseEmail msg + let body = getBody $ email + let el = formatBody body $ screenColumns st + let sbe = scrollCrop 0 (screenRows st) el + let est = (emailState st) { currentEmail = email, emailLines = el, scrollBufferEm = sbe } + put $ st { mode = EmailMode, emailState = est } + changeMode MaildirMode = do st <- get selectedEmails' <- liftIO $ do @@ -64,7 +68,7 @@ incSelectedRow IndexMode = do put st { indexState = inSt' } else -- Move the selected row put $ incrementSelectedRow st - + incSelectedRow MaildirMode = do st <- get let mdSt = maildirState st @@ -88,9 +92,9 @@ incSelectedRow _ = (=<<) put $ get >>= \st -> return $ incrementSelectedRow st decSelectedRow IndexMode = do st <- get let inSt = indexState st - let selRow = selectedRowIn inSt + let selRow = selectedRowIn inSt let startScrolling = (div (screenRows st) 4) - let topScrollRow = scrollRowIn inSt + let topScrollRow = scrollRowIn inSt if topScrollRow > 0 && selRow < startScrolling then do let scrollRowIn' = scrollRowIn inSt - 1 @@ -99,13 +103,13 @@ decSelectedRow IndexMode = do put st { indexState = inSt' } else put $ decrementSelectedRow st - + decSelectedRow MaildirMode = do st <- get let mdSt = maildirState st - let selRow = selectedRowMD mdSt + let selRow = selectedRowMD mdSt let startScrolling = (div (screenRows st) 4) - let topScrollRow = scrollRowMD mdSt + let topScrollRow = scrollRowMD mdSt if topScrollRow > 0 && selRow < startScrolling then do let scrollRowMD' = scrollRowMD mdSt - 1 @@ -114,7 +118,7 @@ decSelectedRow MaildirMode = do put st { maildirState = mdSt' } else put $ decrementSelectedRow st - + decSelectedRow _ = (=<<) put $ get >>= \st -> return $ decrementSelectedRow st {- Given a list, it returns the elements that will be in the next screen refresh @@ -132,7 +136,7 @@ formatIndexModeRows st = mapM formatRow where , (ppSep ++) $ ppIndexSubject . getSubject $ fs ] return (fp, str) - + formatMaildirModeRows st = mapM formatRow where formatRow fp = return $ (fp, (concat $ replicate (numPads - 1) pad) ++ name) where bp = basePath st @@ -75,7 +75,7 @@ screenLoop = do then screenLoop else return () -{- Perform the screen for the next update. A clean is made -} +{- Perform the screen update, by cleaning it first. -} performUpdate :: LazymailUpdate LazymailState performUpdate = do st <- get @@ -137,7 +137,7 @@ drawEmailHelper = do drawEmailHeader st <- get - let body = getBody $ selectedEmail . indexState $ st + let body = getBody $ currentEmail . emailState $ st let maxRows = if statusBar st then (scrRowsAsInteger st) - 1 else scrRowsAsInteger st let emailLines = formatBody body $ (screenColumns st) - 1 liftUpdate $ drawBody ((curRowAsInteger st) + 4) (colPadAsInteger st) maxRows emailLines @@ -146,7 +146,7 @@ drawEmailHelper = do drawEmailHeader = do st <- get liftUpdate $ do - let fs = getFields $ selectedEmail . indexState $ st + let fs = getFields $ currentEmail . emailState $ st let cropWith xs = normalizeLen $ (screenColumns st) - (length xs) let row = curRowAsInteger st setColor $ headerColorID . colorStyle $ st @@ -41,7 +41,6 @@ data MaildirState = MaildirState { data IndexState = IndexState { selectedRowIn :: Int - , selectedEmail :: Message , selectedEmailPath :: FilePath , selectedEmails :: [(FilePath, String)] , scrollRowIn :: Int @@ -57,6 +56,7 @@ data EmailState = EmailState { scrollBufferEm :: [String] , scrollRowEm :: Int , emailLines :: [String] + , currentEmail :: Message } data ColorStyle = ColorStyle { @@ -92,7 +92,6 @@ initialMaildirState = MaildirState { initialIndexState = IndexState { selectedRowIn = 0 - , selectedEmail = Message [] "Dummy email" , selectedEmailPath = "" , selectedEmails = [] , scrollRowIn = 0 @@ -104,6 +103,7 @@ initialEmailState = EmailState { scrollBufferEm = [] , scrollRowEm = 0 , emailLines = [] + , currentEmail = Message [] "Dummy email" } initialComposeState = ComposeState { |