diff options
| author | Joris | 2019-10-22 23:25:05 +0200 | 
|---|---|---|
| committer | Joris | 2019-10-22 23:25:05 +0200 | 
| commit | 61ff1443c42def5a09f624e3df2e2520e97610d0 (patch) | |
| tree | a177b297b2c0728c8edaaf200f05c53e76f121f3 /client/src/Component | |
| parent | 613ffccac4b3ab25c6d4c631fab757da0b35acf6 (diff) | |
Clone incomes
Diffstat (limited to 'client/src/Component')
| -rw-r--r-- | client/src/Component/Table.hs | 54 | 
1 files changed, 40 insertions, 14 deletions
| diff --git a/client/src/Component/Table.hs b/client/src/Component/Table.hs index bf76566..5819f45 100644 --- a/client/src/Component/Table.hs +++ b/client/src/Component/Table.hs @@ -4,56 +4,82 @@ module Component.Table    , Out(..)    ) where -import           Data.Text       (Text) -import           Reflex.Dom      (Dynamic, Event, MonadWidget) -import qualified Reflex.Dom      as R +import           Data.Text        (Text) +import           Reflex.Dom       (Dynamic, Event, MonadWidget) +import qualified Reflex.Dom       as R -import qualified Component.Pages as Pages +import qualified Component.Button as Button +import qualified Component.Modal  as Modal +import qualified Component.Pages  as Pages +import qualified Util.Reflex      as ReflexUtil +import qualified View.Icon        as Icon -data In h r t = In +data In m t h r a = In    { _in_headerLabel :: h -> Text    , _in_rows        :: Dynamic t [r]    , _in_cell        :: h -> r -> Text    , _in_perPage     :: Int    , _in_resetPage   :: Event t () +  , _in_cloneModal  :: Dynamic t r -> Modal.Content t m a    } -data Out = Out -  {} +data Out t a = Out +  { _out_add :: Event t a +  } -view :: forall t m h r. (MonadWidget t m, Bounded h, Enum h)  => In h r t -> m (Out) +view :: forall t m h r a. (MonadWidget t m, Bounded h, Enum h)  => In m t h r a -> m (Out t a)  view input =    R.divClass "table" $ do      rec -      R.divClass "lines" $ do +      result <- R.divClass "lines" $ do -        R.divClass "header" $ +        R.divClass "header" $ do            flip mapM_ [minBound..] $ \header ->              R.divClass "cell" . R.text $                _in_headerLabel input header +          R.divClass "cell" $ R.blank +          let rows = getRange                (_in_perPage input)                  <$> (Pages._out_currentPage pages)                  <*> (_in_rows input)          R.simpleList rows $ \r -> -          R.divClass "row" $ +          R.divClass "row" $ do              flip mapM_ [minBound..] $ \h -> -              R.divClass "cell name" $ +              R.divClass "cell" $                  R.dynText $                    R.ffor r (_in_cell input h) +            clone <- +              R.divClass "cell button" $ +                Button._out_clic <$> (Button.view $ +                  Button.defaultIn Icon.clone) + +            cloned <- +              Modal.view $ Modal.In +                { Modal._in_show    = clone +                , Modal._in_content = _in_cloneModal input r +                } + +            return cloned +        pages <- Pages.view $ Pages.In          { Pages._in_total = length <$> (_in_rows input)          , Pages._in_perPage = _in_perPage input          , Pages._in_reset = _in_resetPage input          } -      return () +      -- return $ +      --   ( R.switch . R.current . fmap (R.leftmost . map (\(a, _, _) -> a)) $ result +      --   , R.switch . R.current . fmap (R.leftmost . map (\(_, b, _) -> b)) $ result +      --   , R.switch . R.current . fmap (R.leftmost . map (\(_, _, c) -> c)) $ result +      --   )      return $ Out -      {} +      { _out_add = R.switch . R.current . fmap R.leftmost $ result +      }  getRange :: forall a. Int -> Int -> [a] -> [a]  getRange perPage currentPage = | 
