Commit 1617d817 authored by Przemyslaw Kaminski's avatar Przemyslaw Kaminski

Merge branch '719-dev-clipboard-copy-improvements' into 'dev'

Resolve "Share link copy to clipboard"

See merge request !512
parents 5491ae2b 6fc48dda
Pipeline #7689 passed with stages
in 30 minutes and 30 seconds
...@@ -11126,6 +11126,10 @@ select.form-control { ...@@ -11126,6 +11126,10 @@ select.form-control {
margin: 0.33em; margin: 0.33em;
} }
.copy-btn {
margin-left: 0.5em;
}
.table tr td { .table tr td {
height: 48px; height: 48px;
} }
......
...@@ -10932,6 +10932,10 @@ select.form-control { ...@@ -10932,6 +10932,10 @@ select.form-control {
margin: 0.33em; margin: 0.33em;
} }
.copy-btn {
margin-left: 0.5em;
}
.table tr td { .table tr td {
height: 48px; height: 48px;
} }
......
...@@ -10777,6 +10777,10 @@ select.form-control { ...@@ -10777,6 +10777,10 @@ select.form-control {
margin: 0.33em; margin: 0.33em;
} }
.copy-btn {
margin-left: 0.5em;
}
.table tr td { .table tr td {
height: 48px; height: 48px;
} }
......
...@@ -11002,6 +11002,10 @@ select.form-control { ...@@ -11002,6 +11002,10 @@ select.form-control {
margin: 0.33em; margin: 0.33em;
} }
.copy-btn {
margin-left: 0.5em;
}
.table tr td { .table tr td {
height: 48px; height: 48px;
} }
......
...@@ -11075,6 +11075,10 @@ select.form-control { ...@@ -11075,6 +11075,10 @@ select.form-control {
margin: 0.33em; margin: 0.33em;
} }
.copy-btn {
margin-left: 0.5em;
}
.table tr td { .table tr td {
height: 48px; height: 48px;
} }
......
module Gargantext.Components.Forest.Tree.Node.Action.Share where module Gargantext.Components.Forest.Tree.Node.Action.Share where
import Gargantext.Prelude
import Data.Array (filter, nub) import Data.Array (filter, nub)
import Data.Either (Either(..)) import Data.Either (Either(..))
import Data.Generic.Rep (class Generic) import Data.Generic.Rep (class Generic)
...@@ -9,6 +11,7 @@ import Data.String (Pattern(..), contains) ...@@ -9,6 +11,7 @@ import Data.String (Pattern(..), contains)
import Data.Tuple.Nested ((/\)) import Data.Tuple.Nested ((/\))
import Effect.Aff (launchAff_) import Effect.Aff (launchAff_)
import Effect.Class (liftEffect) import Effect.Class (liftEffect)
import Effect.Timer (setTimeout)
import Gargantext.Components.Bootstrap as B import Gargantext.Components.Bootstrap as B
import Gargantext.Components.Bootstrap.Types (Elevation(Level1)) import Gargantext.Components.Bootstrap.Types (Elevation(Level1))
import Gargantext.Components.Forest.Tree.Node.Action.Types as Action import Gargantext.Components.Forest.Tree.Node.Action.Types as Action
...@@ -17,14 +20,13 @@ import Gargantext.Components.Forest.Tree.Node.Tools.SubTree (subTreeView, SubTre ...@@ -17,14 +20,13 @@ import Gargantext.Components.Forest.Tree.Node.Tools.SubTree (subTreeView, SubTre
import Gargantext.Components.InputWithAutocomplete (inputWithAutocomplete) import Gargantext.Components.InputWithAutocomplete (inputWithAutocomplete)
import Gargantext.Config.REST (AffRESTError) import Gargantext.Config.REST (AffRESTError)
import Gargantext.Hooks.Loader (useLoader) import Gargantext.Hooks.Loader (useLoader)
import Gargantext.Prelude
import Gargantext.Routes as GR import Gargantext.Routes as GR
import Gargantext.Sessions (Session, get, post) import Gargantext.Sessions (Session, get, post)
import Gargantext.Types (ID, NodeID, NodeType) import Gargantext.Types (ID, NodeID, NodeType)
import Gargantext.Types as GT import Gargantext.Types as GT
import Gargantext.Utils.Clipboard (modalClipboard)
import Gargantext.Utils.Reactix as R2 import Gargantext.Utils.Reactix as R2
import Gargantext.Utils.SimpleJSON as GUSJ import Gargantext.Utils.SimpleJSON as GUSJ
import Gargantext.Utils.Clipboard (modalClipboard)
import Reactix as R import Reactix as R
import Reactix.DOM.HTML as H import Reactix.DOM.HTML as H
import Simple.JSON as JSON import Simple.JSON as JSON
...@@ -197,23 +199,31 @@ shareURLcpt :: R.Component ShareURL ...@@ -197,23 +199,31 @@ shareURLcpt :: R.Component ShareURL
shareURLcpt = R2.hereComponent here "shareURL" hCpt shareURLcpt = R2.hereComponent here "shareURL" hCpt
where where
hCpt hp { nodeType, id, session } _ = do hCpt hp { nodeType, id, session } _ = do
copied <- T.useBox false
useLoader useLoader
{ errorHandler: Just errorHandler { errorHandler: Just errorHandler
, herePrefix: hp , herePrefix: hp
, loader: loadUrl , loader: loadUrl
, path: { nodeType, id, session } , path: { nodeType, id, session }
, render: \url -> shareURLInner { url } [] , render: \url -> shareURLInner { url, copied } []
} }
errorHandler err = here.warn2 "[ShareURL] RESTError" err errorHandler err = here.warn2 "[ShareURL] RESTError" err
shareURLInner :: R2.Component (url :: String) type ShareURLInnerProps =
( url :: String
, copied :: T.Box Boolean
)
shareURLInner :: R2.Component ShareURLInnerProps
shareURLInner = R.createElement shareURLInnercpt shareURLInner = R.createElement shareURLInnercpt
shareURLInnercpt :: R.Component (url :: String) shareURLInnercpt :: R.Component ShareURLInnerProps
shareURLInnercpt = here.component "shareURLInner" cpt shareURLInnercpt = here.component "shareURLInner" cpt
where where
cpt { url } _ = do cpt { url, copied } _ = do
R.useEffect' $ modalClipboard ".copy" url R.useEffect' $ modalClipboard ".copy" url
copied' <- T.useLive T.unequal copied
pure $ Tools.panelNoFooter pure $ Tools.panelNoFooter
{ mError: Nothing { mError: Nothing
...@@ -221,12 +231,15 @@ shareURLInnercpt = here.component "shareURLInner" cpt ...@@ -221,12 +231,15 @@ shareURLInnercpt = here.component "shareURLInner" cpt
, textTitle: "Share the node (URL)" , textTitle: "Share the node (URL)"
} }
[ H.div {} [ H.div {}
[ H.text url [ H.a { href: url } [ H.text url ]
, B.iconButton , B.iconButton
{ name: "clone" { name: if copied' then "check" else "copy"
, title: "Copy to clipboard" , title: if copied' then "Copied" else "Copy to clipboard"
, className: "copy" , className: "copy copy-btn"
, callback: \_ -> pure unit , callback: \_ -> do
T.write_ true copied
_ <- setTimeout 2000 (T.write_ false copied)
pure unit
} }
] ]
] ]
......
...@@ -503,3 +503,7 @@ select.form-control { ...@@ -503,3 +503,7 @@ select.form-control {
margin: 0.33em; margin: 0.33em;
} }
} }
.copy-btn {
margin-left: 0.5em;
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment