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
142
Issues
142
List
Board
Labels
Milestones
Merge Requests
4
Merge Requests
4
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
gargantext
purescript-gargantext
Commits
5686b05c
Commit
5686b05c
authored
Sep 15, 2022
by
Przemyslaw Kaminski
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[ps 0.15] this monstrocity is alive
parent
bc02d207
Pipeline
#3179
canceled with stage
Changes
77
Pipelines
1
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
77 changed files
with
3095 additions
and
1101 deletions
+3095
-1101
packages.json
.psc-package/local/.set/packages.json
+1728
-132
index.html
dist/index.html
+1
-1
index.html
index.html
+1
-1
easy-ps.nix
nix/easy-ps.nix
+3
-4
psc-package-nix.nix
nix/psc-package-nix.nix
+2
-2
package.json
package.json
+6
-2
packages.dhall
packages.dhall
+70
-175
psc-package.json
psc-package.json
+0
-2
spago.dhall
spago.dhall
+5
-4
BaseModal.js
src/Gargantext/Components/Bootstrap/Floaty/BaseModal.js
+2
-4
Tooltip.js
src/Gargantext/Components/Bootstrap/Floaty/Tooltip.js
+5
-3
Tooltip.purs
src/Gargantext/Components/Bootstrap/Floaty/Tooltip.purs
+8
-8
Category.purs
src/Gargantext/Components/Category.purs
+2
-1
Color.purs
src/Gargantext/Components/Charts/Options/Color.purs
+1
-1
ECharts.js
src/Gargantext/Components/Charts/Options/ECharts.js
+5
-4
ECharts.purs
src/Gargantext/Components/Charts/Options/ECharts.purs
+1
-1
Series.purs
src/Gargantext/Components/Charts/Options/Series.purs
+3
-3
CodeEditor.purs
src/Gargantext/Components/CodeEditor.purs
+21
-16
DocsTable.purs
src/Gargantext/Components/DocsTable.purs
+4
-4
FacetsTable.purs
src/Gargantext/Components/FacetsTable.purs
+6
-2
Node.js
src/Gargantext/Components/Forest/Tree/Node.js
+1
-1
Node.purs
src/Gargantext/Components/Forest/Tree/Node.purs
+2
-2
Sidebar.purs
src/Gargantext/Components/GraphExplorer/Sidebar.purs
+2
-1
SlideButton.purs
...gantext/Components/GraphExplorer/Toolbar/SlideButton.purs
+24
-18
Types.purs
src/Gargantext/Components/GraphExplorer/Types.purs
+13
-13
AffjaxSimpleJSONClient.purs
...Gargantext/Components/GraphQL/AffjaxSimpleJSONClient.purs
+8
-8
Form.purs
src/Gargantext/Components/Login/Form.purs
+3
-2
Annuaire.purs
src/Gargantext/Components/Nodes/Annuaire.purs
+6
-7
Types.purs
...antext/Components/Nodes/Annuaire/User/Contacts/Types.purs
+7
-7
Corpus.purs
src/Gargantext/Components/Nodes/Corpus.purs
+2
-1
Code.purs
src/Gargantext/Components/Nodes/Corpus/Code.purs
+2
-1
Dashboard.purs
src/Gargantext/Components/Nodes/Corpus/Dashboard.purs
+3
-2
API.purs
src/Gargantext/Components/PhyloExplorer/API.purs
+60
-60
Resources.js
src/Gargantext/Components/PhyloExplorer/Resources.js
+45
-42
SelectionTab.purs
...antext/Components/PhyloExplorer/Sidebar/SelectionTab.purs
+2
-1
Types.js
src/Gargantext/Components/PhyloExplorer/Types.js
+3
-7
Types.purs
src/Gargantext/Components/PhyloExplorer/Types.purs
+2
-1
RangeSlider.purs
src/Gargantext/Components/RangeSlider.purs
+5
-6
Router.purs
src/Gargantext/Components/Router.purs
+1
-1
REST.purs
src/Gargantext/Config/REST.purs
+1
-1
Functions.purs
src/Gargantext/Core/NgramsTable/Functions.purs
+1
-1
Types.purs
src/Gargantext/Core/NgramsTable/Types.purs
+9
-9
Louvain.js
src/Gargantext/Data/Louvain.js
+378
-378
Methods.purs
src/Gargantext/Hooks/FormValidation/Methods.purs
+2
-2
Types.js
src/Gargantext/Hooks/FormValidation/Types.js
+2
-2
LinkHandler.purs
src/Gargantext/Hooks/LinkHandler.purs
+1
-1
Resize.js
src/Gargantext/Hooks/Resize.js
+2
-4
Scrollbar.js
src/Gargantext/Hooks/Scrollbar.js
+4
-8
Sigma.js
src/Gargantext/Hooks/Sigmax/Sigma.js
+38
-25
Sigmajs.js
src/Gargantext/Hooks/Sigmax/Sigmajs.js
+2
-1
Unboxed.purs
src/Gargantext/Hooks/StateRecord/Unboxed.purs
+2
-2
Version.js
src/Gargantext/Hooks/Version.js
+4
-2
BreakWords.js
src/Gargantext/Text/BreakWords.js
+2
-1
BreakWords.purs
src/Gargantext/Text/BreakWords.purs
+10
-11
Utils.purs
src/Gargantext/Utils.purs
+2
-2
Argonaut.purs
src/Gargantext/Utils/Argonaut.purs
+6
-5
Array.js
src/Gargantext/Utils/Array.js
+1
-2
Array.purs
src/Gargantext/Utils/Array.purs
+1
-1
ArrayBuffer.js
src/Gargantext/Utils/ArrayBuffer.js
+1
-1
BootstrapNative.js
src/Gargantext/Utils/BootstrapNative.js
+1
-1
CacheAPI.js
src/Gargantext/Utils/CacheAPI.js
+7
-7
Console.js
src/Gargantext/Utils/Console.js
+1
-1
Crypto.purs
src/Gargantext/Utils/Crypto.purs
+0
-2
Debug.js
src/Gargantext/Utils/Debug.js
+1
-2
EtherCalc.purs
src/Gargantext/Utils/EtherCalc.purs
+1
-2
HighlightJS.js
src/Gargantext/Utils/HighlightJS.js
+2
-4
JitsiMeet.js
src/Gargantext/Utils/JitsiMeet.js
+3
-3
KarpRabin.purs
src/Gargantext/Utils/KarpRabin.purs
+2
-1
Popover.js
src/Gargantext/Utils/Popover.js
+3
-3
Range.purs
src/Gargantext/Utils/Range.purs
+0
-1
ReactBootstrap.js
src/Gargantext/Utils/ReactBootstrap.js
+12
-9
Reactix.js
src/Gargantext/Utils/Reactix.js
+13
-24
Regex.js
src/Gargantext/Utils/Regex.js
+3
-6
Selection.js
src/Gargantext/Utils/Selection.js
+3
-1
SimpleJSON.purs
src/Gargantext/Utils/SimpleJSON.purs
+3
-2
String.js
src/Gargantext/Utils/String.js
+1
-1
yarn.lock
yarn.lock
+505
-21
No files found.
.psc-package/local/.set/packages.json
View file @
5686b05c
This diff is collapsed.
Click to expand it.
dist/index.html
View file @
5686b05c
<
!
doctype
>
<!doctype
html
>
<html>
<html>
<head>
<head>
<meta
charset=
"utf-8"
/>
<meta
charset=
"utf-8"
/>
...
...
index.html
View file @
5686b05c
<
!
doctype
>
<!doctype
html
>
<html>
<html>
<head>
<head>
<meta
charset=
"utf-8"
/>
<meta
charset=
"utf-8"
/>
...
...
nix/easy-ps.nix
View file @
5686b05c
...
@@ -3,11 +3,10 @@
...
@@ -3,11 +3,10 @@
import
import
(
(
pkgs
.
fetchFromGitHub
{
pkgs
.
fetchFromGitHub
{
#owner = "justinwoo";
owner
=
"justinwoo"
;
owner
=
"cgenie"
;
repo
=
"easy-purescript-nix"
;
repo
=
"easy-purescript-nix"
;
rev
=
"
0d34a62a0bc531baa5350dc305fe56317f706be2
"
;
rev
=
"
master
"
;
sha256
=
"0
brdkkp60l3ggirab0zvhd7q11vk906gaxml7kmbg6gy029j7l5v
"
;
sha256
=
"0
3g9xq451dmrkq8kiz989wnl8k0lmj60ajflz44bhp7cm08hf3bw
"
;
}
}
)
{
)
{
inherit
pkgs
;
inherit
pkgs
;
...
...
nix/psc-package-nix.nix
View file @
5686b05c
...
@@ -3,6 +3,6 @@
...
@@ -3,6 +3,6 @@
pkgs
.
fetchFromGitHub
{
pkgs
.
fetchFromGitHub
{
owner
=
"justinwoo"
;
owner
=
"justinwoo"
;
repo
=
"psc-package-nix"
;
repo
=
"psc-package-nix"
;
rev
=
"
0f1f001e2ea17ad461871a1873050f6aef5f1284
"
;
rev
=
"
e00fdaf2a2628b6b056db12ff4a3069aa04cb536
"
;
sha256
=
"0
gbwcvw8rvxhlg9p6avd0812y263jzim1sra5frbdi0s6q0ngsgi
"
;
sha256
=
"0
p2cblmpma7s058r5nfwzpvdsi98qhh5isvc47052wjbmfinh8db
"
;
}
}
package.json
View file @
5686b05c
...
@@ -36,14 +36,17 @@
...
@@ -36,14 +36,17 @@
"
bootstrap
"
:
"
^4.6.0
"
,
"
bootstrap
"
:
"
^4.6.0
"
,
"
bootstrap-dark
"
:
"
^1.0.3
"
,
"
bootstrap-dark
"
:
"
^1.0.3
"
,
"
create-react-class
"
:
"
^15.6.3
"
,
"
create-react-class
"
:
"
^15.6.3
"
,
"
d3
"
:
"
^7.0.0
"
,
"
crypto
"
:
"
^1.0.1
"
,
"
d3
"
:
"
^7.6.1
"
,
"
echarts
"
:
"
^5.1.2
"
,
"
echarts
"
:
"
^5.1.2
"
,
"
echarts-for-react
"
:
"
^3.0.1
"
,
"
echarts-for-react
"
:
"
^3.0.1
"
,
"
esbuild
"
:
"
^0.15.7
"
,
"
graphql
"
:
"
^15.6.1
"
,
"
graphql
"
:
"
^15.6.1
"
,
"
graphql-ws
"
:
"
^5.5.0
"
,
"
graphql-ws
"
:
"
^5.5.0
"
,
"
highlightjs
"
:
"
^9.16.2
"
,
"
highlightjs
"
:
"
^9.16.2
"
,
"
immer
"
:
"
^9.0.5
"
,
"
immer
"
:
"
^9.0.5
"
,
"
isomorphic-unfetch
"
:
"
^3.1.0
"
,
"
isomorphic-unfetch
"
:
"
^3.1.0
"
,
"
markdown-it
"
:
"
^13.0.1
"
,
"
prop-types
"
:
"
^15.6.2
"
,
"
prop-types
"
:
"
^15.6.2
"
,
"
pullstate
"
:
"
^1.20.6
"
,
"
pullstate
"
:
"
^1.20.6
"
,
"
react
"
:
"
^17.0.2
"
,
"
react
"
:
"
^17.0.2
"
,
...
@@ -52,7 +55,7 @@
...
@@ -52,7 +55,7 @@
"
react-dom
"
:
"
^17.0.2
"
,
"
react-dom
"
:
"
^17.0.2
"
,
"
react-tooltip
"
:
"
^4.2.8
"
,
"
react-tooltip
"
:
"
^4.2.8
"
,
"
secp256k1
"
:
"
^4.0.2
"
,
"
secp256k1
"
:
"
^4.0.2
"
,
"
sigma
"
:
"
https://github.com/garganscript/sigma.js#
garg
"
"
sigma
"
:
"
https://github.com/garganscript/sigma.js#
main
"
},
},
"devDependencies"
:
{
"devDependencies"
:
{
"
@babel/core
"
:
"
^7.15.0
"
,
"
@babel/core
"
:
"
^7.15.0
"
,
...
@@ -63,6 +66,7 @@
...
@@ -63,6 +66,7 @@
"
react-testing-library
"
:
"
^8.0.1
"
,
"
react-testing-library
"
:
"
^8.0.1
"
,
"
sass
"
:
"
^1.35.2
"
,
"
sass
"
:
"
^1.35.2
"
,
"
serve
"
:
"
^12.0.0
"
,
"
serve
"
:
"
^12.0.0
"
,
"
spago
"
:
"
^0.20.9
"
,
"
ssl-serve
"
:
"
^6.5.8
"
,
"
ssl-serve
"
:
"
^6.5.8
"
,
"
taiko
"
:
"
latest
"
,
"
taiko
"
:
"
latest
"
,
"
vscode-languageserver
"
:
"
^7.0.0
"
,
"
vscode-languageserver
"
:
"
^7.0.0
"
,
...
...
packages.dhall
View file @
5686b05c
This diff is collapsed.
Click to expand it.
psc-package.json
View file @
5686b05c
...
@@ -19,7 +19,6 @@
...
@@ -19,7 +19,6 @@
"globals"
,
"globals"
,
"integers"
,
"integers"
,
"js-timers"
,
"js-timers"
,
"markdown-smolder"
,
"math"
,
"math"
,
"maybe"
,
"maybe"
,
"milkis"
,
"milkis"
,
...
@@ -38,7 +37,6 @@
...
@@ -38,7 +37,6 @@
"simple-json"
,
"simple-json"
,
"simple-json-generics"
,
"simple-json-generics"
,
"simplecrypto"
,
"simplecrypto"
,
"smolder"
,
"spec-discovery"
,
"spec-discovery"
,
"spec-quickcheck"
,
"spec-quickcheck"
,
"string-parsers"
,
"string-parsers"
,
...
...
spago.dhall
View file @
5686b05c
...
@@ -15,6 +15,7 @@ to generate this file without the comments in this block.
...
@@ -15,6 +15,7 @@ to generate this file without the comments in this block.
[ "aff"
[ "aff"
, "aff-promise"
, "aff-promise"
, "affjax"
, "affjax"
, "affjax-web"
, "argonaut"
, "argonaut"
, "argonaut-codecs"
, "argonaut-codecs"
, "argonaut-core"
, "argonaut-core"
...
@@ -41,14 +42,14 @@ to generate this file without the comments in this block.
...
@@ -41,14 +42,14 @@ to generate this file without the comments in this block.
, "form-urlencoded"
, "form-urlencoded"
, "formula"
, "formula"
, "functions"
, "functions"
, "globals"
, "graphql-client"
, "graphql-client"
, "http-methods"
, "http-methods"
, "integers"
, "integers"
, "js-timers"
, "js-timers"
, "lists"
, "lists"
, "markdown"
-- , "markdown"
, "markdown-smolder"
, "markdown-it"
--, "markdown-smolder"
, "maybe"
, "maybe"
, "media-types"
, "media-types"
, "milkis"
, "milkis"
...
@@ -74,7 +75,7 @@ to generate this file without the comments in this block.
...
@@ -74,7 +75,7 @@ to generate this file without the comments in this block.
, "simple-json"
, "simple-json"
, "simple-json-generics"
, "simple-json-generics"
, "simplecrypto"
, "simplecrypto"
, "smolder"
--
, "smolder"
, "strings"
, "strings"
, "strings-extra"
, "strings-extra"
, "stringutils"
, "stringutils"
...
...
src/Gargantext/Components/Bootstrap/Floaty/BaseModal.js
View file @
5686b05c
'use strict'
;
'use strict'
;
exports
.
_show
=
show
;
exports
.
_hide
=
hide
;
/**
/**
* @function show
* @function show
* @param {Window} window
* @param {Window} window
* @param {string} querySelector
* @param {string} querySelector
* @unpure {Object} window.$
* @unpure {Object} window.$
*/
*/
function
show
(
window
,
querySelector
)
{
export
function
_
show
(
window
,
querySelector
)
{
window
.
$
(
querySelector
).
modal
(
'show'
);
window
.
$
(
querySelector
).
modal
(
'show'
);
}
}
/**
/**
...
@@ -17,7 +15,7 @@ function show(window, querySelector) {
...
@@ -17,7 +15,7 @@ function show(window, querySelector) {
* @param {string} querySelector
* @param {string} querySelector
* @unpure {Object} window.$
* @unpure {Object} window.$
*/
*/
function
hide
(
window
,
querySelector
)
{
export
function
_
hide
(
window
,
querySelector
)
{
window
.
$
(
querySelector
).
modal
(
'hide'
);
window
.
$
(
querySelector
).
modal
(
'hide'
);
// @XXX Bootstrap not removing some modal elements on "hide" method
// @XXX Bootstrap not removing some modal elements on "hide" method
// @https://stackoverflow.com/questions/50168312/bootstrap-4-close-modal-backdrop-doesnt-disappear
// @https://stackoverflow.com/questions/50168312/bootstrap-4-close-modal-backdrop-doesnt-disappear
...
...
src/Gargantext/Components/Bootstrap/Floaty/Tooltip.js
View file @
5686b05c
'use strict'
;
'use strict'
;
const
reactTooltip
=
require
(
'react-tooltip'
);
import
Tooltip
from
'react-tooltip'
;
console
.
log
(
'Tooltip'
,
Tooltip
);
if
(
typeof
window
!==
'undefined'
)
{
if
(
typeof
window
!==
'undefined'
)
{
window
.
ReactTooltip
=
react
Tooltip
;
window
.
ReactTooltip
=
Tooltip
;
}
}
export
s
.
reactTooltipCpt
=
reactTooltip
;
export
{
Tooltip
as
reactTooltipCpt
}
;
src/Gargantext/Components/Bootstrap/Floaty/Tooltip.purs
View file @
5686b05c
...
@@ -7,7 +7,6 @@ module Gargantext.Components.Bootstrap.Tooltip
...
@@ -7,7 +7,6 @@ module Gargantext.Components.Bootstrap.Tooltip
import Gargantext.Prelude
import Gargantext.Prelude
import ConvertableOptions as CO
import ConvertableOptions as CO
import Data.Symbol (SProxy(..))
import Data.UUID as UUID
import Data.UUID as UUID
import Gargantext.Components.Bootstrap.Types (TooltipEffect(..), TooltipPosition(..), Variant(..))
import Gargantext.Components.Bootstrap.Types (TooltipEffect(..), TooltipPosition(..), Variant(..))
import Gargantext.Utils.Reactix as R2
import Gargantext.Utils.Reactix as R2
...
@@ -15,6 +14,7 @@ import Reactix as R
...
@@ -15,6 +14,7 @@ import Reactix as R
import Reactix.DOM.HTML as H
import Reactix.DOM.HTML as H
import Record as Record
import Record as Record
import Record.Extra as RX
import Record.Extra as RX
import Type.Proxy (Proxy(..))
foreign import reactTooltipCpt :: R.Component Props
foreign import reactTooltipCpt :: R.Component Props
...
@@ -61,20 +61,20 @@ tooltip props = R.rawCreateElement reactTooltipCpt props''
...
@@ -61,20 +61,20 @@ tooltip props = R.rawCreateElement reactTooltipCpt props''
props' = CO.defaults options props
props' = CO.defaults options props
props'' = props'
props'' = props'
# Record.set
# Record.set
(
SProxy :: S
Proxy "effect")
(
Proxy ::
Proxy "effect")
(show props'.effect)
(show props'.effect)
>>> Record.set
>>> Record.set
(
SProxy :: S
Proxy "variant")
(
Proxy ::
Proxy "variant")
(show props'.variant)
(show props'.variant)
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "variant")
(
Proxy ::
Proxy "variant")
(
SProxy :: S
Proxy "type")
(
Proxy ::
Proxy "type")
>>> Record.set
>>> Record.set
(
SProxy :: S
Proxy "position")
(
Proxy ::
Proxy "position")
(show props'.position)
(show props'.position)
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "position")
(
Proxy ::
Proxy "position")
(
SProxy :: S
Proxy "place")
(
Proxy ::
Proxy "place")
-------------------------------------------------------------
-------------------------------------------------------------
...
...
src/Gargantext/Components/Category.purs
View file @
5686b05c
...
@@ -139,7 +139,8 @@ carousselCpt = here.component "caroussel" cpt
...
@@ -139,7 +139,8 @@ carousselCpt = here.component "caroussel" cpt
onClick c = \_-> do
onClick c = \_-> do
setLocalCategories $ Map.insert r._id c
setLocalCategories $ Map.insert r._id c
launchAff_ $ do
launchAff_ $ do
putCategories session nodeId $ CategoryQuery {nodeIds: [r._id], category: c}
_ <- putCategories session nodeId $ CategoryQuery {nodeIds: [r._id], category: c}
pure unit
icon :: Category -> Boolean -> String
icon :: Category -> Boolean -> String
icon cat b = btn b $ "fa fa-" <> (color $ size b $ icon' cat b)
icon cat b = btn b $ "fa fa-" <> (color $ size b $ icon' cat b)
...
...
src/Gargantext/Components/Charts/Options/Color.purs
View file @
5686b05c
...
@@ -40,7 +40,7 @@ magenta :: Color
...
@@ -40,7 +40,7 @@ magenta :: Color
magenta = stringColor "magenta"
magenta = stringColor "magenta"
violet :: Color
violet :: Color
violet =
cssColor CSS.violet
violet =
stringColor "violet"
black :: Color
black :: Color
black = stringColor "black"
black = stringColor "black"
...
...
src/Gargantext/Components/Charts/Options/ECharts.js
View file @
5686b05c
"use strict"
;
"use strict"
;
var
ReactEcharts
=
require
(
"echarts-for-react"
)
;
import
*
as
ReactEcharts
from
"echarts-for-react"
;
exports
.
eChartsClass
=
ReactEcharts
.
default
;
let
eChartsClass
=
ReactEcharts
.
default
;
export
{
eChartsClass
};
/**
/**
* @XXX "echarts-for-react" unsuitable to proper PureScript implementation
* @XXX "echarts-for-react" unsuitable to proper PureScript implementation
...
@@ -11,7 +12,7 @@ exports.eChartsClass = ReactEcharts.default;
...
@@ -11,7 +12,7 @@ exports.eChartsClass = ReactEcharts.default;
* @param {function} fn
* @param {function} fn
* @returns
* @returns
*/
*/
export
s
.
listenerFn1
=
function
(
fn
)
{
export
function
listenerFn1
(
fn
)
{
return
function
()
{
return
function
()
{
var
args
=
Array
.
prototype
.
slice
.
call
(
arguments
);
var
args
=
Array
.
prototype
.
slice
.
call
(
arguments
);
fn
(
args
[
0
])()
fn
(
args
[
0
])()
...
@@ -24,7 +25,7 @@ exports.listenerFn1 = function(fn) {
...
@@ -24,7 +25,7 @@ exports.listenerFn1 = function(fn) {
* @param {object} opts
* @param {object} opts
* @returns
* @returns
*/
*/
export
s
.
dispatchAction
=
fun
ction
(
eChartsInstance
)
{
export
function
dispatchA
ction
(
eChartsInstance
)
{
return
function
(
opts
)
{
return
function
(
opts
)
{
return
function
()
{
return
function
()
{
eChartsInstance
.
dispatchAction
(
opts
);
eChartsInstance
.
dispatchAction
(
opts
);
...
...
src/Gargantext/Components/Charts/Options/ECharts.purs
View file @
5686b05c
...
@@ -54,7 +54,7 @@ chartWith options =
...
@@ -54,7 +54,7 @@ chartWith options =
refListener (Options { onInit }) = case onInit of
refListener (Options { onInit }) = case onInit of
Nothing -> pure unit
Nothing -> pure unit
Just fn -> listenerFn1 (
_ # fn # execOnInit
)
Just fn -> listenerFn1 (
execOnInit fn
)
execOnInit fn = toMaybe >>> case _ of
execOnInit fn = toMaybe >>> case _ of
Nothing -> pure unit
Nothing -> pure unit
...
...
src/Gargantext/Components/Charts/Options/Series.purs
View file @
5686b05c
...
@@ -4,7 +4,6 @@ import Data.Array (foldl)
...
@@ -4,7 +4,6 @@ import Data.Array (foldl)
import Data.Generic.Rep (class Generic)
import Data.Generic.Rep (class Generic)
import Data.Maybe (Maybe(..), maybe)
import Data.Maybe (Maybe(..), maybe)
import Data.Newtype (class Newtype)
import Data.Newtype (class Newtype)
import Data.Symbol (SProxy(..))
import Gargantext.Components.Charts.Options.Data (DataD1, DataD2)
import Gargantext.Components.Charts.Options.Data (DataD1, DataD2)
import Gargantext.Components.Charts.Options.Font (ItemStyle, Tooltip)
import Gargantext.Components.Charts.Options.Font (ItemStyle, Tooltip)
import Gargantext.Components.Charts.Options.Legend (SelectedMode)
import Gargantext.Components.Charts.Options.Legend (SelectedMode)
...
@@ -13,6 +12,7 @@ import Prelude (class Eq, class Show, bind, map, pure, show, ($), (+), (<<<), (<
...
@@ -13,6 +12,7 @@ import Prelude (class Eq, class Show, bind, map, pure, show, ($), (+), (<<<), (<
import Record as Record
import Record as Record
import Record.Unsafe (unsafeSet)
import Record.Unsafe (unsafeSet)
import Simple.JSON as JSON
import Simple.JSON as JSON
import Type.Proxy (Proxy(..))
import Unsafe.Coerce (unsafeCoerce)
import Unsafe.Coerce (unsafeCoerce)
...
@@ -213,8 +213,8 @@ treeLeaf :: String -> Int -> TreeNode
...
@@ -213,8 +213,8 @@ treeLeaf :: String -> Int -> TreeNode
treeLeaf n v = TreeNode { name : n, value : v, children : []}
treeLeaf n v = TreeNode { name : n, value : v, children : []}
nameP =
SProxy :: S
Proxy "name"
nameP =
Proxy ::
Proxy "name"
labelP =
SProxy :: S
Proxy "label"
labelP =
Proxy ::
Proxy "label"
-- | TODO
-- | TODO
...
...
src/Gargantext/Components/CodeEditor.purs
View file @
5686b05c
...
@@ -11,12 +11,13 @@ import Data.String.Utils (endsWith)
...
@@ -11,12 +11,13 @@ import Data.String.Utils (endsWith)
import DOM.Simple.Types (Element)
import DOM.Simple.Types (Element)
import Effect (Effect)
import Effect (Effect)
import FFI.Simple ((.=))
import FFI.Simple ((.=))
import MarkdownIt (renderString)
import Reactix as R
import Reactix as R
import Reactix.DOM.HTML as H
import Reactix.DOM.HTML as H
import Text.Markdown.SlamDown.Parser (parseMd)
--
import Text.Markdown.SlamDown.Parser (parseMd)
import Text.Markdown.SlamDown.Smolder as MD
--
import Text.Markdown.SlamDown.Smolder as MD
import Text.Markdown.SlamDown.Syntax (SlamDownP)
--
import Text.Markdown.SlamDown.Syntax (SlamDownP)
import Text.Smolder.Renderer.String as Smolder
--
import Text.Smolder.Renderer.String as Smolder
import Toestand as T
import Toestand as T
import Gargantext.Prelude
import Gargantext.Prelude
...
@@ -58,16 +59,18 @@ codeNlFix :: CodeType -> Code -> Code
...
@@ -58,16 +59,18 @@ codeNlFix :: CodeType -> Code -> Code
codeNlFix _ "" = " "
codeNlFix _ "" = " "
codeNlFix _ c = if endsWith "\n" c then (c <> " ") else c
codeNlFix _ c = if endsWith "\n" c then (c <> " ") else c
render :: CodeType -> Code -> E
ither Error Html
render :: CodeType -> Code -> E
ffect (Either Error Html)
render Haskell code = Right $ renderHaskell $ codeNlFix Haskell code
render Haskell code =
pure $
Right $ renderHaskell $ codeNlFix Haskell code
render Python code = Right $ renderPython $ codeNlFix Python code
render Python code =
pure $
Right $ renderPython $ codeNlFix Python code
render JSON code = result
render JSON code =
pure
result
where
where
parsedE = jsonParser code
parsedE = jsonParser code
result = case parsedE of
result = case parsedE of
Left err -> Left err
Left err -> Left err
Right parsed -> Right $ R2.stringify parsed 2
Right parsed -> Right $ R2.stringify parsed 2
render Markdown code = Right $ renderMd $ codeNlFix Markdown code
render Markdown code = do
r <- renderMd $ codeNlFix Markdown code
pure $ Right r
previewPostProcess :: CodeType -> Element -> Effect Unit
previewPostProcess :: CodeType -> Element -> Effect Unit
previewPostProcess Haskell htmlEl = do
previewPostProcess Haskell htmlEl = do
...
@@ -83,13 +86,14 @@ previewPostProcess Markdown _ = pure unit
...
@@ -83,13 +86,14 @@ previewPostProcess Markdown _ = pure unit
-- TODO Replace with markdown-it?
-- TODO Replace with markdown-it?
-- https://pursuit.purescript.org/packages/purescript-markdown-it
-- https://pursuit.purescript.org/packages/purescript-markdown-it
renderMd' :: forall e. MD.ToMarkupOptions e -> String -> String
--
renderMd' :: forall e. MD.ToMarkupOptions e -> String -> String
renderMd' options input =
--
renderMd' options input =
either identity (MD.toMarkup' options >>> Smolder.render)
--
either identity (MD.toMarkup' options >>> Smolder.render)
(parseMd input :: Either String (SlamDownP String))
--
(parseMd input :: Either String (SlamDownP String))
renderMd :: String -> String
renderMd :: String -> Effect String
renderMd = renderMd' MD.defaultToMarkupOptions
renderMd = renderString
--renderMd = renderMd' MD.defaultToMarkupOptions
renderHaskell :: String -> String
renderHaskell :: String -> String
renderHaskell s = s
renderHaskell s = s
...
@@ -189,7 +193,8 @@ renderHtml code codeType htmlElRef error =
...
@@ -189,7 +193,8 @@ renderHtml code codeType htmlElRef error =
case (toMaybe $ R.readRef htmlElRef) of
case (toMaybe $ R.readRef htmlElRef) of
Nothing -> pure unit
Nothing -> pure unit
Just htmlEl -> do
Just htmlEl -> do
case render codeType code of
r <- render codeType code
case r of
Left err -> do
Left err -> do
T.write_ (Just err) error
T.write_ (Just err) error
Right rendered -> do
Right rendered -> do
...
...
src/Gargantext/Components/DocsTable.purs
View file @
5686b05c
...
@@ -17,7 +17,6 @@ import Data.Ord.Down (Down(..))
...
@@ -17,7 +17,6 @@ import Data.Ord.Down (Down(..))
import Data.Set (Set)
import Data.Set (Set)
import Data.Set as Set
import Data.Set as Set
import Data.String as Str
import Data.String as Str
import Data.Symbol (SProxy(..))
import Data.Tuple (Tuple(..))
import Data.Tuple (Tuple(..))
import Data.Tuple.Nested ((/\))
import Data.Tuple.Nested ((/\))
import Effect (Effect)
import Effect (Effect)
...
@@ -56,6 +55,7 @@ import Reactix.DOM.HTML as H
...
@@ -56,6 +55,7 @@ import Reactix.DOM.HTML as H
import Record.Extra as RX
import Record.Extra as RX
import Simple.JSON as JSON
import Simple.JSON as JSON
import Toestand as T
import Toestand as T
import Type.Proxy (Proxy(..))
here :: R2.Here
here :: R2.Here
here = R2.here "Gargantext.Components.DocsTable"
here = R2.here "Gargantext.Components.DocsTable"
...
@@ -100,8 +100,8 @@ type PageLayoutProps =
...
@@ -100,8 +100,8 @@ type PageLayoutProps =
| CommonProps
| CommonProps
)
)
_documentIdsDeleted = prop (
SProxy :: S
Proxy "documentIdsDeleted")
_documentIdsDeleted = prop (
Proxy ::
Proxy "documentIdsDeleted")
_localCategories = prop (
SProxy :: S
Proxy "localCategories")
_localCategories = prop (
Proxy ::
Proxy "localCategories")
docViewLayout :: Record LayoutProps -> R.Element
docViewLayout :: Record LayoutProps -> R.Element
docViewLayout props = R.createElement docViewLayoutCpt props []
docViewLayout props = R.createElement docViewLayoutCpt props []
...
@@ -270,7 +270,7 @@ scanDocumentCreationProgress boxes session nodeId currentTask cbk = do
...
@@ -270,7 +270,7 @@ scanDocumentCreationProgress boxes session nodeId currentTask cbk = do
, GT.IsKilled
, GT.IsKilled
, GT.IsFailure
, GT.IsFailure
]
]
hasEndingStatus s = any (
_ # s # eq
) endingStatusList
hasEndingStatus s = any (
eq s
) endingStatusList
if (hasEndingStatus status)
if (hasEndingStatus status)
then
then
...
...
src/Gargantext/Components/FacetsTable.purs
View file @
5686b05c
...
@@ -147,7 +147,9 @@ docViewCpt = here.component "docView" cpt
...
@@ -147,7 +147,9 @@ docViewCpt = here.component "docView" cpt
performDeletions :: Session -> Int -> T.Box Deletions -> Deletions -> Effect Unit
performDeletions :: Session -> Int -> T.Box Deletions -> Deletions -> Effect Unit
performDeletions session nodeId deletions deletions' = do
performDeletions session nodeId deletions deletions' = do
launchAff_ $ deleteDocuments session nodeId (DeleteDocumentQuery q)
launchAff_ $ do
_ <- deleteDocuments session nodeId (DeleteDocumentQuery q)
pure unit
T.modify_ del deletions
T.modify_ del deletions
where
where
q = { documents: Set.toUnfoldable deletions'.pending }
q = { documents: Set.toUnfoldable deletions'.pending }
...
@@ -155,7 +157,9 @@ performDeletions session nodeId deletions deletions' = do
...
@@ -155,7 +157,9 @@ performDeletions session nodeId deletions deletions' = do
markCategory :: Session -> NodeID -> Category -> Array NodeID -> Effect Unit
markCategory :: Session -> NodeID -> Category -> Array NodeID -> Effect Unit
markCategory session nodeId category nids =
markCategory session nodeId category nids =
void $ launchAff_ $ putCategories session nodeId (CategoryQuery q)
void $ launchAff_ $ do
_ <- putCategories session nodeId (CategoryQuery q)
pure unit
where -- TODO add array of delete rows here
where -- TODO add array of delete rows here
q = {nodeIds: nids, category: favCategory category}
q = {nodeIds: nids, category: favCategory category}
...
...
src/Gargantext/Components/Forest/Tree/Node.js
View file @
5686b05c
export
s
.
nodeUserRegexp
=
/
(
@
{1}
.*
)
.gargantext.org$/
;
export
const
nodeUserRegexp
=
/
(
@
{1}
.*
)
.gargantext.org$/
;
src/Gargantext/Components/Forest/Tree/Node.purs
View file @
5686b05c
...
@@ -9,7 +9,6 @@ import Data.Array.NonEmpty as NArray
...
@@ -9,7 +9,6 @@ import Data.Array.NonEmpty as NArray
import Data.Foldable (intercalate)
import Data.Foldable (intercalate)
import Data.Maybe (Maybe(..), maybe)
import Data.Maybe (Maybe(..), maybe)
import Data.String.Regex as Regex
import Data.String.Regex as Regex
import Data.Symbol (SProxy(..))
import Data.Tuple.Nested ((/\))
import Data.Tuple.Nested ((/\))
import Effect (Effect)
import Effect (Effect)
import Effect.Aff (Aff, launchAff)
import Effect.Aff (Aff, launchAff)
...
@@ -44,6 +43,7 @@ import Reactix as R
...
@@ -44,6 +43,7 @@ import Reactix as R
import Reactix.DOM.HTML as H
import Reactix.DOM.HTML as H
import Record as Record
import Record as Record
import Toestand as T
import Toestand as T
import Type.Proxy (Proxy(..))
-- (?) never been able to properly declare PureScript Regex...
-- (?) never been able to properly declare PureScript Regex...
foreign import nodeUserRegexp :: Regex.Regex
foreign import nodeUserRegexp :: Regex.Regex
...
@@ -544,7 +544,7 @@ nodeActionsCpt :: R.Component NodeActionsProps
...
@@ -544,7 +544,7 @@ nodeActionsCpt :: R.Component NodeActionsProps
nodeActionsCpt = here.component "nodeActions" cpt where
nodeActionsCpt = here.component "nodeActions" cpt where
cpt props _ = pure (child props.nodeType)
cpt props _ = pure (child props.nodeType)
where
where
nodeActionsP =
SProxy :: S
Proxy "nodeType"
nodeActionsP =
Proxy ::
Proxy "nodeType"
childProps = Record.delete nodeActionsP props
childProps = Record.delete nodeActionsP props
...
...
src/Gargantext/Components/GraphExplorer/Sidebar.purs
View file @
5686b05c
...
@@ -5,11 +5,12 @@ module Gargantext.Components.GraphExplorer.Sidebar
...
@@ -5,11 +5,12 @@ module Gargantext.Components.GraphExplorer.Sidebar
import Gargantext.Prelude
import Gargantext.Prelude
import Control.Parallel (parTraverse)
import Control.Parallel (parTraverse)
import Data.Array (last
, mapWithIndex
)
import Data.Array (last)
import Data.Array as A
import Data.Array as A
import Data.Either (Either(..))
import Data.Either (Either(..))
import Data.Foldable (intercalate)
import Data.Foldable (intercalate)
import Data.Foldable as F
import Data.Foldable as F
import Data.FunctorWithIndex (mapWithIndex)
import Data.Int (fromString)
import Data.Int (fromString)
import Data.Map as Map
import Data.Map as Map
import Data.Maybe (Maybe(..), fromJust)
import Data.Maybe (Maybe(..), fromJust)
...
...
src/Gargantext/Components/GraphExplorer/Toolbar/SlideButton.purs
View file @
5686b05c
...
@@ -5,7 +5,8 @@ module Gargantext.Components.GraphExplorer.Toolbar.SlideButton
...
@@ -5,7 +5,8 @@ module Gargantext.Components.GraphExplorer.Toolbar.SlideButton
, mouseSelectorSizeButton
, mouseSelectorSizeButton
) where
) where
import Global (readFloat)
import Data.Maybe (Maybe(..))
import Data.Number as DN
import Prelude
import Prelude
import Effect (Effect)
import Effect (Effect)
import Reactix as R
import Reactix as R
...
@@ -29,7 +30,6 @@ type Props =
...
@@ -29,7 +30,6 @@ type Props =
sizeButton :: Record Props -> R.Element
sizeButton :: Record Props -> R.Element
sizeButton props = R.createElement sizeButtonCpt props []
sizeButton props = R.createElement sizeButtonCpt props []
sizeButtonCpt :: R.Component Props
sizeButtonCpt :: R.Component Props
sizeButtonCpt = here.component "sizeButton" cpt where
sizeButtonCpt = here.component "sizeButton" cpt where
cpt { state, caption, min, max, onChange } _ = do
cpt { state, caption, min, max, onChange } _ = do
...
@@ -67,7 +67,10 @@ labelSizeButton sigmaRef state =
...
@@ -67,7 +67,10 @@ labelSizeButton sigmaRef state =
, max: 30.0
, max: 30.0
, onChange: \e -> do
, onChange: \e -> do
let sigma = R.readRef sigmaRef
let sigma = R.readRef sigmaRef
let newValue = readFloat $ R.unsafeEventValue e
let newValue' = DN.fromString $ R.unsafeEventValue e
case newValue' of
Nothing -> pure unit
Just newValue ->
Sigmax.dependOnSigma sigma "[labelSizeButton] sigma: Nothing" $ \s -> do
Sigmax.dependOnSigma sigma "[labelSizeButton] sigma: Nothing" $ \s -> do
Sigma.setSettings s {
Sigma.setSettings s {
defaultLabelSize: newValue
defaultLabelSize: newValue
...
@@ -87,7 +90,10 @@ mouseSelectorSizeButton sigmaRef state =
...
@@ -87,7 +90,10 @@ mouseSelectorSizeButton sigmaRef state =
, max: 50.0
, max: 50.0
, onChange: \e -> do
, onChange: \e -> do
let sigma = R.readRef sigmaRef
let sigma = R.readRef sigmaRef
let newValue = readFloat $ R.unsafeEventValue e
let newValue' = DN.fromString $ R.unsafeEventValue e
case newValue' of
Nothing -> pure unit
Just newValue ->
Sigmax.dependOnSigma sigma "[mouseSelectorSizeButton] sigma: Nothing" $ \s -> do
Sigmax.dependOnSigma sigma "[mouseSelectorSizeButton] sigma: Nothing" $ \s -> do
Sigma.setSettings s {
Sigma.setSettings s {
mouseSelectorSize: newValue
mouseSelectorSize: newValue
...
...
src/Gargantext/Components/GraphExplorer/Types.purs
View file @
5686b05c
...
@@ -9,10 +9,10 @@ import Data.Maybe (Maybe(..), fromJust)
...
@@ -9,10 +9,10 @@ import Data.Maybe (Maybe(..), fromJust)
import Data.Newtype (class Newtype)
import Data.Newtype (class Newtype)
import Data.Ord.Generic (genericCompare)
import Data.Ord.Generic (genericCompare)
import Data.Show.Generic (genericShow)
import Data.Show.Generic (genericShow)
import Data.Symbol (SProxy(..))
import Partial.Unsafe (unsafePartial)
import Partial.Unsafe (unsafePartial)
import Record as Record
import Record as Record
import Simple.JSON as JSON
import Simple.JSON as JSON
import Type.Proxy (Proxy(..))
type GraphId = Int
type GraphId = Int
...
@@ -27,18 +27,18 @@ newtype Node = Node {
...
@@ -27,18 +27,18 @@ newtype Node = Node {
, y :: Number
, y :: Number
}
}
x_coordP =
SProxy :: S
Proxy "x_coord"
x_coordP =
Proxy ::
Proxy "x_coord"
xP =
SProxy :: S
Proxy "x"
xP =
Proxy ::
Proxy "x"
y_coordP =
SProxy :: S
Proxy "y_coord"
y_coordP =
Proxy ::
Proxy "y_coord"
yP =
SProxy :: S
Proxy "y"
yP =
Proxy ::
Proxy "y"
clustDefaultP =
SProxy :: S
Proxy "clustDefault"
clustDefaultP =
Proxy ::
Proxy "clustDefault"
clust_defaultP =
SProxy :: S
Proxy "clust_default"
clust_defaultP =
Proxy ::
Proxy "clust_default"
cameraP =
SProxy :: S
Proxy "camera"
cameraP =
Proxy ::
Proxy "camera"
mCameraP =
SProxy :: S
Proxy "mCamera"
mCameraP =
Proxy ::
Proxy "mCamera"
idP =
SProxy :: S
Proxy "id"
idP =
Proxy ::
Proxy "id"
id_P =
SProxy :: S
Proxy "id_"
id_P =
Proxy ::
Proxy "id_"
typeP =
SProxy :: S
Proxy "type"
typeP =
Proxy ::
Proxy "type"
type_P =
SProxy :: S
Proxy "type_"
type_P =
Proxy ::
Proxy "type_"
derive instance Generic Node _
derive instance Generic Node _
derive instance Newtype Node _
derive instance Newtype Node _
...
...
src/Gargantext/Components/GraphQL/AffjaxSimpleJSONClient.purs
View file @
5686b05c
...
@@ -4,7 +4,7 @@ module Gargantext.Components.GraphQL.AffjaxSimpleJSONClient
...
@@ -4,7 +4,7 @@ module Gargantext.Components.GraphQL.AffjaxSimpleJSONClient
import Prelude
import Prelude
import Affjax (Error(..), Response, URL, defaultRequest, printError, request)
import Affjax
.Web
(Error(..), Response, URL, defaultRequest, printError, request)
import Affjax.RequestBody as RequestBody
import Affjax.RequestBody as RequestBody
import Affjax.RequestHeader (RequestHeader(..))
import Affjax.RequestHeader (RequestHeader(..))
import Affjax.ResponseFormat as ResponseFormat
import Affjax.ResponseFormat as ResponseFormat
...
...
src/Gargantext/Components/Login/Form.purs
View file @
5686b05c
module Gargantext.Components.Login.Form where
module Gargantext.Components.Login.Form where
import Prelude (Unit, bind, discard, not, notEq, pure, show, ($), (&&), (*>), (<>))
import Prelude (Unit, bind, discard, not, notEq, pure, show,
unit,
($), (&&), (*>), (<>))
import Data.Either (Either(..))
import Data.Either (Either(..))
import DOM.Simple.Event as DE
import DOM.Simple.Event as DE
import Effect (Effect)
import Effect (Effect)
...
@@ -107,13 +107,14 @@ submitForm { backend, sessions, visible } cell e = do
...
@@ -107,13 +107,14 @@ submitForm { backend, sessions, visible } cell e = do
state <- T.read cell
state <- T.read cell
launchAff_ $ do
launchAff_ $ do
res <- postAuthRequest backend (req state)
res <- postAuthRequest backend (req state)
case res of
_ <-
case res of
Left message -> liftEffect $ T.write (state { error = message }) cell
Left message -> liftEffect $ T.write (state { error = message }) cell
Right sess ->
Right sess ->
liftEffect $
liftEffect $
Sessions.change (Sessions.Login sess) sessions
Sessions.change (Sessions.Login sess) sessions
*> T.write false visible
*> T.write false visible
*> T.write (state { error = "" }) cell
*> T.write (state { error = "" }) cell
pure unit
where
where
req { username, password } = AuthRequest { username, password }
req { username, password } = AuthRequest { username, password }
...
...
src/Gargantext/Components/Nodes/Annuaire.purs
View file @
5686b05c
...
@@ -10,7 +10,6 @@ import Data.Generic.Rep (class Generic)
...
@@ -10,7 +10,6 @@ import Data.Generic.Rep (class Generic)
import Data.Maybe (Maybe(..), maybe, fromMaybe)
import Data.Maybe (Maybe(..), maybe, fromMaybe)
import Data.Newtype (class Newtype)
import Data.Newtype (class Newtype)
import Data.Sequence as Seq
import Data.Sequence as Seq
import Data.Symbol (SProxy(..))
import Effect.Aff (launchAff_)
import Effect.Aff (launchAff_)
import Gargantext.Components.NgramsTable.Loader (clearCache)
import Gargantext.Components.NgramsTable.Loader (clearCache)
import Gargantext.Components.Nodes.Annuaire.User.Contacts.Types as CT
import Gargantext.Components.Nodes.Annuaire.User.Contacts.Types as CT
...
@@ -30,6 +29,7 @@ import Reactix.DOM.HTML as H
...
@@ -30,6 +29,7 @@ import Reactix.DOM.HTML as H
import Record as Record
import Record as Record
import Simple.JSON as JSON
import Simple.JSON as JSON
import Toestand as T
import Toestand as T
import Type.Proxy (Proxy(..))
here :: R2.Here
here :: R2.Here
here = R2.here "Gargantext.Components.Nodes.Annuaire"
here = R2.here "Gargantext.Components.Nodes.Annuaire"
...
@@ -263,10 +263,10 @@ instance JSON.ReadForeign AnnuaireInfo where
...
@@ -263,10 +263,10 @@ instance JSON.ReadForeign AnnuaireInfo where
inst <- JSON.readImpl f
inst <- JSON.readImpl f
pure $ AnnuaireInfo $ Record.rename user_idP userIdP $ Record.rename parent_idP parentIdP inst
pure $ AnnuaireInfo $ Record.rename user_idP userIdP $ Record.rename parent_idP parentIdP inst
where
where
user_idP =
SProxy :: S
Proxy "user_id"
user_idP =
Proxy ::
Proxy "user_id"
userIdP =
SProxy :: S
Proxy "userId"
userIdP =
Proxy ::
Proxy "userId"
parent_idP =
SProxy :: S
Proxy "parent_id"
parent_idP =
Proxy ::
Proxy "parent_id"
parentIdP =
SProxy :: S
Proxy "parentId"
parentIdP =
Proxy ::
Proxy "parentId"
--newtype AnnuaireTable = AnnuaireTable { annuaireTable :: Array (Maybe Contact)}
--newtype AnnuaireTable = AnnuaireTable { annuaireTable :: Array (Maybe Contact)}
...
@@ -292,4 +292,3 @@ loadPage session {nodeId, params: { offset, limit }} =
...
@@ -292,4 +292,3 @@ loadPage session {nodeId, params: { offset, limit }} =
getAnnuaireInfo :: Session -> Int -> AffRESTError AnnuaireInfo
getAnnuaireInfo :: Session -> Int -> AffRESTError AnnuaireInfo
getAnnuaireInfo session id = get session (NodeAPI Node (Just id) "")
getAnnuaireInfo session id = get session (NodeAPI Node (Just id) "")
src/Gargantext/Components/Nodes/Annuaire/User/Contacts/Types.purs
View file @
5686b05c
...
@@ -7,9 +7,9 @@ import Data.Lens (Lens', lens)
...
@@ -7,9 +7,9 @@ import Data.Lens (Lens', lens)
import Data.Maybe (Maybe(..), fromMaybe)
import Data.Maybe (Maybe(..), fromMaybe)
import Data.Newtype (class Newtype)
import Data.Newtype (class Newtype)
import Data.String as S
import Data.String as S
import Data.Symbol (SProxy(..))
import Record as Record
import Record as Record
import Simple.JSON as JSON
import Simple.JSON as JSON
import Type.Proxy (Proxy(..))
import Gargantext.Prelude (class Eq, bind, pure, ($))
import Gargantext.Prelude (class Eq, bind, pure, ($))
...
@@ -348,7 +348,7 @@ _phone = lens getter setter
...
@@ -348,7 +348,7 @@ _phone = lens getter setter
getter (ContactTouch {phone}) = fromMaybe "" phone
getter (ContactTouch {phone}) = fromMaybe "" phone
setter (ContactTouch ct) val = ContactTouch $ ct { phone = Just val }
setter (ContactTouch ct) val = ContactTouch $ ct { phone = Just val }
user_idP =
SProxy :: S
Proxy "user_id"
user_idP =
Proxy ::
Proxy "user_id"
userIdP =
SProxy :: S
Proxy "userId"
userIdP =
Proxy ::
Proxy "userId"
parent_idP =
SProxy :: S
Proxy "parent_id"
parent_idP =
Proxy ::
Proxy "parent_id"
parentIdP =
SProxy :: S
Proxy "parentId"
parentIdP =
Proxy ::
Proxy "parentId"
src/Gargantext/Components/Nodes/Corpus.purs
View file @
5686b05c
...
@@ -4,6 +4,7 @@ import Data.Array as A
...
@@ -4,6 +4,7 @@ import Data.Array as A
import Data.Either (Either(..))
import Data.Either (Either(..))
import Data.Eq.Generic (genericEq)
import Data.Eq.Generic (genericEq)
import Data.Generic.Rep (class Generic)
import Data.Generic.Rep (class Generic)
import Data.FunctorWithIndex (mapWithIndex)
import Data.List as List
import Data.List as List
import Data.Maybe (Maybe(..), fromMaybe)
import Data.Maybe (Maybe(..), fromMaybe)
import Data.Show.Generic (genericShow)
import Data.Show.Generic (genericShow)
...
@@ -156,7 +157,7 @@ fieldsCodeEditorCpt = here.component "fieldsCodeEditorCpt" cpt
...
@@ -156,7 +157,7 @@ fieldsCodeEditorCpt = here.component "fieldsCodeEditorCpt" cpt
List.modifyAt idx (\{ ftField: Field f } -> { idx, ftField: Field $ f { name = newName } }) fs) fields
List.modifyAt idx (\{ ftField: Field f } -> { idx, ftField: Field $ f { name = newName } }) fs) fields
recomputeIndices :: FTFieldsWithIndex -> FTFieldsWithIndex
recomputeIndices :: FTFieldsWithIndex -> FTFieldsWithIndex
recomputeIndices (FTFieldsWithIndex lst) = FTFieldsWithIndex $
List.
mapWithIndex (\idx -> \{ ftField } -> { idx, ftField }) lst
recomputeIndices (FTFieldsWithIndex lst) = FTFieldsWithIndex $ mapWithIndex (\idx -> \{ ftField } -> { idx, ftField }) lst
hash :: FTFieldWithIndex -> Hash
hash :: FTFieldWithIndex -> Hash
hash { idx, ftField } = Crypto.hash $ "--idx--" <> (show idx) <> "--field--" <> (show ftField)
hash { idx, ftField } = Crypto.hash $ "--idx--" <> (show idx) <> "--field--" <> (show ftField)
...
...
src/Gargantext/Components/Nodes/Corpus/Code.purs
View file @
5686b05c
module Gargantext.Components.Nodes.Corpus.Code where
module Gargantext.Components.Nodes.Corpus.Code where
import Data.Either (Either(..))
import Data.Either (Either(..))
import Data.FunctorWithIndex (mapWithIndex)
import Data.List as List
import Data.List as List
import Data.Maybe (Maybe(..))
import Data.Maybe (Maybe(..))
import Effect (Effect)
import Effect (Effect)
...
@@ -59,7 +60,7 @@ corpusCodeView props = R.createElement corpusCodeViewCpt props []
...
@@ -59,7 +60,7 @@ corpusCodeView props = R.createElement corpusCodeViewCpt props []
corpusCodeViewCpt :: R.Component ViewProps
corpusCodeViewCpt :: R.Component ViewProps
corpusCodeViewCpt = here.component "corpusCodeView" cpt where
corpusCodeViewCpt = here.component "corpusCodeView" cpt where
cpt {corpus: (NodePoly {hyperdata: Hyperdata {fields: FTFieldList fields}}), nodeId, reload, session, boxes} _ = do
cpt {corpus: (NodePoly {hyperdata: Hyperdata {fields: FTFieldList fields}}), nodeId, reload, session, boxes} _ = do
let fieldsWithIndex = FTFieldsWithIndex $
List.
mapWithIndex (\idx -> \ftField -> { idx, ftField }) fields
let fieldsWithIndex = FTFieldsWithIndex $ mapWithIndex (\idx -> \ftField -> { idx, ftField }) fields
fieldsS <- T.useBox fieldsWithIndex
fieldsS <- T.useBox fieldsWithIndex
fields' <- T.useLive T.unequal fieldsS
fields' <- T.useLive T.unequal fieldsS
fieldsRef <- R.useRef fields
fieldsRef <- R.useRef fields
...
...
src/Gargantext/Components/Nodes/Corpus/Dashboard.purs
View file @
5686b05c
...
@@ -2,6 +2,7 @@ module Gargantext.Components.Nodes.Corpus.Dashboard where
...
@@ -2,6 +2,7 @@ module Gargantext.Components.Nodes.Corpus.Dashboard where
import Data.Array as A
import Data.Array as A
import Data.Either (Either(..))
import Data.Either (Either(..))
import Data.FunctorWithIndex (mapWithIndex)
import Data.List as List
import Data.List as List
import Data.Maybe (Maybe(..), fromMaybe)
import Data.Maybe (Maybe(..), fromMaybe)
import Effect (Effect)
import Effect (Effect)
...
@@ -129,7 +130,7 @@ dashboardLayoutLoadedCpt = here.component "dashboardLayoutLoaded" cpt
...
@@ -129,7 +130,7 @@ dashboardLayoutLoadedCpt = here.component "dashboardLayoutLoaded" cpt
where
where
onClickAddChart _ = onChange { charts: A.cons P.CDocsHistogram charts
onClickAddChart _ = onChange { charts: A.cons P.CDocsHistogram charts
, fields }
, fields }
chartsEls =
A.
mapWithIndex chartIdx charts
chartsEls = mapWithIndex chartIdx charts
chartIdx idx chart =
chartIdx idx chart =
renderChart { boxes
renderChart { boxes
, chart
, chart
...
@@ -158,7 +159,7 @@ dashboardCodeEditorCpt :: R.Component CodeEditorProps
...
@@ -158,7 +159,7 @@ dashboardCodeEditorCpt :: R.Component CodeEditorProps
dashboardCodeEditorCpt = here.component "dashboardCodeEditor" cpt
dashboardCodeEditorCpt = here.component "dashboardCodeEditor" cpt
where
where
cpt { fields: FTFieldList fields, nodeId, onChange, session } _ = do
cpt { fields: FTFieldList fields, nodeId, onChange, session } _ = do
let fieldsWithIndex = FTFieldsWithIndex $
List.
mapWithIndex (\idx -> \ftField -> { idx, ftField }) fields
let fieldsWithIndex = FTFieldsWithIndex $ mapWithIndex (\idx -> \ftField -> { idx, ftField }) fields
fieldsS <- T.useBox fieldsWithIndex
fieldsS <- T.useBox fieldsWithIndex
fields' <- T.useLive T.unequal fieldsS
fields' <- T.useLive T.unequal fieldsS
fieldsRef <- R.useRef fields'
fieldsRef <- R.useRef fields'
...
...
src/Gargantext/Components/PhyloExplorer/API.purs
View file @
5686b05c
...
@@ -15,7 +15,6 @@ import Data.Generic.Rep (class Generic)
...
@@ -15,7 +15,6 @@ import Data.Generic.Rep (class Generic)
import Data.Maybe (Maybe(..))
import Data.Maybe (Maybe(..))
import Data.Newtype (class Newtype)
import Data.Newtype (class Newtype)
import Data.Show.Generic (genericShow)
import Data.Show.Generic (genericShow)
import Data.Symbol (SProxy(..))
import Gargantext.Components.PhyloExplorer.JSON (PhyloJSON)
import Gargantext.Components.PhyloExplorer.JSON (PhyloJSON)
import Gargantext.Components.PhyloExplorer.Types (PhyloSet, parseToPhyloSet)
import Gargantext.Components.PhyloExplorer.Types (PhyloSet, parseToPhyloSet)
import Gargantext.Config.REST (AffRESTError)
import Gargantext.Config.REST (AffRESTError)
...
@@ -28,6 +27,7 @@ import Gargantext.Types as GT
...
@@ -28,6 +27,7 @@ import Gargantext.Types as GT
import Record as Record
import Record as Record
import Simple.JSON as JSON
import Simple.JSON as JSON
import Simple.JSON.Generics as JSONG
import Simple.JSON.Generics as JSONG
import Type.Proxy (Proxy(..))
get :: S.Session -> NodeID -> AffRESTError (PhyloSet)
get :: S.Session -> NodeID -> AffRESTError (PhyloSet)
...
@@ -57,23 +57,23 @@ instance JSON.WriteForeign UpdateData where
...
@@ -57,23 +57,23 @@ instance JSON.WriteForeign UpdateData where
where
where
rename
rename
= Record.rename
= Record.rename
(
SProxy :: S
Proxy "proximity")
(
Proxy ::
Proxy "proximity")
(
SProxy :: S
Proxy "_sc_phyloProximity")
(
Proxy ::
Proxy "_sc_phyloProximity")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "synchrony")
(
Proxy ::
Proxy "synchrony")
(
SProxy :: S
Proxy "_sc_phyloSynchrony")
(
Proxy ::
Proxy "_sc_phyloSynchrony")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "quality")
(
Proxy ::
Proxy "quality")
(
SProxy :: S
Proxy "_sc_phyloQuality")
(
Proxy ::
Proxy "_sc_phyloQuality")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "timeUnit")
(
Proxy ::
Proxy "timeUnit")
(
SProxy :: S
Proxy "_sc_timeUnit")
(
Proxy ::
Proxy "_sc_timeUnit")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "clique")
(
Proxy ::
Proxy "clique")
(
SProxy :: S
Proxy "_sc_clique")
(
Proxy ::
Proxy "_sc_clique")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "exportFilter")
(
Proxy ::
Proxy "exportFilter")
(
SProxy :: S
Proxy "_sc_exportFilter")
(
Proxy ::
Proxy "_sc_exportFilter")
data TimeUnit
data TimeUnit
= Epoch TimeUnitCriteria
= Epoch TimeUnitCriteria
...
@@ -96,68 +96,68 @@ instance JSON.WriteForeign TimeUnit where
...
@@ -96,68 +96,68 @@ instance JSON.WriteForeign TimeUnit where
where
where
parseEpoch
parseEpoch
= Record.rename
= Record.rename
(
SProxy :: S
Proxy "period")
(
Proxy ::
Proxy "period")
(
SProxy :: S
Proxy "_epoch_period")
(
Proxy ::
Proxy "_epoch_period")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "step")
(
Proxy ::
Proxy "step")
(
SProxy :: S
Proxy "_epoch_step")
(
Proxy ::
Proxy "_epoch_step")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "matchingFrame")
(
Proxy ::
Proxy "matchingFrame")
(
SProxy :: S
Proxy "_epoch_matchingFrame")
(
Proxy ::
Proxy "_epoch_matchingFrame")
>>> Record.insert
>>> Record.insert
(
SProxy :: S
Proxy "tag")
(
Proxy ::
Proxy "tag")
"Epoch"
"Epoch"
parseYear
parseYear
= Record.rename
= Record.rename
(
SProxy :: S
Proxy "period")
(
Proxy ::
Proxy "period")
(
SProxy :: S
Proxy "_year_period")
(
Proxy ::
Proxy "_year_period")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "step")
(
Proxy ::
Proxy "step")
(
SProxy :: S
Proxy "_year_step")
(
Proxy ::
Proxy "_year_step")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "matchingFrame")
(
Proxy ::
Proxy "matchingFrame")
(
SProxy :: S
Proxy "_year_matchingFrame")
(
Proxy ::
Proxy "_year_matchingFrame")
>>> Record.insert
>>> Record.insert
(
SProxy :: S
Proxy "tag")
(
Proxy ::
Proxy "tag")
"Year"
"Year"
parseMonth
parseMonth
= Record.rename
= Record.rename
(
SProxy :: S
Proxy "period")
(
Proxy ::
Proxy "period")
(
SProxy :: S
Proxy "_month_period")
(
Proxy ::
Proxy "_month_period")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "step")
(
Proxy ::
Proxy "step")
(
SProxy :: S
Proxy "_month_step")
(
Proxy ::
Proxy "_month_step")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "matchingFrame")
(
Proxy ::
Proxy "matchingFrame")
(
SProxy :: S
Proxy "_month_matchingFrame")
(
Proxy ::
Proxy "_month_matchingFrame")
>>> Record.insert
>>> Record.insert
(
SProxy :: S
Proxy "tag")
(
Proxy ::
Proxy "tag")
"Month"
"Month"
parseWeek
parseWeek
= Record.rename
= Record.rename
(
SProxy :: S
Proxy "period")
(
Proxy ::
Proxy "period")
(
SProxy :: S
Proxy "_week_period")
(
Proxy ::
Proxy "_week_period")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "step")
(
Proxy ::
Proxy "step")
(
SProxy :: S
Proxy "_week_step")
(
Proxy ::
Proxy "_week_step")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "matchingFrame")
(
Proxy ::
Proxy "matchingFrame")
(
SProxy :: S
Proxy "_week_matchingFrame")
(
Proxy ::
Proxy "_week_matchingFrame")
>>> Record.insert
>>> Record.insert
(
SProxy :: S
Proxy "tag")
(
Proxy ::
Proxy "tag")
"Week"
"Week"
parseDay
parseDay
= Record.rename
= Record.rename
(
SProxy :: S
Proxy "period")
(
Proxy ::
Proxy "period")
(
SProxy :: S
Proxy "_day_period")
(
Proxy ::
Proxy "_day_period")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "step")
(
Proxy ::
Proxy "step")
(
SProxy :: S
Proxy "_day_step")
(
Proxy ::
Proxy "_day_step")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "matchingFrame")
(
Proxy ::
Proxy "matchingFrame")
(
SProxy :: S
Proxy "_day_matchingFrame")
(
Proxy ::
Proxy "_day_matchingFrame")
>>> Record.insert
>>> Record.insert
(
SProxy :: S
Proxy "tag")
(
Proxy ::
Proxy "tag")
"Day"
"Day"
...
@@ -217,27 +217,27 @@ instance JSON.WriteForeign Clique where
...
@@ -217,27 +217,27 @@ instance JSON.WriteForeign Clique where
where
where
parseFIS
parseFIS
= Record.insert
= Record.insert
(
SProxy :: S
Proxy "tag")
(
Proxy ::
Proxy "tag")
"Fis"
"Fis"
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "support")
(
Proxy ::
Proxy "support")
(
SProxy :: S
Proxy "_fis_support")
(
Proxy ::
Proxy "_fis_support")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "size")
(
Proxy ::
Proxy "size")
(
SProxy :: S
Proxy "_fis_size")
(
Proxy ::
Proxy "_fis_size")
parseMaxClique
parseMaxClique
= Record.insert
= Record.insert
(
SProxy :: S
Proxy "tag")
(
Proxy ::
Proxy "tag")
"MaxClique"
"MaxClique"
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "size")
(
Proxy ::
Proxy "size")
(
SProxy :: S
Proxy "_mcl_size")
(
Proxy ::
Proxy "_mcl_size")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "threshold")
(
Proxy ::
Proxy "threshold")
(
SProxy :: S
Proxy "_mcl_threshold")
(
Proxy ::
Proxy "_mcl_threshold")
>>> Record.rename
>>> Record.rename
(
SProxy :: S
Proxy "filter")
(
Proxy ::
Proxy "filter")
(
SProxy :: S
Proxy "_mcl_filter")
(
Proxy ::
Proxy "_mcl_filter")
data ReflexiveClique
data ReflexiveClique
...
...
src/Gargantext/Components/PhyloExplorer/Resources.js
View file @
5686b05c
...
@@ -4,35 +4,35 @@
...
@@ -4,35 +4,35 @@
/// FIELDS
/// FIELDS
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
var
EXTRACTED_TERMS_EVENT
=
'extracted_terms_event'
;
const
EXTRACTED_TERMS_EVENT
=
'extracted_terms_event'
;
var
EXTRACTED_COUNT_EVENT
=
'extracted_count_event'
;
const
EXTRACTED_COUNT_EVENT
=
'extracted_count_event'
;
var
SELECTED_TERM_EVENT
=
'selected_term_event'
;
const
SELECTED_TERM_EVENT
=
'selected_term_event'
;
var
SELECTED_BRANCH_EVENT
=
'selected_branch_event'
;
const
SELECTED_BRANCH_EVENT
=
'selected_branch_event'
;
var
SELECTED_SOURCE_EVENT
=
'selected_source_event'
;
const
SELECTED_SOURCE_EVENT
=
'selected_source_event'
;
var
DISPLAY_VIEW_EVENT
=
'display_view_event'
;
const
DISPLAY_VIEW_EVENT
=
'display_view_event'
;
var
ISO_LINE_DOM_QUERY
=
'.phylo-isoline'
;
const
ISO_LINE_DOM_QUERY
=
'.phylo-isoline'
;
var
LEFT_COLUMN_DOM_QUERY
=
'.phylo-grid__blueprint__left'
;
const
LEFT_COLUMN_DOM_QUERY
=
'.phylo-grid__blueprint__left'
;
var
CENTER_COLUMN_DOM_QUERY
=
'.phylo-grid__blueprint__center'
;
const
CENTER_COLUMN_DOM_QUERY
=
'.phylo-grid__blueprint__center'
;
var
SCAPE_DOM_QUERY
=
'.phylo-grid__content__scape'
;
const
SCAPE_DOM_QUERY
=
'.phylo-grid__content__scape'
;
// (?) Global thread dependencies:
// (?) Global thread dependencies:
// * d3 <Object> (main D3 proxy))
// * d3 <Object> (main D3 proxy))
// * window <Window> (cf. below function signature for window uses)
// * window <Window> (cf. below function signature for window uses)
// * document <HTMLDocument>
// * document <HTMLDocument>
var
memoTickText
=
{};
// <Object> of <Int> => <TickText>
let
memoTickText
=
{};
// <Object> of <Int> => <TickText>
/// <TickText> ::
/// <TickText> ::
/// <Int> bId
/// <Int> bId
/// <Float> limit
/// <Float> limit
/// <String>text
/// <String>text
var
panel
=
undefined
;
// <Object> instanceof d3.selection
let
panel
=
undefined
;
// <Object> instanceof d3.selection
var
svg
=
undefined
;
// <Object> instanceof d3.selection
let
svg
=
undefined
;
// <Object> instanceof d3.selection
var
label
=
undefined
;
// <Object> instanceof d3.selection
let
label
=
undefined
;
// <Object> instanceof d3.selection
var
zoom
=
undefined
;
// <Function> see https://github.com/d3/d3-zoom#zoom
let
zoom
=
undefined
;
// <Function> see https://github.com/d3/d3-zoom#zoom
var
xScale0
=
undefined
;
// <Function> see https://github.com/d3/d3-scale#_continuous
let
xScale0
=
undefined
;
// <Function> see https://github.com/d3/d3-scale#_continuous
var
yScale0
=
undefined
;
// <Function> see https://github.com/d3/d3-scale#_continuous
let
yScale0
=
undefined
;
// <Function> see https://github.com/d3/d3-scale#_continuous
var
subscribers
=
{};
// <Object> dictionary for pubsub pattern
let
subscribers
=
{};
// <Object> dictionary for pubsub pattern
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
/// HELPERS
/// HELPERS
...
@@ -2279,26 +2279,29 @@ function addEmergenceLabels(k, emergences, branchByGroup, fontScale, opacityScal
...
@@ -2279,26 +2279,29 @@ function addEmergenceLabels(k, emergences, branchByGroup, fontScale, opacityScal
/// EXPORTS
/// EXPORTS
////////////////////////////////////////////////////////////////////////////////
////////////////////////////////////////////////////////////////////////////////
exports
.
_extractedTermsEvent
=
EXTRACTED_TERMS_EVENT
;
export
const
_extractedTermsEvent
=
EXTRACTED_TERMS_EVENT
;
exports
.
_extractedCountEvent
=
EXTRACTED_COUNT_EVENT
;
export
const
_extractedCountEvent
=
EXTRACTED_COUNT_EVENT
;
exports
.
_selectedTermEvent
=
SELECTED_TERM_EVENT
;
export
const
_selectedTermEvent
=
SELECTED_TERM_EVENT
;
exports
.
_selectedBranchEvent
=
SELECTED_BRANCH_EVENT
;
export
const
_selectedBranchEvent
=
SELECTED_BRANCH_EVENT
;
exports
.
_selectedSourceEvent
=
SELECTED_SOURCE_EVENT
;
export
const
_selectedSourceEvent
=
SELECTED_SOURCE_EVENT
;
exports
.
_displayViewEvent
=
DISPLAY_VIEW_EVENT
;
export
const
_displayViewEvent
=
DISPLAY_VIEW_EVENT
;
exports
.
_drawPhylo
=
drawPhylo
;
let
pubsubPublish
=
pubsub
.
publish
;
exports
.
_drawWordCloud
=
drawWordCloud
;
let
pubsubSubscribe
=
pubsub
.
subscribe
;
exports
.
_showLabel
=
showLabel
;
let
pubsubUnsubscribe
=
pubsub
.
unsubscribe
;
exports
.
_termClick
=
termClick
;
exports
.
_resetView
=
resetView
;
export
{
drawPhylo
as
_drawPhylo
,
exports
.
_showLabel
=
showLabel
;
drawWordCloud
as
_drawWordCloud
,
exports
.
_showHeading
=
showHeading
;
showLabel
as
_showLabel
,
exports
.
_showLanding
=
showLanding
;
termClick
as
_termClick
,
exports
.
_exportViz
=
exportViz
;
resetView
as
_resetView
,
exports
.
_doubleClick
=
doubleClick
;
showHeading
as
_showHeading
,
exports
.
_highlightGroups
=
highlightGroups
;
showLanding
as
_showLanding
,
exports
.
_initPath
=
initPath
;
exportViz
as
_exportViz
,
doubleClick
as
_doubleClick
,
exports
.
_publish
=
pubsub
.
publish
;
highlightGroups
as
_highlightGroups
,
exports
.
_subscribe
=
pubsub
.
subscribe
;
initPath
as
_initPath
,
exports
.
_unsubscribe
=
pubsub
.
unsubscribe
;
pubsubPublish
as
_publish
,
pubsubSubscribe
as
_subscribe
,
pubsubUnsubscribe
as
_unsubscribe
};
src/Gargantext/Components/PhyloExplorer/Sidebar/SelectionTab.purs
View file @
5686b05c
...
@@ -4,8 +4,9 @@ module Gargantext.Components.PhyloExplorer.SelectionTab
...
@@ -4,8 +4,9 @@ module Gargantext.Components.PhyloExplorer.SelectionTab
import Gargantext.Prelude
import Gargantext.Prelude
import Data.Array (length,
mapWithIndex,
null)
import Data.Array (length, null)
import Data.Foldable (intercalate)
import Data.Foldable (intercalate)
import Data.FunctorWithIndex (mapWithIndex)
import Data.Int (ceil)
import Data.Int (ceil)
import Data.Maybe (Maybe(..), isJust)
import Data.Maybe (Maybe(..), isJust)
import Data.Tuple.Nested ((/\))
import Data.Tuple.Nested ((/\))
...
...
src/Gargantext/Components/PhyloExplorer/Types.js
View file @
5686b05c
...
@@ -4,7 +4,7 @@
...
@@ -4,7 +4,7 @@
* @param {string} year
* @param {string} year
* @returns {Date}
* @returns {Date}
*/
*/
function
yearToDate
(
year
)
{
export
function
yearToDate
(
year
)
{
var
d
=
new
Date
();
var
d
=
new
Date
();
d
.
setYear
(
parseInt
(
year
));
d
.
setYear
(
parseInt
(
year
));
...
@@ -18,7 +18,7 @@ function yearToDate(year) {
...
@@ -18,7 +18,7 @@ function yearToDate(year) {
* @param {string} str
* @param {string} str
* @returns {Date}
* @returns {Date}
*/
*/
function
stringToDate
(
str
)
{
export
function
stringToDate
(
str
)
{
var
arr
=
(
str
.
replace
(
'"'
,
''
)).
split
(
'-'
);
var
arr
=
(
str
.
replace
(
'"'
,
''
)).
split
(
'-'
);
var
d
=
new
Date
();
var
d
=
new
Date
();
...
@@ -34,7 +34,7 @@ function stringToDate(str) {
...
@@ -34,7 +34,7 @@ function stringToDate(str) {
* @param {string} str
* @param {string} str
* @returns {Date}
* @returns {Date}
*/
*/
function
utcStringToDate
(
str
)
{
export
function
utcStringToDate
(
str
)
{
var
arr
=
((
str
.
replace
(
'"'
,
''
)).
replace
(
' UTC'
,
''
)).
split
(
/
[\s
-:
]
+/
);
var
arr
=
((
str
.
replace
(
'"'
,
''
)).
replace
(
' UTC'
,
''
)).
split
(
/
[\s
-:
]
+/
);
var
d
=
new
Date
();
var
d
=
new
Date
();
...
@@ -45,7 +45,3 @@ function utcStringToDate(str) {
...
@@ -45,7 +45,3 @@ function utcStringToDate(str) {
return
d
;
return
d
;
}
}
exports
.
yearToDate
=
yearToDate
;
exports
.
stringToDate
=
stringToDate
;
exports
.
utcStringToDate
=
utcStringToDate
;
src/Gargantext/Components/PhyloExplorer/Types.purs
View file @
5686b05c
...
@@ -20,6 +20,7 @@ import Gargantext.Prelude
...
@@ -20,6 +20,7 @@ import Gargantext.Prelude
import Data.Array as Array
import Data.Array as Array
import Data.Date as Date
import Data.Date as Date
import Data.Generic.Rep (class Generic)
import Data.Generic.Rep (class Generic)
import Data.FunctorWithIndex (mapWithIndex)
import Data.Int as Int
import Data.Int as Int
import Data.Maybe (Maybe(..), maybe)
import Data.Maybe (Maybe(..), maybe)
import Data.Newtype (class Newtype)
import Data.Newtype (class Newtype)
...
@@ -379,7 +380,7 @@ parseSources
...
@@ -379,7 +380,7 @@ parseSources
-- sorting purpose only
-- sorting purpose only
sortSources :: Array String -> Array Source
sortSources :: Array String -> Array Source
sortSources
sortSources
=
Array.
mapWithIndex setSource
= mapWithIndex setSource
>>> Array.sortWith getLabel
>>> Array.sortWith getLabel
where
where
...
...
src/Gargantext/Components/RangeSlider.purs
View file @
5686b05c
...
@@ -11,6 +11,7 @@ import Data.Eq.Generic (genericEq)
...
@@ -11,6 +11,7 @@ import Data.Eq.Generic (genericEq)
import Data.Int (fromNumber)
import Data.Int (fromNumber)
import Data.Maybe (Maybe(..), fromMaybe)
import Data.Maybe (Maybe(..), fromMaybe)
import Data.Number as DN
import Data.Number as DN
import Data.Number.Format as DNF
import Data.Nullable (Nullable, null)
import Data.Nullable (Nullable, null)
import Data.Traversable (traverse_)
import Data.Traversable (traverse_)
import DOM.Simple as DOM
import DOM.Simple as DOM
...
@@ -18,7 +19,6 @@ import DOM.Simple.Document (document)
...
@@ -18,7 +19,6 @@ import DOM.Simple.Document (document)
import DOM.Simple.Event as Event
import DOM.Simple.Event as Event
import DOM.Simple.EventListener as EL
import DOM.Simple.EventListener as EL
import DOM.Simple (DOMRect)
import DOM.Simple (DOMRect)
import Global (toFixed)
import Effect (Effect)
import Effect (Effect)
import Reactix as R
import Reactix as R
import Reactix.DOM.HTML as H
import Reactix.DOM.HTML as H
...
@@ -169,8 +169,9 @@ renderScaleSel ref props (Range.Closed {min, max}) =
...
@@ -169,8 +169,9 @@ renderScaleSel ref props (Range.Closed {min, max}) =
style = {left: computeLeft, width: computeWidth}
style = {left: computeLeft, width: computeWidth}
percOffsetMin = Range.normalise props.bounds min
percOffsetMin = Range.normalise props.bounds min
percOffsetMax = Range.normalise props.bounds max
percOffsetMax = Range.normalise props.bounds max
computeLeft = (show $ 100.0 * percOffsetMin) <> "%"
computeLeft = formatter $ 100.0 * percOffsetMin
computeWidth = (show $ 100.0 * (percOffsetMax - percOffsetMin)) <> "%"
computeWidth = formatter $ 100.0 * (percOffsetMax - percOffsetMin)
formatter n = (DNF.toStringWith (DNF.fixed 0) n) <> "%"
renderKnob :: Knob -> R.Ref (Nullable DOM.Element) -> Range.NumberRange -> Bounds -> T.Box (Maybe Knob) -> Int -> R.Element
renderKnob :: Knob -> R.Ref (Nullable DOM.Element) -> Range.NumberRange -> Bounds -> T.Box (Maybe Knob) -> Int -> R.Element
...
@@ -178,12 +179,10 @@ renderKnob knob ref (Range.Closed value) bounds set precision =
...
@@ -178,12 +179,10 @@ renderKnob knob ref (Range.Closed value) bounds set precision =
H.div { ref, tabIndex, className, aria, on: { mouseDown: onMouseDown }, style } [
H.div { ref, tabIndex, className, aria, on: { mouseDown: onMouseDown }, style } [
H.div { className: "range-slider__placeholder" }
H.div { className: "range-slider__placeholder" }
[
[
H.text $
text $ toFixed precision
val
H.text $
DNF.toStringWith (DNF.precision precision)
val
]
]
]
]
where
where
text (Just num) = num
text Nothing = "error"
tabIndex = 0
tabIndex = 0
className = "range-slider__knob"
className = "range-slider__knob"
aria = { label: labelPrefix knob <> "value: " <> show val }
aria = { label: labelPrefix knob <> "value: " <> show val }
...
...
src/Gargantext/Components/Router.purs
View file @
5686b05c
...
@@ -134,7 +134,7 @@ mainPageCpt = here.component "mainPage" cpt where
...
@@ -134,7 +134,7 @@ mainPageCpt = here.component "mainPage" cpt where
-> (Unit -> Effect Unit)
-> (Unit -> Effect Unit)
deleteTile tile listBox = const do
deleteTile tile listBox = const do
list <- T.read listBox
list <- T.read listBox
newList <- pure $ filter (
_ # tile.id # findTile # not
) list
newList <- pure $ filter (
not $ findTile $ tile.id
) list
T.write_ newList listBox
T.write_ newList listBox
let hasHorizontalTiles = not $ eq 0 $ length tileAxisXList
let hasHorizontalTiles = not $ eq 0 $ length tileAxisXList
...
...
src/Gargantext/Config/REST.purs
View file @
5686b05c
module Gargantext.Config.REST where
module Gargantext.Config.REST where
import Affjax (Error(..), defaultRequest, request)
import Affjax
.Web
(Error(..), defaultRequest, request)
import Affjax as Affjax
import Affjax as Affjax
import Affjax.RequestBody (formData, formURLEncoded, string)
import Affjax.RequestBody (formData, formURLEncoded, string)
import Affjax.RequestHeader as ARH
import Affjax.RequestHeader as ARH
...
...
src/Gargantext/Core/NgramsTable/Functions.purs
View file @
5686b05c
src/Gargantext/Core/NgramsTable/Types.purs
View file @
5686b05c
...
@@ -23,7 +23,6 @@ import Data.Show.Generic (genericShow)
...
@@ -23,7 +23,6 @@ import Data.Show.Generic (genericShow)
import Data.Set (Set)
import Data.Set (Set)
import Data.Set as Set
import Data.Set as Set
import Data.String.Regex (Regex, regex, replace) as R
import Data.String.Regex (Regex, regex, replace) as R
import Data.Symbol (SProxy(..))
import Data.Tuple (Tuple(..))
import Data.Tuple (Tuple(..))
import Effect (Effect)
import Effect (Effect)
import Effect.Aff (Aff)
import Effect.Aff (Aff)
...
@@ -36,6 +35,7 @@ import Gargantext.Sessions (Session)
...
@@ -36,6 +35,7 @@ import Gargantext.Sessions (Session)
import Gargantext.Types as GT
import Gargantext.Types as GT
import Simple.JSON as JSON
import Simple.JSON as JSON
import Reactix as R
import Reactix as R
import Type.Proxy (Proxy(..))
type Endo a = a -> a
type Endo a = a -> a
...
@@ -276,28 +276,28 @@ instance JSON.WriteForeign NgramsElement where
...
@@ -276,28 +276,28 @@ instance JSON.WriteForeign NgramsElement where
JSON.writeImpl $ ne { children = Set.toUnfoldable ne.children :: Array _ }
JSON.writeImpl $ ne { children = Set.toUnfoldable ne.children :: Array _ }
_parent :: forall parent row. Lens' { parent :: parent | row } parent
_parent :: forall parent row. Lens' { parent :: parent | row } parent
_parent = prop (
SProxy :: S
Proxy "parent")
_parent = prop (
Proxy ::
Proxy "parent")
_root :: forall root row. Lens' { root :: root | row } root
_root :: forall root row. Lens' { root :: root | row } root
_root = prop (
SProxy :: S
Proxy "root")
_root = prop (
Proxy ::
Proxy "root")
_ngrams :: forall row. Lens' { ngrams :: NgramsTerm | row } NgramsTerm
_ngrams :: forall row. Lens' { ngrams :: NgramsTerm | row } NgramsTerm
_ngrams = prop (
SProxy :: S
Proxy "ngrams")
_ngrams = prop (
Proxy ::
Proxy "ngrams")
_children :: forall row. Lens' { children :: Set NgramsTerm | row } (Set NgramsTerm)
_children :: forall row. Lens' { children :: Set NgramsTerm | row } (Set NgramsTerm)
_children = prop (
SProxy :: S
Proxy "children")
_children = prop (
Proxy ::
Proxy "children")
_occurrences :: forall row. Lens' { occurrences :: Int | row } Int
_occurrences :: forall row. Lens' { occurrences :: Int | row } Int
_occurrences = prop (
SProxy :: S
Proxy "occurrences")
_occurrences = prop (
Proxy ::
Proxy "occurrences")
_list :: forall a row. Lens' { list :: a | row } a
_list :: forall a row. Lens' { list :: a | row } a
_list = prop (
SProxy :: S
Proxy "list")
_list = prop (
Proxy ::
Proxy "list")
_ngrams_repo_elements :: forall a row. Lens' { ngrams_repo_elements :: a | row } a
_ngrams_repo_elements :: forall a row. Lens' { ngrams_repo_elements :: a | row } a
_ngrams_repo_elements = prop (
SProxy :: S
Proxy "ngrams_repo_elements")
_ngrams_repo_elements = prop (
Proxy ::
Proxy "ngrams_repo_elements")
_ngrams_scores :: forall a row. Lens' { ngrams_scores :: a | row } a
_ngrams_scores :: forall a row. Lens' { ngrams_scores :: a | row } a
_ngrams_scores = prop (
SProxy :: S
Proxy "ngrams_scores")
_ngrams_scores = prop (
Proxy ::
Proxy "ngrams_scores")
_NgramsElement :: Iso' NgramsElement {
_NgramsElement :: Iso' NgramsElement {
children :: Set NgramsTerm
children :: Set NgramsTerm
...
...
src/Gargantext/Data/Louvain.js
View file @
5686b05c
...
@@ -6,7 +6,7 @@ community detection algorithm (http://arxiv.org/abs/0803.0476)
...
@@ -6,7 +6,7 @@ community detection algorithm (http://arxiv.org/abs/0803.0476)
Based on https://bitbucket.org/taynaud/python-louvain/overview
Based on https://bitbucket.org/taynaud/python-louvain/overview
*/
*/
export
s
.
_jLouvain
=
(
function
(){
export
const
_jLouvain
=
(
function
(){
return
function
(){
return
function
(){
//Constants
//Constants
var
__PASS_MAX
=
-
1
var
__PASS_MAX
=
-
1
...
@@ -381,6 +381,6 @@ exports._jLouvain = (function(){
...
@@ -381,6 +381,6 @@ exports._jLouvain = (function(){
}
}
})();
})();
export
s
.
_init
=
function
(
louvain
,
nodes
,
edges
)
{
export
function
_init
(
louvain
,
nodes
,
edges
)
{
return
Object
.
entries
(
louvain
.
nodes
(
nodes
).
edges
(
edges
)());
return
Object
.
entries
(
louvain
.
nodes
(
nodes
).
edges
(
edges
)());
}
}
src/Gargantext/Hooks/FormValidation/Methods.purs
View file @
5686b05c
...
@@ -96,8 +96,8 @@ useFormValidation = do
...
@@ -96,8 +96,8 @@ useFormValidation = do
result /\ resultBox <- R2.useBox' (V (Right mempty) :: VForm)
result /\ resultBox <- R2.useBox' (V (Right mempty) :: VForm)
memoHasError <- R.useMemo1 result $ const $ hasError result
memoHasError <- R.useMemo1 result $ const $ hasError result
memoHasError' <- R.useMemo1 result $ const $
(_ # result # hasError')
memoHasError' <- R.useMemo1 result $ const $
hasError' result
memoHasError_ <- R.useMemo1 result $ const $
(_ # result # hasError_)
memoHasError_ <- R.useMemo1 result $ const $
hasError_ result
pure
pure
{ tryCount
{ tryCount
...
...
src/Gargantext/Hooks/FormValidation/Types.js
View file @
5686b05c
...
@@ -7,10 +7,10 @@
...
@@ -7,10 +7,10 @@
* @link https://gist.github.com/gregseth/5582254 [2]
* @link https://gist.github.com/gregseth/5582254 [2]
* @type {RegExp}
* @type {RegExp}
*/
*/
export
s
.
emailPattern
=
/
[
a-z0-9!#$%&'*+
/
=?^_`{|}~-
]
+
(?:\.[
a-z0-9!#$%&'*+
/
=?^_`{|}~-
]
+
)
*@
(?:[
a-z0-9
](?:[
a-z0-9-
]
*
[
a-z0-9
])?\.)
+
[
a-z0-9
](?:[
a-z0-9-
]
*
[
a-z0-9
])?
/
;
export
const
emailPattern
=
/
[
a-z0-9!#$%&'*+
/
=?^_`{|}~-
]
+
(?:\.[
a-z0-9!#$%&'*+
/
=?^_`{|}~-
]
+
)
*@
(?:[
a-z0-9
](?:[
a-z0-9-
]
*
[
a-z0-9
])?\.)
+
[
a-z0-9
](?:[
a-z0-9-
]
*
[
a-z0-9
])?
/
;
/**
/**
* Date Pattern
* Date Pattern
* @link https://www.regextester.com/96683
* @link https://www.regextester.com/96683
* @type {RegExp}
* @type {RegExp}
*/
*/
export
s
.
datePattern
=
/
([
12
]\d{3}
-
(
0
[
1-9
]
|1
[
0-2
])
-
(
0
[
1-9
]
|
[
12
]\d
|3
[
01
]))
/
export
const
datePattern
=
/
([
12
]\d{3}
-
(
0
[
1-9
]
|1
[
0-2
])
-
(
0
[
1-9
]
|
[
12
]\d
|3
[
01
]))
/
;
src/Gargantext/Hooks/LinkHandler.purs
View file @
5686b05c
...
@@ -72,7 +72,7 @@ changeTileRoute tileAxisXList tileAxisYList tile newRoute = do
...
@@ -72,7 +72,7 @@ changeTileRoute tileAxisXList tileAxisYList tile newRoute = do
findTile id tile' = eq id $ get (Proxy :: Proxy "id") tile'
findTile id tile' = eq id $ get (Proxy :: Proxy "id") tile'
hasTile :: Array (Record Tile) -> UUID -> Maybe Int
hasTile :: Array (Record Tile) -> UUID -> Maybe Int
hasTile list id = findIndex (
_ # id # findTile
) list
hasTile list id = findIndex (
findTile id
) list
updateTile :: Int -> AppRoute -> Array (Record Tile) -> Array (Record Tile)
updateTile :: Int -> AppRoute -> Array (Record Tile) -> Array (Record Tile)
updateTile index route list = modifyAtIndices
updateTile index route list = modifyAtIndices
...
...
src/Gargantext/Hooks/Resize.js
View file @
5686b05c
'use strict'
;
'use strict'
;
exports
.
_add
=
add
;
exports
.
_remove
=
remove
;
/**
/**
* @function add
* @function add
* @param {Window} window
* @param {Window} window
...
@@ -10,7 +8,7 @@ exports._remove = remove;
...
@@ -10,7 +8,7 @@ exports._remove = remove;
* @param {String} targetQuery
* @param {String} targetQuery
* @param {String} type
* @param {String} type
*/
*/
function
add
(
window
,
document
,
sourceQuery
,
targetQuery
,
type
)
{
export
function
_
add
(
window
,
document
,
sourceQuery
,
targetQuery
,
type
)
{
var
source
=
document
.
querySelector
(
sourceQuery
);
var
source
=
document
.
querySelector
(
sourceQuery
);
var
target
=
document
.
querySelector
(
targetQuery
);
var
target
=
document
.
querySelector
(
targetQuery
);
...
@@ -49,7 +47,7 @@ function add(window, document, sourceQuery, targetQuery, type) {
...
@@ -49,7 +47,7 @@ function add(window, document, sourceQuery, targetQuery, type) {
* @param {Document} document
* @param {Document} document
* @param {String} sourceQuery
* @param {String} sourceQuery
*/
*/
function
remove
(
document
,
sourceQuery
)
{
export
function
_
remove
(
document
,
sourceQuery
)
{
var
source
=
document
.
querySelector
(
sourceQuery
);
var
source
=
document
.
querySelector
(
sourceQuery
);
console
.
log
(
sourceQuery
)
console
.
log
(
sourceQuery
)
source
.
removeEventListener
(
'mousedown'
);
source
.
removeEventListener
(
'mousedown'
);
...
...
src/Gargantext/Hooks/Scrollbar.js
View file @
5686b05c
...
@@ -28,21 +28,17 @@ try {
...
@@ -28,21 +28,17 @@ try {
var
wheelOpt
=
supportsPassive
?
{
passive
:
false
}
:
false
;
var
wheelOpt
=
supportsPassive
?
{
passive
:
false
}
:
false
;
var
wheelEvent
=
'onwheel'
in
document
.
createElement
(
'div'
)
?
'wheel'
:
'mousewheel'
;
var
wheelEvent
=
'onwheel'
in
document
.
createElement
(
'div'
)
?
'wheel'
:
'mousewheel'
;
// call this to Disable
export
function
disableScroll
()
{
function
disableScroll
()
{
// call this to Disable
window
.
addEventListener
(
'DOMMouseScroll'
,
preventDefault
,
false
);
// older FF
window
.
addEventListener
(
'DOMMouseScroll'
,
preventDefault
,
false
);
// older FF
window
.
addEventListener
(
wheelEvent
,
preventDefault
,
wheelOpt
);
// modern desktop
window
.
addEventListener
(
wheelEvent
,
preventDefault
,
wheelOpt
);
// modern desktop
window
.
addEventListener
(
'touchmove'
,
preventDefault
,
wheelOpt
);
// mobile
window
.
addEventListener
(
'touchmove'
,
preventDefault
,
wheelOpt
);
// mobile
window
.
addEventListener
(
'keydown'
,
preventDefaultForScrollKeys
,
false
);
window
.
addEventListener
(
'keydown'
,
preventDefaultForScrollKeys
,
false
);
}
}
export
function
enableScroll
()
{
// call this to Enable
// call this to Enable
function
enableScroll
()
{
window
.
removeEventListener
(
'DOMMouseScroll'
,
preventDefault
,
false
);
window
.
removeEventListener
(
'DOMMouseScroll'
,
preventDefault
,
false
);
window
.
removeEventListener
(
wheelEvent
,
preventDefault
,
wheelOpt
);
window
.
removeEventListener
(
wheelEvent
,
preventDefault
,
wheelOpt
);
window
.
removeEventListener
(
'touchmove'
,
preventDefault
,
wheelOpt
);
window
.
removeEventListener
(
'touchmove'
,
preventDefault
,
wheelOpt
);
window
.
removeEventListener
(
'keydown'
,
preventDefaultForScrollKeys
,
false
);
window
.
removeEventListener
(
'keydown'
,
preventDefaultForScrollKeys
,
false
);
}
}
exports
.
disableScroll
=
disableScroll
;
exports
.
enableScroll
=
enableScroll
;
src/Gargantext/Hooks/Sigmax/Sigma.js
View file @
5686b05c
'use strict'
;
'use strict'
;
const
sigma
=
require
(
'sigma/src/garg.js'
).
sigma
;
//import { sigma } from 'sigma/src/garg.js';
import
sigma
from
'sigma'
;
console
.
log
(
'imported sigma'
,
sigma
);
if
(
typeof
window
!==
'undefined'
)
{
if
(
typeof
window
!==
'undefined'
)
{
window
.
sigma
=
sigma
;
window
.
sigma
=
sigma
;
}
}
const
CustomShapes
=
require
(
'sigma/plugins/garg.js'
).
init
(
sigma
,
window
).
customShapes
;
/*import('sigma/plugins/garg.js').then((module) => {
require
(
'sigma/src/utils/sigma.utils.js'
).
init
(
sigma
);
let CustomShapes = module.init(sigma, window).customShapes;
CustomShapes.init();
});
*/
//import('sigma/src/utils/sigma.utils.js').then((module) => { module.init(sigma) });
// Black circle around a node
// Black circle around a node
/*
(function() {
(function() {
var
originalDef
=
sigma
.
canvas
.
nodes
.
def
;
let
originalDef = sigma.canvas.nodes.def;
sigma.canvas.nodes.def = (node, context, settings) => {
sigma.canvas.nodes.def = (node, context, settings) => {
var
prefix
=
settings
(
'prefix'
)
||
''
;
let
prefix = settings('prefix') || '';
originalDef(node, context, settings);
originalDef(node, context, settings);
...
@@ -32,7 +40,9 @@ require('sigma/src/utils/sigma.utils.js').init(sigma);
...
@@ -32,7 +40,9 @@ require('sigma/src/utils/sigma.utils.js').init(sigma);
context.stroke();
context.stroke();
}
}
})()
})()
*/
/*
sigma.canvas.nodes.selected = (node, context, settings) => {
sigma.canvas.nodes.selected = (node, context, settings) => {
// hack
// hack
// We need to temporarily set node.type to 'def'. This is for 2 reasons
// We need to temporarily set node.type to 'def'. This is for 2 reasons
...
@@ -43,16 +53,18 @@ sigma.canvas.nodes.selected = (node, context, settings) => {
...
@@ -43,16 +53,18 @@ sigma.canvas.nodes.selected = (node, context, settings) => {
sigma.canvas.hovers.def(node, context, settings);
sigma.canvas.hovers.def(node, context, settings);
node.type = 'selected';
node.type = 'selected';
//console.log('hovers, settings:', settings);
//console.log('hovers, settings:', settings);
};
};
*/
CustomShapes
.
init
();
//
CustomShapes.init();
let
sigmaMouseSelector
=
(
sigma
,
options
)
=>
{
/*
let sigmaMouseSelector = function(sigma, options) {
sigma.plugins = sigma.plugins || {};
sigma.plugins = sigma.plugins || {};
sigma.plugins.mouseSelector = (s, renderer) => {
sigma.plugins.mouseSelector = (s, renderer) => {
var
_self
=
this
;
let
_self = this;
var
_offset
=
null
;
let
_offset = null;
const _s = s;
const _s = s;
const _renderer = renderer;
const _renderer = renderer;
const _container = _renderer.container;
const _container = _renderer.container;
...
@@ -169,6 +181,7 @@ let sigmaMouseSelector = (sigma, options) => {
...
@@ -169,6 +181,7 @@ let sigmaMouseSelector = (sigma, options) => {
}
}
sigmaMouseSelector(sigma);
sigmaMouseSelector(sigma);
*/
function
_sigma
(
left
,
right
,
opts
)
{
function
_sigma
(
left
,
right
,
opts
)
{
try
{
try
{
...
@@ -178,14 +191,14 @@ function _sigma(left, right, opts) {
...
@@ -178,14 +191,14 @@ function _sigma(left, right, opts) {
}
}
}
}
function
addRenderer
(
left
,
right
,
sigma
,
renderer
)
{
function
_
addRenderer
(
left
,
right
,
sigma
,
renderer
)
{
try
{
try
{
return
right
(
sigma
.
addRenderer
(
renderer
));
return
right
(
sigma
.
addRenderer
(
renderer
));
}
catch
(
e
)
{
}
catch
(
e
)
{
return
left
(
e
);
return
left
(
e
);
}
}
}
}
function
bindMouseSelectorPlugin
(
left
,
right
,
sig
)
{
function
_
bindMouseSelectorPlugin
(
left
,
right
,
sig
)
{
try
{
try
{
return
right
(
sigma
.
plugins
.
mouseSelector
(
sig
,
sig
.
renderers
[
0
]));
return
right
(
sigma
.
plugins
.
mouseSelector
(
sig
,
sig
.
renderers
[
0
]));
}
catch
(
e
)
{
}
catch
(
e
)
{
...
@@ -193,9 +206,9 @@ function bindMouseSelectorPlugin(left, right, sig) {
...
@@ -193,9 +206,9 @@ function bindMouseSelectorPlugin(left, right, sig) {
return
left
(
e
);
return
left
(
e
);
}
}
}
}
function
bind
(
sigma
,
event
,
handler
)
{
sigma
.
bind
(
event
,
handler
);
}
function
_
bind
(
sigma
,
event
,
handler
)
{
sigma
.
bind
(
event
,
handler
);
}
function
takeScreenshot
(
sigma
)
{
function
_
takeScreenshot
(
sigma
)
{
let
c
=
sigma
.
renderers
[
0
].
container
;
let
c
=
sigma
.
renderers
[
0
].
container
;
let
edges
=
c
.
getElementsByClassName
(
'sigma-edges'
)[
0
];
let
edges
=
c
.
getElementsByClassName
(
'sigma-edges'
)[
0
];
let
scene
=
c
.
getElementsByClassName
(
'sigma-scene'
)[
0
];
let
scene
=
c
.
getElementsByClassName
(
'sigma-scene'
)[
0
];
...
@@ -209,26 +222,26 @@ function takeScreenshot(sigma) {
...
@@ -209,26 +222,26 @@ function takeScreenshot(sigma) {
return
edges
.
toDataURL
(
'image/png'
);
return
edges
.
toDataURL
(
'image/png'
);
}
}
function
getEdges
(
sigma
)
{
function
_
getEdges
(
sigma
)
{
return
sigma
.
graph
.
edges
();
return
sigma
.
graph
.
edges
();
}
}
function
getNodes
(
sigma
)
{
function
_
getNodes
(
sigma
)
{
return
sigma
.
graph
.
nodes
();
return
sigma
.
graph
.
nodes
();
}
}
function
proxySetSettings
(
window
,
sigma
,
settings
)
{
function
_
proxySetSettings
(
window
,
sigma
,
settings
)
{
var
id
=
sigma
.
id
;
var
id
=
sigma
.
id
;
window
.
sigma
.
instances
(
id
).
settings
(
settings
);
window
.
sigma
.
instances
(
id
).
settings
(
settings
);
window
.
sigma
.
instances
(
id
).
refresh
();
window
.
sigma
.
instances
(
id
).
refresh
();
}
}
export
s
.
_sigma
=
_sigma
;
export
{
_sigma
,
exports
.
_addRenderer
=
addRenderer
;
_addRenderer
,
exports
.
_bindMouseSelectorPlugin
=
bindMouseSelectorPlugin
;
_bindMouseSelectorPlugin
,
exports
.
_bind
=
bind
;
_bind
,
exports
.
_takeScreenshot
=
takeScreenshot
;
_takeScreenshot
,
exports
.
_getEdges
=
getEdges
;
_getEdges
,
exports
.
_getNodes
=
getNodes
;
_getNodes
,
exports
.
_proxySetSettings
=
proxySetSettings
;
_proxySetSettings
}
;
src/Gargantext/Hooks/Sigmax/Sigmajs.js
View file @
5686b05c
'use strict'
;
'use strict'
;
exports
.
goToImpl
=
function
(
cam
)
{
export
function
goToImpl
(
cam
)
{
return
function
(
props
)
{
return
function
(
props
)
{
return
cam
.
goTo
(
props
);
return
cam
.
goTo
(
props
);
};
};
...
...
src/Gargantext/Hooks/StateRecord/Unboxed.purs
View file @
5686b05c
...
@@ -78,6 +78,6 @@ main stateBox = do
...
@@ -78,6 +78,6 @@ main stateBox = do
pure
pure
{ state
{ state
, stateBox
, stateBox
, setStateKey : (_ # stateBox # setter)
, setStateKey :
setter stateBox --
(_ # stateBox # setter)
, bindStateKey: (_ # stateBox # binder $ state)
, bindStateKey:
binder stateBox state --
(_ # stateBox # binder $ state)
}
}
src/Gargantext/Hooks/Version.js
View file @
5686b05c
'use strict'
;
'use strict'
;
const
pkg
=
require
(
'../../package.json'
)
;
import
pkg
from
'../../package.json'
;
exports
.
version
=
pkg
.
version
;
let
version
=
pkg
.
version
export
{
version
};
src/Gargantext/Text/BreakWords.js
View file @
5686b05c
'use strict'
;
'use strict'
;
exports
.
_wordRegex
=
/
[
a-z
]
+/gi
;
export
_wordRegex
=
/
[
a-z
]
+/gi
;
src/Gargantext/Text/BreakWords.purs
View file @
5686b05c
...
@@ -45,12 +45,12 @@ preceding :: Breaking -> Int -> String -> Maybe String
...
@@ -45,12 +45,12 @@ preceding :: Breaking -> Int -> String -> Maybe String
preceding b origin word = p $ (lastIndex b) - (length word)
preceding b origin word = p $ (lastIndex b) - (length word)
where p o
where p o
| o == origin = Nothing
| o == origin = Nothing
| otherwise = slice origin o b.source
| otherwise =
Just $
slice origin o b.source
finish :: Breaking -> Int -> Effect Boolean
finish :: Breaking -> Int -> Effect Boolean
finish b origin =
finish b origin =
do
do let last = slice origin (-1) b.source
let last = slice origin (-1) b.source :: String
traverse_ (pushSpace b)
last
pushSpace b
last
pure false
pure false
type Breaking = { source :: String, wordRegex :: Regex, results :: Array BrokenWord }
type Breaking = { source :: String, wordRegex :: Regex, results :: Array BrokenWord }
...
@@ -78,4 +78,3 @@ pushWord :: Breaking -> String -> Effect Unit
...
@@ -78,4 +78,3 @@ pushWord :: Breaking -> String -> Effect Unit
pushWord b = pushResult b <<< Word
pushWord b = pushResult b <<< Word
foreign import _wordRegex :: Regex
foreign import _wordRegex :: Regex
src/Gargantext/Utils.purs
View file @
5686b05c
...
@@ -128,5 +128,5 @@ textEllipsisBreak :: Int -> String -> String
...
@@ -128,5 +128,5 @@ textEllipsisBreak :: Int -> String -> String
textEllipsisBreak len n =
textEllipsisBreak len n =
if S.length n < len then n
if S.length n < len then n
else case (slice 0 len n) of
else case (slice 0 len n) of
Nothing
-> "???"
""
-> "???"
Just
s -> s <> "…"
s -> s <> "…"
src/Gargantext/Utils/Argonaut.purs
View file @
5686b05c
...
@@ -8,7 +8,8 @@ import Data.Argonaut as Argonaut
...
@@ -8,7 +8,8 @@ import Data.Argonaut as Argonaut
import Data.Argonaut.Decode.Error (JsonDecodeError(..))
import Data.Argonaut.Decode.Error (JsonDecodeError(..))
import Data.Either (Either(..))
import Data.Either (Either(..))
import Data.Generic.Rep as GR
import Data.Generic.Rep as GR
import Data.Symbol (class IsSymbol, SProxy(..), reflectSymbol)
import Data.Symbol (class IsSymbol, reflectSymbol)
import Type.Proxy (Proxy(..))
-- | Provide a generic sum JSON decoding for sum types deriving Generic
-- | Provide a generic sum JSON decoding for sum types deriving Generic
genericSumDecodeJson
genericSumDecodeJson
...
@@ -51,7 +52,7 @@ instance
...
@@ -51,7 +52,7 @@ instance
genericSumDecodeJsonRep f = do
genericSumDecodeJsonRep f = do
-- here we attempt to read the following json:
-- here we attempt to read the following json:
-- { "ConstructorName": argument }
-- { "ConstructorName": argument }
let name = reflectSymbol (
S
Proxy :: _ name)
let name = reflectSymbol (Proxy :: _ name)
obj <- Argonaut.decodeJson f
obj <- Argonaut.decodeJson f
inner <- Argonaut.getField obj name
inner <- Argonaut.getField obj name
argument <- genericSumDecodeJsonRep inner
argument <- genericSumDecodeJsonRep inner
...
@@ -81,7 +82,7 @@ instance
...
@@ -81,7 +82,7 @@ instance
genericSumEncodeJsonRep (GR.Constructor inner) = do
genericSumEncodeJsonRep (GR.Constructor inner) = do
-- here we attempt to write the following json:
-- here we attempt to write the following json:
-- { "ConstructorName": argument }
-- { "ConstructorName": argument }
let name = reflectSymbol (
S
Proxy :: _ name)
let name = reflectSymbol (Proxy :: _ name)
let argument = genericSumEncodeJsonRep inner
let argument = genericSumEncodeJsonRep inner
Argonaut.jsonSingletonObject name argument
Argonaut.jsonSingletonObject name argument
...
@@ -123,7 +124,7 @@ instance
...
@@ -123,7 +124,7 @@ instance
then pure $ GR.Constructor GR.NoArguments
then pure $ GR.Constructor GR.NoArguments
else Left $ Named s $ TypeMismatch $ "Enum did not match expected string " <> name
else Left $ Named s $ TypeMismatch $ "Enum did not match expected string " <> name
where
where
name = reflectSymbol (
SProxy :: S
Proxy name)
name = reflectSymbol (
Proxy ::
Proxy name)
genericEnumEncodeJson :: forall a rep
genericEnumEncodeJson :: forall a rep
. GR.Generic a rep
. GR.Generic a rep
...
@@ -147,4 +148,4 @@ instance
...
@@ -147,4 +148,4 @@ instance
instance
instance
( IsSymbol name
( IsSymbol name
) => GenericEnumEncodeJson (GR.Constructor name GR.NoArguments) where
) => GenericEnumEncodeJson (GR.Constructor name GR.NoArguments) where
genericEnumEncodeJsonRep _ = Argonaut.encodeJson $ reflectSymbol (
SProxy :: S
Proxy name)
genericEnumEncodeJsonRep _ = Argonaut.encodeJson $ reflectSymbol (
Proxy ::
Proxy name)
src/Gargantext/Utils/Array.js
View file @
5686b05c
function
_push
(
a
,
i
)
{
export
function
_push
(
a
,
i
)
{
a
.
push
(
i
);
a
.
push
(
i
);
}
}
exports
.
_push
=
_push
;
src/Gargantext/Utils/Array.purs
View file @
5686b05c
...
@@ -36,4 +36,4 @@ min xs = foldr reducer (A.head xs) xs
...
@@ -36,4 +36,4 @@ min xs = foldr reducer (A.head xs) xs
range :: Int -> Int -> Int -> Array Int
range :: Int -> Int -> Int -> Array Int
range start end step = map (\i -> start + i*step) $ A.range 0 end'
range start end step = map (\i -> start + i*step) $ A.range 0 end'
where
where
end' = DI.
round $ DI.
floor $ (DI.toNumber $ end - start) / (DI.toNumber step)
end' = DI.floor $ (DI.toNumber $ end - start) / (DI.toNumber step)
src/Gargantext/Utils/ArrayBuffer.js
View file @
5686b05c
...
@@ -2,7 +2,7 @@
...
@@ -2,7 +2,7 @@
// https://stackoverflow.com/a/9458996
// https://stackoverflow.com/a/9458996
// This is because base64-codec/Data.Base64.encodeBase64 was too slow
// This is because base64-codec/Data.Base64.encodeBase64 was too slow
export
s
.
arrayBufferToBase64Impl
=
function
(
buffer
)
{
export
function
arrayBufferToBase64Impl
(
buffer
)
{
var
binary
=
''
;
var
binary
=
''
;
var
bytes
=
new
Uint8Array
(
buffer
);
var
bytes
=
new
Uint8Array
(
buffer
);
var
len
=
bytes
.
byteLength
;
var
len
=
bytes
.
byteLength
;
...
...
src/Gargantext/Utils/BootstrapNative.js
View file @
5686b05c
"use strict"
;
"use strict"
;
export
s
.
createDropdown
=
functio
n
(
iid
)
{
export
function
createDropdow
n
(
iid
)
{
var
el
=
document
.
getElementById
(
iid
);
var
el
=
document
.
getElementById
(
iid
);
if
(
!
window
.
Dropdown
)
return
;
if
(
!
window
.
Dropdown
)
return
;
...
...
src/Gargantext/Utils/CacheAPI.js
View file @
5686b05c
export
s
.
_makeRequest
=
function
(
url
)
{
export
function
_makeRequest
(
url
)
{
return
function
(
options
)
{
return
function
(
options
)
{
return
new
Request
(
url
,
options
);
return
new
Request
(
url
,
options
);
}
}
}
}
export
s
.
_openCache
=
function
(
cacheName
)
{
export
function
_openCache
(
cacheName
)
{
return
function
()
{
return
function
()
{
return
window
.
caches
.
open
(
cacheName
);
return
window
.
caches
.
open
(
cacheName
);
}
}
}
}
export
s
.
_delete
=
function
(
cacheName
)
{
export
function
_delete
(
cacheName
)
{
return
function
()
{
return
function
()
{
return
caches
.
delete
(
cacheName
);
return
caches
.
delete
(
cacheName
);
}
}
}
}
export
s
.
_deleteReq
=
function
(
cache
)
{
export
function
_deleteReq
(
cache
)
{
return
function
(
req
)
{
return
function
(
req
)
{
return
function
()
{
return
function
()
{
return
cache
.
delete
(
req
);
return
cache
.
delete
(
req
);
...
@@ -24,7 +24,7 @@ exports._deleteReq = function(cache) {
...
@@ -24,7 +24,7 @@ exports._deleteReq = function(cache) {
}
}
}
}
export
s
.
_add
=
function
(
cache
)
{
export
function
_add
(
cache
)
{
return
function
(
req
)
{
return
function
(
req
)
{
return
function
()
{
return
function
()
{
return
cache
.
add
(
req
);
return
cache
.
add
(
req
);
...
@@ -32,7 +32,7 @@ exports._add = function(cache) {
...
@@ -32,7 +32,7 @@ exports._add = function(cache) {
}
}
}
}
export
s
.
_match
=
function
(
cache
)
{
export
function
_match
(
cache
)
{
return
function
(
req
)
{
return
function
(
req
)
{
return
function
()
{
return
function
()
{
return
cache
.
match
(
req
);
return
cache
.
match
(
req
);
...
@@ -40,7 +40,7 @@ exports._match = function(cache) {
...
@@ -40,7 +40,7 @@ exports._match = function(cache) {
}
}
}
}
export
s
.
_fetch
=
function
(
req
)
{
export
function
_fetch
(
req
)
{
return
function
()
{
return
function
()
{
return
fetch
(
req
);
return
fetch
(
req
);
}
}
...
...
src/Gargantext/Utils/Console.js
View file @
5686b05c
...
@@ -3,6 +3,6 @@
...
@@ -3,6 +3,6 @@
* Get Creation Date
* Get Creation Date
* @return {string}
* @return {string}
*/
*/
export
s
.
getCreationDate
=
function
()
{
export
function
getCreationDate
()
{
return
new
Date
().
toLocaleTimeString
()
return
new
Date
().
toLocaleTimeString
()
}
}
src/Gargantext/Utils/Crypto.purs
View file @
5686b05c
...
@@ -34,5 +34,3 @@ instance IsHashable (Set String) where
...
@@ -34,5 +34,3 @@ instance IsHashable (Set String) where
concat :: Array Hash -> String
concat :: Array Hash -> String
concat = Array.foldl (<>) ""
concat = Array.foldl (<>) ""
src/Gargantext/Utils/Debug.js
View file @
5686b05c
function
_debugger
(
a
)
{
export
function
_debugger
(
a
)
{
debugger
;
debugger
;
}
}
exports
.
_debugger
=
_debugger
;
src/Gargantext/Utils/EtherCalc.purs
View file @
5686b05c
module Gargantext.Utils.EtherCalc where
module Gargantext.Utils.EtherCalc where
import Affjax (Error, Response, defaultRequest, request)
import Affjax
.Web
(Error, Response, defaultRequest, request)
import Affjax.ResponseFormat as ResponseFormat
import Affjax.ResponseFormat as ResponseFormat
import Data.Either (Either(..))
import Data.Either (Either(..))
import Data.HTTP.Method (Method(GET))
import Data.HTTP.Method (Method(GET))
...
@@ -17,4 +17,3 @@ downloadCSV base nodeId = do
...
@@ -17,4 +17,3 @@ downloadCSV base nodeId = do
, responseFormat = ResponseFormat.string
, responseFormat = ResponseFormat.string
, method = Left GET }
, method = Left GET }
request req
request req
src/Gargantext/Utils/HighlightJS.js
View file @
5686b05c
'use strict'
;
'use strict'
;
const
hljs
=
require
(
'highlightjs/highlight.pack.min.js'
)
;
import
*
as
hljs
from
'highlightjs/highlight.pack.min.js'
;
function
highlightBlock
(
el
)
{
export
function
_
highlightBlock
(
el
)
{
hljs
.
highlightBlock
(
el
);
hljs
.
highlightBlock
(
el
);
}
}
exports
.
_highlightBlock
=
highlightBlock
;
src/Gargantext/Utils/JitsiMeet.js
View file @
5686b05c
'use strict'
;
'use strict'
;
var
API
=
require
(
'../../src/external-deps/JitsiMeetAPI.js'
)
;
import
API
from
'../../src/external-deps/JitsiMeetAPI.js'
;
// console.log('API', API);
// console.log('API', API);
export
s
.
_api
=
API
;
export
{
API
as
_api
}
;
export
s
.
_jitsiMeetAPI
=
function
(
host
,
options
)
{
export
function
_jitsiMeetAPI
(
host
,
options
)
{
return
new
API
(
host
,
options
);
return
new
API
(
host
,
options
);
};
};
src/Gargantext/Utils/KarpRabin.purs
View file @
5686b05c
...
@@ -26,6 +26,7 @@ module Gargantext.Utils.KarpRabin ( -- * Overview
...
@@ -26,6 +26,7 @@ module Gargantext.Utils.KarpRabin ( -- * Overview
import Data.Array as A
import Data.Array as A
import Data.Enum (fromEnum)
import Data.Enum (fromEnum)
import Data.Foldable (class Foldable, minimum, foldl)
import Data.Foldable (class Foldable, minimum, foldl)
import Data.FunctorWithIndex (mapWithIndex)
import Data.Int (quot)
import Data.Int (quot)
import Data.List as L
import Data.List as L
import Data.Map as M
import Data.Map as M
...
@@ -139,7 +140,7 @@ strictMatcher pats = unsafePartial search
...
@@ -139,7 +140,7 @@ strictMatcher pats = unsafePartial search
<<< S.take hLen
<<< S.take hLen
hashMap =
hashMap =
M.fromFoldableWith (flip (<>))
M.fromFoldableWith (flip (<>))
(
A.
mapWithIndex (\i a -> Tuple (hash a) [i]) pats)
(mapWithIndex (\i a -> Tuple (hash a) [i]) pats)
search :: Partial => String -> Array (Tuple Int (Array Int))
search :: Partial => String -> Array (Tuple Int (Array Int))
search str = if strLen < hLen then []
search str = if strLen < hLen then []
else A.fromFoldable (go 0 shash)
else A.fromFoldable (go 0 shash)
...
...
src/Gargantext/Utils/Popover.js
View file @
5686b05c
'use strict'
;
'use strict'
;
const
popover
=
require
(
'react-awesome-popover'
)
;
import
popover
from
'react-awesome-popover'
;
if
(
typeof
window
!==
'undefined'
)
{
if
(
typeof
window
!==
'undefined'
)
{
window
.
Popover
=
popover
;
window
.
Popover
=
popover
;
}
}
export
s
.
popoverCpt
=
popover
;
export
{
popover
as
popoverCpt
}
;
export
s
.
_setState
=
function
(
el
,
val
)
{
export
function
_setState
(
el
,
val
)
{
el
.
setState
(
val
);
el
.
setState
(
val
);
}
}
src/Gargantext/Utils/Range.purs
View file @
5686b05c
...
@@ -45,4 +45,3 @@ withMin (Closed {max}) min = Closed { min, max }
...
@@ -45,4 +45,3 @@ withMin (Closed {max}) min = Closed { min, max }
-- | Updates the maximum value in a closed range
-- | Updates the maximum value in a closed range
withMax :: forall t. Closed t -> t -> Closed t
withMax :: forall t. Closed t -> t -> Closed t
withMax (Closed {min}) max = Closed { min, max }
withMax (Closed {min}) max = Closed { min, max }
src/Gargantext/Utils/ReactBootstrap.js
View file @
5686b05c
'use strict'
;
'use strict'
;
const
ReactBootstrap
=
require
(
'react-bootstrap'
)
;
import
*
as
ReactBootstrap
from
'react-bootstrap'
;
if
(
typeof
window
!==
'undefined'
)
{
if
(
typeof
window
!==
'undefined'
)
{
window
.
ReactBootstrap
=
ReactBootstrap
;
window
.
ReactBootstrap
=
ReactBootstrap
;
}
}
const
Alert
=
require
(
'react-bootstrap/Alert'
)
;
import
*
as
Alert
from
'react-bootstrap/Alert'
;
const
OverlayTrigger
=
require
(
'react-bootstrap/OverlayTrigger'
)
;
import
*
as
OverlayTrigger
from
'react-bootstrap/OverlayTrigger'
;
const
Popover
=
require
(
'react-bootstrap/Popover'
)
;
import
*
as
Popover
from
'react-bootstrap/Popover'
;
exports
.
alertCpt
=
Alert
;
let
Content
=
Popover
.
Content
;
exports
.
overlayTriggerCpt
=
OverlayTrigger
;
let
Title
=
Popover
.
Title
;
exports
.
popoverCpt
=
Popover
;
exports
.
popoverContentCpt
=
Popover
.
Content
;
export
{
Alert
as
alertCpt
,
exports
.
popoverTitleCpt
=
Popover
.
Title
;
OverlayTrigger
as
overlayTriggerCpt
,
Popover
as
popoverCpt
,
Content
as
popoverContentCpt
,
Title
as
popoverTitleCpt
};
src/Gargantext/Utils/Reactix.js
View file @
5686b05c
'use strict'
;
'use strict'
;
function
addRootElement
(
rootElem
)
{
export
function
_
addRootElement
(
rootElem
)
{
document
.
body
.
insertBefore
(
document
.
body
.
insertBefore
(
rootElem
,
rootElem
,
document
.
body
.
lastElementChild
.
nextElementSibling
document
.
body
.
lastElementChild
.
nextElementSibling
);
);
}
}
function
getSelection
(
_u
)
{
export
function
_
getSelection
(
_u
)
{
return
window
.
getSelection
();
return
window
.
getSelection
();
}
}
function
stringify
(
j
,
indent
)
{
export
function
_
stringify
(
j
,
indent
)
{
return
JSON
.
stringify
(
j
,
null
,
indent
);
return
JSON
.
stringify
(
j
,
null
,
indent
);
}
}
function
postMessage
(
obj
,
msg
,
src
)
{
export
function
_
postMessage
(
obj
,
msg
,
src
)
{
obj
.
contentWindow
.
postMessage
(
msg
,
src
);
obj
.
contentWindow
.
postMessage
(
msg
,
src
);
}
}
function
setCookie
(
c
)
{
export
function
_
setCookie
(
c
)
{
document
.
cookie
=
c
;
document
.
cookie
=
c
;
}
}
function
domRectFromRect
(
obj
)
{
export
function
_
domRectFromRect
(
obj
)
{
return
DOMRectReadOnly
.
fromRect
(
obj
)
return
DOMRectReadOnly
.
fromRect
(
obj
)
}
}
function
preventDefault
(
e
)
{
export
function
_
preventDefault
(
e
)
{
return
e
.
preventDefault
();
return
e
.
preventDefault
();
}
}
function
stopPropagation
(
e
)
{
export
function
_
stopPropagation
(
e
)
{
return
e
.
stopPropagation
();
return
e
.
stopPropagation
();
}
}
function
blur
(
el
)
{
export
function
_
blur
(
el
)
{
return
el
.
blur
();
return
el
.
blur
();
}
}
function
triggerEvent
(
el
,
evtType
)
{
export
function
_
triggerEvent
(
el
,
evtType
)
{
// https://stackoverflow.com/questions/8789423/trigger-onchange-event
// https://stackoverflow.com/questions/8789423/trigger-onchange-event
var
event
=
new
UIEvent
(
evtType
,
{
var
event
=
new
UIEvent
(
evtType
,
{
view
:
window
,
view
:
window
,
...
@@ -49,18 +49,7 @@ function triggerEvent(el, evtType) {
...
@@ -49,18 +49,7 @@ function triggerEvent(el, evtType) {
el
.
dispatchEvent
(
event
);
el
.
dispatchEvent
(
event
);
}
}
exports
.
_addRootElement
=
addRootElement
;
export
function
_keyCode
(
e
)
{
exports
.
_getSelection
=
getSelection
;
exports
.
_stringify
=
stringify
;
exports
.
_postMessage
=
postMessage
;
exports
.
_setCookie
=
setCookie
;
exports
.
_domRectFromRect
=
domRectFromRect
;
exports
.
_preventDefault
=
preventDefault
;
exports
.
_stopPropagation
=
stopPropagation
;
exports
.
_blur
=
blur
;
exports
.
_keyCode
=
function
(
e
)
{
// https://www.w3schools.com/jsref/event_key_keycode.asp
// https://www.w3schools.com/jsref/event_key_keycode.asp
return
e
.
which
||
e
.
keyCode
;
return
e
.
which
||
e
.
keyCode
;
}
}
exports
.
_triggerEvent
=
triggerEvent
;
src/Gargantext/Utils/Regex.js
View file @
5686b05c
function
_cloneRegex
(
r
)
{
export
function
_cloneRegex
(
r
)
{
return
new
RegExp
(
r
.
source
,
r
.
flags
);
return
new
RegExp
(
r
.
source
,
r
.
flags
);
}
}
function
_getRegexLastIndex
(
r
)
{
export
function
_getRegexLastIndex
(
r
)
{
return
r
.
lastIndex
;
return
r
.
lastIndex
;
}
}
function
_execRegex
(
r
,
s
)
{
export
function
_execRegex
(
r
,
s
)
{
return
r
.
exec
(
s
);
return
r
.
exec
(
s
);
}
}
exports
.
_cloneRegex
=
_cloneRegex
;
exports
.
_getRegexLastIndex
=
_getRegexLastIndex
;
exports
.
_execRegex
=
_execRegex
;
src/Gargantext/Utils/Selection.js
View file @
5686b05c
exports
.
_getSelection
=
function
()
{
return
window
.
getSelection
()
||
null
;
};
export
function
_getSelection
()
{
return
window
.
getSelection
()
||
null
;
};
src/Gargantext/Utils/SimpleJSON.purs
View file @
5686b05c
...
@@ -11,7 +11,8 @@ import Foreign (Foreign, ForeignError(..), fail)
...
@@ -11,7 +11,8 @@ import Foreign (Foreign, ForeignError(..), fail)
import Foreign as Foreign
import Foreign as Foreign
import Foreign.Object as FO
import Foreign.Object as FO
import Simple.JSON as JSON
import Simple.JSON as JSON
import Type.Prelude (class IsSymbol, SProxy(..), reflectSymbol)
import Type.Prelude (class IsSymbol, reflectSymbol)
import Type.Proxy (Proxy(..))
taggedSumRep :: forall a rep
taggedSumRep :: forall a rep
. GR.Generic a rep
. GR.Generic a rep
...
@@ -51,7 +52,7 @@ instance ( GenericTaggedSumRep a
...
@@ -51,7 +52,7 @@ instance ( GenericTaggedSumRep a
then withExcept (map $ ErrorAtProperty name) $ GR.Constructor <$> (genericTaggedSumRep $ Foreign.unsafeToForeign obj)
then withExcept (map $ ErrorAtProperty name) $ GR.Constructor <$> (genericTaggedSumRep $ Foreign.unsafeToForeign obj)
else fail $ ForeignError $ "Wrong type tag " <> n' <> " where " <> name <> " was expected."
else fail $ ForeignError $ "Wrong type tag " <> n' <> " where " <> name <> " was expected."
where
where
nameP =
SProxy :: S
Proxy name
nameP =
Proxy ::
Proxy name
name = reflectSymbol nameP
name = reflectSymbol nameP
instance ( JSON.ReadForeign a
instance ( JSON.ReadForeign a
...
...
src/Gargantext/Utils/String.js
View file @
5686b05c
export
s
.
_btoa
=
function
(
s
)
{
export
function
_btoa
(
s
)
{
return
btoa
(
unescape
(
encodeURIComponent
(
s
)));
return
btoa
(
unescape
(
encodeURIComponent
(
s
)));
}
}
yarn.lock
View file @
5686b05c
This diff is collapsed.
Click to expand it.
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