Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
purescript-gargantext
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Grégoire Locqueville
purescript-gargantext
Commits
113500f8
Commit
113500f8
authored
Dec 02, 2018
by
Alexandre Delanoë
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[Annuaire Table] fix fields and adding fields to Contact.
parent
0df854d6
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
109 additions
and
22 deletions
+109
-22
Annuaire.purs
src/Gargantext/Pages/Annuaire.purs
+17
-6
Renders.purs
...argantext/Pages/Annuaire/User/Contacts/Specs/Renders.purs
+11
-6
Types.purs
src/Gargantext/Pages/Annuaire/User/Contacts/Types.purs
+81
-10
No files found.
src/Gargantext/Pages/Annuaire.purs
View file @
113500f8
module Gargantext.Pages.Annuaire where
module Gargantext.Pages.Annuaire where
import Data.Array (head)
import Data.Argonaut (class DecodeJson, decodeJson, (.?), (.??))
import Data.Argonaut (class DecodeJson, decodeJson, (.?), (.??))
import Data.Lens (Prism', prism)
import Data.Lens (Prism', prism)
import Data.Either (Either(..))
import Data.Either (Either(..))
...
@@ -24,7 +25,7 @@ import Gargantext.Components.Tab as Tab
...
@@ -24,7 +25,7 @@ import Gargantext.Components.Tab as Tab
import Gargantext.Components.Table as T
import Gargantext.Components.Table as T
import Gargantext.Config (toUrl, Path(..), NodeType(..), TabType(..), End(..))
import Gargantext.Config (toUrl, Path(..), NodeType(..), TabType(..), End(..))
import Gargantext.Config.REST (get)
import Gargantext.Config.REST (get)
import Gargantext.Pages.Annuaire.User.Contacts.Types (Contact(..), HyperData(..), HyperdataContact(..))
import Gargantext.Pages.Annuaire.User.Contacts.Types (Contact(..), HyperData(..), HyperdataContact(..)
, ContactWhere(..)
)
------------------------------------------------------------------------------
------------------------------------------------------------------------------
type Props = Loader.InnerProps Int AnnuaireInfo ()
type Props = Loader.InnerProps Int AnnuaireInfo ()
...
@@ -166,16 +167,26 @@ pageLoader props = React.createElement pageLoaderClass props []
...
@@ -166,16 +167,26 @@ pageLoader props = React.createElement pageLoaderClass props []
--{-
--{-
renderContactCells :: Maybe Contact -> Array ReactElement
renderContactCells :: Maybe Contact -> Array ReactElement
renderContactCells Nothing = []
renderContactCells Nothing = []
renderContactCells (Just (Contact { id, hyperdata : (HyperdataContact contact) })) =
renderContactCells (Just (Contact { id, hyperdata : (HyperdataContact contact
@{who: who, ou:ou}
) })) =
[ text ""
[ text ""
, a [ href (toUrl Front NodeContact (Just id)) ] [ text $ maybe "name" identity contact.title ]
, a [ href (toUrl Front NodeContact (Just id)) ] [ text $ maybe "name" identity contact.title ]
, text $ maybe "
ecole" identity contact.source
, text $ maybe "
No ContactWhere" renderContactWhereOrg (join $ head <$> ou)
, text
"" -- $ maybe' contact.groupe
, text
$ maybe "No ContactWhere" renderContactWhereDept (join $ head <$> ou)
, text
"" -- $ maybe' contact.groupe
, text
$ maybe "No ContactWhere" renderContactWhereRole (join $ head <$> ou)
]
]
where
where
maybe' = maybe "" identity
maybe' = maybe "" identity
---}
renderContactWhereOrg (ContactWhere { organization: Nothing }) = "No Organization"
renderContactWhereOrg (ContactWhere { organization: Just orga }) =
maybe "No orga (list)" identity (head orga)
renderContactWhereDept (ContactWhere { labTeamDepts : Nothing }) = "Empty Dept"
renderContactWhereDept (ContactWhere { labTeamDepts : Just dept }) =
maybe "No Dept (list)" identity (head dept)
renderContactWhereRole (ContactWhere { role: Nothing }) = "Empty Role"
renderContactWhereRole (ContactWhere { role: Just role }) = role
data HyperdataAnnuaire = HyperdataAnnuaire
data HyperdataAnnuaire = HyperdataAnnuaire
{ title :: Maybe String
{ title :: Maybe String
...
...
src/Gargantext/Pages/Annuaire/User/Contacts/Specs/Renders.purs
View file @
113500f8
...
@@ -22,7 +22,7 @@ render dispatch _ state _ =
...
@@ -22,7 +22,7 @@ render dispatch _ state _ =
[
[
div [className "col-md-12"]
div [className "col-md-12"]
$ case state.contact of
$ case state.contact of
(Just (Contact contact)) -> display (maybe "no name" identity contact.name)
[contactInfos contact.hyperdata]
(Just (Contact contact)) -> display (maybe "no name" identity contact.name)
(contactInfos contact.hyperdata)
Nothing -> display "Contact not found" []
Nothing -> display "Contact not found" []
]
]
...
@@ -38,8 +38,8 @@ display title elems =
...
@@ -38,8 +38,8 @@ display title elems =
[ div [className "col-md-12"]
[ div [className "col-md-12"]
[ div [className "row"]
[ div [className "row"]
[ div [className "col-md-2"]
[ div [className "col-md-2"]
[ ]
--
[ ]
--
[ img [src "/images/Gargantextuel-212x300.jpg"] ]
[ img [src "/images/Gargantextuel-212x300.jpg"] ]
, div [className "col-md-1"] []
, div [className "col-md-1"] []
, div [className "col-mdData.Unfoldable-8"] elems
, div [className "col-mdData.Unfoldable-8"] elems
]
]
...
@@ -56,9 +56,14 @@ mapMyMap f m = toUnfoldable
...
@@ -56,9 +56,14 @@ mapMyMap f m = toUnfoldable
infixl 4 mapMyMap as <.~$>
infixl 4 mapMyMap as <.~$>
contactInfos :: HyperdataContact -> ReactElement
contactInfos :: HyperdataContact -> Array ReactElement
contactInfos (HyperdataContact hyperdata) =
contactInfos (HyperdataContact {who:who,ou:ou}) =
ul [className "list-group"] (infoRender (Tuple "Name" $ maybe "no title" identity hyperdata.role)) {- $
[ ul [className "list-group"] (infoRender (Tuple "Last Name" $ maybe "no title" (\(ContactWho {lastName:lastName}) -> maybe "no lastName" identity lastName) who))
, ul [className "list-group"] (infoRender (Tuple "First name" $ maybe "no title" (\(ContactWho {firstName:firstName}) -> maybe "no firstName" identity firstName) who))
]
{- $
listInfo <.~$> hyperdata
listInfo <.~$> hyperdata
where
where
checkMaybe (Nothing) = empty
checkMaybe (Nothing) = empty
...
...
src/Gargantext/Pages/Annuaire/User/Contacts/Types.purs
View file @
113500f8
...
@@ -24,26 +24,97 @@ data Contact = Contact {
...
@@ -24,26 +24,97 @@ data Contact = Contact {
, hyperdata :: HyperdataContact
, hyperdata :: HyperdataContact
}
}
data ContactWho =
ContactWho { idWho :: Maybe String
, firstName :: Maybe String
, lastName :: Maybe String
, keywords :: Maybe (Array String)
, freetags :: Maybe (Array String)
}
instance decodeContactWho :: DecodeJson ContactWho
where
decodeJson json = do
obj <- decodeJson json
idWho <- obj .?? "id"
firstName <- obj .?? "firstName"
lastName <- obj .?? "lastName"
keywords <- obj .?? "keywords"
freetags <- obj .?? "freetags"
pure $ ContactWho {idWho, firstName, lastName, keywords, freetags}
data ContactWhere =
ContactWhere { organization :: Maybe (Array String)
, labTeamDepts :: Maybe (Array String)
, role :: Maybe String
, office :: Maybe String
, country :: Maybe String
, city :: Maybe String
, touch :: Maybe ContactTouch
, entry :: Maybe String
, exit :: Maybe String
}
instance decodeContactWhere :: DecodeJson ContactWhere
where
decodeJson json = do
obj <- decodeJson json
organization <- obj .?? "organization"
labTeamDepts <- obj .?? "labTeamDepts"
role <- obj .?? "role"
office <- obj .?? "office"
country <- obj .?? "country"
city <- obj .?? "city"
touch <- obj .?? "touch"
entry <- obj .?? "entry"
exit <- obj .?? "exit"
pure $ ContactWhere {organization, labTeamDepts, role, office, country, city, touch, entry, exit}
data ContactTouch =
ContactTouch { mail :: Maybe String
, phone :: Maybe String
, url :: Maybe String
}
instance decodeContactTouch :: DecodeJson ContactTouch
where
decodeJson json = do
obj <- decodeJson json
mail <- obj .?? "mail"
phone <- obj .?? "phone"
url <- obj .?? "url"
pure $ ContactTouch {mail, phone, url}
data HyperdataContact =
data HyperdataContact =
HyperdataContact { bdd :: Maybe String
HyperdataContact { bdd :: Maybe String
,
uniqId :: Maybe String
,
who :: Maybe ContactWho
,
uniqIdBdd :: Maybe String
,
ou :: Maybe (Array ContactWhere)
, title :: Maybe String
, title :: Maybe String
, source :: Maybe String
, source :: Maybe String
, role :: Maybe String
, lastValidation :: Maybe String
, uniqId :: Maybe String
, uniqIdBdd :: Maybe String
}
}
instance decodeHyperdataContact :: DecodeJson HyperdataContact
instance decodeHyperdataContact :: DecodeJson HyperdataContact
where
where
decodeJson json = do
decodeJson json = do
obj <- decodeJson json
obj <- decodeJson json
bdd <- obj .?? "bdd"
bdd <- obj .?? "bdd"
uniqId <- obj .?? "uniqId"
who <- obj .?? "who"
uniqIdBdd <- obj .?? "uniqIdBdd"
ou <- obj .?? "where"
title <- obj .?? "title"
title <- obj .?? "title"
source <- obj .?? "source"
source <- obj .?? "source"
role <- obj .?? "role"
lastValidation <- obj .?? "lastValidation"
pure $ HyperdataContact {bdd, uniqId, uniqIdBdd, title, source, role}
uniqId <- obj .?? "uniqId"
uniqIdBdd <- obj .?? "uniqIdBdd"
pure $ HyperdataContact {bdd, who, ou, title, source, lastValidation, uniqId, uniqIdBdd}
data HyperData c s =
data HyperData c s =
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment