mirror of
https://github.com/status-im/status-react.git
synced 2025-01-10 19:16:59 +00:00
No browsing history kept on iOS [#5078]
Signed-off-by: Andrey Shovkoplyas <motor4ik@gmail.com>
This commit is contained in:
parent
3293c37c81
commit
a644075310
@ -1,4 +1,15 @@
|
|||||||
(function () {
|
(function () {
|
||||||
|
var history = window.history;
|
||||||
|
var pushState = history.pushState;
|
||||||
|
history.pushState = function(state) {
|
||||||
|
setTimeout(function () {
|
||||||
|
WebViewBridge.send(JSON.stringify({
|
||||||
|
type: 'navStateChange',
|
||||||
|
navState: { url: location.href, title: document.title }
|
||||||
|
}))
|
||||||
|
}, 100);
|
||||||
|
return pushState.apply(history, arguments);
|
||||||
|
};
|
||||||
|
|
||||||
WebViewBridge.onMessage = function (messageString) {
|
WebViewBridge.onMessage = function (messageString) {
|
||||||
console.log("received from react-native: " + messageString);
|
console.log("received from react-native: " + messageString);
|
||||||
|
@ -6,7 +6,8 @@
|
|||||||
[status-im.data-store.realm.schemas.account.v4.core :as v4]
|
[status-im.data-store.realm.schemas.account.v4.core :as v4]
|
||||||
[status-im.data-store.realm.schemas.account.v5.core :as v5]
|
[status-im.data-store.realm.schemas.account.v5.core :as v5]
|
||||||
[status-im.data-store.realm.schemas.account.v6.core :as v6]
|
[status-im.data-store.realm.schemas.account.v6.core :as v6]
|
||||||
[status-im.data-store.realm.schemas.account.v7.core :as v7]))
|
[status-im.data-store.realm.schemas.account.v7.core :as v7]
|
||||||
|
[status-im.data-store.realm.schemas.account.v8.core :as v8]))
|
||||||
|
|
||||||
;; TODO(oskarth): Add failing test if directory vXX exists but isn't in schemas.
|
;; TODO(oskarth): Add failing test if directory vXX exists but isn't in schemas.
|
||||||
|
|
||||||
@ -31,4 +32,7 @@
|
|||||||
:migration v6/migration}
|
:migration v6/migration}
|
||||||
{:schema v7/schema
|
{:schema v7/schema
|
||||||
:schemaVersion 7
|
:schemaVersion 7
|
||||||
:migration v7/migration}])
|
:migration v7/migration}
|
||||||
|
{:schema v8/schema
|
||||||
|
:schemaVersion 8
|
||||||
|
:migration v8/migration}])
|
||||||
|
@ -1,17 +1,25 @@
|
|||||||
(ns status-im.data-store.realm.schemas.account.v8.browser)
|
(ns status-im.data-store.realm.schemas.account.v8.browser
|
||||||
|
(:require [taoensso.timbre :as log]))
|
||||||
|
|
||||||
(def schema {:name :browser
|
(def schema {:name :browser
|
||||||
:primaryKey :browser-id
|
:primaryKey :browser-id
|
||||||
:properties {:browser-id :string
|
:properties {:browser-id :string
|
||||||
:name :string
|
:name :string
|
||||||
:timestamp :int
|
:timestamp :int
|
||||||
:dapp? {:type :bool
|
:dapp? {:type :bool
|
||||||
:default false}
|
:default false}
|
||||||
:url {:type :string
|
:history-index {:type :int
|
||||||
:optional true}
|
:optional true}
|
||||||
:contact {:type :string
|
:history {:type "string[]"
|
||||||
:optional true}
|
:optional true}}})
|
||||||
:history-index {:type :int
|
|
||||||
:optional true}
|
(defn migration [old-realm new-realm]
|
||||||
:history {:type :vector
|
(log/debug "migrating browser schema v8")
|
||||||
:optional true}}})
|
(let [browsers (.objects new-realm "browser")
|
||||||
|
old-browsers (.objects old-realm "browser")]
|
||||||
|
(dotimes [i (.-length browsers)]
|
||||||
|
(let [browser (aget browsers i)
|
||||||
|
old-browser (aget old-browsers i)
|
||||||
|
url (aget old-browser "url")]
|
||||||
|
(aset browser "history-index" 0)
|
||||||
|
(aset browser "history" (clj->js [url]))))))
|
25
src/status_im/data_store/realm/schemas/account/v8/core.cljs
Normal file
25
src/status_im/data_store/realm/schemas/account/v8/core.cljs
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
(ns status-im.data-store.realm.schemas.account.v8.core
|
||||||
|
(:require [status-im.data-store.realm.schemas.account.v5.chat :as chat]
|
||||||
|
[status-im.data-store.realm.schemas.account.v6.transport :as transport]
|
||||||
|
[status-im.data-store.realm.schemas.account.v1.contact :as contact]
|
||||||
|
[status-im.data-store.realm.schemas.account.v7.message :as message]
|
||||||
|
[status-im.data-store.realm.schemas.account.v1.request :as request]
|
||||||
|
[status-im.data-store.realm.schemas.account.v1.user-status :as user-status]
|
||||||
|
[status-im.data-store.realm.schemas.account.v1.local-storage :as local-storage]
|
||||||
|
[status-im.data-store.realm.schemas.account.v2.mailserver :as mailserver]
|
||||||
|
[status-im.data-store.realm.schemas.account.v8.browser :as browser]
|
||||||
|
[taoensso.timbre :as log]))
|
||||||
|
|
||||||
|
(def schema [chat/schema
|
||||||
|
transport/schema
|
||||||
|
contact/schema
|
||||||
|
message/schema
|
||||||
|
request/schema
|
||||||
|
mailserver/schema
|
||||||
|
user-status/schema
|
||||||
|
local-storage/schema
|
||||||
|
browser/schema])
|
||||||
|
|
||||||
|
(defn migration [old-realm new-realm]
|
||||||
|
(log/debug "migrating v8 account database: " old-realm new-realm)
|
||||||
|
(browser/migration old-realm new-realm))
|
38
src/status_im/models/browser.cljs
Normal file
38
src/status_im/models/browser.cljs
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
(ns status-im.models.browser
|
||||||
|
(:require [status-im.data-store.browser :as browser-store]))
|
||||||
|
|
||||||
|
(defn get-current-url [{:keys [history history-index]}]
|
||||||
|
(when (and history-index history)
|
||||||
|
(nth history history-index)))
|
||||||
|
|
||||||
|
(defn can-go-back? [{:keys [history-index]}]
|
||||||
|
(pos? history-index))
|
||||||
|
|
||||||
|
(defn can-go-forward? [{:keys [history-index history]}]
|
||||||
|
(< history-index (dec (count history))))
|
||||||
|
|
||||||
|
(defn update-browser-fx [{:keys [db now]} browser]
|
||||||
|
(let [updated-browser (assoc browser :timestamp now)]
|
||||||
|
{:db (update-in db [:browser/browsers (:browser-id updated-browser)]
|
||||||
|
merge updated-browser)
|
||||||
|
:data-store/tx [(browser-store/save-browser-tx updated-browser)]}))
|
||||||
|
|
||||||
|
(defn update-browser-history-fx [cofx browser url loading?]
|
||||||
|
(when-not loading?
|
||||||
|
(let [history-index (:history-index browser)
|
||||||
|
history (:history browser)
|
||||||
|
history-url (try (nth history history-index) (catch js/Error _))]
|
||||||
|
(when (not= history-url url)
|
||||||
|
(let [slash? (= url (str history-url "/"))
|
||||||
|
new-history (if slash?
|
||||||
|
(assoc history history-index url)
|
||||||
|
(conj (subvec history 0 (inc history-index)) url))
|
||||||
|
new-index (if slash?
|
||||||
|
history-index
|
||||||
|
(dec (count new-history)))]
|
||||||
|
(update-browser-fx cofx
|
||||||
|
(assoc browser :history new-history :history-index new-index)))))))
|
||||||
|
|
||||||
|
(defn update-browser-and-navigate [cofx browser]
|
||||||
|
(merge (update-browser-fx cofx browser)
|
||||||
|
{:dispatch [:navigate-to :browser (:browser-id browser)]}))
|
@ -1,56 +0,0 @@
|
|||||||
(ns status-im.models.browser-history
|
|
||||||
(:require [re-frame.core :as re-frame]))
|
|
||||||
|
|
||||||
(defn dont-store-history-on-nav-change? [db]
|
|
||||||
(get-in db [:browser/options :dont-store-history-on-nav-change?]))
|
|
||||||
|
|
||||||
(defn dont-store-history-on-nav-change! []
|
|
||||||
(re-frame/dispatch [:update-browser-options {:dont-store-history-on-nav-change? true}]))
|
|
||||||
|
|
||||||
(defn clear-dont-store-history-on-nav-change! []
|
|
||||||
(re-frame/dispatch [:update-browser-options {:dont-store-history-on-nav-change? false}]))
|
|
||||||
|
|
||||||
(defn dont-store-history-on-nav-change-if-history-exists [db browser-id]
|
|
||||||
(let [browsers (get-in db [:browser/browsers])
|
|
||||||
browser (get browsers browser-id)]
|
|
||||||
(hash-map :dont-store-history-on-nav-change? (some? (:history browser)))))
|
|
||||||
|
|
||||||
(defn back [browser]
|
|
||||||
(let [back-index (dec (:history-index browser))
|
|
||||||
back-url (nth (:history browser) back-index)]
|
|
||||||
(dont-store-history-on-nav-change!)
|
|
||||||
(re-frame/dispatch [:update-browser (-> browser (assoc :url back-url :history-index back-index))])))
|
|
||||||
|
|
||||||
(defn forward [browser]
|
|
||||||
(let [forward-index (inc (:history-index browser))
|
|
||||||
forward-url (nth (:history browser) forward-index)]
|
|
||||||
(dont-store-history-on-nav-change!)
|
|
||||||
(re-frame/dispatch [:update-browser (-> browser (assoc :url forward-url :history-index forward-index))])))
|
|
||||||
|
|
||||||
(defn can-go-back? [browser]
|
|
||||||
(let [hi (:history-index browser)]
|
|
||||||
(and (some? hi) (not= hi 0))))
|
|
||||||
|
|
||||||
(defn can-go-forward? [browser]
|
|
||||||
(let [hi (:history-index browser)]
|
|
||||||
(and (some? hi)
|
|
||||||
(< hi (dec (count (:history browser)))))))
|
|
||||||
|
|
||||||
(defn record-history-in-browser-if-needed [db raw-browser url loading]
|
|
||||||
(let [browser (assoc raw-browser :url url)]
|
|
||||||
(cond
|
|
||||||
loading
|
|
||||||
browser
|
|
||||||
|
|
||||||
(dont-store-history-on-nav-change? db)
|
|
||||||
(do (clear-dont-store-history-on-nav-change!)
|
|
||||||
browser)
|
|
||||||
|
|
||||||
:else
|
|
||||||
(let [history-index (:history-index browser)
|
|
||||||
history (or (:history browser) [])
|
|
||||||
history-url (if history-index (nth history history-index) nil)
|
|
||||||
history-to-index (if history-index (subvec history 0 (inc history-index)) [])
|
|
||||||
new-history (if (not= history-url url) (conj history-to-index url) history)
|
|
||||||
new-index (dec (count new-history))]
|
|
||||||
(assoc browser :history new-history :history-index new-index)))))
|
|
@ -31,7 +31,7 @@
|
|||||||
(defn browse [link]
|
(defn browse [link]
|
||||||
(show {:title (i18n/label :t/browsing-title)
|
(show {:title (i18n/label :t/browsing-title)
|
||||||
:options [{:label (i18n/label :t/browsing-open-in-browser)
|
:options [{:label (i18n/label :t/browsing-open-in-browser)
|
||||||
:action #(re-frame/dispatch [:open-browser {:url link}])}
|
:action #(re-frame/dispatch [:open-url-in-browser link])}
|
||||||
{:label (i18n/label :t/browsing-open-in-web-browser)
|
{:label (i18n/label :t/browsing-open-in-web-browser)
|
||||||
:action #(.openURL react/linking (http/normalize-url link))}]
|
:action #(.openURL react/linking (http/normalize-url link))}]
|
||||||
:cancel-text (i18n/label :t/browsing-cancel)}))
|
:cancel-text (i18n/label :t/browsing-cancel)}))
|
||||||
@ -39,5 +39,5 @@
|
|||||||
(defn browse-dapp [link]
|
(defn browse-dapp [link]
|
||||||
(show {:title (i18n/label :t/browsing-title)
|
(show {:title (i18n/label :t/browsing-title)
|
||||||
:options [{:label (i18n/label :t/browsing-open-in-browser)
|
:options [{:label (i18n/label :t/browsing-open-in-browser)
|
||||||
:action #(re-frame/dispatch [:open-browser {:url link}])}]
|
:action #(re-frame/dispatch [:open-url-in-browser link])}]
|
||||||
:cancel-text (i18n/label :t/browsing-cancel)}))
|
:cancel-text (i18n/label :t/browsing-cancel)}))
|
||||||
|
@ -31,7 +31,7 @@
|
|||||||
[react/text-input {:on-change-text #(reset! url-text %)
|
[react/text-input {:on-change-text #(reset! url-text %)
|
||||||
:on-submit-editing #(do
|
:on-submit-editing #(do
|
||||||
(re-frame/dispatch [:navigate-to-clean :home])
|
(re-frame/dispatch [:navigate-to-clean :home])
|
||||||
(re-frame/dispatch [:open-browser {:url @url-text}]))
|
(re-frame/dispatch [:open-url-in-browser @url-text]))
|
||||||
:placeholder (i18n/label :t/enter-url)
|
:placeholder (i18n/label :t/enter-url)
|
||||||
:auto-capitalize :none
|
:auto-capitalize :none
|
||||||
:auto-correct false
|
:auto-correct false
|
||||||
|
@ -9,18 +9,14 @@
|
|||||||
(spec/def :browser/photo-path (spec/nilable string?))
|
(spec/def :browser/photo-path (spec/nilable string?))
|
||||||
(spec/def :browser/name (spec/nilable string?))
|
(spec/def :browser/name (spec/nilable string?))
|
||||||
(spec/def :browser/dapp? (spec/nilable boolean?))
|
(spec/def :browser/dapp? (spec/nilable boolean?))
|
||||||
(spec/def :browser/fullscreen? (spec/nilable boolean?))
|
|
||||||
(spec/def :browser/error? (spec/nilable boolean?))
|
(spec/def :browser/error? (spec/nilable boolean?))
|
||||||
(spec/def :browser/history (spec/nilable vector?))
|
(spec/def :browser/history (spec/nilable vector?))
|
||||||
(spec/def :browser/history-index (spec/nilable int?))
|
(spec/def :browser/history-index (spec/nilable int?))
|
||||||
(spec/def :browser/dont-store-history-on-nav-change? (spec/nilable boolean?))
|
|
||||||
|
|
||||||
(spec/def :browser/options
|
(spec/def :browser/options
|
||||||
(allowed-keys
|
(allowed-keys
|
||||||
:opt-un [:browser/browser-id
|
:opt-un [:browser/browser-id
|
||||||
:browser/fullscreen?
|
:browser/error?]))
|
||||||
:browser/error?
|
|
||||||
:browser/dont-store-history-on-nav-change?]))
|
|
||||||
|
|
||||||
(spec/def :browser/browser
|
(spec/def :browser/browser
|
||||||
(allowed-keys
|
(allowed-keys
|
||||||
@ -28,8 +24,6 @@
|
|||||||
:browser/timestamp]
|
:browser/timestamp]
|
||||||
:opt-un [:browser/name
|
:opt-un [:browser/name
|
||||||
:browser/dapp?
|
:browser/dapp?
|
||||||
:browser/url
|
|
||||||
:browser/contact
|
|
||||||
:browser/history
|
:browser/history
|
||||||
:browser/history-index]))
|
:browser/history-index]))
|
||||||
|
|
||||||
|
@ -1,6 +1,5 @@
|
|||||||
(ns status-im.ui.screens.browser.events
|
(ns status-im.ui.screens.browser.events
|
||||||
(:require status-im.ui.screens.browser.navigation
|
(:require status-im.ui.screens.browser.navigation
|
||||||
[status-im.models.browser-history :as browser-history]
|
|
||||||
[status-im.utils.handlers :as handlers]
|
[status-im.utils.handlers :as handlers]
|
||||||
[re-frame.core :as re-frame]
|
[re-frame.core :as re-frame]
|
||||||
[status-im.utils.random :as random]
|
[status-im.utils.random :as random]
|
||||||
@ -8,7 +7,15 @@
|
|||||||
[status-im.ui.components.list-selection :as list-selection]
|
[status-im.ui.components.list-selection :as list-selection]
|
||||||
[status-im.utils.universal-links.core :as utils.universal-links]
|
[status-im.utils.universal-links.core :as utils.universal-links]
|
||||||
[status-im.data-store.browser :as browser-store]
|
[status-im.data-store.browser :as browser-store]
|
||||||
[status-im.utils.http :as http]))
|
[status-im.utils.http :as http]
|
||||||
|
[status-im.models.browser :as model]))
|
||||||
|
|
||||||
|
(re-frame/reg-fx
|
||||||
|
:browse
|
||||||
|
(fn [link]
|
||||||
|
(if (utils.universal-links/universal-link? link)
|
||||||
|
(utils.universal-links/open! link)
|
||||||
|
(list-selection/browse link))))
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:initialize-browsers
|
:initialize-browsers
|
||||||
@ -17,71 +24,49 @@
|
|||||||
(let [browsers (into {} (map #(vector (:browser-id %) %) all-stored-browsers))]
|
(let [browsers (into {} (map #(vector (:browser-id %) %) all-stored-browsers))]
|
||||||
{:db (assoc db :browser/browsers browsers)})))
|
{:db (assoc db :browser/browsers browsers)})))
|
||||||
|
|
||||||
(re-frame/reg-fx
|
|
||||||
:browse
|
|
||||||
(fn [link]
|
|
||||||
(if (utils.universal-links/universal-link? link)
|
|
||||||
(do
|
|
||||||
(utils.universal-links/open! link))
|
|
||||||
(list-selection/browse link))))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:browse-link-from-message
|
:browse-link-from-message
|
||||||
(fn [_ [_ link]]
|
(fn [_ [_ link]]
|
||||||
{:browse link}))
|
{:browse link}))
|
||||||
|
|
||||||
(defn get-new-browser [browser now]
|
|
||||||
(cond-> browser
|
|
||||||
true
|
|
||||||
(assoc :timestamp now)
|
|
||||||
(not (:browser-id browser))
|
|
||||||
(assoc :browser-id (random/id))
|
|
||||||
(not (:name browser))
|
|
||||||
(assoc :name (i18n/label :t/browser))
|
|
||||||
(:url browser)
|
|
||||||
(update :url (comp js/decodeURI http/normalize-url))))
|
|
||||||
|
|
||||||
(defn add-browser-fx [{:keys [db now]} browser]
|
|
||||||
(let [new-browser (get-new-browser browser now)]
|
|
||||||
{:db (update-in db [:browser/browsers (:browser-id new-browser)]
|
|
||||||
merge new-browser)
|
|
||||||
:data-store/tx [(browser-store/save-browser-tx new-browser)]}))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:open-dapp-in-browser
|
:open-dapp-in-browser
|
||||||
[re-frame/trim-v]
|
[re-frame/trim-v]
|
||||||
(fn [cofx [{:keys [name dapp-url]}]]
|
(fn [cofx [{:keys [name dapp-url]}]]
|
||||||
(let [browser {:browser-id name
|
(let [browser {:browser-id name
|
||||||
:name name
|
:name name
|
||||||
:dapp? true
|
:dapp? true
|
||||||
:url dapp-url}]
|
:history-index 0
|
||||||
(merge (add-browser-fx cofx browser)
|
:history [(http/normalize-and-decode-url dapp-url)]}]
|
||||||
{:dispatch [:navigate-to :browser {:browser/browser-id (:browser-id browser)}]}))))
|
(model/update-browser-and-navigate cofx browser))))
|
||||||
|
|
||||||
|
(handlers/register-handler-fx
|
||||||
|
:open-url-in-browser
|
||||||
|
[re-frame/trim-v]
|
||||||
|
(fn [cofx [url]]
|
||||||
|
(let [browser {:browser-id (random/id)
|
||||||
|
:name (i18n/label :t/browser)
|
||||||
|
:history-index 0
|
||||||
|
:history [(http/normalize-and-decode-url url)]}]
|
||||||
|
(model/update-browser-and-navigate cofx browser))))
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:open-browser
|
:open-browser
|
||||||
[re-frame/trim-v]
|
[re-frame/trim-v]
|
||||||
(fn [{:keys [now] :as cofx} [browser]]
|
(fn [cofx [browser]]
|
||||||
(let [new-browser (get-new-browser browser now)]
|
(model/update-browser-and-navigate cofx browser)))
|
||||||
(merge (add-browser-fx cofx new-browser)
|
|
||||||
{:dispatch [:navigate-to :browser {:browser/browser-id (:browser-id new-browser)}]}))))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:update-browser
|
:update-browser
|
||||||
[re-frame/trim-v]
|
[re-frame/trim-v]
|
||||||
(fn [{:keys [now] :as cofx} [browser]]
|
(fn [cofx [browser]]
|
||||||
(let [new-browser (get-new-browser browser now)]
|
(model/update-browser-fx cofx browser)))
|
||||||
(-> (add-browser-fx cofx new-browser)
|
|
||||||
(update-in [:db :browser/options] #(assoc % :browser-id (:browser-id new-browser)))))))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:update-browser-on-nav-change
|
:update-browser-on-nav-change
|
||||||
[re-frame/trim-v]
|
[re-frame/trim-v]
|
||||||
(fn [{:keys [db now] :as cofx} [browser url loading]]
|
(fn [cofx [browser url loading]]
|
||||||
(let [new-browser (get-new-browser browser now)
|
(model/update-browser-history-fx cofx browser url loading)))
|
||||||
new-browser-with-history-updated (browser-history/record-history-in-browser-if-needed db new-browser url loading)]
|
|
||||||
(-> (add-browser-fx cofx new-browser-with-history-updated)
|
|
||||||
(update-in [:db :browser/options] assoc :browser-id (:browser-id new-browser-with-history-updated))))))
|
|
||||||
|
|
||||||
(handlers/register-handler-fx
|
(handlers/register-handler-fx
|
||||||
:update-browser-options
|
:update-browser-options
|
||||||
@ -95,3 +80,20 @@
|
|||||||
(fn [{:keys [db]} [browser-id]]
|
(fn [{:keys [db]} [browser-id]]
|
||||||
{:db (update-in db [:browser/browsers] dissoc browser-id)
|
{:db (update-in db [:browser/browsers] dissoc browser-id)
|
||||||
:data-store/tx [(browser-store/remove-browser-tx browser-id)]}))
|
:data-store/tx [(browser-store/remove-browser-tx browser-id)]}))
|
||||||
|
|
||||||
|
(defn nav-update-browser [cofx browser history-index]
|
||||||
|
(model/update-browser-fx cofx (assoc browser :history-index history-index)))
|
||||||
|
|
||||||
|
(handlers/register-handler-fx
|
||||||
|
:browser-nav-back
|
||||||
|
[re-frame/trim-v]
|
||||||
|
(fn [cofx [{:keys [history-index] :as browser}]]
|
||||||
|
(when (pos? history-index)
|
||||||
|
(nav-update-browser cofx browser (dec history-index)))))
|
||||||
|
|
||||||
|
(handlers/register-handler-fx
|
||||||
|
:browser-nav-forward
|
||||||
|
[re-frame/trim-v]
|
||||||
|
(fn [cofx [{:keys [history-index] :as browser}]]
|
||||||
|
(when (< history-index (dec (count (:history browser))))
|
||||||
|
(nav-update-browser cofx browser (inc history-index)))))
|
@ -1,8 +1,6 @@
|
|||||||
(ns status-im.ui.screens.browser.navigation
|
(ns status-im.ui.screens.browser.navigation
|
||||||
(:require [status-im.ui.screens.navigation :as navigation]
|
(:require [status-im.ui.screens.navigation :as navigation]))
|
||||||
[status-im.models.browser-history :as browser-history]))
|
|
||||||
|
|
||||||
(defmethod navigation/preload-data! :browser
|
(defmethod navigation/preload-data! :browser
|
||||||
[db [_ _ {:keys [browser/browser-id]}]]
|
[db [_ _ browser-id]]
|
||||||
(let [dont-store (browser-history/dont-store-history-on-nav-change-if-history-exists db browser-id)]
|
(assoc db :browser/options {:browser-id browser-id}))
|
||||||
(assoc db :browser/options (assoc dont-store :browser-id browser-id))))
|
|
||||||
|
@ -3,7 +3,6 @@
|
|||||||
[status-im.utils.views :as views])
|
[status-im.utils.views :as views])
|
||||||
(:require [cljs.reader :as reader]
|
(:require [cljs.reader :as reader]
|
||||||
[re-frame.core :as re-frame]
|
[re-frame.core :as re-frame]
|
||||||
[status-im.models.browser-history :as browser-history]
|
|
||||||
[status-im.ui.components.react :as react]
|
[status-im.ui.components.react :as react]
|
||||||
[status-im.ui.screens.browser.styles :as styles]
|
[status-im.ui.screens.browser.styles :as styles]
|
||||||
[status-im.ui.components.status-bar.view :as status-bar]
|
[status-im.ui.components.status-bar.view :as status-bar]
|
||||||
@ -17,7 +16,9 @@
|
|||||||
[status-im.i18n :as i18n]
|
[status-im.i18n :as i18n]
|
||||||
[status-im.utils.ethereum.core :as ethereum]
|
[status-im.utils.ethereum.core :as ethereum]
|
||||||
[status-im.ui.components.toolbar.actions :as actions]
|
[status-im.ui.components.toolbar.actions :as actions]
|
||||||
[status-im.ui.components.tooltip.views :as tooltip]))
|
[status-im.ui.components.tooltip.views :as tooltip]
|
||||||
|
[status-im.models.browser :as model]
|
||||||
|
[status-im.utils.platform :as platform]))
|
||||||
|
|
||||||
(views/defview toolbar-content-dapp [name]
|
(views/defview toolbar-content-dapp [name]
|
||||||
(views/letsubs [dapp [:get-dapp-by-name name]]
|
(views/letsubs [dapp [:get-dapp-by-name name]]
|
||||||
@ -36,7 +37,7 @@
|
|||||||
(def browser-config
|
(def browser-config
|
||||||
(reader/read-string (slurp "./src/status_im/utils/browser_config.edn")))
|
(reader/read-string (slurp "./src/status_im/utils/browser_config.edn")))
|
||||||
|
|
||||||
(defn toolbar-content [{:keys [url] :as browser}]
|
(defn toolbar-content [url browser]
|
||||||
(let [url-text (atom url)]
|
(let [url-text (atom url)]
|
||||||
[react/view
|
[react/view
|
||||||
[react/view (styles/toolbar-content false)
|
[react/view (styles/toolbar-content false)
|
||||||
@ -64,6 +65,13 @@
|
|||||||
[react/view styles/web-view-loading
|
[react/view styles/web-view-loading
|
||||||
[components/activity-indicator {:animating true}]]))
|
[components/activity-indicator {:animating true}]]))
|
||||||
|
|
||||||
|
(defn on-bridge-message [message browser]
|
||||||
|
(let [{:strs [type navState]} (js->clj (.parse js/JSON message))
|
||||||
|
{:strs [url]} navState]
|
||||||
|
(when (and platform/ios? (= type "navStateChange"))
|
||||||
|
(when (not= "about:blank" url)
|
||||||
|
(re-frame/dispatch [:update-browser-on-nav-change browser url false])))))
|
||||||
|
|
||||||
(defn on-navigation-change [event browser]
|
(defn on-navigation-change [event browser]
|
||||||
(let [{:strs [url loading]} (js->clj event)]
|
(let [{:strs [url loading]} (js->clj event)]
|
||||||
(when (not= "about:blank" url)
|
(when (not= "about:blank" url)
|
||||||
@ -74,25 +82,28 @@
|
|||||||
(get (:inject-js browser-config) domain-name)))
|
(get (:inject-js browser-config) domain-name)))
|
||||||
|
|
||||||
(views/defview browser []
|
(views/defview browser []
|
||||||
(views/letsubs [webview (atom nil)
|
(views/letsubs [webview (atom nil)
|
||||||
{:keys [address]} [:get-current-account]
|
{:keys [address]} [:get-current-account]
|
||||||
{:keys [dapp? url browser-id name] :as browser} [:get-current-browser]
|
{:keys [dapp? browser-id name] :as browser} [:get-current-browser]
|
||||||
{:keys [can-go-back? can-go-forward? error?]} [:get :browser/options]
|
{:keys [error?]} [:get :browser/options]
|
||||||
rpc-url [:get :rpc-url]
|
rpc-url [:get :rpc-url]
|
||||||
network-id [:get-network-id]]
|
network-id [:get-network-id]]
|
||||||
[react/keyboard-avoiding-view styles/browser
|
(let [can-go-back? (model/can-go-back? browser)
|
||||||
[status-bar/status-bar]
|
can-go-forward? (model/can-go-forward? browser)
|
||||||
[toolbar.view/toolbar {}
|
url (model/get-current-url browser)]
|
||||||
[toolbar.view/nav-button-with-count
|
[react/keyboard-avoiding-view styles/browser
|
||||||
(actions/close (fn []
|
[status-bar/status-bar]
|
||||||
(.sendToBridge @webview "navigate-to-blank")
|
[toolbar.view/toolbar {}
|
||||||
(re-frame/dispatch [:navigate-back])
|
[toolbar.view/nav-button-with-count
|
||||||
(when error?
|
(actions/close (fn []
|
||||||
(re-frame/dispatch [:remove-browser browser-id]))))]
|
(when @webview
|
||||||
(if dapp?
|
(.sendToBridge @webview "navigate-to-blank"))
|
||||||
[toolbar-content-dapp name]
|
(re-frame/dispatch [:navigate-back])
|
||||||
[toolbar-content browser])]
|
(when error?
|
||||||
(if url
|
(re-frame/dispatch [:remove-browser browser-id]))))]
|
||||||
|
(if dapp?
|
||||||
|
[toolbar-content-dapp name]
|
||||||
|
[toolbar-content url browser])]
|
||||||
[components.webview-bridge/webview-bridge
|
[components.webview-bridge/webview-bridge
|
||||||
{:ref #(reset! webview %)
|
{:ref #(reset! webview %)
|
||||||
:source {:uri url}
|
:source {:uri url}
|
||||||
@ -103,6 +114,7 @@
|
|||||||
:render-error web-view-error
|
:render-error web-view-error
|
||||||
:render-loading web-view-loading
|
:render-loading web-view-loading
|
||||||
:on-navigation-state-change #(on-navigation-change % browser)
|
:on-navigation-state-change #(on-navigation-change % browser)
|
||||||
|
:on-bridge-message #(on-bridge-message % browser)
|
||||||
:on-load #(re-frame/dispatch [:update-browser-options {:error? false}])
|
:on-load #(re-frame/dispatch [:update-browser-options {:error? false}])
|
||||||
:on-error #(re-frame/dispatch [:update-browser-options {:error? true}])
|
:on-error #(re-frame/dispatch [:update-browser-options {:error? true}])
|
||||||
:injected-on-start-loading-java-script (str js-res/web3
|
:injected-on-start-loading-java-script (str js-res/web3
|
||||||
@ -112,21 +124,20 @@
|
|||||||
(ethereum/normalized-address address)
|
(ethereum/normalized-address address)
|
||||||
(str network-id)))
|
(str network-id)))
|
||||||
:injected-java-script js-res/webview-js}]
|
:injected-java-script js-res/webview-js}]
|
||||||
[react/view styles/background
|
[react/view styles/toolbar
|
||||||
[react/text (i18n/label :t/enter-dapp-url)]])
|
[react/touchable-highlight {:on-press #(re-frame/dispatch [:browser-nav-back browser])
|
||||||
[react/view styles/toolbar
|
:disabled (not can-go-back?)
|
||||||
[react/touchable-highlight {:on-press #(browser-history/back browser)
|
:style (when-not can-go-back? styles/disabled-button)
|
||||||
:disabled (not (browser-history/can-go-back? browser))
|
:accessibility-label :previou-page-button}
|
||||||
:style (if (not (browser-history/can-go-back? browser)) styles/disabled-button)
|
[react/view
|
||||||
:accessibility-label :previou-page-button}
|
[vector-icons/icon :icons/arrow-left]]]
|
||||||
[react/view
|
[react/touchable-highlight {:on-press #(re-frame/dispatch [:browser-nav-forward browser])
|
||||||
[vector-icons/icon :icons/arrow-left]]]
|
:disabled (not can-go-forward?)
|
||||||
[react/touchable-highlight {:on-press #(browser-history/forward browser)
|
:style (merge styles/forward-button
|
||||||
:disabled (not (browser-history/can-go-forward? browser))
|
(when-not can-go-forward? styles/disabled-button))
|
||||||
:style (merge styles/forward-button (if (not (browser-history/can-go-forward? browser)) styles/disabled-button))
|
:accessibility-label :next-page-button}
|
||||||
:accessibility-label :next-page-button}
|
[react/view
|
||||||
[react/view
|
[vector-icons/icon :icons/arrow-right]]]]
|
||||||
[vector-icons/icon :icons/arrow-right]]]]
|
(when-not dapp?
|
||||||
(when-not dapp?
|
[tooltip/bottom-tooltip-info
|
||||||
[tooltip/bottom-tooltip-info
|
(i18n/label :t/browser-warning)])])))
|
||||||
(i18n/label :t/browser-warning)])]))
|
|
||||||
|
@ -93,7 +93,7 @@
|
|||||||
(spec/def :navigation/prev-view-id (spec/nilable keyword?))
|
(spec/def :navigation/prev-view-id (spec/nilable keyword?))
|
||||||
;; navigation screen params
|
;; navigation screen params
|
||||||
(spec/def :navigation.screen-params/network-details (allowed-keys :req [:networks/selected-network]))
|
(spec/def :navigation.screen-params/network-details (allowed-keys :req [:networks/selected-network]))
|
||||||
(spec/def :navigation.screen-params/browser (allowed-keys :req [:browser/browser-id]))
|
(spec/def :navigation.screen-params/browser (spec/nilable string?))
|
||||||
(spec/def :navigation.screen-params.profile-qr-viewer/contact (spec/nilable map?))
|
(spec/def :navigation.screen-params.profile-qr-viewer/contact (spec/nilable map?))
|
||||||
(spec/def :navigation.screen-params.profile-qr-viewer/source (spec/nilable keyword?))
|
(spec/def :navigation.screen-params.profile-qr-viewer/source (spec/nilable keyword?))
|
||||||
(spec/def :navigation.screen-params.profile-qr-viewer/value (spec/nilable string?))
|
(spec/def :navigation.screen-params.profile-qr-viewer/value (spec/nilable string?))
|
||||||
|
@ -16,7 +16,8 @@
|
|||||||
[status-im.ui.components.chat-preview :as chat-preview]
|
[status-im.ui.components.chat-preview :as chat-preview]
|
||||||
[status-im.ui.components.icons.vector-icons :as vector-icons]
|
[status-im.ui.components.icons.vector-icons :as vector-icons]
|
||||||
[status-im.ui.components.chat-icon.screen :as chat-icon.screen]
|
[status-im.ui.components.chat-icon.screen :as chat-icon.screen]
|
||||||
[status-im.ui.components.common.common :as components.common]))
|
[status-im.ui.components.common.common :as components.common]
|
||||||
|
[status-im.models.browser :as model]))
|
||||||
|
|
||||||
(defn command-short-preview
|
(defn command-short-preview
|
||||||
[{:keys [command] {:keys [amount asset]} :params}]
|
[{:keys [command] {:keys [amount asset]} :params}]
|
||||||
@ -111,8 +112,9 @@
|
|||||||
[message-content-text last-message]
|
[message-content-text last-message]
|
||||||
[unviewed-indicator chat-id]]]]])))
|
[unviewed-indicator chat-id]]]]])))
|
||||||
|
|
||||||
(defview home-list-browser-item-inner-view [{:keys [name url] :as browser}]
|
(defview home-list-browser-item-inner-view [{:keys [name] :as browser}]
|
||||||
(letsubs [dapp [:get-dapp-by-name name]]
|
(letsubs [dapp [:get-dapp-by-name name]
|
||||||
|
url (model/get-current-url browser)]
|
||||||
[react/touchable-highlight {:on-press #(re-frame/dispatch [:open-browser browser])}
|
[react/touchable-highlight {:on-press #(re-frame/dispatch [:open-browser browser])}
|
||||||
[react/view styles/chat-container
|
[react/view styles/chat-container
|
||||||
[react/view styles/chat-icon-container
|
[react/view styles/chat-icon-container
|
||||||
|
@ -25,4 +25,4 @@
|
|||||||
:icon-opts {:color colors/blue}
|
:icon-opts {:color colors/blue}
|
||||||
:accessibility-label :open-collectible-button
|
:accessibility-label :open-collectible-button
|
||||||
:on-press #(re-frame/dispatch [:open-collectible-in-browser
|
:on-press #(re-frame/dispatch [:open-collectible-in-browser
|
||||||
{:url (str "https://www.cryptokitties.co/kitty/" id)}])}]])
|
(str "https://www.cryptokitties.co/kitty/" id)])}]])
|
@ -24,4 +24,4 @@
|
|||||||
:icon :icons/address
|
:icon :icons/address
|
||||||
:icon-opts {:color colors/blue}
|
:icon-opts {:color colors/blue}
|
||||||
:accessibility-label :open-collectible-button
|
:accessibility-label :open-collectible-button
|
||||||
:on-press #(re-frame/dispatch [:open-collectible-in-browser {:url external_url}])}]])
|
:on-press #(re-frame/dispatch [:open-collectible-in-browser external_url])}]])
|
||||||
|
@ -24,4 +24,4 @@
|
|||||||
:icon-opts {:color colors/blue}
|
:icon-opts {:color colors/blue}
|
||||||
:accessibility-label :open-collectible-button
|
:accessibility-label :open-collectible-button
|
||||||
:on-press #(re-frame/dispatch [:open-collectible-in-browser
|
:on-press #(re-frame/dispatch [:open-collectible-in-browser
|
||||||
{:url (str "https://www.etheremon.com/#/mons/" class_id)}])}]])
|
(str "https://www.etheremon.com/#/mons/" class_id)])}]])
|
||||||
|
@ -63,4 +63,4 @@
|
|||||||
:open-collectible-in-browser
|
:open-collectible-in-browser
|
||||||
[re-frame/trim-v]
|
[re-frame/trim-v]
|
||||||
(fn [_ [data]]
|
(fn [_ [data]]
|
||||||
{:dispatch [:open-browser data]}))
|
{:dispatch [:open-url-in-browser data]}))
|
@ -61,7 +61,9 @@
|
|||||||
(utils/show-popup "Error" (str error))))))))
|
(utils/show-popup "Error" (str error))))))))
|
||||||
|
|
||||||
(defn normalize-url [url]
|
(defn normalize-url [url]
|
||||||
(str (when (and url (not (re-find #"^[a-zA-Z-_]+:/" url))) "http://") url))
|
(str (when (and (string? url) (not (re-find #"^[a-zA-Z-_]+:/" url))) "http://") url))
|
||||||
|
|
||||||
|
(def normalize-and-decode-url (comp js/decodeURI normalize-url))
|
||||||
|
|
||||||
(defn parse-payload [o]
|
(defn parse-payload [o]
|
||||||
(when o
|
(when o
|
||||||
|
109
test/cljs/status_im/test/browser/events.cljs
Normal file
109
test/cljs/status_im/test/browser/events.cljs
Normal file
@ -0,0 +1,109 @@
|
|||||||
|
(ns status-im.test.browser.events
|
||||||
|
(:require [cljs.test :refer-macros [deftest is testing]]
|
||||||
|
[day8.re-frame.test :refer-macros [run-test-sync]]
|
||||||
|
[status-im.ui.screens.events :as events]
|
||||||
|
status-im.ui.screens.db
|
||||||
|
status-im.ui.screens.subs
|
||||||
|
[re-frame.core :as re-frame]
|
||||||
|
[status-im.models.browser :as model]))
|
||||||
|
|
||||||
|
(defn test-fixtures []
|
||||||
|
|
||||||
|
(re-frame/reg-fx ::events/init-store #())
|
||||||
|
|
||||||
|
(re-frame/reg-fx :browse #())
|
||||||
|
(re-frame/reg-fx :data-store/tx #())
|
||||||
|
|
||||||
|
(re-frame/reg-cofx
|
||||||
|
:data-store/all-browsers
|
||||||
|
(fn [coeffects _]
|
||||||
|
(assoc coeffects :all-stored-browsers []))))
|
||||||
|
|
||||||
|
(deftest browser-events
|
||||||
|
|
||||||
|
(run-test-sync
|
||||||
|
|
||||||
|
(test-fixtures)
|
||||||
|
|
||||||
|
(re-frame/dispatch [:initialize-db])
|
||||||
|
(re-frame/dispatch [:initialize-browsers])
|
||||||
|
|
||||||
|
(let [browsers (re-frame/subscribe [:browsers])
|
||||||
|
dapp1-url "test.com"
|
||||||
|
dapp2-url "http://test2.com"]
|
||||||
|
|
||||||
|
(testing "open and remove dapps"
|
||||||
|
|
||||||
|
(is (zero? (count @browsers)))
|
||||||
|
|
||||||
|
(re-frame/dispatch [:open-dapp-in-browser {:name "Test Dapp"
|
||||||
|
:dapp-url dapp1-url
|
||||||
|
:description "Test description"}])
|
||||||
|
|
||||||
|
(is (= 1 (count @browsers)))
|
||||||
|
|
||||||
|
(re-frame/dispatch [:open-url-in-browser dapp2-url])
|
||||||
|
|
||||||
|
(is (= 2 (count @browsers)))
|
||||||
|
|
||||||
|
(let [browser1 (first (vals @browsers))
|
||||||
|
browser2 (second (vals @browsers))]
|
||||||
|
(is (and (:dapp? browser1)
|
||||||
|
(not (:dapp? browser2))))
|
||||||
|
(is (and (zero? (:history-index browser1))
|
||||||
|
(zero? (:history-index browser2))))
|
||||||
|
(is (and (= [(str "http://" dapp1-url) (:history browser1)])
|
||||||
|
(= [dapp2-url] (:history browser2)))))
|
||||||
|
|
||||||
|
(re-frame/dispatch [:remove-browser "Test Dapp"])
|
||||||
|
|
||||||
|
(is (= 1 (count @browsers))))
|
||||||
|
|
||||||
|
(testing "navigate dapp"
|
||||||
|
|
||||||
|
(re-frame/dispatch [:open-browser (first (vals @browsers))])
|
||||||
|
|
||||||
|
(let [browser (re-frame/subscribe [:get-current-browser])
|
||||||
|
options (re-frame/subscribe [:get :browser/options])
|
||||||
|
dapp2-url2 (str dapp2-url "/nav2")
|
||||||
|
dapp2-url3 (str dapp2-url "/nav3")]
|
||||||
|
|
||||||
|
(is (zero? (:history-index @browser)))
|
||||||
|
(is (= [dapp2-url] (:history @browser)))
|
||||||
|
|
||||||
|
(is (and (not (model/can-go-back? @browser))
|
||||||
|
(not (model/can-go-forward? @browser))))
|
||||||
|
|
||||||
|
(re-frame/dispatch [:browser-nav-back])
|
||||||
|
(re-frame/dispatch [:browser-nav-forward])
|
||||||
|
|
||||||
|
(re-frame/dispatch [:update-browser-on-nav-change @browser dapp2-url2 false])
|
||||||
|
|
||||||
|
(is (= 1 (:history-index @browser)))
|
||||||
|
(is (= [dapp2-url dapp2-url2] (:history @browser)))
|
||||||
|
|
||||||
|
(is (and (model/can-go-back? @browser)
|
||||||
|
(not (model/can-go-forward? @browser))))
|
||||||
|
|
||||||
|
(re-frame/dispatch [:browser-nav-back @browser])
|
||||||
|
|
||||||
|
(is (zero? (:history-index @browser)))
|
||||||
|
(is (= [dapp2-url dapp2-url2] (:history @browser)))
|
||||||
|
|
||||||
|
(is (and (not (model/can-go-back? @browser))
|
||||||
|
(model/can-go-forward? @browser)))
|
||||||
|
|
||||||
|
(re-frame/dispatch [:update-browser-on-nav-change @browser dapp2-url3 false])
|
||||||
|
|
||||||
|
(is (= 1 (:history-index @browser)))
|
||||||
|
(is (= [dapp2-url dapp2-url3] (:history @browser)))
|
||||||
|
|
||||||
|
(re-frame/dispatch [:browser-nav-back @browser])
|
||||||
|
|
||||||
|
(is (zero? (:history-index @browser)))
|
||||||
|
(is (= [dapp2-url dapp2-url3] (:history @browser)))
|
||||||
|
|
||||||
|
(re-frame/dispatch [:browser-nav-forward @browser])
|
||||||
|
|
||||||
|
(is (= 1 (:history-index @browser)))
|
||||||
|
(is (= [dapp2-url dapp2-url3] (:history @browser))))))))
|
@ -1,117 +0,0 @@
|
|||||||
(ns status-im.test.models.browser-history
|
|
||||||
(:require [cljs.test :refer-macros [deftest is testing]]
|
|
||||||
[status-im.models.browser-history :as model]
|
|
||||||
[re-frame.core :as re-frame]))
|
|
||||||
|
|
||||||
(def test-history ["http://oldest-site-visited.com", "http://most-recent-site-visited.com"])
|
|
||||||
(def test-browser-id "1234567890")
|
|
||||||
|
|
||||||
(deftest dont-store-history-on-nav-change?-test
|
|
||||||
(testing "dont-store-history-on-nav-change?"
|
|
||||||
(let [db {:browser/options {:dont-store-history-on-nav-change? true}}]
|
|
||||||
(is (model/dont-store-history-on-nav-change? db)))))
|
|
||||||
|
|
||||||
(defn fake-dispatch-dont-store-history-on-nav-change! [event]
|
|
||||||
(is (= :update-browser-options (get event 0)))
|
|
||||||
(let [eventMap (get event 1)]
|
|
||||||
(is (= (:dont-store-history-on-nav-change? eventMap) true))))
|
|
||||||
|
|
||||||
(deftest dont-store-history-on-nav-change!-test
|
|
||||||
(testing "dont-store-history-on-nav-change!"
|
|
||||||
(with-redefs [re-frame/dispatch fake-dispatch-dont-store-history-on-nav-change!]
|
|
||||||
(model/dont-store-history-on-nav-change!))))
|
|
||||||
|
|
||||||
(defn fake-dispatch-clear-dont-store-history-on-nav-change! [event]
|
|
||||||
(is (= :update-browser-options (get event 0)))
|
|
||||||
(let [eventMap (get event 1)]
|
|
||||||
(is (= (:dont-store-history-on-nav-change? eventMap) false))))
|
|
||||||
|
|
||||||
(deftest clear-dont-store-history-on-nav-change-test
|
|
||||||
(testing "clear-dont-store-history-on-nav-change!"
|
|
||||||
(with-redefs [re-frame/dispatch fake-dispatch-clear-dont-store-history-on-nav-change!]
|
|
||||||
(model/clear-dont-store-history-on-nav-change!))))
|
|
||||||
|
|
||||||
(deftest dont-store-history-on-nav-change-if-history-exists-test
|
|
||||||
(testing "dont-store-history-on-nav-change-if-history-exists"
|
|
||||||
(let [browser {:browser-id test-browser-id :history test-history}
|
|
||||||
db {:browser/browsers {test-browser-id browser}}
|
|
||||||
browser-no-history {:browser-id test-browser-id}
|
|
||||||
db-no-history {:browser/browsers {test-browser-id browser-no-history}}
|
|
||||||
result (model/dont-store-history-on-nav-change-if-history-exists db test-browser-id)
|
|
||||||
result-no-history (model/dont-store-history-on-nav-change-if-history-exists db-no-history test-browser-id)]
|
|
||||||
(is (get result :dont-store-history-on-nav-change?))
|
|
||||||
(is (not (get result-no-history :dont-store-history-on-nav-change?))))))
|
|
||||||
|
|
||||||
(defn dispatch-on-back-forwards [event expected-index]
|
|
||||||
(let [eventType (get event 0)
|
|
||||||
eventMap (get event 1)]
|
|
||||||
(if (= :update-browser eventType)
|
|
||||||
(do (is (= (:history-index eventMap) expected-index))
|
|
||||||
(is (= (:url eventMap) (get test-history expected-index))))
|
|
||||||
(do (is (= eventType :update-browser-options))
|
|
||||||
(is (= (:dont-store-history-on-nav-change? eventMap) true))))))
|
|
||||||
|
|
||||||
(defn dispatch-on-back [event]
|
|
||||||
(dispatch-on-back-forwards event 0))
|
|
||||||
|
|
||||||
(deftest back-test
|
|
||||||
(testing "back"
|
|
||||||
(let [browser {:browser-id test-browser-id :history-index 1 :history test-history}]
|
|
||||||
(with-redefs [re-frame/dispatch dispatch-on-back]
|
|
||||||
(model/back browser)))))
|
|
||||||
|
|
||||||
(defn dispatch-on-forward [event]
|
|
||||||
(dispatch-on-back-forwards event 1))
|
|
||||||
|
|
||||||
(deftest forward-test
|
|
||||||
(testing "forward"
|
|
||||||
(let [browser {:browser-id test-browser-id :history-index 0 :history test-history}]
|
|
||||||
(with-redefs [re-frame/dispatch dispatch-on-forward]
|
|
||||||
(model/forward browser)))))
|
|
||||||
|
|
||||||
(deftest can-go-back?-test
|
|
||||||
(testing "can-go-back?"
|
|
||||||
(let [browser {:history-index 0 :history test-history}]
|
|
||||||
(is (= (model/can-go-back? browser) false)))
|
|
||||||
(let [browser {:history-index 1 :history test-history}]
|
|
||||||
(is (= (model/can-go-back? browser) true)))))
|
|
||||||
|
|
||||||
(deftest can-go-forward?-test
|
|
||||||
(testing "can-go-forward?"
|
|
||||||
(let [browser {:history-index 0 :history test-history}]
|
|
||||||
(is (= (model/can-go-forward? browser) true)))
|
|
||||||
(let [browser {:history-index 1 :history test-history}]
|
|
||||||
(is (= (model/can-go-forward? browser) false)))))
|
|
||||||
|
|
||||||
(deftest record-history-in-browser-if-needed-test-1
|
|
||||||
(testing "record-history-in-browser-if-needed: dont record when still loading"
|
|
||||||
(let [raw-browser {:history-index 1 :history test-history}
|
|
||||||
url "http://third-site.com"
|
|
||||||
db {:browser/browsers {test-browser-id raw-browser}}]
|
|
||||||
(let [browser (model/record-history-in-browser-if-needed db raw-browser url true)]
|
|
||||||
(is (= (:history-index browser) 1))
|
|
||||||
(is (= (count (:history browser)) 2))))))
|
|
||||||
|
|
||||||
(defn record-history-in-browser-if-needed-test-2-dispatch [event]
|
|
||||||
(is (= :update-browser-options (get event 0)))
|
|
||||||
(let [eventMap (get event 1)]
|
|
||||||
(is (= (:dont-store-history-on-nav-change? eventMap) false))))
|
|
||||||
|
|
||||||
(deftest record-history-in-browser-if-needed-test-2
|
|
||||||
(testing "record-history-in-browser-if-needed: dont record if :dont-store-history-on-nav-change? true"
|
|
||||||
(let [raw-browser {:history-index 1 :history test-history}
|
|
||||||
url "http://third-site.com"
|
|
||||||
db {:browser/browsers {test-browser-id raw-browser} :browser/options {:dont-store-history-on-nav-change? true}}]
|
|
||||||
(with-redefs [re-frame/dispatch record-history-in-browser-if-needed-test-2-dispatch]
|
|
||||||
(let [browser (model/record-history-in-browser-if-needed db raw-browser url false)]
|
|
||||||
(is (= (:history-index browser) 1))
|
|
||||||
(is (= (count (:history browser)) 2)))))))
|
|
||||||
|
|
||||||
(deftest record-history-in-browser-if-needed-test-3
|
|
||||||
(testing "record-history-in-browser-if-needed: record if not loading and allowed"
|
|
||||||
(let [raw-browser {:history-index 1 :history test-history}
|
|
||||||
url "http://third-site.com"
|
|
||||||
db {:browser/browsers {test-browser-id raw-browser} :browser/options {:dont-store-history-on-nav-change? false}}]
|
|
||||||
(let [browser (model/record-history-in-browser-if-needed db raw-browser url false)]
|
|
||||||
(is (= (:history-index browser) 2))
|
|
||||||
(is (= (count (:history browser)) 3))))))
|
|
@ -5,6 +5,7 @@
|
|||||||
[status-im.test.contacts.subs]
|
[status-im.test.contacts.subs]
|
||||||
[status-im.test.accounts.events]
|
[status-im.test.accounts.events]
|
||||||
[status-im.test.data-store.realm.core]
|
[status-im.test.data-store.realm.core]
|
||||||
|
[status-im.test.browser.events]
|
||||||
[status-im.test.wallet.subs]
|
[status-im.test.wallet.subs]
|
||||||
[status-im.test.wallet.transactions.subs]
|
[status-im.test.wallet.transactions.subs]
|
||||||
[status-im.test.wallet.transactions.views]
|
[status-im.test.wallet.transactions.views]
|
||||||
@ -12,7 +13,6 @@
|
|||||||
[status-im.test.bots.events]
|
[status-im.test.bots.events]
|
||||||
[status-im.test.models.mailserver]
|
[status-im.test.models.mailserver]
|
||||||
[status-im.test.models.bootnode]
|
[status-im.test.models.bootnode]
|
||||||
[status-im.test.models.browser-history]
|
|
||||||
[status-im.test.models.account]
|
[status-im.test.models.account]
|
||||||
[status-im.test.models.contact]
|
[status-im.test.models.contact]
|
||||||
[status-im.test.models.network]
|
[status-im.test.models.network]
|
||||||
@ -70,7 +70,6 @@
|
|||||||
'status-im.test.models.mailserver
|
'status-im.test.models.mailserver
|
||||||
'status-im.test.models.bootnode
|
'status-im.test.models.bootnode
|
||||||
'status-im.test.models.account
|
'status-im.test.models.account
|
||||||
'status-im.test.models.browser-history
|
|
||||||
'status-im.test.models.contact
|
'status-im.test.models.contact
|
||||||
'status-im.test.models.network
|
'status-im.test.models.network
|
||||||
'status-im.test.models.wallet
|
'status-im.test.models.wallet
|
||||||
@ -105,4 +104,5 @@
|
|||||||
'status-im.test.utils.universal-links.core
|
'status-im.test.utils.universal-links.core
|
||||||
'status-im.test.utils.http
|
'status-im.test.utils.http
|
||||||
'status-im.test.ui.screens.events
|
'status-im.test.ui.screens.events
|
||||||
'status-im.test.ui.screens.accounts.login.events)
|
'status-im.test.ui.screens.accounts.login.events
|
||||||
|
'status-im.test.browser.events)
|
Loading…
x
Reference in New Issue
Block a user