Unread indicator on community channel (#14960)

* Unread indicator on community channel
* Unread grey dot made a separate component
This commit is contained in:
Volodymyr Kozieiev 2023-02-02 17:09:37 +00:00 committed by GitHub
parent c2cfb4539f
commit 77a798530d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 64 additions and 29 deletions

View File

@ -0,0 +1,10 @@
(ns quo2.components.common.unread-grey-dot.style
(:require [quo2.foundations.colors :as colors]))
(def unread-grey-dot
{:width 8
:height 8
:border-radius 4
:background-color (colors/theme-colors
colors/neutral-40
colors/neutral-60)})

View File

@ -0,0 +1,8 @@
(ns quo2.components.common.unread-grey-dot.view
(:require [react-native.core :as rn]
[quo2.components.common.unread-grey-dot.style :as style]))
(defn unread-grey-dot
[]
[rn/view
{:style style/unread-grey-dot}])

View File

@ -6,6 +6,7 @@
[quo2.components.markdown.text :as text] [quo2.components.markdown.text :as text]
[quo2.foundations.colors :as colors] [quo2.foundations.colors :as colors]
[quo2.components.community.icon :as community-icon] [quo2.components.community.icon :as community-icon]
[quo2.components.common.unread-grey-dot.view :refer [unread-grey-dot]]
[react-native.core :as rn])) [react-native.core :as rn]))
(defn notification-view (defn notification-view
@ -26,13 +27,7 @@
[counter/counter {:type :default} unread-mentions-count] [counter/counter {:type :default} unread-mentions-count]
unread-messages? unread-messages?
[rn/view [unread-grey-dot]))
{:style {:width 8
:height 8
:border-radius 4
:background-color (colors/theme-colors
colors/neutral-40
colors/neutral-60)}}]))
(defn communities-list-view-item (defn communities-list-view-item
[props [props

View File

@ -5,7 +5,8 @@
[quo2.components.markdown.text :as quo2.text] [quo2.components.markdown.text :as quo2.text]
[quo2.foundations.colors :as colors] [quo2.foundations.colors :as colors]
[quo2.theme :as theme] [quo2.theme :as theme]
[react-native.core :as rn])) [react-native.core :as rn]
[quo2.components.common.unread-grey-dot.view :refer [unread-grey-dot]]))
(defn list-item (defn list-item
[{:keys [name locked? mentions-count unread-messages? [{:keys [name locked? mentions-count unread-messages?
@ -42,7 +43,9 @@
{:color (if (theme/dark?) colors/neutral-60 colors/neutral-40)})) {:color (if (theme/dark?) colors/neutral-60 colors/neutral-40)}))
:weight :medium :weight :medium
:size :paragraph-1} (str "# " name)]] :size :paragraph-1} (str "# " name)]]
[rn/view {:style {:height 20}} [rn/view
{:style {:height 20
:justify-content :center}}
(when (and (not locked?) (when (and (not locked?)
muted?) muted?)
[quo2.icons/icon :i/muted [quo2.icons/icon :i/muted
@ -59,6 +62,4 @@
(not muted?) (not muted?)
(not (pos? (int mentions-count))) (not (pos? (int mentions-count)))
unread-messages?) unread-messages?)
[quo2.icons/icon :i/channel-notification [unread-grey-dot])]]])
{:size 20
:no-color true}])]]])

View File

@ -219,16 +219,21 @@
(re-frame/reg-sub (re-frame/reg-sub
:communities/categorized-channels :communities/categorized-channels
(fn [[_ community-id]] (fn [[_ community-id]]
[(re-frame/subscribe [:communities/community community-id])]) [(re-frame/subscribe [:communities/community community-id])
(fn [[{:keys [joined categories chats]}] [_ _]] (re-frame/subscribe [:chats/chats])])
(fn [[{:keys [joined categories chats]} full-chats-data] [_ community-id]]
(reduce (reduce
(fn [acc [_ {:keys [name categoryID id emoji can-post?]}]] (fn [acc [_ {:keys [name categoryID id emoji can-post?]}]]
(let [category (keyword (get-in categories [categoryID :name] (i18n/label :t/none)))] (let [category (keyword (get-in categories
[categoryID :name]
(i18n/label :t/none)))
{:keys [unviewed-messages-count]} (get full-chats-data (str community-id id))]
(update acc (update acc
category category
#(vec (conj %1 %2)) #(vec (conj %1 %2))
{:name name {:name name
:emoji emoji :emoji emoji
:unread-messages? (pos? unviewed-messages-count)
:locked? (or (not joined) (not can-post?)) :locked? (or (not joined) (not can-post?))
:id id}))) :id id})))
{} {}

View File

@ -145,14 +145,14 @@
:communities :communities
{"0x1" {:id "0x1" {"0x1" {:id "0x1"
:chats {"0x1" {:id "0x1" :name "chat1" :categoryID 1 :can-post? true} :chats {"0x1" {:id "0x1" :name "chat1" :categoryID 1 :can-post? true}
"0x2" {:id "0x1" :name "chat2" :categoryID 1 :can-post? false} "0x2" {:id "0x2" :name "chat2" :categoryID 1 :can-post? false}
"0x3" {:id "0x1" :name "chat3" :categoryID 2 :can-post? true}} "0x3" {:id "0x3" :name "chat3" :categoryID 2 :can-post? true}}
:categories {1 {:id 1 :name "category1"} :categories {1 {:id 1 :name "category1"}
2 {:id 2 :name "category2"}} 2 {:id 2 :name "category2"}}
:joined true}}) :joined true}})
(is (= {:category1 [{:name "chat1" :emoji nil :locked? false :id "0x1"} (is (= {:category1 [{:name "chat1" :emoji nil :locked? false :id "0x1" :unread-messages? false}
{:name "chat2" :emoji nil :locked? true :id "0x1"}] {:name "chat2" :emoji nil :locked? true :id "0x2" :unread-messages? false}]
:category2 [{:name "chat3" :emoji nil :locked? false :id "0x1"}]} :category2 [{:name "chat3" :emoji nil :locked? false :id "0x3" :unread-messages? false}]}
(rf/sub [sub-name "0x1"])))) (rf/sub [sub-name "0x1"]))))
(testing "Channels without categories" (testing "Channels without categories"
(swap! rf-db/app-db assoc (swap! rf-db/app-db assoc
@ -160,12 +160,28 @@
:communities :communities
{"0x1" {:id "0x1" {"0x1" {:id "0x1"
:chats {"0x1" {:id "0x1" :name "chat1" :categoryID 1 :can-post? true} :chats {"0x1" {:id "0x1" :name "chat1" :categoryID 1 :can-post? true}
"0x2" {:id "0x1" :name "chat2" :categoryID 1 :can-post? false} "0x2" {:id "0x2" :name "chat2" :categoryID 1 :can-post? false}
"0x3" {:id "0x1" :name "chat3" :can-post? true}} "0x3" {:id "0x3" :name "chat3" :can-post? true}}
:categories {1 {:id 1 :name "category1"} :categories {1 {:id 1 :name "category1"}
2 {:id 2 :name "category2"}} 2 {:id 2 :name "category2"}}
:joined true}}) :joined true}})
(is (= {:category1 [{:name "chat1" :emoji nil :locked? false :id "0x1"} (is (= {:category1 [{:name "chat1" :emoji nil :locked? false :id "0x1" :unread-messages? false}
{:name "chat2" :emoji nil :locked? true :id "0x1"}] {:name "chat2" :emoji nil :locked? true :id "0x2" :unread-messages? false}]
(keyword (i18n/label :t/none)) [{:name "chat3" :emoji nil :locked? false :id "0x1"}]} (keyword (i18n/label :t/none))
[{:name "chat3" :emoji nil :locked? false :id "0x3" :unread-messages? false}]}
(rf/sub [sub-name "0x1"]))))
(testing "Unread messages"
(swap! rf-db/app-db assoc
:communities/enabled? true
:communities
{"0x1" {:id "0x1"
:chats {"0x1" {:id "0x1" :name "chat1" :categoryID 1 :can-post? true}
"0x2" {:id "0x2" :name "chat2" :categoryID 1 :can-post? false}}
:categories {1 {:id 1 :name "category1"}}
:joined true}}
:chats
{"0x10x1" {:unviewed-messages-count 1}
"0x10x2" {:unviewed-messages-count 0}})
(is (= {:category1 [{:name "chat1" :emoji nil :locked? false :id "0x1" :unread-messages? true}
{:name "chat2" :emoji nil :locked? true :id "0x2" :unread-messages? false}]}
(rf/sub [sub-name "0x1"]))))) (rf/sub [sub-name "0x1"])))))