diff options
| author | Joris | 2017-11-08 23:47:26 +0100 | 
|---|---|---|
| committer | Joris | 2017-11-08 23:47:26 +0100 | 
| commit | 27e11b20b06f2f2dbfb56c0998a63169b4b8abc4 (patch) | |
| tree | 845f54d7fe876c9a3078036975ba85ec21d224a1 /server/src/Design/View/Payment | |
| parent | a3601b5e6f5a3e41fa31752a2c704ccd3632790e (diff) | |
Use a better project structure
Diffstat (limited to 'server/src/Design/View/Payment')
| -rw-r--r-- | server/src/Design/View/Payment/Header.hs | 84 | ||||
| -rw-r--r-- | server/src/Design/View/Payment/Pages.hs | 54 | ||||
| -rw-r--r-- | server/src/Design/View/Payment/Table.hs | 42 | 
3 files changed, 180 insertions, 0 deletions
| diff --git a/server/src/Design/View/Payment/Header.hs b/server/src/Design/View/Payment/Header.hs new file mode 100644 index 0000000..f02da8a --- /dev/null +++ b/server/src/Design/View/Payment/Header.hs @@ -0,0 +1,84 @@ +{-# LANGUAGE OverloadedStrings #-} + +module Design.View.Payment.Header +  ( design +  ) where + +import Data.Monoid ((<>)) + +import Clay + +import Design.Constants + +import qualified Design.Helper as Helper +import qualified Design.Color as Color +import qualified Design.Constants as Constants +import qualified Design.Media as Media + +design :: Css +design = do +  Media.desktop $ marginBottom (em 3) +  Media.mobileTablet $ marginBottom (em 2) +  marginLeft (pct blockPercentMargin) +  marginRight (pct blockPercentMargin) + +  ".payerAndAdd" ? do +    Media.tabletDesktop $ display flex +    marginBottom (em 1) + +    ".exceedingPayers" ? do +      backgroundColor Color.mossGreen +      borderRadius (px 5) (px 5) (px 5) (px 5) +      color Color.white +      lineHeight (px Constants.inputHeight) +      paddingLeft (px 10) +      paddingRight (px 10) + +      Media.tabletDesktop $ do +        "flex-grow" -: "1" +        marginRight (px 15) + +      Media.mobile $ do +        marginBottom (em 1) +        textAlign (alignSide sideCenter) + +      ".exceedingPayer:not(:last-child)::after" ? content (stringContent ", ") + +      ".userName" ? marginRight (px 8) + +    ".addPayment" ? do +      Helper.button Color.chestnutRose Color.white (px Constants.inputHeight) Constants.focusLighten +      Media.mobile $ width (pct 100) + +  ".searchLine" ? do +    marginBottom (em 1) +    form ? do +      Media.mobile $ textAlign (alignSide sideCenter) + +      ".textInput" ? do +        display inlineBlock +        marginBottom (px 0) + +        Media.tabletDesktop $ marginRight (px 30) +        Media.mobile $ do +          marginBottom (em 1) +          width (pct 100) + +      ".radioGroup" ? do +        display inlineBlock +        marginBottom (px 0) +        ".title" ? display none + +  ".infos" ? do +    Media.tabletDesktop $ lineHeight (px Constants.inputHeight) +    Media.mobile $ lineHeight (px 25) + +    ".total" <> ".partition" ? do +      Media.mobileTablet $ display block +      Media.mobile $ do +        fontSize (pct 90) +        textAlign (alignSide sideCenter) + +    ".partition" ? do +      color Color.dustyGray +      Media.desktop $ marginLeft (px 15) diff --git a/server/src/Design/View/Payment/Pages.hs b/server/src/Design/View/Payment/Pages.hs new file mode 100644 index 0000000..ade81a8 --- /dev/null +++ b/server/src/Design/View/Payment/Pages.hs @@ -0,0 +1,54 @@ +{-# LANGUAGE OverloadedStrings #-} + +module Design.View.Payment.Pages +  ( design +  ) where + +import Clay + +import qualified Design.Color as Color +import qualified Design.Helper as Helper +import qualified Design.Constants as Constants +import qualified Design.Media as Media + +design :: Css +design = do +  textAlign (alignSide sideCenter) +  Helper.clearFix + +  Media.desktop $ do +    padding (px 40) (px 30) (px 30) (px 30) + +  Media.tablet $ do +    padding (px 30) (px 30) (px 30) (px 30) + +  Media.mobile $ do +    padding (px 20) (px 0) (px 20) (px 0) +    lineHeight (px 40) + +  ".page" ? do +    display inlineBlock +    fontWeight bold + +    Media.desktop $ do +      Helper.button Color.white Color.dustyGray (px 50) Constants.focusDarken + +    Media.tabletDesktop $ do +      border solid (px 2) Color.dustyGray +      marginRight (px 10) + +    Media.tablet $ do +      Helper.button Color.white Color.dustyGray (px 40) Constants.focusDarken +      fontSize (px 15) + +    Media.mobile $ do +      Helper.button Color.white Color.dustyGray (px 30) Constants.focusDarken +      fontSize (px 12) +      border solid (px 1) Color.dustyGray +      marginRight (px 5) + +    ":not(.current)" & cursor pointer + +    ".current" & do +      borderColor Color.chestnutRose +      color Color.chestnutRose diff --git a/server/src/Design/View/Payment/Table.hs b/server/src/Design/View/Payment/Table.hs new file mode 100644 index 0000000..a866b40 --- /dev/null +++ b/server/src/Design/View/Payment/Table.hs @@ -0,0 +1,42 @@ +{-# LANGUAGE OverloadedStrings #-} + +module Design.View.Payment.Table +  ( design +  ) where + +import Clay + +import qualified Design.Color as Color +import qualified Design.Media as Media + +design :: Css +design = do +  ".cell" ? do +    ".name" & do +      Media.tabletDesktop $ width (pct 30) + +    ".cost" & do +      Media.tabletDesktop $ width (pct 10) + +    ".user" & do +      Media.tabletDesktop $ width (pct 15) + +    ".category" & do +      Media.tabletDesktop $ width (pct 10) + +    ".date" & do +      Media.tabletDesktop $ width (pct 15) +      Media.desktop $ do +        ".shortDate" ? display none +        ".longDate" ? display inline +      Media.tablet $ do +        ".shortDate" ? display inline +        ".longDate" ? display none +      Media.mobile $ do +        ".shortDate" ? display none +        ".longDate" ? display inline +        marginBottom (em 0.5) + +    ".button" & svg ? do +      "path" ? ("fill" -: (plain . unValue . value $ Color.chestnutRose)) +      width (px 18) | 
