mirror of
https://github.com/status-im/status-react.git
synced 2025-01-25 18:29:37 +00:00
same-author/direction
This commit is contained in:
parent
9548dd23ee
commit
827a354c1e
@ -144,8 +144,18 @@
|
|||||||
:to "me"})) (range n)))
|
:to "me"})) (range n)))
|
||||||
|
|
||||||
(defn store-message!
|
(defn store-message!
|
||||||
[_ [_ {chat-id :from :as msg}]]
|
[db [_ {chat-id :from
|
||||||
(save-message chat-id msg))
|
outgoing :outgoing
|
||||||
|
:as msg}]]
|
||||||
|
(let [previous-message (peek (get-in db [:chats chat-id :messages]))
|
||||||
|
msg (merge msg
|
||||||
|
{:same-author (if previous-message
|
||||||
|
(= (:from previous-message) outgoing)
|
||||||
|
true)
|
||||||
|
:same-direction (if previous-message
|
||||||
|
(= (:outgoing previous-message) outgoing)
|
||||||
|
true)})]
|
||||||
|
(save-message chat-id msg)))
|
||||||
|
|
||||||
(defn receive-message
|
(defn receive-message
|
||||||
[db [_ {chat-id :from :as msg}]]
|
[db [_ {chat-id :from :as msg}]]
|
||||||
@ -284,7 +294,10 @@
|
|||||||
:to current-chat-id
|
:to current-chat-id
|
||||||
:from identity
|
:from identity
|
||||||
:content-type text-content-type
|
:content-type text-content-type
|
||||||
:outgoing true})))))
|
:outgoing true
|
||||||
|
;; todo should be refactored
|
||||||
|
:same-author false
|
||||||
|
:same-direction false})))))
|
||||||
|
|
||||||
(defn prepare-command [identity chat-id staged-command]
|
(defn prepare-command [identity chat-id staged-command]
|
||||||
(let [command-key (get-in staged-command [:command :command])
|
(let [command-key (get-in staged-command [:command :command])
|
||||||
|
@ -20,15 +20,16 @@
|
|||||||
(when-let [last-msg-id (:last-msg-id chat)]
|
(when-let [last-msg-id (:last-msg-id chat)]
|
||||||
(r/single-cljs (r/get-by-field :msgs :msg-id last-msg-id))))
|
(r/single-cljs (r/get-by-field :msgs :msg-id last-msg-id))))
|
||||||
|
|
||||||
(defn save-message [chat-id {:keys [from to msg-id content content-type outgoing] :or {outgoing false
|
(defn save-message
|
||||||
|
[chat-id {:keys [from to msg-id content content-type outgoing
|
||||||
|
same-author same-direction]
|
||||||
|
:or {outgoing false
|
||||||
to nil} :as msg}]
|
to nil} :as msg}]
|
||||||
(log/debug "save-message" chat-id msg)
|
(log/debug "save-message" chat-id msg)
|
||||||
(when-not (r/exists? :msgs :msg-id msg-id)
|
(when-not (r/exists? :msgs :msg-id msg-id)
|
||||||
(r/write
|
(r/write
|
||||||
(fn []
|
(fn []
|
||||||
(let [chat (r/single-cljs (r/get-by-field :chats :chat-id chat-id))
|
(let [content (if (string? content)
|
||||||
last-message (select-chat-last-message chat)
|
|
||||||
content (if (string? content)
|
|
||||||
content
|
content
|
||||||
(map-to-str content))]
|
(map-to-str content))]
|
||||||
(r/create :msgs {:chat-id chat-id
|
(r/create :msgs {:chat-id chat-id
|
||||||
@ -40,15 +41,8 @@
|
|||||||
:outgoing outgoing
|
:outgoing outgoing
|
||||||
:timestamp (timestamp)
|
:timestamp (timestamp)
|
||||||
:delivery-status nil
|
:delivery-status nil
|
||||||
:same-author (if last-message
|
:same-author same-author
|
||||||
(= (:from last-message) from)
|
:same-direction same-direction} true))))))
|
||||||
true)
|
|
||||||
:same-direction (if last-message
|
|
||||||
(= (:outgoing last-message) outgoing)
|
|
||||||
true)} true)
|
|
||||||
(r/create :chats {:chat-id (:chat-id chat)
|
|
||||||
:last-msg-id msg-id}
|
|
||||||
true))))))
|
|
||||||
|
|
||||||
(defn get-messages [chat-id]
|
(defn get-messages [chat-id]
|
||||||
(->> (-> (r/get-by-field :msgs :chat-id chat-id)
|
(->> (-> (r/get-by-field :msgs :chat-id chat-id)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user