mirror of
https://github.com/status-im/status-react.git
synced 2025-01-11 19:44:47 +00:00
[15902] BUGFIX - Resolve public keys into the user's name in the confirmation drawer and image description (#16176)
This commit is contained in:
parent
86219dbad8
commit
4c8671caa0
@ -34,9 +34,9 @@
|
|||||||
profile-picture name]} context
|
profile-picture name]} context
|
||||||
id (or chat-id public-key)
|
id (or chat-id public-key)
|
||||||
display-name (or
|
display-name (or
|
||||||
name
|
|
||||||
(when-not group-chat
|
(when-not group-chat
|
||||||
(rf/sub [:contacts/contact-name-by-identity id])))
|
(rf/sub [:contacts/contact-name-by-identity id]))
|
||||||
|
name)
|
||||||
contact (when-not group-chat
|
contact (when-not group-chat
|
||||||
(rf/sub [:contacts/contact-by-address
|
(rf/sub [:contacts/contact-by-address
|
||||||
id]))
|
id]))
|
||||||
|
@ -7,7 +7,7 @@
|
|||||||
[utils.re-frame :as rf]
|
[utils.re-frame :as rf]
|
||||||
[status-im2.contexts.chat.lightbox.animations :as anim]
|
[status-im2.contexts.chat.lightbox.animations :as anim]
|
||||||
[status-im2.contexts.chat.lightbox.constants :as c]
|
[status-im2.contexts.chat.lightbox.constants :as c]
|
||||||
[status-im2.constants :as constants]))
|
[status-im2.contexts.chat.messages.content.text.view :as message-view]))
|
||||||
|
|
||||||
(defn get-small-item-layout
|
(defn get-small-item-layout
|
||||||
[_ index]
|
[_ index]
|
||||||
@ -50,15 +50,17 @@
|
|||||||
|
|
||||||
(defn bottom-view
|
(defn bottom-view
|
||||||
[messages index scroll-index insets animations derived item-width props]
|
[messages index scroll-index insets animations derived item-width props]
|
||||||
(let [text (get-in (first messages) [:content :text])
|
(let [{:keys [chat-id content]} (first messages)
|
||||||
padding-horizontal (- (/ item-width 2) (/ c/focused-image-size 2))]
|
padding-horizontal (- (/ item-width 2) (/ c/focused-image-size 2))]
|
||||||
[reanimated/linear-gradient
|
[reanimated/linear-gradient
|
||||||
{:colors [:black :transparent]
|
{:colors [:black :transparent]
|
||||||
:start {:x 0 :y 1}
|
:start {:x 0 :y 1}
|
||||||
:end {:x 0 :y 0}
|
:end {:x 0 :y 0}
|
||||||
:style (style/gradient-container insets animations derived)}
|
:style (style/gradient-container insets animations derived)}
|
||||||
(when constants/image-description-in-lightbox?
|
[message-view/render-parsed-text
|
||||||
[rn/text {:style style/text-style} text])
|
{:content content
|
||||||
|
:chat-id chat-id
|
||||||
|
:style-override style/text-style}]
|
||||||
[rn/flat-list
|
[rn/flat-list
|
||||||
{:ref #(reset! (:small-list-ref props) %)
|
{:ref #(reset! (:small-list-ref props) %)
|
||||||
:key-fn :message-id
|
:key-fn :message-id
|
||||||
|
@ -9,87 +9,106 @@
|
|||||||
[utils.re-frame :as rf]))
|
[utils.re-frame :as rf]))
|
||||||
|
|
||||||
(defn render-inline
|
(defn render-inline
|
||||||
[units {:keys [type literal destination]} chat-id]
|
[units {:keys [type literal destination]} chat-id style-override]
|
||||||
(case (keyword type)
|
(let [show-as-plain-text? (seq style-override)]
|
||||||
:code
|
(case (keyword type)
|
||||||
(conj units [quo/text {:style (merge style/block (style/code)) :weight :code} literal])
|
:code
|
||||||
|
|
||||||
:emph
|
|
||||||
(conj units [quo/text {:style {:font-style :italic}} literal])
|
|
||||||
|
|
||||||
:strong
|
|
||||||
(conj units [quo/text {:weight :bold} literal])
|
|
||||||
|
|
||||||
:strong-emph
|
|
||||||
(conj units
|
|
||||||
[quo/text
|
|
||||||
{:weight :bold
|
|
||||||
:style {:font-style :italic}} literal])
|
|
||||||
|
|
||||||
:del
|
|
||||||
(conj units [quo/text {:style {:text-decoration-line :line-through}} literal])
|
|
||||||
|
|
||||||
:link
|
|
||||||
(conj units
|
|
||||||
[quo/text
|
|
||||||
{:style {:color (colors/theme-colors colors/primary-50 colors/primary-60)}
|
|
||||||
:on-press #(rf/dispatch [:browser.ui/message-link-pressed destination])}
|
|
||||||
destination])
|
|
||||||
|
|
||||||
:mention
|
|
||||||
(conj
|
|
||||||
units
|
|
||||||
[rn/view
|
|
||||||
{:style style/mention-tag-wrapper}
|
|
||||||
[rn/touchable-opacity
|
|
||||||
{:active-opacity 1
|
|
||||||
:on-press #(rf/dispatch [:chat.ui/show-profile literal])
|
|
||||||
:style style/mention-tag}
|
|
||||||
[quo/text
|
|
||||||
{:weight :medium
|
|
||||||
:style style/mention-tag-text}
|
|
||||||
(rf/sub [:messages/resolve-mention literal])]]])
|
|
||||||
|
|
||||||
:edited
|
|
||||||
(conj units
|
|
||||||
|
|
||||||
[quo/text
|
|
||||||
{:weight :medium
|
|
||||||
:style {:font-size 11 ; Font-size must be used instead of props or the
|
|
||||||
; styles will clash with original message text
|
|
||||||
:color (colors/theme-colors colors/neutral-40
|
|
||||||
colors/neutral-50)}}
|
|
||||||
literal])
|
|
||||||
:status-tag
|
|
||||||
(let [community-id (rf/sub [:community-id-by-chat-id chat-id])]
|
|
||||||
(conj units
|
(conj units
|
||||||
[rn/text
|
[quo/text
|
||||||
(when community-id
|
{:style (if show-as-plain-text?
|
||||||
{:style {:color :blue
|
{:color colors/white}
|
||||||
:text-decoration-line :underline}
|
(merge style/block (style/code)))
|
||||||
:on-press #(rf/dispatch [:communities/status-tag-pressed community-id literal])})
|
:weight :code} literal])
|
||||||
"#"
|
|
||||||
literal]))
|
|
||||||
|
|
||||||
(conj units literal)))
|
:emph
|
||||||
|
(conj units
|
||||||
|
[quo/text
|
||||||
|
{:style {:font-style :italic
|
||||||
|
:color (when show-as-plain-text? colors/white)}} literal])
|
||||||
|
|
||||||
|
:strong
|
||||||
|
(conj units
|
||||||
|
[quo/text
|
||||||
|
(cond-> {:weight :bold}
|
||||||
|
show-as-plain-text? (assoc :style {:color colors/white})) literal])
|
||||||
|
|
||||||
|
:strong-emph
|
||||||
|
(conj units
|
||||||
|
[quo/text
|
||||||
|
{:weight :bold
|
||||||
|
:style {:font-style :italic
|
||||||
|
:color (when show-as-plain-text? colors/white)}} literal])
|
||||||
|
|
||||||
|
:del
|
||||||
|
(conj units
|
||||||
|
[quo/text
|
||||||
|
{:style {:text-decoration-line :line-through
|
||||||
|
:color (when show-as-plain-text? colors/white)}} literal])
|
||||||
|
|
||||||
|
:link
|
||||||
|
(conj units
|
||||||
|
[quo/text
|
||||||
|
{:style {:color (colors/theme-colors colors/primary-50 colors/primary-60)}
|
||||||
|
:on-press #(rf/dispatch [:browser.ui/message-link-pressed destination])}
|
||||||
|
destination])
|
||||||
|
|
||||||
|
:mention
|
||||||
|
(conj
|
||||||
|
units
|
||||||
|
[rn/view
|
||||||
|
{:style style/mention-tag-wrapper}
|
||||||
|
[rn/touchable-opacity
|
||||||
|
{:active-opacity 1
|
||||||
|
:on-press #(rf/dispatch [:chat.ui/show-profile literal])
|
||||||
|
:style style/mention-tag}
|
||||||
|
[quo/text
|
||||||
|
{:weight :medium
|
||||||
|
:style style/mention-tag-text}
|
||||||
|
(rf/sub [:messages/resolve-mention literal])]]])
|
||||||
|
|
||||||
|
:edited
|
||||||
|
(conj units
|
||||||
|
|
||||||
|
[quo/text
|
||||||
|
{:weight :medium
|
||||||
|
:style {:font-size 11 ; Font-size must be used instead of props or the
|
||||||
|
; styles will clash with original message text
|
||||||
|
:color (colors/theme-colors colors/neutral-40
|
||||||
|
colors/neutral-50)}}
|
||||||
|
literal])
|
||||||
|
:status-tag
|
||||||
|
(let [community-id (rf/sub [:community-id-by-chat-id chat-id])]
|
||||||
|
(conj units
|
||||||
|
[rn/text
|
||||||
|
(when community-id
|
||||||
|
{:style {:color :blue
|
||||||
|
:text-decoration-line :underline}
|
||||||
|
:on-press #(rf/dispatch [:communities/status-tag-pressed community-id literal])})
|
||||||
|
"#"
|
||||||
|
literal]))
|
||||||
|
|
||||||
|
(conj units literal))))
|
||||||
|
|
||||||
|
|
||||||
(defn render-block
|
(defn render-block
|
||||||
[blocks {:keys [type literal children]} chat-id]
|
[blocks {:keys [type literal children]} chat-id style-override]
|
||||||
(case (keyword type)
|
(case (keyword type)
|
||||||
:paragraph
|
:paragraph
|
||||||
(conj blocks
|
(conj blocks
|
||||||
(reduce
|
[rn/view
|
||||||
(fn [acc e]
|
(reduce
|
||||||
(render-inline acc e chat-id))
|
(fn [acc e]
|
||||||
[quo/text {:size :paragraph-1}]
|
(render-inline acc e chat-id style-override))
|
||||||
children))
|
[quo/text
|
||||||
|
{:style {:size :paragraph-1
|
||||||
|
:color (when (seq style-override) colors/white)}}]
|
||||||
|
children)])
|
||||||
|
|
||||||
:edited-block
|
:edited-block
|
||||||
(conj blocks
|
(conj blocks
|
||||||
(reduce
|
(reduce
|
||||||
(fn [acc e]
|
(fn [acc e]
|
||||||
(render-inline acc e chat-id))
|
(render-inline acc e chat-id style-override))
|
||||||
[quo/text {:size :paragraph-1}]
|
[quo/text {:size :paragraph-1}]
|
||||||
children))
|
children))
|
||||||
|
|
||||||
@ -120,11 +139,11 @@
|
|||||||
(conj parsed-text {:type :edited-block :children [edited-tag]}))))
|
(conj parsed-text {:type :edited-block :children [edited-tag]}))))
|
||||||
|
|
||||||
(defn render-parsed-text
|
(defn render-parsed-text
|
||||||
[{:keys [content chat-id edited-at]}]
|
[{:keys [content chat-id edited-at style-override]}]
|
||||||
^{:key (:parsed-text content)}
|
^{:key (:parsed-text content)}
|
||||||
[rn/view
|
[rn/view {:style style-override}
|
||||||
(reduce (fn [acc e]
|
(reduce (fn [acc e]
|
||||||
(render-block acc e chat-id))
|
(render-block acc e chat-id style-override))
|
||||||
[:<>]
|
[:<>]
|
||||||
(cond-> (:parsed-text content)
|
(cond-> (:parsed-text content)
|
||||||
edited-at
|
edited-at
|
||||||
|
Loading…
x
Reference in New Issue
Block a user