Action.purs 6.34 KB
Newer Older
1
module Gargantext.Components.Forest.Tree.Node.Action where
2

3 4
import Data.Generic.Rep (class Generic)
import Data.Generic.Rep.Eq (genericEq)
5
import Data.Maybe (Maybe(..))
6
import Effect.Aff (Aff)
7

8 9
import Gargantext.Prelude

10 11
import Gargantext.Components.Forest.Tree.Node.Tools.SubTree.Types (SubTreeOut, SubTreeParams(..))
import Gargantext.Components.Forest.Tree.Node.Settings (NodeAction(..), glyphiconNodeAction)
12
import Gargantext.Components.Forest.Tree.Node.Action.Upload.Types (FileType, UploadFileBlob)
13
import Gargantext.Components.Forest.Tree.Node.Action.Update.Types (UpdateNodeParams)
14
import Gargantext.Components.Forest.Tree.Node.Action.Contact.Types (AddContactParams)
15 16
import Gargantext.Sessions (Session)
import Gargantext.Types  as GT
17 18 19 20 21 22

type Props =
  ( dispatch :: Action -> Aff Unit
  , id       :: Int
  , nodeType :: GT.NodeType
  , session  :: Session
Alexandre Delanoë's avatar
Alexandre Delanoë committed
23
  )
24

25

26
data Action = AddNode     String GT.NodeType
27
            | DeleteNode  GT.NodeType
28
            | RenameNode  String
29
            | UpdateNode  UpdateNodeParams
30
            | DoSearch    GT.AsyncTaskWithType
31
            | UploadFile  GT.NodeType FileType (Maybe String) UploadFileBlob
32
            | UploadArbitraryFile  (Maybe String) UploadFileBlob
33
            | DownloadNode
34
            | RefreshTree
35
            | ClosePopover
36

37
            | ShareTeam   String
38
            | AddContact  AddContactParams
39 40 41
            | SharePublic {params :: Maybe SubTreeOut}
            | MoveNode    {params :: Maybe SubTreeOut}
            | MergeNode   {params :: Maybe SubTreeOut}
42
            | LinkNode    {nodeType :: Maybe GT.NodeType, params :: Maybe SubTreeOut}
43

44
            | NoAction
45

46

47
subTreeOut :: Action -> Maybe SubTreeOut
48 49 50 51
subTreeOut (MoveNode    {params}) = params
subTreeOut (MergeNode   {params}) = params
subTreeOut (LinkNode    {params}) = params
subTreeOut (SharePublic {params}) = params
52 53 54
subTreeOut _                    = Nothing

setTreeOut ::  Action -> Maybe SubTreeOut -> Action
Alexandre Delanoë's avatar
Alexandre Delanoë committed
55
setTreeOut (MoveNode  {params:_}) p = MoveNode  {params: p}
Alexandre Delanoë's avatar
Alexandre Delanoë committed
56
setTreeOut (MergeNode {params:_}) p = MergeNode {params: p}
57
setTreeOut (LinkNode  {nodeType, params:_}) p = LinkNode  {nodeType, params: p}
58
setTreeOut (SharePublic {params:_}) p = SharePublic  {params: p}
59 60
setTreeOut a   _             = a

61
derive instance genericAction :: Generic Action _
62

63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
instance eqAction :: Eq Action where
  eq (AddNode s1 nt1) (AddNode s2 nt2) = (eq s1 s2) && (eq nt1 nt2)
  eq (DeleteNode nt1) (DeleteNode nt2) = eq nt1 nt2
  eq (RenameNode s1) (RenameNode s2) = eq s1 s2
  eq (UpdateNode un1) (UpdateNode un2) = eq un1 un2
  eq (DoSearch at1) (DoSearch at2) = eq at1 at2
  eq (UploadFile nt1 ft1 s1 _) (UploadFile nt2 ft2 s2 _) = (eq nt1 nt2) && (eq ft1 ft2) && (eq s1 s2)
  eq (UploadArbitraryFile s1 _) (UploadArbitraryFile s2 _) = eq s1 s2
  eq DownloadNode DownloadNode = true
  eq RefreshTree RefreshTree = true
  eq ClosePopover ClosePopover = true
  eq (ShareTeam s1) (ShareTeam s2) = eq s1 s2
  eq (AddContact ac1) (AddContact ac2) = eq ac1 ac2
  eq (SharePublic p1) (SharePublic p2) = eq p1 p2
  eq (MoveNode p1) (MoveNode p2) = eq p1 p2
  eq (MergeNode p1) (MergeNode p2) = eq p1 p2
  eq (LinkNode l1) (LinkNode l2) = eq l1 l2
  eq NoAction NoAction = true
  eq _ _ = false

instance showAction :: Show Action where
84 85 86 87 88 89 90 91 92
  show (AddNode     _ _    )      = "AddNode"
  show (DeleteNode  _      )      = "DeleteNode"
  show (RenameNode  _      )      = "RenameNode"
  show (UpdateNode  _      )      = "UpdateNode"
  show (ShareTeam   _      )      = "ShareTeam"
  show (AddContact  _      )      = "AddContact"
  show (SharePublic _      )      = "SharePublic"
  show (DoSearch    _      )      = "SearchQuery"
  show (UploadFile  _ _ _ _)      = "UploadFile"
93
  show (UploadArbitraryFile  _ _) = "UploadArbitraryFile"
94 95 96 97 98 99 100
  show  RefreshTree               = "RefreshTree"
  show  ClosePopover              = "ClosePopover"
  show  DownloadNode              = "Download"
  show (MoveNode  _ )             = "MoveNode"
  show (MergeNode _ )             = "MergeNode"
  show (LinkNode  _ )             = "LinkNode"
  show NoAction                   = "NoAction"
101

102
-----------------------------------------------------------------------
103
icon :: Action -> String
104 105 106 107 108 109 110 111 112
icon (AddNode    _ _)             = glyphiconNodeAction (Add [])
icon (DeleteNode _)               = glyphiconNodeAction Delete
icon (RenameNode _)               = glyphiconNodeAction Config
icon (UpdateNode _)               = glyphiconNodeAction Refresh
icon (ShareTeam   _)              = glyphiconNodeAction Share
icon (AddContact  _)              = glyphiconNodeAction Share
icon (SharePublic _ )             = glyphiconNodeAction (Publish { subTreeParams : SubTreeParams {showtypes:[], valitypes:[] }})
icon (DoSearch   _)               = glyphiconNodeAction SearchBox
icon (UploadFile _ _ _ _)         = glyphiconNodeAction Upload
113
icon (UploadArbitraryFile _ _ ) = glyphiconNodeAction Upload
114
icon  RefreshTree                 = glyphiconNodeAction Refresh
115
icon  ClosePopover                = glyphiconNodeAction CloseNodePopover
116 117 118 119
icon  DownloadNode                = glyphiconNodeAction Download
icon (MoveNode _ )                = glyphiconNodeAction (Move  { subTreeParams : SubTreeParams {showtypes:[], valitypes:[] }})
icon (MergeNode _ )               = glyphiconNodeAction (Merge { subTreeParams : SubTreeParams {showtypes:[], valitypes:[] }})
icon (LinkNode _  )               = glyphiconNodeAction (Link  { subTreeParams : SubTreeParams {showtypes:[], valitypes:[] }})
120

121
icon NoAction                     = "hand-o-right"
122

123 124
-- icon _             = "hand-o-right"

125
text :: Action -> String
126 127 128 129 130 131 132 133 134
text (AddNode     _ _    )      = "Add !"
text (DeleteNode _       )      = "Delete !"
text (RenameNode  _      )      = "Rename !"
text (UpdateNode  _      )      = "Update !"
text (ShareTeam   _      )      = "Share with team !"
text (AddContact  _      )      = "Add contact !"
text (SharePublic _      )      = "Publish !"
text (DoSearch    _      )      = "Launch search !"
text (UploadFile  _ _ _ _)      = "Upload File !"
135
text (UploadArbitraryFile  _ _) = "Upload arbitrary file !"
136 137 138 139 140 141 142
text  RefreshTree               = "Refresh Tree !"
text  ClosePopover              = "Close Popover !"
text DownloadNode               = "Download !"
text (MoveNode  _ )             = "Move !"
text (MergeNode _ )             = "Merge !"
text (LinkNode  _ )             = "Link !"
text NoAction                   = "No Action"
143
-----------------------------------------------------------------------