2016-05-19 16:31:56 +00:00
|
|
|
(ns status-im.utils.utils
|
2018-03-16 17:50:17 +00:00
|
|
|
(:require [status-im.i18n :as i18n]
|
2018-05-18 00:30:33 +00:00
|
|
|
[status-im.react-native.js-dependencies :as rn-dependencies]
|
2019-03-19 12:24:57 +00:00
|
|
|
[re-frame.core :as re-frame]
|
2019-10-04 11:52:33 +00:00
|
|
|
[status-im.utils.platform :as platform]
|
|
|
|
[status-im.ethereum.eip55 :as eip55]
|
|
|
|
[status-im.ethereum.core :as ethereum]))
|
2016-03-27 14:59:03 +00:00
|
|
|
|
2018-04-26 04:37:32 +00:00
|
|
|
(defn show-popup
|
|
|
|
([title content]
|
2018-05-07 14:09:06 +00:00
|
|
|
(show-popup title content nil))
|
2018-04-26 04:37:32 +00:00
|
|
|
([title content on-dismiss]
|
2018-05-07 14:09:06 +00:00
|
|
|
(.alert (.-Alert rn-dependencies/react-native)
|
|
|
|
title
|
|
|
|
content
|
|
|
|
(clj->js
|
|
|
|
(vector (merge {:text "OK"
|
|
|
|
:style "cancel"
|
|
|
|
:accessibility-label :cancel-button}
|
|
|
|
(when on-dismiss {:onPress on-dismiss}))))
|
|
|
|
(when on-dismiss
|
|
|
|
(clj->js {:cancelable false})))))
|
2016-03-27 14:59:03 +00:00
|
|
|
|
2019-05-13 07:58:41 +00:00
|
|
|
(defn vibrate []
|
|
|
|
#_(.vibrate (.-Vibration rn-dependencies/react-native)))
|
|
|
|
|
2018-09-03 00:32:28 +00:00
|
|
|
(re-frame/reg-fx
|
|
|
|
:utils/show-popup
|
2018-09-27 09:47:16 +00:00
|
|
|
(fn [{:keys [title content on-dismiss]}]
|
2018-09-03 00:32:28 +00:00
|
|
|
(show-popup title content on-dismiss)))
|
|
|
|
|
2017-05-12 22:44:17 +00:00
|
|
|
(defn show-confirmation
|
2019-02-05 12:04:06 +00:00
|
|
|
[{:keys [title content confirm-button-text on-dismiss on-accept on-cancel cancel-button-text
|
|
|
|
extra-options]}]
|
2018-09-20 11:24:14 +00:00
|
|
|
(.alert (.-Alert rn-dependencies/react-native)
|
|
|
|
title
|
|
|
|
content
|
|
|
|
;; Styles are only relevant on iOS. On Android first button is 'neutral' and second is 'positive'
|
|
|
|
(clj->js
|
2019-02-05 12:04:06 +00:00
|
|
|
(concat
|
|
|
|
(vector (merge {:text (or cancel-button-text (i18n/label :t/cancel))
|
|
|
|
:style "cancel"
|
|
|
|
:accessibility-label :cancel-button}
|
|
|
|
(when on-cancel {:onPress on-cancel}))
|
|
|
|
{:text (or confirm-button-text (i18n/label :t/ok))
|
|
|
|
:onPress on-accept
|
|
|
|
:style "default"
|
|
|
|
:accessibility-label :confirm-button})
|
|
|
|
(or extra-options nil)))
|
2018-11-30 15:11:32 +00:00
|
|
|
#js {:cancelable false}))
|
2017-05-12 22:44:17 +00:00
|
|
|
|
2018-11-22 09:22:02 +00:00
|
|
|
(re-frame/reg-fx
|
|
|
|
:utils/show-confirmation
|
|
|
|
(fn [{:keys [title content confirm-button-text on-accept on-cancel cancel-button-text]}]
|
|
|
|
(show-confirmation {:title title
|
|
|
|
:content content
|
|
|
|
:confirm-button-text confirm-button-text
|
|
|
|
:cancel-button-text cancel-button-text
|
|
|
|
:on-accept on-accept
|
|
|
|
:on-cancel on-cancel})))
|
|
|
|
|
2017-09-27 10:40:50 +00:00
|
|
|
(defn show-question
|
|
|
|
([title content on-accept]
|
|
|
|
(show-question title content on-accept nil))
|
|
|
|
([title content on-accept on-cancel]
|
|
|
|
(.alert (.-Alert rn-dependencies/react-native)
|
|
|
|
title
|
|
|
|
content
|
|
|
|
(clj->js
|
2018-03-04 02:56:39 +00:00
|
|
|
(vector (merge {:text (i18n/label :t/no)
|
|
|
|
:accessibility-label :no-button}
|
2017-10-25 15:33:46 +00:00
|
|
|
(when on-cancel {:onPress on-cancel}))
|
2018-03-04 02:56:39 +00:00
|
|
|
{:text (i18n/label :t/yes)
|
|
|
|
:onPress on-accept
|
|
|
|
:accessibility-label :yes-button})))))
|
2017-09-27 10:40:50 +00:00
|
|
|
|
2019-07-09 11:37:18 +00:00
|
|
|
(defn get-shortened-address
|
|
|
|
"Takes first and last 4 digits from address including leading 0x
|
|
|
|
and adds unicode ellipsis in between"
|
|
|
|
[address]
|
|
|
|
(when address
|
|
|
|
(str (subs address 0 6) "\u2026" (subs address (- (count address) 4) (count address)))))
|
|
|
|
|
2019-10-04 11:52:33 +00:00
|
|
|
(defn get-shortened-checksum-address [address]
|
|
|
|
(when address
|
|
|
|
(get-shortened-address (eip55/address->checksum (ethereum/normalized-address address)))))
|
|
|
|
|
2017-12-30 04:35:25 +00:00
|
|
|
;; background-timer
|
|
|
|
|
|
|
|
(defn set-timeout [cb ms]
|
2019-03-19 12:24:57 +00:00
|
|
|
(if platform/desktop?
|
|
|
|
(js/setTimeout cb ms)
|
2019-08-26 12:57:26 +00:00
|
|
|
(.setTimeout rn-dependencies/background-timer cb ms)))
|
2017-12-30 04:35:25 +00:00
|
|
|
|
2018-11-26 20:41:29 +00:00
|
|
|
(defn unread-messages-count
|
|
|
|
"display actual # if less than 1K, round to the lowest thousand if between 1 and 10K, otherwise 10K+ for anything larger"
|
|
|
|
[messages-count]
|
|
|
|
(let [round-to-lowest-single-thousand #(-> %
|
|
|
|
(/ 1000)
|
|
|
|
(Math/floor)
|
|
|
|
(str "K+"))]
|
|
|
|
(cond
|
|
|
|
(< messages-count 1000) (str messages-count)
|
|
|
|
(<= 1000 messages-count 10000) (round-to-lowest-single-thousand messages-count)
|
|
|
|
(> messages-count 10000) "10K+")))
|
|
|
|
|
2018-05-18 00:30:33 +00:00
|
|
|
;; same as re-frame dispatch-later but using background timer for long
|
|
|
|
;; running timeouts
|
|
|
|
(re-frame/reg-fx
|
|
|
|
:utils/dispatch-later
|
|
|
|
(fn [params]
|
|
|
|
(doseq [{:keys [ms dispatch]} params]
|
|
|
|
(set-timeout #(re-frame/dispatch dispatch) ms))))
|
|
|
|
|
2017-12-30 04:35:25 +00:00
|
|
|
(defn clear-timeout [id]
|
2019-03-19 12:24:57 +00:00
|
|
|
(if platform/desktop?
|
|
|
|
(js/clearTimeout id)
|
2019-08-26 12:57:26 +00:00
|
|
|
(.clearTimeout rn-dependencies/background-timer id)))
|
2017-12-30 04:35:25 +00:00
|
|
|
|
|
|
|
(defn set-interval [cb ms]
|
2019-03-19 12:24:57 +00:00
|
|
|
(if platform/desktop?
|
|
|
|
(js/setInterval cb ms)
|
2019-08-26 12:57:26 +00:00
|
|
|
(.setInterval rn-dependencies/background-timer cb ms)))
|
2017-12-30 04:35:25 +00:00
|
|
|
|
|
|
|
(defn clear-interval [id]
|
2019-03-19 12:24:57 +00:00
|
|
|
(if platform/desktop?
|
|
|
|
(js/clearInterval id)
|
2019-08-26 12:57:26 +00:00
|
|
|
(.clearInterval rn-dependencies/background-timer id)))
|