ButtonGroup.purs 1.32 KB
Newer Older
arturo's avatar
arturo committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
module Gargantext.Components.Bootstrap.ButtonGroup
  ( buttonGroup
  ) where

import Gargantext.Prelude

import Data.Foldable (intercalate)
import Gargantext.Utils ((?))
import Gargantext.Utils.Reactix as R2
import Reactix as R
import Reactix.DOM.HTML as H

type Props   = ( | Options )
type Options =
  ( className :: String
  , collapse  :: Boolean
  )

options :: Record Options
options =
  { className : ""
  , collapse  : true
  }

-- | Structural Component for the Bootstrap Button Group
-- |
-- | https://getbootstrap.com/docs/4.0/components/button-group/
buttonGroup :: forall r. R2.OptComponent Options Props r
buttonGroup = R2.optComponent component options

componentName :: String
componentName = "b-button-group"

bootstrapName :: String
bootstrapName = "btn-group"

component :: R.Component Props
component = R.hooksComponent componentName cpt where
  cpt props children = do
    -- Computed
    let
      className = intercalate " "
        -- provided custom className
        [ props.className
        -- BEM classNames
        , componentName
        , props.collapse ?
            componentName <> "--collapse" $
            componentName <> "--no-collapse"
        -- Bootstrap specific classNames
        , bootstrapName
        ]

    -- Render
    pure $

      H.div
      { className
      , role: "group"
      }
      children