diff options
Diffstat (limited to 'webgui/src')
-rw-r--r-- | webgui/src/Main.hs | 36 |
1 files changed, 27 insertions, 9 deletions
diff --git a/webgui/src/Main.hs b/webgui/src/Main.hs index 141b0ea..dde6eb1 100644 --- a/webgui/src/Main.hs +++ b/webgui/src/Main.hs | |||
@@ -115,7 +115,7 @@ setup Config{..} window (split -> (socketErr, dataUpdate)) = void $ do | |||
115 | errorsTab = maybe (fatal "Could not make nonfatal errors visible") return =<< getElementById window "errors-tab" | 115 | errorsTab = maybe (fatal "Could not make nonfatal errors visible") return =<< getElementById window "errors-tab" |
116 | errors #+ [UI.li # set TP.text str] | 116 | errors #+ [UI.li # set TP.text str] |
117 | errorsTab # set style [("display", "inline-block")] | 117 | errorsTab # set style [("display", "inline-block")] |
118 | switchTab "errors" | 118 | runFunction $ switchTab "errors" |
119 | fatal :: String -> UI a | 119 | fatal :: String -> UI a |
120 | fatal str = do | 120 | fatal str = do |
121 | (getBody window #) . set children =<< sequence [UI.p # set TP.text str # set UI.class_ "fatal"] | 121 | (getBody window #) . set children =<< sequence [UI.p # set TP.text str # set UI.class_ "fatal"] |
@@ -165,34 +165,49 @@ setup Config{..} window (split -> (socketErr, dataUpdate)) = void $ do | |||
165 | let | 165 | let |
166 | saveAction automatic = do | 166 | saveAction automatic = do |
167 | s@(EditorState{..}) <- currentValue editorStatus | 167 | s@(EditorState{..}) <- currentValue editorStatus |
168 | when (not $ maybe True null eTitle && null eText) $ case ePrintout of | 168 | r <- when' (not $ maybe True null eTitle && null eText) $ case ePrintout of |
169 | Left err -> when (not automatic) . emitError $ "Could not save draft due to error parsing bbcode: " ++ show err | 169 | Left err -> do |
170 | when (not automatic) . emitError $ "Could not save draft due to error parsing bbcode: " ++ show err | ||
171 | return False | ||
170 | Right p -> do | 172 | Right p -> do |
171 | draftId <- case associatedDraft of | 173 | draftId <- case associatedDraft of |
172 | Nothing -> draftCreate (T.pack <$> eTitle) p | 174 | Nothing -> draftCreate (T.pack <$> eTitle) p |
173 | Just i -> i <$ when (different s) (draftReplace i (T.pack <$> eTitle) p) | 175 | Just i -> i <$ when (different s) (draftReplace i (T.pack <$> eTitle) p) |
174 | time <- liftIO getCurrentTime | 176 | time <- liftIO getCurrentTime |
175 | modifyStatus (\x -> x { associatedDraft = Just draftId, lastSaved = Just (time, s) }) | 177 | modifyStatus (\x -> x { associatedDraft = Just draftId, lastSaved = Just (time, s) }) |
178 | return True | ||
179 | return $ fromMaybe False r | ||
176 | where | 180 | where |
177 | different s | 181 | different s |
178 | | Just (_, s') <- lastSaved s = not $ and [ eTitle s == eTitle s' | 182 | | Just (_, s') <- lastSaved s = not $ and [ eTitle s == eTitle s' |
179 | , eText s == eText s' | 183 | , eText s == eText s' |
180 | ] | 184 | ] |
181 | | otherwise = True | 185 | | otherwise = True |
186 | when' :: Applicative m => Bool -> m a -> m (Maybe a) | ||
187 | when' True = fmap Just | ||
188 | when' False = const $ pure Nothing | ||
182 | discardAction = do | 189 | discardAction = do |
183 | -- maybe (return ()) draftDelete . associatedDraft =<< currentValue editorStatus | 190 | -- maybe (return ()) draftDelete . associatedDraft =<< currentValue editorStatus |
184 | saveAction False | 191 | saved <- saveAction False |
185 | modifyStatus $ const def | 192 | when saved $ modifyStatus $ const def |
186 | printAction = do | 193 | printAction = do |
187 | emitError "Printing not implemented" | 194 | EditorState{..} <- currentValue editorStatus |
188 | 195 | case ePrintout of | |
189 | onEvent (tick autoSaveTimer) (const $ saveAction True) | 196 | Right po -> case associatedDraft of |
197 | Just dId -> do | ||
198 | saved <- saveAction False | ||
199 | when saved $ runFunction . focusJob =<< draftPrint dId Nothing -- FIXME | ||
200 | Nothing -> do | ||
201 | runFunction . focusJob =<< jobCreate Nothing po -- FIXME | ||
202 | Left err -> emitError $ "Could not print draft due to error parsing bbcode: " ++ show err | ||
203 | |||
204 | onEvent (tick autoSaveTimer) (const . void $ saveAction True) | ||
190 | 205 | ||
191 | return saveButton # sink UI.enabled (saveable <$> editorStatus) | 206 | return saveButton # sink UI.enabled (saveable <$> editorStatus) |
192 | return printButton # sink UI.enabled (printable <$> editorStatus) | 207 | return printButton # sink UI.enabled (printable <$> editorStatus) |
193 | return discardButton # sink UI.enabled (discardable <$> editorStatus) | 208 | return discardButton # sink UI.enabled (discardable <$> editorStatus) |
194 | 209 | ||
195 | on UI.click saveButton . const $ saveAction False | 210 | on UI.click saveButton . const . void $ saveAction False |
196 | on UI.click printButton $ const printAction | 211 | on UI.click printButton $ const printAction |
197 | on UI.click discardButton $ const discardAction | 212 | on UI.click discardButton $ const discardAction |
198 | 213 | ||
@@ -256,6 +271,9 @@ setup Config{..} window (split -> (socketErr, dataUpdate)) = void $ do | |||
256 | | "draft/" `isPrefixOf` p = True | 271 | | "draft/" `isPrefixOf` p = True |
257 | | otherwise = False | 272 | | otherwise = False |
258 | 273 | ||
274 | focusJob :: JobId -> JSFunction () | ||
275 | focusJob (JobId (fromInteger -> i)) = ffi "alert(%1)" (i :: Int) -- FIXME | ||
276 | |||
259 | switchTab :: String -> JSFunction () | 277 | switchTab :: String -> JSFunction () |
260 | switchTab = ffi "$(%1).first().trigger(\"click\")" . (\p -> "a[href='#" ++ p ++ "']") | 278 | switchTab = ffi "$(%1).first().trigger(\"click\")" . (\p -> "a[href='#" ++ p ++ "']") |
261 | 279 | ||