Tabs.purs 2.11 KB
Newer Older
1 2 3 4 5 6 7 8
module Gargantext.Pages.Corpus.Graph.Tabs where

import Prelude hiding (div)
import Data.Lens (view)
import Data.List (fromFoldable)
import Data.Tuple (Tuple(..))
import Gargantext.Config (TabType(..), TabSubType(..))
import Gargantext.Components.GraphExplorer.Types (GraphSideCorpus(..))
9
import Gargantext.Components.FacetsTable (TextQuery, docViewSpec)
10
import Gargantext.Components.Table as T
11 12 13 14 15 16
import Gargantext.Components.Tab as Tab
import React (ReactElement, ReactClass, Children, createElement)
import Thermite ( Spec, PerformAction, Render, _performAction, _render
                , hideState, noState, cmapProps, simpleSpec, createClass
                )

17
type Props = { query :: TextQuery, sides :: Array GraphSideCorpus }
18 19 20 21 22

tabsElt :: Props -> ReactElement
tabsElt props = createElement tabsClass props []

-- TODO no need for Children here
23
tabsClass :: ReactClass { query :: TextQuery, sides :: Array GraphSideCorpus, children :: Children }
24 25 26 27 28
tabsClass = createClass "GraphTabs" pureTabs (const {})

pureTabs :: Spec {} Props Void
pureTabs = hideState (const {activeTab: 0}) statefulTabs

29
tab :: forall props state. TextQuery -> GraphSideCorpus -> Tuple String (Spec state props Tab.Action)
30
tab query (GraphSideCorpus {corpusId: nodeId, corpusLabel}) =
31
  Tuple corpusLabel $
32
    cmapProps (const {nodeId, query, chart, totalRecords: 4736, container}) $
33
      noState docViewSpec
34 35 36
  where
    -- TODO totalRecords: probably need to insert a corpusLoader.
    chart = mempty
37
    container = T.graphContainer {title: corpusLabel}
38 39 40

statefulTabs :: Spec Tab.State Props Tab.Action
statefulTabs =
41 42
  withProps (\{query, sides} ->
    Tab.tabs identity identity $ fromFoldable $ tab query <$> sides)
43 44 45 46 47 48 49 50 51 52 53 54 55 56

-- TODO move to Thermite
-- | This function captures the props of the `Spec` as a function argument.
withProps
  :: forall state props action
   . (props -> Spec state props action)
  -> Spec state props action
withProps f = simpleSpec performAction render
  where
    performAction :: PerformAction state props action
    performAction a p st = view _performAction (f p) a p st

    render :: Render state props action
    render k p st = view _render (f p) k p st