Persist switcher cards (#14701)

b4bdfd3d...d40290a6
This commit is contained in:
Parvesh Monu 2023-01-05 21:50:09 +05:30 committed by GitHub
parent 7cf17b5d34
commit d6159ac269
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 108 additions and 46 deletions

View File

@ -0,0 +1,41 @@
(ns status-im.data-store.switcher-cards
(:require [clojure.set :as set]
[clojure.walk :as walk]
[utils.re-frame :as rf]
[taoensso.timbre :as log]))
(defn <-rpc
[switcher-cards]
(walk/postwalk-replace
{:cardId :card-id
:screenId :screen-id}
switcher-cards))
(defn rpc->
[switcher-card]
(set/rename-keys switcher-card
{:card-id :cardId
:screen-id :screenId}))
(rf/defn upsert-switcher-card-rpc
[_ switcher-card]
{:json-rpc/call [{:method "wakuext_upsertSwitcherCard"
:params [(rpc-> switcher-card)]
:on-success #()
:on-error #()}]})
(rf/defn delete-switcher-card-rpc
[_ card-id]
{:json-rpc/call [{:method "wakuext_deleteSwitcherCard"
:params [card-id]
:on-success #()
:on-error #()}]})
(rf/defn fetch-switcher-cards-rpc
[_]
{:json-rpc/call [{:method "wakuext_switcherCards"
:params []
:on-success #(rf/dispatch
[:shell/switcher-cards-loaded
(:switcherCards ^js %)])
:on-error #(log/error "Failed to fetch switcher cards" %)}]})

View File

@ -9,6 +9,7 @@
[status-im.data-store.chats :as data-store.chats] [status-im.data-store.chats :as data-store.chats]
[status-im.data-store.invitations :as data-store.invitations] [status-im.data-store.invitations :as data-store.invitations]
[status-im.data-store.settings :as data-store.settings] [status-im.data-store.settings :as data-store.settings]
[status-im.data-store.switcher-cards :as switcher-cards-store]
[status-im.data-store.visibility-status-updates :as visibility-status-updates-store] [status-im.data-store.visibility-status-updates :as visibility-status-updates-store]
[status-im.ethereum.core :as ethereum] [status-im.ethereum.core :as ethereum]
[status-im.ethereum.eip55 :as eip55] [status-im.ethereum.eip55 :as eip55]
@ -473,7 +474,8 @@
(multiaccounts/get-profile-picture) (multiaccounts/get-profile-picture)
(multiaccounts/switch-preview-privacy-mode-flag) (multiaccounts/switch-preview-privacy-mode-flag)
(link-preview/request-link-preview-whitelist) (link-preview/request-link-preview-whitelist)
(visibility-status-updates-store/fetch-visibility-status-updates-rpc)))) (visibility-status-updates-store/fetch-visibility-status-updates-rpc)
(switcher-cards-store/fetch-switcher-cards-rpc))))
(defn get-new-auth-method (defn get-new-auth-method
[auth-method save-password?] [auth-method save-password?]

View File

@ -1,10 +1,12 @@
(ns status-im2.contexts.shell.events (ns status-im2.contexts.shell.events
(:require [utils.re-frame :as rf] (:require [utils.re-frame :as rf]
[re-frame.core :as re-frame] [re-frame.core :as re-frame]
[status-im.utils.core :as utils]
[status-im2.common.constants :as constants] [status-im2.common.constants :as constants]
[status-im2.navigation.events :as navigation] [status-im2.navigation.events :as navigation]
[status-im2.contexts.shell.animation :as animation] [status-im2.contexts.shell.animation :as animation]
[status-im2.contexts.shell.constants :as shell.constants])) [status-im2.contexts.shell.constants :as shell.constants]
[status-im.data-store.switcher-cards :as switcher-cards-store]))
;; Effects ;; Effects
@ -29,59 +31,76 @@
;; Events ;; Events
(rf/defn add-switcher-card (rf/defn switcher-cards-loaded
{:events [:shell/add-switcher-card]} {:events [:shell/switcher-cards-loaded]}
[{:keys [db now] :as cofx} view-id id] [{:keys [db]} loaded-switcher-cards]
{:db (assoc db
:shell/switcher-cards
(utils/index-by :card-id (switcher-cards-store/<-rpc loaded-switcher-cards)))})
(defn calculate-card-data
[db now view-id id]
(case view-id (case view-id
:chat :chat
(let [chat (get-in db [:chats id])] (let [chat (get-in db [:chats id])]
(case (:chat-type chat) (case (:chat-type chat)
constants/one-to-one-chat-type constants/one-to-one-chat-type
{:shell/navigate-from-shell-fx :chats-stack {:navigate-from :chats-stack
:db (assoc-in :card-id id
db :switcher-card {:type shell.constants/one-to-one-chat-card
[:shell/switcher-cards id] :card-id id
{:type shell.constants/one-to-one-chat-card :clock now
:id id :screen-id id}}
:clock now})}
constants/private-group-chat-type constants/private-group-chat-type
{:shell/navigate-from-shell-fx :chats-stack {:navigate-from :chats-stack
:db (assoc-in :card-id id
db :switcher-card {:type shell.constants/private-group-chat-card
[:shell/switcher-cards id] :card-id id
{:type shell.constants/private-group-chat-card :clock now
:id id :screen-id id}}
:clock now})}
constants/community-chat-type constants/community-chat-type
{:shell/navigate-from-shell-fx :communities-stack {:navigate-from :communities-stack
:db (assoc-in :card-id (:community-id chat)
db :switcher-card {:type shell.constants/community-channel-card
[:shell/switcher-cards (:community-id chat)] :card-id (:community-id chat)
{:type shell.constants/community-channel-card :clock now
:id (:community-id chat) :screen-id (:chat-id chat)}}
:clock now
:channel-id (:chat-id chat)})}
nil)) nil))
:community :community
{:shell/navigate-from-shell-fx :communities-stack {:navigate-from :communities-stack
:db (assoc-in :card-id (:community-id id)
db :switcher-card {:type shell.constants/community-card
[:shell/switcher-cards (:community-id id)] :card-id (:community-id id)
{:type shell.constants/community-card :clock now
:id (:community-id id) :screen-id (:community-id id)}}
:clock now
:channel-id nil})}
nil)) nil))
(rf/defn add-switcher-card
{:events [:shell/add-switcher-card]}
[{:keys [db now] :as cofx} view-id id]
(let [card-data (calculate-card-data db now view-id id)
switcher-card (:switcher-card card-data)]
(when card-data
(rf/merge
cofx
{:db (assoc-in
db
[:shell/switcher-cards (:card-id card-data)]
switcher-card)
:shell/navigate-from-shell-fx (:navigate-from card-data)}
(switcher-cards-store/upsert-switcher-card-rpc switcher-card)))))
(rf/defn close-switcher-card (rf/defn close-switcher-card
{:events [:shell/close-switcher-card]} {:events [:shell/close-switcher-card]}
[{:keys [db]} id] [{:keys [db] :as cofx} card-id]
{:db (update-in db [:shell/switcher-cards] dissoc id)}) (rf/merge
cofx
{:db (update db :shell/switcher-cards dissoc card-id)}
(switcher-cards-store/delete-switcher-card-rpc card-id)))
(rf/defn navigate-to-jump-to (rf/defn navigate-to-jump-to
{:events [:shell/navigate-to-jump-to]} {:events [:shell/navigate-to-jump-to]}

View File

@ -47,19 +47,19 @@
(i18n/label :t/jump-to)]) (i18n/label :t/jump-to)])
(defn render-card (defn render-card
[{:keys [id type channel-id] :as card}] [{:keys [type screen-id] :as card}]
(let [card-data (case type (let [card-data (case type
shell.constants/one-to-one-chat-card shell.constants/one-to-one-chat-card
(rf/sub [:shell/one-to-one-chat-card id]) (rf/sub [:shell/one-to-one-chat-card screen-id])
shell.constants/private-group-chat-card shell.constants/private-group-chat-card
(rf/sub [:shell/private-group-chat-card id]) (rf/sub [:shell/private-group-chat-card screen-id])
shell.constants/community-card shell.constants/community-card
(rf/sub [:shell/community-card id]) (rf/sub [:shell/community-card screen-id])
shell.constants/community-channel-card shell.constants/community-channel-card
(rf/sub [:shell/community-channel-card channel-id]) (rf/sub [:shell/community-channel-card screen-id])
nil)] nil)]
[switcher-cards/card (merge card card-data)])) [switcher-cards/card (merge card card-data)]))

View File

@ -3,7 +3,7 @@
"_comment": "Instead use: scripts/update-status-go.sh <rev>", "_comment": "Instead use: scripts/update-status-go.sh <rev>",
"owner": "status-im", "owner": "status-im",
"repo": "status-go", "repo": "status-go",
"version": "d43e06f4c27a900641cd55c2a46002e6f0909c95", "version": "v0.117.3",
"commit-sha1": "d43e06f4c27a900641cd55c2a46002e6f0909c95", "commit-sha1": "d40290a649133eb7b7f450b5c5b74eec28ba232d",
"src-sha256": "18n5h3yx6wxb5l1nvra868dhnyl732zvpdn3mqg4zfsjxmx82np7" "src-sha256": "140j0gbp8nxzncya9mcpvlxnax5ajfl8c32ih20b29n8j525gw66"
} }