Merge pull request #258 from status-im/bug/#243
More clear validation message in "Add new contact" form (#243)
Former-commit-id: c0cc465070
This commit is contained in:
commit
8643a1eb2a
|
@ -176,7 +176,8 @@
|
|||
:to-line-width 0}
|
||||
:onBlur on-blur})
|
||||
:on-change-text #(on-change-text %)
|
||||
:on-change #(on-change %)} value]
|
||||
:on-change #(on-change %)
|
||||
:default-value value}]
|
||||
[view {:style (st/underline-container line-color)
|
||||
:onLayout #(r/set-state component {:max-line-width (get-width %)})}
|
||||
[animated-view {:style (st/underline focus-line-color line-width)}]]
|
||||
|
|
|
@ -178,3 +178,6 @@
|
|||
:right 0
|
||||
:width 200
|
||||
:height 170})
|
||||
|
||||
(def qr-input
|
||||
{:margin-right 42})
|
||||
|
|
|
@ -28,8 +28,7 @@
|
|||
[status-im.i18n :refer [label]]
|
||||
[cljs.spec :as s]
|
||||
[status-im.contacts.validations :as v]
|
||||
[status-im.contacts.styles :as st]
|
||||
[status-im.components.styles :as cst]))
|
||||
[status-im.contacts.styles :as st]))
|
||||
|
||||
|
||||
(def toolbar-title
|
||||
|
@ -53,29 +52,32 @@
|
|||
:photo-path (identicon id)
|
||||
:whisper-identity id}])))
|
||||
|
||||
(defn- validation-error-message [whisper-identity error]
|
||||
(cond
|
||||
(not (s/valid? ::v/unique-identity whisper-identity)) (label :t/contact-already-added)
|
||||
(not (s/valid? ::v/whisper-identity whisper-identity)) (label :t/enter-valid-address)
|
||||
:else error))
|
||||
|
||||
(defn toolbar-action [new-contact-identity error]
|
||||
(let [valid-contact? (and
|
||||
(s/valid? ::v/whisper-identity new-contact-identity)
|
||||
(nil? error))]
|
||||
{:image {:source {:uri (if valid-contact?
|
||||
(let [error-message (validation-error-message new-contact-identity error)]
|
||||
{:image {:source {:uri (if (str/blank? error-message)
|
||||
:icon_ok_blue
|
||||
:icon_ok_disabled)}
|
||||
:style icon-search}
|
||||
:handler #(when valid-contact?
|
||||
:handler #(when (str/blank? error-message)
|
||||
(on-add-contact new-contact-identity))}))
|
||||
|
||||
(defview contact-whisper-id-input [whisper-identity error]
|
||||
[]
|
||||
(let [error (if (str/blank? whisper-identity) "" error)
|
||||
error (if (s/valid? ::v/whisper-identity whisper-identity)
|
||||
error
|
||||
(label :t/enter-valid-address))]
|
||||
(let [error (when-not (str/blank? whisper-identity)
|
||||
(validation-error-message whisper-identity error))]
|
||||
[view button-input-container
|
||||
[text-field
|
||||
{:error error
|
||||
:error-color "#7099e6"
|
||||
:input-style st/qr-input
|
||||
:value whisper-identity
|
||||
:wrapper-style (merge button-input)
|
||||
:wrapper-style button-input
|
||||
:label (label :t/address)
|
||||
:on-change-text #(do
|
||||
(dispatch [:set-in [:new-contact-identity] %])
|
||||
|
@ -83,6 +85,7 @@
|
|||
[scan-button {:showLabel (zero? (count whisper-identity))
|
||||
:handler #(dispatch [:scan-qr-code {:toolbar-title (label :t/new-contact)} :set-contact-identity-from-qr])}]]))
|
||||
|
||||
|
||||
(defview new-contact []
|
||||
[new-contact-identity [:get :new-contact-identity]
|
||||
error [:get :new-contact-address-error]]
|
||||
|
|
|
@ -159,6 +159,7 @@
|
|||
:whisper-identity "Whisper Identity"
|
||||
:address-explication "Maybe here should be some text explaining what an address is and where to look for it"
|
||||
:enter-valid-address "Please enter a valid address or scan a QR code"
|
||||
:contact-already-added "The contact has already been added"
|
||||
:unknown-address "Unknown address"
|
||||
|
||||
|
||||
|
|
Loading…
Reference in New Issue