From 0c1ec9a56e6c7c7f1f4402657cf6defde3a2c17d Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 9 May 2016 18:17:40 +0300 Subject: [PATCH 01/26] chat's views & styles Former-commit-id: 6932f1c1031b45b4a8ed10249bb610c654f427db --- src/syng_im/android/core.cljs | 8 +++---- .../chat.cljs => chat/screen.cljs} | 8 +++---- .../styles/chat.cljs} | 2 +- .../styles/message.cljs} | 17 +------------ .../views/message.cljs} | 4 ++-- .../views/new_message.cljs} | 4 ++-- src/syng_im/participants/styles.cljs | 24 +++++++++++++++++++ .../views/contact.cljs} | 21 +++++++--------- .../views/new.cljs} | 24 +++++++++---------- .../views/remove.cljs} | 22 ++++++++--------- 10 files changed, 69 insertions(+), 65 deletions(-) rename src/syng_im/{components/chat.cljs => chat/screen.cljs} (96%) rename src/syng_im/{components/chat_styles.cljs => chat/styles/chat.cljs} (99%) rename src/syng_im/{components/chat/chat_message_styles.cljs => chat/styles/message.cljs} (95%) rename src/syng_im/{components/chat/chat_message.cljs => chat/views/message.cljs} (98%) rename src/syng_im/{components/chat/chat_message_new.cljs => chat/views/new_message.cljs} (94%) create mode 100644 src/syng_im/participants/styles.cljs rename src/syng_im/{components/chats/new_participant_contact.cljs => participants/views/contact.cljs} (50%) rename src/syng_im/{components/chat/new_participants.cljs => participants/views/new.cljs} (59%) rename src/syng_im/{components/chat/remove_participants.cljs => participants/views/remove.cljs} (66%) diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index a8cf5785f9..329d9081e8 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -8,11 +8,11 @@ [syng-im.subs] [syng-im.components.react :refer [navigator app-registry]] [syng-im.components.contact-list.contact-list :refer [contact-list]] - [syng-im.components.chat :refer [chat]] + [syng-im.chat.screen :refer [chat]] [syng-im.components.chats.chats-list :refer [chats-list]] [syng-im.components.chats.new-group :refer [new-group]] - [syng-im.components.chat.new-participants :refer [new-participants]] - [syng-im.components.chat.remove-participants :refer [remove-participants]] + [syng-im.participants.views.new :refer [new-participants]] + [syng-im.participants.views.remove :refer [remove-participants]] [syng-im.utils.logging :as log] [syng-im.utils.utils :refer [toast]] [syng-im.navigation :as nav] @@ -34,7 +34,7 @@ (defn app-root [] (let [signed-up (subscribe [:signed-up]) - view-id (subscribe [:view-id])] + view-id (subscribe [:view-id])] (fn [] (case (if @signed-up @view-id :chat) :add-participants [new-participants] diff --git a/src/syng_im/components/chat.cljs b/src/syng_im/chat/screen.cljs similarity index 96% rename from src/syng_im/components/chat.cljs rename to src/syng_im/chat/screen.cljs index 9607463a93..579cd44da0 100644 --- a/src/syng_im/components/chat.cljs +++ b/src/syng_im/chat/screen.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat +(ns syng-im.chat.screen (:require [clojure.string :as s] [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.components.react :refer [view @@ -11,15 +11,15 @@ list-view list-item android?]] - [syng-im.components.chat-styles :as st] + [syng-im.chat.styles.chat :as st] [syng-im.utils.logging :as log] [syng-im.resources :as res] [syng-im.constants :refer [content-type-status]] [syng-im.utils.listview :refer [to-datasource to-datasource2]] [syng-im.components.invertible-scroll-view :refer [invertible-scroll-view]] - [syng-im.components.chat.chat-message :refer [chat-message]] - [syng-im.components.chat.chat-message-new :refer [chat-message-new]])) + [syng-im.chat.views.message :refer [chat-message]] + [syng-im.chat.views.new-message :refer [chat-message-new]])) (defn contacts-by-identity [contacts] (->> contacts diff --git a/src/syng_im/components/chat_styles.cljs b/src/syng_im/chat/styles/chat.cljs similarity index 99% rename from src/syng_im/components/chat_styles.cljs rename to src/syng_im/chat/styles/chat.cljs index f66e57ed89..9ebf92eadb 100644 --- a/src/syng_im/components/chat_styles.cljs +++ b/src/syng_im/chat/styles/chat.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat-styles +(ns syng-im.chat.styles.chat (:require [syng-im.components.styles :refer [font title-font color-white diff --git a/src/syng_im/components/chat/chat_message_styles.cljs b/src/syng_im/chat/styles/message.cljs similarity index 95% rename from src/syng_im/components/chat/chat_message_styles.cljs rename to src/syng_im/chat/styles/message.cljs index c336fbb8d5..356419841b 100644 --- a/src/syng_im/components/chat/chat_message_styles.cljs +++ b/src/syng_im/chat/styles/message.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat.chat-message-styles +(ns syng-im.chat.styles.message (:require [syng-im.components.styles :refer [font color-light-blue-transparent color-white @@ -312,18 +312,3 @@ (def new-message-container {:backgroundColor color-white :elevation 4}) - -(def participants-container - {:flex 1 - :backgroundColor :white}) - -(def participants-list - {:backgroundColor :white}) - -(def new-participant-image - {:width 20 - :height 18}) - -(def remove-participants-image - {:width 22 - :height 30}) diff --git a/src/syng_im/components/chat/chat_message.cljs b/src/syng_im/chat/views/message.cljs similarity index 98% rename from src/syng_im/components/chat/chat_message.cljs rename to src/syng_im/chat/views/message.cljs index cbf794972b..a65cd07825 100644 --- a/src/syng_im/components/chat/chat_message.cljs +++ b/src/syng_im/chat/views/message.cljs @@ -1,11 +1,11 @@ -(ns syng-im.components.chat.chat-message +(ns syng-im.chat.views.message (:require [clojure.string :as s] [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view text image touchable-highlight]] - [syng-im.components.chat.chat-message-styles :as st] + [syng-im.chat.styles.message :as st] [syng-im.models.commands :refer [parse-command-msg-content parse-command-request]] [syng-im.resources :as res] diff --git a/src/syng_im/components/chat/chat_message_new.cljs b/src/syng_im/chat/views/new_message.cljs similarity index 94% rename from src/syng_im/components/chat/chat_message_new.cljs rename to src/syng_im/chat/views/new_message.cljs index 545d0052b7..75c28662e0 100644 --- a/src/syng_im/components/chat/chat_message_new.cljs +++ b/src/syng_im/chat/views/new_message.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat.chat-message-new +(ns syng-im.chat.views.new-message (:require [re-frame.core :refer [subscribe]] [syng-im.components.react :refer [view]] @@ -9,7 +9,7 @@ [syng-im.components.chat.input.confirmation-code :refer [confirmation-code-input-view]] [syng-im.components.chat.input.money :refer [money-input-view]] [syng-im.components.chat.input.simple-command-staged :refer [simple-command-staged-view]] - [syng-im.components.chat.chat-message-styles :as st])) + [syng-im.chat.styles.message :as st])) (defn staged-command-view [stage-command] [simple-command-staged-view stage-command]) diff --git a/src/syng_im/participants/styles.cljs b/src/syng_im/participants/styles.cljs new file mode 100644 index 0000000000..482436f30a --- /dev/null +++ b/src/syng_im/participants/styles.cljs @@ -0,0 +1,24 @@ +(ns syng-im.participants.styles) + +(def participants-container + {:flex 1 + :backgroundColor :white}) + +(def participants-list + {:backgroundColor :white}) + +(def new-participant-image + {:width 20 + :height 18}) + +(def remove-participants-image + {:width 22 + :height 30}) + +(def participant-container + {:flexDirection :row + :marginTop 5 + :marginBottom 5 + :paddingLeft 15 + :paddingRight 15 + :height 75}) diff --git a/src/syng_im/components/chats/new_participant_contact.cljs b/src/syng_im/participants/views/contact.cljs similarity index 50% rename from src/syng_im/components/chats/new_participant_contact.cljs rename to src/syng_im/participants/views/contact.cljs index 97985c6468..0309fee299 100644 --- a/src/syng_im/components/chats/new_participant_contact.cljs +++ b/src/syng_im/participants/views/contact.cljs @@ -1,21 +1,16 @@ -(ns syng-im.components.chats.new-participant-contact - (:require [syng-im.resources :as res] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] +(ns syng-im.participants.views.contact + (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.components.react :refer [view]] [syng-im.components.contact-list.contact-inner :refer [contact-inner-view]] [syng-im.components.item-checkbox :refer [item-checkbox]] - [syng-im.utils.logging :as log] - [reagent.core :as r])) + [reagent.core :as r] + [syng-im.participants.styles :as st])) -(defn new-participant-contact [{:keys [whisper-identity] :as contact} navigator] +(defn participant-contact [{:keys [whisper-identity] :as contact}] + ;; todo must be moved to handlers (let [checked (r/atom false)] - (fn [] - [view {:style {:flexDirection "row" - :marginTop 5 - :marginBottom 5 - :paddingLeft 15 - :paddingRight 15 - :height 75}} + (fn [{:keys [whisper-identity] :as contact}] + [view st/participant-container [item-checkbox {:onToggle (fn [checked?] (reset! checked checked?) (dispatch [:select-new-participant whisper-identity checked?])) diff --git a/src/syng_im/components/chat/new_participants.cljs b/src/syng_im/participants/views/new.cljs similarity index 59% rename from src/syng_im/components/chat/new_participants.cljs rename to src/syng_im/participants/views/new.cljs index 91beecf10a..f5073a7879 100644 --- a/src/syng_im/components/chat/new_participants.cljs +++ b/src/syng_im/participants/views/new.cljs @@ -1,27 +1,27 @@ -(ns syng-im.components.chat.new-participants +(ns syng-im.participants.views.new (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.resources :as res] [syng-im.components.react :refer [view]] [syng-im.components.realm :refer [list-view]] [syng-im.components.toolbar :refer [toolbar]] [syng-im.utils.listview :refer [to-realm-datasource]] - [syng-im.components.chats.new-participant-contact - :refer [new-participant-contact]] + [syng-im.participants.views.contact + :refer [participant-contact]] [reagent.core :as r] - [syng-im.components.chat.chat-message-styles :as st])) + [syng-im.participants.styles :as st])) (defn new-participants-toolbar [navigator] [toolbar {:navigator navigator :title "Add Participants" - :action {:image {:source res/v ;; {:uri "icon_search"} + :action {:image {:source res/v ;; {:uri "icon_search"} :style st/new-participant-image} :handler #(dispatch [:add-new-participants navigator])}}]) -(defn new-participants-row [navigator] - (fn [row _ _] - (r/as-element - [new-participant-contact (js->clj row :keywordize-keys true) navigator]))) +(defn new-participants-row + [row _ _] + (r/as-element + [participant-contact (js->clj row :keywordize-keys true)])) (defn new-participants [{:keys [navigator]}] (let [contacts (subscribe [:all-new-contacts])] @@ -29,7 +29,7 @@ (let [contacts-ds (to-realm-datasource @contacts)] [view st/participants-container [new-participants-toolbar navigator] - [list-view {:dataSource contacts-ds + [list-view {:dataSource contacts-ds :enableEmptySections true - :renderRow (new-participants-row navigator) - :style st/participants-list}]])))) + :renderRow new-participants-row + :style st/participants-list}]])))) diff --git a/src/syng_im/components/chat/remove_participants.cljs b/src/syng_im/participants/views/remove.cljs similarity index 66% rename from src/syng_im/components/chat/remove_participants.cljs rename to src/syng_im/participants/views/remove.cljs index d9c5053c2d..d475406c8a 100644 --- a/src/syng_im/components/chat/remove_participants.cljs +++ b/src/syng_im/participants/views/remove.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat.remove-participants +(ns syng-im.participants.views.remove (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.resources :as res] [syng-im.components.react :refer [view text-input text image @@ -6,10 +6,10 @@ [syng-im.components.realm :refer [list-view]] [syng-im.components.toolbar :refer [toolbar]] [syng-im.utils.listview :refer [to-realm-datasource]] - [syng-im.components.chats.new-participant-contact - :refer [new-participant-contact]] + [syng-im.participants.views.contact + :refer [participant-contact]] [reagent.core :as r] - [syng-im.components.chat.chat-message-styles :as st])) + [syng-im.participants.styles :as st])) (defn remove-participants-toolbar [navigator] [toolbar @@ -19,10 +19,10 @@ :image {:source res/trash-icon ;; {:uri "icon_search"} :style st/remove-participants-image}}}]) -(defn remove-participants-row [navigator] - (fn [row _ _] - (r/as-element - [new-participant-contact (js->clj row :keywordize-keys true) navigator]))) +(defn remove-participants-row + [row _ _] + (r/as-element + [participant-contact (js->clj row :keywordize-keys true)])) (defn remove-participants [{:keys [navigator]}] (let [contacts (subscribe [:current-chat-contacts])] @@ -30,7 +30,7 @@ (let [contacts-ds (to-realm-datasource @contacts)] [view st/participants-container [remove-participants-toolbar navigator] - [list-view {:dataSource contacts-ds + [list-view {:dataSource contacts-ds :enableEmptySections true - :renderRow (remove-participants-row navigator) - :style st/participants-list}]])))) + :renderRow remove-participants-row + :style st/participants-list}]])))) From 3be2f2c06ce295e7b1559368c2af94b4541e117c Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 9 May 2016 19:28:40 +0300 Subject: [PATCH 02/26] chat inputs/suggestions/commands Former-commit-id: 4b1b5a944960decb7f8e10de9fba70536650a242 --- src/syng_im/android/core.cljs | 2 +- .../input => chat/styles}/input_styles.cljs | 2 +- .../styles/plain_input.cljs} | 2 +- .../styles/suggestions.cljs} | 2 +- .../views/command.cljs} | 4 +-- src/syng_im/chat/views/confirmation_code.cljs | 6 +++++ src/syng_im/chat/views/money.cljs | 9 +++++++ src/syng_im/chat/views/new_message.cljs | 14 +++++------ .../chat/input => chat/views}/password.cljs | 4 +-- .../chat/input => chat/views}/phone.cljs | 4 +-- .../views/plain_input.cljs} | 6 ++--- .../views/staged_command.cljs} | 4 +-- .../chat => chat/views}/suggestions.cljs | 25 ++++++++++--------- .../chat/input/confirmation_code.cljs | 7 ------ src/syng_im/components/chat/input/money.cljs | 10 -------- .../views/{new.cljs => create.cljs} | 2 +- 16 files changed, 51 insertions(+), 52 deletions(-) rename src/syng_im/{components/chat/input => chat/styles}/input_styles.cljs (98%) rename src/syng_im/{components/chat/plain_message_input_styles.cljs => chat/styles/plain_input.cljs} (94%) rename src/syng_im/{components/chat/suggestions_styles.cljs => chat/styles/suggestions.cljs} (95%) rename src/syng_im/{components/chat/input/simple_command.cljs => chat/views/command.cljs} (93%) create mode 100644 src/syng_im/chat/views/confirmation_code.cljs create mode 100644 src/syng_im/chat/views/money.cljs rename src/syng_im/{components/chat/input => chat/views}/password.cljs (62%) rename src/syng_im/{components/chat/input => chat/views}/phone.cljs (63%) rename src/syng_im/{components/chat/plain_message_input.cljs => chat/views/plain_input.cljs} (89%) rename src/syng_im/{components/chat/input/simple_command_staged.cljs => chat/views/staged_command.cljs} (90%) rename src/syng_im/{components/chat => chat/views}/suggestions.cljs (62%) delete mode 100644 src/syng_im/components/chat/input/confirmation_code.cljs delete mode 100644 src/syng_im/components/chat/input/money.cljs rename src/syng_im/participants/views/{new.cljs => create.cljs} (97%) diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index 329d9081e8..c2d44af2a6 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -11,7 +11,7 @@ [syng-im.chat.screen :refer [chat]] [syng-im.components.chats.chats-list :refer [chats-list]] [syng-im.components.chats.new-group :refer [new-group]] - [syng-im.participants.views.new :refer [new-participants]] + [syng-im.participants.views.create :refer [new-participants]] [syng-im.participants.views.remove :refer [remove-participants]] [syng-im.utils.logging :as log] [syng-im.utils.utils :refer [toast]] diff --git a/src/syng_im/components/chat/input/input_styles.cljs b/src/syng_im/chat/styles/input_styles.cljs similarity index 98% rename from src/syng_im/components/chat/input/input_styles.cljs rename to src/syng_im/chat/styles/input_styles.cljs index c5debbcafd..f282ad1fc5 100644 --- a/src/syng_im/components/chat/input/input_styles.cljs +++ b/src/syng_im/chat/styles/input_styles.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat.input.input-styles +(ns syng-im.chat.styles.input (:require [syng-im.components.styles :refer [font color-white color-blue diff --git a/src/syng_im/components/chat/plain_message_input_styles.cljs b/src/syng_im/chat/styles/plain_input.cljs similarity index 94% rename from src/syng_im/components/chat/plain_message_input_styles.cljs rename to src/syng_im/chat/styles/plain_input.cljs index 01b90f2bf8..944d9f0c63 100644 --- a/src/syng_im/components/chat/plain_message_input_styles.cljs +++ b/src/syng_im/chat/styles/plain_input.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat.plain-message-input-styles +(ns syng-im.chat.styles.plain-input (:require [syng-im.components.styles :refer [font text2-color color-white diff --git a/src/syng_im/components/chat/suggestions_styles.cljs b/src/syng_im/chat/styles/suggestions.cljs similarity index 95% rename from src/syng_im/components/chat/suggestions_styles.cljs rename to src/syng_im/chat/styles/suggestions.cljs index 80ae964e68..c6a7f959b2 100644 --- a/src/syng_im/components/chat/suggestions_styles.cljs +++ b/src/syng_im/chat/styles/suggestions.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat.suggestions-styles +(ns syng-im.chat.styles.suggestions (:require [syng-im.components.styles :refer [font color-white]])) (def suggestion-item-container diff --git a/src/syng_im/components/chat/input/simple_command.cljs b/src/syng_im/chat/views/command.cljs similarity index 93% rename from src/syng_im/components/chat/input/simple_command.cljs rename to src/syng_im/chat/views/command.cljs index 53982f762a..c77ef93de8 100644 --- a/src/syng_im/components/chat/input/simple_command.cljs +++ b/src/syng_im/chat/views/command.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat.input.simple-command +(ns syng-im.chat.views.command (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.components.react :refer [view image @@ -7,7 +7,7 @@ text-input touchable-highlight]] [syng-im.resources :as res] - [syng-im.components.chat.input.input-styles :as st])) + [syng-im.chat.styles.input :as st])) (defn cancel-command-input [] (dispatch [:cancel-command])) diff --git a/src/syng_im/chat/views/confirmation_code.cljs b/src/syng_im/chat/views/confirmation_code.cljs new file mode 100644 index 0000000000..9e98fb9c46 --- /dev/null +++ b/src/syng_im/chat/views/confirmation_code.cljs @@ -0,0 +1,6 @@ +(ns syng-im.chat.views.confirmation-code + (:require + [syng-im.chat.views.command :refer [simple-command-input-view]])) + +(defn confirmation-code-input-view [command] + [simple-command-input-view command {:keyboardType :numeric}]) diff --git a/src/syng_im/chat/views/money.cljs b/src/syng_im/chat/views/money.cljs new file mode 100644 index 0000000000..7166476cf0 --- /dev/null +++ b/src/syng_im/chat/views/money.cljs @@ -0,0 +1,9 @@ +(ns syng-im.chat.views.money + (:require + [syng-im.chat.views.command :refer [simple-command-input-view]] + [syng-im.chat.styles.input :as st])) + +(defn money-input-view [command] + [simple-command-input-view command + {:keyboardType :numeric + :style st/money-input}]) diff --git a/src/syng_im/chat/views/new_message.cljs b/src/syng_im/chat/views/new_message.cljs index 75c28662e0..988e0de9d6 100644 --- a/src/syng_im/chat/views/new_message.cljs +++ b/src/syng_im/chat/views/new_message.cljs @@ -2,13 +2,13 @@ (:require [re-frame.core :refer [subscribe]] [syng-im.components.react :refer [view]] - [syng-im.components.chat.plain-message-input :refer [plain-message-input-view]] - [syng-im.components.chat.input.simple-command :refer [simple-command-input-view]] - [syng-im.components.chat.input.phone :refer [phone-input-view]] - [syng-im.components.chat.input.password :refer [password-input-view]] - [syng-im.components.chat.input.confirmation-code :refer [confirmation-code-input-view]] - [syng-im.components.chat.input.money :refer [money-input-view]] - [syng-im.components.chat.input.simple-command-staged :refer [simple-command-staged-view]] + [syng-im.chat.views.plain-input :refer [plain-message-input-view]] + [syng-im.chat.views.command :refer [simple-command-input-view]] + [syng-im.chat.views.phone :refer [phone-input-view]] + [syng-im.chat.views.password :refer [password-input-view]] + [syng-im.chat.views.confirmation-code :refer [confirmation-code-input-view]] + [syng-im.chat.views.money :refer [money-input-view]] + [syng-im.chat.views.staged-command :refer [simple-command-staged-view]] [syng-im.chat.styles.message :as st])) (defn staged-command-view [stage-command] diff --git a/src/syng_im/components/chat/input/password.cljs b/src/syng_im/chat/views/password.cljs similarity index 62% rename from src/syng_im/components/chat/input/password.cljs rename to src/syng_im/chat/views/password.cljs index 8385fa2c1c..253464ce0c 100644 --- a/src/syng_im/components/chat/input/password.cljs +++ b/src/syng_im/chat/views/password.cljs @@ -1,6 +1,6 @@ -(ns syng-im.components.chat.input.password +(ns syng-im.chat.views.password (:require - [syng-im.components.chat.input.simple-command + [syng-im.chat.views.command :refer [simple-command-input-view]])) (defn password-input-view [command] diff --git a/src/syng_im/components/chat/input/phone.cljs b/src/syng_im/chat/views/phone.cljs similarity index 63% rename from src/syng_im/components/chat/input/phone.cljs rename to src/syng_im/chat/views/phone.cljs index 267178e382..20b7c756ac 100644 --- a/src/syng_im/components/chat/input/phone.cljs +++ b/src/syng_im/chat/views/phone.cljs @@ -1,6 +1,6 @@ -(ns syng-im.components.chat.input.phone +(ns syng-im.chat.views.phone (:require - [syng-im.components.chat.input.simple-command + [syng-im.chat.views.command :refer [simple-command-input-view]])) (defn phone-input-view [command] diff --git a/src/syng_im/components/chat/plain_message_input.cljs b/src/syng_im/chat/views/plain_input.cljs similarity index 89% rename from src/syng_im/components/chat/plain_message_input.cljs rename to src/syng_im/chat/views/plain_input.cljs index f90fa057cc..ec8a88672b 100644 --- a/src/syng_im/components/chat/plain_message_input.cljs +++ b/src/syng_im/chat/views/plain_input.cljs @@ -1,11 +1,11 @@ -(ns syng-im.components.chat.plain-message-input +(ns syng-im.chat.views.plain-input (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.components.react :refer [view icon touchable-highlight text-input]] - [syng-im.components.chat.suggestions :refer [suggestions-view]] - [syng-im.components.chat.plain-message-input-styles :as st])) + [syng-im.chat.views.suggestions :refer [suggestions-view]] + [syng-im.chat.styles.plain-input :as st])) (defn set-input-message [message] (dispatch [:set-chat-input-text message])) diff --git a/src/syng_im/components/chat/input/simple_command_staged.cljs b/src/syng_im/chat/views/staged_command.cljs similarity index 90% rename from src/syng_im/components/chat/input/simple_command_staged.cljs rename to src/syng_im/chat/views/staged_command.cljs index a2e0b571ee..c7a0b50568 100644 --- a/src/syng_im/components/chat/input/simple_command_staged.cljs +++ b/src/syng_im/chat/views/staged_command.cljs @@ -1,11 +1,11 @@ -(ns syng-im.components.chat.input.simple-command-staged +(ns syng-im.chat.views.staged-command (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view image text touchable-highlight]] [syng-im.resources :as res] - [syng-im.components.chat.input.input-styles :as st])) + [syng-im.chat.styles.input :as st])) (defn cancel-command-input [staged-command] (dispatch [:unstage-command staged-command])) diff --git a/src/syng_im/components/chat/suggestions.cljs b/src/syng_im/chat/views/suggestions.cljs similarity index 62% rename from src/syng_im/components/chat/suggestions.cljs rename to src/syng_im/chat/views/suggestions.cljs index b1bbd0d75e..97461c2741 100644 --- a/src/syng_im/components/chat/suggestions.cljs +++ b/src/syng_im/chat/views/suggestions.cljs @@ -1,6 +1,6 @@ -(ns syng-im.components.chat.suggestions +(ns syng-im.chat.views.suggestions (:require-macros - [natal-shell.core :refer [with-error-view]]) + [natal-shell.core :refer [with-error-view]]) (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view text @@ -8,20 +8,21 @@ list-view list-item]] [syng-im.utils.listview :refer [to-datasource]] - [syng-im.components.chat.suggestions-styles :as st])) + [syng-im.chat.styles.suggestions :as st])) (defn set-command-input [command] (dispatch [:set-chat-command command])) -(defn suggestion-list-item [suggestion] +(defn suggestion-list-item + [{:keys [description command] + label :text + :as suggestion}] [touchable-highlight - {:onPress #(set-command-input (keyword (:command suggestion)))} + {:onPress #(set-command-input (keyword command))} [view st/suggestion-item-container [view (st/suggestion-background suggestion) - [text {:style st/suggestion-text} - (:text suggestion)]] - [text {:style st/suggestion-description} - (:description suggestion)]]]) + [text {:style st/suggestion-text} label]] + [text {:style st/suggestion-description} description]]]) (defn render-row [row _ _] (list-item [suggestion-list-item (js->clj row :keywordize-keys true)])) @@ -32,7 +33,7 @@ (let [suggestions @suggestions-atom] (when (seq suggestions) [view (st/suggestions-container suggestions) - [list-view {:dataSource (to-datasource suggestions) + [list-view {:dataSource (to-datasource suggestions) :enableEmptySections true - :renderRow render-row - :style {}}]]))))) + :renderRow render-row + :style {}}]]))))) diff --git a/src/syng_im/components/chat/input/confirmation_code.cljs b/src/syng_im/components/chat/input/confirmation_code.cljs deleted file mode 100644 index 7ba41043d6..0000000000 --- a/src/syng_im/components/chat/input/confirmation_code.cljs +++ /dev/null @@ -1,7 +0,0 @@ -(ns syng-im.components.chat.input.confirmation-code - (:require - [syng-im.components.chat.input.simple-command - :refer [simple-command-input-view]])) - -(defn confirmation-code-input-view [command] - [simple-command-input-view command {:keyboardType :numeric}]) diff --git a/src/syng_im/components/chat/input/money.cljs b/src/syng_im/components/chat/input/money.cljs deleted file mode 100644 index be53c5dbc2..0000000000 --- a/src/syng_im/components/chat/input/money.cljs +++ /dev/null @@ -1,10 +0,0 @@ -(ns syng-im.components.chat.input.money - (:require - [syng-im.components.chat.input.simple-command - :refer [simple-command-input-view]] - [syng-im.components.chat.input.input-styles :as st])) - -(defn money-input-view [command] - [simple-command-input-view command - {:keyboardType :numeric - :style st/money-input}]) diff --git a/src/syng_im/participants/views/new.cljs b/src/syng_im/participants/views/create.cljs similarity index 97% rename from src/syng_im/participants/views/new.cljs rename to src/syng_im/participants/views/create.cljs index f5073a7879..38729add4b 100644 --- a/src/syng_im/participants/views/new.cljs +++ b/src/syng_im/participants/views/create.cljs @@ -1,4 +1,4 @@ -(ns syng-im.participants.views.new +(ns syng-im.participants.views.create (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.resources :as res] [syng-im.components.react :refer [view]] From 8a99e2a614a38f5e3beaf89577549edff26c2a0c Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Tue, 10 May 2016 13:58:37 +0300 Subject: [PATCH 03/26] chat & navigation handlers/subs Former-commit-id: f429a15be874f45a3c04cf220b19bea8aa5277b7 --- src/syng_im/android/core.cljs | 2 +- src/syng_im/chat/handlers.cljs | 287 +++++++++++++++++++++ src/syng_im/chat/screen.cljs | 16 +- src/syng_im/chat/subs.cljs | 78 ++++++ src/syng_im/chat/views/command.cljs | 2 +- src/syng_im/chat/views/plain_input.cljs | 2 +- src/syng_im/handlers.cljs | 317 +----------------------- src/syng_im/navigation/handlers.cljs | 17 ++ src/syng_im/navigation/subs.cljs | 7 + src/syng_im/subs.cljs | 87 +------ 10 files changed, 406 insertions(+), 409 deletions(-) create mode 100644 src/syng_im/chat/handlers.cljs create mode 100644 src/syng_im/chat/subs.cljs create mode 100644 src/syng_im/navigation/handlers.cljs create mode 100644 src/syng_im/navigation/subs.cljs diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index c2d44af2a6..87ceaf1e8b 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -27,7 +27,7 @@ ;; this listener and handle application's closing ;; in handlers (let [stack (subscribe [:navigation-stack])] - (when (< 1 (count stack)) + (when (< 1 (count @stack)) (dispatch [:navigate-back]) true)))] (add-event-listener "hardwareBackPress" new-listener))) diff --git a/src/syng_im/chat/handlers.cljs b/src/syng_im/chat/handlers.cljs new file mode 100644 index 0000000000..93196354c1 --- /dev/null +++ b/src/syng_im/chat/handlers.cljs @@ -0,0 +1,287 @@ +(ns syng-im.chat.handlers + (:require [syng-im.db :as db] + [re-frame.core :refer [register-handler enrich after debug]] + [syng-im.models.commands :as commands] + [clojure.string :as str] + [syng-im.models.chat :as chat] + [syng-im.handlers.suggestions :as suggestions] + [syng-im.protocol.api :as api] + [syng-im.models.messages :as messages] + [syng-im.constants :refer [text-content-type + content-type-command]] + [syng-im.utils.random :as random] + [syng-im.components.react :as r] + [syng-im.handlers.sign-up :as sign-up-service] + [syng-im.models.chats :as chats])) + +(register-handler :set-show-actions + (fn [db [_ show-actions]] + (assoc-in db db/show-actions-path show-actions))) + +(register-handler :load-more-messages + (fn [db _] + db + ;; TODO implement + #_(let [chat-id (get-in db [:chat :current-chat-id]) + messages [:chats chat-id :messages] + new-messages (gen-messages 10)] + (update-in db messages concat new-messages)))) + +(defn safe-trim [s] + (when (string? s) + (str/trim s))) + +(register-handler :cancel-command + (fn [{:keys [current-chat-id] :as db} _] + (-> db + (assoc-in [:chats current-chat-id :command-input] {}) + (update-in [:chats current-chat-id :input-text] safe-trim)))) + +(register-handler :set-chat-command-content + (fn [db [_ content]] + (commands/set-chat-command-content db content))) + +(register-handler :stage-command + (fn [{:keys [current-chat-id] :as db} _] + (let [db (chat/set-chat-input-text db nil) + {:keys [command content]} + (get-in db [:chats current-chat-id :command-input]) + command-info {:command command + :content content + :handler (:handler command)}] + (commands/stage-command db command-info)))) + +(register-handler :set-response-chat-command + (fn [db [_ to-msg-id command-key]] + (commands/set-response-chat-command db to-msg-id command-key))) + +(defn update-text [db [_ text]] + (chat/set-chat-input-text db text)) + +(defn update-command [db [_ text]] + (let [{:keys [command]} (suggestions/check-suggestion db text)] + (commands/set-chat-command db command))) + +(register-handler :set-chat-input-text + ((enrich update-command) update-text)) + +(register-handler :send-group-chat-msg + (fn [db [_ chat-id text]] + (let [{msg-id :msg-id + {from :from} :msg} (api/send-group-user-msg {:group-id chat-id + :content text}) + msg {:msg-id msg-id + :from from + :to nil + :content text + :content-type text-content-type + :outgoing true}] + (messages/save-message chat-id msg) + (chat/signal-chat-updated db chat-id)))) + +(defn console? [s] + (= "console" s)) + +(def not-console? + (complement console?)) + +(defn check-author-direction + [db chat-id {:keys [from outgoing] :as message}] + (let [previous-message (first (get-in db [:chats chat-id :messages]))] + (merge message + {:same-author (if previous-message + (= (:from previous-message) from) + true) + :same-direction (if previous-message + (= (:outgoing previous-message) outgoing) + true)}))) + +(defn add-message-to-db + [db chat-id message] + (let [messages [:chats chat-id :messages]] + (update-in db messages conj message))) + +(defn prepare-message + [{:keys [identity current-chat-id] :as db} _] + (let [text (get-in db [:chats current-chat-id :input-text]) + {:keys [command]} (suggestions/check-suggestion db (str text " ")) + message (check-author-direction + db current-chat-id + {:msg-id (random/id) + :chat-id current-chat-id + :content text + :to current-chat-id + :from identity + :content-type text-content-type + :outgoing true})] + (if command + (commands/set-chat-command db command) + (assoc db :new-message (when-not (str/blank? text) message))))) + +(defn prepare-command [identity chat-id staged-command] + (let [command-key (get-in staged-command [:command :command]) + content {:command (name command-key) + :content (:content staged-command)}] + {:msg-id (random/id) + :from identity + :to chat-id + :content content + :content-type content-type-command + :outgoing true + :handler (:handler staged-command)})) + +(defn prepare-staged-commans + [{:keys [current-chat-id identity] :as db} _] + (let [staged-commands (get-in db [:chats current-chat-id :staged-commands])] + (->> staged-commands + (map #(prepare-command identity current-chat-id %)) + ;todo this is wrong :( + (map #(check-author-direction db current-chat-id %)) + (assoc db :new-commands)))) + +(defn add-message + [{:keys [new-message current-chat-id] :as db}] + (if new-message + (add-message-to-db db current-chat-id new-message) + db)) + +(defn add-commands + [{:keys [new-commands current-chat-id] :as db}] + (reduce + #(add-message-to-db %1 current-chat-id %2) + db + new-commands)) + +(defn clear-input + [{:keys [current-chat-id new-message] :as db} _] + (if new-message + (assoc-in db [:chats current-chat-id :input-text] nil) + db)) + +(defn clear-staged-commands + [{:keys [current-chat-id] :as db} _] + (assoc-in db [:chats current-chat-id :staged-commands] [])) + +(defn send-message! + [{:keys [new-message current-chat-id]} _] + (when (and new-message (not-console? current-chat-id)) + (api/send-user-msg {:to current-chat-id + :content (:content new-message)}))) + +(defn save-message-to-realm! + [{:keys [new-message current-chat-id]} _] + (when new-message + (messages/save-message current-chat-id new-message))) + +(defn save-commands-to-realm! + [{:keys [new-commands current-chat-id]} _] + (doseq [new-command new-commands] + (messages/save-message current-chat-id (dissoc new-command :handler)))) + +(defn handle-commands + [{:keys [new-commands]}] + (doseq [{{content :content} :content + handler :handler} new-commands] + (when handler + (handler content)))) + +(register-handler :send-chat-msg + (-> prepare-message + ((enrich prepare-staged-commans)) + ((enrich add-message)) + ((enrich add-commands)) + ((enrich clear-input)) + ((enrich clear-staged-commands)) + ((after (fn [_ _] (r/dismiss-keyboard!)))) + ((after send-message!)) + ((after save-message-to-realm!)) + ((after save-commands-to-realm!)) + ((after handle-commands)))) + +(register-handler :unstage-command + (fn [db [_ staged-command]] + (let [] + (commands/unstage-command db staged-command)))) + +(register-handler :set-chat-command + (fn [db [_ command-key]] + ;; todo what is going on there?! + (commands/set-chat-command db command-key))) + +(register-handler :init-console-chat + (fn [db [_]] + (sign-up-service/init db))) + +(register-handler :save-password + (fn [db [_ password]] + (sign-up-service/save-password password) + (assoc db :password-saved true))) + +(register-handler :sign-up + (-> (fn [db [_ phone-number]] + (assoc db :user-phone-number phone-number)) + ((after (fn [& _] (sign-up-service/on-sign-up-response)))))) + +(register-handler :sign-up-confirm + (fn [db [_ confirmation-code]] + (sign-up-service/on-send-code-response confirmation-code) + db)) + +(register-handler :set-signed-up + (fn [db [_ signed-up]] + (sign-up-service/set-signed-up db signed-up))) + + +(defn load-messages! + [db _] + db + (->> (:current-chat-id db) + messages/get-messages + (assoc db :messages))) + +(defn init-chat + [{:keys [messages current-chat-id] :as db} _] + (assoc-in db [:chats current-chat-id :messages] messages)) + +(register-handler :init-chat + (-> load-messages! + ((enrich init-chat)) + debug)) + +(defn initialize-chats + [{:keys [loaded-chats] :as db} _] + (let [chats (->> loaded-chats + (map (fn [{:keys [chat-id] :as chat}] + [chat-id chat])) + (into {}))] + (-> db + (assoc :chats chats) + (dissoc :loaded-chats)))) + +(defn load-chats! + [db _] + (assoc db :loaded-chats (chats/chats-list))) + +(register-handler :initialize-chats + ((enrich initialize-chats) load-chats!)) + + +(defn store-message! + [{:keys [new-message]} [_ {chat-id :from}]] + (messages/save-message chat-id new-message)) + +(defn receive-message + [db [_ {chat-id :from :as message}]] + (let [message' (check-author-direction db chat-id message)] + (-> db + (add-message-to-db chat-id message') + (assoc :new-message message')))) + +(register-handler :received-msg + (-> receive-message + ((after store-message!)))) + +(register-handler :group-received-msg + (fn [db [_ {chat-id :group-id :as msg}]] + (messages/save-message chat-id msg) + (chat/signal-chat-updated db chat-id))) diff --git a/src/syng_im/chat/screen.cljs b/src/syng_im/chat/screen.cljs index 579cd44da0..116f012651 100644 --- a/src/syng_im/chat/screen.cljs +++ b/src/syng_im/chat/screen.cljs @@ -1,22 +1,16 @@ (ns syng-im.chat.screen (:require [clojure.string :as s] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] + [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view text image icon - navigator touchable-highlight - toolbar-android list-view - list-item - android?]] + list-item]] [syng-im.chat.styles.chat :as st] - [syng-im.utils.logging :as log] [syng-im.resources :as res] - [syng-im.constants :refer [content-type-status]] - [syng-im.utils.listview :refer [to-datasource - to-datasource2]] + [syng-im.utils.listview :refer [to-datasource2]] [syng-im.components.invertible-scroll-view :refer [invertible-scroll-view]] [syng-im.chat.views.message :refer [chat-message]] [syng-im.chat.views.new-message :refer [chat-message-new]])) @@ -29,8 +23,8 @@ (defn add-msg-color [{:keys [from] :as msg} contact-by-identity] (if (= "system" from) - (assoc msg :text-color "#4A5258" - :background-color "#D3EEEF") + (assoc msg :text-color :#4A5258 + :background-color :#D3EEEF) (let [{:keys [text-color background-color]} (get contact-by-identity from)] (assoc msg :text-color text-color :background-color background-color)))) diff --git a/src/syng_im/chat/subs.cljs b/src/syng_im/chat/subs.cljs new file mode 100644 index 0000000000..eabff6a23f --- /dev/null +++ b/src/syng_im/chat/subs.cljs @@ -0,0 +1,78 @@ +(ns syng-im.chat.subs + (:require-macros [reagent.ratom :refer [reaction]]) + (:require [re-frame.core :refer [register-sub]] + [syng-im.db :as db] + ;todo handlers in subs?... + [syng-im.handlers.suggestions :refer [get-suggestions]] + [syng-im.models.commands :as commands])) + +(register-sub :chat-properties + (fn [db [_ properties]] + (->> properties + (map (fn [k] + [k (-> @db + (get-in [:chats (:current-chat-id @db) k]) + (reaction))])) + (into {})))) + +(register-sub + :show-actions + (fn [db _] + (reaction (get-in @db db/show-actions-path)))) + +(register-sub :chat + (fn [db [_ k]] + (-> @db + (get-in [:chats (:current-chat-id @db) k]) + (reaction)))) + + +(register-sub :get-chat-messages + (fn [db _] + (let [chat-id (:current-chat-id @db)] + (reaction (get-in @db [:chats chat-id :messages]))))) + +(register-sub :get-current-chat-id + (fn [db _] + (reaction (:current-chat-id @db)))) + +(register-sub :get-suggestions + (fn [db _] + (let [input-text (->> (:current-chat-id @db) + db/chat-input-text-path + (get-in @db) + (reaction))] + (reaction (get-suggestions @db @input-text))))) + +(register-sub :get-commands + (fn [db _] + (reaction (commands/get-commands @db)))) + +(register-sub :get-chat-input-text + (fn [db _] + (->> (db/chat-input-text-path (:current-chat-id @db)) + (get-in @db) + (reaction)))) + +(register-sub :get-chat-staged-commands + (fn [db _] + (->> (db/chat-staged-commands-path (:current-chat-id @db)) + (get-in @db) + (reaction)))) + +(register-sub :get-chat-command + (fn [db _] + (reaction (commands/get-chat-command @db)))) + +(register-sub :get-chat-command-content + (fn [db _] + (reaction (commands/get-chat-command-content @db)))) + +(register-sub :chat-command-request + (fn [db _] + (reaction (commands/get-chat-command-request @db)))) + +(register-sub :get-current-chat + (fn [db _] + (let [current-chat-id (:current-chat-id @db)] + (reaction (get-in @db [:chats current-chat-id]))))) diff --git a/src/syng_im/chat/views/command.cljs b/src/syng_im/chat/views/command.cljs index c77ef93de8..0f6c8b55b2 100644 --- a/src/syng_im/chat/views/command.cljs +++ b/src/syng_im/chat/views/command.cljs @@ -1,5 +1,5 @@ (ns syng-im.chat.views.command - (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] + (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view image icon diff --git a/src/syng_im/chat/views/plain_input.cljs b/src/syng_im/chat/views/plain_input.cljs index ec8a88672b..09408cf9b3 100644 --- a/src/syng_im/chat/views/plain_input.cljs +++ b/src/syng_im/chat/views/plain_input.cljs @@ -1,5 +1,5 @@ (ns syng-im.chat.views.plain-input - (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] + (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view icon touchable-highlight diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index 338ce23aa6..ab81a94276 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -2,7 +2,7 @@ (:require [re-frame.core :refer [register-handler after dispatch debug enrich]] [schema.core :as s :include-macros true] - [syng-im.db :as db :refer [app-db schema]] + [syng-im.db :refer [app-db schema]] [syng-im.protocol.api :refer [init-protocol]] [syng-im.protocol.protocol-handler :refer [make-handler]] [syng-im.models.protocol :refer [update-identity @@ -11,15 +11,8 @@ [syng-im.models.contacts :as contacts] [syng-im.models.messages :refer [save-message update-message! - message-by-id - get-messages]] - [syng-im.models.commands :as commands :refer [set-chat-command - set-response-chat-command - set-chat-command-content - set-chat-command-request - stage-command - unstage-command - set-commands]] + message-by-id]] + [syng-im.models.commands :refer [set-commands]] [syng-im.handlers.server :as server] [syng-im.handlers.contacts :as contacts-service] [syng-im.handlers.suggestions :refer [get-command @@ -28,14 +21,13 @@ load-commands apply-staged-commands check-suggestion]] - [syng-im.handlers.sign-up :as sign-up-service] [syng-im.models.chats :refer [chat-exists? create-chat chat-add-participants chat-remove-participants set-chat-active re-join-group-chat - chat-by-id2] :as chats] + chat-by-id2]] [syng-im.models.chat :refer [signal-chat-updated set-current-chat-id current-chat-id @@ -55,8 +47,7 @@ nav-pop]] [syng-im.utils.crypt :refer [gen-random-bytes]] [syng-im.utils.random :as random] - [clojure.string :as str] - [syng-im.components.react :as r])) + syng-im.chat.handlers)) ;; -- Middleware ------------------------------------------------------------ ;; @@ -113,11 +104,6 @@ (log/debug action commands) (set-commands db commands))) -(register-handler :set-show-actions - (fn [db [action show-actions]] - (log/debug action) - (assoc-in db db/show-actions-path show-actions))) - ;; -- Protocol -------------------------------------------------------------- (register-handler :initialize-protocol @@ -143,43 +129,6 @@ :from "console" :to "me"})) (range n))) -(defn store-message! - [{:keys [new-message]} [_ {chat-id :from}]] - (save-message chat-id new-message)) - -(defn add-message-to-db - [db chat-id message] - (let [messages [:chats chat-id :messages]] - (update-in db messages conj message))) - -(defn check-author-direction - [db chat-id {:keys [from outgoing] :as message}] - (let [previous-message (first (get-in db [:chats chat-id :messages]))] - (merge message - {:same-author (if previous-message - (= (:from previous-message) from) - true) - :same-direction (if previous-message - (= (:outgoing previous-message) outgoing) - true)}))) - -(defn receive-message - [db [_ {chat-id :from :as message}]] - (let [message' (check-author-direction db chat-id message)] - (-> db - (add-message-to-db chat-id message') - (assoc :new-message message')))) - -(register-handler :received-msg - (-> receive-message - ((after store-message!)))) - -(register-handler :group-received-msg - (fn [db [action {chat-id :group-id :as msg}]] - (log/debug action "msg" msg) - (save-message chat-id msg) - (signal-chat-updated db chat-id))) - (defn system-message [msg-id content] {:from "system" :msg-id msg-id @@ -283,109 +232,6 @@ (let [{:keys [chat-id]} (message-by-id msg-id)] (signal-chat-updated db chat-id)))) -(defn console? [s] - (= "console" s)) - -(def not-console? - (complement console?)) - -(defn prepare-message - [{:keys [identity current-chat-id] :as db} _] - (let [text (get-in db [:chats current-chat-id :input-text]) - {:keys [command]} (check-suggestion db (str text " ")) - message (check-author-direction - db current-chat-id - {:msg-id (random/id) - :chat-id current-chat-id - :content text - :to current-chat-id - :from identity - :content-type text-content-type - :outgoing true})] - (if command - (set-chat-command db command) - (assoc db :new-message (when-not (str/blank? text) message))))) - -(defn prepare-command [identity chat-id staged-command] - (let [command-key (get-in staged-command [:command :command]) - content {:command (name command-key) - :content (:content staged-command)}] - {:msg-id (random/id) - :from identity - :to chat-id - :content content - :content-type content-type-command - :outgoing true - :handler (:handler staged-command)})) - -(defn prepare-staged-commans - [{:keys [current-chat-id identity] :as db} _] - (let [staged-commands (get-in db [:chats current-chat-id :staged-commands])] - (->> staged-commands - (map #(prepare-command identity current-chat-id %)) - ;todo this is wrong :( - (map #(check-author-direction db current-chat-id %)) - (assoc db :new-commands)))) - -(defn add-message - [{:keys [new-message current-chat-id] :as db}] - (if new-message - (add-message-to-db db current-chat-id new-message) - db)) - -(defn add-commands - [{:keys [new-commands current-chat-id] :as db}] - (reduce - #(add-message-to-db %1 current-chat-id %2) - db - new-commands)) - -(defn clear-input - [{:keys [current-chat-id new-message] :as db} _] - (if new-message - (assoc-in db [:chats current-chat-id :input-text] nil) - db)) - -(defn clear-staged-commands - [{:keys [current-chat-id] :as db} _] - (assoc-in db [:chats current-chat-id :staged-commands] [])) - -(defn send-message! - [{:keys [new-message current-chat-id]} _] - (when (and new-message (not-console? current-chat-id)) - (api/send-user-msg {:to current-chat-id - :content (:content new-message)}))) - -(defn save-message-to-realm! - [{:keys [new-message current-chat-id]} _] - (when new-message - (save-message current-chat-id new-message))) - -(defn save-commands-to-realm! - [{:keys [new-commands current-chat-id]} _] - (doseq [new-command new-commands] - (save-message current-chat-id (dissoc new-command :handler)))) - -(defn handle-commands - [{:keys [new-commands]}] - (doseq [{{content :content} :content - handler :handler} new-commands] - (when handler - (handler content)))) - -(register-handler :send-chat-msg - (-> prepare-message - ((enrich prepare-staged-commans)) - ((enrich add-message)) - ((enrich add-commands)) - ((enrich clear-input)) - ((enrich clear-staged-commands)) - ((after (fn [_ _] (r/dismiss-keyboard!)))) - ((after send-message!)) - ((after save-message-to-realm!)) - ((after save-commands-to-realm!)) - ((after handle-commands)))) - (register-handler :leave-group-chat (fn [db [action navigator]] (log/debug action) @@ -395,21 +241,6 @@ (left-chat-msg chat-id) (signal-chat-updated db chat-id)))) -(register-handler :send-group-chat-msg - (fn [db [action chat-id text]] - (log/debug action "chat-id" chat-id "text" text) - (let [{msg-id :msg-id - {from :from} :msg} (api/send-group-user-msg {:group-id chat-id - :content text}) - msg {:msg-id msg-id - :from from - :to nil - :content text - :content-type text-content-type - :outgoing true}] - (save-message chat-id msg) - (signal-chat-updated db chat-id)))) - ;; -- User data -------------------------------------------------------------- (register-handler :set-user-phone-number @@ -423,16 +254,6 @@ ;; -- Sign up -------------------------------------------------------------- -(register-handler :sign-up - (-> (fn [db [_ phone-number]] - (assoc db :user-phone-number phone-number)) - ((after (fn [& _] (sign-up-service/on-sign-up-response)))))) - -(register-handler :sign-up-confirm - (fn [db [_ confirmation-code]] - (sign-up-service/on-send-code-response confirmation-code) - db)) - (register-handler :sync-contacts (fn [db [_ handler]] (contacts-service/sync-contacts handler) @@ -453,60 +274,8 @@ (dispatch [:navigate-to navigator {:view-id :chat} nav-type]) db))) -(register-handler :init-console-chat - (fn [db [_]] - (sign-up-service/init db))) - -(register-handler :set-signed-up - (fn [db [_ signed-up]] - (sign-up-service/set-signed-up db signed-up))) - -;; -- Chat -------------------------------------------------------------- - -(defn update-text [db [_ text]] - (set-chat-input-text db text)) - -(defn update-command [db [_ text]] - (let [{:keys [command]} (check-suggestion db text)] - (set-chat-command db command))) - -(register-handler :set-chat-input-text - ((enrich update-command) update-text)) - -(register-handler :set-chat-command - (fn [db [_ command-key]] - ;; todo what is going on there?! - (set-chat-command db command-key))) - -(register-handler :stage-command - (fn [{:keys [current-chat-id] :as db} _] - (let [db (set-chat-input-text db nil) - {:keys [command content]} - (get-in db [:chats current-chat-id :command-input]) - command-info {:command command - :content content - :handler (:handler command)}] - (stage-command db command-info)))) - -(register-handler :unstage-command - (fn [db [_ staged-command]] - (let [] - (unstage-command db staged-command)))) - -(register-handler :set-response-chat-command - (fn [db [_ to-msg-id command-key]] - (set-response-chat-command db to-msg-id command-key))) - -(register-handler :set-chat-command-content - (fn [db [_ content]] - (set-chat-command-content db content))) - -(register-handler :set-chat-command-request - (fn [db [_ msg-id handler]] - (set-chat-command-request db msg-id handler))) - (register-handler :show-contacts - (fn [db [action navigator]] + (fn [db [_ navigator]] (nav-push navigator {:view-id :contact-list}) db)) @@ -576,77 +345,3 @@ (if (chat-exists? group-id) (re-join-group-chat db group-id identities group-name) (create-chat db group-id identities true group-name)))) - -(register-handler :navigate-to - (fn [db [_ view-id]] - (-> db - (assoc :view-id view-id) - (update :navigation-stack conj view-id)))) - -(register-handler :navigate-back - (fn [{:keys [navigation-stack] :as db} _] - (log/debug :navigate-back) - (if (>= 1 (count navigation-stack)) - db - (let [[view-id :as navigation-stack'] (pop navigation-stack)] - (-> db - (assoc :view-id view-id) - (assoc :navigation-stack navigation-stack')))))) - -(register-handler :load-more-messages - (fn [db _] - db - ;; TODO implement - #_(let [chat-id (get-in db [:chat :current-chat-id]) - messages [:chats chat-id :messages] - new-messages (gen-messages 10)] - (update-in db messages concat new-messages)))) - -(defn load-messages! - [db _] - db - (->> (current-chat-id db) - get-messages - (assoc db :messages))) - -(defn init-chat - [{:keys [messages] :as db} _] - (let [id (current-chat-id db)] - (assoc-in db [:chats id :messages] messages))) - -(register-handler :init-chat - (-> load-messages! - ((enrich init-chat)) - debug)) - -(defn initialize-chats - [{:keys [loaded-chats] :as db} _] - (let [chats (->> loaded-chats - (map (fn [{:keys [chat-id] :as chat}] - [chat-id chat])) - (into {}))] - (-> db - (assoc :chats chats) - (dissoc :loaded-chats)))) - -(defn load-chats! - [db _] - (assoc db :loaded-chats (chats/chats-list))) - -(register-handler :initialize-chats - ((enrich initialize-chats) load-chats!)) - -(defn safe-trim [s] - (when (string? s) - (str/trim s))) - -(register-handler :cancel-command - (fn [{:keys [current-chat-id] :as db} _] - (-> db - (assoc-in [:chats current-chat-id :command-input] {}) - (update-in [:chats current-chat-id :input-text] safe-trim)))) - -(register-handler :save-password - (fn [db [_ password]] - (sign-up-service/save-password password) - (assoc db :password-saved true))) diff --git a/src/syng_im/navigation/handlers.cljs b/src/syng_im/navigation/handlers.cljs new file mode 100644 index 0000000000..e39d0fc175 --- /dev/null +++ b/src/syng_im/navigation/handlers.cljs @@ -0,0 +1,17 @@ +(ns syng-im.navigation.handlers + (:require [re-frame.core :refer [register-handler]])) + +(register-handler :navigate-to + (fn [db [_ view-id]] + (-> db + (assoc :view-id view-id) + (update :navigation-stack conj view-id)))) + +(register-handler :navigate-back + (fn [{:keys [navigation-stack] :as db} _] + (if (>= 1 (count navigation-stack)) + db + (let [[view-id :as navigation-stack'] (pop navigation-stack)] + (-> db + (assoc :view-id view-id) + (assoc :navigation-stack navigation-stack')))))) diff --git a/src/syng_im/navigation/subs.cljs b/src/syng_im/navigation/subs.cljs new file mode 100644 index 0000000000..deda90b09e --- /dev/null +++ b/src/syng_im/navigation/subs.cljs @@ -0,0 +1,7 @@ +(ns syng-im.navigation.subs + (:require-macros [reagent.ratom :refer [reaction]]) + (:require [re-frame.core :refer [register-sub]])) + +(register-sub :navigation-stack + (fn [db _] + (reaction (:navigation-stack @db)))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index 2d877d06ff..826e3d0ee4 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -1,65 +1,12 @@ (ns syng-im.subs (:require-macros [reagent.ratom :refer [reaction]]) (:require [re-frame.core :refer [register-sub]] - [syng-im.db :as db] - [syng-im.models.chat :refer [current-chat-id - chat-updated?]] - [syng-im.models.chats :refer [chats-list - chats-updated? - chat-by-id]] - [syng-im.models.messages :refer [get-messages]] + [syng-im.models.chat :refer [current-chat-id chat-updated?]] + [syng-im.models.chats :refer [chats-list chats-updated? chat-by-id]] [syng-im.models.contacts :refer [contacts-list contacts-list-exclude contacts-list-include]] - [syng-im.models.commands :refer [get-commands - get-chat-command - get-chat-command-content - get-chat-command-request - parse-command-request]] - [syng-im.handlers.suggestions :refer [get-suggestions]])) - -;; -- Chat -------------------------------------------------------------- - -(register-sub :get-chat-messages - (fn [db _] - (let [chat-id (current-chat-id @db)] - (reaction (get-in @db [:chats chat-id :messages]))))) - -(register-sub :get-current-chat-id - (fn [db _] - (reaction (current-chat-id @db)))) - -(register-sub :get-suggestions - (fn [db _] - (let [input-text (->> (current-chat-id @db) - db/chat-input-text-path - (get-in @db) - (reaction))] - (reaction (get-suggestions @db @input-text))))) - -(register-sub :get-commands - (fn [db _] - (reaction (get-commands @db)))) - -(register-sub :get-chat-input-text - (fn [db _] - (reaction (get-in @db (db/chat-input-text-path (current-chat-id @db)))))) - -(register-sub :get-chat-staged-commands - (fn [db _] - (reaction (get-in @db (db/chat-staged-commands-path (current-chat-id @db)))))) - -(register-sub :get-chat-command - (fn [db _] - (reaction (get-chat-command @db)))) - -(register-sub :get-chat-command-content - (fn [db _] - (reaction (get-chat-command-content @db)))) - -(register-sub :chat-command-request - (fn [db _] - (reaction (get-chat-command-request @db)))) + syng-im.chat.subs)) ;; -- Chats list -------------------------------------------------------------- @@ -70,11 +17,6 @@ (let [_ @chats-updated] (chats-list)))))) -(register-sub :get-current-chat - (fn [db _] - (let [current-chat-id (current-chat-id @db)] - (reaction (get-in @db [:chats current-chat-id]))))) - ;; -- User data -------------------------------------------------------------- ;; (register-sub @@ -101,11 +43,6 @@ (reaction (get @db :signed-up)))) -(register-sub - :show-actions - (fn [db _] - (reaction (get-in @db db/show-actions-path)))) - (register-sub :get-contacts (fn [db _] @@ -145,24 +82,6 @@ (fn [db _] (reaction (@db :view-id)))) -(register-sub :chat - (fn [db [_ k]] - (-> @db - (get-in [:chats (current-chat-id @db) k]) - (reaction)))) - -(register-sub :navigation-stack - (fn [db _] - (reaction (:navigation-stack @db)))) - (register-sub :db (fn [db _] (reaction @db))) -(register-sub :chat-properties - (fn [db [_ properties]] - (->> properties - (map (fn [k] - [k (-> @db - (get-in [:chats (:current-chat-id @db) k]) - (reaction))])) - (into {})))) From 39772b41f7ad07014c022a1912cd4502ce264894 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Tue, 10 May 2016 15:25:36 +0300 Subject: [PATCH 04/26] more navigation handlers Former-commit-id: 38161d9e10dffc1a5bb58f495457873fede418fc --- src/syng_im/chat/views/message.cljs | 3 +- .../components/chats/chat_list_item.cljs | 2 +- src/syng_im/components/chats/chats_list.cljs | 3 +- src/syng_im/handlers.cljs | 45 +-------------- src/syng_im/navigation/handlers.cljs | 56 +++++++++++++++++-- src/syng_im/navigation/subs.cljs | 4 ++ src/syng_im/subs.cljs | 4 -- 7 files changed, 60 insertions(+), 57 deletions(-) diff --git a/src/syng_im/chat/views/message.cljs b/src/syng_im/chat/views/message.cljs index a65cd07825..b7fe165406 100644 --- a/src/syng_im/chat/views/message.cljs +++ b/src/syng_im/chat/views/message.cljs @@ -112,8 +112,7 @@ (defn text-message [{:keys [content] :as message}] [message-view message - [text {:style (st/text-message message)} - content]]) + [text {:style (st/text-message message)} content]]) (defmethod message-content text-content-type [wrapper message] diff --git a/src/syng_im/components/chats/chat_list_item.cljs b/src/syng_im/components/chats/chat_list_item.cljs index a6cc0dc5a1..574af6fc87 100644 --- a/src/syng_im/components/chats/chat_list_item.cljs +++ b/src/syng_im/components/chats/chat_list_item.cljs @@ -11,7 +11,7 @@ (defn chat-list-item [chat-obj navigator] [touchable-highlight - {:on-press #(dispatch [:show-chat (aget chat-obj "chat-id") navigator :push])} + {:on-press #(dispatch [:show-chat (aget chat-obj "chat-id") :push])} ;; TODO add [photo-path delivery-status new-messages-count online] values to chat-obj ;; TODO should chat-obj be clj-map? [view {} [chat-list-item-inner-view (merge (js->clj chat-obj :keywordize-keys true) diff --git a/src/syng_im/components/chats/chats_list.cljs b/src/syng_im/components/chats/chats_list.cljs index f102e7be6b..9083be800d 100644 --- a/src/syng_im/components/chats/chats_list.cljs +++ b/src/syng_im/components/chats/chats_list.cljs @@ -61,8 +61,7 @@ :color "white"}}]] [action-button-item {:title "New Group Chat" :buttonColor "#1abc9c" - :onPress (fn [] - (dispatch [:show-group-new navigator]))} + :onPress #(dispatch [:show-group-new])} [icon {:name "person-stalker" :style {:fontSize 20 :height 22 diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index ab81a94276..a40a84dfa6 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -33,7 +33,6 @@ current-chat-id update-new-group-selection update-new-participants-selection - clear-new-group clear-new-participants new-group-selection set-chat-input-text @@ -117,18 +116,6 @@ (update-identity identity) (set-initialized true)))) -(defn gen-messages [n] - (mapv (fn [_] - (let [id (random-uuid)] - {:msg-id id - :content (str id - "ooops sdfg dsfg" - "s dfg\ndsfg dfg\ndsfgdsfgdsfg") - :content-type text-content-type - :outgoing false - :from "console" - :to "me"})) (range n))) - (defn system-message [msg-id content] {:from "system" :msg-id msg-id @@ -267,29 +254,11 @@ ;; -- Chats -------------------------------------------------------------- -(register-handler :show-chat - (fn [db [action chat-id navigator nav-type]] - (log/debug action "chat-id" chat-id) - (let [db (set-current-chat-id db chat-id)] - (dispatch [:navigate-to navigator {:view-id :chat} nav-type]) - db))) - -(register-handler :show-contacts - (fn [db [_ navigator]] - (nav-push navigator {:view-id :contact-list}) - db)) - (register-handler :select-new-participant (fn [db [action identity add?]] (log/debug action identity add?) (update-new-participants-selection db identity add?))) -(register-handler :show-remove-participants - (fn [db [action navigator]] - (log/debug action) - (nav-push navigator {:view-id :remove-participants}) - (clear-new-participants db))) - (register-handler :remove-selected-participants (fn [db [action navigator]] (log/debug action) @@ -302,12 +271,6 @@ (removed-participant-msg chat-id ident)) (signal-chat-updated db chat-id)))) -(register-handler :show-add-participants - (fn [db [action navigator]] - (log/debug action) - (nav-push navigator {:view-id :add-participants}) - (clear-new-participants db))) - (register-handler :add-new-participants (fn [db [action navigator]] (log/debug action) @@ -319,12 +282,6 @@ (api/group-add-participant chat-id ident)) db))) -(register-handler :show-group-new - (fn [db [action navigator]] - (log/debug action) - (nav-push navigator {:view-id :new-group}) - (clear-new-group db))) - (register-handler :select-for-new-group (fn [db [action identity add?]] (log/debug action identity add?) @@ -336,7 +293,7 @@ (let [identities (vec (new-group-selection db)) group-id (api/start-group-chat identities group-name) db (create-chat db group-id identities true group-name)] - (dispatch [:show-chat group-id navigator :replace]) + (dispatch [:show-chat group-id :replace]) db))) (register-handler :group-chat-invite-received diff --git a/src/syng_im/navigation/handlers.cljs b/src/syng_im/navigation/handlers.cljs index e39d0fc175..281b044318 100644 --- a/src/syng_im/navigation/handlers.cljs +++ b/src/syng_im/navigation/handlers.cljs @@ -1,11 +1,30 @@ (ns syng-im.navigation.handlers - (:require [re-frame.core :refer [register-handler]])) + (:require [re-frame.core :refer [register-handler dispatch]] + [syng-im.models.chat :as chat])) + +(defn push-view [db view-id] + (-> db + (update :navigation-stack conj view-id) + (assoc :view-id view-id))) + +(defn replace-top-element [stack view-id] + (let [stack' (if (pos? (count stack)) + (pop stack) + stack)] + (conj stack' view-id))) + +(defn replace-view [db view-id] + (-> db + (update :navigation-stack replace-top-element view-id) + (assoc :view-id view-id))) (register-handler :navigate-to (fn [db [_ view-id]] - (-> db - (assoc :view-id view-id) - (update :navigation-stack conj view-id)))) + (push-view db view-id))) + +(register-handler :navigation-replace + (fn [db [_ view-id]] + (replace-view db view-id))) (register-handler :navigate-back (fn [{:keys [navigation-stack] :as db} _] @@ -15,3 +34,32 @@ (-> db (assoc :view-id view-id) (assoc :navigation-stack navigation-stack')))))) + +(register-handler :show-group-new + (fn [db _] + (-> db + (push-view :new-group) + chat/clear-new-group))) + +(register-handler :show-chat + (fn [db [_ chat-id nav-type]] + (let [update-view-id-fn (if (= :replace nav-type) replace-view push-view)] + (-> db + (update-view-id-fn :chat) + (chat/set-current-chat-id chat-id))))) + +(register-handler :show-contacts + (fn [db _] + (push-view db :contact-list))) + +(register-handler :show-remove-participants + (fn [db _] + (-> db + (push-view :remove-participants) + chat/clear-new-participants))) + +(register-handler :show-add-participants + (fn [db _] + (-> db + (push-view :add-participants) + chat/clear-new-participants))) diff --git a/src/syng_im/navigation/subs.cljs b/src/syng_im/navigation/subs.cljs index deda90b09e..d7b2dc4a0a 100644 --- a/src/syng_im/navigation/subs.cljs +++ b/src/syng_im/navigation/subs.cljs @@ -2,6 +2,10 @@ (:require-macros [reagent.ratom :refer [reaction]]) (:require [re-frame.core :refer [register-sub]])) +(register-sub :view-id + (fn [db _] + (reaction (@db :view-id)))) + (register-sub :navigation-stack (fn [db _] (reaction (:navigation-stack @db)))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index 826e3d0ee4..360064daf4 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -78,10 +78,6 @@ (map :identity))] (contacts-list-include current-participants))))))) -(register-sub :view-id - (fn [db _] - (reaction (@db :view-id)))) - (register-sub :db (fn [db _] (reaction @db))) From fb22a08b79941500349a54b396c37c115de12a83 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Tue, 10 May 2016 17:40:21 +0300 Subject: [PATCH 05/26] remove chat model Former-commit-id: 544571e3a7c4ce4ab04df0ba2e30ffb65ce4e70d --- src/syng_im/chat/handlers.cljs | 24 +++---- src/syng_im/chat/subs.cljs | 6 +- src/syng_im/components/chats/new_group.cljs | 9 ++- src/syng_im/components/discovery/subs.cljs | 52 ++++++++-------- src/syng_im/db.cljs | 8 --- src/syng_im/handlers.cljs | 69 +++++++++------------ src/syng_im/handlers/sign_up.cljs | 3 +- src/syng_im/handlers/suggestions.cljs | 4 +- src/syng_im/models/chat.cljs | 52 ---------------- src/syng_im/models/chats.cljs | 6 +- src/syng_im/models/commands.cljs | 21 +++---- src/syng_im/navigation/handlers.cljs | 14 +++-- src/syng_im/subs.cljs | 9 +-- 13 files changed, 105 insertions(+), 172 deletions(-) delete mode 100644 src/syng_im/models/chat.cljs diff --git a/src/syng_im/chat/handlers.cljs b/src/syng_im/chat/handlers.cljs index 93196354c1..42d9294301 100644 --- a/src/syng_im/chat/handlers.cljs +++ b/src/syng_im/chat/handlers.cljs @@ -1,9 +1,7 @@ (ns syng-im.chat.handlers - (:require [syng-im.db :as db] - [re-frame.core :refer [register-handler enrich after debug]] + (:require [re-frame.core :refer [register-handler enrich after debug]] [syng-im.models.commands :as commands] [clojure.string :as str] - [syng-im.models.chat :as chat] [syng-im.handlers.suggestions :as suggestions] [syng-im.protocol.api :as api] [syng-im.models.messages :as messages] @@ -16,7 +14,7 @@ (register-handler :set-show-actions (fn [db [_ show-actions]] - (assoc-in db db/show-actions-path show-actions))) + (assoc db :show-actions show-actions))) (register-handler :load-more-messages (fn [db _] @@ -41,9 +39,13 @@ (fn [db [_ content]] (commands/set-chat-command-content db content))) +(defn update-input-text + [{:keys [current-chat-id] :as db} text] + (assoc-in db [:chats current-chat-id :input-text] text)) + (register-handler :stage-command (fn [{:keys [current-chat-id] :as db} _] - (let [db (chat/set-chat-input-text db nil) + (let [db (update-input-text db nil) {:keys [command content]} (get-in db [:chats current-chat-id :command-input]) command-info {:command command @@ -55,8 +57,9 @@ (fn [db [_ to-msg-id command-key]] (commands/set-response-chat-command db to-msg-id command-key))) -(defn update-text [db [_ text]] - (chat/set-chat-input-text db text)) +(defn update-text + [db [_ text]] + (update-input-text db text)) (defn update-command [db [_ text]] (let [{:keys [command]} (suggestions/check-suggestion db text)] @@ -76,8 +79,7 @@ :content text :content-type text-content-type :outgoing true}] - (messages/save-message chat-id msg) - (chat/signal-chat-updated db chat-id)))) + (messages/save-message chat-id msg)))) (defn console? [s] (= "console" s)) @@ -225,7 +227,7 @@ (register-handler :sign-up-confirm (fn [db [_ confirmation-code]] (sign-up-service/on-send-code-response confirmation-code) - db)) + (sign-up-service/set-signed-up db true))) (register-handler :set-signed-up (fn [db [_ signed-up]] @@ -284,4 +286,4 @@ (register-handler :group-received-msg (fn [db [_ {chat-id :group-id :as msg}]] (messages/save-message chat-id msg) - (chat/signal-chat-updated db chat-id))) + db)) diff --git a/src/syng_im/chat/subs.cljs b/src/syng_im/chat/subs.cljs index eabff6a23f..35f7386b93 100644 --- a/src/syng_im/chat/subs.cljs +++ b/src/syng_im/chat/subs.cljs @@ -18,7 +18,7 @@ (register-sub :show-actions (fn [db _] - (reaction (get-in @db db/show-actions-path)))) + (reaction (:show-actions @db)))) (register-sub :chat (fn [db [_ k]] @@ -50,13 +50,13 @@ (register-sub :get-chat-input-text (fn [db _] - (->> (db/chat-input-text-path (:current-chat-id @db)) + (->> [:chats (:current-chat-id @db) :input-text] (get-in @db) (reaction)))) (register-sub :get-chat-staged-commands (fn [db _] - (->> (db/chat-staged-commands-path (:current-chat-id @db)) + (->> [:chats (:current-chat-id @db) :staged-commands] (get-in @db) (reaction)))) diff --git a/src/syng_im/components/chats/new_group.cljs b/src/syng_im/components/chats/new_group.cljs index 5ec1cb1066..7f9c852b71 100644 --- a/src/syng_im/components/chats/new_group.cljs +++ b/src/syng_im/components/chats/new_group.cljs @@ -23,11 +23,10 @@ (defn new-group-toolbar [navigator group-name] [toolbar {:navigator navigator :title "New group chat" - :action {:image {:source res/v ;; {:uri "icon_search"} - :style {:width 20 - :height 18}} - :handler (fn [] - (dispatch [:create-new-group group-name navigator]))}}]) + :action {:image {:source res/v ;; {:uri "icon_search"} + :style {:width 20 + :height 18}} + :handler #(dispatch [:create-new-group group-name])}}]) (defn new-group [{:keys [navigator]}] (let [contacts (subscribe [:all-contacts]) diff --git a/src/syng_im/components/discovery/subs.cljs b/src/syng_im/components/discovery/subs.cljs index d1a8eb5399..c335d4366d 100644 --- a/src/syng_im/components/discovery/subs.cljs +++ b/src/syng_im/components/discovery/subs.cljs @@ -13,36 +13,36 @@ (register-sub :get-discoveries - (fn [db _] - (let [discoveries-updated (-> (discoveries-updated? @db) - (reaction))] - (reaction - (let [_ @discoveries-updated] - (discovery-list)))))) + (fn [db _] + (let [discoveries-updated (-> (discoveries-updated? @db) + (reaction))] + (reaction + (let [_ @discoveries-updated] + (discovery-list)))))) (register-sub :get-discoveries-by-tag - (fn [db [_ tag limit]] - (let [discoveries-updated (-> (discoveries-updated? @db) - (reaction))] - (log/debug "Getting discoveries for: " tag) - (reaction - (let [_ @discoveries-updated] - (discoveries-by-tag tag limit)))))) + (fn [db [_ tag limit]] + (let [discoveries-updated (-> (discoveries-updated? @db) + (reaction))] + (log/debug "Getting discoveries for: " tag) + (reaction + (let [_ @discoveries-updated] + (discoveries-by-tag tag limit)))))) (register-sub :get-popular-tags - (fn [db [_ limit]] - (let [discoveries-updated (-> (discoveries-updated? @db) - (reaction))] - (log/debug "Getting tags limited: " limit) - (reaction - (let [_ @discoveries-updated] - (get-tag-popular limit)))))) + (fn [db [_ limit]] + (let [discoveries-updated (-> (discoveries-updated? @db) + (reaction))] + (log/debug "Getting tags limited: " limit) + (reaction + (let [_ @discoveries-updated] + (get-tag-popular limit)))))) (register-sub :get-current-tag - (fn [db _] - (let [current-tag-updated (-> (current-tag-updated? @db) - (reaction))] - (reaction - (let [_ @current-tag-updated] - (current-tag @db)))))) + (fn [db _] + (let [current-tag-updated (-> (current-tag-updated? @db) + (reaction))] + (reaction + (let [_ @current-tag-updated] + (current-tag @db)))))) diff --git a/src/syng_im/db.cljs b/src/syng_im/db.cljs index 09f45f2725..71274d6a97 100644 --- a/src/syng_im/db.cljs +++ b/src/syng_im/db.cljs @@ -27,10 +27,7 @@ (def protocol-initialized-path [:protocol-initialized]) (def identity-password-path [:identity-password]) -(def current-chat-id-path [:current-chat-id]) (def updated-chats-signal-path [:chats-updated-signal]) -(defn updated-chat-signal-path [chat-id] - [:chats chat-id :chat-updated-signal]) (defn chat-input-text-path [chat-id] [:chats chat-id :input-text]) (defn chat-staged-commands-path [chat-id] @@ -45,11 +42,6 @@ [:chats chat-id :command-requests]) (defn chat-command-request-path [chat-id msg-id] [:chats chat-id :command-requests msg-id]) -(def show-actions-path [:show-actions]) -(def new-group-path [:new-group]) -(def new-participants-path [:new-participants]) (def updated-discoveries-signal-path [:discovery-updated-signal]) -(defn updated-discovery-signal-path [whisper-id] - [:discoveries whisper-id :discovery-updated-signal]) (def current-tag-path [:current-tag]) (def updated-current-tag-signal-path [:current-tag-updated-signal]) diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index a40a84dfa6..6c42200632 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -28,15 +28,6 @@ set-chat-active re-join-group-chat chat-by-id2]] - [syng-im.models.chat :refer [signal-chat-updated - set-current-chat-id - current-chat-id - update-new-group-selection - update-new-participants-selection - clear-new-participants - new-group-selection - set-chat-input-text - new-participants-selection]] [syng-im.utils.logging :as log] [syng-im.protocol.api :as api] [syng-im.constants :refer [text-content-type @@ -46,7 +37,9 @@ nav-pop]] [syng-im.utils.crypt :refer [gen-random-bytes]] [syng-im.utils.random :as random] - syng-im.chat.handlers)) + syng-im.chat.handlers + syng-im.navigation.handlers + syng-im.components.discovery.handlers)) ;; -- Middleware ------------------------------------------------------------ ;; @@ -173,60 +166,51 @@ (register-handler :group-chat-invite-acked (fn [db [action from group-id ack-msg-id]] (log/debug action from group-id ack-msg-id) - (joined-chat-msg group-id from ack-msg-id) - (signal-chat-updated db group-id))) + (joined-chat-msg group-id from ack-msg-id))) (register-handler :participant-removed-from-group (fn [db [action from group-id identity msg-id]] (log/debug action msg-id from group-id identity) (chat-remove-participants group-id [identity]) - (participant-removed-from-group-msg group-id identity from msg-id) - (signal-chat-updated db group-id))) + (participant-removed-from-group-msg group-id identity from msg-id))) (register-handler :you-removed-from-group (fn [db [action from group-id msg-id]] (log/debug action msg-id from group-id) (you-removed-from-group-msg group-id from msg-id) - (set-chat-active group-id false) - (signal-chat-updated db group-id))) + (set-chat-active group-id false))) (register-handler :participant-left-group (fn [db [action from group-id msg-id]] (log/debug action msg-id from group-id) (if (= (api/my-identity) from) db - (do (participant-left-group-msg group-id from msg-id) - (signal-chat-updated db group-id))))) + (participant-left-group-msg group-id from msg-id)))) (register-handler :participant-invited-to-group (fn [db [action from group-id identity msg-id]] (log/debug action msg-id from group-id identity) - (participant-invited-to-group-msg group-id identity from msg-id) - (signal-chat-updated db group-id))) + (participant-invited-to-group-msg group-id identity from msg-id))) (register-handler :acked-msg (fn [db [action from msg-id]] (log/debug action from msg-id) (update-message! {:msg-id msg-id - :delivery-status :delivered}) - (signal-chat-updated db from))) + :delivery-status :delivered}))) (register-handler :msg-delivery-failed (fn [db [action msg-id]] (log/debug action msg-id) (update-message! {:msg-id msg-id - :delivery-status :failed}) - (let [{:keys [chat-id]} (message-by-id msg-id)] - (signal-chat-updated db chat-id)))) + :delivery-status :failed}))) (register-handler :leave-group-chat (fn [db [action navigator]] (log/debug action) - (let [chat-id (current-chat-id db)] + (let [chat-id (:current-chat-id db)] (api/leave-group-chat chat-id) (set-chat-active chat-id false) - (left-chat-msg chat-id) - (signal-chat-updated db chat-id)))) + (left-chat-msg chat-id)))) ;; -- User data -------------------------------------------------------------- @@ -253,6 +237,11 @@ (contacts/load-syng-contacts db))) ;; -- Chats -------------------------------------------------------------- +(defn update-new-participants-selection [db identity add?] + (update db :new-participants (fn [new-participants] + (if add? + (conj new-participants identity) + (disj new-participants identity))))) (register-handler :select-new-participant (fn [db [action identity add?]] @@ -262,35 +251,39 @@ (register-handler :remove-selected-participants (fn [db [action navigator]] (log/debug action) - (let [identities (vec (new-participants-selection db)) - chat-id (current-chat-id db)] + (let [identities (vec (:new-participants db)) + chat-id (:current-chat-id db)] (chat-remove-participants chat-id identities) (nav-pop navigator) (doseq [ident identities] (api/group-remove-participant chat-id ident) - (removed-participant-msg chat-id ident)) - (signal-chat-updated db chat-id)))) + (removed-participant-msg chat-id ident))))) (register-handler :add-new-participants (fn [db [action navigator]] (log/debug action) - (let [identities (vec (new-participants-selection db)) - chat-id (current-chat-id db)] + (let [identities (vec (:new-participants db)) + chat-id (:current-chat-id db)] (chat-add-participants chat-id identities) (nav-pop navigator) (doseq [ident identities] (api/group-add-participant chat-id ident)) db))) +(defn update-new-group-selection [db identity add?] + (update-in db :new-group (fn [new-group] + (if add? + (conj new-group identity) + (disj new-group identity))))) + (register-handler :select-for-new-group - (fn [db [action identity add?]] - (log/debug action identity add?) + (fn [db [_ identity add?]] (update-new-group-selection db identity add?))) (register-handler :create-new-group - (fn [db [action group-name navigator]] + (fn [db [action group-name]] (log/debug action) - (let [identities (vec (new-group-selection db)) + (let [identities (vec (:new-group db)) group-id (api/start-group-chat identities group-name) db (create-chat db group-id identities true group-name)] (dispatch [:show-chat group-id :replace]) diff --git a/src/syng_im/handlers/sign_up.cljs b/src/syng_im/handlers/sign_up.cljs index 014d8532b8..dfbd1fa945 100644 --- a/src/syng_im/handlers/sign_up.cljs +++ b/src/syng_im/handlers/sign_up.cljs @@ -2,7 +2,6 @@ (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.persistence.simple-kv-store :as kv] [syng-im.protocol.state.storage :as s] - [syng-im.models.chat :refer [set-current-chat-id]] [syng-im.models.chats :as c] [syng-im.utils.utils :refer [log on-error http-post toast]] [syng-im.utils.random :as random] @@ -196,5 +195,5 @@ (-> db (assoc-in [:chats "console"] console-chat) (assoc :new-chat console-chat) - (set-current-chat-id "console") + (assoc :current-chat-id "console") (intro)))))) diff --git a/src/syng_im/handlers/suggestions.cljs b/src/syng_im/handlers/suggestions.cljs index 8ce337b436..bf9fc11e65 100644 --- a/src/syng_im/handlers/suggestions.cljs +++ b/src/syng_im/handlers/suggestions.cljs @@ -1,7 +1,6 @@ (ns syng-im.handlers.suggestions (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.db :as db] - [syng-im.models.chat :refer [current-chat-id]] [syng-im.models.commands :refer [commands suggestions get-commands @@ -39,7 +38,8 @@ (command-handler to-msg-id command-key content))))) (defn apply-staged-commands [db] - (let [staged-commands (get-in db (db/chat-staged-commands-path (current-chat-id db)))] + (let [staged-commands (get-in db (db/chat-staged-commands-path + (:current-chat-id db)))] (dorun (map (fn [staged-command] (when-let [handler (:handler staged-command)] (handler))) diff --git a/src/syng_im/models/chat.cljs b/src/syng_im/models/chat.cljs deleted file mode 100644 index 920442174b..0000000000 --- a/src/syng_im/models/chat.cljs +++ /dev/null @@ -1,52 +0,0 @@ -(ns syng-im.models.chat - (:require [syng-im.db :as db])) - -(defn set-current-chat-id [db chat-id] - (assoc-in db db/current-chat-id-path chat-id)) - -(defn current-chat-id [db] - (get-in db db/current-chat-id-path)) - -(defn signal-chat-updated [db chat-id] - (update-in db (db/updated-chat-signal-path chat-id) (fn [current] - (if current - (inc current) - 0)))) - -(defn chat-updated? [db chat-id] - (get-in db (db/updated-chat-signal-path chat-id))) - -(defn update-new-group-selection [db identity add?] - (update-in db db/new-group-path (fn [new-group] - (if add? - (conj new-group identity) - (disj new-group identity))))) - -(defn update-new-participants-selection [db identity add?] - (update-in db db/new-participants-path (fn [new-participants] - (if add? - (conj new-participants identity) - (disj new-participants identity))))) - -(defn new-group-selection [db] - (get-in db db/new-group-path)) - -(defn clear-new-group [db] - (assoc-in db db/new-group-path #{})) - -(defn new-participants-selection [db] - (get-in db db/new-participants-path)) - -(defn clear-new-participants [db] - (assoc-in db db/new-participants-path #{})) - -(defn set-chat-input-text [db text] - (assoc-in db (db/chat-input-text-path (current-chat-id db)) text)) - -(comment - - (swap! re-frame.db/app-db (fn [db] - (signal-chat-updated db "0x0479a5ed1f38cadfad1db6cd56c4b659b0ebe052bbe9efa950f6660058519fa4ca6be2dda66afa80de96ab00eb97a2605d5267a1e8f4c2a166ab551f6826608cdd"))) - - (current-chat-id @re-frame.db/app-db) - ) diff --git a/src/syng_im/models/chats.cljs b/src/syng_im/models/chats.cljs index ade0679521..31a6819e06 100644 --- a/src/syng_im/models/chats.cljs +++ b/src/syng_im/models/chats.cljs @@ -7,8 +7,7 @@ [syng-im.utils.logging :as log] [syng-im.constants :refer [content-type-status]] [syng-im.models.messages :refer [save-message]] - [syng-im.persistence.realm-queries :refer [include-query]] - [syng-im.models.chat :refer [signal-chat-updated]])) + [syng-im.persistence.realm-queries :refer [include-query]])) (defn signal-chats-updated [db] (update-in db db/updated-chats-signal-path (fn [current] @@ -96,8 +95,7 @@ :is-active true :name group-name :contacts contacts} true)))) - (-> (signal-chats-updated db) - (signal-chat-updated group-id))) + (signal-chats-updated db)) (defn normalize-contacts [chats] diff --git a/src/syng_im/models/commands.cljs b/src/syng_im/models/commands.cljs index ad6ccaccb3..177dfaacfd 100644 --- a/src/syng_im/models/commands.cljs +++ b/src/syng_im/models/commands.cljs @@ -4,7 +4,6 @@ [cljs.core.async :as async :refer [chan put! !]] [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.db :as db] - [syng-im.models.chat :refer [current-chat-id]] [syng-im.components.styles :refer [color-blue color-dark-mint]] [syng-im.utils.utils :refer [log toast]])) @@ -80,18 +79,18 @@ (first (filter #(= command-key (:command %)) commands))) (defn get-chat-command-content [db] - (get-in db (db/chat-command-content-path (current-chat-id db)))) + (get-in db (db/chat-command-content-path (:current-chat-id db)))) (defn set-chat-command-content [db content] (assoc-in db - [:chats (get-in db db/current-chat-id-path) :command-input :content] + [:chats (:current-chat-id db) :command-input :content] content)) (defn get-chat-command [db] - (get-in db (db/chat-command-path (current-chat-id db)))) + (get-in db (db/chat-command-path (:current-chat-id db)))) (defn set-response-chat-command [db msg-id command-key] - (let [chat-id (current-chat-id db)] + (let [chat-id (:current-chat-id db)] (-> db (assoc-in [:chats chat-id :command-input :content] nil) (assoc-in [:chats chat-id :command-input :command] @@ -102,29 +101,29 @@ (set-response-chat-command db nil command-key)) (defn get-chat-command-to-msg-id [db] - (get-in db (db/chat-command-to-msg-id-path (current-chat-id db)))) + (get-in db (db/chat-command-to-msg-id-path (:current-chat-id db)))) (defn stage-command [db command-info] - (update-in db (db/chat-staged-commands-path (current-chat-id db)) + (update-in db (db/chat-staged-commands-path (:current-chat-id db)) (fn [staged-commands] (if staged-commands (conj staged-commands command-info) [command-info])))) (defn unstage-command [db staged-command] - (update-in db (db/chat-staged-commands-path (current-chat-id db)) + (update-in db (db/chat-staged-commands-path (:current-chat-id db)) (fn [staged-commands] (filterv #(not= % staged-command) staged-commands)))) (defn clear-staged-commands [db] - (assoc-in db (db/chat-staged-commands-path (current-chat-id db)) [])) + (assoc-in db (db/chat-staged-commands-path (:current-chat-id db)) [])) (defn get-chat-command-request [db] - (get-in db (db/chat-command-request-path (current-chat-id db) + (get-in db (db/chat-command-request-path (:current-chat-id db) (get-chat-command-to-msg-id db)))) (defn set-chat-command-request [db msg-id handler] - (update-in db (db/chat-command-requests-path (current-chat-id db)) + (update-in db (db/chat-command-requests-path (:current-chat-id db)) #(assoc % msg-id handler))) (defn parse-command-msg-content [commands content] diff --git a/src/syng_im/navigation/handlers.cljs b/src/syng_im/navigation/handlers.cljs index 281b044318..f45b66a934 100644 --- a/src/syng_im/navigation/handlers.cljs +++ b/src/syng_im/navigation/handlers.cljs @@ -1,6 +1,5 @@ (ns syng-im.navigation.handlers - (:require [re-frame.core :refer [register-handler dispatch]] - [syng-im.models.chat :as chat])) + (:require [re-frame.core :refer [register-handler dispatch]])) (defn push-view [db view-id] (-> db @@ -39,27 +38,30 @@ (fn [db _] (-> db (push-view :new-group) - chat/clear-new-group))) + (assoc-in :new-group #{})))) (register-handler :show-chat (fn [db [_ chat-id nav-type]] (let [update-view-id-fn (if (= :replace nav-type) replace-view push-view)] (-> db (update-view-id-fn :chat) - (chat/set-current-chat-id chat-id))))) + (assoc :current-chat-id chat-id))))) (register-handler :show-contacts (fn [db _] (push-view db :contact-list))) +(defn clear-new-participants [db] + (assoc-in db :new-participants #{})) + (register-handler :show-remove-participants (fn [db _] (-> db (push-view :remove-participants) - chat/clear-new-participants))) + clear-new-participants))) (register-handler :show-add-participants (fn [db _] (-> db (push-view :add-participants) - chat/clear-new-participants))) + clear-new-participants))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index 360064daf4..bb186a0923 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -1,12 +1,13 @@ (ns syng-im.subs (:require-macros [reagent.ratom :refer [reaction]]) (:require [re-frame.core :refer [register-sub]] - [syng-im.models.chat :refer [current-chat-id chat-updated?]] [syng-im.models.chats :refer [chats-list chats-updated? chat-by-id]] [syng-im.models.contacts :refer [contacts-list contacts-list-exclude contacts-list-include]] - syng-im.chat.subs)) + syng-im.chat.subs + syng-im.navigation.subs + syng-im.components.discovery.subs)) ;; -- Chats list -------------------------------------------------------------- @@ -56,7 +57,7 @@ (register-sub :all-new-contacts (fn [db _] - (let [current-chat-id (reaction (current-chat-id @db)) + (let [current-chat-id (reaction (:current-chat-id @db)) chat (reaction (when-let [chat-id @current-chat-id] (chat-by-id chat-id)))] (reaction @@ -68,7 +69,7 @@ (register-sub :current-chat-contacts (fn [db _] - (let [current-chat-id (reaction (current-chat-id @db)) + (let [current-chat-id (reaction (:current-chat-id @db)) chat (reaction (when-let [chat-id @current-chat-id] (chat-by-id chat-id)))] (reaction From 6e2809e270e4cae34c3b34ee2aad16e8948a2161 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Tue, 10 May 2016 19:06:22 +0300 Subject: [PATCH 06/26] contacts screen/views Former-commit-id: f1584b8342af1f35c1b733681fbcbd32576cf655 --- src/syng_im/android/core.cljs | 2 +- .../screen.cljs} | 8 ++--- .../views}/contact.cljs | 4 +-- .../views}/contact_inner.cljs | 2 +- src/syng_im/models/chats.cljs | 15 ++------- src/syng_im/subs.cljs | 31 ++++--------------- 6 files changed, 16 insertions(+), 46 deletions(-) rename src/syng_im/{components/contact_list/contact_list.cljs => contacts/screen.cljs} (90%) rename src/syng_im/{components/contact_list => contacts/views}/contact.cljs (77%) rename src/syng_im/{components/contact_list => contacts/views}/contact_inner.cljs (97%) diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index 93e8a278ef..56c654bfd2 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -7,7 +7,7 @@ [syng-im.handlers] [syng-im.subs] [syng-im.components.react :refer [navigator app-registry]] - [syng-im.components.contact-list.contact-list :refer [contact-list]] + [syng-im.contacts.screen :refer [contact-list]] [syng-im.components.discovery.discovery :refer [discovery]] [syng-im.components.discovery.discovery-tag :refer [discovery-tag]] [syng-im.chat.screen :refer [chat]] diff --git a/src/syng_im/components/contact_list/contact_list.cljs b/src/syng_im/contacts/screen.cljs similarity index 90% rename from src/syng_im/components/contact_list/contact_list.cljs rename to src/syng_im/contacts/screen.cljs index d4c3ef242c..abdc736d5d 100644 --- a/src/syng_im/components/contact_list/contact_list.cljs +++ b/src/syng_im/contacts/screen.cljs @@ -1,12 +1,12 @@ -(ns syng-im.components.contact-list.contact-list +(ns syng-im.contacts.screen (:require-macros - [natal-shell.data-source :refer [data-source clone-with-rows]] - [natal-shell.core :refer [with-error-view]]) + [natal-shell.data-source :refer [data-source clone-with-rows]] + [natal-shell.core :refer [with-error-view]]) (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.components.react :refer [view text image touchable-highlight navigator list-view list-item]] - [syng-im.components.contact-list.contact :refer [contact-view]] + [syng-im.contacts.views.contact :refer [contact-view]] [syng-im.components.styles :refer [font title-font color-white diff --git a/src/syng_im/components/contact_list/contact.cljs b/src/syng_im/contacts/views/contact.cljs similarity index 77% rename from src/syng_im/components/contact_list/contact.cljs rename to src/syng_im/contacts/views/contact.cljs index 7b9d5af1c1..6bbbdc7938 100644 --- a/src/syng_im/components/contact_list/contact.cljs +++ b/src/syng_im/contacts/views/contact.cljs @@ -1,8 +1,8 @@ -(ns syng-im.components.contact-list.contact +(ns syng-im.contacts.views.contact (:require [syng-im.components.react :refer [view text image touchable-highlight]] [syng-im.resources :as res] [syng-im.navigation :as nav] - [syng-im.components.contact-list.contact-inner :refer [contact-inner-view]])) + [syng-im.contacts.views.contact-inner :refer [contact-inner-view]])) (defn show-chat [navigator whisper-identity] (nav/nav-push navigator {:view-id :chat})) diff --git a/src/syng_im/components/contact_list/contact_inner.cljs b/src/syng_im/contacts/views/contact_inner.cljs similarity index 97% rename from src/syng_im/components/contact_list/contact_inner.cljs rename to src/syng_im/contacts/views/contact_inner.cljs index 13e79d983b..3dd46f458f 100644 --- a/src/syng_im/components/contact_list/contact_inner.cljs +++ b/src/syng_im/contacts/views/contact_inner.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.contact-list.contact-inner +(ns syng-im.contacts.views.contact-inner (:require [clojure.string :as s] [syng-im.components.react :refer [view image text]] [syng-im.components.styles :refer [font diff --git a/src/syng_im/models/chats.cljs b/src/syng_im/models/chats.cljs index 31a6819e06..8d1425b989 100644 --- a/src/syng_im/models/chats.cljs +++ b/src/syng_im/models/chats.cljs @@ -3,20 +3,11 @@ [syng-im.persistence.realm :as r] [syng-im.utils.random :as random :refer [timestamp]] [clojure.string :refer [join blank?]] - [syng-im.db :as db] [syng-im.utils.logging :as log] [syng-im.constants :refer [content-type-status]] [syng-im.models.messages :refer [save-message]] [syng-im.persistence.realm-queries :refer [include-query]])) -(defn signal-chats-updated [db] - (update-in db db/updated-chats-signal-path (fn [current] - (if current - (inc current) - 0)))) - -(defn chats-updated? [db] - (get-in db db/updated-chats-signal-path)) (defn chat-name-from-contacts [identities] (let [chat-name (->> identities @@ -52,8 +43,6 @@ ([{:keys [last-msg-id] :as chat}] (let [chat (assoc chat :last-msg-id (or last-msg-id ""))] (r/write #(r/create :chats chat)))) - ([db chat-id identities group-chat?] - (create-chat db chat-id identities group-chat? nil)) ([db chat-id identities group-chat? chat-name] (if (chat-exists? chat-id) db @@ -72,7 +61,7 @@ :contacts contacts :last-msg-id ""})))) (add-status-message chat-id) - (signal-chats-updated db))))) + db)))) (defn chat-contacts [chat-id] (-> (r/get-by-field :chats :chat-id chat-id) @@ -95,7 +84,7 @@ :is-active true :name group-name :contacts contacts} true)))) - (signal-chats-updated db)) + db) (defn normalize-contacts [chats] diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index bb186a0923..39e1250f42 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -1,7 +1,7 @@ (ns syng-im.subs (:require-macros [reagent.ratom :refer [reaction]]) (:require [re-frame.core :refer [register-sub]] - [syng-im.models.chats :refer [chats-list chats-updated? chat-by-id]] + [syng-im.models.chats :refer [chats-list chat-by-id]] [syng-im.models.contacts :refer [contacts-list contacts-list-exclude contacts-list-include]] @@ -13,10 +13,7 @@ (register-sub :get-chats (fn [db _] - (let [chats-updated (reaction (chats-updated? @db))] - (reaction - (let [_ @chats-updated] - (chats-list)))))) + (reaction (:chats @db)))) ;; -- User data -------------------------------------------------------------- @@ -26,34 +23,19 @@ ;; (reaction ;; (get @db :user-phone-number)))) -(register-sub - :get-user-identity - (fn [db _] - (reaction - (get @db :user-identity)))) - -(register-sub - :get-loading - (fn [db _] - (reaction - (get @db :loading)))) - (register-sub :signed-up (fn [db _] - (reaction - (get @db :signed-up)))) + (reaction (:signed-up @db)))) (register-sub :get-contacts (fn [db _] - (reaction - (get @db :contacts)))) + (reaction (:contacts @db)))) (register-sub :all-contacts - (fn [db _] - (reaction - (contacts-list)))) + (fn [_ _] + (reaction (contacts-list)))) (register-sub :all-new-contacts (fn [db _] @@ -81,4 +63,3 @@ (register-sub :db (fn [db _] (reaction @db))) - From fc6926cbfda428a9dde87faee29bee46f6b3c2ec Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Wed, 11 May 2016 14:47:40 +0300 Subject: [PATCH 07/26] chats-list & new-group views/styles Former-commit-id: 0b3469cd649b822520317ac473ac1ccc7f154ae4 --- src/syng_im/android/core.cljs | 6 +- .../styles/{input_styles.cljs => input.cljs} | 0 .../screen.cljs} | 54 ++++---- src/syng_im/chats_list/styles.cljs | 122 ++++++++++++++++ .../chats_list/views/chat_list_item.cljs | 21 +++ src/syng_im/chats_list/views/inner_item.cljs | 52 +++++++ .../components/chats/chat_list_item.cljs | 37 ----- .../chats/chat_list_item_inner.cljs | 131 ------------------ src/syng_im/components/chats/new_group.cljs | 89 ------------ .../components/chats/new_group_contact.cljs | 20 --- .../discovery/discovery_popular_list.cljs | 1 - .../discovery/discovery_recent.cljs | 12 +- .../components/discovery/discovery_tag.cljs | 38 +++-- src/syng_im/components/realm.cljs | 5 +- src/syng_im/components/toolbar.cljs | 12 +- src/syng_im/contacts/views/contact.cljs | 15 +- src/syng_im/contacts/views/contact_inner.cljs | 3 +- src/syng_im/db.cljs | 4 +- src/syng_im/handlers.cljs | 5 + src/syng_im/models/discoveries.cljs | 5 +- src/syng_im/models/protocol.cljs | 4 +- src/syng_im/navigation/handlers.cljs | 11 +- src/syng_im/new_group/screen.cljs | 52 +++++++ src/syng_im/new_group/styles.cljs | 67 +++++++++ src/syng_im/new_group/views/contact.cljs | 19 +++ src/syng_im/participants/views/contact.cljs | 2 +- src/syng_im/participants/views/create.cljs | 7 +- src/syng_im/participants/views/remove.cljs | 7 +- src/syng_im/subs.cljs | 4 + 29 files changed, 424 insertions(+), 381 deletions(-) rename src/syng_im/chat/styles/{input_styles.cljs => input.cljs} (100%) rename src/syng_im/{components/chats/chats_list.cljs => chats_list/screen.cljs} (56%) create mode 100644 src/syng_im/chats_list/styles.cljs create mode 100644 src/syng_im/chats_list/views/chat_list_item.cljs create mode 100644 src/syng_im/chats_list/views/inner_item.cljs delete mode 100644 src/syng_im/components/chats/chat_list_item.cljs delete mode 100644 src/syng_im/components/chats/chat_list_item_inner.cljs delete mode 100644 src/syng_im/components/chats/new_group.cljs delete mode 100644 src/syng_im/components/chats/new_group_contact.cljs create mode 100644 src/syng_im/new_group/screen.cljs create mode 100644 src/syng_im/new_group/styles.cljs create mode 100644 src/syng_im/new_group/views/contact.cljs diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index 56c654bfd2..fb82b1b085 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -11,13 +11,11 @@ [syng-im.components.discovery.discovery :refer [discovery]] [syng-im.components.discovery.discovery-tag :refer [discovery-tag]] [syng-im.chat.screen :refer [chat]] - [syng-im.components.chats.chats-list :refer [chats-list]] - [syng-im.components.chats.new-group :refer [new-group]] + [syng-im.chats-list.screen :refer [chats-list]] + [syng-im.new-group.screen :refer [new-group]] [syng-im.participants.views.create :refer [new-participants]] [syng-im.participants.views.remove :refer [remove-participants]] - [syng-im.utils.logging :as log] [syng-im.utils.utils :refer [toast]] - [syng-im.navigation :as nav] [syng-im.utils.encryption])) (def back-button-handler (cljs/atom {:nav nil diff --git a/src/syng_im/chat/styles/input_styles.cljs b/src/syng_im/chat/styles/input.cljs similarity index 100% rename from src/syng_im/chat/styles/input_styles.cljs rename to src/syng_im/chat/styles/input.cljs diff --git a/src/syng_im/components/chats/chats_list.cljs b/src/syng_im/chats_list/screen.cljs similarity index 56% rename from src/syng_im/components/chats/chats_list.cljs rename to src/syng_im/chats_list/screen.cljs index 9083be800d..a9e238288f 100644 --- a/src/syng_im/components/chats/chats_list.cljs +++ b/src/syng_im/chats_list/screen.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chats.chats-list +(ns syng-im.chats-list.screen (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.components.react :refer [android? view @@ -9,10 +9,9 @@ [syng-im.components.realm :refer [list-view]] [syng-im.utils.logging :as log] [syng-im.navigation :refer [nav-pop]] - [syng-im.resources :as res] [syng-im.utils.listview :refer [to-realm-datasource]] [reagent.core :as r] - [syng-im.components.chats.chat-list-item :refer [chat-list-item]] + [syng-im.chats-list.views.chat-list-item :refer [chat-list-item]] [syng-im.components.action-button :refer [action-button action-button-item]] [syng-im.components.styles :refer [font @@ -26,43 +25,42 @@ [syng-im.components.icons.ionicons :refer [icon]])) (defn chats-list-toolbar [] - [toolbar {:nav-action {:image {:source {:uri "icon_hamburger"} - :style {:width 16 - :height 12}} + [toolbar {:nav-action {:image {:source {:uri "icon_hamburger"} + :style {:width 16 + :height 12}} :handler (fn [])} :title "Chats" - :action {:image {:source {:uri "icon_search"} - :style {:width 17 - :height 17}} + :action {:image {:source {:uri "icon_search"} + :style {:width 17 + :height 17}} :handler (fn [])}}]) -(defn chats-list [{:keys [navigator]}] +(defn chats-list [] (let [chats (subscribe [:get-chats])] (fn [] (let [chats @chats - _ (log/debug "chats=" chats) datasource (to-realm-datasource chats)] - [view {:style {:flex 1 - :backgroundColor "white"}} + [view {:flex 1 + :backgroundColor :white} [chats-list-toolbar] [list-view {:dataSource datasource - :enableEmptySections true - :renderRow (fn [row section-id row-id] - (r/as-element [chat-list-item row navigator])) - :style {:backgroundColor "white"}}] + :renderRow (fn [row _ _] + (r/as-element [chat-list-item row])) + :style {:backgroundColor :white}}] [action-button {:buttonColor color-blue} - [action-button-item {:title "New Chat" - :buttonColor "#9b59b6" - :onPress #(dispatch [:navigate-to - :contact-list])} - [icon {:name "android-create" + [action-button-item + {:title "New Chat" + :buttonColor :#9b59b6 + :onPress #(dispatch [:navigate-to :contact-list])} + [icon {:name :android-create :style {:fontSize 20 :height 22 - :color "white"}}]] - [action-button-item {:title "New Group Chat" - :buttonColor "#1abc9c" - :onPress #(dispatch [:show-group-new])} - [icon {:name "person-stalker" + :color :white}}]] + [action-button-item + {:title "New Group Chat" + :buttonColor :#1abc9c + :onPress #(dispatch [:show-group-new])} + [icon {:name :person-stalker :style {:fontSize 20 :height 22 - :color "white"}}]]]])))) + :color :white}}]]]])))) diff --git a/src/syng_im/chats_list/styles.cljs b/src/syng_im/chats_list/styles.cljs new file mode 100644 index 0000000000..14594cc72c --- /dev/null +++ b/src/syng_im/chats_list/styles.cljs @@ -0,0 +1,122 @@ +(ns syng-im.chats-list.styles + (:require [syng-im.components.styles :refer [font + title-font + color-white + color-blue + online-color + text1-color + text2-color + new-messages-count-color]])) + +(def contact-photo-container + {:borderRadius 50}) + +(def contact-photo-image + {:borderRadius 50 + :width 40 + :height 40}) + +(def online-container + {:position :absolute + :top 24 + :left 24 + :width 20 + :height 20 + :borderRadius 50 + :backgroundColor online-color + :borderWidth 2 + :borderColor color-white}) + +(def online-dot + {:position :absolute + :top 6 + :width 4 + :height 4 + :borderRadius 50 + :backgroundColor color-white}) + +(def online-dot-left + (assoc online-dot :left 3)) + +(def online-dot-right + (assoc online-dot :left 9)) + +(def chat-container + {:flexDirection :row + :paddingVertical 15 + :paddingHorizontal 16 + :height 90}) + +(def photo-container + {:marginTop 2 + :width 44 + :height 44}) + +(def item-container + {:flexDirection :column + :marginLeft 12 + :flex 1}) + +(def name-view + {:flexDirection :row}) + +(def name-text + {:marginTop -2.5 + :color text1-color + :fontSize 14 + :fontFamily title-font}) + +(def group-icon + {:marginTop 4 + :marginLeft 8 + :width 14 + :height 9}) + +(def memebers-text + {:marginTop -0.5 + :marginLeft 4 + :fontFamily font + :fontSize 12 + :color text2-color}) + +(def last-message-text + {:marginTop 7 + :marginRight 40 + :color text1-color + :fontFamily font + :fontSize 14 + :lineHeight 20}) + +(def status-container + {:flexDirection :row + :position :absolute + :top 0 + :right 0}) + +(def status-image + {:marginTop 6 + :width 9 + :height 7}) + +(def datetime-text + {:fontFamily font + :fontSize 12 + :color text2-color + :marginLeft 5}) + +(def new-messages-container + {:position :absolute + :top 36 + :right 0 + :width 24 + :height 24 + :backgroundColor new-messages-count-color + :borderRadius 50}) + +(def new-messages-text + {:top 4 + :left 0 + :fontFamily title-font + :fontSize 10 + :color color-blue + :textAlign :center}) diff --git a/src/syng_im/chats_list/views/chat_list_item.cljs b/src/syng_im/chats_list/views/chat_list_item.cljs new file mode 100644 index 0000000000..9f91eb7bdb --- /dev/null +++ b/src/syng_im/chats_list/views/chat_list_item.cljs @@ -0,0 +1,21 @@ +(ns syng-im.chats-list.views.chat-list-item + (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] + [syng-im.components.react :refer [view + text + image + touchable-highlight]] + [syng-im.components.styles :refer [font]] + [syng-im.chats-list.views.inner-item :refer + [chat-list-item-inner-view]])) + +(defn chat-list-item [chat-obj] + [touchable-highlight + {:on-press #(dispatch [:show-chat (aget chat-obj "chat-id") :push])} + ;; TODO add [photo-path delivery-status new-messages-count online] values to chat-obj + ;; TODO should chat-obj be clj-map? + [view [chat-list-item-inner-view (merge (js->clj chat-obj :keywordize-keys true) + {:photo-path nil + :delivery-status :seen + :new-messages-count 3 + :timestamp "13:54" + :online true})]]]) diff --git a/src/syng_im/chats_list/views/inner_item.cljs b/src/syng_im/chats_list/views/inner_item.cljs new file mode 100644 index 0000000000..0e43c75426 --- /dev/null +++ b/src/syng_im/chats_list/views/inner_item.cljs @@ -0,0 +1,52 @@ +(ns syng-im.chats-list.views.inner-item + (:require [clojure.string :as s] + [syng-im.components.react :refer [view image icon text]] + [syng-im.chats-list.styles :as st] + [syng-im.resources :as res])) + + +(defn contact-photo [photo-path] + [view st/contact-photo-container + [image {:source (if (s/blank? photo-path) + res/user-no-photo + {:uri photo-path}) + :style st/contact-photo-image}]]) + +(defn contact-online [online] + (when online + [view st/online-container + [view st/online-dot-left] + [view st/online-dot-right]])) + +(defn chat-list-item-inner-view + [{:keys [name photo-path delivery-status timestamp new-messages-count online + group-chat contacts]}] + [view st/chat-container + [view st/photo-container + [contact-photo photo-path] + [contact-online online]] + [view st/item-container + [view st/name-view + [text {:style st/name-text} name] + (when group-chat + [icon :group st/group-icon]) + (when group-chat + [text {:style st/memebers-text} + (if (< 1 (count contacts)) + (str (count contacts) " members") + "1 member")])] + [text {:style st/last-message-text + :numberOfLines 2} + (repeatedly 5 #(str "Hi, I'm " name "! "))]] + [view + [view st/status-container + (when delivery-status + [image {:source (if (= (keyword delivery-status) :seen) + {:uri :icon_ok_small} + ;; todo change icon + {:uri :icon_ok_small}) + :style st/status-image}]) + [text {:style st/datetime-text} timestamp]] + (when (pos? new-messages-count) + [view st/new-messages-container + [text {:style st/new-messages-text} new-messages-count]])]]) diff --git a/src/syng_im/components/chats/chat_list_item.cljs b/src/syng_im/components/chats/chat_list_item.cljs deleted file mode 100644 index 574af6fc87..0000000000 --- a/src/syng_im/components/chats/chat_list_item.cljs +++ /dev/null @@ -1,37 +0,0 @@ -(ns syng-im.components.chats.chat-list-item - (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.components.react :refer [view - text - image - touchable-highlight]] - [syng-im.components.styles :refer [font]] - [syng-im.components.chats.chat-list-item-inner :refer [chat-list-item-inner-view]] - [syng-im.utils.logging :as log] - [syng-im.resources :as res])) - -(defn chat-list-item [chat-obj navigator] - [touchable-highlight - {:on-press #(dispatch [:show-chat (aget chat-obj "chat-id") :push])} - ;; TODO add [photo-path delivery-status new-messages-count online] values to chat-obj - ;; TODO should chat-obj be clj-map? - [view {} [chat-list-item-inner-view (merge (js->clj chat-obj :keywordize-keys true) - {:photo-path nil - :delivery-status :seen - :new-messages-count 3 - :timestamp "13:54" - :online true})]]]) - -(comment [view {:style {:flexDirection "row" - :width 260 - :marginVertical 5}} - [image {:source res/chat-icon - :style {:borderWidth 2 - :borderColor "#FFFFFF" - :width 32 - :height 30 - :marginRight 5 - :marginLeft 5}}] - [text {:style {:fontSize 14 - :fontFamily font - :color "#4A5258"}} - (subs (aget chat-obj "name") 0 30)]]) diff --git a/src/syng_im/components/chats/chat_list_item_inner.cljs b/src/syng_im/components/chats/chat_list_item_inner.cljs deleted file mode 100644 index 2c59897bfc..0000000000 --- a/src/syng_im/components/chats/chat_list_item_inner.cljs +++ /dev/null @@ -1,131 +0,0 @@ -(ns syng-im.components.chats.chat-list-item-inner - (:require [clojure.string :as s] - [syng-im.components.react :refer [view image text]] - [syng-im.components.styles :refer [font - title-font - color-white - color-blue - online-color - text1-color - text2-color - new-messages-count-color]] - [syng-im.resources :as res])) - -(defn contact-photo [{:keys [photo-path]}] - [view {:borderRadius 50} - [image {:source (if (s/blank? photo-path) - res/user-no-photo - {:uri photo-path}) - :style {:borderRadius 50 - :width 40 - :height 40}}]]) - -(defn contact-online [{:keys [online]}] - (when online - [view {:position "absolute" - :top 24 - :left 24 - :width 20 - :height 20 - :borderRadius 50 - :backgroundColor online-color - :borderWidth 2 - :borderColor color-white} - [view {:position "absolute" - :top 6 - :left 3 - :width 4 - :height 4 - :borderRadius 50 - :backgroundColor color-white}] - [view {:position "absolute" - :top 6 - :left 9 - :width 4 - :height 4 - :borderRadius 50 - :backgroundColor color-white}]])) - -(defn chat-list-item-inner-view - [{:keys [name photo-path delivery-status timestamp new-messages-count online - group-chat contacts]}] - [view {:style {:flexDirection "row" - :paddingVertical 15 - :paddingHorizontal 16 - :height 90}} - [view {:marginTop 2 - :width 44 - :height 44} -;;; photo - [contact-photo {:photo-path photo-path}] -;;; online - [contact-online {:online online}]] - [view {:style {:flexDirection "column" - :marginLeft 12 - :flex 1}} -;;; name - [view {:style {:flexDirection "row"}} - [text {:style {:marginTop -2.5 - :color text1-color - :fontSize 14 - :fontFamily title-font}} name] -;;; group size - (when group-chat - [image {:source {:uri "icon_group"} - :style {:marginTop 4 - :marginLeft 8 - :width 14 - :height 9}}]) - (when group-chat - [text {:style {:marginTop -0.5 - :marginLeft 4 - :fontFamily font - :fontSize 12 - :color text2-color}} - (if (< 1 (count contacts)) - (str (count contacts) " members") - "1 member")])] -;;; last message - [text {:style {:marginTop 7 - :marginRight 40 - :color text1-color - :fontFamily font - :fontSize 14 - :lineHeight 20} - :numberOfLines 2} - (repeatedly 5 #(str "Hi, I'm " name "! "))]] - [view {} -;;; delivery status - [view {:style {:flexDirection "row" - :position "absolute" - :top 0 - :right 0}} - (when delivery-status - [image {:source (if (= (keyword delivery-status) :seen) - {:uri "icon_ok_small"} - {:uri "icon_ok_small"}) - :style {:marginTop 6 - :width 9 - :height 7}}]) -;;; datetime - [text {:style {:fontFamily font - :fontSize 12 - :color text2-color - :marginLeft 5}} - timestamp]] -;;; new messages count - (when (pos? new-messages-count) - [view {:style {:position "absolute" - :top 36 - :right 0 - :width 24 - :height 24 - :backgroundColor new-messages-count-color - :borderRadius 50}} - [text {:style {:top 4 - :left 0 - :fontFamily title-font - :fontSize 10 - :color color-blue - :textAlign "center"}} - new-messages-count]])]]) diff --git a/src/syng_im/components/chats/new_group.cljs b/src/syng_im/components/chats/new_group.cljs deleted file mode 100644 index 7f9c852b71..0000000000 --- a/src/syng_im/components/chats/new_group.cljs +++ /dev/null @@ -1,89 +0,0 @@ -(ns syng-im.components.chats.new-group - (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.resources :as res] - [syng-im.components.react :refer [view - text-input - text - image - touchable-highlight]] - [syng-im.components.styles :refer [font - title-font - color-white - color-purple - text1-color - text2-color - toolbar-background1]] - [syng-im.components.toolbar :refer [toolbar]] - [syng-im.components.realm :refer [list-view]] - [syng-im.utils.listview :refer [to-realm-datasource]] - [syng-im.components.chats.new-group-contact :refer [new-group-contact]] - [reagent.core :as r] - [syng-im.navigation :refer [nav-pop]])) - -(defn new-group-toolbar [navigator group-name] - [toolbar {:navigator navigator - :title "New group chat" - :action {:image {:source res/v ;; {:uri "icon_search"} - :style {:width 20 - :height 18}} - :handler #(dispatch [:create-new-group group-name])}}]) - -(defn new-group [{:keys [navigator]}] - (let [contacts (subscribe [:all-contacts]) - group-name (r/atom nil)] - (fn [{:keys [navigator]}] - (let [contacts-ds (to-realm-datasource @contacts)] - [view {:style {:flex 1 - :flexDirection "column" - :backgroundColor color-white}} - [new-group-toolbar navigator @group-name] - [view {:style {:marginHorizontal 16}} - [text {:style {:marginTop 24 - :marginBottom 16 - :color text2-color - :fontFamily font - :fontSize 14 - :lineHeight 20}} - "Chat name"] - [text-input {:underlineColorAndroid color-purple - :style {:marginLeft -4 - :fontSize 14 - :fontFamily font - :color text1-color} - :autoFocus true - :placeholder "Group Name" - :placeholderTextColor text2-color - :onChangeText (fn [new-text] - (reset! group-name new-text) - (r/flush)) - :onSubmitEditing (fn [e] - ;(dispatch [:send-chat-msg @chat-id @text]) - (reset! group-name nil))} - @group-name] - [text {:style {:marginTop 24 - :marginBottom 16 - :color text2-color - :fontFamily font - :fontSize 14 - :lineHeight 20}} - "Members"] - [touchable-highlight {:on-press (fn [])} - [view {:style {:flexDirection "row" - :marginBottom 16}} - [image {:source {:uri "icon_add_gray"} - :style {:marginVertical 19 - :marginHorizontal 3 - :width 17 - :height 17}}] - [text {:style {:marginTop 18 - :marginLeft 32 - :color text2-color - :fontFamily font - :fontSize 14 - :lineHeight 20}} - "Add members"]]] - [list-view {:dataSource contacts-ds - :enableEmptySections true - :renderRow (fn [row section-id row-id] - (r/as-element [new-group-contact (js->clj row :keywordize-keys true) navigator])) - :style {:backgroundColor "white"}}]]])))) diff --git a/src/syng_im/components/chats/new_group_contact.cljs b/src/syng_im/components/chats/new_group_contact.cljs deleted file mode 100644 index 79153d775b..0000000000 --- a/src/syng_im/components/chats/new_group_contact.cljs +++ /dev/null @@ -1,20 +0,0 @@ -(ns syng-im.components.chats.new-group-contact - (:require [syng-im.resources :as res] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.components.react :refer [view]] - [syng-im.components.contact-list.contact-inner :refer [contact-inner-view]] - [syng-im.components.item-checkbox :refer [item-checkbox]] - [syng-im.utils.logging :as log] - [reagent.core :as r])) - -(defn new-group-contact [{:keys [whisper-identity] :as contact} navigator] - (let [checked (r/atom false)] - (fn [] - [view {:style {:flexDirection "row" - :height 56}} - [item-checkbox {:onToggle (fn [checked?] - (reset! checked checked?) - (dispatch [:select-for-new-group whisper-identity checked?])) - :checked @checked - :size 30}] - [contact-inner-view contact]]))) diff --git a/src/syng_im/components/discovery/discovery_popular_list.cljs b/src/syng_im/components/discovery/discovery_popular_list.cljs index 0291a1bb82..55a4b94c83 100644 --- a/src/syng_im/components/discovery/discovery_popular_list.cljs +++ b/src/syng_im/components/discovery/discovery_popular_list.cljs @@ -9,7 +9,6 @@ text image]] [reagent.core :as r] - [syng-im.components.realm :refer [list-view]] [syng-im.components.discovery.styles :as st] [syng-im.utils.listview :refer [to-realm-datasource]] [syng-im.components.discovery.discovery-popular-list-item :refer [discovery-popular-list-item] ]) diff --git a/src/syng_im/components/discovery/discovery_recent.cljs b/src/syng_im/components/discovery/discovery_recent.cljs index 4b1a650322..c253ca02b4 100644 --- a/src/syng_im/components/discovery/discovery_recent.cljs +++ b/src/syng_im/components/discovery/discovery_recent.cljs @@ -21,15 +21,13 @@ (defn render-separator [sectionID, rowID, adjacentRowHighlighted] (let [elem (r/as-element [view {:style st/row-separator - :key rowID}])] + :key rowID}])] elem)) (defn discovery-recent [] (let [discoveries (subscribe [:get-discoveries]) - datasource (to-realm-datasource @discoveries)] - [list-view {:dataSource datasource - :enableEmptySections true - :renderRow render-row + datasource (to-realm-datasource @discoveries)] + [list-view {:dataSource datasource + :renderRow render-row :renderSeparator render-separator - :style st/recent-list}] - )) \ No newline at end of file + :style st/recent-list}])) diff --git a/src/syng_im/components/discovery/discovery_tag.cljs b/src/syng_im/components/discovery/discovery_tag.cljs index f8a7fa88a8..70cffe6d23 100644 --- a/src/syng_im/components/discovery/discovery_tag.cljs +++ b/src/syng_im/components/discovery/discovery_tag.cljs @@ -20,7 +20,7 @@ (let [elem (discovery-popular-list-item row)] elem) (r/as-element [text "null"]) - )) + )) (defn render-separator [sectionID, rowID, adjacentRowHighlighted] (let [elem (r/as-element [view {:style st/row-separator @@ -33,27 +33,25 @@ (str " #" tag)]]) (defn discovery-tag [{:keys [tag navigator]}] - (let [tag (subscribe [:get-current-tag]) + (let [tag (subscribe [:get-current-tag]) discoveries (subscribe [:get-discoveries-by-tag @tag 0])] (log/debug "Got discoveries: " @discoveries) (fn [] - (let [items @discoveries + (let [items @discoveries datasource (to-realm-datasource items)] - [view {:style st/discovery-tag-container} - [toolbar {:navigator navigator - :nav-action {:image {:source {:uri "icon_back"} - :style st/icon-back} - :handler (fn [] (nav-pop navigator))} - :title "Add Participants" - :content (title-content @tag) - :action {:image {:source {:uri "icon_search"} - :style st/icon-search} - :handler (fn [] - ())}}] + [view {:style st/discovery-tag-container} + [toolbar {:navigator navigator + :nav-action {:image {:source {:uri "icon_back"} + :style st/icon-back} + :handler (fn [] (nav-pop navigator))} + :title "Add Participants" + :content (title-content @tag) + :action {:image {:source {:uri "icon_search"} + :style st/icon-search} + :handler (fn [] + ())}}] - [list-view {:dataSource datasource - :enableEmptySections true - :renderRow render-row - :renderSeparator render-separator - :style st/recent-list}] - ])))) \ No newline at end of file + [list-view {:dataSource datasource + :renderRow render-row + :renderSeparator render-separator + :style st/recent-list}]])))) diff --git a/src/syng_im/components/realm.cljs b/src/syng_im/components/realm.cljs index 524c2f6909..93f8d84ccc 100644 --- a/src/syng_im/components/realm.cljs +++ b/src/syng_im/components/realm.cljs @@ -3,7 +3,10 @@ (set! js/window.RealmReactNative (js/require "realm/react-native")) -(def list-view (r/adapt-react-class (.-ListView js/RealmReactNative))) +(def list-view-class (r/adapt-react-class (.-ListView js/RealmReactNative))) + +(defn list-view [props] + [list-view-class (merge {:enableEmptySections true} props)]) (comment diff --git a/src/syng_im/components/toolbar.cljs b/src/syng_im/components/toolbar.cljs index 4e9a38fd0c..6bc93a9aa7 100644 --- a/src/syng_im/components/toolbar.cljs +++ b/src/syng_im/components/toolbar.cljs @@ -1,6 +1,5 @@ (ns syng-im.components.toolbar - (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.resources :as res] + (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view text-input text @@ -13,12 +12,9 @@ text1-color text2-color toolbar-background1]] - [syng-im.components.realm :refer [list-view]] - [syng-im.utils.listview :refer [to-realm-datasource]] - [reagent.core :as r] - [syng-im.navigation :refer [nav-pop]])) + [syng-im.utils.listview :refer [to-realm-datasource]])) -(defn toolbar [{:keys [navigator title nav-action action background-color content style]}] +(defn toolbar [{:keys [title nav-action action background-color content style]}] (let [style (merge {:flexDirection "row" :backgroundColor (or background-color toolbar-background1) :height 56 @@ -31,7 +27,7 @@ :alignItems "center" :justifyContent "center"} [image (:image nav-action)]]] - [touchable-highlight {:on-press #(nav-pop navigator)} + [touchable-highlight {:on-press #(dispatch [:navigate-back])} [view {:width 56 :height 56} [image {:source {:uri "icon_back"} diff --git a/src/syng_im/contacts/views/contact.cljs b/src/syng_im/contacts/views/contact.cljs index 6bbbdc7938..41df1c47d8 100644 --- a/src/syng_im/contacts/views/contact.cljs +++ b/src/syng_im/contacts/views/contact.cljs @@ -1,13 +1,8 @@ (ns syng-im.contacts.views.contact - (:require [syng-im.components.react :refer [view text image touchable-highlight]] - [syng-im.resources :as res] - [syng-im.navigation :as nav] + (:require [syng-im.components.react :refer [view touchable-highlight]] + [re-frame.core :refer [dispatch]] [syng-im.contacts.views.contact-inner :refer [contact-inner-view]])) -(defn show-chat [navigator whisper-identity] - (nav/nav-push navigator {:view-id :chat})) - -(defn contact-view [{:keys [navigator contact]}] - (let [{:keys [whisper-identity]} contact] - [touchable-highlight {:onPress #(show-chat navigator whisper-identity)} - [view {} [contact-inner-view contact]]])) +(defn contact-view [{:keys [contact]}] + [touchable-highlight {:onPress #(dispatch [:navigate-to :chat])} + [view {} [contact-inner-view contact]]]) diff --git a/src/syng_im/contacts/views/contact_inner.cljs b/src/syng_im/contacts/views/contact_inner.cljs index 3dd46f458f..9e47992a18 100644 --- a/src/syng_im/contacts/views/contact_inner.cljs +++ b/src/syng_im/contacts/views/contact_inner.cljs @@ -43,8 +43,7 @@ :borderRadius 50 :backgroundColor color-white}]])) -(defn contact-inner-view [{:keys [name photo-path delivery-status datetime new-messages-count - online whisper-identity]}] +(defn contact-inner-view [{:keys [name photo-path online]}] [view {:style {:flexDirection "row" :height 56}} [view {:style {:marginTop 8 diff --git a/src/syng_im/db.cljs b/src/syng_im/db.cljs index 71274d6a97..d7b452a0f3 100644 --- a/src/syng_im/db.cljs +++ b/src/syng_im/db.cljs @@ -19,15 +19,13 @@ :show-actions false :new-group #{} :new-participants #{} - :signed-up false + :signed-up true :view-id default-view :navigation-stack (list default-view) :name "My Name" :current-tag nil}) (def protocol-initialized-path [:protocol-initialized]) -(def identity-password-path [:identity-password]) -(def updated-chats-signal-path [:chats-updated-signal]) (defn chat-input-text-path [chat-id] [:chats chat-id :input-text]) (defn chat-staged-commands-path [chat-id] diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index 6c42200632..3aa7e8aa63 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -57,6 +57,11 @@ ;; -- Common -------------------------------------------------------------- +(register-handler :set + (debug + (fn [db [_ k v]] + (assoc db k v)))) + (register-handler :initialize-db (fn [_ _] app-db)) diff --git a/src/syng_im/models/discoveries.cljs b/src/syng_im/models/discoveries.cljs index 5a568a11c9..03f7a623ad 100644 --- a/src/syng_im/models/discoveries.cljs +++ b/src/syng_im/models/discoveries.cljs @@ -7,10 +7,7 @@ [syng-im.db :as db])) (defn signal-discoveries-updated [db] - (update-in db db/updated-discoveries-signal-path (fn [current] - (if current - (inc current) - 0)))) + (update-in db db/updated-discoveries-signal-path #(if % (inc %) 0))) (defn discoveries-updated? [db] (get-in db db/updated-discoveries-signal-path)) diff --git a/src/syng_im/models/protocol.cljs b/src/syng_im/models/protocol.cljs index 301876a0d7..176cab7047 100644 --- a/src/syng_im/models/protocol.cljs +++ b/src/syng_im/models/protocol.cljs @@ -13,14 +13,14 @@ (assoc-in db db/protocol-initialized-path initialized?)) (defn update-identity [db identity] - (let [password (get-in db db/identity-password-path) + (let [password (:identity-password db) encrypted (password-encrypt password (to-edn-string identity))] (s/put kv/kv-store :identity encrypted) (assoc db :user-identity identity))) (defn stored-identity [db] (let [encrypted (s/get kv/kv-store :identity) - password (get-in db db/identity-password-path)] + password (:identity-password db)] (when encrypted (read-string (password-decrypt password encrypted))))) diff --git a/src/syng_im/navigation/handlers.cljs b/src/syng_im/navigation/handlers.cljs index f45b66a934..d15d29bf0d 100644 --- a/src/syng_im/navigation/handlers.cljs +++ b/src/syng_im/navigation/handlers.cljs @@ -1,5 +1,5 @@ (ns syng-im.navigation.handlers - (:require [re-frame.core :refer [register-handler dispatch]])) + (:require [re-frame.core :refer [register-handler dispatch debug]])) (defn push-view [db view-id] (-> db @@ -35,10 +35,11 @@ (assoc :navigation-stack navigation-stack')))))) (register-handler :show-group-new - (fn [db _] - (-> db - (push-view :new-group) - (assoc-in :new-group #{})))) + (debug + (fn [db _] + (-> db + (push-view :new-group) + (assoc :new-group #{}))))) (register-handler :show-chat (fn [db [_ chat-id nav-type]] diff --git a/src/syng_im/new_group/screen.cljs b/src/syng_im/new_group/screen.cljs new file mode 100644 index 0000000000..695aa37040 --- /dev/null +++ b/src/syng_im/new_group/screen.cljs @@ -0,0 +1,52 @@ +(ns syng-im.new-group.screen + (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] + [syng-im.resources :as res] + [syng-im.components.react :refer [view + text-input + text + image + icon + touchable-highlight]] + [syng-im.components.styles :refer [color-purple]] + [syng-im.components.toolbar :refer [toolbar]] + [syng-im.components.realm :refer [list-view]] + [syng-im.utils.listview :refer [to-realm-datasource]] + [syng-im.new-group.views.contact :refer [new-group-contact]] + [reagent.core :as r] + [syng-im.new-group.styles :as st])) + + +(defn new-group-toolbar [group-name] + [toolbar {:title "New group chat" + :action {:image {:source res/v ;; {:uri "icon_search"} + :style st/toolbar-icon} + :handler #(dispatch [:create-new-group group-name])}}]) + +(defn new-group [] + (let [contacts (subscribe [:all-contacts]) + group-name (subscribe [:get ::group-name])] + (fn [] + (let [contacts-ds (to-realm-datasource @contacts)] + [view st/new-group-container + [new-group-toolbar @group-name] + [view st/chat-name-container + [text {:style st/chat-name-text} "Chat name"] + [text-input + {:underlineColorAndroid color-purple + :style st/group-name-input + :autoFocus true + :placeholder "Group Name" + :onChangeText #(dispatch [:set ::group-name %]) + :onSubmitEditing #(dispatch [:set ::group-name nil])} + @group-name] + [text {:style st/members-text} "Members"] + [touchable-highlight {:on-press (fn [])} + [view st/add-container + [icon :add_gray st/add-icon] + [text {:style st/add-text} "Add members"]]] + [list-view + {:dataSource contacts-ds + :renderRow (fn [row _ _] + (let [row' (js->clj row :keywordize-keys true)] + (r/as-element [new-group-contact row']))) + :style st/contacts-list}]]])))) diff --git a/src/syng_im/new_group/styles.cljs b/src/syng_im/new_group/styles.cljs new file mode 100644 index 0000000000..695c616ea9 --- /dev/null +++ b/src/syng_im/new_group/styles.cljs @@ -0,0 +1,67 @@ +(ns syng-im.new-group.styles + (:require [syng-im.components.styles :refer [font + title-font + color-white + color-purple + text1-color + text2-color + toolbar-background1]])) + +(def toolbar-icon + {:width 20 + :height 18}) + +(def new-group-container + {:flex 1 + :flexDirection :column + :backgroundColor color-white}) + +(def chat-name-container + {:marginHorizontal 16}) + +(def chat-name-text + {:marginTop 24 + :marginBottom 16 + :color text2-color + :fontFamily font + :fontSize 14 + :lineHeight 20}) + +(def group-name-input + {:marginLeft -4 + :fontSize 14 + :fontFamily font + :color text1-color}) + +(def members-text + {:marginTop 24 + :marginBottom 16 + :color text2-color + :fontFamily font + :fontSize 14 + :lineHeight 20}) + +(def add-container + {:flexDirection :row + :marginBottom 16}) + +(def add-icon + {:marginVertical 19 + :marginHorizontal 3 + :width 17 + :height 17}) + +(def add-text + {:marginTop 18 + :marginLeft 32 + :color text2-color + :fontFamily font + :fontSize 14 + :lineHeight 20}) + +(def contacts-list + {:backgroundColor :white}) + +(def contact-container + {:flexDirection :row + :height 56}) diff --git a/src/syng_im/new_group/views/contact.cljs b/src/syng_im/new_group/views/contact.cljs new file mode 100644 index 0000000000..2a12eb2bc5 --- /dev/null +++ b/src/syng_im/new_group/views/contact.cljs @@ -0,0 +1,19 @@ +(ns syng-im.new-group.views.contact + (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] + [syng-im.components.react :refer [view]] + [syng-im.contacts.views.contact-inner :refer [contact-inner-view]] + [syng-im.components.item-checkbox :refer [item-checkbox]] + [reagent.core :as r] + [syng-im.new-group.styles :as st])) + +(defn new-group-contact [{:keys [whisper-identity] :as contact}] + (let [checked (r/atom false)] + (fn [] + [view st/contact-container + [item-checkbox + {:onToggle (fn [checked?] + (reset! checked checked?) + (dispatch [:select-for-new-group whisper-identity checked?])) + :checked @checked + :size 30}] + [contact-inner-view contact]]))) diff --git a/src/syng_im/participants/views/contact.cljs b/src/syng_im/participants/views/contact.cljs index 0309fee299..f193f24deb 100644 --- a/src/syng_im/participants/views/contact.cljs +++ b/src/syng_im/participants/views/contact.cljs @@ -1,7 +1,7 @@ (ns syng-im.participants.views.contact (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.components.react :refer [view]] - [syng-im.components.contact-list.contact-inner :refer [contact-inner-view]] + [syng-im.contacts.views.contact-inner :refer [contact-inner-view]] [syng-im.components.item-checkbox :refer [item-checkbox]] [reagent.core :as r] [syng-im.participants.styles :as st])) diff --git a/src/syng_im/participants/views/create.cljs b/src/syng_im/participants/views/create.cljs index 38729add4b..7e2c522295 100644 --- a/src/syng_im/participants/views/create.cljs +++ b/src/syng_im/participants/views/create.cljs @@ -29,7 +29,6 @@ (let [contacts-ds (to-realm-datasource @contacts)] [view st/participants-container [new-participants-toolbar navigator] - [list-view {:dataSource contacts-ds - :enableEmptySections true - :renderRow new-participants-row - :style st/participants-list}]])))) + [list-view {:dataSource contacts-ds + :renderRow new-participants-row + :style st/participants-list}]])))) diff --git a/src/syng_im/participants/views/remove.cljs b/src/syng_im/participants/views/remove.cljs index d475406c8a..306d91084d 100644 --- a/src/syng_im/participants/views/remove.cljs +++ b/src/syng_im/participants/views/remove.cljs @@ -30,7 +30,6 @@ (let [contacts-ds (to-realm-datasource @contacts)] [view st/participants-container [remove-participants-toolbar navigator] - [list-view {:dataSource contacts-ds - :enableEmptySections true - :renderRow remove-participants-row - :style st/participants-list}]])))) + [list-view {:dataSource contacts-ds + :renderRow remove-participants-row + :style st/participants-list}]])))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index 39e1250f42..e20b7561c6 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -15,6 +15,10 @@ (fn [db _] (reaction (:chats @db)))) +(register-sub :get + (fn [db [_ k]] + (reaction (k @db)))) + ;; -- User data -------------------------------------------------------------- ;; (register-sub From d3cfaa7196fd38cb3c2c890e6885f4060561d6bd Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Wed, 11 May 2016 14:58:03 +0300 Subject: [PATCH 08/26] chats-list screen styles Former-commit-id: bb0a6c848f70fbb2a79c59bb2a9350a6a6bcbc11 --- src/syng_im/chats_list/screen.cljs | 27 +++++++++++---------------- src/syng_im/chats_list/styles.cljs | 25 +++++++++++++++++++++++++ 2 files changed, 36 insertions(+), 16 deletions(-) diff --git a/src/syng_im/chats_list/screen.cljs b/src/syng_im/chats_list/screen.cljs index a9e238288f..96320dc886 100644 --- a/src/syng_im/chats_list/screen.cljs +++ b/src/syng_im/chats_list/screen.cljs @@ -22,17 +22,17 @@ text1-color text2-color]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.components.icons.ionicons :refer [icon]])) + [syng-im.components.icons.ionicons :refer [icon]] + [syng-im.chats-list.styles :as st])) + (defn chats-list-toolbar [] - [toolbar {:nav-action {:image {:source {:uri "icon_hamburger"} - :style {:width 16 - :height 12}} + [toolbar {:nav-action {:image {:source {:uri :icon_hamburger} + :style st/hamburger-icon } :handler (fn [])} :title "Chats" - :action {:image {:source {:uri "icon_search"} - :style {:width 17 - :height 17}} + :action {:image {:source {:uri :icon_search} + :style st/search-icon} :handler (fn [])}}]) (defn chats-list [] @@ -40,27 +40,22 @@ (fn [] (let [chats @chats datasource (to-realm-datasource chats)] - [view {:flex 1 - :backgroundColor :white} + [view st/chats-container [chats-list-toolbar] [list-view {:dataSource datasource :renderRow (fn [row _ _] (r/as-element [chat-list-item row])) - :style {:backgroundColor :white}}] + :style st/list-container}] [action-button {:buttonColor color-blue} [action-button-item {:title "New Chat" :buttonColor :#9b59b6 :onPress #(dispatch [:navigate-to :contact-list])} [icon {:name :android-create - :style {:fontSize 20 - :height 22 - :color :white}}]] + :style st/create-icon}]] [action-button-item {:title "New Group Chat" :buttonColor :#1abc9c :onPress #(dispatch [:show-group-new])} [icon {:name :person-stalker - :style {:fontSize 20 - :height 22 - :color :white}}]]]])))) + :style st/person-stalker-icon}]]]])))) diff --git a/src/syng_im/chats_list/styles.cljs b/src/syng_im/chats_list/styles.cljs index 14594cc72c..5b37f27122 100644 --- a/src/syng_im/chats_list/styles.cljs +++ b/src/syng_im/chats_list/styles.cljs @@ -120,3 +120,28 @@ :fontSize 10 :color color-blue :textAlign :center}) + +(def hamburger-icon + {:width 16 + :height 12}) + +(def search-icon + {:width 17 + :height 17}) + +(def chats-container + {:flex 1 + :backgroundColor :white}) + +(def list-container + {:backgroundColor :white}) + +(def create-icon + {:fontSize 20 + :height 22 + :color :white}) + +(def person-stalker-icon + {:fontSize 20 + :height 22 + :color :white}) From a2467348e32a455c061438e7c9b67a4794cd0f34 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Wed, 11 May 2016 16:06:37 +0300 Subject: [PATCH 09/26] contacts styles Former-commit-id: c5c71691c33d2c16b14bb49b3a44048bd52129a7 --- src/syng_im/chats_list/screen.cljs | 24 ++----- src/syng_im/components/carousel/styles.cljs | 4 +- src/syng_im/components/discovery/styles.cljs | 26 +++---- src/syng_im/components/styles.cljs | 2 +- src/syng_im/components/toolbar.cljs | 18 ++--- src/syng_im/contacts/handlers.cljs | 14 ++++ src/syng_im/contacts/screen.cljs | 51 +++++--------- src/syng_im/contacts/styles.cljs | 69 +++++++++++++++++++ src/syng_im/contacts/subs.cljs | 5 ++ src/syng_im/contacts/views/contact.cljs | 2 +- src/syng_im/contacts/views/contact_inner.cljs | 59 ++++------------ src/syng_im/handlers.cljs | 3 +- src/syng_im/ios/core.cljs | 6 +- src/syng_im/models/chats.cljs | 4 +- src/syng_im/subs.cljs | 7 +- 15 files changed, 161 insertions(+), 133 deletions(-) create mode 100644 src/syng_im/contacts/handlers.cljs create mode 100644 src/syng_im/contacts/styles.cljs create mode 100644 src/syng_im/contacts/subs.cljs diff --git a/src/syng_im/chats_list/screen.cljs b/src/syng_im/chats_list/screen.cljs index 96320dc886..8d3edbec7b 100644 --- a/src/syng_im/chats_list/screen.cljs +++ b/src/syng_im/chats_list/screen.cljs @@ -1,26 +1,16 @@ (ns syng-im.chats-list.screen - (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.components.react :refer [android? - view + (:require [re-frame.core :refer [subscribe dispatch]] + [syng-im.components.react :refer [view text image - touchable-highlight - navigator]] + touchable-highlight]] [syng-im.components.realm :refer [list-view]] - [syng-im.utils.logging :as log] - [syng-im.navigation :refer [nav-pop]] [syng-im.utils.listview :refer [to-realm-datasource]] [reagent.core :as r] [syng-im.chats-list.views.chat-list-item :refer [chat-list-item]] [syng-im.components.action-button :refer [action-button action-button-item]] - [syng-im.components.styles :refer [font - title-font - color-white - color-black - color-blue - text1-color - text2-color]] + [syng-im.components.styles :refer [color-blue]] [syng-im.components.toolbar :refer [toolbar]] [syng-im.components.icons.ionicons :refer [icon]] [syng-im.chats-list.styles :as st])) @@ -28,7 +18,7 @@ (defn chats-list-toolbar [] [toolbar {:nav-action {:image {:source {:uri :icon_hamburger} - :style st/hamburger-icon } + :style st/hamburger-icon} :handler (fn [])} :title "Chats" :action {:image {:source {:uri :icon_search} @@ -36,7 +26,7 @@ :handler (fn [])}}]) (defn chats-list [] - (let [chats (subscribe [:get-chats])] + (let [chats (subscribe [:get :chats])] (fn [] (let [chats @chats datasource (to-realm-datasource chats)] @@ -45,7 +35,7 @@ [list-view {:dataSource datasource :renderRow (fn [row _ _] (r/as-element [chat-list-item row])) - :style st/list-container}] + :style st/list-container}] [action-button {:buttonColor color-blue} [action-button-item {:title "New Chat" diff --git a/src/syng_im/components/carousel/styles.cljs b/src/syng_im/components/carousel/styles.cljs index def9de8c10..b9a05aaff1 100644 --- a/src/syng_im/components/carousel/styles.cljs +++ b/src/syng_im/components/carousel/styles.cljs @@ -19,6 +19,6 @@ (defn page [page-width margin] {:width page-width - :justifyContent "center" + :justifyContent :center :marginLeft margin - :marginRight margin}) \ No newline at end of file + :marginRight margin}) diff --git a/src/syng_im/components/discovery/styles.cljs b/src/syng_im/components/discovery/styles.cljs index 9c988558f9..957a1f7940 100644 --- a/src/syng_im/components/discovery/styles.cljs +++ b/src/syng_im/components/discovery/styles.cljs @@ -17,7 +17,7 @@ :borderBottomColor "#eff2f3"}) (def row - {:flexDirection "row"}) + {:flexDirection :row}) (def column {:flexDirection "column"}) @@ -34,8 +34,8 @@ (def discovery-title {:color "#000000de" - :alignSelf "center" - :textAlign "center" + :alignSelf :center + :textAlign :center :fontFamily "sans-serif" :fontSize 16}) @@ -71,8 +71,8 @@ :fontSize 14 :paddingRight 5 :paddingBottom 2 - :alignItems "center" - :justifyContent "center"}) + :alignItems :center + :justifyContent :center}) (def tag-name-container {:flexDirection "column" @@ -86,8 +86,8 @@ :fontSize 12 :paddingRight 5 :paddingBottom 2 - :alignItems "center" - :justifyContent "center"}) + :alignItems :center + :justifyContent :center}) (def tag-count-container {:flex 0.2 @@ -98,18 +98,18 @@ (def popular-list-container {:flex 1 - :backgroundColor "white" + :backgroundColor :white :paddingLeft 10 :paddingTop 16}) (def popular-list - {:backgroundColor "white" + {:backgroundColor :white :paddingTop 13}) ;; discover_popular_list_item.cjls (def popular-list-item - {:flexDirection "row" + {:flexDirection :row :paddingTop 10 :paddingBottom 10}) @@ -132,7 +132,7 @@ (def popular-list-item-avatar-container {:flex 0.2 :flexDirection "column" - :alignItems "center" + :alignItems :center :paddingTop 5}) (def popular-list-item-avatar @@ -144,7 +144,7 @@ ;; discovery_recent (def recent-list - {:backgroundColor "white" + {:backgroundColor :white :paddingLeft 15}) ;; discovery_tag @@ -172,4 +172,4 @@ (def icon-search {:width 17 - :height 17}) \ No newline at end of file + :height 17}) diff --git a/src/syng_im/components/styles.cljs b/src/syng_im/components/styles.cljs index 5f55404a35..77cad2f864 100644 --- a/src/syng_im/components/styles.cljs +++ b/src/syng_im/components/styles.cljs @@ -8,7 +8,7 @@ (def color-black "#000000de") (def color-purple "#a187d5") (def color-gray "#838c93de") -(def color-white "white") +(def color-white :white) (def color-light-blue "#bbc4cb") (def color-light-blue-transparent "#bbc4cb32") (def color-dark-mint "#5fc48d") diff --git a/src/syng_im/components/toolbar.cljs b/src/syng_im/components/toolbar.cljs index 6bc93a9aa7..edc824c83b 100644 --- a/src/syng_im/components/toolbar.cljs +++ b/src/syng_im/components/toolbar.cljs @@ -15,7 +15,7 @@ [syng-im.utils.listview :refer [to-realm-datasource]])) (defn toolbar [{:keys [title nav-action action background-color content style]}] - (let [style (merge {:flexDirection "row" + (let [style (merge {:flexDirection :row :backgroundColor (or background-color toolbar-background1) :height 56 :elevation 2} style)] @@ -24,8 +24,8 @@ [touchable-highlight {:on-press (:handler nav-action)} [view {:width 56 :height 56 - :alignItems "center" - :justifyContent "center"} + :alignItems :center + :justifyContent :center} [image (:image nav-action)]]] [touchable-highlight {:on-press #(dispatch [:navigate-back])} [view {:width 56 @@ -37,12 +37,12 @@ :height 14}}]]]) (if content [view {:style {:flex 1 - :alignItems "center" - :justifyContent "center"}} + :alignItems :center + :justifyContent :center}} content] [view {:style {:flex 1 - :alignItems "center" - :justifyContent "center"}} + :alignItems :center + :justifyContent :center}} [text {:style {:marginTop -2.5 :color text1-color :fontSize 16 @@ -51,7 +51,7 @@ [touchable-highlight {:on-press (:handler action)} [view {:width 56 :height 56 - :alignItems "center" - :justifyContent "center"} + :alignItems :center + :justifyContent :center} [image (:image action)]]]])) diff --git a/src/syng_im/contacts/handlers.cljs b/src/syng_im/contacts/handlers.cljs new file mode 100644 index 0000000000..58586cc671 --- /dev/null +++ b/src/syng_im/contacts/handlers.cljs @@ -0,0 +1,14 @@ +(ns syng-im.contacts.handlers + (:require [re-frame.core :refer [register-handler after]] + [syng-im.models.contacts :as contacts])) + +(defn save-contact + [_ [_ contact]] + (contacts/save-syng-contacts [contact])) + +(register-handler :add-contact + (-> (fn [db [_ contact]] + (update db :contacts conj contact)) + ((after save-contact)))) + + diff --git a/src/syng_im/contacts/screen.cljs b/src/syng_im/contacts/screen.cljs index abdc736d5d..5c1f2c0de8 100644 --- a/src/syng_im/contacts/screen.cljs +++ b/src/syng_im/contacts/screen.cljs @@ -3,50 +3,37 @@ [natal-shell.data-source :refer [data-source clone-with-rows]] [natal-shell.core :refer [with-error-view]]) (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.components.react :refer [view text image touchable-highlight - navigator list-view + [syng-im.components.react :refer [view text + image + touchable-highlight + list-view list-item]] [syng-im.contacts.views.contact :refer [contact-view]] - [syng-im.components.styles :refer [font - title-font - color-white - color-black - color-blue - text1-color - text2-color - toolbar-background2]] + [syng-im.components.styles :refer [toolbar-background2]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.navigation :refer [nav-pop]] - [syng-im.resources :as res] - [syng-im.utils.logging :as log])) + [syng-im.contacts.styles :as st])) -(defn render-row [navigator row section-id row-id] - (list-item [contact-view {:navigator navigator - :contact (js->clj row :keywordize-keys true)}])) +(defn render-row [row _ _] + (list-item [contact-view (js->clj row :keywordize-keys true)])) (defn get-data-source [contacts] - (clone-with-rows (data-source {:rowHasChanged (fn [row1 row2] - (not= row1 row2))}) - contacts)) + (clone-with-rows (data-source {:rowHasChanged not=}) contacts)) -(defn contact-list-toolbar [navigator] - [toolbar {:navigator navigator - :title "Contacts" +(defn contact-list-toolbar [] + [toolbar {:title "Contacts" :background-color toolbar-background2 - :action {:image {:source {:uri "icon_search"} - :style {:width 17 - :height 17}} + :action {:image {:source {:uri :icon_search} + :style st/search-icon} :handler (fn [])}}]) -(defn contact-list [{:keys [navigator]}] +(defn contact-list [] (let [contacts (subscribe [:get-contacts])] (fn [] (let [contacts-ds (get-data-source @contacts)] - [view {:style {:flex 1 - :backgroundColor "white"}} - [contact-list-toolbar navigator] + [view st/contacts-list-container + [contact-list-toolbar] (when contacts-ds - [list-view {:dataSource contacts-ds + [list-view {:dataSource contacts-ds :enableEmptySections true - :renderRow (partial render-row navigator) - :style {:backgroundColor "white"}}])])))) + :renderRow render-row + :style st/contacts-list}])])))) diff --git a/src/syng_im/contacts/styles.cljs b/src/syng_im/contacts/styles.cljs new file mode 100644 index 0000000000..819c5582eb --- /dev/null +++ b/src/syng_im/contacts/styles.cljs @@ -0,0 +1,69 @@ +(ns syng-im.contacts.styles + (:require [syng-im.components.styles :refer [font + title-font + text1-color + color-white + online-color]])) + +(def search-icon + {:width 17 + :height 17}) + +(def contacts-list-container + {:flex 1 + :backgroundColor :white}) + +(def contacts-list + {:backgroundColor :white}) + +(def contact-photo-container + {:borderRadius 50}) + +(def photo-image + {:borderRadius 50 + :width 40 + :height 40}) + +(def online-container + {:position :absolute + :top 24 + :left 24 + :width 20 + :height 20 + :borderRadius 50 + :backgroundColor online-color + :borderWidth 2 + :borderColor color-white}) + +(def online-dot + {:position :absolute + :top 6 + :width 4 + :height 4 + :borderRadius 50 + :backgroundColor color-white}) + +(def online-dot-left + (assoc online-dot :left 3)) + +(def online-dot-right + (assoc online-dot :left 9)) + +(def contact-container + {:flexDirection :row + :height 56}) + +(def photo-container + {:marginTop 8 + :marginLeft 16 + :width 44 + :height 44}) + +(def name-container + {:justifyContent :center}) + +(def name-text + {:marginLeft 16 + :fontSize 16 + :fontFamily font + :color text1-color}) diff --git a/src/syng_im/contacts/subs.cljs b/src/syng_im/contacts/subs.cljs new file mode 100644 index 0000000000..8396dac043 --- /dev/null +++ b/src/syng_im/contacts/subs.cljs @@ -0,0 +1,5 @@ +(ns syng-im.contacts.subs + (:require-macros [reagent.ratom :refer [reaction]]) + (:require [re-frame.core :refer [register-sub]])) + + diff --git a/src/syng_im/contacts/views/contact.cljs b/src/syng_im/contacts/views/contact.cljs index 41df1c47d8..d094ae02f0 100644 --- a/src/syng_im/contacts/views/contact.cljs +++ b/src/syng_im/contacts/views/contact.cljs @@ -3,6 +3,6 @@ [re-frame.core :refer [dispatch]] [syng-im.contacts.views.contact-inner :refer [contact-inner-view]])) -(defn contact-view [{:keys [contact]}] +(defn contact-view [contact] [touchable-highlight {:onPress #(dispatch [:navigate-to :chat])} [view {} [contact-inner-view contact]]]) diff --git a/src/syng_im/contacts/views/contact_inner.cljs b/src/syng_im/contacts/views/contact_inner.cljs index 9e47992a18..d96ed3cd35 100644 --- a/src/syng_im/contacts/views/contact_inner.cljs +++ b/src/syng_im/contacts/views/contact_inner.cljs @@ -1,65 +1,30 @@ (ns syng-im.contacts.views.contact-inner (:require [clojure.string :as s] [syng-im.components.react :refer [view image text]] - [syng-im.components.styles :refer [font - title-font - text1-color - color-white - online-color]] - [syng-im.resources :as res])) + [syng-im.resources :as res] + [syng-im.contacts.styles :as st])) (defn contact-photo [{:keys [photo-path]}] - [view {:borderRadius 50} + [view st/contact-photo-container [image {:source (if (s/blank? photo-path) res/user-no-photo {:uri photo-path}) - :style {:borderRadius 50 - :width 40 - :height 40}}]]) + :style st/photo-image}]]) (defn contact-online [{:keys [online]}] (when online - [view {:position "absolute" - :top 24 - :left 24 - :width 20 - :height 20 - :borderRadius 50 - :backgroundColor online-color - :borderWidth 2 - :borderColor color-white} - [view {:position "absolute" - :top 6 - :left 3 - :width 4 - :height 4 - :borderRadius 50 - :backgroundColor color-white}] - [view {:position "absolute" - :top 6 - :left 9 - :width 4 - :height 4 - :borderRadius 50 - :backgroundColor color-white}]])) + [view st/online-container + [view st/online-dot-left] + [view st/online-dot-right]])) (defn contact-inner-view [{:keys [name photo-path online]}] - [view {:style {:flexDirection "row" - :height 56}} - [view {:style {:marginTop 8 - :marginLeft 16 - :width 44 - :height 44}} -;;; photo + [view st/contact-container + [view st/photo-container [contact-photo {:photo-path photo-path}] -;;; online [contact-online {:online online}]] -;;; name - [view {:style {:justifyContent "center"}} - [text {:style {:marginLeft 16 - :fontSize 16 - :fontFamily font - :color text1-color}} + [view st/name-container + [text {:style st/name-text} (if (pos? (count name)) name + ;; todo is this correct behaviour? "Noname")]]]) diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index 3aa7e8aa63..8b7e1849a7 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -39,7 +39,8 @@ [syng-im.utils.random :as random] syng-im.chat.handlers syng-im.navigation.handlers - syng-im.components.discovery.handlers)) + syng-im.components.discovery.handlers + syng-im.contacts.handlers)) ;; -- Middleware ------------------------------------------------------------ ;; diff --git a/src/syng_im/ios/core.cljs b/src/syng_im/ios/core.cljs index 02147cce96..c84d1c2404 100644 --- a/src/syng_im/ios/core.cljs +++ b/src/syng_im/ios/core.cljs @@ -20,13 +20,13 @@ (defn app-root [] (let [greeting (subscribe [:get-greeting])] (fn [] - [view {:style {:flex-direction "column" :margin 40 :align-items "center"}} - [text {:style {:font-size 30 :font-weight "100" :margin-bottom 20 :text-align "center"}} @greeting] + [view {:style {:flex-direction "column" :margin 40 :align-items :center}} + [text {:style {:font-size 30 :font-weight "100" :margin-bottom 20 :text-align :center}} @greeting] [image {:source logo-img :style {:width 80 :height 80 :margin-bottom 30}}] [touchable-highlight {:style {:background-color "#999" :padding 10 :border-radius 5} :on-press #(alert "HELLO!")} - [text {:style {:color "white" :text-align "center" :font-weight "bold"}} "press me"]]]))) + [text {:style {:color :white :text-align :center :font-weight "bold"}} "press me"]]]))) (defn init [] (dispatch-sync [:initialize-db]) diff --git a/src/syng_im/models/chats.cljs b/src/syng_im/models/chats.cljs index 8d1425b989..f92f3f67e5 100644 --- a/src/syng_im/models/chats.cljs +++ b/src/syng_im/models/chats.cljs @@ -123,13 +123,13 @@ chat (r/single (r/get-by-field :chats :chat-id chat-id))] (-> (aget chat "contacts") (r/filtered query) - (.forEach (fn [object index collection] + (.forEach (fn [object _ _] (aset object "is-in-chat" false)))))))) (defn active-group-chats [] (let [results (r/filtered (r/get-all :chats) "group-chat = true && is-active = true")] - (js->clj (.map results (fn [object index collection] + (js->clj (.map results (fn [object _ _] (aget object "chat-id")))))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index e20b7561c6..04e6813ee0 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -7,14 +7,11 @@ contacts-list-include]] syng-im.chat.subs syng-im.navigation.subs - syng-im.components.discovery.subs)) + syng-im.components.discovery.subs + syng-im.contacts.subs)) ;; -- Chats list -------------------------------------------------------------- -(register-sub :get-chats - (fn [db _] - (reaction (:chats @db)))) - (register-sub :get (fn [db [_ k]] (reaction (k @db)))) From 8fb71e46b7d301094511346c7ac84a2e22d99733 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Thu, 12 May 2016 12:56:47 +0300 Subject: [PATCH 10/26] contacts handlers Former-commit-id: 73d3fdb3e6e54192520750988317412d407df66f --- src/syng_im/chat/screen.cljs | 15 ++- .../components/discovery/discovery.cljs | 35 ++++--- src/syng_im/contacts/handlers.cljs | 91 ++++++++++++++++++- src/syng_im/contacts/screen.cljs | 13 +-- src/syng_im/contacts/subs.cljs | 2 - src/syng_im/db.cljs | 7 +- src/syng_im/handlers.cljs | 14 --- src/syng_im/handlers/contacts.cljs | 64 ------------- src/syng_im/models/contacts.cljs | 60 ++++-------- src/syng_im/models/messages.cljs | 4 - src/syng_im/models/protocol.cljs | 8 +- src/syng_im/utils/phone_number.cljs | 1 + 12 files changed, 143 insertions(+), 171 deletions(-) delete mode 100644 src/syng_im/handlers/contacts.cljs diff --git a/src/syng_im/chat/screen.cljs b/src/syng_im/chat/screen.cljs index aef8258b45..8b40ce8cfc 100644 --- a/src/syng_im/chat/screen.cljs +++ b/src/syng_im/chat/screen.cljs @@ -64,9 +64,9 @@ (defn on-action-selected [position] (case position - 0 (dispatch [:show-add-participants #_navigator]) - 1 (dispatch [:show-remove-participants #_navigator]) - 2 (dispatch [:leave-group-chat #_navigator]))) + 0 (dispatch [:show-add-participants]) + 1 (dispatch [:show-remove-participants]) + 2 (dispatch [:leave-group-chat]))) (defn overlay [{:keys [on-click-outside]} items] [view st/actions-overlay @@ -97,21 +97,18 @@ :icon :menu_group :icon-style {:width 25 :height 19} - :handler nil #_#(dispatch [:show-add-participants - navigator])} + :handler #(dispatch [:show-add-participants])} {:title "Remove Contact from chat" :subtitle "Alex, John" :icon :search_gray_copy :icon-style {:width 17 :height 17} - :handler nil #_#(dispatch - [:show-remove-participants navigator])} + :handler #(dispatch [:show-remove-participants])} {:title "Leave Chat" :icon :muted :icon-style {:width 18 :height 21} - :handler nil #_#(dispatch [:leave-group-chat - navigator])} + :handler #(dispatch [:leave-group-chat])} {:title "Settings" :subtitle "Not implemented" :icon :settings diff --git a/src/syng_im/components/discovery/discovery.cljs b/src/syng_im/components/discovery/discovery.cljs index 21acf38988..2738781de8 100644 --- a/src/syng_im/components/discovery/discovery.cljs +++ b/src/syng_im/components/discovery/discovery.cljs @@ -31,7 +31,7 @@ :autoFocus true :placeholder "Type your search tags here" :onSubmitEditing (fn [e] - (let [search (aget e "nativeEvent" "text") + (let [search (aget e "nativeEvent" "text") hashtags (get-hashtags search)] (dispatch [:broadcast-status search hashtags])))}] [view @@ -50,25 +50,26 @@ (dispatch [:updated-discoveries])))) (defn discovery [{:keys [navigator]}] + [] (let [showSearch (r/atom false)] (fn [] [view {:style {:flex 1 :backgroundColor "#eef2f5"}} - [toolbar {:style st/discovery-toolbar - :navigator navigator - :nav-action {:image {:source {:uri "icon_hamburger"} - :style {:width 16 - :height 12}} + [toolbar {:style st/discovery-toolbar + :navigator navigator + :nav-action {:image {:source {:uri "icon_hamburger"} + :style {:width 16 + :height 12}} :handler create-fake-discovery} - :title "Add Participants" - :content (title-content @showSearch) - :action {:image {:source {:uri "icon_search"} - :style {:width 17 - :height 17}} - :handler (fn [] - (if @showSearch - (reset! showSearch false) - (reset! showSearch true)))}}] + :title "Add Participants" + :content (title-content @showSearch) + :action {:image {:source {:uri "icon_search"} + :style {:width 17 + :height 17}} + :handler (fn [] + (if @showSearch + (reset! showSearch false) + (reset! showSearch true)))}}] [scroll-view {:style {}} [view {:style st/section-spacing} [text {:style st/discovery-subtitle} "Popular tags"]] @@ -76,7 +77,3 @@ [view {:style st/section-spacing} [text {:style st/discovery-subtitle} "Recent"]] [discovery-recent]]]))) - (comment - (def page-width (aget (natal-shell.dimensions/get "window") "width")) - (def page-height (aget (natal-shell.dimensions/get "window") "height")) - ) diff --git a/src/syng_im/contacts/handlers.cljs b/src/syng_im/contacts/handlers.cljs index 58586cc671..c434a95ea1 100644 --- a/src/syng_im/contacts/handlers.cljs +++ b/src/syng_im/contacts/handlers.cljs @@ -1,6 +1,15 @@ (ns syng-im.contacts.handlers - (:require [re-frame.core :refer [register-handler after]] - [syng-im.models.contacts :as contacts])) + (:require [re-frame.core :refer [register-handler after dispatch]] + [syng-im.models.contacts :as contacts] + [syng-im.utils.crypt :refer [encrypt]] + [clojure.string :as s] + [syng-im.utils.utils :refer [http-post]] + [syng-im.utils.phone-number :refer [format-phone-number]])) + +(defn side-effect! [handler] + (fn [db params] + (handler db params) + db)) (defn save-contact [_ [_ contact]] @@ -11,4 +20,82 @@ (update db :contacts conj contact)) ((after save-contact)))) +(defn load-contacts! [db _] + (let [contacts (contacts/get-contacts)] + (assoc db :contacts contacts))) +(register-handler :load-syng-contacts load-contacts!) + +(def react-native-contacts (js/require "react-native-contacts")) + +(defn contact-name [contact] + (->> contact + ((juxt :givenName :middleName :familyName)) + (remove s/blank?) + (s/join " "))) + +(defn normalize-phone-contacts [contacts] + (let [contacts' (js->clj contacts :keywordize-keys true)] + (map (fn [{:keys [thumbnailPath phoneNumbers] :as contact}] + {:name (contact-name contact) + :photo-path thumbnailPath + :phone-numbers phoneNumbers}) contacts'))) + +(defn fetch-contacts-from-phone! + [_ _] + (.getAll react-native-contacts + (fn [error contacts] + (if error + (dispatch [:error-on-fetching-loading error]) + (let [contacts' (normalize-phone-contacts contacts)] + (dispatch [:get-contacts-identities contacts'])))))) + +(register-handler :sync-contacts + (side-effect! fetch-contacts-from-phone!)) + +(defn get-contacts-by-hash [contacts] + (->> contacts + (mapcat (fn [{:keys [phone-numbers] :as contact}] + (map (fn [{:keys [number]}] + (let [number' (format-phone-number number)] + [(encrypt number') + (-> contact + (assoc :phone-number number') + (dissoc :phone-numbers))])) + phone-numbers))) + (into {}))) + +(defn add-identity [contacts-by-hash contacts] + (map (fn [{:keys [phone-number-hash whisper-identity]}] + (let [contact (contacts-by-hash phone-number-hash)] + (assoc contact :whisper-identity whisper-identity))) + (js->clj contacts))) + +(defn request-stored-contacts [contacts] + (let [contacts-by-hash (get-contacts-by-hash contacts) + data (keys contacts-by-hash)] + (http-post "get-contacts" {:phone-number-hashes data} + (fn [{:keys [contacts]}] + (let [contacts' (add-identity contacts-by-hash contacts)] + (dispatch [:add-contacts contacts'])))))) + +(defn get-identities-by-contacts! [_ [_ contacts]] + (request-stored-contacts contacts)) + +(register-handler :get-contacts-identities + (side-effect! get-identities-by-contacts!)) + +(defn save-contacts! [{:keys [new-contacts]} _] + (contacts/save-syng-contacts new-contacts)) + +(defn add-new-contacts + [{:keys [contacts] :as db} [_ new-contacts]] + (let [identities (set (map :whisper-identity contacts)) + new-contacts' (remove #(identities (:whisper-identity %)) new-contacts)] + (-> db + (update :contacts concat new-contacts') + (assoc :new-contacts new-contacts')))) + +(register-handler :add-contacts + (after save-contacts!) + add-new-contacts) diff --git a/src/syng_im/contacts/screen.cljs b/src/syng_im/contacts/screen.cljs index 5c1f2c0de8..73d3a4d610 100644 --- a/src/syng_im/contacts/screen.cljs +++ b/src/syng_im/contacts/screen.cljs @@ -11,10 +11,11 @@ [syng-im.contacts.views.contact :refer [contact-view]] [syng-im.components.styles :refer [toolbar-background2]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.contacts.styles :as st])) + [syng-im.contacts.styles :as st] + [syng-im.utils.listview :as lw])) (defn render-row [row _ _] - (list-item [contact-view (js->clj row :keywordize-keys true)])) + (list-item [contact-view row])) (defn get-data-source [contacts] (clone-with-rows (data-source {:rowHasChanged not=}) contacts)) @@ -22,14 +23,14 @@ (defn contact-list-toolbar [] [toolbar {:title "Contacts" :background-color toolbar-background2 - :action {:image {:source {:uri :icon_search} - :style st/search-icon} + :action {:image {:source {:uri :icon_search} + :style st/search-icon} :handler (fn [])}}]) (defn contact-list [] - (let [contacts (subscribe [:get-contacts])] + (let [contacts (subscribe [:get :contacts])] (fn [] - (let [contacts-ds (get-data-source @contacts)] + (let [contacts-ds (lw/to-datasource2 @contacts)] [view st/contacts-list-container [contact-list-toolbar] (when contacts-ds diff --git a/src/syng_im/contacts/subs.cljs b/src/syng_im/contacts/subs.cljs index 8396dac043..81459071c6 100644 --- a/src/syng_im/contacts/subs.cljs +++ b/src/syng_im/contacts/subs.cljs @@ -1,5 +1,3 @@ (ns syng-im.contacts.subs (:require-macros [reagent.ratom :refer [reaction]]) (:require [re-frame.core :refer [register-sub]])) - - diff --git a/src/syng_im/db.cljs b/src/syng_im/db.cljs index d7b452a0f3..f907e5a618 100644 --- a/src/syng_im/db.cljs +++ b/src/syng_im/db.cljs @@ -7,13 +7,12 @@ (def default-view :discovery) ;; initial state of app-db -(def app-db {:greeting "Hello Clojure in iOS and Android!" - :identity-password "replace-me-with-user-entered-password" +(def app-db {:identity-password "replace-me-with-user-entered-password" :identity "me" :contacts [] :current-chat-id "console" - :chat {:command nil - :last-message nil} + :chat {:command nil + :last-message nil} :chats {} :chats-updated-signal 0 :show-actions false diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index 8b7e1849a7..342ec071df 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -14,7 +14,6 @@ message-by-id]] [syng-im.models.commands :refer [set-commands]] [syng-im.handlers.server :as server] - [syng-im.handlers.contacts :as contacts-service] [syng-im.handlers.suggestions :refer [get-command handle-command get-command-handler @@ -229,19 +228,6 @@ (user-data/load-phone-number) db)) -;; -- Sign up -------------------------------------------------------------- - -(register-handler :sync-contacts - (fn [db [_ handler]] - (contacts-service/sync-contacts handler) - db)) - -;; -- Contacts -------------------------------------------------------------- - -(register-handler :load-syng-contacts - (fn [db [_ value]] - (contacts/load-syng-contacts db))) - ;; -- Chats -------------------------------------------------------------- (defn update-new-participants-selection [db identity add?] (update db :new-participants (fn [new-participants] diff --git a/src/syng_im/handlers/contacts.cljs b/src/syng_im/handlers/contacts.cljs deleted file mode 100644 index 53b0146a49..0000000000 --- a/src/syng_im/handlers/contacts.cljs +++ /dev/null @@ -1,64 +0,0 @@ -(ns syng-im.handlers.contacts - (:require-macros [cljs.core.async.macros :refer [go]]) - (:require [clojure.string :as cstr] - [cljs.core.async :as async :refer [chan put! clj (:contacts data)))) - -(defn- get-contacts-by-hash [contacts] - (let [numbers-info (reduce (fn [numbers contact] - (into numbers - (map (fn [c] - {:number (format-phone-number (:number c)) - :contact contact}) - (:phone-numbers contact)))) - '() - contacts)] - (reduce (fn [m number-info] - (let [number (:number number-info) - hash (encrypt number)] - (assoc m hash number-info))) - {} - numbers-info))) - -(defn- request-syng-contacts [contacts] - (let [contacts-by-hash (get-contacts-by-hash contacts) - data (keys contacts-by-hash) - ch (chan)] - (http-post "get-contacts" {:phone-number-hashes data} - (fn [data] - (put! ch - (to-syng-contacts contacts-by-hash data)))) - ch)) - -(defn sync-contacts [handler] - (go - (let [result (clj raw-contacts :keywordize-keys true)))})))) - ch)) +(defn load-phone-contacts + ([callback] (.getAll react-native-contacts callback)) + ([] + (.getAll react-native-contacts + (fn [error raw-contacts] + (println raw-contacts) + {:error error + :contacts + (when (not error) + (log raw-contacts) + (map (fn [contact] + (merge contact + (generate-contact 1) + {:name (:givenName contact) + :photo-path (:thumbnailPath contact) + :phone-numbers (:phoneNumbers contact)})) + (js->clj raw-contacts :keywordize-keys true)))})))) -(defn- get-contacts [] - (if fake-contacts? - [{:phone-number "123" - :whisper-identity "abc" - :name "fake" - :photo-path ""}] - (realm/get-list :contacts))) - -(defn load-syng-contacts [db] - (let [contacts (map (fn [contact] - (merge contact - {:delivery-status (if (< (rand) 0.5) :delivered :seen) - :datetime "15:30" - :new-messages-count (rand-int 3) - :online (< (rand) 0.5)})) - (get-contacts))] - (assoc db :contacts contacts))) +(defn get-contacts [] + (realm/collection->map (realm/get-all :contacts))) (defn- create-contact [{:keys [phone-number whisper-identity name photo-path]}] (realm/create :contacts diff --git a/src/syng_im/models/messages.cljs b/src/syng_im/models/messages.cljs index b8fc9cff57..bf58efd2cd 100644 --- a/src/syng_im/models/messages.cljs +++ b/src/syng_im/models/messages.cljs @@ -16,10 +16,6 @@ [s] (keywordize-keys (apply hash-map (split s #"[;=]")))) -(defn select-chat-last-message [chat] - (when-let [last-msg-id (:last-msg-id chat)] - (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 same-author same-direction] diff --git a/src/syng_im/models/protocol.cljs b/src/syng_im/models/protocol.cljs index 176cab7047..aff7283d97 100644 --- a/src/syng_im/models/protocol.cljs +++ b/src/syng_im/models/protocol.cljs @@ -6,8 +6,7 @@ [syng-im.utils.types :refer [to-edn-string]] [re-frame.db :refer [app-db]] [syng-im.db :as db] - [syng-im.persistence.simple-kv-store :as kv] - [syng-im.utils.logging :as log])) + [syng-im.persistence.simple-kv-store :as kv])) (defn set-initialized [db initialized?] (assoc-in db db/protocol-initialized-path initialized?)) @@ -23,8 +22,3 @@ password (:identity-password db)] (when encrypted (read-string (password-decrypt password encrypted))))) - -(comment - - (stored-identity @re-frame.db/app-db) - ) diff --git a/src/syng_im/utils/phone_number.cljs b/src/syng_im/utils/phone_number.cljs index 6a7481faf4..19ec1ac526 100644 --- a/src/syng_im/utils/phone_number.cljs +++ b/src/syng_im/utils/phone_number.cljs @@ -5,5 +5,6 @@ (def country-code (subs locale 3 5)) (set! js/PhoneNumber (js/require "awesome-phonenumber")) +;; todo check wrong numbers, .getNumber returns empty string (defn format-phone-number [number] (str (.getNumber (js/PhoneNumber. number country-code "international")))) From f9cee873d19409d286d9c8ff5a1d78c0cc7dd1df Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Fri, 13 May 2016 14:58:58 +0300 Subject: [PATCH 11/26] discoveries Former-commit-id: 748abd40e48f3a0210ecb33c3e72c4591673ee0a --- src/syng_im/android/core.cljs | 4 +- src/syng_im/chat/handlers.cljs | 3 +- src/syng_im/chat/subs.cljs | 2 +- .../{handlers => chat}/suggestions.cljs | 3 +- src/syng_im/components/carousel/carousel.cljs | 2 +- .../components/discovery/discovery.cljs | 79 -------------- .../discovery/discovery_popular.cljs | 23 ---- .../discovery/discovery_popular_list.cljs | 43 -------- .../discovery_popular_list_item.cljs | 23 ---- .../discovery/discovery_recent.cljs | 33 ------ .../components/discovery/handlers.cljs | 44 -------- src/syng_im/components/discovery/subs.cljs | 48 --------- src/syng_im/components/toolbar.cljs | 30 +++--- src/syng_im/contacts/handlers.cljs | 17 ++- .../discovery/discovery_popular_list.cljs | 40 +++++++ .../discovery_popular_list_item.cljs | 15 +++ src/syng_im/discovery/discovery_recent.cljs | 23 ++++ .../discovery/discovery_tag.cljs | 6 +- src/syng_im/discovery/handlers.cljs | 76 +++++++++++++ src/syng_im/discovery/screen.cljs | 62 +++++++++++ .../{components => }/discovery/styles.cljs | 2 +- src/syng_im/discovery/subs.cljs | 26 +++++ src/syng_im/discovery/views/popular.cljs | 22 ++++ src/syng_im/handlers.cljs | 21 ++-- src/syng_im/handlers/server.cljs | 3 +- src/syng_im/models/chats.cljs | 1 - src/syng_im/models/contacts.cljs | 100 ++---------------- src/syng_im/models/discoveries.cljs | 80 ++++++-------- src/syng_im/models/user_data.cljs | 17 --- src/syng_im/navigation/handlers.cljs | 6 +- src/syng_im/persistence/realm.cljs | 42 ++++---- src/syng_im/subs.cljs | 12 +-- src/syng_im/utils/handlers.cljs | 8 ++ 33 files changed, 388 insertions(+), 528 deletions(-) rename src/syng_im/{handlers => chat}/suggestions.cljs (96%) delete mode 100644 src/syng_im/components/discovery/discovery.cljs delete mode 100644 src/syng_im/components/discovery/discovery_popular.cljs delete mode 100644 src/syng_im/components/discovery/discovery_popular_list.cljs delete mode 100644 src/syng_im/components/discovery/discovery_popular_list_item.cljs delete mode 100644 src/syng_im/components/discovery/discovery_recent.cljs delete mode 100644 src/syng_im/components/discovery/handlers.cljs delete mode 100644 src/syng_im/components/discovery/subs.cljs create mode 100644 src/syng_im/discovery/discovery_popular_list.cljs create mode 100644 src/syng_im/discovery/discovery_popular_list_item.cljs create mode 100644 src/syng_im/discovery/discovery_recent.cljs rename src/syng_im/{components => }/discovery/discovery_tag.cljs (91%) create mode 100644 src/syng_im/discovery/handlers.cljs create mode 100644 src/syng_im/discovery/screen.cljs rename src/syng_im/{components => }/discovery/styles.cljs (98%) create mode 100644 src/syng_im/discovery/subs.cljs create mode 100644 src/syng_im/discovery/views/popular.cljs delete mode 100644 src/syng_im/models/user_data.cljs create mode 100644 src/syng_im/utils/handlers.cljs diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index fb82b1b085..cec2fd2772 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -8,8 +8,8 @@ [syng-im.subs] [syng-im.components.react :refer [navigator app-registry]] [syng-im.contacts.screen :refer [contact-list]] - [syng-im.components.discovery.discovery :refer [discovery]] - [syng-im.components.discovery.discovery-tag :refer [discovery-tag]] + [syng-im.discovery.screen :refer [discovery]] + [syng-im.discovery.discovery-tag :refer [discovery-tag]] [syng-im.chat.screen :refer [chat]] [syng-im.chats-list.screen :refer [chats-list]] [syng-im.new-group.screen :refer [new-group]] diff --git a/src/syng_im/chat/handlers.cljs b/src/syng_im/chat/handlers.cljs index 42d9294301..e5fd8213e0 100644 --- a/src/syng_im/chat/handlers.cljs +++ b/src/syng_im/chat/handlers.cljs @@ -2,7 +2,7 @@ (:require [re-frame.core :refer [register-handler enrich after debug]] [syng-im.models.commands :as commands] [clojure.string :as str] - [syng-im.handlers.suggestions :as suggestions] + [syng-im.chat.suggestions :as suggestions] [syng-im.protocol.api :as api] [syng-im.models.messages :as messages] [syng-im.constants :refer [text-content-type @@ -221,6 +221,7 @@ (register-handler :sign-up (-> (fn [db [_ phone-number]] + ;; todo save phone number to db (assoc db :user-phone-number phone-number)) ((after (fn [& _] (sign-up-service/on-sign-up-response)))))) diff --git a/src/syng_im/chat/subs.cljs b/src/syng_im/chat/subs.cljs index 35f7386b93..9b5692c094 100644 --- a/src/syng_im/chat/subs.cljs +++ b/src/syng_im/chat/subs.cljs @@ -3,7 +3,7 @@ (:require [re-frame.core :refer [register-sub]] [syng-im.db :as db] ;todo handlers in subs?... - [syng-im.handlers.suggestions :refer [get-suggestions]] + [syng-im.chat.suggestions :refer [get-suggestions]] [syng-im.models.commands :as commands])) (register-sub :chat-properties diff --git a/src/syng_im/handlers/suggestions.cljs b/src/syng_im/chat/suggestions.cljs similarity index 96% rename from src/syng_im/handlers/suggestions.cljs rename to src/syng_im/chat/suggestions.cljs index bf9fc11e65..86718068d7 100644 --- a/src/syng_im/handlers/suggestions.cljs +++ b/src/syng_im/chat/suggestions.cljs @@ -1,4 +1,4 @@ -(ns syng-im.handlers.suggestions +(ns syng-im.chat.suggestions (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.db :as db] [syng-im.models.commands :refer [commands @@ -8,7 +8,6 @@ get-chat-command-to-msg-id clear-staged-commands]] [syng-im.utils.utils :refer [log on-error http-get]] - [syng-im.utils.logging :as log] [clojure.string :as s])) (defn suggestion? [text] diff --git a/src/syng_im/components/carousel/carousel.cljs b/src/syng_im/components/carousel/carousel.cljs index b489482f5d..28831eb3ec 100644 --- a/src/syng_im/components/carousel/carousel.cljs +++ b/src/syng_im/components/carousel/carousel.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.carousel +(ns syng-im.components.carousel.carousel (:require [syng-im.components.react :refer [android? view scroll-view diff --git a/src/syng_im/components/discovery/discovery.cljs b/src/syng_im/components/discovery/discovery.cljs deleted file mode 100644 index 2738781de8..0000000000 --- a/src/syng_im/components/discovery/discovery.cljs +++ /dev/null @@ -1,79 +0,0 @@ -(ns syng-im.components.discovery.discovery - - (:require - [syng-im.utils.logging :as log] - [re-frame.core :refer [dispatch]] - [syng-im.models.discoveries :refer [save-discoveries]] - [syng-im.components.react :refer [android? - view - scroll-view - text - text-input]] - [reagent.core :as r] - [syng-im.components.toolbar :refer [toolbar]] - [syng-im.components.discovery.discovery-popular :refer [discovery-popular]] - [syng-im.components.discovery.discovery-recent :refer [discovery-recent]] - [syng-im.components.discovery.styles :as st] - [syng-im.persistence.realm :as realm])) - -(def search-input (atom {:search "x"})) - -(defn get-hashtags [status] - (let [hashtags (map #(subs % 1) (re-seq #"#[^ !?,;:.]+" status))] - (if hashtags - hashtags - []))) - -(defn title-content [showSearch] - (if showSearch - [text-input {:underlineColorAndroid "transparent" - :style st/discovery-search-input - :autoFocus true - :placeholder "Type your search tags here" - :onSubmitEditing (fn [e] - (let [search (aget e "nativeEvent" "text") - hashtags (get-hashtags search)] - (dispatch [:broadcast-status search hashtags])))}] - [view - [text {:style st/discovery-title} "Discover"]])) - -(defn create-fake-discovery [] - (let [number (rand-int 999)] - (do - (save-discoveries [{:name (str "Name " number) - :status (str "Status This is some longer status to get the second line " number) - :whisper-id (str number) - :photo "" - :location "" - :tags ["tag1" "tag2" "tag3"] - :last-updated (new js/Date)}]) - (dispatch [:updated-discoveries])))) - -(defn discovery [{:keys [navigator]}] - [] - (let [showSearch (r/atom false)] - (fn [] - [view {:style {:flex 1 - :backgroundColor "#eef2f5"}} - [toolbar {:style st/discovery-toolbar - :navigator navigator - :nav-action {:image {:source {:uri "icon_hamburger"} - :style {:width 16 - :height 12}} - :handler create-fake-discovery} - :title "Add Participants" - :content (title-content @showSearch) - :action {:image {:source {:uri "icon_search"} - :style {:width 17 - :height 17}} - :handler (fn [] - (if @showSearch - (reset! showSearch false) - (reset! showSearch true)))}}] - [scroll-view {:style {}} - [view {:style st/section-spacing} - [text {:style st/discovery-subtitle} "Popular tags"]] - [discovery-popular navigator] - [view {:style st/section-spacing} - [text {:style st/discovery-subtitle} "Recent"]] - [discovery-recent]]]))) diff --git a/src/syng_im/components/discovery/discovery_popular.cljs b/src/syng_im/components/discovery/discovery_popular.cljs deleted file mode 100644 index df33467899..0000000000 --- a/src/syng_im/components/discovery/discovery_popular.cljs +++ /dev/null @@ -1,23 +0,0 @@ -(ns syng-im.components.discovery.discovery-popular - (:require - [re-frame.core :refer [subscribe]] - [syng-im.utils.logging :as log] - [syng-im.components.react :refer [android? - text]] - [syng-im.components.carousel :refer [carousel]] - [syng-im.components.discovery.styles :as st] - [syng-im.components.discovery.discovery-popular-list :refer [discovery-popular-list]] - )) - -(defn page-width [] - (.-width (.get (.. js/React -Dimensions) "window"))) - -(defn discovery-popular [navigator] - (let [popular-tags (subscribe [:get-popular-tags 3])] - (log/debug "Got popular tags: " @popular-tags) - (if (> (count @popular-tags) 0) - [carousel {:pageStyle st/carousel-page-style - :sneak 20} - (for [tag @popular-tags] - (discovery-popular-list (.-name tag) (.-count tag) navigator))] - [text "None"]))) \ No newline at end of file diff --git a/src/syng_im/components/discovery/discovery_popular_list.cljs b/src/syng_im/components/discovery/discovery_popular_list.cljs deleted file mode 100644 index 55a4b94c83..0000000000 --- a/src/syng_im/components/discovery/discovery_popular_list.cljs +++ /dev/null @@ -1,43 +0,0 @@ -(ns syng-im.components.discovery.discovery-popular-list - (:require - [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.utils.logging :as log] - [syng-im.components.react :refer [android? - view - list-view - touchable-highlight - text - image]] - [reagent.core :as r] - [syng-im.components.discovery.styles :as st] - [syng-im.utils.listview :refer [to-realm-datasource]] - [syng-im.components.discovery.discovery-popular-list-item :refer [discovery-popular-list-item] ]) - ) - - -(defn render-row [row section-id row-id] - (let [elem (discovery-popular-list-item row)] - elem) -) - -(defn render-separator [sectionID, rowID, adjacentRowHighlighted] - (let [elem (r/as-element [view {:style st/row-separator - :key rowID}])] - elem)) - -(defn discovery-popular-list [tag count navigator] - (let [discoveries (subscribe [:get-discoveries-by-tag tag 3])] - [view {:style st/popular-list-container} - [view st/row - [view st/tag-name-container - [touchable-highlight {:onPress #(dispatch [:show-discovery-tag tag navigator :push])} - [text {:style st/tag-name} - (str " #" (name tag))]]] - [view {:style st/tag-count-container} - [text {:style st/tag-count} - count]]] - [list-view {:dataSource (to-realm-datasource @discoveries) - :enableEmptySections true - :renderRow render-row - :renderSeparator render-separator - :style st/popular-list}]])) diff --git a/src/syng_im/components/discovery/discovery_popular_list_item.cljs b/src/syng_im/components/discovery/discovery_popular_list_item.cljs deleted file mode 100644 index 2313d4ff76..0000000000 --- a/src/syng_im/components/discovery/discovery_popular_list_item.cljs +++ /dev/null @@ -1,23 +0,0 @@ -(ns syng-im.components.discovery.discovery-popular-list-item - (:require - [syng-im.utils.logging :as log] - [syng-im.components.react :refer [android? - view - text - image]] - [syng-im.components.discovery.styles :as st] - [reagent.core :as r]) - ) - -(defn discovery-popular-list-item [discovery] - (r/as-element [view {:style st/popular-list-item} - [view {:style st/popular-list-item-name-container} - [text {:style st/popular-list-item-name} (aget discovery "name")] - [text {:style st/popular-list-item-status - :numberOfLines 2} (aget discovery "status")] - ] - [view {:style st/popular-list-item-avatar-container} - [image {:style st/popular-list-item-avatar - :source {:uri "icon_avatar"}}] - ] - ])) \ No newline at end of file diff --git a/src/syng_im/components/discovery/discovery_recent.cljs b/src/syng_im/components/discovery/discovery_recent.cljs deleted file mode 100644 index c253ca02b4..0000000000 --- a/src/syng_im/components/discovery/discovery_recent.cljs +++ /dev/null @@ -1,33 +0,0 @@ -(ns syng-im.components.discovery.discovery-recent - (:require-macros - [natal-shell.data-source :refer [data-source clone-with-rows]] - - ) - (:require - [re-frame.core :refer [subscribe]] - [syng-im.components.react :refer [android? - view]] - [syng-im.components.realm :refer [list-view]] - [syng-im.utils.listview :refer [to-realm-datasource]] - [syng-im.components.discovery.styles :as st] - [syng-im.components.discovery.discovery-popular-list-item :refer [discovery-popular-list-item]] - [reagent.core :as r])) - - -(defn render-row [row section-id row-id] - (let [elem (discovery-popular-list-item row)] - elem) - ) - -(defn render-separator [sectionID, rowID, adjacentRowHighlighted] - (let [elem (r/as-element [view {:style st/row-separator - :key rowID}])] - elem)) - -(defn discovery-recent [] - (let [discoveries (subscribe [:get-discoveries]) - datasource (to-realm-datasource @discoveries)] - [list-view {:dataSource datasource - :renderRow render-row - :renderSeparator render-separator - :style st/recent-list}])) diff --git a/src/syng_im/components/discovery/handlers.cljs b/src/syng_im/components/discovery/handlers.cljs deleted file mode 100644 index 44d24c99d9..0000000000 --- a/src/syng_im/components/discovery/handlers.cljs +++ /dev/null @@ -1,44 +0,0 @@ -(ns syng-im.components.discovery.handlers - (:require [re-frame.core :refer [register-handler after dispatch]] - [syng-im.utils.logging :as log] - [syng-im.protocol.api :as api] - [syng-im.navigation :refer [nav-push - nav-replace - nav-pop]] - [syng-im.models.discoveries :refer [save-discoveries - set-current-tag - signal-discoveries-updated]])) - - -;; -- Discovery -------------------------------------------------------------- - -(register-handler :discovery-response-received - (fn [db [_ from payload]] - (let [{:keys [name status hashtags location]} payload - location (if location location "")] - (save-discoveries [{:name name - :status status - :whisper-id from - :photo "" - :location location - :tags hashtags - :last-updated (js/Date.)}]) - (signal-discoveries-updated db)))) - -(register-handler :updated-discoveries - (fn [db _] - (signal-discoveries-updated db))) - -(register-handler :broadcast-status - (fn [db [action status hashtags]] - (let [name (:name db)] - (log/debug "Status: " status ", Hashtags: " hashtags) - (api/broadcast-discover-status name status hashtags) - db))) - -(register-handler :show-discovery-tag - (fn [db [action tag navigator nav-type]] - (log/debug action "setting current tag: " tag) - (let [db (set-current-tag db tag)] - (dispatch [:navigate-to navigator {:view-id :discovery-tag} nav-type]) - db))) \ No newline at end of file diff --git a/src/syng_im/components/discovery/subs.cljs b/src/syng_im/components/discovery/subs.cljs deleted file mode 100644 index c335d4366d..0000000000 --- a/src/syng_im/components/discovery/subs.cljs +++ /dev/null @@ -1,48 +0,0 @@ -(ns syng-im.components.discovery.subs - (:require-macros [reagent.ratom :refer [reaction]]) - (:require [re-frame.core :refer [register-sub]] - [syng-im.db :as db] - [syng-im.utils.logging :as log] - [syng-im.models.discoveries :refer [discovery-list - current-tag - get-tag-popular - discoveries-by-tag - current-tag-updated? - discoveries-updated?]])) - - - -(register-sub :get-discoveries - (fn [db _] - (let [discoveries-updated (-> (discoveries-updated? @db) - (reaction))] - (reaction - (let [_ @discoveries-updated] - (discovery-list)))))) - -(register-sub :get-discoveries-by-tag - (fn [db [_ tag limit]] - (let [discoveries-updated (-> (discoveries-updated? @db) - (reaction))] - (log/debug "Getting discoveries for: " tag) - (reaction - (let [_ @discoveries-updated] - (discoveries-by-tag tag limit)))))) - -(register-sub :get-popular-tags - (fn [db [_ limit]] - (let [discoveries-updated (-> (discoveries-updated? @db) - (reaction))] - (log/debug "Getting tags limited: " limit) - (reaction - (let [_ @discoveries-updated] - (get-tag-popular limit)))))) - -(register-sub :get-current-tag - (fn [db _] - (let [current-tag-updated (-> (current-tag-updated? @db) - (reaction))] - (reaction - (let [_ @current-tag-updated] - (current-tag @db)))))) - diff --git a/src/syng_im/components/toolbar.cljs b/src/syng_im/components/toolbar.cljs index edc824c83b..d13ac69050 100644 --- a/src/syng_im/components/toolbar.cljs +++ b/src/syng_im/components/toolbar.cljs @@ -2,6 +2,7 @@ (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view text-input + icon text image touchable-highlight]] @@ -30,23 +31,22 @@ [touchable-highlight {:on-press #(dispatch [:navigate-back])} [view {:width 56 :height 56} - [image {:source {:uri "icon_back"} - :style {:marginTop 21 - :marginLeft 23 - :width 8 - :height 14}}]]]) + [icon :back {:marginTop 21 + :marginLeft 23 + :width 8 + :height 14}]]]) (if content - [view {:style {:flex 1 - :alignItems :center - :justifyContent :center}} + [view {:flex 1 + :alignItems :center + :justifyContent :center} content] - [view {:style {:flex 1 - :alignItems :center - :justifyContent :center}} - [text {:style {:marginTop -2.5 - :color text1-color - :fontSize 16 - :fontFamily font}} + [view {:flex 1 + :alignItems :center + :justifyContent :center} + [text {:marginTop -2.5 + :color text1-color + :fontSize 16 + :fontFamily font} title]]) [touchable-highlight {:on-press (:handler action)} [view {:width 56 diff --git a/src/syng_im/contacts/handlers.cljs b/src/syng_im/contacts/handlers.cljs index c434a95ea1..9cb4903d9b 100644 --- a/src/syng_im/contacts/handlers.cljs +++ b/src/syng_im/contacts/handlers.cljs @@ -4,16 +4,12 @@ [syng-im.utils.crypt :refer [encrypt]] [clojure.string :as s] [syng-im.utils.utils :refer [http-post]] - [syng-im.utils.phone-number :refer [format-phone-number]])) - -(defn side-effect! [handler] - (fn [db params] - (handler db params) - db)) + [syng-im.utils.phone-number :refer [format-phone-number]] + [syng-im.utils.handlers :as u])) (defn save-contact [_ [_ contact]] - (contacts/save-syng-contacts [contact])) + (contacts/save-contacts [contact])) (register-handler :add-contact (-> (fn [db [_ contact]] @@ -26,6 +22,7 @@ (register-handler :load-syng-contacts load-contacts!) +;; TODO see https://github.com/rt2zz/react-native-contacts/issues/45 (def react-native-contacts (js/require "react-native-contacts")) (defn contact-name [contact] @@ -51,7 +48,7 @@ (dispatch [:get-contacts-identities contacts'])))))) (register-handler :sync-contacts - (side-effect! fetch-contacts-from-phone!)) + (u/side-effect! fetch-contacts-from-phone!)) (defn get-contacts-by-hash [contacts] (->> contacts @@ -83,10 +80,10 @@ (request-stored-contacts contacts)) (register-handler :get-contacts-identities - (side-effect! get-identities-by-contacts!)) + (u/side-effect! get-identities-by-contacts!)) (defn save-contacts! [{:keys [new-contacts]} _] - (contacts/save-syng-contacts new-contacts)) + (contacts/save-contacts new-contacts)) (defn add-new-contacts [{:keys [contacts] :as db} [_ new-contacts]] diff --git a/src/syng_im/discovery/discovery_popular_list.cljs b/src/syng_im/discovery/discovery_popular_list.cljs new file mode 100644 index 0000000000..9eebed2463 --- /dev/null +++ b/src/syng_im/discovery/discovery_popular_list.cljs @@ -0,0 +1,40 @@ +(ns syng-im.discovery.discovery-popular-list + (:require + [re-frame.core :refer [subscribe dispatch dispatch-sync]] + [syng-im.utils.logging :as log] + [syng-im.components.react :refer [android? + view + list-view + list-item + touchable-highlight + text + image]] + [reagent.core :as r] + [syng-im.discovery.styles :as st] + [syng-im.utils.listview :refer [to-realm-datasource to-datasource2]] + [syng-im.discovery.discovery-popular-list-item :refer [discovery-popular-list-item] ]) + ) + + +(defn render-row [row _ _] + (list-item [discovery-popular-list-item row])) + +(defn render-separator [sectionID rowID adjacentRowHighlighted] + (list-item [view {:style st/row-separator + :key rowID}])) + +(defn discovery-popular-list [tag count] + (let [discoveries (subscribe [:get-discoveries-by-tag tag 3])] + (fn [tag count] + [view st/popular-list-container + [view st/row + [view st/tag-name-container + [touchable-highlight {:onPress #(dispatch [:show-discovery-tag tag])} + [text {:style st/tag-name} (str " #" (name tag))]]] + [view st/tag-count-container + [text {:style st/tag-count} count]]] + [list-view {:dataSource (to-datasource2 @discoveries) + :enableEmptySections true + :renderRow render-row + :renderSeparator render-separator + :style st/popular-list}]]))) diff --git a/src/syng_im/discovery/discovery_popular_list_item.cljs b/src/syng_im/discovery/discovery_popular_list_item.cljs new file mode 100644 index 0000000000..65df82164a --- /dev/null +++ b/src/syng_im/discovery/discovery_popular_list_item.cljs @@ -0,0 +1,15 @@ +(ns syng-im.discovery.discovery-popular-list-item + (:require [syng-im.components.react :refer [view text image]] + [syng-im.discovery.styles :as st] + [reagent.core :as r])) + +(defn discovery-popular-list-item + [{:keys [name status]}] + [view st/popular-list-item + [view st/popular-list-item-name-container + [text {:style st/popular-list-item-name} name] + [text {:style st/popular-list-item-status + :numberOfLines 2} status]] + [view st/popular-list-item-avatar-container + [image {:style st/popular-list-item-avatar + :source {:uri :icon_avatar}}]]]) diff --git a/src/syng_im/discovery/discovery_recent.cljs b/src/syng_im/discovery/discovery_recent.cljs new file mode 100644 index 0000000000..d9128b2fef --- /dev/null +++ b/src/syng_im/discovery/discovery_recent.cljs @@ -0,0 +1,23 @@ +(ns syng-im.discovery.discovery-recent + (:require + [re-frame.core :refer [subscribe]] + [syng-im.components.react :refer [view list-view list-item]] + [syng-im.utils.listview :refer [to-realm-datasource to-datasource2]] + [syng-im.discovery.styles :as st] + [syng-im.discovery.discovery-popular-list-item + :refer [discovery-popular-list-item]])) + +(defn render-row [row _ _] + (list-item [discovery-popular-list-item row])) + +(defn render-separator [_ row-id _] + (list-item [view {:style st/row-separator + :key row-id}])) + +(defn discovery-recent [] + (let [discoveries (subscribe [:get :discoveries])] + (fn [] + [list-view {:dataSource (to-datasource2 @discoveries) + :renderRow render-row + :renderSeparator render-separator + :style st/recent-list}]))) diff --git a/src/syng_im/components/discovery/discovery_tag.cljs b/src/syng_im/discovery/discovery_tag.cljs similarity index 91% rename from src/syng_im/components/discovery/discovery_tag.cljs rename to src/syng_im/discovery/discovery_tag.cljs index 70cffe6d23..5123eab794 100644 --- a/src/syng_im/components/discovery/discovery_tag.cljs +++ b/src/syng_im/discovery/discovery_tag.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.discovery.discovery-tag +(ns syng-im.discovery.discovery-tag (:require [re-frame.core :refer [subscribe]] [syng-im.utils.logging :as log] @@ -11,8 +11,8 @@ [syng-im.components.realm :refer [list-view]] [syng-im.components.toolbar :refer [toolbar]] [reagent.core :as r] - [syng-im.components.discovery.discovery-popular-list-item :refer [discovery-popular-list-item]] - [syng-im.components.discovery.styles :as st])) + [syng-im.discovery.discovery-popular-list-item :refer [discovery-popular-list-item]] + [syng-im.discovery.styles :as st])) (defn render-row [row section-id row-id] (log/debug "discovery-tag-row: " row section-id row-id) diff --git a/src/syng_im/discovery/handlers.cljs b/src/syng_im/discovery/handlers.cljs new file mode 100644 index 0000000000..c1cdf901c4 --- /dev/null +++ b/src/syng_im/discovery/handlers.cljs @@ -0,0 +1,76 @@ +(ns syng-im.discovery.handlers + (:require [re-frame.core :refer [register-handler after dispatch enrich + log-ex debug]] + [syng-im.protocol.api :as api] + [syng-im.models.discoveries :refer [save-discoveries + set-current-tag]] + [syng-im.navigation.handlers :as nav] + [syng-im.models.discoveries :as discoveries] + [syng-im.utils.handlers :as u])) + +(defmethod nav/preload-data! :discovery + [{:keys [] :as db} _] + (-> db + (assoc :tags (discoveries/all-tags)) + (assoc :discoveries (discoveries/discovery-list)))) + +(register-handler :discovery-response-received + (u/side-effect! + (fn [_ [_ from payload]] + (let [{:keys [name status hashtags location]} payload + location (or location "") + discovery [{:name name + :status status + :whisper-id from + :photo "" + :location location + :tags (map #(hash-map :name %) hashtags) + :last-updated (js/Date.)}]] + (dispatch [:add-discovery discovery]))))) + +(register-handler :broadcast-status + (fn [{:keys [name] :as db} [_ status hashtags]] + (api/broadcast-discover-status name status hashtags) + db)) + +(register-handler :show-discovery-tag + (fn [db [_ tag]] + (let [db (set-current-tag db tag)] + (dispatch [:navigate-to :discovery-tag]) + db))) + +;; todo remove this +(register-handler :create-fake-discovery! + (u/side-effect! + (fn [_ _] + (let [number (rand-int 999) + discovery {:name (str "Name " number) + :status (str "Status This is some longer status to get the second line " number) + :whisper-id (str number) + :photo "" + :location "" + :tags [{:name "tag1"} + {:name "tag2"} + {:name "tag3"}] + :last-updated (new js/Date)}] + (dispatch [:add-discovery discovery]))))) + +(defn add-discovery + [db [_ discovery]] + (-> db + (assoc :new-discovery discovery) + (update :discoveries conj discovery))) + +(defn save-discovery! + [{:keys [new-discovery]} _] + (discoveries/save-discoveries [new-discovery])) + +(defn reload-tags! + [db _] + (assoc db :tags (discoveries/all-tags))) + +(register-handler :add-discovery + (-> add-discovery + debug + ((after save-discovery!)) + ((enrich reload-tags!)))) diff --git a/src/syng_im/discovery/screen.cljs b/src/syng_im/discovery/screen.cljs new file mode 100644 index 0000000000..eb1838fcd7 --- /dev/null +++ b/src/syng_im/discovery/screen.cljs @@ -0,0 +1,62 @@ +(ns syng-im.discovery.screen + + (:require + [syng-im.utils.logging :as log] + [re-frame.core :refer [dispatch subscribe]] + [syng-im.models.discoveries :refer [save-discoveries]] + [syng-im.components.react :refer [android? + view + scroll-view + text + text-input]] + [reagent.core :as r] + [syng-im.components.toolbar :refer [toolbar]] + [syng-im.discovery.views.popular :refer [popular]] + [syng-im.discovery.discovery-recent :refer [discovery-recent]] + [syng-im.discovery.styles :as st] + [syng-im.persistence.realm :as realm])) + +(defn get-hashtags [status] + (let [hashtags (map #(subs % 1) (re-seq #"#[^ !?,;:.]+" status))] + (or hashtags []))) + +(defn title-content [showSearch] + (if showSearch + [text-input {:style st/discovery-search-input + :autoFocus true + :placeholder "Type your search tags here" + :onSubmitEditing (fn [e] + (let [search (aget e "nativeEvent" "text") + hashtags (get-hashtags search)] + (dispatch [:broadcast-status search hashtags])))}] + [view + [text {:style st/discovery-title} "Discover"]])) + +(defn toogle-search [current-value] + (dispatch [:set ::show-search (not current-value)])) + +(defn discovery [] + [] + (let [show-search (subscribe [:get ::show-search])] + (fn [] + [view {:flex 1 + :backgroundColor :#eef2f5} + [toolbar + {:style st/discovery-toolbar + :nav-action {:image {:source {:uri :icon_hamburger} + :style {:width 16 + :height 12}} + :handler #(dispatch [:create-fake-discovery!])} + :title "Add Participants" + :content (title-content @show-search) + :action {:image {:source {:uri :icon_search} + :style {:width 17 + :height 17}} + :handler #(toogle-search @show-search)}}] + [scroll-view {:style {}} + [view st/section-spacing + [text {:style st/discovery-subtitle} "Popular tags"]] + [popular] + [view st/section-spacing + [text {:style st/discovery-subtitle} "Recent"]] + [discovery-recent]]]))) diff --git a/src/syng_im/components/discovery/styles.cljs b/src/syng_im/discovery/styles.cljs similarity index 98% rename from src/syng_im/components/discovery/styles.cljs rename to src/syng_im/discovery/styles.cljs index 957a1f7940..b4518d057d 100644 --- a/src/syng_im/components/discovery/styles.cljs +++ b/src/syng_im/discovery/styles.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.discovery.styles +(ns syng-im.discovery.styles (:require [syng-im.components.styles :refer [font title-font color-white diff --git a/src/syng_im/discovery/subs.cljs b/src/syng_im/discovery/subs.cljs new file mode 100644 index 0000000000..09c98628a6 --- /dev/null +++ b/src/syng_im/discovery/subs.cljs @@ -0,0 +1,26 @@ +(ns syng-im.discovery.subs + (:require-macros [reagent.ratom :refer [reaction]]) + (:require [re-frame.core :refer [register-sub]] + [syng-im.models.discoveries :refer [current-tag + current-tag-updated?]])) + +(register-sub :get-discoveries-by-tag + (fn [db [_ tag limit]] + (let [discoveries (reaction (:discoveries @db))] + (->> @discoveries + (into [] (comp (filter #(some #{tag} (map :name (:tags %)))) + (take limit))) + (reaction))))) + +(register-sub :get-popular-tags + (fn [db [_ limit]] + (reaction (take limit (:tags @db))))) + +(register-sub :get-current-tag + (fn [db _] + (let [current-tag-updated (-> (current-tag-updated? @db) + (reaction))] + (reaction + (let [_ @current-tag-updated] + (current-tag @db)))))) + diff --git a/src/syng_im/discovery/views/popular.cljs b/src/syng_im/discovery/views/popular.cljs new file mode 100644 index 0000000000..91bd8f8b7a --- /dev/null +++ b/src/syng_im/discovery/views/popular.cljs @@ -0,0 +1,22 @@ +(ns syng-im.discovery.views.popular + (:require + [re-frame.core :refer [subscribe]] + [syng-im.utils.logging :as log] + [syng-im.components.react :refer [android? + text]] + [syng-im.components.carousel.carousel :refer [carousel]] + [syng-im.discovery.styles :as st] + [syng-im.discovery.discovery-popular-list :refer [discovery-popular-list]])) + +(defn page-width [] + (.-width (.get (.. js/React -Dimensions) "window"))) + +(defn popular [] + (let [popular-tags (subscribe [:get-popular-tags 3])] + (log/debug "Got popular tags: " @popular-tags) + (if (pos? (count @popular-tags)) + [carousel {:pageStyle st/carousel-page-style + :sneak 20} + (for [{:keys [name count]} @popular-tags] + [discovery-popular-list name count])] + [text "None"]))) diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index 342ec071df..021b072111 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -7,14 +7,13 @@ [syng-im.protocol.protocol-handler :refer [make-handler]] [syng-im.models.protocol :refer [update-identity set-initialized]] - [syng-im.models.user-data :as user-data] [syng-im.models.contacts :as contacts] [syng-im.models.messages :refer [save-message update-message! message-by-id]] [syng-im.models.commands :refer [set-commands]] [syng-im.handlers.server :as server] - [syng-im.handlers.suggestions :refer [get-command + [syng-im.chat.suggestions :refer [get-command handle-command get-command-handler load-commands @@ -37,8 +36,8 @@ [syng-im.utils.crypt :refer [gen-random-bytes]] [syng-im.utils.random :as random] syng-im.chat.handlers - syng-im.navigation.handlers - syng-im.components.discovery.handlers + [syng-im.navigation.handlers :as nav] + syng-im.discovery.handlers syng-im.contacts.handlers)) ;; -- Middleware ------------------------------------------------------------ @@ -62,7 +61,12 @@ (fn [db [_ k v]] (assoc db k v)))) +(defn preload-data! + [{:keys [view-id] :as db} _] + (nav/preload-data! db [nil view-id])) + (register-handler :initialize-db + (enrich preload-data!) (fn [_ _] app-db)) (register-handler :set-loading @@ -218,15 +222,10 @@ (left-chat-msg chat-id)))) ;; -- User data -------------------------------------------------------------- - -(register-handler :set-user-phone-number - (fn [db [_ value]] - (assoc db :user-phone-number value))) - (register-handler :load-user-phone-number (fn [db [_]] - (user-data/load-phone-number) - db)) + ;; todo fetch phone number from db + (assoc db :user-phone-number "123"))) ;; -- Chats -------------------------------------------------------------- (defn update-new-participants-selection [db identity add?] diff --git a/src/syng_im/handlers/server.cljs b/src/syng_im/handlers/server.cljs index 76707a8a33..70c0a45fe7 100644 --- a/src/syng_im/handlers/server.cljs +++ b/src/syng_im/handlers/server.cljs @@ -1,12 +1,11 @@ (ns syng-im.handlers.server (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.models.user-data :as user-data] [syng-im.utils.utils :refer [log on-error http-post]] [syng-im.utils.logging :as log])) (defn sign-up [db phone-number handler] - (user-data/save-phone-number phone-number) + ;(user-data/save-phone-number phone-number) (http-post "sign-up" {:phone-number phone-number :whisper-identity (get-in db [:user-identity :public])} (fn [body] diff --git a/src/syng_im/models/chats.cljs b/src/syng_im/models/chats.cljs index f92f3f67e5..9bfca22293 100644 --- a/src/syng_im/models/chats.cljs +++ b/src/syng_im/models/chats.cljs @@ -8,7 +8,6 @@ [syng-im.models.messages :refer [save-message]] [syng-im.persistence.realm-queries :refer [include-query]])) - (defn chat-name-from-contacts [identities] (let [chat-name (->> identities (map (fn [identity] diff --git a/src/syng_im/models/contacts.cljs b/src/syng_im/models/contacts.cljs index ecec1e6992..6369cb9262 100644 --- a/src/syng_im/models/contacts.cljs +++ b/src/syng_im/models/contacts.cljs @@ -1,71 +1,21 @@ (ns syng-im.models.contacts - (:require [cljs.core.async :as async :refer [chan put! !]] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.utils.utils :refer [log toast]] - [syng-im.persistence.realm :as realm] - [syng-im.persistence.realm :as r] + (:require [syng-im.persistence.realm :as r] [syng-im.persistence.realm-queries :refer [include-query exclude-query]])) -;; TODO see https://github.com/rt2zz/react-native-contacts/issues/45 - -(def react-native-contacts (js/require "react-native-contacts")) - -(defn- generate-contact [n] - {:name (str "Contact " n) - :photo-path "" - :phone-numbers [{:label "mobile" :number (apply str (repeat 7 n))}] - :delivery-status (if (< (rand) 0.5) :delivered :seen) - :datetime "15:30" - :new-messages-count (rand-int 3) - :online (< (rand) 0.5)}) - -(defn- generate-contacts [n] - (map generate-contact (range 1 (inc n)))) - -(defn load-phone-contacts - ([callback] (.getAll react-native-contacts callback)) - ([] - (.getAll react-native-contacts - (fn [error raw-contacts] - (println raw-contacts) - {:error error - :contacts - (when (not error) - (log raw-contacts) - (map (fn [contact] - (merge contact - (generate-contact 1) - {:name (:givenName contact) - :photo-path (:thumbnailPath contact) - :phone-numbers (:phoneNumbers contact)})) - (js->clj raw-contacts :keywordize-keys true)))})))) - (defn get-contacts [] - (realm/collection->map (realm/get-all :contacts))) + (-> (r/get-all :contacts) + (r/sorted :name :asc) + r/collection->map)) -(defn- create-contact [{:keys [phone-number whisper-identity name photo-path]}] - (realm/create :contacts - {:phone-number phone-number - :whisper-identity whisper-identity - :name (or name "") - :photo-path (or photo-path "")})) +(defn create-contact [{:keys [name photo-path] :as contact}] + (->> {:name (or name "") + :photo-path (or photo-path "")} + (merge contact) + (r/create :contacts))) -(defn- contact-exist? [contacts contact] - (some #(= (:phone-number contact) (:phone-number %)) contacts)) - -(defn- add-contacts [contacts] - (realm/write (fn [] - (let [db-contacts (get-contacts)] - (dorun (map (fn [contact] - (if (not (contact-exist? db-contacts contact)) - (create-contact contact) - ;; TODO else override? - )) - contacts)))))) - -(defn save-syng-contacts [syng-contacts] - (add-contacts syng-contacts)) +(defn save-contacts [contacts] + (r/write #(mapv create-contact contacts))) ;;;;;;;;;;;;;;;;;;;;---------------------------------------------- @@ -87,31 +37,3 @@ (defn contact-by-identity [identity] (r/single-cljs (r/get-by-field :contacts :whisper-identity identity))) - -(comment - - (r/write #(create-contact {:phone-number "0543072333" - :whisper-identity "0x04e43e861a6dd99ad9eee7bd58af89dcaa430188ebec8698de7b7bad54573324fff4ac5cb9bb277af317efd7abfc917b91bf48cc41e40bf70062fd79400016a1f9" - :name "Splinter" - :photo-path ""})) - - (r/write #(create-contact {:phone-number "0544828649" - :whisper-identity "0x0487954e7fa746d8cf787403c2c491aadad540b9bb1f0f7b8184792e91c33b6a394079295f5777ec6d4af9ad5ba24794b3ff1ec8be9ff6a708c85a163733192665" - :name "Exodius" - :photo-path ""})) - - (r/write #(create-contact {:phone-number "0522222222" - :whisper-identity "0x0407c278af94e0b4599645023f5bec03cbdb3973bd0ae33b94c6a5885d9d20e82ff3f3c3584a637ba016af40bac2f711fd6028045756f561e36e4b07d0c2b4e623" - :name "Mr. Eagle" - :photo-path ""})) - - (r/write #(create-contact {:phone-number "0533333333" - :whisper-identity "0x04512f852558ea09d09419019f3f443ec03ff2c1913c48e567723d70e5abf239ed87fb62486b90b85e12de5d327501c1993c9905a69f2ca7e1bfbaab12dd033313" - :name "Mr. PiggyBear" - :photo-path ""})) - - (contacts-list) - - (:new-group @re-frame.db/app-db) - - ) diff --git a/src/syng_im/models/discoveries.cljs b/src/syng_im/models/discoveries.cljs index 03f7a623ad..2261d8e63c 100644 --- a/src/syng_im/models/discoveries.cljs +++ b/src/syng_im/models/discoveries.cljs @@ -1,22 +1,13 @@ (ns syng-im.models.discoveries - (:require [cljs.core.async :as async :refer [chan put! !]] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] + (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.utils.logging :as log] [syng-im.persistence.realm :as realm] [syng-im.persistence.realm :as r] [syng-im.db :as db])) -(defn signal-discoveries-updated [db] - (update-in db db/updated-discoveries-signal-path #(if % (inc %) 0))) - -(defn discoveries-updated? [db] - (get-in db db/updated-discoveries-signal-path)) - (defn current-tag-updated? [db] (get-in db db/updated-current-tag-signal-path)) - - (defn current-tag [db] (get-in db db/current-tag-path)) @@ -29,21 +20,21 @@ (r/single-cljs))) (defn decrease-tag-counter [tag] - (let [tag (:name tag) + (let [tag (:name tag) tag-object (get-tag tag)] (if tag-object (let [counter (dec (:count tag-object))] - (if (= counter 0) + (if (zero? counter) (realm/delete tag-object) - (realm/create :tag {:name tag + (realm/create :tag {:name tag :count counter} true)))))) (defn increase-tag-counter [tag] - (let [tag (:name tag) + (let [tag (:name tag) tag-object (get-tag tag)] (if tag-object - (realm/create :tag {:name tag + (realm/create :tag {:name tag :count (inc (:count tag-object))} true)))) @@ -59,49 +50,37 @@ (:tags (-> (r/get-by-field :discoveries :whisper-id whisper-id) (r/single-cljs)))) -(defn- create-discovery [{:keys [name status whisper-id photo location tags last-updated]}] - (let [tags (mapv (fn [tag] {:name tag}) tags) - discovery {:name name - :status status - :whisper-id whisper-id - :photo photo - :location location - :tags tags - :last-updated last-updated}] - (log/debug "Creating discovery: " discovery tags) +(defn- create-discovery [{:keys [tags] :as discovery}] + (log/debug "Creating discovery: " discovery tags) + (realm/create :discoveries discovery true) + (increase-tags-counter tags)) + +(defn- update-discovery [{:keys [whisper-id tags] :as discovery}] + (let [old-tags (get-tags whisper-id) + tags (map :name tags)] + (decrease-tags-counter old-tags) (realm/create :discoveries discovery true) (increase-tags-counter tags))) -(defn- update-discovery [{:keys [name status whisper-id photo location tags last-updated]}] - (let [old-tags (get-tags whisper-id) - tags (mapv (fn [tag] {:name tag}) tags) - discovery {:name name - :status status - :whisper-id whisper-id - :photo photo - :location location - :tags tags - :last-updated last-updated}] - (decrease-tags-counter old-tags) - (realm/create :discoveries discovery true) - (increase-tags-counter tags))) - (defn- discovery-exist? [discoveries discovery] (some #(= (:whisper-id discovery) (:whisper-id %)) discoveries)) (defn discovery-list [] - (-> (r/get-all :discoveries) - (r/sorted :last-updated :desc))) + (->> (-> (r/get-all :discoveries) + (r/sorted :last-updated :desc) + r/collection->map) + (map #(update % :tags vals)) + (into '()))) (defn- add-discoveries [discoveries] (realm/write (fn [] - (let [db-discoveries (.slice (discovery-list) 0)] - (dorun (map (fn [discovery] - (if (not (discovery-exist? db-discoveries discovery)) - (create-discovery discovery) - (update-discovery discovery) - )) - discoveries)))))) + (let [db-discoveries (discovery-list)] + (mapv (fn [discovery] + (if-not (discovery-exist? db-discoveries + discovery) + (create-discovery discovery) + (update-discovery discovery))) + discoveries))))) (defn save-discoveries [discoveries] (add-discoveries discoveries)) @@ -114,6 +93,11 @@ (r/page discoveries 0 limit) discoveries))) +(defn all-tags [] + (-> (r/get-all :tag) + (r/sorted :count :desc) + r/collection->map)) + (defn get-tag-popular [limit] (-> (r/get-all :tag) (r/sorted :count :desc) diff --git a/src/syng_im/models/user_data.cljs b/src/syng_im/models/user_data.cljs deleted file mode 100644 index 463a731b5a..0000000000 --- a/src/syng_im/models/user_data.cljs +++ /dev/null @@ -1,17 +0,0 @@ -(ns syng-im.models.user-data - (:require-macros - [natal-shell.async-storage :refer [get-item set-item]]) - (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.utils.utils :refer [log on-error toast]])) - -(defn save-phone-number [phone-number] - (set-item "user-phone-number" phone-number) - (dispatch [:set-user-phone-number phone-number])) - -(defn load-phone-number [] - (get-item "user-phone-number" - (fn [error value] - (if error - (on-error error) - (dispatch [:set-user-phone-number (when value - (str value))]))))) diff --git a/src/syng_im/navigation/handlers.cljs b/src/syng_im/navigation/handlers.cljs index d15d29bf0d..112fc6ec0a 100644 --- a/src/syng_im/navigation/handlers.cljs +++ b/src/syng_im/navigation/handlers.cljs @@ -1,5 +1,5 @@ (ns syng-im.navigation.handlers - (:require [re-frame.core :refer [register-handler dispatch debug]])) + (:require [re-frame.core :refer [register-handler dispatch debug enrich]])) (defn push-view [db view-id] (-> db @@ -17,7 +17,11 @@ (update :navigation-stack replace-top-element view-id) (assoc :view-id view-id))) +(defmulti preload-data! (fn [_ [_ view-id]] view-id)) +(defmethod preload-data! :default [db _] db) + (register-handler :navigate-to + (enrich preload-data!) (fn [db [_ view-id]] (push-view db view-id))) diff --git a/src/syng_im/persistence/realm.cljs b/src/syng_im/persistence/realm.cljs index 83faef94a4..01879ebb3a 100644 --- a/src/syng_im/persistence/realm.cljs +++ b/src/syng_im/persistence/realm.cljs @@ -44,28 +44,28 @@ :properties {:chat-id "string" :name "string" :group-chat {:type "bool" - :indexed true} - :is-active "bool" - :timestamp "int" - :contacts {:type "list" - :objectType "chat-contact"} + :indexed true} + :is-active "bool" + :timestamp "int" + :contacts {:type "list" + :objectType "chat-contact"} :last-msg-id "string"}} - {:name :tag - :primaryKey :name - :properties {:name "string" - :count {:type "int" - :optional true - :default 0}}} - {:name :discoveries - :primaryKey :whisper-id - :properties {:name "string" - :status "string" - :whisper-id "string" - :photo "string" - :location "string" - :tags {:type "list" - :objectType "tag"} - :last-updated "date"}}]}) + {:name :tag + :primaryKey :name + :properties {:name "string" + :count {:type "int" + :optional true + :default 0}}} + {:name :discoveries + :primaryKey :whisper-id + :properties {:name "string" + :status "string" + :whisper-id "string" + :photo "string" + :location "string" + :tags {:type "list" + :objectType "tag"} + :last-updated "date"}}]}) (def realm (js/Realm. (clj->js opts))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index 04e6813ee0..1f713b248e 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -2,12 +2,12 @@ (:require-macros [reagent.ratom :refer [reaction]]) (:require [re-frame.core :refer [register-sub]] [syng-im.models.chats :refer [chats-list chat-by-id]] - [syng-im.models.contacts :refer [contacts-list + [syng-im.models.contacts :refer [get-contacts contacts-list-exclude contacts-list-include]] syng-im.chat.subs syng-im.navigation.subs - syng-im.components.discovery.subs + syng-im.discovery.subs syng-im.contacts.subs)) ;; -- Chats list -------------------------------------------------------------- @@ -18,12 +18,6 @@ ;; -- User data -------------------------------------------------------------- -;; (register-sub -;; :get-user-phone-number -;; (fn [db _] -;; (reaction -;; (get @db :user-phone-number)))) - (register-sub :signed-up (fn [db _] @@ -36,7 +30,7 @@ (register-sub :all-contacts (fn [_ _] - (reaction (contacts-list)))) + (reaction (get-contacts)))) (register-sub :all-new-contacts (fn [db _] diff --git a/src/syng_im/utils/handlers.cljs b/src/syng_im/utils/handlers.cljs new file mode 100644 index 0000000000..154022cad1 --- /dev/null +++ b/src/syng_im/utils/handlers.cljs @@ -0,0 +1,8 @@ +(ns syng-im.utils.handlers) + +(defn side-effect! + "Middleware for handlers that will not affect db." + [handler] + (fn [db params] + (handler db params) + db)) From 3fc884db255a8943500f17bd338760d42d7c9407 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Fri, 13 May 2016 15:52:02 +0300 Subject: [PATCH 12/26] discoveries order Former-commit-id: 74249dc7174693022070249414d0fcb2af3e4c9a --- src/syng_im/models/discoveries.cljs | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/syng_im/models/discoveries.cljs b/src/syng_im/models/discoveries.cljs index 2261d8e63c..f374f6ba03 100644 --- a/src/syng_im/models/discoveries.cljs +++ b/src/syng_im/models/discoveries.cljs @@ -69,8 +69,7 @@ (->> (-> (r/get-all :discoveries) (r/sorted :last-updated :desc) r/collection->map) - (map #(update % :tags vals)) - (into '()))) + (map #(update % :tags vals)))) (defn- add-discoveries [discoveries] (realm/write (fn [] From 4fd5bd6f00bff537d16f1609fc30884720f6708b Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Fri, 13 May 2016 16:52:42 +0300 Subject: [PATCH 13/26] tag screen Former-commit-id: 83e4c584cb043302a8a830f979f177333f9d44fa --- src/syng_im/android/core.cljs | 2 +- src/syng_im/db.cljs | 2 - src/syng_im/discovery/discovery_tag.cljs | 57 ------------------- src/syng_im/discovery/handlers.cljs | 24 ++++---- src/syng_im/discovery/screen.cljs | 18 ++---- src/syng_im/discovery/subs.cljs | 22 +++---- src/syng_im/discovery/tag.cljs | 42 ++++++++++++++ src/syng_im/discovery/views/popular.cljs | 2 +- .../popular_list.cljs} | 24 +++----- .../popular_list_item.cljs} | 5 +- .../recent.cljs} | 8 +-- src/syng_im/models/commands.cljs | 7 +-- src/syng_im/models/discoveries.cljs | 9 --- 13 files changed, 88 insertions(+), 134 deletions(-) delete mode 100644 src/syng_im/discovery/discovery_tag.cljs create mode 100644 src/syng_im/discovery/tag.cljs rename src/syng_im/discovery/{discovery_popular_list.cljs => views/popular_list.cljs} (60%) rename src/syng_im/discovery/{discovery_popular_list_item.cljs => views/popular_list_item.cljs} (82%) rename src/syng_im/discovery/{discovery_recent.cljs => views/recent.cljs} (78%) diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index cec2fd2772..0117816228 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -9,7 +9,7 @@ [syng-im.components.react :refer [navigator app-registry]] [syng-im.contacts.screen :refer [contact-list]] [syng-im.discovery.screen :refer [discovery]] - [syng-im.discovery.discovery-tag :refer [discovery-tag]] + [syng-im.discovery.tag :refer [discovery-tag]] [syng-im.chat.screen :refer [chat]] [syng-im.chats-list.screen :refer [chats-list]] [syng-im.new-group.screen :refer [new-group]] diff --git a/src/syng_im/db.cljs b/src/syng_im/db.cljs index f907e5a618..6e079af948 100644 --- a/src/syng_im/db.cljs +++ b/src/syng_im/db.cljs @@ -39,6 +39,4 @@ [:chats chat-id :command-requests]) (defn chat-command-request-path [chat-id msg-id] [:chats chat-id :command-requests msg-id]) -(def updated-discoveries-signal-path [:discovery-updated-signal]) -(def current-tag-path [:current-tag]) (def updated-current-tag-signal-path [:current-tag-updated-signal]) diff --git a/src/syng_im/discovery/discovery_tag.cljs b/src/syng_im/discovery/discovery_tag.cljs deleted file mode 100644 index 5123eab794..0000000000 --- a/src/syng_im/discovery/discovery_tag.cljs +++ /dev/null @@ -1,57 +0,0 @@ -(ns syng-im.discovery.discovery-tag - (:require - [re-frame.core :refer [subscribe]] - [syng-im.utils.logging :as log] - [syng-im.utils.listview :refer [to-realm-datasource - to-datasource]] - [syng-im.navigation :refer [nav-pop]] - [syng-im.components.react :refer [android? - view - text]] - [syng-im.components.realm :refer [list-view]] - [syng-im.components.toolbar :refer [toolbar]] - [reagent.core :as r] - [syng-im.discovery.discovery-popular-list-item :refer [discovery-popular-list-item]] - [syng-im.discovery.styles :as st])) - -(defn render-row [row section-id row-id] - (log/debug "discovery-tag-row: " row section-id row-id) - (if row - (let [elem (discovery-popular-list-item row)] - elem) - (r/as-element [text "null"]) - )) - -(defn render-separator [sectionID, rowID, adjacentRowHighlighted] - (let [elem (r/as-element [view {:style st/row-separator - :key rowID}])] - elem)) - -(defn title-content [tag] - [view {:style st/tag-title-container} - [text {:style st/tag-title} - (str " #" tag)]]) - -(defn discovery-tag [{:keys [tag navigator]}] - (let [tag (subscribe [:get-current-tag]) - discoveries (subscribe [:get-discoveries-by-tag @tag 0])] - (log/debug "Got discoveries: " @discoveries) - (fn [] - (let [items @discoveries - datasource (to-realm-datasource items)] - [view {:style st/discovery-tag-container} - [toolbar {:navigator navigator - :nav-action {:image {:source {:uri "icon_back"} - :style st/icon-back} - :handler (fn [] (nav-pop navigator))} - :title "Add Participants" - :content (title-content @tag) - :action {:image {:source {:uri "icon_search"} - :style st/icon-search} - :handler (fn [] - ())}}] - - [list-view {:dataSource datasource - :renderRow render-row - :renderSeparator render-separator - :style st/recent-list}]])))) diff --git a/src/syng_im/discovery/handlers.cljs b/src/syng_im/discovery/handlers.cljs index c1cdf901c4..0b00f15cd9 100644 --- a/src/syng_im/discovery/handlers.cljs +++ b/src/syng_im/discovery/handlers.cljs @@ -2,17 +2,18 @@ (:require [re-frame.core :refer [register-handler after dispatch enrich log-ex debug]] [syng-im.protocol.api :as api] - [syng-im.models.discoveries :refer [save-discoveries - set-current-tag]] + [syng-im.models.discoveries :refer [save-discoveries]] [syng-im.navigation.handlers :as nav] [syng-im.models.discoveries :as discoveries] [syng-im.utils.handlers :as u])) (defmethod nav/preload-data! :discovery - [{:keys [] :as db} _] - (-> db - (assoc :tags (discoveries/all-tags)) - (assoc :discoveries (discoveries/discovery-list)))) + [{:keys [discoveries] :as db} _] + (if-not (seq discoveries) + (-> db + (assoc :tags (discoveries/all-tags)) + (assoc :discoveries (discoveries/discovery-list))) + db)) (register-handler :discovery-response-received (u/side-effect! @@ -29,15 +30,14 @@ (dispatch [:add-discovery discovery]))))) (register-handler :broadcast-status - (fn [{:keys [name] :as db} [_ status hashtags]] - (api/broadcast-discover-status name status hashtags) - db)) + (u/side-effect! + (fn [{:keys [name]} [_ status hashtags]] + (api/broadcast-discover-status name status hashtags)))) (register-handler :show-discovery-tag (fn [db [_ tag]] - (let [db (set-current-tag db tag)] - (dispatch [:navigate-to :discovery-tag]) - db))) + (dispatch [:navigate-to :discovery-tag]) + (assoc db :current-tag tag))) ;; todo remove this (register-handler :create-fake-discovery! diff --git a/src/syng_im/discovery/screen.cljs b/src/syng_im/discovery/screen.cljs index eb1838fcd7..751125324a 100644 --- a/src/syng_im/discovery/screen.cljs +++ b/src/syng_im/discovery/screen.cljs @@ -1,27 +1,21 @@ (ns syng-im.discovery.screen - (:require - [syng-im.utils.logging :as log] [re-frame.core :refer [dispatch subscribe]] - [syng-im.models.discoveries :refer [save-discoveries]] - [syng-im.components.react :refer [android? - view + [syng-im.components.react :refer [view scroll-view text text-input]] - [reagent.core :as r] [syng-im.components.toolbar :refer [toolbar]] [syng-im.discovery.views.popular :refer [popular]] - [syng-im.discovery.discovery-recent :refer [discovery-recent]] - [syng-im.discovery.styles :as st] - [syng-im.persistence.realm :as realm])) + [syng-im.discovery.views.recent :refer [discovery-recent]] + [syng-im.discovery.styles :as st])) (defn get-hashtags [status] (let [hashtags (map #(subs % 1) (re-seq #"#[^ !?,;:.]+" status))] (or hashtags []))) -(defn title-content [showSearch] - (if showSearch +(defn title-content [show-search] + (if show-search [text-input {:style st/discovery-search-input :autoFocus true :placeholder "Type your search tags here" @@ -48,7 +42,7 @@ :height 12}} :handler #(dispatch [:create-fake-discovery!])} :title "Add Participants" - :content (title-content @show-search) + :content [title-content @show-search] :action {:image {:source {:uri :icon_search} :style {:width 17 :height 17}} diff --git a/src/syng_im/discovery/subs.cljs b/src/syng_im/discovery/subs.cljs index 09c98628a6..053094706b 100644 --- a/src/syng_im/discovery/subs.cljs +++ b/src/syng_im/discovery/subs.cljs @@ -1,26 +1,20 @@ (ns syng-im.discovery.subs (:require-macros [reagent.ratom :refer [reaction]]) - (:require [re-frame.core :refer [register-sub]] - [syng-im.models.discoveries :refer [current-tag - current-tag-updated?]])) + (:require [re-frame.core :refer [register-sub]])) (register-sub :get-discoveries-by-tag (fn [db [_ tag limit]] - (let [discoveries (reaction (:discoveries @db))] + (let [discoveries (reaction (:discoveries @db)) + tag' (or tag (:current-tag @db)) + filter-tag (filter #(some #{tag'} (map :name (:tags %)))) + xform (if limit + (comp filter-tag (take limit)) + filter-tag)] (->> @discoveries - (into [] (comp (filter #(some #{tag} (map :name (:tags %)))) - (take limit))) + (into [] xform) (reaction))))) (register-sub :get-popular-tags (fn [db [_ limit]] (reaction (take limit (:tags @db))))) -(register-sub :get-current-tag - (fn [db _] - (let [current-tag-updated (-> (current-tag-updated? @db) - (reaction))] - (reaction - (let [_ @current-tag-updated] - (current-tag @db)))))) - diff --git a/src/syng_im/discovery/tag.cljs b/src/syng_im/discovery/tag.cljs new file mode 100644 index 0000000000..ab04eb55c9 --- /dev/null +++ b/src/syng_im/discovery/tag.cljs @@ -0,0 +1,42 @@ +(ns syng-im.discovery.tag + (:require + [re-frame.core :refer [subscribe dispatch]] + [syng-im.utils.logging :as log] + [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.components.react :refer [view text list-view list-item]] + [syng-im.components.toolbar :refer [toolbar]] + [syng-im.discovery.views.popular-list-item :refer [popular-list-item]] + [syng-im.discovery.styles :as st])) + +(defn render-row [row _ _] + (list-item [popular-list-item row])) + +(defn render-separator [_ row-id _] + (list-item [view {:style st/row-separator + :key row-id}])) + +(defn title-content [tag] + [view st/tag-title-container + [text {:style st/tag-title} (str " #" tag)]]) + +(defn discovery-tag [] + (let [tag (subscribe [:get :current-tag]) + discoveries (subscribe [:get-discoveries-by-tag])] + (log/debug "Got discoveries: " @discoveries) + (fn [] + (let [items @discoveries + datasource (to-datasource2 items)] + [view st/discovery-tag-container + [toolbar {:nav-action {:image {:source {:uri :icon_back} + :style st/icon-back} + :handler #(dispatch [:navigate-back])} + :title "Add Participants" + :content (title-content @tag) + :action {:image {:source {:uri :icon_search} + :style st/icon-search} + :handler (fn [])}}] + + [list-view {:dataSource datasource + :renderRow render-row + :renderSeparator render-separator + :style st/recent-list}]])))) diff --git a/src/syng_im/discovery/views/popular.cljs b/src/syng_im/discovery/views/popular.cljs index 91bd8f8b7a..0df56adde7 100644 --- a/src/syng_im/discovery/views/popular.cljs +++ b/src/syng_im/discovery/views/popular.cljs @@ -6,7 +6,7 @@ text]] [syng-im.components.carousel.carousel :refer [carousel]] [syng-im.discovery.styles :as st] - [syng-im.discovery.discovery-popular-list :refer [discovery-popular-list]])) + [syng-im.discovery.views.popular-list :refer [discovery-popular-list]])) (defn page-width [] (.-width (.get (.. js/React -Dimensions) "window"))) diff --git a/src/syng_im/discovery/discovery_popular_list.cljs b/src/syng_im/discovery/views/popular_list.cljs similarity index 60% rename from src/syng_im/discovery/discovery_popular_list.cljs rename to src/syng_im/discovery/views/popular_list.cljs index 9eebed2463..4a82a4573d 100644 --- a/src/syng_im/discovery/discovery_popular_list.cljs +++ b/src/syng_im/discovery/views/popular_list.cljs @@ -1,27 +1,21 @@ -(ns syng-im.discovery.discovery-popular-list +(ns syng-im.discovery.views.popular-list (:require - [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.utils.logging :as log] - [syng-im.components.react :refer [android? - view + [re-frame.core :refer [subscribe dispatch]] + [syng-im.components.react :refer [view list-view list-item touchable-highlight - text - image]] - [reagent.core :as r] + text]] [syng-im.discovery.styles :as st] - [syng-im.utils.listview :refer [to-realm-datasource to-datasource2]] - [syng-im.discovery.discovery-popular-list-item :refer [discovery-popular-list-item] ]) - ) - + [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.discovery.views.popular-list-item :refer [popular-list-item]])) (defn render-row [row _ _] - (list-item [discovery-popular-list-item row])) + (list-item [popular-list-item row])) -(defn render-separator [sectionID rowID adjacentRowHighlighted] +(defn render-separator [_ row-id _] (list-item [view {:style st/row-separator - :key rowID}])) + :key row-id}])) (defn discovery-popular-list [tag count] (let [discoveries (subscribe [:get-discoveries-by-tag tag 3])] diff --git a/src/syng_im/discovery/discovery_popular_list_item.cljs b/src/syng_im/discovery/views/popular_list_item.cljs similarity index 82% rename from src/syng_im/discovery/discovery_popular_list_item.cljs rename to src/syng_im/discovery/views/popular_list_item.cljs index 65df82164a..bb7eb18d91 100644 --- a/src/syng_im/discovery/discovery_popular_list_item.cljs +++ b/src/syng_im/discovery/views/popular_list_item.cljs @@ -1,9 +1,10 @@ -(ns syng-im.discovery.discovery-popular-list-item +(ns syng-im.discovery.views.popular-list-item + ;syng-im.discovery.views.popular-list-item (:require [syng-im.components.react :refer [view text image]] [syng-im.discovery.styles :as st] [reagent.core :as r])) -(defn discovery-popular-list-item +(defn popular-list-item [{:keys [name status]}] [view st/popular-list-item [view st/popular-list-item-name-container diff --git a/src/syng_im/discovery/discovery_recent.cljs b/src/syng_im/discovery/views/recent.cljs similarity index 78% rename from src/syng_im/discovery/discovery_recent.cljs rename to src/syng_im/discovery/views/recent.cljs index d9128b2fef..598bcd66f8 100644 --- a/src/syng_im/discovery/discovery_recent.cljs +++ b/src/syng_im/discovery/views/recent.cljs @@ -1,14 +1,14 @@ -(ns syng-im.discovery.discovery-recent +(ns syng-im.discovery.views.recent (:require [re-frame.core :refer [subscribe]] [syng-im.components.react :refer [view list-view list-item]] [syng-im.utils.listview :refer [to-realm-datasource to-datasource2]] [syng-im.discovery.styles :as st] - [syng-im.discovery.discovery-popular-list-item - :refer [discovery-popular-list-item]])) + [syng-im.discovery.views.popular-list-item + :refer [popular-list-item]])) (defn render-row [row _ _] - (list-item [discovery-popular-list-item row])) + (list-item [popular-list-item row])) (defn render-separator [_ row-id _] (list-item [view {:style st/row-separator diff --git a/src/syng_im/models/commands.cljs b/src/syng_im/models/commands.cljs index 177dfaacfd..15d7ffc8fa 100644 --- a/src/syng_im/models/commands.cljs +++ b/src/syng_im/models/commands.cljs @@ -1,12 +1,9 @@ (ns syng-im.models.commands (:require [clojure.string :refer [join split]] [clojure.walk :refer [stringify-keys keywordize-keys]] - [cljs.core.async :as async :refer [chan put! !]] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] + [re-frame.core :refer [subscribe dispatch]] [syng-im.db :as db] - [syng-im.components.styles :refer [color-blue - color-dark-mint]] - [syng-im.utils.utils :refer [log toast]])) + [syng-im.components.styles :refer [color-blue color-dark-mint]])) ;; todo delete (def commands [{:command :money diff --git a/src/syng_im/models/discoveries.cljs b/src/syng_im/models/discoveries.cljs index f374f6ba03..6e8ea4cf0d 100644 --- a/src/syng_im/models/discoveries.cljs +++ b/src/syng_im/models/discoveries.cljs @@ -5,15 +5,6 @@ [syng-im.persistence.realm :as r] [syng-im.db :as db])) -(defn current-tag-updated? [db] - (get-in db db/updated-current-tag-signal-path)) - -(defn current-tag [db] - (get-in db db/current-tag-path)) - -(defn set-current-tag [db tag] - (assoc-in db db/current-tag-path tag)) - (defn get-tag [tag] (log/debug "Getting tag: " tag) (-> (r/get-by-field :tag :name tag) From 9031ab5144bc135e80876474415d66f587aff3c9 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Fri, 13 May 2016 16:58:14 +0300 Subject: [PATCH 14/26] some missed styles Former-commit-id: c62feb0159e147414afb2d620dba1d1d596e97e8 --- src/syng_im/discovery/screen.cljs | 21 +++++++++------------ src/syng_im/discovery/styles.cljs | 12 ++++++++++++ 2 files changed, 21 insertions(+), 12 deletions(-) diff --git a/src/syng_im/discovery/screen.cljs b/src/syng_im/discovery/screen.cljs index 751125324a..302a8aa11c 100644 --- a/src/syng_im/discovery/screen.cljs +++ b/src/syng_im/discovery/screen.cljs @@ -33,24 +33,21 @@ [] (let [show-search (subscribe [:get ::show-search])] (fn [] - [view {:flex 1 - :backgroundColor :#eef2f5} + [view st/discovery-container [toolbar {:style st/discovery-toolbar :nav-action {:image {:source {:uri :icon_hamburger} - :style {:width 16 - :height 12}} + :style st/hamburger-icon} :handler #(dispatch [:create-fake-discovery!])} :title "Add Participants" :content [title-content @show-search] :action {:image {:source {:uri :icon_search} - :style {:width 17 - :height 17}} + :style st/search-icon} :handler #(toogle-search @show-search)}}] [scroll-view {:style {}} - [view st/section-spacing - [text {:style st/discovery-subtitle} "Popular tags"]] - [popular] - [view st/section-spacing - [text {:style st/discovery-subtitle} "Recent"]] - [discovery-recent]]]))) + [view st/section-spacing + [text {:style st/discovery-subtitle} "Popular tags"]] + [popular] + [view st/section-spacing + [text {:style st/discovery-subtitle} "Recent"]] + [discovery-recent]]]))) diff --git a/src/syng_im/discovery/styles.cljs b/src/syng_im/discovery/styles.cljs index b4518d057d..6b7c1ef10d 100644 --- a/src/syng_im/discovery/styles.cljs +++ b/src/syng_im/discovery/styles.cljs @@ -173,3 +173,15 @@ (def icon-search {:width 17 :height 17}) + +(def discovery-container + {:flex 1 + :backgroundColor :#eef2f5}) + +(def hamburger-icon + {:width 16 + :height 12}) + +(def search-icon + {:width 17 + :height 17}) From ee5a169c8ef025cffb6cad7abb7cc8cccab53616 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Fri, 13 May 2016 17:34:04 +0300 Subject: [PATCH 15/26] move discoveries model Former-commit-id: c27fddfe18a86a596887a2524b2b5b1656428f8c --- src/syng_im/discovery/handlers.cljs | 10 +++++----- .../discoveries.cljs => discovery/model.cljs} | 14 ++++---------- src/syng_im/discovery/views/recent.cljs | 1 + src/syng_im/handlers.cljs | 4 +--- src/syng_im/models/messages.cljs | 3 --- 5 files changed, 11 insertions(+), 21 deletions(-) rename src/syng_im/{models/discoveries.cljs => discovery/model.cljs} (89%) diff --git a/src/syng_im/discovery/handlers.cljs b/src/syng_im/discovery/handlers.cljs index 0b00f15cd9..2efd7543ed 100644 --- a/src/syng_im/discovery/handlers.cljs +++ b/src/syng_im/discovery/handlers.cljs @@ -1,10 +1,8 @@ (ns syng-im.discovery.handlers - (:require [re-frame.core :refer [register-handler after dispatch enrich - log-ex debug]] + (:require [re-frame.core :refer [register-handler after dispatch enrich]] [syng-im.protocol.api :as api] - [syng-im.models.discoveries :refer [save-discoveries]] [syng-im.navigation.handlers :as nav] - [syng-im.models.discoveries :as discoveries] + [syng-im.discovery.model :as discoveries] [syng-im.utils.handlers :as u])) (defmethod nav/preload-data! :discovery @@ -12,6 +10,9 @@ (if-not (seq discoveries) (-> db (assoc :tags (discoveries/all-tags)) + ;; todo add limit + ;; todo hash-map with whisper-id as key and sorted by last-update + ;; may be more efficient here (assoc :discoveries (discoveries/discovery-list))) db)) @@ -71,6 +72,5 @@ (register-handler :add-discovery (-> add-discovery - debug ((after save-discovery!)) ((enrich reload-tags!)))) diff --git a/src/syng_im/models/discoveries.cljs b/src/syng_im/discovery/model.cljs similarity index 89% rename from src/syng_im/models/discoveries.cljs rename to src/syng_im/discovery/model.cljs index 6e8ea4cf0d..40d92407b2 100644 --- a/src/syng_im/models/discoveries.cljs +++ b/src/syng_im/discovery/model.cljs @@ -1,9 +1,8 @@ -(ns syng-im.models.discoveries - (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.utils.logging :as log] +(ns syng-im.discovery.model + ;syng-im.models.discoveries + (:require [syng-im.utils.logging :as log] [syng-im.persistence.realm :as realm] - [syng-im.persistence.realm :as r] - [syng-im.db :as db])) + [syng-im.persistence.realm :as r])) (defn get-tag [tag] (log/debug "Getting tag: " tag) @@ -88,8 +87,3 @@ (r/sorted :count :desc) r/collection->map)) -(defn get-tag-popular [limit] - (-> (r/get-all :tag) - (r/sorted :count :desc) - (r/page 0 limit))) - diff --git a/src/syng_im/discovery/views/recent.cljs b/src/syng_im/discovery/views/recent.cljs index 598bcd66f8..b1bebc2d0a 100644 --- a/src/syng_im/discovery/views/recent.cljs +++ b/src/syng_im/discovery/views/recent.cljs @@ -17,6 +17,7 @@ (defn discovery-recent [] (let [discoveries (subscribe [:get :discoveries])] (fn [] + ;; todo fetch more on :onEndReached [list-view {:dataSource (to-datasource2 @discoveries) :renderRow render-row :renderSeparator render-separator diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index 021b072111..ac8ce2f21e 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -8,9 +8,7 @@ [syng-im.models.protocol :refer [update-identity set-initialized]] [syng-im.models.contacts :as contacts] - [syng-im.models.messages :refer [save-message - update-message! - message-by-id]] + [syng-im.models.messages :refer [save-message update-message!]] [syng-im.models.commands :refer [set-commands]] [syng-im.handlers.server :as server] [syng-im.chat.suggestions :refer [get-command diff --git a/src/syng_im/models/messages.cljs b/src/syng_im/models/messages.cljs index bf58efd2cd..b4c6d3b834 100644 --- a/src/syng_im/models/messages.cljs +++ b/src/syng_im/models/messages.cljs @@ -51,9 +51,6 @@ (update message :content str-to-map) message))))) -(defn message-by-id [msg-id] - (r/single-cljs (r/get-by-field :msgs :msg-id msg-id))) - (defn update-message! [{:keys [msg-id] :as msg}] (log/debug "update-message!" msg) (r/write From 96821edf6bb192c03e53a4cafdb817816af83dc5 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Fri, 13 May 2016 18:56:52 +0300 Subject: [PATCH 16/26] remove to-realm-datasource Former-commit-id: f484b190fde34712150ef6c87b776f8acfd85b82 --- src/syng_im/chats_list/screen.cljs | 47 ++++++++--------- .../chats_list/views/chat_list_item.cljs | 7 ++- src/syng_im/components/react.cljs | 39 -------------- src/syng_im/components/realm.cljs | 12 ----- src/syng_im/components/toolbar.cljs | 3 +- src/syng_im/discovery/views/recent.cljs | 2 +- src/syng_im/handlers.cljs | 4 +- src/syng_im/new_group/screen.cljs | 52 +++++++++++-------- src/syng_im/participants/views/create.cljs | 10 ++-- src/syng_im/participants/views/remove.cljs | 22 ++++---- src/syng_im/subs.cljs | 38 +++++++------- src/syng_im/utils/listview.cljs | 6 --- 12 files changed, 91 insertions(+), 151 deletions(-) diff --git a/src/syng_im/chats_list/screen.cljs b/src/syng_im/chats_list/screen.cljs index 8d3edbec7b..277e1fc022 100644 --- a/src/syng_im/chats_list/screen.cljs +++ b/src/syng_im/chats_list/screen.cljs @@ -1,11 +1,12 @@ (ns syng-im.chats-list.screen (:require [re-frame.core :refer [subscribe dispatch]] - [syng-im.components.react :refer [view + [syng-im.components.react :refer [list-view + list-item + view text image touchable-highlight]] - [syng-im.components.realm :refer [list-view]] - [syng-im.utils.listview :refer [to-realm-datasource]] + [syng-im.utils.listview :refer [to-datasource2]] [reagent.core :as r] [syng-im.chats-list.views.chat-list-item :refer [chat-list-item]] [syng-im.components.action-button :refer [action-button @@ -28,24 +29,22 @@ (defn chats-list [] (let [chats (subscribe [:get :chats])] (fn [] - (let [chats @chats - datasource (to-realm-datasource chats)] - [view st/chats-container - [chats-list-toolbar] - [list-view {:dataSource datasource - :renderRow (fn [row _ _] - (r/as-element [chat-list-item row])) - :style st/list-container}] - [action-button {:buttonColor color-blue} - [action-button-item - {:title "New Chat" - :buttonColor :#9b59b6 - :onPress #(dispatch [:navigate-to :contact-list])} - [icon {:name :android-create - :style st/create-icon}]] - [action-button-item - {:title "New Group Chat" - :buttonColor :#1abc9c - :onPress #(dispatch [:show-group-new])} - [icon {:name :person-stalker - :style st/person-stalker-icon}]]]])))) + [view st/chats-container + [chats-list-toolbar] + [list-view {:dataSource (to-datasource2 (vals @chats)) + :renderRow (fn [row _ _] + (list-item [chat-list-item row])) + :style st/list-container}] + [action-button {:buttonColor color-blue} + [action-button-item + {:title "New Chat" + :buttonColor :#9b59b6 + :onPress #(dispatch [:navigate-to :contact-list])} + [icon {:name :android-create + :style st/create-icon}]] + [action-button-item + {:title "New Group Chat" + :buttonColor :#1abc9c + :onPress #(dispatch [:show-group-new])} + [icon {:name :person-stalker + :style st/person-stalker-icon}]]]]))) diff --git a/src/syng_im/chats_list/views/chat_list_item.cljs b/src/syng_im/chats_list/views/chat_list_item.cljs index 9f91eb7bdb..3673701ccc 100644 --- a/src/syng_im/chats_list/views/chat_list_item.cljs +++ b/src/syng_im/chats_list/views/chat_list_item.cljs @@ -8,12 +8,11 @@ [syng-im.chats-list.views.inner-item :refer [chat-list-item-inner-view]])) -(defn chat-list-item [chat-obj] +(defn chat-list-item [{:keys [chat-id] :as chat}] [touchable-highlight - {:on-press #(dispatch [:show-chat (aget chat-obj "chat-id") :push])} + {:on-press #(dispatch [:show-chat chat-id :push])} ;; TODO add [photo-path delivery-status new-messages-count online] values to chat-obj - ;; TODO should chat-obj be clj-map? - [view [chat-list-item-inner-view (merge (js->clj chat-obj :keywordize-keys true) + [view [chat-list-item-inner-view (merge chat {:photo-path nil :delivery-status :seen :new-messages-count 3 diff --git a/src/syng_im/components/react.cljs b/src/syng_im/components/react.cljs index 64b6dcd001..4ac5483aa2 100644 --- a/src/syng_im/components/react.cljs +++ b/src/syng_im/components/react.cljs @@ -40,42 +40,3 @@ (r/as-element component)) (def dismiss-keyboard! (js/require "dismissKeyboard")) - -(comment - (.-width (.get (.. js/React -Dimensions) "window")) - ) - - -;; (do -;; (def activity-indicator-ios (r/adapt-react-class (.-ActivityIndicatorIOS js/React))) -;; (def animated-image (r/adapt-react-class (.-Animated.Image js/React))) -;; (def animated-text (r/adapt-react-class (.-Animated.Text js/React))) -;; (def animated-view (r/adapt-react-class (.-Animated.View js/React))) -;; (def date-picker-ios (r/adapt-react-class (.-DatePickerIOS js/React))) -;; (def drawer-layout-android (r/adapt-react-class (.-DrawerLayoutAndroid js/React))) -;; (def image (r/adapt-react-class (.-Image js/React))) -;; (def list-view (r/adapt-react-class (.-ListView js/React))) -;; (def map-view (r/adapt-react-class (.-MapView js/React))) -;; (def modal (r/adapt-react-class (.-Modal js/React))) -;; (def navigator (r/adapt-react-class (.-Navigator js/React))) -;; (def navigator-ios (r/adapt-react-class (.-NavigatorIOS js/React))) -;; (def picker-ios (r/adapt-react-class (.-PickerIOS js/React))) -;; (def progress-bar-android (r/adapt-react-class (.-ProgressBarAndroid js/React))) -;; (def progress-view-ios (r/adapt-react-class (.-ProgressViewIOS js/React))) -;; (def pull-to-refresh-view-android (r/adapt-react-class (.-PullToRefreshViewAndroid js/React))) -;; (def scroll-view (r/adapt-react-class (.-ScrollView js/React))) -;; (def segmented-control-ios (r/adapt-react-class (.-SegmentedControlIOS js/React))) -;; (def slider-ios (r/adapt-react-class (.-SliderIOS js/React))) -;; (def switch (r/adapt-react-class (.-Switch js/React))) -;; (def tab-bar-ios (r/adapt-react-class (.-TabBarIOS js/React))) -;; (def tab-bar-ios-item (r/adapt-react-class (.-TabBarIOS.Item js/React))) -;; (def text (r/adapt-react-class (.-Text js/React))) -;; (def text-input (r/adapt-react-class (.-TextInput js/React))) -;; (def toolbar-android (r/adapt-react-class (.-ToolbarAndroid js/React))) -;; (def touchable-highlight (r/adapt-react-class (.-TouchableHighlight js/React))) -;; (def touchable-native-feedback (r/adapt-react-class (.-TouchableNativeFeedback js/React))) -;; (def touchable-opacity (r/adapt-react-class (.-TouchableOpacity js/React))) -;; (def touchable-without-feedback (r/adapt-react-class (.-TouchableWithoutFeedback js/React))) -;; (def view (r/adapt-react-class (.-View js/React))) -;; (def view-pager-android (r/adapt-react-class (.-ViewPagerAndroid js/React))) -;; (def web-view (r/adapt-react-class (.-WebView js/React)))) diff --git a/src/syng_im/components/realm.cljs b/src/syng_im/components/realm.cljs index 93f8d84ccc..f9ea17d84e 100644 --- a/src/syng_im/components/realm.cljs +++ b/src/syng_im/components/realm.cljs @@ -7,15 +7,3 @@ (defn list-view [props] [list-view-class (merge {:enableEmptySections true} props)]) - -(comment - - - ;(set! js/wat (js/require "realm.react-native.ListView")) - ;(.-Results js/Realm) - ; - ;(r/realm) - ; - ;(require '[syng-im.persistence.realm :as r]) - - ) diff --git a/src/syng_im/components/toolbar.cljs b/src/syng_im/components/toolbar.cljs index d13ac69050..13353f3321 100644 --- a/src/syng_im/components/toolbar.cljs +++ b/src/syng_im/components/toolbar.cljs @@ -12,8 +12,7 @@ color-purple text1-color text2-color - toolbar-background1]] - [syng-im.utils.listview :refer [to-realm-datasource]])) + toolbar-background1]])) (defn toolbar [{:keys [title nav-action action background-color content style]}] (let [style (merge {:flexDirection :row diff --git a/src/syng_im/discovery/views/recent.cljs b/src/syng_im/discovery/views/recent.cljs index b1bebc2d0a..77792e55a7 100644 --- a/src/syng_im/discovery/views/recent.cljs +++ b/src/syng_im/discovery/views/recent.cljs @@ -2,7 +2,7 @@ (:require [re-frame.core :refer [subscribe]] [syng-im.components.react :refer [view list-view list-item]] - [syng-im.utils.listview :refer [to-realm-datasource to-datasource2]] + [syng-im.utils.listview :refer [to-datasource2]] [syng-im.discovery.styles :as st] [syng-im.discovery.views.popular-list-item :refer [popular-list-item]])) diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index ac8ce2f21e..ceccb47de1 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -238,12 +238,12 @@ (update-new-participants-selection db identity add?))) (register-handler :remove-selected-participants - (fn [db [action navigator]] + (fn [db [action]] (log/debug action) (let [identities (vec (:new-participants db)) chat-id (:current-chat-id db)] (chat-remove-participants chat-id identities) - (nav-pop navigator) + (dispatch [:navigate-back]) (doseq [ident identities] (api/group-remove-participant chat-id ident) (removed-participant-msg chat-id ident))))) diff --git a/src/syng_im/new_group/screen.cljs b/src/syng_im/new_group/screen.cljs index 695aa37040..91fcd8c3ad 100644 --- a/src/syng_im/new_group/screen.cljs +++ b/src/syng_im/new_group/screen.cljs @@ -6,39 +6,46 @@ text image icon - touchable-highlight]] + touchable-highlight + list-view + list-item]] [syng-im.components.styles :refer [color-purple]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.components.realm :refer [list-view]] - [syng-im.utils.listview :refer [to-realm-datasource]] + [syng-im.utils.listview :refer [to-datasource2]] [syng-im.new-group.views.contact :refer [new-group-contact]] - [reagent.core :as r] [syng-im.new-group.styles :as st])) -(defn new-group-toolbar [group-name] - [toolbar {:title "New group chat" - :action {:image {:source res/v ;; {:uri "icon_search"} - :style st/toolbar-icon} - :handler #(dispatch [:create-new-group group-name])}}]) +(defn new-group-toolbar [] + (let [group-name (subscribe [:get ::group-name])] + (fn [] + [toolbar + {:title "New group chat" + :action {:image {:source res/v ;; {:uri "icon_search"} + :style st/toolbar-icon} + :handler #(dispatch [:create-new-group @group-name])}}]))) + +(defn group-name-input [] + (let [group-name (subscribe [:get ::group-name])] + (fn [] + [text-input + {:underlineColorAndroid color-purple + :style st/group-name-input + :autoFocus true + :placeholder "Group Name" + :onChangeText #(dispatch [:set ::group-name %]) + :onSubmitEditing #(dispatch [:set ::group-name nil])} + @group-name]))) (defn new-group [] - (let [contacts (subscribe [:all-contacts]) - group-name (subscribe [:get ::group-name])] + (let [contacts (subscribe [:all-contacts])] (fn [] - (let [contacts-ds (to-realm-datasource @contacts)] + (let [contacts-ds (to-datasource2 @contacts)] [view st/new-group-container - [new-group-toolbar @group-name] + [new-group-toolbar] [view st/chat-name-container [text {:style st/chat-name-text} "Chat name"] - [text-input - {:underlineColorAndroid color-purple - :style st/group-name-input - :autoFocus true - :placeholder "Group Name" - :onChangeText #(dispatch [:set ::group-name %]) - :onSubmitEditing #(dispatch [:set ::group-name nil])} - @group-name] + [group-name-input] [text {:style st/members-text} "Members"] [touchable-highlight {:on-press (fn [])} [view st/add-container @@ -47,6 +54,5 @@ [list-view {:dataSource contacts-ds :renderRow (fn [row _ _] - (let [row' (js->clj row :keywordize-keys true)] - (r/as-element [new-group-contact row']))) + (list-item [new-group-contact row])) :style st/contacts-list}]]])))) diff --git a/src/syng_im/participants/views/create.cljs b/src/syng_im/participants/views/create.cljs index 7e2c522295..296fb3089b 100644 --- a/src/syng_im/participants/views/create.cljs +++ b/src/syng_im/participants/views/create.cljs @@ -1,10 +1,9 @@ (ns syng-im.participants.views.create (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.resources :as res] - [syng-im.components.react :refer [view]] - [syng-im.components.realm :refer [list-view]] + [syng-im.components.react :refer [view list-view list-item]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.utils.listview :refer [to-realm-datasource]] + [syng-im.utils.listview :refer [to-datasource2]] [syng-im.participants.views.contact :refer [participant-contact]] [reagent.core :as r] @@ -20,13 +19,12 @@ (defn new-participants-row [row _ _] - (r/as-element - [participant-contact (js->clj row :keywordize-keys true)])) + (list-item [participant-contact row])) (defn new-participants [{:keys [navigator]}] (let [contacts (subscribe [:all-new-contacts])] (fn [] - (let [contacts-ds (to-realm-datasource @contacts)] + (let [contacts-ds (to-datasource2 @contacts)] [view st/participants-container [new-participants-toolbar navigator] [list-view {:dataSource contacts-ds diff --git a/src/syng_im/participants/views/remove.cljs b/src/syng_im/participants/views/remove.cljs index 306d91084d..aa938b86ac 100644 --- a/src/syng_im/participants/views/remove.cljs +++ b/src/syng_im/participants/views/remove.cljs @@ -2,34 +2,32 @@ (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.resources :as res] [syng-im.components.react :refer [view text-input text image - touchable-highlight]] - [syng-im.components.realm :refer [list-view]] + touchable-highlight list-view + list-item]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.utils.listview :refer [to-realm-datasource]] + [syng-im.utils.listview :refer [to-datasource2]] [syng-im.participants.views.contact :refer [participant-contact]] [reagent.core :as r] [syng-im.participants.styles :as st])) -(defn remove-participants-toolbar [navigator] +(defn remove-participants-toolbar [] [toolbar - {:navigator navigator - :title "Remove Participants" - :action {:handler #(dispatch [:remove-selected-participants navigator]) + {:title "Remove Participants" + :action {:handler #(dispatch [:remove-selected-participants]) :image {:source res/trash-icon ;; {:uri "icon_search"} :style st/remove-participants-image}}}]) (defn remove-participants-row [row _ _] - (r/as-element - [participant-contact (js->clj row :keywordize-keys true)])) + (r/as-element [participant-contact row])) -(defn remove-participants [{:keys [navigator]}] +(defn remove-participants [] (let [contacts (subscribe [:current-chat-contacts])] (fn [] - (let [contacts-ds (to-realm-datasource @contacts)] + (let [contacts-ds (to-datasource2 @contacts)] [view st/participants-container - [remove-participants-toolbar navigator] + [remove-participants-toolbar] [list-view {:dataSource contacts-ds :renderRow remove-participants-row :style st/participants-list}]])))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index 1f713b248e..e485b39220 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -29,32 +29,30 @@ (reaction (:contacts @db)))) (register-sub :all-contacts - (fn [_ _] - (reaction (get-contacts)))) + (fn [db _] + (let [contacts (reaction (:contacts @db))] + (reaction (sort-by :name @contacts))))) + +(defn contacts-by-current-chat [fn db] + (let [current-chat-id (:current-chat-id @db) + chat (reaction (get-in @db [:chats current-chat-id])) + contacts (reaction (:contacts @db))] + (reaction + (when @chat + (let [current-participants (->> @chat + :contacts + (map :identity) + set)] + (fn #(current-participants (:whisper-identity %)) + @contacts)))))) (register-sub :all-new-contacts (fn [db _] - (let [current-chat-id (reaction (:current-chat-id @db)) - chat (reaction (when-let [chat-id @current-chat-id] - (chat-by-id chat-id)))] - (reaction - (when @chat - (let [current-participants (->> @chat - :contacts - (map :identity))] - (contacts-list-exclude current-participants))))))) + (contacts-by-current-chat remove db))) (register-sub :current-chat-contacts (fn [db _] - (let [current-chat-id (reaction (:current-chat-id @db)) - chat (reaction (when-let [chat-id @current-chat-id] - (chat-by-id chat-id)))] - (reaction - (when @chat - (let [current-participants (->> @chat - :contacts - (map :identity))] - (contacts-list-include current-participants))))))) + (contacts-by-current-chat filter db))) (register-sub :db (fn [db _] (reaction @db))) diff --git a/src/syng_im/utils/listview.cljs b/src/syng_im/utils/listview.cljs index d52b674394..f2fa7371e4 100644 --- a/src/syng_im/utils/listview.cljs +++ b/src/syng_im/utils/listview.cljs @@ -5,12 +5,6 @@ (defn to-datasource [items] (clone-with-rows (data-source {:rowHasChanged not=}) items)) -(defn to-realm-datasource [items] - (-> (cljs.core/clj->js {:rowHasChanged not=}) - (js/RealmReactNative.ListView.DataSource.) - (clone-with-rows items))) - - (defn clone-with-rows2 [ds rows] (.cloneWithRows ds (reduce (fn [ac el] (.push ac el) ac) (clj->js []) rows))) From 8de3be1f6f00cd5e2fbba652c7a274d377debfe1 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Fri, 13 May 2016 19:03:14 +0300 Subject: [PATCH 17/26] replace to-datasource2 Former-commit-id: 85e05a451dcd87db0df35b25db6e3a23bbe7fcbe --- src/syng_im/chat/screen.cljs | 4 ++-- src/syng_im/chat/views/suggestions.cljs | 4 +--- src/syng_im/chats_list/screen.cljs | 4 ++-- src/syng_im/contacts/screen.cljs | 2 +- src/syng_im/discovery/tag.cljs | 4 ++-- src/syng_im/discovery/views/popular_list.cljs | 4 ++-- src/syng_im/discovery/views/recent.cljs | 4 ++-- src/syng_im/new_group/screen.cljs | 4 ++-- src/syng_im/participants/views/create.cljs | 4 ++-- src/syng_im/participants/views/remove.cljs | 4 ++-- src/syng_im/utils/listview.cljs | 11 ++++------- 11 files changed, 22 insertions(+), 27 deletions(-) diff --git a/src/syng_im/chat/screen.cljs b/src/syng_im/chat/screen.cljs index 8b40ce8cfc..3c7785ab78 100644 --- a/src/syng_im/chat/screen.cljs +++ b/src/syng_im/chat/screen.cljs @@ -10,7 +10,7 @@ list-item]] [syng-im.chat.styles.chat :as st] [syng-im.resources :as res] - [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.utils.listview :refer [to-datasource]] [syng-im.components.invertible-scroll-view :refer [invertible-scroll-view]] [syng-im.chat.views.message :refer [chat-message]] [syng-im.chat.views.new-message :refer [chat-message-new]])) @@ -169,7 +169,7 @@ :renderScrollComponent #(invertible-scroll-view (js->clj %)) :onEndReached #(dispatch [:load-more-messages]) :enableEmptySections true - :dataSource (to-datasource2 @messages)}])))) + :dataSource (to-datasource @messages)}])))) (defn chat [] (let [is-active (subscribe [:chat :is-active]) diff --git a/src/syng_im/chat/views/suggestions.cljs b/src/syng_im/chat/views/suggestions.cljs index 97461c2741..64bc62b278 100644 --- a/src/syng_im/chat/views/suggestions.cljs +++ b/src/syng_im/chat/views/suggestions.cljs @@ -1,6 +1,4 @@ (ns syng-im.chat.views.suggestions - (:require-macros - [natal-shell.core :refer [with-error-view]]) (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view text @@ -25,7 +23,7 @@ [text {:style st/suggestion-description} description]]]) (defn render-row [row _ _] - (list-item [suggestion-list-item (js->clj row :keywordize-keys true)])) + (list-item [suggestion-list-item row])) (defn suggestions-view [] (let [suggestions-atom (subscribe [:get-suggestions])] diff --git a/src/syng_im/chats_list/screen.cljs b/src/syng_im/chats_list/screen.cljs index 277e1fc022..5d0092fc98 100644 --- a/src/syng_im/chats_list/screen.cljs +++ b/src/syng_im/chats_list/screen.cljs @@ -6,7 +6,7 @@ text image touchable-highlight]] - [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.utils.listview :refer [to-datasource]] [reagent.core :as r] [syng-im.chats-list.views.chat-list-item :refer [chat-list-item]] [syng-im.components.action-button :refer [action-button @@ -31,7 +31,7 @@ (fn [] [view st/chats-container [chats-list-toolbar] - [list-view {:dataSource (to-datasource2 (vals @chats)) + [list-view {:dataSource (to-datasource (vals @chats)) :renderRow (fn [row _ _] (list-item [chat-list-item row])) :style st/list-container}] diff --git a/src/syng_im/contacts/screen.cljs b/src/syng_im/contacts/screen.cljs index 73d3a4d610..9170c7b9cb 100644 --- a/src/syng_im/contacts/screen.cljs +++ b/src/syng_im/contacts/screen.cljs @@ -30,7 +30,7 @@ (defn contact-list [] (let [contacts (subscribe [:get :contacts])] (fn [] - (let [contacts-ds (lw/to-datasource2 @contacts)] + (let [contacts-ds (lw/to-datasource @contacts)] [view st/contacts-list-container [contact-list-toolbar] (when contacts-ds diff --git a/src/syng_im/discovery/tag.cljs b/src/syng_im/discovery/tag.cljs index ab04eb55c9..455adce8fc 100644 --- a/src/syng_im/discovery/tag.cljs +++ b/src/syng_im/discovery/tag.cljs @@ -2,7 +2,7 @@ (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.utils.logging :as log] - [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.utils.listview :refer [to-datasource]] [syng-im.components.react :refer [view text list-view list-item]] [syng-im.components.toolbar :refer [toolbar]] [syng-im.discovery.views.popular-list-item :refer [popular-list-item]] @@ -25,7 +25,7 @@ (log/debug "Got discoveries: " @discoveries) (fn [] (let [items @discoveries - datasource (to-datasource2 items)] + datasource (to-datasource items)] [view st/discovery-tag-container [toolbar {:nav-action {:image {:source {:uri :icon_back} :style st/icon-back} diff --git a/src/syng_im/discovery/views/popular_list.cljs b/src/syng_im/discovery/views/popular_list.cljs index 4a82a4573d..c56ac14206 100644 --- a/src/syng_im/discovery/views/popular_list.cljs +++ b/src/syng_im/discovery/views/popular_list.cljs @@ -7,7 +7,7 @@ touchable-highlight text]] [syng-im.discovery.styles :as st] - [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.utils.listview :refer [to-datasource]] [syng-im.discovery.views.popular-list-item :refer [popular-list-item]])) (defn render-row [row _ _] @@ -27,7 +27,7 @@ [text {:style st/tag-name} (str " #" (name tag))]]] [view st/tag-count-container [text {:style st/tag-count} count]]] - [list-view {:dataSource (to-datasource2 @discoveries) + [list-view {:dataSource (to-datasource @discoveries) :enableEmptySections true :renderRow render-row :renderSeparator render-separator diff --git a/src/syng_im/discovery/views/recent.cljs b/src/syng_im/discovery/views/recent.cljs index 77792e55a7..6eb1dc4038 100644 --- a/src/syng_im/discovery/views/recent.cljs +++ b/src/syng_im/discovery/views/recent.cljs @@ -2,7 +2,7 @@ (:require [re-frame.core :refer [subscribe]] [syng-im.components.react :refer [view list-view list-item]] - [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.utils.listview :refer [to-datasource]] [syng-im.discovery.styles :as st] [syng-im.discovery.views.popular-list-item :refer [popular-list-item]])) @@ -18,7 +18,7 @@ (let [discoveries (subscribe [:get :discoveries])] (fn [] ;; todo fetch more on :onEndReached - [list-view {:dataSource (to-datasource2 @discoveries) + [list-view {:dataSource (to-datasource @discoveries) :renderRow render-row :renderSeparator render-separator :style st/recent-list}]))) diff --git a/src/syng_im/new_group/screen.cljs b/src/syng_im/new_group/screen.cljs index 91fcd8c3ad..5e7843c86b 100644 --- a/src/syng_im/new_group/screen.cljs +++ b/src/syng_im/new_group/screen.cljs @@ -11,7 +11,7 @@ list-item]] [syng-im.components.styles :refer [color-purple]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.utils.listview :refer [to-datasource]] [syng-im.new-group.views.contact :refer [new-group-contact]] [syng-im.new-group.styles :as st])) @@ -40,7 +40,7 @@ (defn new-group [] (let [contacts (subscribe [:all-contacts])] (fn [] - (let [contacts-ds (to-datasource2 @contacts)] + (let [contacts-ds (to-datasource @contacts)] [view st/new-group-container [new-group-toolbar] [view st/chat-name-container diff --git a/src/syng_im/participants/views/create.cljs b/src/syng_im/participants/views/create.cljs index 296fb3089b..c059bfc785 100644 --- a/src/syng_im/participants/views/create.cljs +++ b/src/syng_im/participants/views/create.cljs @@ -3,7 +3,7 @@ [syng-im.resources :as res] [syng-im.components.react :refer [view list-view list-item]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.utils.listview :refer [to-datasource]] [syng-im.participants.views.contact :refer [participant-contact]] [reagent.core :as r] @@ -24,7 +24,7 @@ (defn new-participants [{:keys [navigator]}] (let [contacts (subscribe [:all-new-contacts])] (fn [] - (let [contacts-ds (to-datasource2 @contacts)] + (let [contacts-ds (to-datasource @contacts)] [view st/participants-container [new-participants-toolbar navigator] [list-view {:dataSource contacts-ds diff --git a/src/syng_im/participants/views/remove.cljs b/src/syng_im/participants/views/remove.cljs index aa938b86ac..40ff3528f7 100644 --- a/src/syng_im/participants/views/remove.cljs +++ b/src/syng_im/participants/views/remove.cljs @@ -5,7 +5,7 @@ touchable-highlight list-view list-item]] [syng-im.components.toolbar :refer [toolbar]] - [syng-im.utils.listview :refer [to-datasource2]] + [syng-im.utils.listview :refer [to-datasource]] [syng-im.participants.views.contact :refer [participant-contact]] [reagent.core :as r] @@ -25,7 +25,7 @@ (defn remove-participants [] (let [contacts (subscribe [:current-chat-contacts])] (fn [] - (let [contacts-ds (to-datasource2 @contacts)] + (let [contacts-ds (to-datasource @contacts)] [view st/participants-container [remove-participants-toolbar] [list-view {:dataSource contacts-ds diff --git a/src/syng_im/utils/listview.cljs b/src/syng_im/utils/listview.cljs index f2fa7371e4..ab7031662e 100644 --- a/src/syng_im/utils/listview.cljs +++ b/src/syng_im/utils/listview.cljs @@ -1,13 +1,10 @@ (ns syng-im.utils.listview - (:require-macros [natal-shell.data-source :refer [data-source clone-with-rows]]) + (:require-macros [natal-shell.data-source :refer [data-source]]) (:require [syng-im.components.realm])) -(defn to-datasource [items] - (clone-with-rows (data-source {:rowHasChanged not=}) items)) - -(defn clone-with-rows2 [ds rows] +(defn clone-with-rows [ds rows] (.cloneWithRows ds (reduce (fn [ac el] (.push ac el) ac) (clj->js []) rows))) -(defn to-datasource2 [items] - (clone-with-rows2 (data-source {:rowHasChanged not=}) items)) +(defn to-datasource [items] + (clone-with-rows (data-source {:rowHasChanged not=}) items)) From a24cdd293e8f909592862c7b4241c2591bb28bd7 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Sat, 14 May 2016 12:39:01 +0300 Subject: [PATCH 18/26] defview suggestion Former-commit-id: 780b12049e997190832a06a01245b9ed5f4d1f18 --- src/syng_im/discovery/screen.cljs | 43 +++++++++---------- src/syng_im/discovery/views/popular.cljs | 18 ++++---- src/syng_im/discovery/views/popular_list.cljs | 30 ++++++------- .../discovery/views/popular_list_item.cljs | 1 - src/syng_im/discovery/views/recent.cljs | 15 +++---- src/syng_im/utils/views.clj | 27 ++++++++++++ 6 files changed, 79 insertions(+), 55 deletions(-) create mode 100644 src/syng_im/utils/views.clj diff --git a/src/syng_im/discovery/screen.cljs b/src/syng_im/discovery/screen.cljs index 302a8aa11c..3f3a2fdf8b 100644 --- a/src/syng_im/discovery/screen.cljs +++ b/src/syng_im/discovery/screen.cljs @@ -1,4 +1,5 @@ (ns syng-im.discovery.screen + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [re-frame.core :refer [dispatch subscribe]] [syng-im.components.react :refer [view @@ -29,25 +30,23 @@ (defn toogle-search [current-value] (dispatch [:set ::show-search (not current-value)])) -(defn discovery [] - [] - (let [show-search (subscribe [:get ::show-search])] - (fn [] - [view st/discovery-container - [toolbar - {:style st/discovery-toolbar - :nav-action {:image {:source {:uri :icon_hamburger} - :style st/hamburger-icon} - :handler #(dispatch [:create-fake-discovery!])} - :title "Add Participants" - :content [title-content @show-search] - :action {:image {:source {:uri :icon_search} - :style st/search-icon} - :handler #(toogle-search @show-search)}}] - [scroll-view {:style {}} - [view st/section-spacing - [text {:style st/discovery-subtitle} "Popular tags"]] - [popular] - [view st/section-spacing - [text {:style st/discovery-subtitle} "Recent"]] - [discovery-recent]]]))) +(defview discovery [] + [show-search [:get ::show-search]] + [view st/discovery-container + [toolbar + {:style st/discovery-toolbar + :nav-action {:image {:source {:uri :icon_hamburger} + :style st/hamburger-icon} + :handler #(dispatch [:create-fake-discovery!])} + :title "Add Participants" + :content [title-content show-search] + :action {:image {:source {:uri :icon_search} + :style st/search-icon} + :handler #(toogle-search show-search)}}] + [scroll-view {:style {}} + [view st/section-spacing + [text {:style st/discovery-subtitle} "Popular tags"]] + [popular] + [view st/section-spacing + [text {:style st/discovery-subtitle} "Recent"]] + [discovery-recent]]]) diff --git a/src/syng_im/discovery/views/popular.cljs b/src/syng_im/discovery/views/popular.cljs index 0df56adde7..8d95e8d094 100644 --- a/src/syng_im/discovery/views/popular.cljs +++ b/src/syng_im/discovery/views/popular.cljs @@ -1,4 +1,5 @@ (ns syng-im.discovery.views.popular + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [re-frame.core :refer [subscribe]] [syng-im.utils.logging :as log] @@ -11,12 +12,11 @@ (defn page-width [] (.-width (.get (.. js/React -Dimensions) "window"))) -(defn popular [] - (let [popular-tags (subscribe [:get-popular-tags 3])] - (log/debug "Got popular tags: " @popular-tags) - (if (pos? (count @popular-tags)) - [carousel {:pageStyle st/carousel-page-style - :sneak 20} - (for [{:keys [name count]} @popular-tags] - [discovery-popular-list name count])] - [text "None"]))) +(defview popular [] + [popular-tags [:get-popular-tags 3]] + (if (pos? (count popular-tags)) + [carousel {:pageStyle st/carousel-page-style + :sneak 20} + (for [{:keys [name count]} popular-tags] + [discovery-popular-list name count])] + [text "None"])) diff --git a/src/syng_im/discovery/views/popular_list.cljs b/src/syng_im/discovery/views/popular_list.cljs index c56ac14206..78426570f6 100644 --- a/src/syng_im/discovery/views/popular_list.cljs +++ b/src/syng_im/discovery/views/popular_list.cljs @@ -1,4 +1,5 @@ (ns syng-im.discovery.views.popular-list + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view @@ -17,18 +18,17 @@ (list-item [view {:style st/row-separator :key row-id}])) -(defn discovery-popular-list [tag count] - (let [discoveries (subscribe [:get-discoveries-by-tag tag 3])] - (fn [tag count] - [view st/popular-list-container - [view st/row - [view st/tag-name-container - [touchable-highlight {:onPress #(dispatch [:show-discovery-tag tag])} - [text {:style st/tag-name} (str " #" (name tag))]]] - [view st/tag-count-container - [text {:style st/tag-count} count]]] - [list-view {:dataSource (to-datasource @discoveries) - :enableEmptySections true - :renderRow render-row - :renderSeparator render-separator - :style st/popular-list}]]))) +(defview discovery-popular-list [tag count] + [discoveries [:get-discoveries-by-tag tag 3]] + [view st/popular-list-container + [view st/row + [view st/tag-name-container + [touchable-highlight {:onPress #(dispatch [:show-discovery-tag tag])} + [text {:style st/tag-name} (str " #" (name tag))]]] + [view st/tag-count-container + [text {:style st/tag-count} count]]] + [list-view {:dataSource (to-datasource discoveries) + :enableEmptySections true + :renderRow render-row + :renderSeparator render-separator + :style st/popular-list}]]) diff --git a/src/syng_im/discovery/views/popular_list_item.cljs b/src/syng_im/discovery/views/popular_list_item.cljs index bb7eb18d91..6812cf4d1c 100644 --- a/src/syng_im/discovery/views/popular_list_item.cljs +++ b/src/syng_im/discovery/views/popular_list_item.cljs @@ -1,5 +1,4 @@ (ns syng-im.discovery.views.popular-list-item - ;syng-im.discovery.views.popular-list-item (:require [syng-im.components.react :refer [view text image]] [syng-im.discovery.styles :as st] [reagent.core :as r])) diff --git a/src/syng_im/discovery/views/recent.cljs b/src/syng_im/discovery/views/recent.cljs index 6eb1dc4038..e690890b2b 100644 --- a/src/syng_im/discovery/views/recent.cljs +++ b/src/syng_im/discovery/views/recent.cljs @@ -1,4 +1,5 @@ (ns syng-im.discovery.views.recent + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [re-frame.core :refer [subscribe]] [syng-im.components.react :refer [view list-view list-item]] @@ -14,11 +15,9 @@ (list-item [view {:style st/row-separator :key row-id}])) -(defn discovery-recent [] - (let [discoveries (subscribe [:get :discoveries])] - (fn [] - ;; todo fetch more on :onEndReached - [list-view {:dataSource (to-datasource @discoveries) - :renderRow render-row - :renderSeparator render-separator - :style st/recent-list}]))) +(defview discovery-recent [] + [discoveries [:get :discoveries]] + [list-view {:dataSource (to-datasource discoveries) + :renderRow render-row + :renderSeparator render-separator + :style st/recent-list}]) diff --git a/src/syng_im/utils/views.clj b/src/syng_im/utils/views.clj new file mode 100644 index 0000000000..3eb1487e76 --- /dev/null +++ b/src/syng_im/utils/views.clj @@ -0,0 +1,27 @@ +(ns syng-im.utils.views) + +(defn prepare-subs [subs] + (let [pairs (map (fn [[form sub]] + {:form form + :sub sub + :sym (gensym)}) + (partition 2 subs))] + [(mapcat (fn [{:keys [sym sub]}] + [sym `(re-frame.core/subscribe ~sub)]) + pairs) + (mapcat (fn [{:keys [sym form]}] + [form `(deref ~sym)]) + pairs)])) + +(defmacro defview + [n params & rest] + (let [[subs body] (if (= 1 (count rest)) + [nil (first rest)] + rest) + [subs-bindings vars-bindings] (prepare-subs subs)] + `(defn ~n ~params + (let [~@subs-bindings] + (fn ~params + (let [~@vars-bindings] + ~body)))))) + From becdb591d9df4ec0b97b4c1f71b1183ab1faea4d Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 16 May 2016 10:45:59 +0300 Subject: [PATCH 19/26] start chat with contact Former-commit-id: af0ed4c3a92b8eeb1a8955d30effef96e2bf5e85 --- src/syng_im/android/core.cljs | 2 +- src/syng_im/chat/handlers.cljs | 74 ++++++++++++++++--- src/syng_im/chat/screen.cljs | 45 ++++++----- .../chat/styles/{chat.cljs => screen.cljs} | 2 +- src/syng_im/chat/subs.cljs | 4 + src/syng_im/contacts/handlers.cljs | 11 ++- src/syng_im/contacts/screen.cljs | 29 +++----- src/syng_im/contacts/subs.cljs | 5 ++ src/syng_im/contacts/views/contact.cljs | 14 +++- src/syng_im/db.cljs | 2 +- src/syng_im/models/commands.cljs | 62 ++++++++-------- src/syng_im/participants/views/create.cljs | 14 ++-- src/syng_im/subs.cljs | 7 +- 13 files changed, 167 insertions(+), 104 deletions(-) rename src/syng_im/chat/styles/{chat.cljs => screen.cljs} (99%) diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index 0117816228..dee02d8a98 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -52,7 +52,7 @@ (dispatch [:initialize-chats]) (dispatch [:initialize-protocol]) (dispatch [:load-user-phone-number]) - (dispatch [:load-syng-contacts]) + (dispatch [:load-contacts]) ;; load commands from remote server (todo: uncomment) ;; (dispatch [:load-commands]) (dispatch [:init-console-chat]) diff --git a/src/syng_im/chat/handlers.cljs b/src/syng_im/chat/handlers.cljs index e5fd8213e0..1619f46596 100644 --- a/src/syng_im/chat/handlers.cljs +++ b/src/syng_im/chat/handlers.cljs @@ -1,5 +1,5 @@ (ns syng-im.chat.handlers - (:require [re-frame.core :refer [register-handler enrich after debug]] + (:require [re-frame.core :refer [register-handler enrich after debug dispatch]] [syng-im.models.commands :as commands] [clojure.string :as str] [syng-im.chat.suggestions :as suggestions] @@ -10,7 +10,9 @@ [syng-im.utils.random :as random] [syng-im.components.react :as r] [syng-im.handlers.sign-up :as sign-up-service] - [syng-im.models.chats :as chats])) + [syng-im.models.chats :as chats] + [syng-im.navigation.handlers :as nav] + [syng-im.models.chats :as c])) (register-handler :set-show-actions (fn [db [_ show-actions]] @@ -236,15 +238,16 @@ (defn load-messages! - [db _] - db - (->> (:current-chat-id db) - messages/get-messages - (assoc db :messages))) + ([db] (load-messages! db nil)) + ([db _] + (->> (:current-chat-id db) + messages/get-messages + (assoc db :messages)))) (defn init-chat - [{:keys [messages current-chat-id] :as db} _] - (assoc-in db [:chats current-chat-id :messages] messages)) + ([db] (init-chat db nil)) + ([{:keys [messages current-chat-id] :as db} _] + (assoc-in db [:chats current-chat-id :messages] messages))) (register-handler :init-chat (-> load-messages! @@ -256,9 +259,11 @@ (let [chats (->> loaded-chats (map (fn [{:keys [chat-id] :as chat}] [chat-id chat])) - (into {}))] + (into {})) + ids (set (keys chats))] (-> db (assoc :chats chats) + (assoc :chats-ids ids) (dissoc :loaded-chats)))) (defn load-chats! @@ -268,7 +273,6 @@ (register-handler :initialize-chats ((enrich initialize-chats) load-chats!)) - (defn store-message! [{:keys [new-message]} [_ {chat-id :from}]] (messages/save-message chat-id new-message)) @@ -288,3 +292,51 @@ (fn [db [_ {chat-id :group-id :as msg}]] (messages/save-message chat-id msg) db)) + +(defn load-chat! + [{:keys [chats current-chat-id] :as db}] + (when-not (chats current-chat-id) + (c/create-chat {})) + db) + +(defmethod nav/preload-data! :chat + [{:keys [current-chat-id] :as db} [_ _ id]] + (-> db + (assoc :current-chat-id (or id current-chat-id)) + load-messages! + init-chat)) + +(defn prepare-chat + [{:keys [contacts] :as db} [_ contcat-id]] + (let [name (get-in contacts [contcat-id :name]) + chat {:chat-id contcat-id + :name name + :group-chat false + :is-active true + :timestamp (.getTime (js/Date.)) + ;; todo how to choose color? + ;; todo do we need to have some color for not group chat? + :contacts [{:identity contcat-id + :text-color :#FFFFFF + :background-color :#AB7967}]}] + (assoc db :new-chat chat))) + +(defn add-chat [{:keys [new-chat] :as db} [_ chat-id]] + (-> db + (update :chats assoc chat-id new-chat) + (update :chats-ids conj chat-id))) + +(defn save-chat! + [{:keys [new-chat]} _] + (chats/create-chat new-chat)) + +(defn open-chat! + [_ [_ chat-id]] + (dispatch [:navigate-to :chat chat-id])) + +(register-handler :start-chat + (-> prepare-chat + ((enrich add-chat)) + ((after save-chat!)) + ((after open-chat!)) + debug)) diff --git a/src/syng_im/chat/screen.cljs b/src/syng_im/chat/screen.cljs index 3c7785ab78..e2a18adac0 100644 --- a/src/syng_im/chat/screen.cljs +++ b/src/syng_im/chat/screen.cljs @@ -1,4 +1,5 @@ (ns syng-im.chat.screen + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [clojure.string :as s] [re-frame.core :refer [subscribe dispatch]] [syng-im.components.react :refer [view @@ -8,7 +9,7 @@ touchable-highlight list-view list-item]] - [syng-im.chat.styles.chat :as st] + [syng-im.chat.styles.screen :as st] [syng-im.resources :as res] [syng-im.utils.listview :refer [to-datasource]] [syng-im.components.invertible-scroll-view :refer [invertible-scroll-view]] @@ -91,7 +92,7 @@ (defn actions-list-view [] (let [{:keys [group-chat active]} - (subscribe [:chat-properties [:group-chat :name :contacts :active]])] + (subscribe [:chat-properties [:group-chat :active]])] (when-let [actions (when (and @group-chat @active) [{:title "Add Contact to chat" :icon :menu_group @@ -160,25 +161,23 @@ [chat-photo {}] [contact-online {:online true}]]])]))) -(defn messages-view [group-chat] - (let [messages (subscribe [:chat :messages]) - contacts (subscribe [:chat :contacts])] - (fn [group-chat] - (let [contacts' (contacts-by-identity @contacts)] - [list-view {:renderRow (message-row contacts' group-chat) - :renderScrollComponent #(invertible-scroll-view (js->clj %)) - :onEndReached #(dispatch [:load-more-messages]) - :enableEmptySections true - :dataSource (to-datasource @messages)}])))) +(defview messages-view [group-chat] + [messages [:chat :messages] + contacts [:chat :contacts]] + (let [contacts' (contacts-by-identity contacts)] + [list-view {:renderRow (message-row contacts' group-chat) + :renderScrollComponent #(invertible-scroll-view (js->clj %)) + :onEndReached #(dispatch [:load-more-messages]) + :enableEmptySections true + :dataSource (to-datasource messages)}])) -(defn chat [] - (let [is-active (subscribe [:chat :is-active]) - group-chat (subscribe [:chat :group-chat]) - show-actions-atom (subscribe [:show-actions])] - (fn [] - [view st/chat-view - [toolbar] - [messages-view @group-chat] - (when @group-chat [typing-all]) - (when is-active [chat-message-new]) - (when @show-actions-atom [actions-view])]))) +(defview chat [] + [is-active [:chat :is-active] + group-chat [:chat :group-chat] + show-actions-atom [:show-actions]] + [view st/chat-view + [toolbar] + [messages-view group-chat] + (when group-chat [typing-all]) + (when is-active [chat-message-new]) + (when show-actions-atom [actions-view])]) diff --git a/src/syng_im/chat/styles/chat.cljs b/src/syng_im/chat/styles/screen.cljs similarity index 99% rename from src/syng_im/chat/styles/chat.cljs rename to src/syng_im/chat/styles/screen.cljs index 9ebf92eadb..f212f83bcd 100644 --- a/src/syng_im/chat/styles/chat.cljs +++ b/src/syng_im/chat/styles/screen.cljs @@ -1,4 +1,4 @@ -(ns syng-im.chat.styles.chat +(ns syng-im.chat.styles.screen (:require [syng-im.components.styles :refer [font title-font color-white diff --git a/src/syng_im/chat/subs.cljs b/src/syng_im/chat/subs.cljs index 9b5692c094..f2725baeba 100644 --- a/src/syng_im/chat/subs.cljs +++ b/src/syng_im/chat/subs.cljs @@ -76,3 +76,7 @@ (fn [db _] (let [current-chat-id (:current-chat-id @db)] (reaction (get-in @db [:chats current-chat-id]))))) + +(register-sub :get-chat + (fn [db [_ chat-id]] + (reaction (get-in @db [:chats chat-id])))) diff --git a/src/syng_im/contacts/handlers.cljs b/src/syng_im/contacts/handlers.cljs index 9cb4903d9b..ac58a379ba 100644 --- a/src/syng_im/contacts/handlers.cljs +++ b/src/syng_im/contacts/handlers.cljs @@ -12,15 +12,18 @@ (contacts/save-contacts [contact])) (register-handler :add-contact - (-> (fn [db [_ contact]] - (update db :contacts conj contact)) + (-> (fn [db [_ {:keys [whisper-identity] :as contact}]] + (update db :contacts assoc whisper-identity contact)) ((after save-contact)))) (defn load-contacts! [db _] - (let [contacts (contacts/get-contacts)] + (let [contacts (->> (contacts/get-contacts) + (map (fn [{:keys [whisper-identity] :as contact}] + [whisper-identity contact])) + (into {}))] (assoc db :contacts contacts))) -(register-handler :load-syng-contacts load-contacts!) +(register-handler :load-contacts load-contacts!) ;; TODO see https://github.com/rt2zz/react-native-contacts/issues/45 (def react-native-contacts (js/require "react-native-contacts")) diff --git a/src/syng_im/contacts/screen.cljs b/src/syng_im/contacts/screen.cljs index 9170c7b9cb..3e16b78380 100644 --- a/src/syng_im/contacts/screen.cljs +++ b/src/syng_im/contacts/screen.cljs @@ -1,7 +1,5 @@ (ns syng-im.contacts.screen - (:require-macros - [natal-shell.data-source :refer [data-source clone-with-rows]] - [natal-shell.core :refer [with-error-view]]) + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.components.react :refer [view text image @@ -17,9 +15,6 @@ (defn render-row [row _ _] (list-item [contact-view row])) -(defn get-data-source [contacts] - (clone-with-rows (data-source {:rowHasChanged not=}) contacts)) - (defn contact-list-toolbar [] [toolbar {:title "Contacts" :background-color toolbar-background2 @@ -27,14 +22,14 @@ :style st/search-icon} :handler (fn [])}}]) -(defn contact-list [] - (let [contacts (subscribe [:get :contacts])] - (fn [] - (let [contacts-ds (lw/to-datasource @contacts)] - [view st/contacts-list-container - [contact-list-toolbar] - (when contacts-ds - [list-view {:dataSource contacts-ds - :enableEmptySections true - :renderRow render-row - :style st/contacts-list}])])))) +(defview contact-list [] + [contacts [:get-contacts]] + [view st/contacts-list-container + [contact-list-toolbar] + ;; todo what if there is no contacts, should we show some information + ;; about this? + (when contacts + [list-view {:dataSource (lw/to-datasource contacts) + :enableEmptySections true + :renderRow render-row + :style st/contacts-list}])]) diff --git a/src/syng_im/contacts/subs.cljs b/src/syng_im/contacts/subs.cljs index 81459071c6..5e9616002f 100644 --- a/src/syng_im/contacts/subs.cljs +++ b/src/syng_im/contacts/subs.cljs @@ -1,3 +1,8 @@ (ns syng-im.contacts.subs (:require-macros [reagent.ratom :refer [reaction]]) (:require [re-frame.core :refer [register-sub]])) + +(register-sub :get-contacts + (fn [db _] + (let [contacts (reaction (:contacts @db))] + (reaction (vals @contacts))))) diff --git a/src/syng_im/contacts/views/contact.cljs b/src/syng_im/contacts/views/contact.cljs index d094ae02f0..861a4c3cfa 100644 --- a/src/syng_im/contacts/views/contact.cljs +++ b/src/syng_im/contacts/views/contact.cljs @@ -1,8 +1,16 @@ (ns syng-im.contacts.views.contact + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [syng-im.components.react :refer [view touchable-highlight]] - [re-frame.core :refer [dispatch]] + [re-frame.core :refer [dispatch subscribe]] [syng-im.contacts.views.contact-inner :refer [contact-inner-view]])) -(defn contact-view [contact] - [touchable-highlight {:onPress #(dispatch [:navigate-to :chat])} +(defn on-press [chat whisper-identity] + (if chat + #(dispatch [:navigate-to :chat whisper-identity]) + #(dispatch [:start-chat whisper-identity]))) + +(defview contact-view [{:keys [whisper-identity] :as contact}] + [chat [:get-chat whisper-identity]] + [touchable-highlight + {:onPress (on-press chat whisper-identity)} [view {} [contact-inner-view contact]]]) diff --git a/src/syng_im/db.cljs b/src/syng_im/db.cljs index 6e079af948..19eaa4ced4 100644 --- a/src/syng_im/db.cljs +++ b/src/syng_im/db.cljs @@ -10,6 +10,7 @@ (def app-db {:identity-password "replace-me-with-user-entered-password" :identity "me" :contacts [] + :contacts-ids #{} :current-chat-id "console" :chat {:command nil :last-message nil} @@ -39,4 +40,3 @@ [:chats chat-id :command-requests]) (defn chat-command-request-path [chat-id msg-id] [:chats chat-id :command-requests msg-id]) -(def updated-current-tag-signal-path [:current-tag-updated-signal]) diff --git a/src/syng_im/models/commands.cljs b/src/syng_im/models/commands.cljs index 15d7ffc8fa..c35492bd0a 100644 --- a/src/syng_im/models/commands.cljs +++ b/src/syng_im/models/commands.cljs @@ -75,52 +75,56 @@ (defn find-command [commands command-key] (first (filter #(= command-key (:command %)) commands))) -(defn get-chat-command-content [db] - (get-in db (db/chat-command-content-path (:current-chat-id db)))) +(defn get-chat-command-content + [{:keys [current-chat-id] :as db}] + (get-in db (db/chat-command-content-path current-chat-id))) -(defn set-chat-command-content [db content] - (assoc-in db - [:chats (:current-chat-id db) :command-input :content] - content)) +(defn set-chat-command-content + [{:keys [current-chat-id] :as db} content] + (assoc-in db [:chats current-chat-id :command-input :content] content)) -(defn get-chat-command [db] - (get-in db (db/chat-command-path (:current-chat-id db)))) +(defn get-chat-command + [{:keys [current-chat-id] :as db}] + (get-in db (db/chat-command-path current-chat-id))) -(defn set-response-chat-command [db msg-id command-key] - (let [chat-id (:current-chat-id db)] - (-> db - (assoc-in [:chats chat-id :command-input :content] nil) - (assoc-in [:chats chat-id :command-input :command] - (get-command db command-key)) - (assoc-in [:chats chat-id :command-input :to-msg-id] msg-id)))) +(defn set-response-chat-command + [{:keys [current-chat-id] :as db} msg-id command-key] + (update-in db [:chats current-chat-id :command-input] merge + {:content nil + :command (get-command db command-key) + :to-msg-id msg-id})) (defn set-chat-command [db command-key] (set-response-chat-command db nil command-key)) -(defn get-chat-command-to-msg-id [db] - (get-in db (db/chat-command-to-msg-id-path (:current-chat-id db)))) +(defn get-chat-command-to-msg-id + [{:keys [current-chat-id] :as db}] + (get-in db (db/chat-command-to-msg-id-path current-chat-id))) -(defn stage-command [db command-info] - (update-in db (db/chat-staged-commands-path (:current-chat-id db)) - (fn [staged-commands] - (if staged-commands - (conj staged-commands command-info) - [command-info])))) +(defn stage-command + [{:keys [current-chat-id] :as db} command-info] + (update-in db (db/chat-staged-commands-path current-chat-id) + #(if % + (conj % command-info) + [command-info]))) (defn unstage-command [db staged-command] (update-in db (db/chat-staged-commands-path (:current-chat-id db)) (fn [staged-commands] (filterv #(not= % staged-command) staged-commands)))) -(defn clear-staged-commands [db] - (assoc-in db (db/chat-staged-commands-path (:current-chat-id db)) [])) +(defn clear-staged-commands + [{:keys [current-chat-id] :as db}] + (assoc-in db (db/chat-staged-commands-path current-chat-id) [])) -(defn get-chat-command-request [db] - (get-in db (db/chat-command-request-path (:current-chat-id db) +(defn get-chat-command-request + [{:keys [current-chat-id] :as db}] + (get-in db (db/chat-command-request-path current-chat-id (get-chat-command-to-msg-id db)))) -(defn set-chat-command-request [db msg-id handler] - (update-in db (db/chat-command-requests-path (:current-chat-id db)) +(defn set-chat-command-request + [{:keys [current-chat-id] :as db} msg-id handler] + (update-in db (db/chat-command-requests-path current-chat-id) #(assoc % msg-id handler))) (defn parse-command-msg-content [commands content] diff --git a/src/syng_im/participants/views/create.cljs b/src/syng_im/participants/views/create.cljs index c059bfc785..20a84dfbfa 100644 --- a/src/syng_im/participants/views/create.cljs +++ b/src/syng_im/participants/views/create.cljs @@ -4,29 +4,27 @@ [syng-im.components.react :refer [view list-view list-item]] [syng-im.components.toolbar :refer [toolbar]] [syng-im.utils.listview :refer [to-datasource]] - [syng-im.participants.views.contact - :refer [participant-contact]] + [syng-im.participants.views.contact :refer [participant-contact]] [reagent.core :as r] [syng-im.participants.styles :as st])) -(defn new-participants-toolbar [navigator] +(defn new-participants-toolbar [] [toolbar - {:navigator navigator - :title "Add Participants" + {:title "Add Participants" :action {:image {:source res/v ;; {:uri "icon_search"} :style st/new-participant-image} - :handler #(dispatch [:add-new-participants navigator])}}]) + :handler #(dispatch [:add-new-participants])}}]) (defn new-participants-row [row _ _] (list-item [participant-contact row])) -(defn new-participants [{:keys [navigator]}] +(defn new-participants [] (let [contacts (subscribe [:all-new-contacts])] (fn [] (let [contacts-ds (to-datasource @contacts)] [view st/participants-container - [new-participants-toolbar navigator] + [new-participants-toolbar] [list-view {:dataSource contacts-ds :renderRow new-participants-row :style st/participants-list}]])))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index e485b39220..a4c96c2ffb 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -23,11 +23,6 @@ (fn [db _] (reaction (:signed-up @db)))) -(register-sub - :get-contacts - (fn [db _] - (reaction (:contacts @db)))) - (register-sub :all-contacts (fn [db _] (let [contacts (reaction (:contacts @db))] @@ -44,7 +39,7 @@ (map :identity) set)] (fn #(current-participants (:whisper-identity %)) - @contacts)))))) + (vals @contacts))))))) (register-sub :all-new-contacts (fn [db _] From b893cce7bb420063f04cb6c3a62680763751de63 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 16 May 2016 13:40:43 +0300 Subject: [PATCH 20/26] drawer Former-commit-id: ac4548f63b8f00afb67840d276f1024f37bdb3d3 --- src/syng_im/chats_list/screen.cljs | 42 ++++++++++++++++-------------- src/syng_im/components/drawer.cljs | 8 +++--- 2 files changed, 26 insertions(+), 24 deletions(-) diff --git a/src/syng_im/chats_list/screen.cljs b/src/syng_im/chats_list/screen.cljs index 5d0092fc98..f13e07c24c 100644 --- a/src/syng_im/chats_list/screen.cljs +++ b/src/syng_im/chats_list/screen.cljs @@ -11,6 +11,7 @@ [syng-im.chats-list.views.chat-list-item :refer [chat-list-item]] [syng-im.components.action-button :refer [action-button action-button-item]] + [syng-im.components.drawer :refer [drawer-view open-drawer]] [syng-im.components.styles :refer [color-blue]] [syng-im.components.toolbar :refer [toolbar]] [syng-im.components.icons.ionicons :refer [icon]] @@ -20,7 +21,7 @@ (defn chats-list-toolbar [] [toolbar {:nav-action {:image {:source {:uri :icon_hamburger} :style st/hamburger-icon} - :handler (fn [])} + :handler open-drawer} :title "Chats" :action {:image {:source {:uri :icon_search} :style st/search-icon} @@ -29,22 +30,23 @@ (defn chats-list [] (let [chats (subscribe [:get :chats])] (fn [] - [view st/chats-container - [chats-list-toolbar] - [list-view {:dataSource (to-datasource (vals @chats)) - :renderRow (fn [row _ _] - (list-item [chat-list-item row])) - :style st/list-container}] - [action-button {:buttonColor color-blue} - [action-button-item - {:title "New Chat" - :buttonColor :#9b59b6 - :onPress #(dispatch [:navigate-to :contact-list])} - [icon {:name :android-create - :style st/create-icon}]] - [action-button-item - {:title "New Group Chat" - :buttonColor :#1abc9c - :onPress #(dispatch [:show-group-new])} - [icon {:name :person-stalker - :style st/person-stalker-icon}]]]]))) + [drawer-view + [view st/chats-container + [chats-list-toolbar] + [list-view {:dataSource (to-datasource (vals @chats)) + :renderRow (fn [row _ _] + (list-item [chat-list-item row])) + :style st/list-container}] + [action-button {:buttonColor color-blue} + [action-button-item + {:title "New Chat" + :buttonColor :#9b59b6 + :onPress #(dispatch [:navigate-to :contact-list])} + [icon {:name :android-create + :style st/create-icon}]] + [action-button-item + {:title "New Group Chat" + :buttonColor :#1abc9c + :onPress #(dispatch [:show-group-new])} + [icon {:name :person-stalker + :style st/person-stalker-icon}]]]]]))) diff --git a/src/syng_im/components/drawer.cljs b/src/syng_im/components/drawer.cljs index 9716333b54..74d38d8f4e 100644 --- a/src/syng_im/components/drawer.cljs +++ b/src/syng_im/components/drawer.cljs @@ -35,9 +35,9 @@ [text {:style st/menu-item-text} name]]) -(defn drawer-menu [navigator] +(defn drawer-menu [] (let [username (subscribe [:get :username])] - (fn [navigator] + (fn [] [view st/drawer-menu [view st/user-photo-container [user-photo {}]] @@ -72,10 +72,10 @@ [text {:style st/switch-users-text} "Switch users"]]]]))) -(defn drawer-view [{:keys [navigator]} items] +(defn drawer-view [items] [drawer-layout-android {:drawerWidth 260 :drawerPosition js/React.DrawerLayoutAndroid.positions.Left - :render-navigation-view #(r/as-element [drawer-menu navigator]) + :render-navigation-view #(r/as-element [drawer-menu]) :ref (fn [drawer] (reset! drawer-atom drawer))} items]) From 1e179302950826a8925fb29c4477fe703c23999f Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 16 May 2016 14:05:43 +0300 Subject: [PATCH 21/26] content-suggestions Former-commit-id: c833764e224334f9212073265cb1dc3a25433492 --- .../styles/content_suggestions.cljs} | 2 +- src/syng_im/chat/views/command.cljs | 3 +- .../chat/views/content_suggestions.cljs | 36 +++++++++++++ .../components/chat/content_suggestions.cljs | 50 ------------------- 4 files changed, 39 insertions(+), 52 deletions(-) rename src/syng_im/{components/chat/content_suggestions_styles.cljs => chat/styles/content_suggestions.cljs} (96%) create mode 100644 src/syng_im/chat/views/content_suggestions.cljs delete mode 100644 src/syng_im/components/chat/content_suggestions.cljs diff --git a/src/syng_im/components/chat/content_suggestions_styles.cljs b/src/syng_im/chat/styles/content_suggestions.cljs similarity index 96% rename from src/syng_im/components/chat/content_suggestions_styles.cljs rename to src/syng_im/chat/styles/content_suggestions.cljs index c0169e8ea3..60c670fada 100644 --- a/src/syng_im/components/chat/content_suggestions_styles.cljs +++ b/src/syng_im/chat/styles/content_suggestions.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.chat.content-suggestions-styles +(ns syng-im.chat.styles.content-suggestions (:require [syng-im.components.styles :refer [font color-light-blue-transparent color-white diff --git a/src/syng_im/chat/views/command.cljs b/src/syng_im/chat/views/command.cljs index 0a2fd24210..688e3d0736 100644 --- a/src/syng_im/chat/views/command.cljs +++ b/src/syng_im/chat/views/command.cljs @@ -5,7 +5,8 @@ text text-input touchable-highlight]] - [syng-im.components.chat.content-suggestions :refer [content-suggestions-view]] + [syng-im.chat.views.content-suggestions :refer + [content-suggestions-view]] [syng-im.chat.styles.input :as st])) (defn cancel-command-input [] diff --git a/src/syng_im/chat/views/content_suggestions.cljs b/src/syng_im/chat/views/content_suggestions.cljs new file mode 100644 index 0000000000..a2e67c8cfc --- /dev/null +++ b/src/syng_im/chat/views/content_suggestions.cljs @@ -0,0 +1,36 @@ +(ns syng-im.chat.views.content-suggestions + (:require-macros [syng-im.utils.views :refer [defview]]) + (:require [re-frame.core :refer [subscribe dispatch]] + [syng-im.components.react :refer [view + icon + text + touchable-highlight + list-view + list-item]] + [syng-im.chat.styles.content-suggestions :as st] + [syng-im.utils.listview :refer [to-datasource]])) + +(defn set-command-content [content] + (dispatch [:set-chat-command-content content])) + +(defn suggestion-list-item [{:keys [value description]}] + [touchable-highlight {:onPress #(set-command-content value)} + [view st/suggestion-container + [view st/suggestion-sub-container + [text {:style st/value-text} value] + [text {:style st/description-text} description]]]]) + +(defn render-row [row _ _] + (list-item [suggestion-list-item row])) + +(defview content-suggestions-view [] + [suggestions [:get-content-suggestions]] + (when (seq suggestions) + [view + [touchable-highlight {:style st/drag-down-touchable + ;; TODO hide suggestions? + :onPress (fn [])} + [view [icon :drag_down st/drag-down-icon]]] + [view (st/suggestions-container (count suggestions)) + [list-view {:dataSource (to-datasource suggestions) + :renderRow render-row}]]])) diff --git a/src/syng_im/components/chat/content_suggestions.cljs b/src/syng_im/components/chat/content_suggestions.cljs deleted file mode 100644 index e79a88bc6f..0000000000 --- a/src/syng_im/components/chat/content_suggestions.cljs +++ /dev/null @@ -1,50 +0,0 @@ -(ns syng-im.components.chat.content-suggestions - (:require-macros - [natal-shell.core :refer [with-error-view]]) - (:require [clojure.string :as cstr] - [reagent.core :as r] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.components.react :refer [view - icon - text - touchable-highlight - list-view - list-item]] - [syng-im.components.chat.content-suggestions-styles :as st] - [syng-im.utils.listview :refer [to-datasource]] - [syng-im.utils.utils :refer [log toast http-post]] - [syng-im.utils.logging :as log])) - -(defn set-command-content [content] - (dispatch [:set-chat-command-content content])) - -(defn suggestion-list-item [suggestion] - [touchable-highlight {:onPress (fn [] - (set-command-content (:value suggestion))) - :underlay-color :transparent} - [view st/suggestion-container - [view st/suggestion-sub-container - [text {:style st/value-text} - (:value suggestion)] - [text {:style st/description-text} - (:description suggestion)]]]]) - -(defn render-row [row section-id row-id] - (list-item [suggestion-list-item (js->clj row :keywordize-keys true)])) - -(defn content-suggestions-view [] - (let [suggestions-atom (subscribe [:get-content-suggestions])] - (fn [] - (let [suggestions @suggestions-atom] - (when (seq suggestions) - [view nil - [touchable-highlight {:style st/drag-down-touchable - :onPress (fn [] - ;; TODO hide suggestions? - ) - :underlay-color :transparent} - [view nil - [icon :drag_down st/drag-down-icon]]] - [view (st/suggestions-container (count suggestions)) - [list-view {:dataSource (to-datasource suggestions) - :renderRow render-row}]]]))))) From d8ae553f89b5881addac8f04a1e0f97126240de5 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 16 May 2016 14:38:07 +0300 Subject: [PATCH 22/26] profiles/drawer structure Former-commit-id: 1977d29b72611eae865aea741ffae56438179fa6 --- src/syng_im/android/core.cljs | 2 +- src/syng_im/chats_list/screen.cljs | 2 +- .../styles.cljs} | 2 +- .../{drawer.cljs => drawer/view.cljs} | 4 +- src/syng_im/components/profile.cljs | 109 ------------------ src/syng_im/contacts/subs.cljs | 2 +- src/syng_im/navigation/handlers.cljs | 9 +- src/syng_im/profile/screen.cljs | 98 ++++++++++++++++ .../styles.cljs} | 2 +- 9 files changed, 110 insertions(+), 120 deletions(-) rename src/syng_im/components/{drawer_styles.cljs => drawer/styles.cljs} (97%) rename src/syng_im/components/{drawer.cljs => drawer/view.cljs} (97%) delete mode 100644 src/syng_im/components/profile.cljs create mode 100644 src/syng_im/profile/screen.cljs rename src/syng_im/{components/profile_styles.cljs => profile/styles.cljs} (98%) diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index 0805f7504b..f1bb1815fb 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -14,7 +14,7 @@ [syng-im.new-group.screen :refer [new-group]] [syng-im.participants.views.create :refer [new-participants]] [syng-im.participants.views.remove :refer [remove-participants]] - [syng-im.components.profile :refer [profile my-profile]] + [syng-im.profile.screen :refer [profile my-profile]] [syng-im.utils.utils :refer [toast]] [syng-im.utils.encryption])) diff --git a/src/syng_im/chats_list/screen.cljs b/src/syng_im/chats_list/screen.cljs index f13e07c24c..55c4457540 100644 --- a/src/syng_im/chats_list/screen.cljs +++ b/src/syng_im/chats_list/screen.cljs @@ -11,7 +11,7 @@ [syng-im.chats-list.views.chat-list-item :refer [chat-list-item]] [syng-im.components.action-button :refer [action-button action-button-item]] - [syng-im.components.drawer :refer [drawer-view open-drawer]] + [syng-im.components.drawer.view :refer [drawer-view open-drawer]] [syng-im.components.styles :refer [color-blue]] [syng-im.components.toolbar :refer [toolbar]] [syng-im.components.icons.ionicons :refer [icon]] diff --git a/src/syng_im/components/drawer_styles.cljs b/src/syng_im/components/drawer/styles.cljs similarity index 97% rename from src/syng_im/components/drawer_styles.cljs rename to src/syng_im/components/drawer/styles.cljs index b6ee3c0808..4e26767b26 100644 --- a/src/syng_im/components/drawer_styles.cljs +++ b/src/syng_im/components/drawer/styles.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.drawer-styles +(ns syng-im.components.drawer.styles (:require [syng-im.components.styles :refer [font color-light-blue-transparent color-white diff --git a/src/syng_im/components/drawer.cljs b/src/syng_im/components/drawer/view.cljs similarity index 97% rename from src/syng_im/components/drawer.cljs rename to src/syng_im/components/drawer/view.cljs index 74d38d8f4e..3c96ce3395 100644 --- a/src/syng_im/components/drawer.cljs +++ b/src/syng_im/components/drawer/view.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.drawer +(ns syng-im.components.drawer.view (:require [clojure.string :as s] [re-frame.core :refer [subscribe dispatch dispatch-sync]] [reagent.core :as r] @@ -11,7 +11,7 @@ drawer-layout-android touchable-opacity]] [syng-im.resources :as res] - [syng-im.components.drawer-styles :as st])) + [syng-im.components.drawer.styles :as st])) (defonce drawer-atom (atom)) diff --git a/src/syng_im/components/profile.cljs b/src/syng_im/components/profile.cljs deleted file mode 100644 index bec17f16fe..0000000000 --- a/src/syng_im/components/profile.cljs +++ /dev/null @@ -1,109 +0,0 @@ -(ns syng-im.components.profile - (:require [clojure.string :as s] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.components.react :refer [android? - view - text - text-input - image - icon - scroll-view - touchable-highlight - touchable-opacity]] - [syng-im.resources :as res] - [syng-im.components.profile-styles :as st])) - -(defn user-photo [{:keys [photo-path]}] - [image {:source (if (s/blank? photo-path) - res/user-no-photo - {:uri photo-path}) - :style st/user-photo}]) - -(defn user-online [{:keys [online]}] - (when online - [view st/user-online-container - [view st/user-online-dot-left] - [view st/user-online-dot-right]])) - -(defn profile-property-view [{:keys [name value]}] - [view st/profile-property-view-container - [view st/profile-property-view-sub-container - [text {:style st/profile-property-view-label} - name] - [text {:style st/profile-property-view-value} - value]]]) - -(defn message-user [identity] - (when identity - (dispatch [:show-chat identity nil :push]))) - -(defn profile [] - (let [contact (subscribe [:contact])] - (fn [] - [scroll-view {:style st/profile} - [touchable-highlight {:style st/back-btn-touchable - :on-press #(dispatch [:navigate-back])} - [view st/back-btn-container - [icon :back st/back-btn-icon]]] - [view st/status-block - [view st/user-photo-container - [user-photo {}] - [user-online {:online true}]] - [text {:style st/user-name} - (:name @contact)] - [text {:style st/status} - "!not implemented"] - [view st/btns-container - [touchable-highlight {:onPress #(message-user (:whisper-identity @contact))} - [view st/message-btn - [text {:style st/message-btn-text} - "Message"]]] - [touchable-highlight {:onPress (fn [] - ;; TODO not implemented - )} - [view st/more-btn - [icon :more_vertical_blue st/more-btn-image]]]]] - [view st/profile-properties-container - [profile-property-view {:name "Username" - :value (:name @contact)}] - [profile-property-view {:name "Phone number" - :value (:phone-number @contact)}] - [profile-property-view {:name "Email" - :value "!not implemented"}] - [view st/report-user-container - [touchable-opacity {} - [text {:style st/report-user-text} - "REPORT USER"]]]]]))) - -(defn my-profile [] - (let [username (subscribe [:get :username]) - phone-number (subscribe [:get :phone-number]) - email (subscribe [:get :email]) - status (subscribe [:get :status])] - (fn [] - [scroll-view {:style st/profile} - [touchable-highlight {:style st/back-btn-touchable - :on-press #(dispatch [:navigate-back])} - [view st/back-btn-container - [icon :back st/back-btn-icon]]] - [touchable-highlight {:style st/actions-btn-touchable - :on-press (fn [] - ;; TODO not implemented - )} - [view st/actions-btn-container - [icon :dots st/actions-btn-icon]]] - [view st/status-block - [view st/user-photo-container - [user-photo {}] - [user-online {:online true}]] - [text {:style st/user-name} - @username] - [text {:style st/status} - @status]] - [view st/profile-properties-container - [profile-property-view {:name "Username" - :value @username}] - [profile-property-view {:name "Phone number" - :value @phone-number}] - [profile-property-view {:name "Email" - :value @email}]]]))) diff --git a/src/syng_im/contacts/subs.cljs b/src/syng_im/contacts/subs.cljs index 848b85f7d7..d889f12b60 100644 --- a/src/syng_im/contacts/subs.cljs +++ b/src/syng_im/contacts/subs.cljs @@ -28,7 +28,7 @@ (register-sub :contact (fn [db _] (let [identity (:contact-identity @db)] - (reaction (get-in db [:contacts identity]))))) + (reaction (get-in @db [:contacts identity]))))) (register-sub :all-new-contacts (fn [db _] diff --git a/src/syng_im/navigation/handlers.cljs b/src/syng_im/navigation/handlers.cljs index 404059cf2e..217bd88136 100644 --- a/src/syng_im/navigation/handlers.cljs +++ b/src/syng_im/navigation/handlers.cljs @@ -72,10 +72,11 @@ clear-new-participants))) (register-handler :show-profile - (fn [db [_ identity]] - (let [db (assoc db :contact-identity identity)] - (dispatch [:navigate-to :profile]) - db))) + (debug + (fn [db [_ identity]] + (let [db (assoc db :contact-identity identity)] + (dispatch [:navigate-to :profile]) + db)))) (register-handler :show-my-profile (fn [db _] diff --git a/src/syng_im/profile/screen.cljs b/src/syng_im/profile/screen.cljs new file mode 100644 index 0000000000..9d075c4999 --- /dev/null +++ b/src/syng_im/profile/screen.cljs @@ -0,0 +1,98 @@ +(ns syng-im.profile.screen + (:require-macros [syng-im.utils.views :refer [defview]]) + (:require [clojure.string :as s] + [re-frame.core :refer [subscribe dispatch]] + [syng-im.components.react :refer [view + text + image + icon + scroll-view + touchable-highlight + touchable-opacity]] + [syng-im.resources :as res] + [syng-im.profile.styles :as st])) + +(defn user-photo [{:keys [photo-path]}] + [image {:source (if (s/blank? photo-path) + res/user-no-photo + {:uri photo-path}) + :style st/user-photo}]) + +(defn user-online [{:keys [online]}] + (when online + [view st/user-online-container + [view st/user-online-dot-left] + [view st/user-online-dot-right]])) + +(defn profile-property-view [{:keys [name value]}] + [view st/profile-property-view-container + [view st/profile-property-view-sub-container + [text {:style st/profile-property-view-label} name] + [text {:style st/profile-property-view-value} value]]]) + +(defn message-user [identity] + (when identity + (dispatch [:show-chat identity :push]))) + +(defview profile [] + [{:keys [name whisper-identity phone-number]} [:contact]] + [scroll-view {:style st/profile} + [touchable-highlight {:style st/back-btn-touchable + :on-press #(dispatch [:navigate-back])} + [view st/back-btn-container + [icon :back st/back-btn-icon]]] + [view st/status-block + [view st/user-photo-container + [user-photo {}] + [user-online {:online true}]] + [text {:style st/user-name} name] + [text {:style st/status} "!not implemented"] + [view st/btns-container + [touchable-highlight {:onPress #(message-user whisper-identity)} + [view st/message-btn + [text {:style st/message-btn-text} "Message"]]] + [touchable-highlight {:onPress (fn [] + ;; TODO not implemented + )} + [view st/more-btn + [icon :more_vertical_blue st/more-btn-image]]]]] + [view st/profile-properties-container + [profile-property-view {:name "Username" + :value name}] + [profile-property-view {:name "Phone number" + :value phone-number}] + [profile-property-view {:name "Email" + :value "!not implemented"}] + [view st/report-user-container + [touchable-opacity {} + [text {:style st/report-user-text} "REPORT USER"]]]]]) + +(defview my-profile [] + [username [:get :username] + phone-number [:get :phone-number] + email [:get :email] + status [:get :status]] + [scroll-view {:style st/profile} + [touchable-highlight {:style st/back-btn-touchable + :on-press #(dispatch [:navigate-back])} + [view st/back-btn-container + [icon :back st/back-btn-icon]]] + [touchable-highlight {:style st/actions-btn-touchable + :on-press (fn [] + ;; TODO not implemented + )} + [view st/actions-btn-container + [icon :dots st/actions-btn-icon]]] + [view st/status-block + [view st/user-photo-container + [user-photo {}] + [user-online {:online true}]] + [text {:style st/user-name} username] + [text {:style st/status} status]] + [view st/profile-properties-container + [profile-property-view {:name "Username" + :value username}] + [profile-property-view {:name "Phone number" + :value phone-number}] + [profile-property-view {:name "Email" + :value email}]]]) diff --git a/src/syng_im/components/profile_styles.cljs b/src/syng_im/profile/styles.cljs similarity index 98% rename from src/syng_im/components/profile_styles.cljs rename to src/syng_im/profile/styles.cljs index 347b89c282..545016ca4d 100644 --- a/src/syng_im/components/profile_styles.cljs +++ b/src/syng_im/profile/styles.cljs @@ -1,4 +1,4 @@ -(ns syng-im.components.profile-styles +(ns syng-im.profile.styles (:require [syng-im.components.styles :refer [font color-light-blue-transparent color-white From 60b2dc9c6373dd032a287e5dc81f2289fd0d7db3 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 16 May 2016 15:38:27 +0300 Subject: [PATCH 23/26] empty sections Former-commit-id: 739ca7cb1babd1b818bcd81e1867ce9d8ddae048 --- src/syng_im/components/react.cljs | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/syng_im/components/react.cljs b/src/syng_im/components/react.cljs index 86ae7657e7..e19ffe11fe 100644 --- a/src/syng_im/components/react.cljs +++ b/src/syng_im/components/react.cljs @@ -15,7 +15,9 @@ (merge {:underlay-color :transparent} props) content]) (def toolbar-android (r/adapt-react-class (.-ToolbarAndroid js/React))) -(def list-view (r/adapt-react-class (.-ListView js/React))) +(def list-view-class (r/adapt-react-class (.-ListView js/React))) +(defn list-view [props] + [list-view-class (merge {:enableEmptySections true} props)]) (def scroll-view (r/adapt-react-class (.-ScrollView js/React))) (def touchable-without-feedback (r/adapt-react-class (.-TouchableWithoutFeedback js/React))) (def text-input-class (r/adapt-react-class (.-TextInput js/React))) From 5c2bc27feba9a7a4390d81892f602b776430a626 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 16 May 2016 15:50:06 +0300 Subject: [PATCH 24/26] discoveries toolbar Former-commit-id: 5f0862e3b79cd2aa2215c2d185f1eb7f93f8d9de --- src/syng_im/discovery/screen.cljs | 38 +++++++++++++++---------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/src/syng_im/discovery/screen.cljs b/src/syng_im/discovery/screen.cljs index 3f3a2fdf8b..8f51f391ac 100644 --- a/src/syng_im/discovery/screen.cljs +++ b/src/syng_im/discovery/screen.cljs @@ -16,16 +16,17 @@ (or hashtags []))) (defn title-content [show-search] - (if show-search - [text-input {:style st/discovery-search-input - :autoFocus true - :placeholder "Type your search tags here" - :onSubmitEditing (fn [e] - (let [search (aget e "nativeEvent" "text") - hashtags (get-hashtags search)] - (dispatch [:broadcast-status search hashtags])))}] - [view - [text {:style st/discovery-title} "Discover"]])) + [view st/discovery-toolbar-content + (if show-search + [text-input {:style st/discovery-search-input + :autoFocus true + :placeholder "Type your search tags here" + :onSubmitEditing (fn [e] + (let [search (aget e "nativeEvent" "text") + hashtags (get-hashtags search)] + (dispatch [:broadcast-status search hashtags])))}] + [view + [text {:style st/discovery-title} "Discover"]])]) (defn toogle-search [current-value] (dispatch [:set ::show-search (not current-value)])) @@ -34,15 +35,14 @@ [show-search [:get ::show-search]] [view st/discovery-container [toolbar - {:style st/discovery-toolbar - :nav-action {:image {:source {:uri :icon_hamburger} - :style st/hamburger-icon} - :handler #(dispatch [:create-fake-discovery!])} - :title "Add Participants" - :content [title-content show-search] - :action {:image {:source {:uri :icon_search} - :style st/search-icon} - :handler #(toogle-search show-search)}}] + {:style st/discovery-toolbar + :nav-action {:image {:source {:uri :icon_hamburger} + :style st/hamburger-icon} + :handler #(dispatch [:create-fake-discovery!])} + :custom-content [title-content show-search] + :action {:image {:source {:uri :icon_search} + :style st/search-icon} + :handler #(toogle-search show-search)}}] [scroll-view {:style {}} [view st/section-spacing [text {:style st/discovery-subtitle} "Popular tags"]] From 21f96ae2fb80486e588f25685d9e2f8457951aba Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Mon, 16 May 2016 16:04:07 +0300 Subject: [PATCH 25/26] fix giant 'type' Former-commit-id: c2b4a1ec33ff93390338463ccf930f5d8513e0b4 --- src/syng_im/chat/styles/input.cljs | 7 ------- src/syng_im/chat/views/money.cljs | 6 ++---- 2 files changed, 2 insertions(+), 11 deletions(-) diff --git a/src/syng_im/chat/styles/input.cljs b/src/syng_im/chat/styles/input.cljs index 3bebde177f..dcbc893f86 100644 --- a/src/syng_im/chat/styles/input.cljs +++ b/src/syng_im/chat/styles/input.cljs @@ -6,13 +6,6 @@ text2-color chat-background color-black]])) -(def money-input - {:flex 1 - :marginLeft 8 - :lineHeight 42 - :fontSize 32 - :fontFamily font - :color :black}) (def command-input-and-suggestions-container {:flexDirection :column}) diff --git a/src/syng_im/chat/views/money.cljs b/src/syng_im/chat/views/money.cljs index 7166476cf0..4706009bfd 100644 --- a/src/syng_im/chat/views/money.cljs +++ b/src/syng_im/chat/views/money.cljs @@ -1,9 +1,7 @@ (ns syng-im.chat.views.money (:require - [syng-im.chat.views.command :refer [simple-command-input-view]] - [syng-im.chat.styles.input :as st])) + [syng-im.chat.views.command :refer [simple-command-input-view]])) (defn money-input-view [command] [simple-command-input-view command - {:keyboardType :numeric - :style st/money-input}]) + {:keyboardType :numeric}]) From f7bb98895490e6c21de763938cbe2317ffab78e6 Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Tue, 17 May 2016 13:32:20 +0300 Subject: [PATCH 26/26] more cleanup in handlers/subs Former-commit-id: 4752643ed7279fd54418af4e790bf18bdef35f4b --- src/syng_im/android/core.cljs | 6 +-- src/syng_im/chat/handlers.cljs | 41 +++++++++------------ src/syng_im/{handlers => chat}/sign_up.cljs | 3 +- src/syng_im/components/drawer/view.cljs | 9 ++--- src/syng_im/handlers.cljs | 1 - src/syng_im/models/messages.cljs | 39 ++++++++++---------- src/syng_im/navigation/handlers.cljs | 19 ++++------ src/syng_im/navigation/subs.cljs | 11 ------ src/syng_im/subs.cljs | 17 --------- 9 files changed, 53 insertions(+), 93 deletions(-) rename src/syng_im/{handlers => chat}/sign_up.cljs (99%) delete mode 100644 src/syng_im/navigation/subs.cljs diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index f1bb1815fb..125b49b6df 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -23,15 +23,15 @@ ;; todo: it might be better always return false from ;; this listener and handle application's closing ;; in handlers - (let [stack (subscribe [:navigation-stack])] + (let [stack (subscribe [:get :navigation-stack])] (when (< 1 (count @stack)) (dispatch [:navigate-back]) true)))] (add-event-listener "hardwareBackPress" new-listener))) (defn app-root [] - (let [signed-up (subscribe [:signed-up]) - view-id (subscribe [:view-id])] + (let [signed-up (subscribe [:get :signed-up]) + view-id (subscribe [:get :view-id])] (fn [] (case (if @signed-up @view-id :chat) :discovery [discovery] diff --git a/src/syng_im/chat/handlers.cljs b/src/syng_im/chat/handlers.cljs index b8c65037fb..82f37ececf 100644 --- a/src/syng_im/chat/handlers.cljs +++ b/src/syng_im/chat/handlers.cljs @@ -9,10 +9,11 @@ content-type-command]] [syng-im.utils.random :as random] [syng-im.components.react :as r] - [syng-im.handlers.sign-up :as sign-up-service] + [syng-im.chat.sign-up :as sign-up-service] [syng-im.models.chats :as chats] [syng-im.navigation.handlers :as nav] - [syng-im.models.chats :as c])) + [syng-im.models.chats :as c] + [syng-im.utils.handlers :as u])) (register-handler :set-show-actions (fn [db [_ show-actions]] @@ -71,17 +72,18 @@ ((enrich update-command) update-text)) (register-handler :send-group-chat-msg - (fn [db [_ chat-id text]] - (let [{msg-id :msg-id - {from :from} :msg} (api/send-group-user-msg {:group-id chat-id - :content text}) - msg {:msg-id msg-id - :from from - :to nil - :content text - :content-type text-content-type - :outgoing true}] - (messages/save-message chat-id msg)))) + (u/side-effect! + (fn [_ [_ chat-id text]] + (let [{msg-id :msg-id + {from :from} :msg} (api/send-group-user-msg {:group-id chat-id + :content text}) + msg {:msg-id msg-id + :from from + :to nil + :content text + :content-type text-content-type + :outgoing true}] + (messages/save-message chat-id msg))))) (defn console? [s] (= "console" s)) @@ -236,7 +238,6 @@ (fn [db [_ signed-up]] (sign-up-service/set-signed-up db signed-up))) - (defn load-messages! ([db] (load-messages! db nil)) ([db _] @@ -289,15 +290,9 @@ ((after store-message!)))) (register-handler :group-received-msg - (fn [db [_ {chat-id :group-id :as msg}]] - (messages/save-message chat-id msg) - db)) - -(defn load-chat! - [{:keys [chats current-chat-id] :as db}] - (when-not (chats current-chat-id) - (c/create-chat {})) - db) + (u/side-effect! + (fn [_ [_ {chat-id :group-id :as msg}]] + (messages/save-message chat-id msg)))) (defmethod nav/preload-data! :chat [{:keys [current-chat-id] :as db} [_ _ id]] diff --git a/src/syng_im/handlers/sign_up.cljs b/src/syng_im/chat/sign_up.cljs similarity index 99% rename from src/syng_im/handlers/sign_up.cljs rename to src/syng_im/chat/sign_up.cljs index dfbd1fa945..8cef60aac0 100644 --- a/src/syng_im/handlers/sign_up.cljs +++ b/src/syng_im/chat/sign_up.cljs @@ -1,4 +1,5 @@ -(ns syng-im.handlers.sign-up +(ns syng-im.chat.sign-up + ;syng-im.handlers.sign-up (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]] [syng-im.persistence.simple-kv-store :as kv] [syng-im.protocol.state.storage :as s] diff --git a/src/syng_im/components/drawer/view.cljs b/src/syng_im/components/drawer/view.cljs index 3c96ce3395..6edf297ac2 100644 --- a/src/syng_im/components/drawer/view.cljs +++ b/src/syng_im/components/drawer/view.cljs @@ -46,18 +46,15 @@ @username]] [view st/menu-items-container [menu-item {:name "Profile" - :handler (fn [] - (dispatch [:show-my-profile]))}] + :handler #(dispatch [:navigate-to :my-profile])}] [menu-item {:name "Settings" :handler (fn [] ;; TODO not implemented )}] [menu-item {:name "Discovery" - :handler (fn [] - (dispatch [:navigate-to :discovery]))}] + :handler #(dispatch [:navigate-to :discovery])}] [menu-item {:name "Contacts" - :handler (fn [] - (dispatch [:show-contacts navigator]))}] + :handler #(dispatch [:show-contacts navigator])}] [menu-item {:name "Invite friends" :handler (fn [] ;; TODO not implemented diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index a5b2371adf..2b90f5991e 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -15,7 +15,6 @@ [syng-im.models.commands :refer [set-commands]] [syng-im.handlers.server :as server] [syng-im.chat.suggestions :refer [load-commands]] - [syng-im.handlers.sign-up :as sign-up-service] [syng-im.models.chats :refer [chat-exists? create-chat chat-add-participants diff --git a/src/syng_im/models/messages.cljs b/src/syng_im/models/messages.cljs index b4c6d3b834..e650e85127 100644 --- a/src/syng_im/models/messages.cljs +++ b/src/syng_im/models/messages.cljs @@ -17,28 +17,28 @@ (keywordize-keys (apply hash-map (split s #"[;=]")))) (defn save-message - [chat-id {:keys [from to msg-id content content-type outgoing - same-author same-direction] + ;; todo remove chat-id parameter + [chat-id {:keys [to msg-id content outgoing] + ;; outgoing should be explicitely defined in handlers :or {outgoing false - to nil} :as msg}] - (log/debug "save-message" chat-id msg) + to nil} :as message}] (when-not (r/exists? :msgs :msg-id msg-id) (r/write (fn [] - (let [content (if (string? content) - content - (map-to-str content))] - (r/create :msgs {:chat-id chat-id - :msg-id msg-id - :from from - :to to - :content content - :content-type content-type - :outgoing outgoing - :timestamp (timestamp) - :delivery-status nil - :same-author same-author - :same-direction same-direction} true)))))) + (let [content' (if (string? content) + content + (map-to-str content)) + message' (merge message + {:chat-id chat-id + :content content' + :timestamp (timestamp) + :delivery-status nil})] + (r/create :msgs message' true)))))) + +(defn command-type? [type] + (contains? + #{c/content-type-command c/content-type-command-request} + type)) (defn get-messages [chat-id] (->> (-> (r/get-by-field :msgs :chat-id chat-id) @@ -46,8 +46,7 @@ (r/collection->map)) (into '()) (map (fn [{:keys [content-type] :as message}] - (if (#{c/content-type-command c/content-type-command-request} - content-type) + (if (command-type? content-type) (update message :content str-to-map) message))))) diff --git a/src/syng_im/navigation/handlers.cljs b/src/syng_im/navigation/handlers.cljs index 217bd88136..98671d3e77 100644 --- a/src/syng_im/navigation/handlers.cljs +++ b/src/syng_im/navigation/handlers.cljs @@ -1,5 +1,6 @@ (ns syng-im.navigation.handlers - (:require [re-frame.core :refer [register-handler dispatch debug enrich]])) + (:require [re-frame.core :refer [register-handler dispatch debug enrich + after]])) (defn push-view [db view-id] (-> db @@ -71,14 +72,10 @@ (push-view :add-participants) clear-new-participants))) -(register-handler :show-profile - (debug - (fn [db [_ identity]] - (let [db (assoc db :contact-identity identity)] - (dispatch [:navigate-to :profile]) - db)))) +(defn show-profile + [db [_ identity]] + (-> db + (assoc :contact-identity identity) + (push-view :profile))) -(register-handler :show-my-profile - (fn [db _] - (dispatch [:navigate-to :my-profile]) - db)) +(register-handler :show-profile show-profile) diff --git a/src/syng_im/navigation/subs.cljs b/src/syng_im/navigation/subs.cljs deleted file mode 100644 index d7b2dc4a0a..0000000000 --- a/src/syng_im/navigation/subs.cljs +++ /dev/null @@ -1,11 +0,0 @@ -(ns syng-im.navigation.subs - (:require-macros [reagent.ratom :refer [reaction]]) - (:require [re-frame.core :refer [register-sub]])) - -(register-sub :view-id - (fn [db _] - (reaction (@db :view-id)))) - -(register-sub :navigation-stack - (fn [db _] - (reaction (:navigation-stack @db)))) diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index 117d670427..5479e808ae 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -1,27 +1,10 @@ (ns syng-im.subs (:require-macros [reagent.ratom :refer [reaction]]) (:require [re-frame.core :refer [register-sub]] - [syng-im.models.chats :refer [chats-list chat-by-id]] - [syng-im.models.contacts :refer [get-contacts - contacts-list-exclude - contacts-list-include - contact-by-identity]] syng-im.chat.subs - syng-im.navigation.subs syng-im.discovery.subs syng-im.contacts.subs)) -;; -- Chats list -------------------------------------------------------------- - (register-sub :get (fn [db [_ k]] (reaction (k @db)))) - -;; -- User data -------------------------------------------------------------- -(register-sub - :signed-up - (fn [db _] - (reaction (:signed-up @db)))) - -(register-sub :db - (fn [db _] (reaction @db)))