mirror of
https://github.com/status-im/status-mobile.git
synced 2025-01-27 00:49:39 +00:00
move input events (#18183)
This commit is contained in:
parent
c1a17d9d53
commit
16a52b38e8
@ -1,10 +0,0 @@
|
|||||||
(ns status-im.chat.models.input-test
|
|
||||||
(:require
|
|
||||||
[cljs.test :refer-macros [deftest is]]
|
|
||||||
[status-im.chat.models.input :as input]))
|
|
||||||
|
|
||||||
(deftest text->emoji
|
|
||||||
(is (nil? (input/text->emoji nil)))
|
|
||||||
(is (= "" (input/text->emoji "")))
|
|
||||||
(is (= "test" (input/text->emoji "test")))
|
|
||||||
(is (= "word1 \uD83D\uDC4D word2" (input/text->emoji "word1 :+1: word2"))))
|
|
@ -161,3 +161,18 @@
|
|||||||
:on-error #(log/error "Error while calling wakuext_chatMentionClearMentions"
|
:on-error #(log/error "Error while calling wakuext_chatMentionClearMentions"
|
||||||
{:error %})}]}
|
{:error %})}]}
|
||||||
(clear-suggestions))))
|
(clear-suggestions))))
|
||||||
|
|
||||||
|
(rf/defn select-mention
|
||||||
|
{:events [:chat.ui/select-mention]}
|
||||||
|
[{:keys [db]} {:keys [primary-name searched-text match public-key] :as user}]
|
||||||
|
(let [chat-id (:current-chat-id db)
|
||||||
|
text (get-in db [:chat/inputs chat-id :input-text])
|
||||||
|
method "wakuext_chatMentionSelectMention"
|
||||||
|
params [chat-id text primary-name public-key]]
|
||||||
|
{:json-rpc/call [{:method method
|
||||||
|
:params params
|
||||||
|
:on-success #(rf/dispatch [:mention/on-select-mention-success %
|
||||||
|
primary-name match searched-text public-key])
|
||||||
|
:on-error #(rf/dispatch [:mention/on-error
|
||||||
|
{:method method
|
||||||
|
:params params} %])}]}))
|
||||||
|
@ -10,7 +10,6 @@
|
|||||||
status-im.bootnodes.core
|
status-im.bootnodes.core
|
||||||
status-im.browser.core
|
status-im.browser.core
|
||||||
status-im.browser.permissions
|
status-im.browser.permissions
|
||||||
status-im.chat.models.input
|
|
||||||
status-im.chat.models.loading
|
status-im.chat.models.loading
|
||||||
status-im.contact.block
|
status-im.contact.block
|
||||||
status-im.currency.core
|
status-im.currency.core
|
||||||
|
@ -32,7 +32,7 @@
|
|||||||
(js/setTimeout #(reanimated/set-shared-value background-y
|
(js/setTimeout #(reanimated/set-shared-value background-y
|
||||||
(- window-height))
|
(- window-height))
|
||||||
300)
|
300)
|
||||||
(rf/dispatch [:chat.ui/send-current-message])
|
(rf/dispatch [:chat.ui/replace-mentions-and-send-current-message])
|
||||||
(rf/dispatch [:chat.ui/set-input-maximized false])
|
(rf/dispatch [:chat.ui/set-input-maximized false])
|
||||||
(rf/dispatch [:chat.ui/set-input-content-height comp-constants/input-height])
|
(rf/dispatch [:chat.ui/set-input-content-height comp-constants/input-height])
|
||||||
(rf/dispatch [:chat.ui/set-chat-input-text nil])
|
(rf/dispatch [:chat.ui/set-chat-input-text nil])
|
||||||
|
@ -1,41 +1,25 @@
|
|||||||
(ns status-im.chat.models.input
|
(ns status-im2.contexts.chat.composer.events
|
||||||
(:require
|
(:require [clojure.string :as string]
|
||||||
["emojilib" :as emojis]
|
[status-im.chat.models.mentions :as mentions]
|
||||||
[clojure.string :as string]
|
[status-im.data-store.messages :as data-store-messages]
|
||||||
[goog.object :as object]
|
[status-im2.constants :as constants]
|
||||||
[re-frame.core :as re-frame]
|
[status-im2.contexts.chat.composer.link-preview.events :as link-preview]
|
||||||
[status-im.chat.models.mentions :as mentions]
|
[status-im2.contexts.chat.messages.transport.events :as messages.transport]
|
||||||
[status-im.data-store.messages :as data-store-messages]
|
[taoensso.timbre :as log]
|
||||||
[status-im2.constants :as constants]
|
[utils.emojilib :as emoji]
|
||||||
[status-im2.contexts.chat.composer.link-preview.events :as link-preview]
|
[utils.i18n :as i18n]
|
||||||
[status-im2.contexts.chat.messages.transport.events :as messages.transport]
|
[utils.re-frame :as rf]
|
||||||
[taoensso.timbre :as log]
|
utils.string))
|
||||||
[utils.i18n :as i18n]
|
|
||||||
[utils.re-frame :as rf]
|
|
||||||
[utils.string :as utils.string]))
|
|
||||||
|
|
||||||
(defn text->emoji
|
|
||||||
"Replaces emojis in a specified `text`"
|
|
||||||
[text]
|
|
||||||
(utils.string/safe-replace text
|
|
||||||
#":([a-z_\-+0-9]*):"
|
|
||||||
(fn [[original emoji-id]]
|
|
||||||
(if-let [emoji-map (object/get (.-lib emojis) emoji-id)]
|
|
||||||
(.-char ^js emoji-map)
|
|
||||||
original))))
|
|
||||||
|
|
||||||
;; effects
|
|
||||||
|
|
||||||
(rf/defn set-chat-input-text
|
(rf/defn set-chat-input-text
|
||||||
"Set input text for current-chat. Takes db and input text and cofx
|
|
||||||
as arguments and returns new fx. Always clear all validation messages."
|
|
||||||
{:events [:chat.ui/set-chat-input-text]}
|
{:events [:chat.ui/set-chat-input-text]}
|
||||||
[{:keys [db] :as cofx} new-input chat-id]
|
[{:keys [db] :as cofx} new-input chat-id]
|
||||||
(let [current-chat-id (or chat-id (:current-chat-id db))]
|
(let [current-chat-id (or chat-id (:current-chat-id db))]
|
||||||
(rf/merge cofx
|
(rf/merge
|
||||||
{:db (assoc-in db [:chat/inputs current-chat-id :input-text] (text->emoji new-input))}
|
cofx
|
||||||
(when (empty? new-input)
|
{:db (assoc-in db [:chat/inputs current-chat-id :input-text] (emoji/text->emoji new-input))}
|
||||||
(mentions/clear-mentions)))))
|
(when (empty? new-input)
|
||||||
|
(mentions/clear-mentions)))))
|
||||||
|
|
||||||
(rf/defn set-input-content-height
|
(rf/defn set-input-content-height
|
||||||
{:events [:chat.ui/set-input-content-height]}
|
{:events [:chat.ui/set-input-content-height]}
|
||||||
@ -66,27 +50,6 @@
|
|||||||
[{db :db} recording?]
|
[{db :db} recording?]
|
||||||
{:db (assoc db :chats/recording? recording?)})
|
{:db (assoc db :chats/recording? recording?)})
|
||||||
|
|
||||||
(rf/defn select-mention
|
|
||||||
{:events [:chat.ui/select-mention]}
|
|
||||||
[{:keys [db] :as cofx} text-input-ref {:keys [primary-name searched-text match public-key] :as user}]
|
|
||||||
(let [chat-id (:current-chat-id db)
|
|
||||||
text (get-in db [:chat/inputs chat-id :input-text])
|
|
||||||
method "wakuext_chatMentionSelectMention"
|
|
||||||
params [chat-id text primary-name public-key]]
|
|
||||||
{:json-rpc/call [{:method method
|
|
||||||
:params params
|
|
||||||
:on-success #(rf/dispatch [:mention/on-select-mention-success %
|
|
||||||
primary-name match searched-text public-key])
|
|
||||||
:on-error #(rf/dispatch [:mention/on-error
|
|
||||||
{:method method
|
|
||||||
:params params} %])}]}))
|
|
||||||
|
|
||||||
(rf/defn disable-chat-cooldown
|
|
||||||
"Turns off chat cooldown (protection against message spamming)"
|
|
||||||
{:events [:chat/disable-cooldown]}
|
|
||||||
[{:keys [db]}]
|
|
||||||
{:db (assoc db :chat/cooldown-enabled? false)})
|
|
||||||
|
|
||||||
(rf/defn reply-to-message
|
(rf/defn reply-to-message
|
||||||
"Sets reference to previous chat message and focuses on input"
|
"Sets reference to previous chat message and focuses on input"
|
||||||
{:events [:chat.ui/reply-to-message]}
|
{:events [:chat.ui/reply-to-message]}
|
||||||
@ -103,7 +66,7 @@
|
|||||||
(rf/defn edit-message
|
(rf/defn edit-message
|
||||||
"Sets reference to previous chat message and focuses on input"
|
"Sets reference to previous chat message and focuses on input"
|
||||||
{:events [:chat.ui/edit-message]}
|
{:events [:chat.ui/edit-message]}
|
||||||
[{:keys [db] :as cofx} message]
|
[{:keys [db]} message]
|
||||||
(let [current-chat-id (:current-chat-id db)
|
(let [current-chat-id (:current-chat-id db)
|
||||||
text (get-in message [:content :text])]
|
text (get-in message [:content :text])]
|
||||||
{:db (-> db
|
{:db (-> db
|
||||||
@ -116,21 +79,6 @@
|
|||||||
:dispatch-n [[:chat.ui/set-chat-input-text nil current-chat-id]
|
:dispatch-n [[:chat.ui/set-chat-input-text nil current-chat-id]
|
||||||
[:mention/to-input-field text current-chat-id]]}))
|
[:mention/to-input-field text current-chat-id]]}))
|
||||||
|
|
||||||
(rf/defn show-contact-request-input
|
|
||||||
"Sets reference to previous chat message and focuses on input"
|
|
||||||
{:events [:chat.ui/send-contact-request]}
|
|
||||||
[{:keys [db]}]
|
|
||||||
(let [current-chat-id (:current-chat-id db)]
|
|
||||||
{:db (-> db
|
|
||||||
(assoc-in [:chat/inputs current-chat-id :metadata :sending-contact-request]
|
|
||||||
current-chat-id)
|
|
||||||
(assoc-in [:chat/inputs current-chat-id :metadata :responding-to-message]
|
|
||||||
nil)
|
|
||||||
(assoc-in [:chat/inputs current-chat-id :metadata :editing-message] nil)
|
|
||||||
(update-in [:chat/inputs current-chat-id :metadata]
|
|
||||||
dissoc
|
|
||||||
:sending-image))}))
|
|
||||||
|
|
||||||
(rf/defn cancel-message-reply
|
(rf/defn cancel-message-reply
|
||||||
"Cancels stage message reply"
|
"Cancels stage message reply"
|
||||||
{:events [:chat.ui/cancel-message-reply]}
|
{:events [:chat.ui/cancel-message-reply]}
|
||||||
@ -138,49 +86,6 @@
|
|||||||
(let [current-chat-id (:current-chat-id db)]
|
(let [current-chat-id (:current-chat-id db)]
|
||||||
{:db (assoc-in db [:chat/inputs current-chat-id :metadata :responding-to-message] nil)}))
|
{:db (assoc-in db [:chat/inputs current-chat-id :metadata :responding-to-message] nil)}))
|
||||||
|
|
||||||
(defn emoji-only-content?
|
|
||||||
"Determines if text is just an emoji"
|
|
||||||
[{:keys [text response-to]}]
|
|
||||||
(and (not response-to)
|
|
||||||
(string? text)
|
|
||||||
(re-matches constants/regx-emoji text)))
|
|
||||||
|
|
||||||
(defn build-text-message
|
|
||||||
[{:keys [db]} input-text current-chat-id]
|
|
||||||
(when-not (string/blank? input-text)
|
|
||||||
(let [{:keys [message-id]}
|
|
||||||
(get-in db [:chat/inputs current-chat-id :metadata :responding-to-message])
|
|
||||||
preferred-name (get-in db [:profile/profile :preferred-name])
|
|
||||||
emoji? (emoji-only-content? {:text input-text
|
|
||||||
:response-to message-id})]
|
|
||||||
{:chat-id current-chat-id
|
|
||||||
:content-type (if emoji?
|
|
||||||
constants/content-type-emoji
|
|
||||||
constants/content-type-text)
|
|
||||||
:text input-text
|
|
||||||
:response-to message-id
|
|
||||||
:ens-name preferred-name
|
|
||||||
:link-previews (map #(select-keys % [:url :title :description :thumbnail])
|
|
||||||
(get-in db [:chat/link-previews :unfurled]))})))
|
|
||||||
|
|
||||||
(defn build-image-messages
|
|
||||||
[{db :db} chat-id input-text]
|
|
||||||
(let [images (get-in db [:chat/inputs chat-id :metadata :sending-image])
|
|
||||||
{:keys [message-id]} (get-in db [:chat/inputs chat-id :metadata :responding-to-message])
|
|
||||||
album-id (str (random-uuid))]
|
|
||||||
(mapv (fn [[_ {:keys [resized-uri width height]}]]
|
|
||||||
{:chat-id chat-id
|
|
||||||
:album-id album-id
|
|
||||||
:content-type constants/content-type-image
|
|
||||||
:image-path (utils.string/safe-replace resized-uri #"file://" "")
|
|
||||||
:image-width width
|
|
||||||
:image-height height
|
|
||||||
:text input-text
|
|
||||||
:link-previews (map #(select-keys % [:url :title :description :thumbnail])
|
|
||||||
(get-in db [:chat/link-previews :unfurled]))
|
|
||||||
:response-to message-id})
|
|
||||||
images)))
|
|
||||||
|
|
||||||
(rf/defn clean-input
|
(rf/defn clean-input
|
||||||
[{:keys [db] :as cofx} current-chat-id]
|
[{:keys [db] :as cofx} current-chat-id]
|
||||||
(rf/merge cofx
|
(rf/merge cofx
|
||||||
@ -201,6 +106,50 @@
|
|||||||
(link-preview/reset-unfurled)
|
(link-preview/reset-unfurled)
|
||||||
(mentions/clear-mentions))))
|
(mentions/clear-mentions))))
|
||||||
|
|
||||||
|
|
||||||
|
(defn emoji-only-content?
|
||||||
|
"Determines if text is just an emoji"
|
||||||
|
[{:keys [text response-to]}]
|
||||||
|
(and (not response-to)
|
||||||
|
(string? text)
|
||||||
|
(re-matches constants/regx-emoji text)))
|
||||||
|
|
||||||
|
(defn build-image-messages
|
||||||
|
[{db :db} chat-id input-text]
|
||||||
|
(let [images (get-in db [:chat/inputs chat-id :metadata :sending-image])
|
||||||
|
{:keys [message-id]} (get-in db [:chat/inputs chat-id :metadata :responding-to-message])
|
||||||
|
album-id (str (random-uuid))]
|
||||||
|
(mapv (fn [[_ {:keys [resized-uri width height]}]]
|
||||||
|
{:chat-id chat-id
|
||||||
|
:album-id album-id
|
||||||
|
:content-type constants/content-type-image
|
||||||
|
:image-path (utils.string/safe-replace resized-uri #"file://" "")
|
||||||
|
:image-width width
|
||||||
|
:image-height height
|
||||||
|
:text input-text
|
||||||
|
:link-previews (map #(select-keys % [:url :title :description :thumbnail])
|
||||||
|
(get-in db [:chat/link-previews :unfurled]))
|
||||||
|
:response-to message-id})
|
||||||
|
images)))
|
||||||
|
|
||||||
|
(defn build-text-message
|
||||||
|
[{:keys [db]} input-text current-chat-id]
|
||||||
|
(when-not (string/blank? input-text)
|
||||||
|
(let [{:keys [message-id]}
|
||||||
|
(get-in db [:chat/inputs current-chat-id :metadata :responding-to-message])
|
||||||
|
preferred-name (get-in db [:profile/profile :preferred-name])
|
||||||
|
emoji? (emoji-only-content? {:text input-text
|
||||||
|
:response-to message-id})]
|
||||||
|
{:chat-id current-chat-id
|
||||||
|
:content-type (if emoji?
|
||||||
|
constants/content-type-emoji
|
||||||
|
constants/content-type-text)
|
||||||
|
:text input-text
|
||||||
|
:response-to message-id
|
||||||
|
:ens-name preferred-name
|
||||||
|
:link-previews (map #(select-keys % [:url :title :description :thumbnail])
|
||||||
|
(get-in db [:chat/link-previews :unfurled]))})))
|
||||||
|
|
||||||
(rf/defn send-messages
|
(rf/defn send-messages
|
||||||
[{:keys [db] :as cofx} input-text current-chat-id]
|
[{:keys [db] :as cofx} input-text current-chat-id]
|
||||||
(let [image-messages (build-image-messages cofx current-chat-id input-text)
|
(let [image-messages (build-image-messages cofx current-chat-id input-text)
|
||||||
@ -214,8 +163,10 @@
|
|||||||
(messages.transport/send-chat-messages messages)))))
|
(messages.transport/send-chat-messages messages)))))
|
||||||
|
|
||||||
(rf/defn send-audio-message
|
(rf/defn send-audio-message
|
||||||
[{:keys [db] :as cofx} audio-path duration current-chat-id]
|
{:events [:chat/send-audio]}
|
||||||
(let [{:keys [message-id]}
|
[{:keys [db] :as cofx} audio-path duration]
|
||||||
|
(let [{:keys [current-chat-id]} db
|
||||||
|
{:keys [message-id]}
|
||||||
(get-in db [:chat/inputs current-chat-id :metadata :responding-to-message])]
|
(get-in db [:chat/inputs current-chat-id :metadata :responding-to-message])]
|
||||||
(when-not (string/blank? audio-path)
|
(when-not (string/blank? audio-path)
|
||||||
(rf/merge
|
(rf/merge
|
||||||
@ -230,17 +181,6 @@
|
|||||||
(when message-id
|
(when message-id
|
||||||
{:response-to message-id}))])))))
|
{:response-to message-id}))])))))
|
||||||
|
|
||||||
(rf/defn send-sticker-message
|
|
||||||
[cofx {:keys [hash packID pack]} current-chat-id]
|
|
||||||
(when-not (or (string/blank? hash) (and (string/blank? packID) (string/blank? pack)))
|
|
||||||
(messages.transport/send-chat-messages
|
|
||||||
cofx
|
|
||||||
[{:chat-id current-chat-id
|
|
||||||
:content-type constants/content-type-sticker
|
|
||||||
:sticker {:hash hash
|
|
||||||
:pack (int (if (string/blank? packID) pack packID))}
|
|
||||||
:text (i18n/label :t/update-to-see-sticker {"locale" "en"})}])))
|
|
||||||
|
|
||||||
(rf/defn send-edited-message
|
(rf/defn send-edited-message
|
||||||
[{:keys [db]
|
[{:keys [db]
|
||||||
:as cofx} text {:keys [message-id quoted-message chat-id]}]
|
:as cofx} text {:keys [message-id quoted-message chat-id]}]
|
||||||
@ -262,79 +202,29 @@
|
|||||||
:js-response true
|
:js-response true
|
||||||
:on-error #(log/error "failed to edit message " %)
|
:on-error #(log/error "failed to edit message " %)
|
||||||
:on-success (fn [result]
|
:on-success (fn [result]
|
||||||
(re-frame/dispatch [:sanitize-messages-and-process-response
|
(rf/dispatch [:sanitize-messages-and-process-response
|
||||||
result]))}]}
|
result]))}]}
|
||||||
(link-preview/reset-unfurled)
|
(link-preview/reset-unfurled)
|
||||||
(cancel-message-edit)))
|
(cancel-message-edit)))
|
||||||
|
|
||||||
(rf/defn send-current-message
|
(rf/defn replace-mentions-and-send-current-message
|
||||||
"Sends message from current chat input"
|
"Sends message from current chat input"
|
||||||
{:events [:chat.ui/send-current-message]}
|
{:events [:chat.ui/replace-mentions-and-send-current-message]}
|
||||||
[{{:keys [current-chat-id] :as db} :db :as cofx}]
|
[{{:keys [current-chat-id] :as db} :db}]
|
||||||
(let [{:keys [input-text metadata]} (get-in db [:chat/inputs current-chat-id])
|
(let [{:keys [input-text metadata]} (get-in db [:chat/inputs current-chat-id])]
|
||||||
editing-message (:editing-message metadata)
|
{:json-rpc/call [{:method "wakuext_chatMentionReplaceWithPublicKey"
|
||||||
method "wakuext_chatMentionReplaceWithPublicKey"
|
:params [current-chat-id input-text]
|
||||||
params [current-chat-id input-text]]
|
:on-error #(log/error "[wakuext_chatMentionReplaceWithPublicKey] on-error" %)
|
||||||
{:json-rpc/call [{:method method
|
:on-success #(rf/dispatch [:chat.ui/send-current-message-with-mentions
|
||||||
:params params
|
|
||||||
:on-error #(rf/dispatch [:mention/on-error {:method method :params params} %])
|
|
||||||
:on-success #(rf/dispatch [:mention/on-replace-with-public-key-success
|
|
||||||
current-chat-id
|
current-chat-id
|
||||||
editing-message
|
(:editing-message metadata)
|
||||||
input-text
|
input-text
|
||||||
%])}]}))
|
%])}]}))
|
||||||
|
|
||||||
(rf/defn on-replace-with-public-key-success
|
(rf/defn send-current-message-with-mentions
|
||||||
{:events [:mention/on-replace-with-public-key-success]}
|
{:events [:chat.ui/send-current-message-with-mentions]}
|
||||||
[{:keys [db] :as cofx} current-chat-id editing-message input-text new-text]
|
[{:keys [db] :as cofx} current-chat-id editing-message input-text new-text]
|
||||||
(log/debug "[mentions] on-replace-with-public-key-success"
|
|
||||||
{:chat-id current-chat-id
|
|
||||||
:editing-message editing-message
|
|
||||||
:input-text input-text
|
|
||||||
:new-text new-text})
|
|
||||||
(rf/merge cofx
|
(rf/merge cofx
|
||||||
(if editing-message
|
(if editing-message
|
||||||
(send-edited-message new-text editing-message)
|
(send-edited-message new-text editing-message)
|
||||||
(send-messages new-text current-chat-id))))
|
(send-messages new-text current-chat-id))))
|
||||||
|
|
||||||
(rf/defn send-contact-request
|
|
||||||
{:events [:contacts/send-contact-request]}
|
|
||||||
[{:keys [db] :as cofx} public-key message]
|
|
||||||
(rf/merge cofx
|
|
||||||
{:chat.ui/clear-inputs nil
|
|
||||||
:json-rpc/call [{:method "wakuext_sendContactRequest"
|
|
||||||
:js-response true
|
|
||||||
:params [{:id public-key :message message}]
|
|
||||||
:on-error #(log/warn "failed to send a contact request" %)
|
|
||||||
:on-success #(re-frame/dispatch [:transport/message-sent %])}]}
|
|
||||||
(mentions/clear-mentions)
|
|
||||||
(clean-input (:current-chat-id db))))
|
|
||||||
|
|
||||||
(rf/defn cancel-contact-request
|
|
||||||
"Cancels contact request"
|
|
||||||
{:events [:chat.ui/cancel-contact-request]}
|
|
||||||
[{:keys [db] :as cofx}]
|
|
||||||
(let [current-chat-id (:current-chat-id db)]
|
|
||||||
(rf/merge cofx
|
|
||||||
{:db (assoc-in db [:chat/inputs current-chat-id :metadata :sending-contact-request] nil)}
|
|
||||||
(mentions/clear-mentions)
|
|
||||||
(clean-input (:current-chat-id db)))))
|
|
||||||
|
|
||||||
(rf/defn chat-send-sticker
|
|
||||||
{:events [:chat/send-sticker]}
|
|
||||||
[{{:keys [current-chat-id] :as db} :db :as cofx} {:keys [hash packID pack] :as sticker}]
|
|
||||||
(rf/merge
|
|
||||||
cofx
|
|
||||||
{:db (update db
|
|
||||||
:stickers/recent-stickers
|
|
||||||
(fn [recent]
|
|
||||||
(conj (remove #(= hash (:hash %)) recent) sticker)))
|
|
||||||
:json-rpc/call [{:method "stickers_addRecent"
|
|
||||||
:params [(int (if (string/blank? packID) pack packID)) hash]
|
|
||||||
:on-success #()}]}
|
|
||||||
(send-sticker-message sticker current-chat-id)))
|
|
||||||
|
|
||||||
(rf/defn chat-send-audio
|
|
||||||
{:events [:chat/send-audio]}
|
|
||||||
[{{:keys [current-chat-id] :as db} :db :as cofx} audio-path duration]
|
|
||||||
(send-audio-message cofx audio-path duration current-chat-id))
|
|
@ -25,7 +25,7 @@
|
|||||||
[user _ _ render-data]
|
[user _ _ render-data]
|
||||||
[contact-list-item/contact-list-item
|
[contact-list-item/contact-list-item
|
||||||
{:on-press (fn []
|
{:on-press (fn []
|
||||||
(rf/dispatch [:chat.ui/select-mention nil user])
|
(rf/dispatch [:chat.ui/select-mention user])
|
||||||
(update-cursor user render-data))}
|
(update-cursor user render-data))}
|
||||||
user])
|
user])
|
||||||
|
|
||||||
|
@ -11,6 +11,7 @@
|
|||||||
status-im2.common.theme.events
|
status-im2.common.theme.events
|
||||||
[status-im2.common.toasts.events]
|
[status-im2.common.toasts.events]
|
||||||
[status-im2.contexts.add-new-contact.events]
|
[status-im2.contexts.add-new-contact.events]
|
||||||
|
status-im2.contexts.chat.composer.events
|
||||||
status-im2.contexts.chat.events
|
status-im2.contexts.chat.events
|
||||||
status-im2.contexts.chat.photo-selector.events
|
status-im2.contexts.chat.photo-selector.events
|
||||||
status-im2.contexts.communities.overview.events
|
status-im2.contexts.communities.overview.events
|
||||||
|
19
src/utils/emojilib.cljs
Normal file
19
src/utils/emojilib.cljs
Normal file
@ -0,0 +1,19 @@
|
|||||||
|
(ns utils.emojilib
|
||||||
|
(:require ["emojilib" :as emojis]
|
||||||
|
[goog.object :as object]
|
||||||
|
utils.string))
|
||||||
|
|
||||||
|
(def lib (.-lib emojis))
|
||||||
|
|
||||||
|
(defn get-char
|
||||||
|
[emoji-id]
|
||||||
|
(when-let [emoji-map (object/get lib emoji-id)]
|
||||||
|
(.-char ^js emoji-map)))
|
||||||
|
|
||||||
|
(defn text->emoji
|
||||||
|
"Replaces emojis in a specified `text`"
|
||||||
|
[text]
|
||||||
|
(utils.string/safe-replace text
|
||||||
|
#":([a-z_\-+0-9]*):"
|
||||||
|
(fn [[original emoji-id]]
|
||||||
|
(or (get-char emoji-id) original))))
|
Loading…
x
Reference in New Issue
Block a user