Merge develop into group-chat-settings

Former-commit-id: e93e7724e2d1113abefbbdb4c31693da49102e6e
This commit is contained in:
virvar 2016-05-17 14:38:55 +03:00
commit 8d2532eb46
9 changed files with 53 additions and 89 deletions

View File

@ -25,15 +25,15 @@
;; todo: it might be better always return false from ;; todo: it might be better always return false from
;; this listener and handle application's closing ;; this listener and handle application's closing
;; in handlers ;; in handlers
(let [stack (subscribe [:navigation-stack])] (let [stack (subscribe [:get :navigation-stack])]
(when (< 1 (count @stack)) (when (< 1 (count @stack))
(dispatch [:navigate-back]) (dispatch [:navigate-back])
true)))] true)))]
(add-event-listener "hardwareBackPress" new-listener))) (add-event-listener "hardwareBackPress" new-listener)))
(defn app-root [] (defn app-root []
(let [signed-up (subscribe [:signed-up]) (let [signed-up (subscribe [:get :signed-up])
view-id (subscribe [:view-id])] view-id (subscribe [:get :view-id])]
(fn [] (fn []
(case (if @signed-up @view-id :chat) (case (if @signed-up @view-id :chat)
:discovery [discovery] :discovery [discovery]

View File

@ -9,10 +9,11 @@
content-type-command]] content-type-command]]
[syng-im.utils.random :as random] [syng-im.utils.random :as random]
[syng-im.components.react :as r] [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.models.chats :as chats]
[syng-im.navigation.handlers :as nav] [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 (register-handler :set-show-actions
(fn [db [_ show-actions]] (fn [db [_ show-actions]]
@ -71,7 +72,8 @@
((enrich update-command) update-text)) ((enrich update-command) update-text))
(register-handler :send-group-chat-msg (register-handler :send-group-chat-msg
(fn [db [_ chat-id text]] (u/side-effect!
(fn [_ [_ chat-id text]]
(let [{msg-id :msg-id (let [{msg-id :msg-id
{from :from} :msg} (api/send-group-user-msg {:group-id chat-id {from :from} :msg} (api/send-group-user-msg {:group-id chat-id
:content text}) :content text})
@ -81,7 +83,7 @@
:content text :content text
:content-type text-content-type :content-type text-content-type
:outgoing true}] :outgoing true}]
(messages/save-message chat-id msg)))) (messages/save-message chat-id msg)))))
(defn console? [s] (defn console? [s]
(= "console" s)) (= "console" s))
@ -236,7 +238,6 @@
(fn [db [_ signed-up]] (fn [db [_ signed-up]]
(sign-up-service/set-signed-up db signed-up))) (sign-up-service/set-signed-up db signed-up)))
(defn load-messages! (defn load-messages!
([db] (load-messages! db nil)) ([db] (load-messages! db nil))
([db _] ([db _]
@ -289,15 +290,9 @@
((after store-message!)))) ((after store-message!))))
(register-handler :group-received-msg (register-handler :group-received-msg
(fn [db [_ {chat-id :group-id :as msg}]] (u/side-effect!
(messages/save-message chat-id msg) (fn [_ [_ {chat-id :group-id :as msg}]]
db)) (messages/save-message chat-id msg))))
(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 (defmethod nav/preload-data! :chat
[{:keys [current-chat-id] :as db} [_ _ id]] [{:keys [current-chat-id] :as db} [_ _ id]]

View File

@ -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]] (:require [re-frame.core :refer [subscribe dispatch dispatch-sync]]
[syng-im.persistence.simple-kv-store :as kv] [syng-im.persistence.simple-kv-store :as kv]
[syng-im.protocol.state.storage :as s] [syng-im.protocol.state.storage :as s]

View File

@ -46,18 +46,15 @@
@username]] @username]]
[view st/menu-items-container [view st/menu-items-container
[menu-item {:name "Profile" [menu-item {:name "Profile"
:handler (fn [] :handler #(dispatch [:navigate-to :my-profile])}]
(dispatch [:show-my-profile]))}]
[menu-item {:name "Settings" [menu-item {:name "Settings"
:handler (fn [] :handler (fn []
;; TODO not implemented ;; TODO not implemented
)}] )}]
[menu-item {:name "Discovery" [menu-item {:name "Discovery"
:handler (fn [] :handler #(dispatch [:navigate-to :discovery])}]
(dispatch [:navigate-to :discovery]))}]
[menu-item {:name "Contacts" [menu-item {:name "Contacts"
:handler (fn [] :handler #(dispatch [:show-contacts navigator])}]
(dispatch [:show-contacts navigator]))}]
[menu-item {:name "Invite friends" [menu-item {:name "Invite friends"
:handler (fn [] :handler (fn []
;; TODO not implemented ;; TODO not implemented

View File

@ -17,7 +17,6 @@
[syng-im.models.commands :refer [set-commands]] [syng-im.models.commands :refer [set-commands]]
[syng-im.handlers.server :as server] [syng-im.handlers.server :as server]
[syng-im.chat.suggestions :refer [load-commands]] [syng-im.chat.suggestions :refer [load-commands]]
[syng-im.handlers.sign-up :as sign-up-service]
[syng-im.models.chats :refer [chat-exists? [syng-im.models.chats :refer [chat-exists?
create-chat create-chat
chat-add-participants chat-add-participants

View File

@ -18,29 +18,28 @@
(keywordize-keys (apply hash-map (split s #"[;=]")))) (keywordize-keys (apply hash-map (split s #"[;=]"))))
(defn save-message (defn save-message
[chat-id {:keys [from to msg-id content content-type outgoing ;; todo remove chat-id parameter
same-author same-direction] [chat-id {:keys [to msg-id content outgoing]
;; outgoing should be explicitely defined in handlers
:or {outgoing false :or {outgoing false
to nil} :as msg}] to nil} :as message}]
(log/debug "save-message" chat-id msg)
(when-not (r/exists? :msgs :msg-id msg-id) (when-not (r/exists? :msgs :msg-id msg-id)
(r/write (r/write
(fn [] (fn []
(let [content (if (string? content) (let [content' (if (string? content)
content content
(map-to-str content))] (map-to-str content))
(r/create :msgs {:chat-id chat-id message' (merge message
:msg-id msg-id {:chat-id chat-id
:from from :content content'
:to to
:content content
:content-type content-type
:outgoing outgoing
:timestamp (timestamp) :timestamp (timestamp)
:delivery-status nil :delivery-status nil})]
;; TODO 'some?' is temp (r/create :msgs message' true))))))
:same-author (some? same-author)
:same-direction (some? same-direction)} true)))))) (defn command-type? [type]
(contains?
#{c/content-type-command c/content-type-command-request}
type))
(defn get-messages [chat-id] (defn get-messages [chat-id]
(->> (-> (r/get-by-field :msgs :chat-id chat-id) (->> (-> (r/get-by-field :msgs :chat-id chat-id)
@ -48,8 +47,7 @@
(r/collection->map)) (r/collection->map))
(into '()) (into '())
(map (fn [{:keys [content-type] :as message}] (map (fn [{:keys [content-type] :as message}]
(if (#{c/content-type-command c/content-type-command-request} (if (command-type? content-type)
content-type)
(update message :content str-to-map) (update message :content str-to-map)
message))))) message)))))

View File

@ -1,5 +1,6 @@
(ns syng-im.navigation.handlers (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] (defn push-view [db view-id]
(-> db (-> db
@ -71,14 +72,10 @@
(push-view :add-participants) (push-view :add-participants)
clear-new-participants))) clear-new-participants)))
(register-handler :show-profile (defn show-profile
(debug [db [_ identity]]
(fn [db [_ identity]] (-> db
(let [db (assoc db :contact-identity identity)] (assoc :contact-identity identity)
(dispatch [:navigate-to :profile]) (push-view :profile)))
db))))
(register-handler :show-my-profile (register-handler :show-profile show-profile)
(fn [db _]
(dispatch [:navigate-to :my-profile])
db))

View File

@ -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))))

View File

@ -3,21 +3,9 @@
(:require [re-frame.core :refer [register-sub]] (:require [re-frame.core :refer [register-sub]]
syng-im.chat.subs syng-im.chat.subs
syng-im.group-settings.subs syng-im.group-settings.subs
syng-im.navigation.subs
syng-im.discovery.subs syng-im.discovery.subs
syng-im.contacts.subs)) syng-im.contacts.subs))
;; -- Chats list --------------------------------------------------------------
(register-sub :get (register-sub :get
(fn [db [_ k]] (fn [db [_ k]]
(reaction (k @db)))) (reaction (k @db))))
;; -- User data --------------------------------------------------------------
(register-sub
:signed-up
(fn [db _]
(reaction (:signed-up @db))))
(register-sub :db
(fn [db _] (reaction @db)))