diff options
Diffstat (limited to 'client')
| -rw-r--r-- | client/src/Component/Input.hs | 2 | ||||
| -rw-r--r-- | client/src/Component/Table.hs | 9 | ||||
| -rw-r--r-- | client/src/View/Category/Category.hs | 34 | ||||
| -rw-r--r-- | client/src/View/Category/Table.hs | 16 | ||||
| -rw-r--r-- | client/src/View/Income/Table.hs | 3 | ||||
| -rw-r--r-- | client/src/View/Payment/Table.hs | 3 | 
6 files changed, 36 insertions, 31 deletions
| diff --git a/client/src/Component/Input.hs b/client/src/Component/Input.hs index 37020da..bcff377 100644 --- a/client/src/Component/Input.hs +++ b/client/src/Component/Input.hs @@ -57,7 +57,7 @@ view input reset validate = do            ]          inputAttr = R.ffor value (\v -> -          if T.null v && _in_inputType input /= "date" +          if T.null v && _in_inputType input /= "date" && _in_inputType input /= "color"              then M.empty              else M.singleton "class" "filled") diff --git a/client/src/Component/Table.hs b/client/src/Component/Table.hs index f82cfa6..1482f91 100644 --- a/client/src/Component/Table.hs +++ b/client/src/Component/Table.hs @@ -21,7 +21,8 @@ data In m t h r = In    , _in_cloneModal  :: r -> Modal.Content t m    , _in_editModal   :: r -> Modal.Content t m    , _in_deleteModal :: r -> Modal.Content t m -  , _in_isOwner     :: r -> Bool +  , _in_canEdit     :: r -> Bool +  , _in_canDelete   :: r -> Bool    }  data Out t = Out @@ -62,8 +63,6 @@ view input =                  , Modal._in_content = _in_cloneModal input row                  } -            let isOwner = _in_isOwner input row -              let visibleIf cond =                    R.elAttr                      "div" @@ -71,7 +70,7 @@ view input =              editButton <-                R.divClass "cell button" $ -                visibleIf isOwner $ +                visibleIf (_in_canEdit input row) $                    Button._out_clic <$> (Button.view $                      Button.defaultIn Icon.edit) @@ -83,7 +82,7 @@ view input =              deleteButton <-                R.divClass "cell button" $ -                visibleIf isOwner $ +                visibleIf (_in_canDelete input row) $                    Button._out_clic <$> (Button.view $                      Button.defaultIn Icon.delete) diff --git a/client/src/View/Category/Category.hs b/client/src/View/Category/Category.hs index 77a331a..5b41bb6 100644 --- a/client/src/View/Category/Category.hs +++ b/client/src/View/Category/Category.hs @@ -53,13 +53,14 @@ view input = do      deleteCategory <- eventFromResult $ Table._out_delete . (\(_, b, _) -> b)      result <- Loadable.viewShowValueWhileLoading categoryPage $ -      \(CategoryPage page categories count) -> do +      \(CategoryPage page categories usedCategories count) -> do          header <- headerView          table <- Table.view $ Table.In            { Table._in_currentUser = _in_currentUser input            , Table._in_currency = _in_currency input            , Table._in_categories = categories +          , Table._in_usedCategories = usedCategories            , Table._in_users = _in_users input            } @@ -75,18 +76,19 @@ view input = do  headerView :: forall t m. MonadWidget t m => m (Event t ())  headerView = -  R.divClass "titleButton" $ do -    R.el "h1" $ -      R.text $ -        Msg.get Msg.Category_Title - -    addCategory <- Button._out_clic <$> -      (Button.view . Button.defaultIn . R.text $ -        Msg.get Msg.Category_Add) - -    addCategory <- Modal.view $ Modal.In -      { Modal._in_show    = addCategory -      , Modal._in_content = Form.view $ Form.In { Form._in_operation = Form.New } -      } - -    return addCategory +  R.divClass "withMargin" $ +    R.divClass "titleButton" $ do +      R.el "h1" $ +        R.text $ +          Msg.get Msg.Category_Title + +      addCategory <- Button._out_clic <$> +        (Button.view . Button.defaultIn . R.text $ +          Msg.get Msg.Category_Add) + +      addCategory <- Modal.view $ Modal.In +        { Modal._in_show    = addCategory +        , Modal._in_content = Form.view $ Form.In { Form._in_operation = Form.New } +        } + +      return addCategory diff --git a/client/src/View/Category/Table.hs b/client/src/View/Category/Table.hs index fbe76e9..90d013d 100644 --- a/client/src/View/Category/Table.hs +++ b/client/src/View/Category/Table.hs @@ -10,8 +10,8 @@ import qualified Data.Text               as T  import           Reflex.Dom              (Dynamic, Event, MonadWidget)  import qualified Reflex.Dom              as R -import           Common.Model            (Category (..), Currency, User (..), -                                          UserId) +import           Common.Model            (Category (..), CategoryId, Currency, +                                          User (..), UserId)  import qualified Common.Model            as CM  import qualified Common.Msg              as Msg  import qualified Common.View.Format      as Format @@ -24,10 +24,11 @@ import qualified Util.Either             as EitherUtil  import qualified View.Category.Form      as Form  data In t = In -  { _in_currentUser :: UserId -  , _in_currency    :: Currency -  , _in_categories  :: [Category] -  , _in_users       :: [User] +  { _in_currentUser    :: UserId +  , _in_currency       :: Currency +  , _in_categories     :: [Category] +  , _in_usedCategories :: [CategoryId] +  , _in_users          :: [User]    }  data Out t = Out @@ -60,7 +61,8 @@ view input = do              e            return $ () <$ R.fmapMaybe EitherUtil.eitherToMaybe res          } -    , Table._in_isOwner = const True +    , Table._in_canEdit = const True +    , Table._in_canDelete = not . flip elem (_in_usedCategories input) . _category_id      }    return $ Out diff --git a/client/src/View/Income/Table.hs b/client/src/View/Income/Table.hs index c7f172b..7b7940d 100644 --- a/client/src/View/Income/Table.hs +++ b/client/src/View/Income/Table.hs @@ -59,7 +59,8 @@ view input = do              e            return $ () <$ R.fmapMaybe EitherUtil.eitherToMaybe res          } -    , Table._in_isOwner = (== (_in_currentUser input)) . _income_userId +    , Table._in_canEdit = (== (_in_currentUser input)) . _income_userId +    , Table._in_canDelete = (== (_in_currentUser input)) . _income_userId      }    return $ Out diff --git a/client/src/View/Payment/Table.hs b/client/src/View/Payment/Table.hs index 6744d3a..bfa0fb9 100644 --- a/client/src/View/Payment/Table.hs +++ b/client/src/View/Payment/Table.hs @@ -74,7 +74,8 @@ view input = do              e            return $ () <$ R.fmapMaybe EitherUtil.eitherToMaybe res          } -    , Table._in_isOwner = (== (_in_currentUser input)) . _payment_user +    , Table._in_canEdit = (== (_in_currentUser input)) . _payment_user +    , Table._in_canDelete = (== (_in_currentUser input)) . _payment_user      }    return $ Out | 
