feat: new text message (1) (#15005)

* feat: new text message
This commit is contained in:
Omar Basem 2023-02-20 19:14:03 +04:00 committed by GitHub
parent 58013db24c
commit 3fbb7cb0a7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 97 additions and 6 deletions

View File

@ -1 +1,19 @@
(ns status-im2.contexts.chat.messages.content.text.style) (ns status-im2.contexts.chat.messages.content.text.style
(:require
[quo2.foundations.colors :as colors]))
(def block
{:border-radius 6
:padding-horizontal 3
:transform [{:translateY 4}]})
(def quote
{:border-left-width 1
:padding-left 10
:border-left-color colors/neutral-40})
(defn code
[]
{:background-color (colors/theme-colors colors/neutral-5 colors/white-opa-5)
:border-width 1
:border-color (colors/theme-colors colors/neutral-20 colors/white-opa-20)})

View File

@ -1,11 +1,85 @@
(ns status-im2.contexts.chat.messages.content.text.view (ns status-im2.contexts.chat.messages.content.text.view
(:require (:require
[quo2.core :as quo]
[quo2.foundations.colors :as colors]
[react-native.core :as rn] [react-native.core :as rn]
[status-im.ui2.screens.chat.messages.message :as old-message] [status-im2.contexts.chat.messages.content.text.style :as style]
[status-im2.contexts.chat.messages.link-preview.view :as link-preview])) [status-im2.contexts.chat.messages.link-preview.view :as link-preview]
[utils.re-frame :as rf]))
(defn render-inline
[units {:keys [type literal destination]}]
(case (keyword type)
:code
(conj units [rn/view {:style (merge style/block (style/code))} [quo/text {:weight :code} literal]])
: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/touchable-opacity
{:active-opacity 1
:on-press #(rf/dispatch [:chat.ui/show-profile literal])
:style (merge style/block {:background-color colors/primary-50-opa-10})}
[quo/text
{:weight :medium
:style {:color (colors/theme-colors colors/primary-50 colors/primary-60)}}
(rf/sub [:contacts/contact-name-by-identity literal])]])
(conj units literal)))
(defn render-block
[blocks {:keys [type ^js literal children]}]
(case (keyword type)
:paragraph
(conj blocks
(reduce
render-inline
[quo/text]
children))
:blockquote
(conj blocks
[rn/view {:style style/quote}
[quo/text literal]])
:codeblock
(conj blocks
[rn/view {:style (merge style/block (style/code))}
[quo/text (subs literal 0 (dec (count literal)))]])
blocks))
(defn render-parsed-text
[{:keys [content]}]
(reduce render-block
[:<>]
(:parsed-text content)))
(defn text-content (defn text-content
[message-data context] [message-data context]
[rn/view [rn/view
[old-message/render-parsed-text message-data] [render-parsed-text message-data]
[link-preview/link-preview message-data context]]) [link-preview/link-preview message-data context]])

View File

@ -133,8 +133,7 @@
[author message-data] [author message-data]
(case content-type (case content-type
constants/content-type-text constants/content-type-text [content.text/text-content message-data context]
[not-implemented/not-implemented [content.text/text-content message-data context]]
constants/content-type-emoji constants/content-type-emoji
[not-implemented/not-implemented [old-message/emoji message-data]] [not-implemented/not-implemented [old-message/emoji message-data]]