Merge with 'design'

This commit is contained in:
virvar 2016-05-05 13:30:12 +03:00
commit f06cdee11b
6 changed files with 168 additions and 149 deletions

View File

@ -9,22 +9,7 @@
(def content-type-command "command") (def content-type-command "command")
(def content-type-command-request "command-request") (def content-type-command-request "command-request")
(def content-type-status "status") (def content-type-status "status")
(def group-chat-colors [{:background "#AB7967", :text "#FFFFFF"}
{:background "#B48EAD", :text "#FFFFFF"}
{:background "#8FA1B3", :text "#FFFFFF"}
{:background "#96B5B4", :text "#FFFFFF"}
{:background "#A3BE8C", :text "#FFFFFF"}
{:background "#EBCB8B", :text "#FFFFFF"}
{:background "#D08770", :text "#FFFFFF"}
{:background "#BF616A", :text "#FFFFFF"}
{:background "#EFF1F5", :text "#000000"}
{:background "#DFE1E8", :text "#000000"}
{:background "#C0C5CE", :text "#000000"}
{:background "#A7ADBA", :text "#000000"}
{:background "#65737E", :text "#FFFFFF"}
{:background "#4F5B66", :text "#FFFFFF"}
{:background "#343D46", :text "#FFFFFF"}
{:background "#2B303B", :text "#FFFFFF"}])
(comment (comment

View File

@ -1,57 +1,59 @@
(ns syng-im.handlers (ns syng-im.handlers
(:require (:require
[re-frame.core :refer [register-handler after dispatch]] [re-frame.core :refer [register-handler after dispatch]]
[schema.core :as s :include-macros true] [schema.core :as s :include-macros true]
[syng-im.db :as db :refer [app-db schema]] [syng-im.db :as db :refer [app-db schema]]
[syng-im.protocol.api :refer [init-protocol]] [syng-im.protocol.api :refer [init-protocol]]
[syng-im.protocol.protocol-handler :refer [make-handler]] [syng-im.protocol.protocol-handler :refer [make-handler]]
[syng-im.models.protocol :refer [update-identity [syng-im.models.protocol :refer [update-identity
set-initialized]] set-initialized]]
[syng-im.models.user-data :as user-data] [syng-im.models.user-data :as user-data]
[syng-im.models.contacts :as contacts] [syng-im.models.contacts :as contacts]
[syng-im.models.messages :refer [save-message [syng-im.models.messages :refer [save-message
update-message! update-message!
message-by-id]] message-by-id]]
[syng-im.models.commands :as commands :refer [set-chat-command [syng-im.models.commands :as commands :refer [set-chat-command
set-response-chat-command set-response-chat-command
set-chat-command-content set-chat-command-content
set-chat-command-request set-chat-command-request
stage-command stage-command
unstage-command unstage-command
set-commands]] set-commands]]
[syng-im.handlers.server :as server] [syng-im.handlers.server :as server]
[syng-im.handlers.contacts :as contacts-service] [syng-im.handlers.contacts :as contacts-service]
[syng-im.handlers.suggestions :refer [get-command [syng-im.handlers.suggestions :refer [get-command
handle-command handle-command
get-command-handler get-command-handler
load-commands load-commands
apply-staged-commands apply-staged-commands
check-suggestion]] check-suggestion]]
[syng-im.handlers.sign-up :as sign-up-service] [syng-im.handlers.sign-up :as sign-up-service]
[syng-im.models.chats :refer [create-chat [syng-im.models.chats :refer [chat-exists?
chat-add-participants create-chat
chat-remove-participants chat-add-participants
set-chat-active]] chat-remove-participants
[syng-im.models.chat :refer [signal-chat-updated set-chat-active
set-current-chat-id re-join-group-chat]]
current-chat-id [syng-im.models.chat :refer [signal-chat-updated
update-new-group-selection set-current-chat-id
update-new-participants-selection current-chat-id
clear-new-group update-new-group-selection
clear-new-participants update-new-participants-selection
new-group-selection clear-new-group
set-chat-input-text clear-new-participants
new-participants-selection]] new-group-selection
[syng-im.utils.logging :as log] set-chat-input-text
[syng-im.protocol.api :as api] new-participants-selection]]
[syng-im.constants :refer [text-content-type [syng-im.utils.logging :as log]
content-type-command]] [syng-im.protocol.api :as api]
[syng-im.navigation :refer [nav-push [syng-im.constants :refer [text-content-type
nav-replace content-type-command]]
nav-pop]] [syng-im.navigation :refer [nav-push
[syng-im.utils.crypt :refer [gen-random-bytes]] nav-replace
[syng-im.utils.random :as random])) nav-pop]]
[syng-im.utils.crypt :refer [gen-random-bytes]]
[syng-im.utils.random :as random]))
;; -- Middleware ------------------------------------------------------------ ;; -- Middleware ------------------------------------------------------------
;; ;;
@ -113,9 +115,9 @@
db)) db))
(register-handler :set-commands (register-handler :set-commands
(fn [db [action commands]] (fn [db [action commands]]
(log/debug action commands) (log/debug action commands)
(set-commands db commands))) (set-commands db commands)))
(register-handler :set-show-actions (register-handler :set-show-actions
(fn [db [action show-actions]] (fn [db [action show-actions]]
@ -152,13 +154,15 @@
(defn joined-chat-msg [chat-id from msg-id] (defn joined-chat-msg [chat-id from msg-id]
(let [contact-name (:name (contacts/contact-by-identity from))] (let [contact-name (:name (contacts/contact-by-identity from))]
(save-message chat-id {:from "system" (save-message chat-id {:from "system"
:msg-id msg-id :msg-id (str msg-id "_" from)
:content (str (or contact-name from) " received chat invitation") :content (str (or contact-name from) " received chat invitation")
:content-type text-content-type}))) :content-type text-content-type})))
(defn participant-invited-to-group-msg [chat-id identity from msg-id] (defn participant-invited-to-group-msg [chat-id identity from msg-id]
(let [inviter-name (:name (contacts/contact-by-identity from)) (let [inviter-name (:name (contacts/contact-by-identity from))
invitee-name (:name (contacts/contact-by-identity identity))] invitee-name (if (= identity (api/my-identity))
"You"
(:name (contacts/contact-by-identity identity)))]
(save-message chat-id {:from "system" (save-message chat-id {:from "system"
:msg-id msg-id :msg-id msg-id
:content (str (or inviter-name from) " invited " (or invitee-name identity)) :content (str (or inviter-name from) " invited " (or invitee-name identity))
@ -222,8 +226,10 @@
(register-handler :participant-left-group (register-handler :participant-left-group
(fn [db [action from group-id msg-id]] (fn [db [action from group-id msg-id]]
(log/debug action msg-id from group-id) (log/debug action msg-id from group-id)
(participant-left-group-msg group-id from msg-id) (if (= (api/my-identity) from)
(signal-chat-updated db group-id))) db
(do (participant-left-group-msg group-id from msg-id)
(signal-chat-updated db group-id)))))
(register-handler :participant-invited-to-group (register-handler :participant-invited-to-group
(fn [db [action from group-id identity msg-id]] (fn [db [action from group-id identity msg-id]]
@ -249,26 +255,26 @@
(defn send-staged-commands [db chat-id] (defn send-staged-commands [db chat-id]
(let [staged-commands (get-in db (db/chat-staged-commands-path chat-id))] (let [staged-commands (get-in db (db/chat-staged-commands-path chat-id))]
(dorun (dorun
(map (map
(fn [staged-command] (fn [staged-command]
(let [command-key (get-in staged-command [:command :command]) (let [command-key (get-in staged-command [:command :command])
content (commands/format-command-msg-content command-key content (commands/format-command-msg-content command-key
(:content staged-command)) (:content staged-command))
msg (if (= chat-id "console") msg (if (= chat-id "console")
(sign-up-service/send-console-command db command-key content) (sign-up-service/send-console-command db command-key content)
;; TODO handle command, now sends as plain message ;; TODO handle command, now sends as plain message
(let [{msg-id :msg-id (let [{msg-id :msg-id
{from :from {from :from
to :to} :msg} (api/send-user-msg {:to chat-id to :to} :msg} (api/send-user-msg {:to chat-id
:content content})] :content content})]
{:msg-id msg-id {:msg-id msg-id
:from from :from from
:to to :to to
:content content :content content
:content-type content-type-command :content-type content-type-command
:outgoing true}))] :outgoing true}))]
(save-message chat-id msg))) (save-message chat-id msg)))
staged-commands)) staged-commands))
db)) db))
(register-handler :send-chat-msg (register-handler :send-chat-msg
@ -280,7 +286,7 @@
(let [msg (when (pos? (count text)) (let [msg (when (pos? (count text))
(if (= chat-id "console") (if (= chat-id "console")
(sign-up-service/send-console-msg text) (sign-up-service/send-console-msg text)
(let [{msg-id :msg-id (let [{msg-id :msg-id
{from :from {from :from
to :to} :msg} (api/send-user-msg {:to chat-id to :to} :msg} (api/send-user-msg {:to chat-id
:content text})] :content text})]
@ -309,7 +315,7 @@
(register-handler :send-chat-command (register-handler :send-chat-command
(fn [db [action chat-id command content]] (fn [db [action chat-id command content]]
(log/debug action "chat-id" chat-id "command" command "content" content) (log/debug action "chat-id" chat-id "command" command "content" content)
(let [db (set-chat-input-text db nil) (let [db (set-chat-input-text db nil)
msg (if (= chat-id "console") msg (if (= chat-id "console")
(sign-up-service/send-console-command db command content) (sign-up-service/send-console-command db command content)
;; TODO handle command, now sends as plain message ;; TODO handle command, now sends as plain message
@ -409,7 +415,7 @@
(register-handler :stage-command (register-handler :stage-command
(fn [db [action chat-id command content]] (fn [db [action chat-id command content]]
(log/debug action "chat-id" chat-id "command" command "content" content) (log/debug action "chat-id" chat-id "command" command "content" content)
(let [db (set-chat-input-text db nil) (let [db (set-chat-input-text db nil)
command-info {:command command command-info {:command command
:content content :content content
:handler (get-command-handler db (:command command) content)}] :handler (get-command-handler db (:command command) content)}]
@ -502,8 +508,10 @@
(register-handler :group-chat-invite-received (register-handler :group-chat-invite-received
(fn [db [action from group-id identities group-name]] (fn [db [action from group-id identities group-name]]
(log/debug action from group-id identities) (log/debug action from group-id identities)
(create-chat db group-id identities true group-name))) (if (chat-exists? group-id)
(re-join-group-chat db group-id identities group-name)
(create-chat db group-id identities true group-name))))
(comment (comment
(dispatch [:set-signed-up true])
) )

View File

@ -1,13 +1,14 @@
(ns syng-im.models.chats (ns syng-im.models.chats
(:require [syng-im.persistence.realm :as r] (:require [clojure.set :refer [difference]]
[syng-im.persistence.realm :as r]
[syng-im.utils.random :as random :refer [timestamp]] [syng-im.utils.random :as random :refer [timestamp]]
[clojure.string :refer [join blank?]] [clojure.string :refer [join blank?]]
[syng-im.db :as db] [syng-im.db :as db]
[syng-im.utils.logging :as log] [syng-im.utils.logging :as log]
[syng-im.constants :refer [group-chat-colors [syng-im.constants :refer [content-type-status]]
content-type-status]]
[syng-im.models.messages :refer [save-message]] [syng-im.models.messages :refer [save-message]]
[syng-im.persistence.realm-queries :refer [include-query]])) [syng-im.persistence.realm-queries :refer [include-query]]
[syng-im.models.chat :refer [signal-chat-updated]]))
(defn signal-chats-updated [db] (defn signal-chats-updated [db]
(update-in db db/updated-chats-signal-path (fn [current] (update-in db db/updated-chats-signal-path (fn [current]
@ -33,6 +34,9 @@
(or (chat-name-from-contacts identities) (or (chat-name-from-contacts identities)
chat-id)) chat-id))
(defn chat-exists? [chat-id]
(r/exists? :chats :chat-id chat-id))
(defn add-status-message [chat-id] (defn add-status-message [chat-id]
;; TODO Get real status ;; TODO Get real status
(save-message chat-id (save-message chat-id
@ -49,17 +53,15 @@
([db chat-id identities group-chat?] ([db chat-id identities group-chat?]
(create-chat db chat-id identities group-chat? nil)) (create-chat db chat-id identities group-chat? nil))
([db chat-id identities group-chat? chat-name] ([db chat-id identities group-chat? chat-name]
(if (r/exists? :chats :chat-id chat-id) (if (chat-exists? chat-id)
db db
(let [chat-name (or chat-name (let [chat-name (or chat-name
(get-chat-name chat-id identities)) (get-chat-name chat-id identities))
_ (log/debug "creating chat" chat-name)] _ (log/debug "creating chat" chat-name)]
(r/write (r/write
(fn [] (fn []
(let [contacts (mapv (fn [ident {:keys [background text]}] (let [contacts (mapv (fn [ident]
{:identity ident {:identity ident}) identities)]
:background-color background
:text-color text}) identities group-chat-colors)]
(r/create :chats {:chat-id chat-id (r/create :chats {:chat-id chat-id
:is-active true :is-active true
:name chat-name :name chat-name
@ -70,6 +72,30 @@
(add-status-message chat-id) (add-status-message chat-id)
(signal-chats-updated db))))) (signal-chats-updated db)))))
(defn chat-contacts [chat-id]
(-> (r/get-by-field :chats :chat-id chat-id)
(r/single)
(aget "contacts")))
(defn re-join-group-chat [db group-id identities group-name]
(r/write
(fn []
(let [new-identities (set identities)
only-old-contacts (->> (chat-contacts group-id)
(r/cljs-list)
(remove (fn [{:keys [identity]}]
(new-identities identity))))
contacts (->> new-identities
(mapv (fn [ident]
{:identity ident}))
(concat only-old-contacts))]
(r/create :chats {:chat-id group-id
:is-active true
:name group-name
:contacts contacts} true))))
(-> (signal-chats-updated db)
(signal-chat-updated group-id)))
(defn chats-list [] (defn chats-list []
(r/sorted (r/get-all :chats) :timestamp :desc)) (r/sorted (r/get-all :chats) :timestamp :desc))
@ -81,29 +107,22 @@
(defn chat-add-participants [chat-id identities] (defn chat-add-participants [chat-id identities]
(r/write (r/write
(fn [] (fn []
(let [contacts (-> (r/get-by-field :chats :chat-id chat-id) (let [contacts (chat-contacts chat-id)]
(r/single) (doseq [contact-identity identities]
(aget "contacts")) (if-let [contact-exists (.find contacts (fn [object index collection]
colors-in-use (set (.map contacts (fn [object index collection] (= contact-identity (aget object "identity"))))]
{:text-color (aget object "text-color") (aset contact-exists "is-in-chat" true)
:background-color (aget object "background-color")}))) (.push contacts (clj->js {:identity contact-identity}))))))))
colors (filter (fn [color]
(not (contains? colors-in-use color))) group-chat-colors)
new-contacts (mapv (fn [ident {:keys [background text]}]
{:identity ident
:background-color background
:text-color text}) identities colors)]
(doseq [contact new-contacts]
(.push contacts (clj->js contact)))))))
(defn chat-remove-participants [chat-id identities] (defn chat-remove-participants [chat-id identities]
(r/write (r/write
(fn [] (fn []
(let [query (include-query :identity identities) (let [query (include-query :identity identities)
chat (r/single (r/get-by-field :chats :chat-id chat-id))] chat (r/single (r/get-by-field :chats :chat-id chat-id))]
(-> (aget chat "contacts") (-> (aget chat "contacts")
(r/filtered query) (r/filtered query)
(r/delete)))))) (.forEach (fn [object index collection]
(aset object "is-in-chat" false))))))))
(defn active-group-chats [] (defn active-group-chats []
(let [results (r/filtered (r/get-all :chats) (let [results (r/filtered (r/get-all :chats)
@ -118,7 +137,7 @@
(r/single) (r/single)
(aset "is-active" active?))))) (aset "is-active" active?)))))
#_(comment (comment
(active-group-chats) (active-group-chats)
@ -135,10 +154,9 @@
(-> (aget (aget (chats-list) 0) "contacts") (-> (aget (aget (chats-list) 0) "contacts")
(js->clj :keywordize-keys true) (r/cljs-list))
)
(r/delete (chats-list)) (r/write (fn [] (r/delete (chats-list))))
(swap! re-frame.db/app-db signal-chats-updated) (swap! re-frame.db/app-db signal-chats-updated)
@ -152,4 +170,8 @@
(swap! re-frame.db/app-db (fn [db] (swap! re-frame.db/app-db (fn [db]
(create-chat db "A group chat"))) (create-chat db "A group chat")))
(-> (chats-list)
(.find (fn [object index collection]
(= "console1" (aget object "chat-id")))))
) )

View File

@ -111,13 +111,13 @@
(comment (comment
(r/write #(create-contact {:phone-number "0543072333" (r/write #(create-contact {:phone-number "0543072333"
:whisper-identity "0x041e1a37a0317a66f8d826e6779d808a9f39b88c2f896c5d3c08c4ded259719be256e4e6d6f49dab2324993ec822b588f2c0591b7a723cb0be659f2eccf48b5fed" :whisper-identity "0x04e43e861a6dd99ad9eee7bd58af89dcaa430188ebec8698de7b7bad54573324fff4ac5cb9bb277af317efd7abfc917b91bf48cc41e40bf70062fd79400016a1f9"
:name "Mr. Bean" :name "Splinter"
:photo-path ""})) :photo-path ""}))
(r/write #(create-contact {:phone-number "0544828649" (r/write #(create-contact {:phone-number "0544828649"
:whisper-identity "0x04dcbf434bbf6925f251b7f43337f66a5a3f943e8983284045af703551cab39684d8c838e73f0234169f26fe126d7ef1ea3b8c1013e7dad1d4c5a82c7a651647fd" :whisper-identity "0x0487954e7fa746d8cf787403c2c491aadad540b9bb1f0f7b8184792e91c33b6a394079295f5777ec6d4af9ad5ba24794b3ff1ec8be9ff6a708c85a163733192665"
:name "Mr. Batman" :name "Exodius"
:photo-path ""})) :photo-path ""}))
(r/write #(create-contact {:phone-number "0522222222" (r/write #(create-contact {:phone-number "0522222222"

View File

@ -36,9 +36,9 @@
:same-author "bool" :same-author "bool"
:same-direction "bool"}} :same-direction "bool"}}
{:name :chat-contact {:name :chat-contact
:properties {:identity "string" :properties {:identity "string"
:text-color "string" :is-in-chat {:type "bool"
:background-color "string"}} :default true}}}
{:name :chats {:name :chats
:primaryKey :chat-id :primaryKey :chat-id
:properties {:chat-id "string" :properties {:chat-id "string"
@ -109,6 +109,10 @@
(some-> (aget result 0) (some-> (aget result 0)
(js->clj :keywordize-keys true))) (js->clj :keywordize-keys true)))
(defn cljs-list [results]
(-> (js->clj results :keywordize-keys true)
(vals)))
(defn list-to-array [record list-field] (defn list-to-array [record list-field]
(update-in record [list-field] (comp vec vals))) (update-in record [list-field] (comp vec vals)))

View File

@ -23,7 +23,7 @@
(register-sub :get-chat-messages (register-sub :get-chat-messages
(fn [db _] (fn [db _]
(let [chat-id (reaction (current-chat-id @db)) (let [chat-id (reaction (current-chat-id @db))
chat-updated (reaction (chat-updated? @db @chat-id))] chat-updated (reaction (chat-updated? @db @chat-id))]
(reaction (reaction
(let [_ @chat-updated] (let [_ @chat-updated]
@ -42,16 +42,16 @@
(reaction (get-suggestions @db @input-text))))) (reaction (get-suggestions @db @input-text)))))
(register-sub :get-commands (register-sub :get-commands
(fn [db _] (fn [db _]
(reaction (get-commands @db)))) (reaction (get-commands @db))))
(register-sub :get-chat-input-text (register-sub :get-chat-input-text
(fn [db _] (fn [db _]
(reaction (get-in @db (db/chat-input-text-path (current-chat-id @db)))))) (reaction (get-in @db (db/chat-input-text-path (current-chat-id @db))))))
(register-sub :get-chat-staged-commands (register-sub :get-chat-staged-commands
(fn [db _] (fn [db _]
(reaction (get-in @db (db/chat-staged-commands-path (current-chat-id @db)))))) (reaction (get-in @db (db/chat-staged-commands-path (current-chat-id @db))))))
(register-sub :get-chat-command (register-sub :get-chat-command
(fn [db _] (fn [db _]
@ -104,10 +104,10 @@
(get @db :loading)))) (get @db :loading))))
(register-sub (register-sub
:signed-up :signed-up
(fn [db _] (fn [db _]
(reaction (reaction
(get @db :signed-up)))) (get @db :signed-up))))
(register-sub (register-sub
:show-actions :show-actions
@ -118,7 +118,7 @@
:get-contacts :get-contacts
(fn [db _] (fn [db _]
(reaction (reaction
(get @db :contacts)))) (get @db :contacts))))
(register-sub :all-contacts (register-sub :all-contacts
(fn [db _] (fn [db _]
@ -128,8 +128,8 @@
(register-sub :all-new-contacts (register-sub :all-new-contacts
(fn [db _] (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 (reaction (when-let [chat-id @current-chat-id]
(chat-by-id chat-id)))] (chat-by-id chat-id)))]
(reaction (reaction
(when @chat (when @chat
(let [current-participants (->> @chat (let [current-participants (->> @chat
@ -140,8 +140,8 @@
(register-sub :current-chat-contacts (register-sub :current-chat-contacts
(fn [db _] (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 (reaction (when-let [chat-id @current-chat-id]
(chat-by-id chat-id)))] (chat-by-id chat-id)))]
(reaction (reaction
(when @chat (when @chat
(let [current-participants (->> @chat (let [current-participants (->> @chat