mirror of
https://github.com/status-im/status-react.git
synced 2025-01-28 03:36:23 +00:00
Merge pull request #47 from status-im/protocol-integration-bugfixes
Protocol integration bugfixes Former-commit-id: e4c6f6d5318b253d7a84658148177e6ab5c2f851
This commit is contained in:
commit
ea34c72c00
@ -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
|
||||||
|
|
||||||
|
@ -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)))
|
||||||
|
|
||||||
;; -- Protocol --------------------------------------------------------------
|
;; -- Protocol --------------------------------------------------------------
|
||||||
|
|
||||||
@ -148,13 +150,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))
|
||||||
@ -218,8 +222,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]]
|
||||||
@ -245,26 +251,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
|
||||||
@ -276,7 +282,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})]
|
||||||
@ -305,7 +311,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
|
||||||
@ -405,7 +411,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)}]
|
||||||
@ -498,8 +504,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])
|
||||||
)
|
)
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
(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 :refer [timestamp]]
|
[syng-im.utils.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.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]
|
||||||
@ -31,21 +32,22 @@
|
|||||||
(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 create-chat
|
(defn create-chat
|
||||||
([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
|
||||||
@ -54,6 +56,30 @@
|
|||||||
:contacts contacts}))))
|
:contacts contacts}))))
|
||||||
(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))
|
||||||
|
|
||||||
@ -65,29 +91,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)
|
||||||
@ -102,7 +121,7 @@
|
|||||||
(r/single)
|
(r/single)
|
||||||
(aset "is-active" active?)))))
|
(aset "is-active" active?)))))
|
||||||
|
|
||||||
#_(comment
|
(comment
|
||||||
(active-group-chats)
|
(active-group-chats)
|
||||||
|
|
||||||
|
|
||||||
@ -119,10 +138,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)
|
||||||
|
|
||||||
@ -136,4 +154,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")))))
|
||||||
)
|
)
|
||||||
|
@ -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"
|
||||||
|
@ -34,9 +34,9 @@
|
|||||||
:delivery-status {:type "string"
|
:delivery-status {:type "string"
|
||||||
:optional true}}}
|
:optional true}}}
|
||||||
{: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"
|
||||||
@ -106,6 +106,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)))
|
||||||
|
|
||||||
|
@ -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,16 +104,16 @@
|
|||||||
(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
|
||||||
: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 _]
|
||||||
@ -123,8 +123,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
|
||||||
@ -135,8 +135,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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user