From 0b8356a96e8798a336780cdecab36825c1cf56dd Mon Sep 17 00:00:00 2001 From: janherich Date: Tue, 13 Feb 2018 17:11:55 +0100 Subject: [PATCH] Fetch short preview during sending --- src/status_im/chat/events/input.cljs | 49 ++++++++++-------- .../ui/screens/home/views/inner_item.cljs | 50 +++++++------------ 2 files changed, 47 insertions(+), 52 deletions(-) diff --git a/src/status_im/chat/events/input.cljs b/src/status_im/chat/events/input.cljs index f33fc2e9f2..61a5e1e4cd 100644 --- a/src/status_im/chat/events/input.cljs +++ b/src/status_im/chat/events/input.cljs @@ -2,7 +2,7 @@ (:require [clojure.string :as string] [re-frame.core :as re-frame] [taoensso.timbre :as log] - [status-im.chat.constants :as constants] + [status-im.chat.constants :as constants] [status-im.chat.models :as model] [status-im.chat.models.input :as input-model] [status-im.chat.models.commands :as commands-model] @@ -277,29 +277,36 @@ :proceed-event-creator (partial event-after-creator command-message)}))) +;; TODO (janherich) request-command-data functions and event need to be refactored, they are needlessly complicated (defn proceed-command "Proceed with command processing by setting up and executing chain of events: 1. Params validation - 2. Preview fetching" + 2. Short preview fetching + 3. Preview fetching" [{:keys [current-chat-id chats] :as db} {{:keys [bot]} :command :as content} message-id current-time] - (let [params-template {:content content - :chat-id current-chat-id - :group-id (when (get-in chats [current-chat-id :group-chat]) - current-chat-id) - :jail-id (or bot current-chat-id) - :message-id message-id - :current-time current-time} - preview-params (merge params-template - {:data-type :preview - :event-after-creator (fn [command-message jail-response] - [::send-command - (assoc-in command-message [:command :preview] jail-response)])}) - validation-params (merge params-template - {:data-type :validator - :event-after-creator (fn [_ jail-response] - [::proceed-validation - jail-response - [[::request-command-data preview-params]]])})] + (let [params-template {:content content + :chat-id current-chat-id + :group-id (when (get-in chats [current-chat-id :group-chat]) + current-chat-id) + :jail-id (or bot current-chat-id) + :message-id message-id + :current-time current-time} + preview-params (merge params-template + {:data-type :preview + :event-after-creator (fn [command-message jail-response] + [::send-command + (assoc-in command-message [:command :preview] jail-response)])}) + short-preview-params (merge params-template + {:data-type :short-preview + :event-after-creator (fn [_ jail-response] + [::request-command-data + (assoc-in preview-params [:content :command :short-preview] jail-response)])}) + validation-params (merge params-template + {:data-type :validator + :event-after-creator (fn [_ jail-response] + [::proceed-validation + jail-response + [[::request-command-data short-preview-params]]])})] (request-command-data db validation-params))) ;;;; Handlers @@ -443,7 +450,7 @@ (handlers/register-handler-fx :send-current-message - message-model/send-interceptors + message-model/send-interceptors (fn [{{:keys [current-chat-id current-public-key] :as db} :db message-id :random-id current-time :now :as cofx} _] (when-not (get-in db [:chat-ui-props current-chat-id :sending-in-progress?]) diff --git a/src/status_im/ui/screens/home/views/inner_item.cljs b/src/status_im/ui/screens/home/views/inner_item.cljs index 190ccef969..bb73836121 100644 --- a/src/status_im/ui/screens/home/views/inner_item.cljs +++ b/src/status_im/ui/screens/home/views/inner_item.cljs @@ -16,42 +16,30 @@ [taoensso.timbre :as log] [status-im.ui.components.chat-icon.screen :as chat-icon.screen])) -(defn message-content-text [{:keys [content] :as message}] - (reagent/create-class - {:display-name "message-content-text" - :component-will-mount - #(when (and (or (:command content) - (:content-command content)) - (not (:short-preview content))) - (re-frame/dispatch [:request-command-message-data message - {:data-type :short-preview - :cache-data? true}])) - :reagent-render - (fn [{:keys [content] :as message}] - [react/view styles/last-message-container - (cond +(defn message-content-text [{:keys [content] :as message}] + [react/view styles/last-message-container + (cond - (not message) - [react/text {:style styles/last-message-text} - (i18n/label :t/no-messages)] + (not message) + [react/text {:style styles/last-message-text} + (i18n/label :t/no-messages)] - (str/blank? content) - [react/text {:style styles/last-message-text} - ""] + (str/blank? content) + [react/text {:style styles/last-message-text} + ""] - (:content content) - [react/text {:style styles/last-message-text - :number-of-lines 1} - (:content content)] + (:content content) + [react/text {:style styles/last-message-text + :number-of-lines 1} + (:content content)] - (and (:command content) - (-> content :short-preview :markup)) - (commands-utils/generate-hiccup (-> content :short-preview :markup)) + (and (:command content) (-> content :short-preview :markup)) + (commands-utils/generate-hiccup (-> content :short-preview :markup)) - :else - [react/text {:style styles/last-message-text - :number-of-lines 1} - content])])})) + :else + [react/text {:style styles/last-message-text + :number-of-lines 1} + content])]) (defview message-status [{:keys [chat-id contacts]} {:keys [message-id user-statuses outgoing] :as msg}]