Renameable.purs 3.14 KB
Newer Older
1 2 3 4 5
module Gargantext.Components.Renameable where

import Effect (Effect)
import Reactix as R
import Reactix.DOM.HTML as H
6
import Toestand as T
7 8 9 10 11 12 13

import Gargantext.Prelude

import Gargantext.Components.InputWithEnter (inputWithEnter)
import Gargantext.Utils.Reactix as R2


14 15
here :: R2.Here
here = R2.here "Gargantext.Components.Renameable"
16 17 18 19

type RenameableProps =
  (
    onRename :: String -> Effect Unit
20
  , text     :: String
21 22
  )

23 24
renameable :: R2.Component RenameableProps
renameable = R.createElement renameableCpt
25
renameableCpt :: R.Component RenameableProps
26
renameableCpt = here.component "renameableCpt" cpt
27
  where
28 29 30
    cpt { onRename, text } _ = do
      isEditing <- T.useBox false
      state <- T.useBox text
31 32 33 34 35 36 37 38
      textRef <- R.useRef text

      -- handle props change of text
      R.useEffect1' text $ do
        if R.readRef textRef == text then
          pure unit
        else do
          R.setRef textRef text
39
          T.write_ text state
40 41

      pure $ H.div { className: "renameable" } [
42
        renameableText { isEditing, onRename, state } []
43 44 45 46
      ]

type RenameableTextProps =
  (
47 48 49
    isEditing :: T.Box Boolean
  , onRename  :: String -> Effect Unit
  , state     :: T.Box String
50 51
  )

52 53
renameableText :: R2.Component RenameableTextProps
renameableText = R.createElement renameableTextCpt
54
renameableTextCpt :: R.Component RenameableTextProps
55
renameableTextCpt = here.component "renameableText" cpt
56
  where
57
    cpt props@{ isEditing } _ = do
58 59 60 61 62 63 64 65 66 67 68 69 70
      isEditing' <- T.useLive T.unequal isEditing

      pure $ if isEditing' then
               notEditing props []
             else
               editing props []


notEditing :: R2.Component RenameableTextProps
notEditing = R.createElement notEditingCpt
notEditingCpt :: R.Component RenameableTextProps
notEditingCpt = here.component "notEditing" cpt
  where
71
    cpt { isEditing, state } _ = do
72 73
      state' <- T.useLive T.unequal state

74 75
      pure $ H.div { className: "input-group" }
        [ H.input { className: "form-control"
76
                  , defaultValue: state'
77 78 79
                  , disabled: 1
                  , type: "text" }
        , H.div { className: "btn input-group-append"
80
                , on: { click: \_ -> T.write_ true isEditing } }
81 82 83
          [ H.span { className: "fa fa-pencil" } []
          ]
        ]
84 85 86 87 88 89 90


editing :: R2.Component RenameableTextProps
editing = R.createElement editingCpt
editingCpt :: R.Component RenameableTextProps
editingCpt = here.component "editing" cpt
  where
91
    cpt { isEditing, onRename, state } _ = do
92 93
      state' <- T.useLive T.unequal state

94 95 96 97
      pure $ H.div { className: "input-group" }
        [ inputWithEnter {
            autoFocus: false
          , className: "form-control text"
98 99 100 101
          , defaultValue: state'
          , onBlur: \s -> T.write_ s state
          , onEnter: submit state'
          , onValueChanged: \s -> T.write_ s state
102 103 104 105 106 107 108 109 110
          , placeholder: ""
          , type: "text"
          }
        , H.div { className: "btn input-group-append"
                , on: { click: submit } }
          [ H.span { className: "fa fa-floppy-o" } []
          ]
        ]
      where
111 112
        submit text _ = do
          T.write_ false isEditing
113
          onRename text