add background image

This commit is contained in:
Filip Gralinski 2018-01-18 08:21:06 +01:00
parent 069e3cf5e1
commit ce9ef289f6
7 changed files with 40 additions and 7 deletions

View File

@ -146,6 +146,7 @@ instance Yesod App where
isAuthorized (ResetPasswordR _) _ = return Authorized isAuthorized (ResetPasswordR _) _ = return Authorized
isAuthorized (ToggleSubmissionTagR _) _ = return Authorized isAuthorized (ToggleSubmissionTagR _) _ = return Authorized
isAuthorized (ChallengeImageR _) _ = return Authorized
-- Default to Authorized for now. -- Default to Authorized for now.
isAuthorized _ _ = isTrustedAuthorized isAuthorized _ _ = isTrustedAuthorized

View File

@ -17,6 +17,11 @@ import qualified Data.Text as T
import PersistSHA1 import PersistSHA1
import qualified Data.ByteString as S
import qualified Data.ByteString.Lazy as L
import Data.Conduit.Binary (sinkLbs, sourceFile)
getCreateChallengeR :: Handler Html getCreateChallengeR :: Handler Html
getCreateChallengeR = do getCreateChallengeR = do
(formWidget, formEnctype) <- generateFormPost sampleForm (formWidget, formEnctype) <- generateFormPost sampleForm
@ -69,6 +74,16 @@ addChallenge name publicRepoId privateRepoId chan = do
else do else do
err chan "README was not found" err chan "README was not found"
return (defaultTitle, defaultDescription) return (defaultTitle, defaultDescription)
let imageFilePath = publicRepoDir </> imageFile
doesImageFileExists <- liftIO $ doesFileExist imageFilePath
mImage <- if doesImageFileExists
then do
fileBytes <- liftIO $ runResourceT $ sourceFile imageFilePath $$ sinkLbs
return $ Just (S.pack . L.unpack $ fileBytes)
else do
return Nothing
time <- liftIO getCurrentTime time <- liftIO getCurrentTime
challengeId <- runDB $ insert $ Challenge { challengeId <- runDB $ insert $ Challenge {
challengePublicRepo=publicRepoId, challengePublicRepo=publicRepoId,
@ -76,7 +91,8 @@ addChallenge name publicRepoId privateRepoId chan = do
challengeName=name, challengeName=name,
challengeTitle=(T.pack $ title), challengeTitle=(T.pack $ title),
challengeDescription=(T.pack $ description), challengeDescription=(T.pack $ description),
challengeStamp=time} challengeStamp=time,
challengeImage=mImage }
updateTests challengeId chan updateTests challengeId chan
return () return ()

View File

@ -42,6 +42,9 @@ defaultDescription = ""
readmeFile :: FilePath readmeFile :: FilePath
readmeFile = "README.md" readmeFile = "README.md"
imageFile :: FilePath
imageFile = ".seeme.png"
getTitleAndDescription :: String -> (String, String) getTitleAndDescription :: String -> (String, String)
getTitleAndDescription contents = (title, description) getTitleAndDescription contents = (title, description)
where title = fromMaybe defaultTitle $ extractFirstHeader doc where title = fromMaybe defaultTitle $ extractFirstHeader doc

View File

@ -4,10 +4,18 @@ import Import
getListChallengesR :: Handler Html getListChallengesR :: Handler Html
getListChallengesR = do getListChallengesR = do
challenges' <- runDB $ selectList [] [Desc ChallengeStamp] challenges <- runDB $ selectList [] [Desc ChallengeStamp]
let challenges = map (\(Entity _ v) -> v) challenges'
defaultLayout $ do defaultLayout $ do
setTitle "List challenges" setTitle "List challenges"
$(widgetFile "list-challenges") $(widgetFile "list-challenges")
listChallengesCore challenges = $(widgetFile "list-challenges-core") listChallengesCore challenges = $(widgetFile "list-challenges-core")
getChallengeImageR :: ChallengeId -> Handler Html
getChallengeImageR challengeId = do
challenge <- runDB $ get404 challengeId
case challengeImage challenge of
Just image -> do
addHeader "Content-Disposition" "attachment; filename=\"image.png\""
sendResponse (typePng, toContent image)
Nothing -> sendResponseStatus status202 ()

View File

@ -36,6 +36,7 @@ Challenge
title Text title Text
description Text description Text
stamp UTCTime default=now() stamp UTCTime default=now()
image ByteString Maybe
Test Test
challenge ChallengeId challenge ChallengeId
metric Metric metric Metric

View File

@ -10,6 +10,7 @@
/view-progress/#Int ViewProgressR GET /view-progress/#Int ViewProgressR GET
/open-view-progress/#Int OpenViewProgressR GET /open-view-progress/#Int OpenViewProgressR GET
/list-challenges ListChallengesR GET /list-challenges ListChallengesR GET
/challenge-image/#ChallengeId ChallengeImageR GET
/challenge/#Text ShowChallengeR GET /challenge/#Text ShowChallengeR GET
/challenge-readme/#Text ChallengeReadmeR GET /challenge-readme/#Text ChallengeReadmeR GET

View File

@ -1,4 +1,7 @@
$forall challenge <- challenges $forall (Entity challengeId challenge) <- challenges
<div class="panel panel-success"> <div class="panel panel-success">
<div class="panel-heading"><a .challenge-link href="@{ShowChallengeR (challengeName challenge)}">#{challengeTitle challenge}</a> <div class="panel-heading"><a .challenge-link href="@{ShowChallengeR (challengeName challenge)}">#{challengeTitle challenge}</a>
<div class="panel-body">#{challengeDescription challenge} $if isJust (challengeImage challenge)
<div class="panel-body" style="background-image:url(@{ChallengeImageR challengeId}); background-color:lightgrey; background-blend-mode:screen;background-size: 100%;">#{challengeDescription challenge}
$else
<div class="panel-body">#{challengeDescription challenge}