Show QR in profile (#422)
BIN
android/app/src/main/res/drawable-hdpi/icon_qr_gray.png
Normal file
After Width: | Height: | Size: 2.7 KiB |
Before Width: | Height: | Size: 422 B After Width: | Height: | Size: 826 B |
BIN
android/app/src/main/res/drawable-mdpi/icon_qr_gray.png
Normal file
After Width: | Height: | Size: 1.9 KiB |
BIN
android/app/src/main/res/drawable-xhdpi/icon_qr_gray.png
Normal file
After Width: | Height: | Size: 3.5 KiB |
BIN
android/app/src/main/res/drawable-xxhdpi/icon_qr_gray.png
Normal file
After Width: | Height: | Size: 5.1 KiB |
BIN
android/app/src/main/res/drawable-xxxhdpi/icon_qr_gray.png
Normal file
After Width: | Height: | Size: 917 B |
21
ios/StatusIm/Images.xcassets/icon_qr_gray.imageset/Contents.json
vendored
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"images" : [
|
||||||
|
{
|
||||||
|
"idiom" : "universal",
|
||||||
|
"filename" : "icon_qr_gray.png",
|
||||||
|
"scale" : "1x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "universal",
|
||||||
|
"scale" : "2x"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"idiom" : "universal",
|
||||||
|
"scale" : "3x"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"info" : {
|
||||||
|
"version" : 1,
|
||||||
|
"author" : "xcode"
|
||||||
|
}
|
||||||
|
}
|
BIN
ios/StatusIm/Images.xcassets/icon_qr_gray.imageset/icon_qr_gray.png
vendored
Normal file
After Width: | Height: | Size: 5.1 KiB |
@ -20,7 +20,6 @@
|
|||||||
icon-qr
|
icon-qr
|
||||||
button-input
|
button-input
|
||||||
white-form-text-input]]
|
white-form-text-input]]
|
||||||
[status-im.qr-scanner.views.scan-button :refer [scan-button]]
|
|
||||||
[status-im.i18n :refer [label]]
|
[status-im.i18n :refer [label]]
|
||||||
[status-im.accounts.login.styles :as st]))
|
[status-im.accounts.login.styles :as st]))
|
||||||
|
|
||||||
|
28
src/status_im/components/image_button/styles.cljs
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
(ns status-im.components.image-button.styles)
|
||||||
|
|
||||||
|
(def image-button
|
||||||
|
{:position :absolute
|
||||||
|
:bottom 2
|
||||||
|
:right 16
|
||||||
|
:flex 1
|
||||||
|
:height 50
|
||||||
|
:alignItems :center})
|
||||||
|
|
||||||
|
(def image-button-content
|
||||||
|
{:flex 1
|
||||||
|
:flexDirection :row
|
||||||
|
:height 50
|
||||||
|
:alignItems :center
|
||||||
|
:alignSelf :center})
|
||||||
|
|
||||||
|
(def image-button-text
|
||||||
|
{:flex 1
|
||||||
|
:flexDirection :column
|
||||||
|
:letter-spacing -0.3
|
||||||
|
:margin-left 8})
|
||||||
|
|
||||||
|
(def scan-button-text
|
||||||
|
(merge image-button-text {:color "#7099e6"}))
|
||||||
|
|
||||||
|
(def show-qr-button-text
|
||||||
|
(merge image-button-text {:color "#838c93"}))
|
31
src/status_im/components/image_button/view.cljs
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
(ns status-im.components.image-button.view
|
||||||
|
(:require [re-frame.core :refer [subscribe dispatch dispatch-sync]]
|
||||||
|
[status-im.components.react :refer [view
|
||||||
|
text
|
||||||
|
image
|
||||||
|
touchable-highlight]]
|
||||||
|
[status-im.components.styles :refer [icon-scan]]
|
||||||
|
[status-im.i18n :refer [label]]
|
||||||
|
[status-im.components.image-button.styles :as st]))
|
||||||
|
|
||||||
|
(defn image-button [{:keys [value style icon handler]}]
|
||||||
|
[view st/image-button
|
||||||
|
[touchable-highlight {:on-press handler}
|
||||||
|
[view st/image-button-content
|
||||||
|
[image {:source {:uri (or icon :scan_blue)}
|
||||||
|
:style icon-scan}]
|
||||||
|
(when text
|
||||||
|
[text {:style style} value])]]])
|
||||||
|
|
||||||
|
(defn scan-button [{:keys [show-label? handler]}]
|
||||||
|
[image-button {:icon :scan_blue
|
||||||
|
:value (if show-label?
|
||||||
|
(label :t/scan-qr))
|
||||||
|
:style st/scan-button-text
|
||||||
|
:handler handler}])
|
||||||
|
|
||||||
|
(defn show-qr-button [{:keys [handler]}]
|
||||||
|
[image-button {:icon :icon_qr_gray
|
||||||
|
:value (label :t/show-qr)
|
||||||
|
:style st/show-qr-button-text
|
||||||
|
:handler handler}])
|
@ -20,7 +20,7 @@
|
|||||||
icon-back
|
icon-back
|
||||||
button-input-container
|
button-input-container
|
||||||
button-input]]
|
button-input]]
|
||||||
[status-im.qr-scanner.views.scan-button :refer [scan-button]]
|
[status-im.components.image-button.view :refer [scan-button]]
|
||||||
[status-im.i18n :refer [label]]
|
[status-im.i18n :refer [label]]
|
||||||
[cljs.spec :as s]
|
[cljs.spec :as s]
|
||||||
[status-im.contacts.validations :as v]
|
[status-im.contacts.validations :as v]
|
||||||
@ -90,7 +90,7 @@
|
|||||||
:on-change-text #(do
|
:on-change-text #(do
|
||||||
(dispatch [:set-in [:new-contact-identity] %])
|
(dispatch [:set-in [:new-contact-identity] %])
|
||||||
(dispatch [:set :new-contact-address-error nil]))}]
|
(dispatch [:set :new-contact-address-error nil]))}]
|
||||||
[scan-button {:showLabel (zero? (count whisper-identity))
|
[scan-button {:show-label? (zero? (count whisper-identity))
|
||||||
:handler #(dispatch [:scan-qr-code
|
:handler #(dispatch [:scan-qr-code
|
||||||
{:toolbar-title (label :t/new-contact)}
|
{:toolbar-title (label :t/new-contact)}
|
||||||
:set-contact-identity-from-qr])}]]))
|
:set-contact-identity-from-qr])}]]))
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
(defview member-menu []
|
(defview member-menu []
|
||||||
[{:keys [name] :as participant} [:selected-participant]]
|
[{:keys [name] :as participant} [:selected-participant]]
|
||||||
(when participant
|
(when participant
|
||||||
[modal {:animated false
|
[modal {:animationType :none
|
||||||
:transparent false
|
:transparent false
|
||||||
:onRequestClose close-member-menu}
|
:onRequestClose close-member-menu}
|
||||||
[touchable-highlight {:style st/modal-container
|
[touchable-highlight {:style st/modal-container
|
||||||
|
@ -9,9 +9,11 @@
|
|||||||
text-input
|
text-input
|
||||||
image
|
image
|
||||||
icon
|
icon
|
||||||
|
modal
|
||||||
scroll-view
|
scroll-view
|
||||||
touchable-highlight
|
touchable-highlight
|
||||||
touchable-opacity
|
touchable-opacity
|
||||||
|
touchable-without-feedback
|
||||||
show-image-picker
|
show-image-picker
|
||||||
dismiss-keyboard!]]
|
dismiss-keyboard!]]
|
||||||
[status-im.components.icons.custom-icons :refer [oct-icon]]
|
[status-im.components.icons.custom-icons :refer [oct-icon]]
|
||||||
@ -27,6 +29,7 @@
|
|||||||
[status-im.profile.validations :as v]
|
[status-im.profile.validations :as v]
|
||||||
[status-im.profile.styles :as st]
|
[status-im.profile.styles :as st]
|
||||||
[status-im.utils.random :refer [id]]
|
[status-im.utils.random :refer [id]]
|
||||||
|
[status-im.components.image-button.view :refer [show-qr-button]]
|
||||||
[status-im.i18n :refer [label]]))
|
[status-im.i18n :refer [label]]))
|
||||||
|
|
||||||
(defn toolbar [{:keys [account edit?]}]
|
(defn toolbar [{:keys [account edit?]}]
|
||||||
@ -161,8 +164,20 @@
|
|||||||
)}
|
)}
|
||||||
[view [text {:style st/report-user-text} (label :t/report-user)]]]]]])
|
[view [text {:style st/report-user-text} (label :t/report-user)]]]]]])
|
||||||
|
|
||||||
|
(defview qr-modal []
|
||||||
|
[qr [:get-in [:profile-edit :qr-code]]]
|
||||||
|
[modal {:transparent true
|
||||||
|
:visible (not (nil? qr))
|
||||||
|
:animationType :fade}
|
||||||
|
[touchable-without-feedback {:on-press #(dispatch [:set-in [:profile-edit :qr-code] nil])}
|
||||||
|
[view st/qr-code-container
|
||||||
|
[view st/qr-code
|
||||||
|
[qr-code {:value (str "ethereum:" qr)
|
||||||
|
:size 220}]]]]])
|
||||||
|
|
||||||
(defview my-profile []
|
(defview my-profile []
|
||||||
[edit? [:get-in [:profile-edit :edit?]]
|
[edit? [:get-in [:profile-edit :edit?]]
|
||||||
|
qr [:get-in [:profile-edit :qr-code]]
|
||||||
current-account [:get-current-account]
|
current-account [:get-current-account]
|
||||||
changed-account [:get :profile-edit]]
|
changed-account [:get :profile-edit]]
|
||||||
(let [{:keys [phone
|
(let [{:keys [phone
|
||||||
@ -171,6 +186,7 @@
|
|||||||
changed-account
|
changed-account
|
||||||
current-account)]
|
current-account)]
|
||||||
[scroll-view {:style st/profile
|
[scroll-view {:style st/profile
|
||||||
|
:bounces false
|
||||||
:keyboardShouldPersistTaps true}
|
:keyboardShouldPersistTaps true}
|
||||||
[status-bar]
|
[status-bar]
|
||||||
[toolbar {:account account
|
[toolbar {:account account
|
||||||
@ -188,16 +204,20 @@
|
|||||||
[view st/underline-container]]
|
[view st/underline-container]]
|
||||||
|
|
||||||
[view st/profile-property
|
[view st/profile-property
|
||||||
|
[view st/profile-property-row
|
||||||
|
[view st/profile-property-field
|
||||||
[selectable-field {:label (label :t/address)
|
[selectable-field {:label (label :t/address)
|
||||||
:value address}]
|
:value address}]]
|
||||||
|
[show-qr-button {:handler #(dispatch [:set-in [:profile-edit :qr-code] address])}]]
|
||||||
[view st/underline-container]]
|
[view st/underline-container]]
|
||||||
|
|
||||||
[view st/profile-property
|
[view st/profile-property
|
||||||
|
[view st/profile-property-row
|
||||||
|
[view st/profile-property-field
|
||||||
[selectable-field {:label (label :t/public-key)
|
[selectable-field {:label (label :t/public-key)
|
||||||
:value public-key}]]
|
:value public-key}]]
|
||||||
|
[show-qr-button {:handler #(dispatch [:set-in [:profile-edit :qr-code] public-key])}]]]
|
||||||
|
|
||||||
[view st/underline-container]
|
[view st/underline-container]
|
||||||
|
|
||||||
[view st/qr-code-container
|
[qr-modal]]]))
|
||||||
[qr-code {:value (str "ethereum:" public-key)
|
|
||||||
:size 220}]]]]))
|
|
||||||
|
@ -121,6 +121,14 @@
|
|||||||
(def profile-property
|
(def profile-property
|
||||||
{:margin-left 16})
|
{:margin-left 16})
|
||||||
|
|
||||||
|
(def profile-property-row
|
||||||
|
{:flex 1
|
||||||
|
:flex-direction :row})
|
||||||
|
|
||||||
|
(def profile-property-field
|
||||||
|
{:margin-right 90
|
||||||
|
:flex 1})
|
||||||
|
|
||||||
(def profile-input-wrapper
|
(def profile-input-wrapper
|
||||||
{:margin-bottom 16})
|
{:margin-bottom 16})
|
||||||
|
|
||||||
@ -145,7 +153,17 @@
|
|||||||
(def qr-code-container
|
(def qr-code-container
|
||||||
{:flex 1
|
{:flex 1
|
||||||
:alignItems :center
|
:alignItems :center
|
||||||
:margin 32})
|
:justify-content :center
|
||||||
|
:background-color "#000000aa"})
|
||||||
|
|
||||||
|
(def qr-code
|
||||||
|
{:width 250
|
||||||
|
:height 250
|
||||||
|
:background-color "white"
|
||||||
|
:border-radius 4
|
||||||
|
:align-items :center
|
||||||
|
:padding-top 15
|
||||||
|
:elevation 4})
|
||||||
|
|
||||||
(def hashtag
|
(def hashtag
|
||||||
{:color "#7099e6"})
|
{:color "#7099e6"})
|
||||||
|
@ -74,25 +74,3 @@
|
|||||||
:flexDirection :column
|
:flexDirection :column
|
||||||
:color color-white
|
:color color-white
|
||||||
:margin-left 8})
|
:margin-left 8})
|
||||||
|
|
||||||
|
|
||||||
(def scan-button
|
|
||||||
{:position :absolute
|
|
||||||
:bottom 0
|
|
||||||
:right 16
|
|
||||||
:flex 1
|
|
||||||
:height 50
|
|
||||||
:alignItems :center})
|
|
||||||
|
|
||||||
(def scan-button-content
|
|
||||||
{:flex 1
|
|
||||||
:flexDirection :row
|
|
||||||
:height 50
|
|
||||||
:alignItems :center
|
|
||||||
:alignSelf :center})
|
|
||||||
|
|
||||||
(def scan-text
|
|
||||||
{:flex 1
|
|
||||||
:flexDirection :column
|
|
||||||
:color "#7099e6"
|
|
||||||
:margin-left 8})
|
|
@ -1,21 +0,0 @@
|
|||||||
(ns status-im.qr-scanner.views.import-button
|
|
||||||
(:require-macros [status-im.utils.views :refer [defview]])
|
|
||||||
(:require [re-frame.core :refer [subscribe dispatch dispatch-sync]]
|
|
||||||
[status-im.components.react :refer [view
|
|
||||||
text
|
|
||||||
image
|
|
||||||
touchable-highlight]]
|
|
||||||
[status-im.components.styles :refer [icon-qr]]
|
|
||||||
[status-im.i18n :refer [label]]
|
|
||||||
[status-im.qr-scanner.styles :as st]))
|
|
||||||
|
|
||||||
|
|
||||||
(defview import-button [handler]
|
|
||||||
[]
|
|
||||||
[view st/import-button
|
|
||||||
[touchable-highlight
|
|
||||||
{:on-press handler}
|
|
||||||
[view st/import-button-content
|
|
||||||
[image {:source {:uri :icon_qr}
|
|
||||||
:style icon-qr}]
|
|
||||||
[text {:style st/import-text} (label :t/import-qr)]]]])
|
|
@ -1,22 +0,0 @@
|
|||||||
(ns status-im.qr-scanner.views.scan-button
|
|
||||||
(:require-macros [status-im.utils.views :refer [defview]])
|
|
||||||
(:require [re-frame.core :refer [subscribe dispatch dispatch-sync]]
|
|
||||||
[status-im.components.react :refer [view
|
|
||||||
text
|
|
||||||
image
|
|
||||||
touchable-highlight]]
|
|
||||||
[status-im.components.styles :refer [icon-scan]]
|
|
||||||
[status-im.i18n :refer [label]]
|
|
||||||
[status-im.qr-scanner.styles :as st]))
|
|
||||||
|
|
||||||
|
|
||||||
(defview scan-button [{:keys [showLabel icon labelStyle handler]}]
|
|
||||||
(let [showLabel (if (nil? showLabel) true showLabel)]
|
|
||||||
[view st/scan-button
|
|
||||||
[touchable-highlight
|
|
||||||
{:on-press handler}
|
|
||||||
[view st/scan-button-content
|
|
||||||
[image {:source {:uri (or icon :scan_blue)}
|
|
||||||
:style icon-scan}]
|
|
||||||
(when showLabel [text {:style (merge st/scan-text labelStyle)}
|
|
||||||
(label :t/scan-qr)])]]]))
|
|
@ -117,6 +117,7 @@
|
|||||||
:contacts-group-people "People"
|
:contacts-group-people "People"
|
||||||
:contacts-group-new-chat "Start new chat"
|
:contacts-group-new-chat "Start new chat"
|
||||||
:no-contacts "No contacts yet"
|
:no-contacts "No contacts yet"
|
||||||
|
:show-qr "Show QR"
|
||||||
|
|
||||||
;group-settings
|
;group-settings
|
||||||
:remove "Remove"
|
:remove "Remove"
|
||||||
|