From ae1918a2aed109400cda0e376fec6d37cdb5d79f Mon Sep 17 00:00:00 2001 From: Roman Volosovskyi Date: Fri, 20 May 2016 19:12:04 +0300 Subject: [PATCH] chat name/load messages on [:navigate-to :chat id]/ other --- .../main/res/drawable-hdpi/icon_ok_purple.png | Bin 0 -> 644 bytes .../main/res/drawable-mdpi/icon_ok_purple.png | Bin 0 -> 504 bytes .../res/drawable-xhdpi/icon_ok_purple.png | Bin 0 -> 931 bytes .../res/drawable-xxhdpi/icon_ok_purple.png | Bin 0 -> 1520 bytes .../res/drawable-xxxhdpi/icon_ok_purple.png | Bin 0 -> 2055 bytes src/syng_im/android/core.cljs | 4 +- src/syng_im/chat/handlers.cljs | 14 ++- .../chats_list/views/chat_list_item.cljs | 2 +- src/syng_im/components/react.cljs | 8 +- src/syng_im/group_settings/handlers.cljs | 95 ++++++++---------- src/syng_im/group_settings/screen.cljs | 93 ++++++++++------- .../group_settings/styles/chat_name_edit.cljs | 19 ---- .../group_settings/styles/group_settings.cljs | 46 ++++----- src/syng_im/group_settings/subs.cljs | 11 +- .../group_settings/views/chat_name_edit.cljs | 31 ------ src/syng_im/group_settings/views/member.cljs | 2 +- src/syng_im/handlers.cljs | 8 +- src/syng_im/navigation/handlers.cljs | 8 +- src/syng_im/new_group/handlers.cljs | 2 +- src/syng_im/new_group/subs.cljs | 8 +- src/syng_im/participants/subs.cljs | 3 + .../views/{create.cljs => add.cljs} | 19 ++-- src/syng_im/participants/views/remove.cljs | 17 ++-- src/syng_im/profile/screen.cljs | 2 +- src/syng_im/subs.cljs | 4 + src/syng_im/utils/subs.cljs | 10 ++ 26 files changed, 190 insertions(+), 216 deletions(-) create mode 100644 android/app/src/main/res/drawable-hdpi/icon_ok_purple.png create mode 100644 android/app/src/main/res/drawable-mdpi/icon_ok_purple.png create mode 100644 android/app/src/main/res/drawable-xhdpi/icon_ok_purple.png create mode 100644 android/app/src/main/res/drawable-xxhdpi/icon_ok_purple.png create mode 100644 android/app/src/main/res/drawable-xxxhdpi/icon_ok_purple.png delete mode 100644 src/syng_im/group_settings/styles/chat_name_edit.cljs delete mode 100644 src/syng_im/group_settings/views/chat_name_edit.cljs create mode 100644 src/syng_im/participants/subs.cljs rename src/syng_im/participants/views/{create.cljs => add.cljs} (66%) create mode 100644 src/syng_im/utils/subs.cljs diff --git a/android/app/src/main/res/drawable-hdpi/icon_ok_purple.png b/android/app/src/main/res/drawable-hdpi/icon_ok_purple.png new file mode 100644 index 0000000000000000000000000000000000000000..b28a5ca6d021ccc79a439897407957341a607a51 GIT binary patch literal 644 zcmV-~0(Px%K1oDDR7efAl+RBSQ4q)9ESQude*he+mtC&}ymBNVrWY!vP$VQY2niv^AU8R& zYm71e02(Z{TOe4YjVF&ilW^_Z3)RHGqCwc_cecE`4aGuj-(jb3_RaURGxIt^ba~|+ z8Bi0H5{Y9_|V>0JA?Z96jt zxsKctN~E+HdUOzpn#p+lGKkLvJwu@3Zpf8V_Gd%~{>w5b?|A7j2)Ax861A=bu^tr) zs;63!IVD5_0pC%A7{2WED%b^R2X;=MLFwG-RdW{B*S==fIIVd10}#JeYOMOh`&25a zrsWMP;K)oPNPN5wh~MIG$~FPx$vPnciR45gtlF2UvaTLej`?XUl5<77u#J(il)pBwY2SO|tHzLGR;ou~+8br9b znIh4PKR{*9E+Up0y9lv6S)0!E`HiGh(?nWx`Tgd-@B8Gv@9zQp<8w`%#)&q$M@L|! zoVDrm_-D`iIuVs4W5W@Fmd7s=RCrwnpfcXdsR2zE7H&tbsmnwSU)?%{cX47i87o?> z*;iq8v^b|E!Hdrg1f>XgBrsOlWX-(}%cB*?VX~^KZXzf_#6ygN%GTce8~;RKqe&7O z{ee)Y4)J=m4IRSs2hq%I354i1%sDNmUv4T}i*~s&6vQ=qoT7R)iF;Cv2#R1fTN(y4 zZiBUqJW$V{un09;a@yp&K!G@UlKTGUl?bR15ck0lWohooybIL$@2qVof1VpRMgT_g z(W+>dYxU&H%vl`Af0000|00001b5ch_0Itp) z=>Px&T}ebiR7efQmQ73(K@`W|n?(gKM$dZTptM{(crh9cYBWUS7eT^D7Zi*!8e8fozW3` z^`O6HRe%!4*gl)X^EAvXDbuv7f-hMtoZQa^4!dCxSX-dI{B=Qr5>e{_fecf=l*|TY zra-{UdWWw|HVU?6X2d#3AWs2Au@iAQLr=i_H;nZcFu7gGnD3>`SGSt;byQ$x8pKCh}Bppm+tdnx-iqjbpzJsRi)~}XN zDxIzaoeQ8uoqKxHKq<0q2!tvIl-*Lw^e&Umda$C6)<5HZ5dt>R@&ER5*VoO`#td7{ zUNF>Ezg!qOeny0(Ad{Qky4}DT+VY{E*UvLTYKF>6Ocj^;PEw>sltzCrEi_iW5-@U(1tX*& zMtdiVr+)o?DFAmOgA;nY|CQ=nwQ~60k5V)8dDlt<{0B+LLJ72M>kR+^002ovPDHLk FV1m&BuO$Eg literal 0 HcmV?d00001 diff --git a/android/app/src/main/res/drawable-xxhdpi/icon_ok_purple.png b/android/app/src/main/res/drawable-xxhdpi/icon_ok_purple.png new file mode 100644 index 0000000000000000000000000000000000000000..b2942242644f2d7dd118965e582153e77c3e271f GIT binary patch literal 1520 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 literal 0 HcmV?d00001 diff --git a/src/syng_im/android/core.cljs b/src/syng_im/android/core.cljs index a7c6315b1e..3ab9a35ad5 100644 --- a/src/syng_im/android/core.cljs +++ b/src/syng_im/android/core.cljs @@ -12,10 +12,9 @@ [syng-im.chat.screen :refer [chat]] [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.add :refer [new-participants]] [syng-im.participants.views.remove :refer [remove-participants]] [syng-im.group-settings.screen :refer [group-settings]] - [syng-im.group-settings.views.chat-name-edit :refer [chat-name-edit]] [syng-im.profile.screen :refer [profile my-profile]] [syng-im.utils.utils :refer [toast]] [syng-im.utils.encryption])) @@ -43,7 +42,6 @@ :chat-list [chats-list] :new-group [new-group] :group-settings [group-settings] - :chat-name-edit [chat-name-edit] :contact-list [contact-list] :chat [chat] :profile [profile] diff --git a/src/syng_im/chat/handlers.cljs b/src/syng_im/chat/handlers.cljs index 67acc9a6fa..73f2a2ece6 100644 --- a/src/syng_im/chat/handlers.cljs +++ b/src/syng_im/chat/handlers.cljs @@ -187,7 +187,8 @@ ((enrich add-commands)) ((enrich clear-input)) ((enrich clear-staged-commands)) - ((after send-message!)) + ;; todo uncomment once + ;((after send-message!)) ((after save-message-to-realm!)) ((after save-commands-to-realm!)) ((after handle-commands)))) @@ -283,10 +284,13 @@ (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)) + (let [messages (get-in db [:chats current-chat-id :messages])] + (if (seq messages) + (-> db + (assoc :current-chat-id (or id current-chat-id)) + load-messages! + init-chat) + db))) (defn prepare-chat [{:keys [contacts] :as db} [_ contcat-id]] 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 3673701ccc..ddc6c87b9b 100644 --- a/src/syng_im/chats_list/views/chat_list_item.cljs +++ b/src/syng_im/chats_list/views/chat_list_item.cljs @@ -10,7 +10,7 @@ (defn chat-list-item [{:keys [chat-id] :as chat}] [touchable-highlight - {:on-press #(dispatch [:show-chat chat-id :push])} + {:on-press #(dispatch [:navigate-to :chat chat-id])} ;; TODO add [photo-path delivery-status new-messages-count online] values to chat-obj [view [chat-list-item-inner-view (merge chat {:photo-path nil diff --git a/src/syng_im/components/react.cljs b/src/syng_im/components/react.cljs index 58c99aa6e4..e3f1289e00 100644 --- a/src/syng_im/components/react.cljs +++ b/src/syng_im/components/react.cljs @@ -35,9 +35,11 @@ (def picker-item (r/adapt-react-class (.-Item (.-Picker js/React)))) -(defn icon [n style] - [image {:source {:uri (keyword (str "icon_" (name n)))} - :style style}]) +(defn icon + ([n] (icon n {})) + ([n style] + [image {:source {:uri (keyword (str "icon_" (name n)))} + :style style}])) (def platform (.. js/React -Platform -OS)) diff --git a/src/syng_im/group_settings/handlers.cljs b/src/syng_im/group_settings/handlers.cljs index 0871624cb1..58dbda4067 100644 --- a/src/syng_im/group_settings/handlers.cljs +++ b/src/syng_im/group_settings/handlers.cljs @@ -1,72 +1,59 @@ (ns syng-im.group-settings.handlers - (:require [re-frame.core :refer [register-handler debug dispatch]] + (:require [re-frame.core :refer [register-handler debug dispatch after]] [syng-im.persistence.realm :as r] - [syng-im.models.messages :refer [clear-history]])) + [syng-im.models.messages :refer [clear-history]] + [clojure.string :as s])) -(defn set-chat-name [db] - (let [chat-id (:current-chat-id db) - name (:new-chat-name db)] - (r/write (fn [] - (-> (r/get-by-field :chats :chat-id chat-id) - (r/single) - (aset "name" name)))) - (assoc-in db [:chats chat-id :name] name))) +(defn save-chat-property! + [db-name property-name] + (fn [{:keys [current-chat-id] :as db} _] + (let [property (db-name db)] + (r/write (fn [] + (-> (r/get-by-field :chats :chat-id current-chat-id) + (r/single) + (aset (name property-name) property))))))) -(defn set-chat-color [db] - (let [chat-id (:current-chat-id db) - color (:new-chat-color db)] - (r/write (fn [] - (-> (r/get-by-field :chats :chat-id chat-id) - (r/single) - (aset "color" color)))) - (assoc-in db [:chats chat-id :color] color))) +(defn update-chat-property + [db-name property-name] + (fn [{:keys [current-chat-id] :as db} _] + (let [property (db-name db)] + (assoc-in db [:chats current-chat-id property-name] property)))) (defn delete-chat [chat-id] (r/write - (fn [] - (-> (r/get-by-field :chats :chat-id chat-id) - (r/single) - (r/delete)))) + (fn [] + (-> (r/get-by-field :chats :chat-id chat-id) + (r/single) + (r/delete)))) ;; TODO temp. Update chat in db atom (dispatch [:initialize-chats])) +(defn prepare-chat-settings + [{:keys [current-chat-id] :as db} _] + (let [{:keys [name color]} (-> db + (get-in [:chats current-chat-id]) + (select-keys [:name :color]))] + (-> db + (assoc :new-chat-name name + :new-chat-color color + :group-settings {})))) + (register-handler :show-group-settings - (fn [db _] - (let [chat-id (:current-chat-id db) - chat-name (get-in db [:chats chat-id :name]) - chat-color (get-in db [:chats chat-id :color]) - db (assoc db - :new-chat-name chat-name - :new-chat-color chat-color - :group-settings-show-color-picker false - :group-settings-selected-member nil)] - (dispatch [:navigate-to :group-settings]) - db))) + (after (fn [_ _] (dispatch [:navigate-to :group-settings]))) + prepare-chat-settings) (register-handler :set-chat-name - (fn [db [action]] - (set-chat-name db))) + (after (save-chat-property! :new-chat-name :name)) + (update-chat-property :new-chat-name :name)) (register-handler :set-chat-color - (fn [db [action]] - (set-chat-color db))) - -(register-handler :set-new-chat-name - (fn [db [action name]] - (assoc db :new-chat-name name))) - -(register-handler :set-new-chat-color - (fn [db [action color]] - (assoc db :new-chat-color color))) - -(register-handler :select-group-chat-member - (fn [db [action identity]] - (assoc db :group-settings-selected-member identity))) - -(register-handler :set-group-settings-show-color-picker - (fn [db [action show?]] - (assoc db :group-settings-show-color-picker show?))) + (after (save-chat-property! :new-chat-color :color)) + (update-chat-property :new-chat-color :color)) (register-handler :clear-history - (fn [db [action]] + (fn [db _] (clear-history (:current-chat-id db)))) + +(register-handler :group-settings + (fn [db [_ k v]] + (assoc-in db [:group-settings k] v))) diff --git a/src/syng_im/group_settings/screen.cljs b/src/syng_im/group_settings/screen.cljs index 7e06fd98af..c74c74c020 100644 --- a/src/syng_im/group_settings/screen.cljs +++ b/src/syng_im/group_settings/screen.cljs @@ -13,13 +13,14 @@ touchable-highlight]] [syng-im.components.toolbar :refer [toolbar]] [syng-im.group-settings.styles.group-settings :as st] - [syng-im.group-settings.views.member :refer [member-view]])) + [syng-im.group-settings.views.member :refer [member-view]] + [clojure.string :as s])) (defn remove-member [{:keys [whisper-identity]}] (dispatch [:chat-remove-member whisper-identity])) (defn close-member-menu [] - (dispatch [:select-group-chat-member nil])) + (dispatch [:set :group-settings-selected-member nil])) (defview member-menu [] [member [:group-settings-selected-member]] @@ -58,15 +59,15 @@ subtitle])]]]) (defn close-chat-color-picker [] - (dispatch [:set-group-settings-show-color-picker false])) + (dispatch [:group-settings :show-color-picker false])) (defn set-chat-color [] (close-chat-color-picker) (dispatch [:set-chat-color])) (defview chat-color-picker [] - [show-color-picker [:get :group-settings-show-color-picker] - new-color [:get :new-chat-color]] + [show-color-picker [:group-settings :show-color-picker] + new-color [:get :new-chat-color]] [modal {:animated false :transparent false :onRequestClose close-chat-color-picker} @@ -74,11 +75,11 @@ :on-press close-chat-color-picker} [view st/modal-color-picker-inner-container [picker {:selectedValue new-color - :onValueChange #(dispatch [:set-new-chat-color %])} - [picker-item {:label "Blue" :value "#7099e6"}] - [picker-item {:label "Purple" :value "#a187d5"}] - [picker-item {:label "Green" :value "green"}] - [picker-item {:label "Red" :value "red"}]] + :onValueChange #(dispatch [:set :new-chat-color %])} + [picker-item {:label "Blue" :value "#7099e6"}] + [picker-item {:label "Purple" :value "#a187d5"}] + [picker-item {:label "Green" :value "green"}] + [picker-item {:label "Red" :value "red"}]] [touchable-highlight {:on-press set-chat-color} [text {:style st/modal-color-picker-save-btn-text} "Save"]]]]]) @@ -88,7 +89,7 @@ [view {:style (st/chat-color-icon chat-color)}]) (defn show-chat-color-picker [] - (dispatch [:set-group-settings-show-color-picker true])) + (dispatch [:group-settings :show-color-picker true])) (defn settings-view [] ;; TODO implement settings handlers @@ -105,22 +106,22 @@ {:icon :muted :icon-style {:width 18 :height 21}})) - {:icon :close-gray - :icon-style {:width 12 - :height 12} - :title "Clear history" - :handler #(dispatch [:clear-history])} - {:icon :bin - :icon-style {:width 12 - :height 18} - :title "Delete and leave" - :handler #(dispatch [:leave-group-chat])}]] + {:icon :close-gray + :icon-style {:width 12 + :height 12} + :title "Clear history" + :handler #(dispatch [:clear-history])} + {:icon :bin + :icon-style {:width 12 + :height 18} + :title "Delete and leave" + :handler #(dispatch [:leave-group-chat])}]] [view st/settings-container (for [setting settings] ^{:key setting} [setting-view setting])])) (defview chat-icon [] - [name [:chat :name] + [name [:chat :name] color [:chat :color]] [view (st/chat-icon color) [text {:style st/chat-icon-text} (first name)]]) @@ -129,24 +130,44 @@ [toolbar {:title "Chat settings" :custom-action [chat-icon]}]) +(defn focus [] + (dispatch [:set ::name-input-focused true])) + +(defn blur [] + (dispatch [:set ::name-input-focused false])) + +(defn save [] + (dispatch [:set-chat-name])) + +(defview chat-name [] + [name [:chat :name] + new-name [:get :new-chat-name] + focused? [:get ::name-input-focused]] + [view + [text {:style st/chat-name-text} "Chat name"] + [view (st/chat-name-value-container focused?) + [text-input {:style st/chat-name-value + :ref #(when (and % focused?) (.focus %)) + :on-change-text #(dispatch [:set :new-chat-name %]) + :on-focus focus + :on-blur blur} + name] + (if (or focused? (not= name new-name)) + [touchable-highlight {:style st/chat-name-btn-edit-container + :on-press save} + [view [icon :ok-purple st/add-members-icon]]] + [touchable-highlight {:style st/chat-name-btn-edit-container + :on-press focus} + [text {:style st/chat-name-btn-edit-text} "Edit"]])]]) + (defview group-settings [] - [chat-name [:chat :name] - selected-member [:group-settings-selected-member] - show-color-picker [:get :group-settings-show-color-picker]] + [selected-member [:group-settings-selected-member] + show-color-picker [:group-settings :show-color-picker]] [view st/group-settings [new-group-toolbar] [scroll-view st/body - [text {:style st/chat-name-text} - "Chat name"] - [view st/chat-name-value-container - [text {:style st/chat-name-value} - chat-name] - [touchable-highlight {:style st/chat-name-btn-edit-container - :on-press show-chat-name-edit} - [text {:style st/chat-name-btn-edit-text} - "Edit"]]] - [text {:style st/members-text} - "Members"] + [chat-name] + [text {:style st/members-text} "Members"] [touchable-highlight {:on-press #(dispatch [:show-add-participants])} [view st/add-members-container [icon :add-gray st/add-members-icon] diff --git a/src/syng_im/group_settings/styles/chat_name_edit.cljs b/src/syng_im/group_settings/styles/chat_name_edit.cljs deleted file mode 100644 index 0a5afb59d3..0000000000 --- a/src/syng_im/group_settings/styles/chat_name_edit.cljs +++ /dev/null @@ -1,19 +0,0 @@ -(ns syng-im.group-settings.styles.chat-name-edit - (:require [syng-im.components.styles :refer [font - color-white - text1-color]])) - -(def save-action-icon - {:width 18 - :height 14}) - -(def chat-name-container - {:flex 1 - :flexDirection :column - :backgroundColor color-white}) - -(def chat-name-input - {:marginLeft 12 - :fontSize 14 - :fontFamily font - :color text1-color}) diff --git a/src/syng_im/group_settings/styles/group_settings.cljs b/src/syng_im/group_settings/styles/group_settings.cljs index 092ab7387e..118caf7121 100644 --- a/src/syng_im/group_settings/styles/group_settings.cljs +++ b/src/syng_im/group_settings/styles/group_settings.cljs @@ -24,17 +24,17 @@ :backgroundColor color-white}) (def modal-member-name - {:color text2-color - :fontFamily font - :fontSize 14 - :lineHeight 20}) + {:color text2-color + :fontFamily font + :fontSize 14 + :lineHeight 20}) (def modal-remove-text - {:margin 10 - :color text1-color - :fontFamily font - :fontSize 14 - :lineHeight 20}) + {:margin 10 + :color text1-color + :fontFamily font + :fontSize 14 + :lineHeight 20}) (def modal-color-picker-inner-container {:borderRadius 10 @@ -42,12 +42,12 @@ :backgroundColor color-white}) (def modal-color-picker-save-btn-text - {:margin 10 - :alignSelf :center - :color text1-color - :fontFamily font - :fontSize 14 - :lineHeight 20}) + {:margin 10 + :alignSelf :center + :color text1-color + :fontFamily font + :fontSize 14 + :lineHeight 20}) (def chat-members-container {:marginBottom 10}) @@ -85,14 +85,14 @@ :fontSize 14 :lineHeight 20}) -(def chat-name-value-container +(defn chat-name-value-container [focused?] {:flexDirection :row :marginLeft 16 :height 56 :alignItems :center :justifyContent :center - :borderBottomWidth 1 - :borderBottomColor separator-color}) + :borderBottomWidth 2 + :borderBottomColor (if focused? color-purple separator-color)}) (def chat-name-value {:flex 1 @@ -105,11 +105,11 @@ :justifyContent :center}) (def chat-name-btn-edit-text - {:marginTop -1 - :color text2-color - :fontFamily font - :fontSize 16 - :lineHeight 20}) + {:marginTop -1 + :color text2-color + :fontFamily font + :fontSize 16 + :lineHeight 20}) (def members-text {:marginTop 24 diff --git a/src/syng_im/group_settings/subs.cljs b/src/syng_im/group_settings/subs.cljs index 8ef774b5f6..844a7088af 100644 --- a/src/syng_im/group_settings/subs.cljs +++ b/src/syng_im/group_settings/subs.cljs @@ -1,14 +1,13 @@ (ns syng-im.group-settings.subs (:require-macros [reagent.ratom :refer [reaction]]) - (:require [re-frame.core :refer [register-sub]] - [syng-im.models.contacts :refer [contact-by-identity]])) + (:require [re-frame.core :refer [register-sub]])) (register-sub :group-settings-selected-member (fn [db [_]] (reaction (let [identity (get @db :group-settings-selected-member)] - (contact-by-identity identity))))) + (get-in @db [:contacts identity]))))) -(register-sub :group-settings-show-color-picker - (fn [db [_]] - (reaction (get @db :group-settings-show-color-picker)))) +(register-sub :group-settings + (fn [db [_ k]] + (reaction (get-in @db [:group-settings k])))) diff --git a/src/syng_im/group_settings/views/chat_name_edit.cljs b/src/syng_im/group_settings/views/chat_name_edit.cljs deleted file mode 100644 index 7ba34e6dd7..0000000000 --- a/src/syng_im/group_settings/views/chat_name_edit.cljs +++ /dev/null @@ -1,31 +0,0 @@ -(ns syng-im.group-settings.views.chat-name-edit - (:require-macros [syng-im.utils.views :refer [defview]]) - (:require [reagent.core :as r] - [re-frame.core :refer [subscribe dispatch dispatch-sync]] - [syng-im.components.react :refer [view text-input]] - [syng-im.components.toolbar :refer [toolbar]] - [syng-im.group-settings.styles.chat-name-edit :as st] - [syng-im.components.styles :refer [toolbar-background2 - text2-color]])) - -(defn save-group-chat-name [] - (dispatch [:set-chat-name]) - (dispatch [:navigate-back])) - -(defn chat-name-edit-toolbar [chat-name] - [toolbar {:background-color toolbar-background2 - :title "Edit chat name" - ;; TODO change to dark 'ok' icon - :action {:image {:source {:uri :icon_ok} - :style st/save-action-icon} - :handler save-group-chat-name}}]) - -(defview chat-name-edit [] - [new-chat-name [:get :new-chat-name]] - [view st/chat-name-container - [chat-name-edit-toolbar] - [text-input {:style st/chat-name-input - :autoFocus true - :placeholderTextColor text2-color - :onChangeText #(dispatch [:set-new-chat-name %])} - new-chat-name]]) diff --git a/src/syng_im/group_settings/views/member.cljs b/src/syng_im/group_settings/views/member.cljs index 6584724755..593a8c7eab 100644 --- a/src/syng_im/group_settings/views/member.cljs +++ b/src/syng_im/group_settings/views/member.cljs @@ -38,6 +38,6 @@ [text {:style st/role-text} role])] [touchable-highlight - {:on-press #(dispatch [:select-group-chat-member whisper-identity])} + {:on-press #(dispatch [:set :group-settings-selected-member whisper-identity])} [view st/more-btn [icon :more-vertical st/more-btn-icon]]]]) diff --git a/src/syng_im/handlers.cljs b/src/syng_im/handlers.cljs index 5ca72c1d61..3123cf44b6 100644 --- a/src/syng_im/handlers.cljs +++ b/src/syng_im/handlers.cljs @@ -63,6 +63,11 @@ (fn [db [_ k v]] (assoc db k v)))) +(register-handler :set-in + (debug + (fn [db [_ path v]] + (assoc-in db path v)))) + (register-handler :initialize-db (fn [_ _] (assoc app-db @@ -279,12 +284,13 @@ (dispatch [:initialize-chats]) db)) + (register-handler :chat-remove-member (fn [db [action]] (let [chat-id (:current-chat-id db) identity (:group-settings-selected-member db) db (chat-remove-member db)] - (dispatch [:select-group-chat-member nil]) + (dispatch [:set :group-settings-selected-member nil]) ;; TODO fix and uncomment (api/group-remove-participant chat-id identity) (removed-participant-msg chat-id identity) diff --git a/src/syng_im/navigation/handlers.cljs b/src/syng_im/navigation/handlers.cljs index 36dd8a768d..6166d13ec6 100644 --- a/src/syng_im/navigation/handlers.cljs +++ b/src/syng_im/navigation/handlers.cljs @@ -27,6 +27,7 @@ (push-view db view-id))) (register-handler :navigation-replace + (enrich preload-data!) (fn [db [_ view-id]] (replace-view db view-id))) @@ -46,13 +47,6 @@ (push-view :new-group) (assoc :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) - (assoc :current-chat-id chat-id))))) - (register-handler :show-contacts (fn [db _] (push-view db :contact-list))) diff --git a/src/syng_im/new_group/handlers.cljs b/src/syng_im/new_group/handlers.cljs index 3823eb1c2e..949466b268 100644 --- a/src/syng_im/new_group/handlers.cljs +++ b/src/syng_im/new_group/handlers.cljs @@ -56,7 +56,7 @@ (defn show-chat! [{:keys [new-group-id]} _] - (dispatch [:show-chat new-group-id :replace])) + (dispatch [:navigation-replace :chat new-group-id])) (defn enable-creat-buttion [db _] diff --git a/src/syng_im/new_group/subs.cljs b/src/syng_im/new_group/subs.cljs index 62fc941747..fd33058b1e 100644 --- a/src/syng_im/new_group/subs.cljs +++ b/src/syng_im/new_group/subs.cljs @@ -1,9 +1,7 @@ (ns syng-im.new-group.subs (:require-macros [reagent.ratom :refer [reaction]]) - (:require [re-frame.core :refer [register-sub]])) + (:require [re-frame.core :refer [register-sub]] + [syng-im.utils.subs :as u])) (register-sub :is-contact-selected? - (fn [db [_ id]] - (-> (:selected-contacts @db) - (contains? id) - (reaction)))) + (u/contains-sub :selected-contacts)) diff --git a/src/syng_im/participants/subs.cljs b/src/syng_im/participants/subs.cljs new file mode 100644 index 0000000000..810a9ff3f6 --- /dev/null +++ b/src/syng_im/participants/subs.cljs @@ -0,0 +1,3 @@ +(ns syng-im.participants.subs) + +() diff --git a/src/syng_im/participants/views/create.cljs b/src/syng_im/participants/views/add.cljs similarity index 66% rename from src/syng_im/participants/views/create.cljs rename to src/syng_im/participants/views/add.cljs index 20a84dfbfa..826579fcd1 100644 --- a/src/syng_im/participants/views/create.cljs +++ b/src/syng_im/participants/views/add.cljs @@ -1,4 +1,5 @@ -(ns syng-im.participants.views.create +(ns syng-im.participants.views.add + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.resources :as res] [syng-im.components.react :refer [view list-view list-item]] @@ -19,12 +20,10 @@ [row _ _] (list-item [participant-contact row])) -(defn new-participants [] - (let [contacts (subscribe [:all-new-contacts])] - (fn [] - (let [contacts-ds (to-datasource @contacts)] - [view st/participants-container - [new-participants-toolbar] - [list-view {:dataSource contacts-ds - :renderRow new-participants-row - :style st/participants-list}]])))) +(defview new-participants [] + [contacts [:all-new-contacts]] + [view st/participants-container + [new-participants-toolbar] + [list-view {:dataSource (to-datasource contacts) + :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 40ff3528f7..32cbd1882e 100644 --- a/src/syng_im/participants/views/remove.cljs +++ b/src/syng_im/participants/views/remove.cljs @@ -1,4 +1,5 @@ (ns syng-im.participants.views.remove + (:require-macros [syng-im.utils.views :refer [defview]]) (:require [re-frame.core :refer [subscribe dispatch]] [syng-im.resources :as res] [syng-im.components.react :refer [view text-input text image @@ -22,12 +23,10 @@ [row _ _] (r/as-element [participant-contact row])) -(defn remove-participants [] - (let [contacts (subscribe [:current-chat-contacts])] - (fn [] - (let [contacts-ds (to-datasource @contacts)] - [view st/participants-container - [remove-participants-toolbar] - [list-view {:dataSource contacts-ds - :renderRow remove-participants-row - :style st/participants-list}]])))) +(defview remove-participants [] + [contacts [:current-chat-contacts]] + [view st/participants-container + [remove-participants-toolbar] + [list-view {:dataSource (to-datasource contacts) + :renderRow remove-participants-row + :style st/participants-list}]]) diff --git a/src/syng_im/profile/screen.cljs b/src/syng_im/profile/screen.cljs index 9d075c4999..00f36886ed 100644 --- a/src/syng_im/profile/screen.cljs +++ b/src/syng_im/profile/screen.cljs @@ -32,7 +32,7 @@ (defn message-user [identity] (when identity - (dispatch [:show-chat identity :push]))) + (dispatch [:navigate-to :chat identity]))) (defview profile [] [{:keys [name whisper-identity phone-number]} [:contact]] diff --git a/src/syng_im/subs.cljs b/src/syng_im/subs.cljs index 055e3e8760..6964ed715a 100644 --- a/src/syng_im/subs.cljs +++ b/src/syng_im/subs.cljs @@ -10,3 +10,7 @@ (register-sub :get (fn [db [_ k]] (reaction (k @db)))) + +(register-sub :get-in + (fn [db [_ path]] + (reaction (get-in @db path)))) diff --git a/src/syng_im/utils/subs.cljs b/src/syng_im/utils/subs.cljs new file mode 100644 index 0000000000..1ea1b7d0ee --- /dev/null +++ b/src/syng_im/utils/subs.cljs @@ -0,0 +1,10 @@ +(ns syng-im.utils.subs + (:require-macros [reagent.ratom :refer [reaction]])) + +(defn contains-sub + "Creates subscrition that cheks if collection (map or set) contains element" + [collection] + (fn [db [_ element]] + (-> (collection @db) + (contains? element) + (reaction))))