mirror of
https://github.com/status-im/status-react.git
synced 2025-01-27 11:16:03 +00:00
Added new extension primitives
Signed-off-by: Julien Eluard <julien.eluard@gmail.com>
This commit is contained in:
parent
76a724a2e7
commit
ec69938529
@ -149,8 +149,8 @@
|
||||
(description [_] description)
|
||||
(parameters [_] parameters)
|
||||
(validate [_ _ _])
|
||||
(on-send [_ _ _] {:dispatch on-send})
|
||||
(on-receive [_ _ _] {:dispatch on-receive})
|
||||
(on-send [_ _ _] (when on-send {:dispatch on-send}))
|
||||
(on-receive [_ _ _] (when on-receive {:dispatch on-receive}))
|
||||
(short-preview [_ props] (short-preview props))
|
||||
(preview [_ props] (preview props)))]
|
||||
(load-commands cofx [new-command])))
|
||||
|
@ -8,16 +8,15 @@
|
||||
[status-im.accounts.update.core :as accounts.update]
|
||||
[status-im.chat.commands.core :as commands]
|
||||
[status-im.chat.commands.impl.transactions :as transactions]
|
||||
[status-im.ui.components.react :as react]
|
||||
[status-im.ui.components.button.view :as button]
|
||||
[status-im.ui.components.checkbox.view :as checkbox]
|
||||
[status-im.ui.components.list.views :as list]
|
||||
[status-im.ui.components.react :as react]
|
||||
[status-im.i18n :as i18n]
|
||||
[status-im.ui.components.colors :as colors]
|
||||
[status-im.ui.screens.navigation :as navigation]
|
||||
[status-im.utils.handlers :as handlers]
|
||||
[status-im.utils.fx :as fx]))
|
||||
; TODO add list, links, radio buttons
|
||||
; wallet/balance
|
||||
; wallet/tokens
|
||||
; http/ post, put, delete
|
||||
|
||||
(re-frame/reg-fx
|
||||
::alert
|
||||
@ -64,30 +63,76 @@
|
||||
(defn- json? [res]
|
||||
(string/starts-with? (get-in res [:headers "content-type"]) "application/json"))
|
||||
|
||||
(defn- parse-body [o]
|
||||
(js->clj (js/JSON.parse o) :keywordize-keys true))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
:http/get
|
||||
(fn [_ [_ {:keys [url on-success on-failure timeout]}]]
|
||||
{:http-raw-get (merge {:url url
|
||||
:success-event-creator
|
||||
(fn [o]
|
||||
(let [res (if (json? o) (update o :body #(js->clj (js/JSON.parse %) :keywordize-keys true) o))]
|
||||
(let [res (if (json? o) (update o :body parse-body o))]
|
||||
(on-success res)))}
|
||||
(when on-failure
|
||||
{:failure-event-creator on-failure})
|
||||
(when timeout
|
||||
{:timeout-ms timeout}))}))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
:ipfs/cat
|
||||
(fn [_ [_ {:keys [hash on-success on-failure]}]]
|
||||
{:http-raw-get (merge {:url (str "https://ipfs.infura.io/ipfs/" hash)
|
||||
:success-event-creator
|
||||
(fn [o]
|
||||
(let [res (if (json? o) (update o :body parse-body o))]
|
||||
(on-success res)))}
|
||||
(when on-failure
|
||||
{:failure-event-creator on-failure})
|
||||
{:timeout-ms 5000})}))
|
||||
|
||||
(re-frame/reg-event-fx
|
||||
:http/post
|
||||
(fn [_ [_ {:keys [url body on-success on-failure timeout]}]]
|
||||
{:http-raw-post (merge {:url url
|
||||
:body body
|
||||
:success-event-creator
|
||||
(fn [o]
|
||||
(let [res (if (json? o) (update o :body parse-body o))]
|
||||
(on-success res)))}
|
||||
(when on-failure
|
||||
{:failure-event-creator on-failure})
|
||||
(when timeout
|
||||
{:timeout-ms timeout}))}))
|
||||
|
||||
(defn button [{:keys [on-click]} label]
|
||||
[button/secondary-button {:on-press #(re-frame/dispatch (on-click {}))} label])
|
||||
|
||||
(defn input [{:keys [on-change placeholder]}]
|
||||
[react/text-input {:on-change-text #(re-frame/dispatch (on-change {})) :placeholder placeholder}])
|
||||
[react/text-input {:placeholder placeholder
|
||||
:style {:width "100%"}
|
||||
:on-change-text #(re-frame/dispatch (on-change {:value %}))}])
|
||||
|
||||
(defn touchable-opacity [{:keys [on-press]}]
|
||||
[react/touchable-opacity {:on-press #(re-frame/dispatch (on-press {}))}])
|
||||
(defn touchable-opacity [{:keys [on-press]} & children]
|
||||
(into [react/touchable-opacity {:on-press #(re-frame/dispatch (on-press {}))}] children))
|
||||
|
||||
(defn image [{:keys [uri]}]
|
||||
[react/image {:source {:uri uri}}])
|
||||
(defn image [{:keys [uri style]}]
|
||||
[react/image (merge {:style (merge {:width 100 :height 100} style)} (when uri {:source {:uri uri}}))])
|
||||
|
||||
(defn link [{:keys [uri]}]
|
||||
[react/text
|
||||
{:style {:color colors/white
|
||||
:text-decoration-line :underline}
|
||||
:on-press #(re-frame/dispatch [:browser.ui/message-link-pressed uri])}
|
||||
uri])
|
||||
|
||||
(defn list [{:keys [data item-view]}]
|
||||
[list/flat-list {:data data :key-fn (fn [_ i] (str i)) :render-fn item-view}])
|
||||
|
||||
(defn checkbox [{:keys [on-change checked]}]
|
||||
[react/view {:style {:background-color colors/white}}
|
||||
[checkbox/checkbox (merge {:checked checked :style {:padding 0}}
|
||||
(when on-change {:on-value-change #(re-frame/dispatch (on-change {:value %}))}))]])
|
||||
|
||||
(def capacities
|
||||
{:components {'view {:value react/view}
|
||||
@ -96,6 +141,9 @@
|
||||
'image {:value image :properties {:uri :string}}
|
||||
'input {:value input :properties {:on-change :event :placeholder :string}}
|
||||
'button {:value button :properties {:on-click :event}}
|
||||
'link {:value link :properties {:uri :string}}
|
||||
'list {:value list :properties {:data :vector :item-view :view}}
|
||||
'checkbox {:value checkbox :properties {:on-change :event :checked :boolean}}
|
||||
'nft-token-viewer {:value transactions/nft-token :properties {:token :string}}
|
||||
'transaction-status {:value transactions/transaction-status :properties {:outgoing :string :tx-hash :string}}
|
||||
'asset-selector {:value transactions/choose-nft-asset-suggestion}
|
||||
@ -129,15 +177,25 @@
|
||||
:timeout? :string
|
||||
:on-success :event
|
||||
:on-failure? :event}}
|
||||
'browser/open {:value :browser/open :arguments {:url :string}}
|
||||
'chat/open {:value :chat/open :arguments {:url :string}}
|
||||
'http/post
|
||||
{:permissions [:read]
|
||||
:value :http/post
|
||||
:arguments {:url :string
|
||||
:body :string
|
||||
:timeout? :string
|
||||
:on-success :event
|
||||
:on-failure? :event}}
|
||||
'ipfs/cat
|
||||
{:permissions [:read]
|
||||
:value :ipfs/cat
|
||||
:arguments {:hash :string
|
||||
:on-success :event
|
||||
:on-failure? :event}}
|
||||
'ethereum/sign
|
||||
{:arguments
|
||||
{:account :string
|
||||
:message :string
|
||||
:on-result :event}}
|
||||
'ethereum/send-raw-transaction
|
||||
{:arguments {:data :string}}
|
||||
'ethereum/send-transaction
|
||||
{:arguments
|
||||
{:from :string
|
||||
@ -147,14 +205,6 @@
|
||||
:value? :string
|
||||
:data? :string
|
||||
:nonce? :string}}
|
||||
'ethereum/new-contract
|
||||
{:arguments
|
||||
{:from :string
|
||||
:gas? :string
|
||||
:gas-price? :string
|
||||
:value? :string
|
||||
:data? :string
|
||||
:nonce? :string}}
|
||||
'ethereum/call
|
||||
{:arguments
|
||||
{:from? :string
|
||||
@ -163,14 +213,7 @@
|
||||
:gas-price? :string
|
||||
:value? :string
|
||||
:data? :string
|
||||
:block :string}}
|
||||
'ethereum/logs
|
||||
{:arguments
|
||||
{:from? :string
|
||||
:to :string
|
||||
:address :string
|
||||
:topics :string
|
||||
:blockhash :string}}}
|
||||
:block :string}}}
|
||||
:hooks {:commands commands/command-hook}})
|
||||
|
||||
(defn read-extension [{:keys [value]}]
|
||||
|
@ -1,18 +1,17 @@
|
||||
(ns status-im.ui.components.checkbox.view
|
||||
(:require [status-im.ui.components.checkbox.styles :as styles]
|
||||
[status-im.ui.components.react :as react]
|
||||
[status-im.ui.components.icons.vector-icons :as vector-icons]
|
||||
[status-im.utils.platform :as platform]))
|
||||
|
||||
(defn- checkbox-generic [{:keys [on-value-change checked? accessibility-label] :or {accessibility-label :checkbox}} plain?]
|
||||
(defn- checkbox-generic [{:keys [on-value-change checked? accessibility-label style] :or {accessibility-label :checkbox}} plain?]
|
||||
(let [icon-check-container (if plain? #() styles/icon-check-container)
|
||||
check-icon (if plain? styles/plain-check-icon styles/check-icon)]
|
||||
(if platform/android?
|
||||
[react/view styles/wrapper
|
||||
[react/view (merge styles/wrapper style)
|
||||
[react/check-box {:on-value-change on-value-change
|
||||
:value checked?
|
||||
:accessibility-label accessibility-label}]]
|
||||
[react/touchable-highlight (merge {:style styles/wrapper
|
||||
[react/touchable-highlight (merge {:style (merge styles/wrapper style)
|
||||
:accessibility-label accessibility-label}
|
||||
(when on-value-change {:on-press #(on-value-change (not checked?))}))
|
||||
[react/view (icon-check-container checked?)
|
||||
|
@ -2,13 +2,38 @@
|
||||
(:require [status-im.utils.utils :as utils]
|
||||
[status-im.react-native.js-dependencies :as rn-dependencies]
|
||||
[taoensso.timbre :as log]
|
||||
[goog.Uri :as uri]
|
||||
[clojure.string :as string])
|
||||
(:refer-clojure :exclude [get]))
|
||||
|
||||
;; Default HTTP request timeout ms
|
||||
(def http-request-default-timeout-ms 3000)
|
||||
|
||||
(defn- headers [response]
|
||||
(let [entries (es6-iterator-seq (.entries (.-headers response)))]
|
||||
(reduce #(assoc %1 (string/trim (string/lower-case (first %2))) (string/trim (second %2))) {} entries)))
|
||||
|
||||
(defn raw-post
|
||||
"Performs an HTTP POST request and returns raw results :status :headers :body."
|
||||
([url body on-success] (raw-post url body on-success nil))
|
||||
([url body on-success on-error]
|
||||
(raw-post url body on-success on-error nil))
|
||||
([url body on-success on-error {:keys [timeout-ms]}]
|
||||
(-> (rn-dependencies/fetch url
|
||||
(clj->js {:method "POST"
|
||||
:headers {"Cache-Control" "no-cache"}
|
||||
:body body
|
||||
:timeout (or timeout-ms http-request-default-timeout-ms)}))
|
||||
(.then (fn [response]
|
||||
(->
|
||||
(.text response)
|
||||
(.then (fn [body]
|
||||
(on-success {:status (.-status response)
|
||||
:headers (headers response)
|
||||
:body body}))))))
|
||||
(.catch (or on-error
|
||||
(fn [error]
|
||||
(utils/show-popup "Error" (str error))))))))
|
||||
|
||||
(defn post
|
||||
"Performs an HTTP POST request"
|
||||
([url data on-success]
|
||||
@ -49,10 +74,6 @@
|
||||
(on-error {:response-body error})
|
||||
(utils/show-popup "Error" (str error))))))))
|
||||
|
||||
(defn- headers [response]
|
||||
(let [entries (es6-iterator-seq (.entries (.-headers response)))]
|
||||
(reduce #(assoc %1 (string/trim (string/lower-case (first %2))) (string/trim (second %2))) {} entries)))
|
||||
|
||||
(defn raw-get
|
||||
"Performs an HTTP GET request and returns raw results :status :headers :body."
|
||||
([url] (raw-get url nil))
|
||||
|
Loading…
x
Reference in New Issue
Block a user