Routes.purs 7.39 KB
Newer Older
1 2 3
module Gargantext.Routes where

import Prelude
4

5
import Data.Maybe (Maybe(..))
6 7
import Data.UUID (UUID)
import Gargantext.Types (ChartOpts, ChartType, CorpusMetricOpts, CTabNgramType, Id, Limit, ListId, DocId, NgramsGetOpts, NgramsGetTableAllOpts, NodeType, Offset, OrderBy, SearchOpts, SessionId, TabSubType, TabType, TermList)
8
import Gargantext.Types as GT
9 10

data AppRoute
11
  = Annuaire       SessionId Int
12
  | ContactPage    SessionId Int Int
13
  | Corpus         SessionId Int
14
  | CorpusCode     SessionId Int
15 16 17
  | CorpusDocument SessionId Int Int Int
  | Dashboard      SessionId Int
  | Document       SessionId Int Int
18 19 20 21
  | Folder         SessionId Int
  | FolderPrivate  SessionId Int
  | FolderPublic   SessionId Int
  | FolderShared   SessionId Int
22 23 24
  | Home
  | Lists          SessionId Int
  | Login
25
  | PGraphExplorer  SessionId Int
26
  | PhyloExplorer   SessionId Int
27
  | RouteFile       SessionId Int
28
  | RouteFrameCalc  SessionId Int
29
  | RouteFrameCode  SessionId Int
30
  | RouteFrameWrite SessionId Int
31
  | RouteFrameVisio SessionId Int
32
  | Team            SessionId Int
33
  | NodeTexts       SessionId Int
34
  | UserPage        SessionId Int
35

36

37
derive instance Eq AppRoute
38

39 40 41 42
data SessionRoute
  = Tab TabType (Maybe Id)
  | Children NodeType Offset Limit (Maybe OrderBy) (Maybe Id)
  | GetNgrams NgramsGetOpts (Maybe Id)
43
  | GetNgramsTableAll NgramsGetTableAllOpts (Maybe Id)
44
  | GetNgramsTableVersion { listId :: ListId, tabType :: TabType } (Maybe Id)
Alexandre Delanoë's avatar
Alexandre Delanoë committed
45
  | PutNgrams TabType (Maybe ListId) (Maybe TermList) (Maybe Id)
46
  | PostNgramsChartsAsync (Maybe Id)
Alexandre Delanoë's avatar
Alexandre Delanoë committed
47
  -- ^ This name is not good. In particular this URL is used both in PUT and POST.
48 49 50
  | RecomputeNgrams   (TabSubType CTabNgramType) Id ListId
  | RecomputeListChart ChartType  CTabNgramType  Id ListId
  | NodeAPI       NodeType (Maybe Id) String
51
  | TreeFirstLevel (Maybe Id) String
52 53
  | GraphAPI      Id String
  | ListsRoute    ListId
54
  | ListDocument (Maybe ListId) (Maybe DocId)
55
  | Search        SearchOpts (Maybe Id)
56
  | CorpusMetrics CorpusMetricOpts  (Maybe Id)
57
  | CorpusMetricsHash { listId :: ListId, tabType :: TabType }  (Maybe Id)
58
  | Chart ChartOpts (Maybe Id)
59
  | ChartHash { chartType :: ChartType, listId :: Maybe ListId, tabType :: TabType } (Maybe Id)
60
  -- | AnnuaireContact AnnuaireId DocId
61
  | PhyloAPI Id
62

63
instance Show AppRoute where
64 65
  show Home                     = "Home"
  show Login                    = "Login"
66 67 68 69 70 71
  show (Folder        s i)      = "Folder"         <> show i <> " (" <> show s <> ")"
  show (FolderPrivate s i)      = "FolderPrivate"  <> show i <> " (" <> show s <> ")"
  show (FolderPublic  s i)      = "FolderPublic"   <> show i <> " (" <> show s <> ")"
  show (FolderShared  s i)      = "FolderShared"   <> show i <> " (" <> show s <> ")"
  show (Team          s i)      = "Team"           <> show i <> " (" <> show s <> ")"
  show (Corpus        s i)      = "Corpus"         <> show i <> " (" <> show s <> ")"
72
  show (CorpusCode    s i)      = "CorpusCode"     <> show i <> " (" <> show s <> ")"
73
  show (Document    _ s i)      = "Document"       <> show i <> " (" <> show s <> ")"
74
  show (CorpusDocument s _ _ i) = "CorpusDocument" <> show i <> " (" <> show s <> ")"
75
  show (PGraphExplorer s i)     = "graphExplorer"  <> show i <> " (" <> show s <> ")"
76
  show (PhyloExplorer  s i)     = "phyloExplorer"  <> show i <> " (" <> show s <> ")"
77
  show (Dashboard      s i)     = "Dashboard"      <> show i <> " (" <> show s <> ")"
78
  show (NodeTexts      s i)     = "texts"          <> show i <> " (" <> show s <> ")"
79 80 81 82
  show (Lists          s i)     = "lists"          <> show i <> " (" <> show s <> ")"
  show (Annuaire       s i)     = "Annuaire"       <> show i <> " (" <> show s <> ")"
  show (UserPage       s i)     = "User"           <> show i <> " (" <> show s <> ")"
  show (ContactPage  s a i)     = "Contact"        <> show a <> "::" <> show i <> " (" <> show s <> ")"
83 84
  show (RouteFrameWrite s i)    = "write"          <> show i <> " (" <> show s <> ")"
  show (RouteFrameCalc  s i)    = "calc"           <> show i <> " (" <> show s <> ")"
85
  show (RouteFrameCode  s i)    = "code"           <> show i <> " (" <> show s <> ")"
86
  show (RouteFrameVisio s i)    = "visio"          <> show i <> " (" <> show s <> ")"
87
  show (RouteFile       s i)    = "file"           <> show i <> " (" <> show s <> ")"
88

89 90

appPath :: AppRoute -> String
91 92 93 94 95 96 97
appPath Home                     = ""
appPath Login                    = "login"
appPath (Folder s i)             = "folder/"        <> show s <> "/" <> show i
appPath (FolderPrivate s i)      = "folderPrivate/" <> show s <> "/" <> show i
appPath (FolderPublic s i)       = "folderPublic/"  <> show s <> "/" <> show i
appPath (FolderShared s i)       = "folderShared/"  <> show s <> "/" <> show i
appPath (Team s i)               = "team/"          <> show s <> "/" <> show i
98
appPath (CorpusDocument s c l i) = "corpus/" <> show s <> "/" <> show c <> "/list/" <> show l <> "/document/" <> show i
99
appPath (Corpus s i)             = "corpus/"     <> show s <> "/" <> show i
100
appPath (CorpusCode s i)         = "corpusCode/" <> show s <> "/" <> show i
101 102 103
appPath (Document s l i)         = "list/"       <> show s <> "/" <> show l <> "/document/" <> show i
appPath (Dashboard s i)          = "dashboard/"  <> show s <> "/" <> show i
appPath (PGraphExplorer s i)     = "graph/"      <> show s <> "/" <> show i
104
appPath (PhyloExplorer  s i)     = "phylo/"      <> show s <> "/" <> show i
105
appPath (NodeTexts s i)          = "texts/"      <> show s <> "/" <> show i
106 107 108 109 110
appPath (Lists s i)              = "lists/"      <> show s <> "/" <> show i
appPath (Annuaire s i)           = "annuaire/"   <> show s <> "/" <> show i
appPath (UserPage s i)           = "user/"       <> show s <> "/" <> show i
appPath (ContactPage s a i)      = "annuaire/"   <> show s <> "/" <> show a <> "/contact/" <> show i
appPath (RouteFrameWrite s i)    = "write/"     <> show s <> "/" <> show i
111 112 113
appPath (RouteFrameCalc  s i)     = "calc/"      <> show s <> "/" <> show i
appPath (RouteFrameCode  s i)     = "code/"      <> show s <> "/" <> show i
appPath (RouteFrameVisio s i)     = "visio/"      <> show s <> "/" <> show i
114
appPath (RouteFile s i)          = "file/"      <> show s <> "/" <> show i
115

116
nodeTypeAppRoute :: NodeType -> SessionId -> Int -> Maybe AppRoute
Karen Konou's avatar
Karen Konou committed
117 118 119 120 121 122 123 124
nodeTypeAppRoute GT.Annuaire s i       = Just $ Annuaire s i
nodeTypeAppRoute GT.Corpus s i         = Just $ Corpus s i
nodeTypeAppRoute GT.Dashboard s i      = Just $ Dashboard s i
nodeTypeAppRoute GT.Folder s i         = Just $ Folder s i
nodeTypeAppRoute GT.FolderPrivate s i  = Just $ FolderPrivate s i
nodeTypeAppRoute GT.FolderPublic s i   = Just $ FolderPublic s i
nodeTypeAppRoute GT.FolderShared s i   = Just $ FolderShared s i
nodeTypeAppRoute GT.Graph s i          = Just $ PGraphExplorer s i
125
nodeTypeAppRoute GT.Phylo s i          = Just $ PhyloExplorer  s i
Karen Konou's avatar
Karen Konou committed
126 127 128 129 130
nodeTypeAppRoute GT.NodeContact s i    = Just $ Annuaire s i
nodeTypeAppRoute GT.NodeFile s i       = Just $ RouteFile s i
nodeTypeAppRoute GT.NodeList s i       = Just $ Lists s i
nodeTypeAppRoute GT.NodeUser s i       = Just $ UserPage s i
nodeTypeAppRoute GT.Team s i           = Just $ Team s i
131
nodeTypeAppRoute GT.NodeTexts s i      = Just $ NodeTexts s i
Karen Konou's avatar
Karen Konou committed
132
nodeTypeAppRoute GT.NodeFrameWrite s i = Just $ RouteFrameWrite s i
133 134
nodeTypeAppRoute GT.NodeFrameCalc  s i = Just $ RouteFrameCalc  s i
nodeTypeAppRoute GT.NodeFrameVisio s i = Just $ RouteFrameVisio s i
Karen Konou's avatar
Karen Konou committed
135
nodeTypeAppRoute _ _ _                 = Nothing
136 137 138 139 140 141 142 143


------------------------------------------------------

type Tile =
  ( id    :: UUID
  , route :: AppRoute
  )