RAM bundle basic setup

This commit is contained in:
Roman Volosovskyi 2019-05-22 08:50:49 +03:00
parent 9b04dc6530
commit c7c7b50281
No known key found for this signature in database
GPG Key ID: 0238A4B5ECEE70DE
132 changed files with 1227 additions and 671 deletions

View File

@ -80,6 +80,8 @@ project.ext.react = [
nodeExecutableAndArgs: ["node", "--max-old-space-size=16384"], nodeExecutableAndArgs: ["node", "--max-old-space-size=16384"],
entryFile: "index.android.js", entryFile: "index.android.js",
bundleInPr: true, bundleInPr: true,
bundleCommand: "ram-bundle",
bundleConfig: "packager/config.js"
] ]
apply from: "../../node_modules/react-native/react.gradle" apply from: "../../node_modules/react-native/react.gradle"

View File

@ -46,7 +46,6 @@
"hi-base32" "hi-base32"
"react-native-mail" "react-native-mail"
"react-native-shake"] "react-native-shake"]
;; Desktop modules ;; Desktop modules
:desktop-modules ["realm" :desktop-modules ["realm"
"react-native-languages" "react-native-languages"

View File

@ -1,7 +1,6 @@
(ns status-im.ui.components.react (ns status-im.ui.components.react
(:require-macros [status-im.utils.views :as views]) (:require-macros [status-im.utils.views :as views])
(:require [clojure.string :as string] (:require [goog.object :as object]
[goog.object :as object]
[reagent.core :as reagent] [reagent.core :as reagent]
[status-im.ui.components.styles :as styles] [status-im.ui.components.styles :as styles]
[status-im.utils.utils :as utils] [status-im.utils.utils :as utils]
@ -17,31 +16,42 @@
(or (object/get js-dependencies/react-native name) {}) (or (object/get js-dependencies/react-native name) {})
#js {})) #js {}))
(defn lazy-get-react-property [name]
(let [react-property (atom nil)]
(fn []
(if @react-property
@react-property
(reset! react-property (get-react-property name))))))
(defn adapt-class [class] (defn adapt-class [class]
(when class (when class
(reagent/adapt-react-class class))) (reagent/adapt-react-class class)))
(defn get-class [name] (defn get-class [name]
(adapt-class (get-react-property name))) (let [react-class (atom nil)]
(fn []
(if @react-class
@react-class
(reset! react-class
(adapt-class (get-react-property name)))))))
(def native-modules (.-NativeModules js-dependencies/react-native)) (def native-modules (.-NativeModules js-dependencies/react-native))
(def device-event-emitter (.-DeviceEventEmitter js-dependencies/react-native)) (def device-event-emitter (.-DeviceEventEmitter js-dependencies/react-native))
(def dismiss-keyboard! js-dependencies/dismiss-keyboard)
(def back-handler (get-react-property "BackHandler")) (defn dismiss-keyboard! [] ((js-dependencies/dismiss-keyboard)))
(def splash-screen (.-SplashScreen native-modules)) (def splash-screen (.-SplashScreen native-modules))
;; React Components ;; React Components
(def app-registry (get-react-property "AppRegistry")) (def app-registry (get-react-property "AppRegistry"))
(def app-state (get-react-property "AppState")) (def app-state (lazy-get-react-property "AppState"))
(def net-info (get-react-property "NetInfo")) (def net-info (lazy-get-react-property "NetInfo"))
(def view (get-class "View")) (def view ((get-class "View")))
(def safe-area-view (get-class "SafeAreaView")) (def safe-area-view (get-class "SafeAreaView"))
(def progress-bar (get-class "ProgressBarAndroid")) (def progress-bar (get-class "ProgressBarAndroid"))
(def status-bar-class (when-not platform/desktop? (get-react-property "StatusBar"))) (def status-bar-class (when-not platform/desktop? (get-react-property "StatusBar")))
(def status-bar (get-class (if platform/desktop? "View" "StatusBar")))
(def scroll-view (get-class "ScrollView")) (def scroll-view (get-class "ScrollView"))
(def web-view (get-class "WebView")) (def web-view (get-class "WebView"))
@ -49,11 +59,12 @@
(def refresh-control (get-class "RefreshControl")) (def refresh-control (get-class "RefreshControl"))
(def text-class (get-class "Text")) (def text-class ((get-class "Text")))
(def text-input-class (get-class "TextInput")) (def text-input-class (get-class "TextInput"))
(def image-class (get-class "Image")) (def image-class (get-class "Image"))
(def picker-class (get-class "Picker")) (def picker-obj (lazy-get-react-property "Picker"))
(def picker-item-class (adapt-class (.-Item (get-react-property "Picker")))) (defn picker-class [] (adapt-class (picker-obj)))
(defn picker-item-class [] (adapt-class (.-Item (picker-obj))))
(defn valid-source? [source] (defn valid-source? [source]
(or (not (map? source)) (or (not (map? source))
@ -63,30 +74,34 @@
(defn image [{:keys [source] :as props}] (defn image [{:keys [source] :as props}]
(when (valid-source? source) (when (valid-source? source)
[image-class props])) (let [source (if (fn? source) (source) source)]
[(image-class) (assoc props :source source)])))
(def switch (get-class "Switch")) (def switch-class (get-class "Switch"))
(def check-box (get-class "CheckBox"))
(defn switch [props]
[(switch-class) props])
(def touchable-highlight-class (get-class "TouchableHighlight")) (def touchable-highlight-class (get-class "TouchableHighlight"))
(def touchable-without-feedback-class (get-class "TouchableWithoutFeedback")) (def touchable-without-feedback-class (get-class "TouchableWithoutFeedback"))
(def touchable-opacity (get-class "TouchableOpacity")) (def touchable-opacity (get-class "TouchableOpacity"))
(def activity-indicator (get-class "ActivityIndicator")) (def activity-indicator-class (get-class "ActivityIndicator"))
(defn activity-indicator [props]
[(activity-indicator-class) props])
(def modal (get-class "Modal")) (def modal (get-class "Modal"))
(def pan-responder (.-PanResponder js-dependencies/react-native)) (def pan-responder (lazy-get-react-property "PanResponder"))
(def animated (.-Animated js-dependencies/react-native)) (def animated (lazy-get-react-property "Animated"))
(def animated-view (reagent/adapt-react-class (.-View animated))) (defn animated-view []
(def animated-text (reagent/adapt-react-class (.-Text animated))) (reagent/adapt-react-class (.-View (animated))))
(def dimensions (.-Dimensions js-dependencies/react-native)) (def dimensions (lazy-get-react-property "Dimensions"))
(def keyboard (.-Keyboard js-dependencies/react-native)) (def keyboard (lazy-get-react-property "Keyboard"))
(def linking (.-Linking js-dependencies/react-native)) (def linking (lazy-get-react-property "Linking"))
(def desktop-notification (.-DesktopNotification (.-NativeModules js-dependencies/react-native))) (def desktop-notification (.-DesktopNotification (.-NativeModules js-dependencies/react-native)))
(def slider (get-class "Slider"))
(def max-font-size-multiplier 1.25) (def max-font-size-multiplier 1.25)
(defn prepare-text-props [props] (defn prepare-text-props [props]
@ -122,7 +137,7 @@
(defn text-input (defn text-input
[options text] [options text]
[text-input-class [(text-input-class)
(merge (merge
{:underline-color-android :transparent {:underline-color-android :transparent
:max-font-size-multiplier max-font-size-multiplier :max-font-size-multiplier max-font-size-multiplier
@ -145,30 +160,30 @@
:style style}])) :style style}]))
(defn touchable-highlight [props content] (defn touchable-highlight [props content]
[touchable-highlight-class [(touchable-highlight-class)
(merge {:underlay-color :transparent} props) (merge {:underlay-color :transparent} props)
content]) content])
(defn touchable-without-feedback [props content] (defn touchable-without-feedback [props content]
[touchable-without-feedback-class [(touchable-without-feedback-class)
props props
content]) content])
(defn get-dimensions [name] (defn get-dimensions [name]
(js->clj (.get dimensions name) :keywordize-keys true)) (js->clj (.get (dimensions) name) :keywordize-keys true))
(defn list-item [component] (defn list-item [component]
(reagent/as-element component)) (reagent/as-element component))
(defn value->picker-item [{:keys [value label]}] (defn value->picker-item [{:keys [value label]}]
[picker-item-class {:value (or value "") :label (or label value "")}]) [(picker-item-class) {:value (or value "") :label (or label value "")}])
(defn picker [{:keys [style on-change selected enabled data]}] (defn picker [{:keys [style on-change selected enabled data]}]
(into (into
[picker-class (merge (when style {:style style}) [(picker-class) (merge (when style {:style style})
(when enabled {:enabled enabled}) (when enabled {:enabled enabled})
(when on-change {:on-value-change on-change}) (when on-change {:on-value-change on-change})
(when selected {:selected-value selected}))] (when selected {:selected-value selected}))]
(map value->picker-item data))) (map value->picker-item data)))
;; Image picker ;; Image picker
@ -184,7 +199,7 @@
([images-fn] ([images-fn]
(show-image-picker images-fn nil)) (show-image-picker images-fn nil))
([images-fn media-type] ([images-fn media-type]
(let [image-picker (.-default image-picker-class)] (let [image-picker (.-default (image-picker-class))]
(-> image-picker (-> image-picker
(.openPicker (clj->js {:multiple false :mediaType (or media-type "any")})) (.openPicker (clj->js {:multiple false :mediaType (or media-type "any")}))
(.then images-fn) (.then images-fn)
@ -210,7 +225,7 @@
(defn keyboard-avoiding-view [props & children] (defn keyboard-avoiding-view [props & children]
(let [view-element (if platform/ios? (let [view-element (if platform/ios?
[keyboard-avoiding-view-class (merge {:behavior :padding} props)] [(keyboard-avoiding-view-class) (merge {:behavior :padding} props)]
[view props])] [view props])]
(vec (concat view-element children)))) (vec (concat view-element children))))
@ -309,7 +324,7 @@
:height 100 :height 100
:z-index -1000}]) :z-index -1000}])
children (conj children bottom-background)] children (conj children bottom-background)]
(apply vector safe-area-view props children)))) (apply vector (safe-area-view) props children))))
(defmethod create-main-screen-view :default [_] (defmethod create-main-screen-view :default [_]
view) view)

View File

@ -1837,7 +1837,7 @@
); );
runOnlyForDeploymentPostprocessing = 0; runOnlyForDeploymentPostprocessing = 0;
shellPath = /bin/sh; shellPath = /bin/sh;
shellScript = "set -o errexit\nexport NODE_BINARY=\"node\"\nexport NODE_ARGS=\" --max-old-space-size=16384 \"\n../node_modules/react-native/scripts/react-native-xcode.sh\n"; shellScript = "set -o errexit\nexport BUNDLE_COMMAND=\"ram-bundle\"\nexport BUNDLE_CONFIG=\"packager/config.js\"\nexport NODE_BINARY=\"node\"\nexport NODE_ARGS=\" --max-old-space-size=16384 \"\n\n../node_modules/react-native/scripts/react-native-xcode.sh\n";
}; };
2EAC54E16AB243C3EBBFE1BA /* [CP] Check Pods Manifest.lock */ = { 2EAC54E16AB243C3EBBFE1BA /* [CP] Check Pods Manifest.lock */ = {
isa = PBXShellScriptBuildPhase; isa = PBXShellScriptBuildPhase;

35
packager/config.js Normal file
View File

@ -0,0 +1,35 @@
const modulePaths = require('./modulePaths');
const resolve = require('path').resolve;
const fs = require('fs');
const { getDefaultConfig } = require("metro-config");
// Update the following line if the root folder of your app is somewhere else.
const ROOT_FOLDER = resolve(__dirname, '..');
module.exports = (async () => {
const {
resolver: { sourceExts, assetExts }
} = await getDefaultConfig();
return {
transformer: {
babelTransformerPath: require.resolve("react-native-svg-transformer"),
getTransformOptions: async () => {
const moduleMap = {};
modulePaths.forEach(path => {
if (fs.existsSync(path)) {
moduleMap[resolve(path)] = true;
}
});
return {
preloadedModules: moduleMap,
transform: { inlineRequires: { blacklist: moduleMap } },
}
},
},
projectRoot:ROOT_FOLDER,
resolver: {
assetExts: assetExts.filter(ext => ext !== "svg"),
sourceExts: [...sourceExts, "svg"]
}
};
})();

415
packager/modulePaths.js Normal file
View File

@ -0,0 +1,415 @@
module.exports = [
"node_modules/react-native/Libraries/Core/InitializeCore.js",
"index.android.js",
"index.ios.js",
"node_modules/react-native-config/index.js",
"node_modules/react-native/Libraries/react-native/react-native-implementation.js",
"node_modules/react-native/Libraries/BatchedBridge/NativeModules.js",
"node_modules/invariant/browser.js",
"node_modules/react-native/Libraries/BatchedBridge/BatchedBridge.js",
"node_modules/react-native/Libraries/BatchedBridge/MessageQueue.js",
"node_modules/react-native/Libraries/Utilities/stringifySafe.js",
"node_modules/react-native/Libraries/Utilities/defineLazyObjectProperty.js",
"node_modules/react-native/Libraries/EventEmitter/RCTDeviceEventEmitter.js",
"node_modules/react-native/Libraries/vendor/emitter/EventSubscriptionVendor.js",
"node_modules/react-native/Libraries/vendor/emitter/EventEmitter.js",
"node_modules/react-native/Libraries/vendor/emitter/EmitterSubscription.js",
"node_modules/react-native/Libraries/vendor/emitter/EventSubscription.js",
"node_modules/react-native/Libraries/ReactNative/UIManager.js",
"node_modules/react-native/Libraries/Utilities/Platform.android.js",
"node_modules/react-native/Libraries/ReactNative/UIManagerProperties.js",
"node_modules/react-native/Libraries/Components/ActivityIndicator/ActivityIndicator.js",
"node_modules/react-native/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.android.js",
"node_modules/react-native/Libraries/react-native/React.js",
"node_modules/react/index.js",
"node_modules/object-assign/index.js",
"node_modules/react/cjs/react.production.min.js",
"node_modules/react/node_modules/prop-types/checkPropTypes.js",
"node_modules/react/node_modules/prop-types/lib/ReactPropTypesSecret.js",
"node_modules/react-native/Libraries/ReactNative/requireNativeComponent.js",
"node_modules/react-native/Libraries/Renderer/shims/createReactNativeComponentClass.js",
"node_modules/react-native/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js",
"node_modules/react-native/Libraries/ReactNative/getNativeComponentAttributes.js",
"node_modules/react-native/node_modules/fbjs/lib/warning.js",
"node_modules/@babel/runtime/helpers/objectSpread.js",
"node_modules/@babel/runtime/helpers/defineProperty.js",
"node_modules/react-native/Libraries/Components/View/ReactNativeStyleAttributes.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedViewStylePropTypes.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedLayoutPropTypes.js",
"node_modules/react-native/node_modules/prop-types/index.js",
"node_modules/react-native/node_modules/prop-types/factoryWithTypeCheckers.js",
"node_modules/react-native/node_modules/prop-types/lib/ReactPropTypesSecret.js",
"node_modules/react-native/node_modules/prop-types/checkPropTypes.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedShadowPropTypesIOS.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedColorPropType.js",
"node_modules/react-native/Libraries/Color/normalizeColor.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedTransformPropTypes.js",
"node_modules/react-native/Libraries/Utilities/deprecatedPropType.js",
"node_modules/react-native/Libraries/Text/TextStylePropTypes.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedImageStylePropTypes.js",
"node_modules/react-native/Libraries/StyleSheet/processTransform.js",
"node_modules/react-native/Libraries/Utilities/differ/sizesDiffer.js",
"node_modules/react-native/Libraries/StyleSheet/processColor.js",
"node_modules/react-native/Libraries/Image/AssetRegistry.js",
"node_modules/react-native/Libraries/Utilities/PixelRatio.js",
"node_modules/react-native/Libraries/Utilities/Dimensions.js",
"node_modules/react-native/Libraries/Utilities/DeviceInfo.js",
"node_modules/react-native/Libraries/Components/View/View.js",
"node_modules/react-native/Libraries/Components/View/ViewNativeComponent.js",
"node_modules/react-native/Libraries/Text/TextAncestor.js",
"node_modules/react-native/Libraries/StyleSheet/StyleSheet.js",
"node_modules/react-native/Libraries/StyleSheet/flattenStyle.js",
"node_modules/react-native/Libraries/StyleSheet/StyleSheetValidation.js",
"node_modules/react-native/Libraries/vendor/core/merge.js",
"node_modules/react-native/Libraries/vendor/core/mergeInto.js",
"node_modules/react-native/Libraries/vendor/core/mergeHelpers.js",
"node_modules/react-native/Libraries/Components/View/ReactNativeViewAttributes.js",
"node_modules/react-native/Libraries/Components/Touchable/Touchable.js",
"node_modules/react-native/node_modules/fbjs/lib/keyMirror.js",
"node_modules/react-native/Libraries/EventEmitter/NativeEventEmitter.js",
"node_modules/react-native/Libraries/Renderer/shims/ReactNative.js",
"node_modules/react-native/Libraries/Core/setUpGlobals.js",
"node_modules/react-native/Libraries/Core/polyfillES6Collections.js",
"node_modules/react-native/Libraries/vendor/core/_shouldPolyfillES6Collection.js",
"node_modules/react-native/Libraries/Utilities/PolyfillFunctions.js",
"node_modules/react-native/Libraries/Core/setUpSystrace.js",
"node_modules/react-native/Libraries/Core/setUpErrorHandling.js",
"node_modules/react-native/Libraries/Core/ExceptionsManager.js",
"node_modules/stacktrace-parser/index.js",
"node_modules/stacktrace-parser/lib/stacktrace-parser.js",
"node_modules/react-native/Libraries/Network/fetch.js",
"node_modules/react-native/Libraries/vendor/core/whatwg-fetch.js",
"node_modules/react-native/Libraries/Core/checkNativeVersion.js",
"node_modules/react-native/Libraries/Core/ReactNativeVersionCheck.js",
"node_modules/react-native/Libraries/Core/ReactNativeVersion.js",
"node_modules/react-native/Libraries/Core/polyfillPromise.js",
"node_modules/react-native/Libraries/Promise.js",
"node_modules/promise/setimmediate/done.js",
"node_modules/promise/setimmediate/core.js",
"node_modules/promise/setimmediate/es6-extensions.js",
"node_modules/promise/setimmediate/rejection-tracking.js",
"node_modules/react-native/Libraries/Core/setUpRegeneratorRuntime.js",
"node_modules/regenerator-runtime/runtime.js",
"node_modules/react-native/Libraries/Core/setUpTimers.js",
"node_modules/react-native/Libraries/Core/Timers/JSTimers.js",
"node_modules/react-native/node_modules/fbjs/lib/ExecutionEnvironment.js",
"node_modules/react-native/Libraries/Core/setUpXHR.js",
"node_modules/react-native/Libraries/Blob/BlobManager.js",
"node_modules/react-native/Libraries/Blob/Blob.js",
"node_modules/react-native/Libraries/Blob/BlobRegistry.js",
"node_modules/event-target-shim/lib/event-target.js",
"node_modules/event-target-shim/lib/commons.js",
"node_modules/event-target-shim/lib/custom-event-target.js",
"node_modules/event-target-shim/lib/event-wrapper.js",
"node_modules/react-native/Libraries/Network/FormData.js",
"node_modules/base64-js/index.js",
"node_modules/react-native/Libraries/WebSocket/WebSocket.js",
"node_modules/react-native/Libraries/WebSocket/WebSocketEvent.js",
"node_modules/react-native/Libraries/Blob/File.js",
"node_modules/react-native/Libraries/Core/setUpAlert.js",
"node_modules/react-native/Libraries/Core/setUpGeolocation.js",
"node_modules/react-native/Libraries/Utilities/logError.js",
"node_modules/react-native/Libraries/Core/setUpBatchedBridge.js",
"node_modules/react-native/Libraries/Utilities/RCTLog.js",
"node_modules/react-native/Libraries/Utilities/infoLog.js",
"node_modules/react-native/Libraries/Core/setUpSegmentFetcher.js",
"node_modules/react-native/Libraries/AppState/AppState.js",
"node_modules/react-native/Libraries/JSInspector/JSInspector.js",
"node_modules/react-native/Libraries/JSInspector/NetworkAgent.js",
"node_modules/react-native/Libraries/JSInspector/InspectorAgent.js",
"node_modules/react-native/Libraries/EventEmitter/RCTEventEmitter.js",
"node_modules/react-native/Libraries/Utilities/differ/deepDiffer.js",
"node_modules/react-native/Libraries/Components/TextInput/TextInputState.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedViewAccessibility.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedEdgeInsetsPropType.js",
"node_modules/react-native/Libraries/Animated/src/Animated.js",
"node_modules/react-native/Libraries/Animated/src/nodes/AnimatedValue.js",
"node_modules/react-native/Libraries/Animated/src/nodes/AnimatedInterpolation.js",
"node_modules/react-native/Libraries/Animated/src/nodes/AnimatedWithChildren.js",
"node_modules/react-native/Libraries/Animated/src/nodes/AnimatedNode.js",
"node_modules/react-native/Libraries/Animated/src/nodes/AnimatedValueXY.js",
"node_modules/react-native/Libraries/Animated/src/AnimatedImplementation.js",
"node_modules/react-native/Libraries/Animated/src/Easing.js",
"node_modules/react-native/Libraries/Animated/src/AnimatedEvent.js",
"node_modules/react-native/Libraries/Animated/src/createAnimatedComponent.js",
"node_modules/react-native/Libraries/Animated/src/nodes/AnimatedProps.js",
"node_modules/react-native/Libraries/Animated/src/nodes/AnimatedStyle.js",
"node_modules/react-native/Libraries/Animated/src/nodes/AnimatedTransform.js",
"node_modules/react-native/Libraries/Components/Keyboard/Keyboard.js",
"node_modules/react-native/Libraries/Utilities/dismissKeyboard.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedViewPropTypes.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedStyleSheetPropType.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/deprecatedCreateStrictShapeTypeChecker.js",
"node_modules/react-native/Libraries/Components/View/PlatformViewPropTypes.android.js",
"node_modules/react-native/Libraries/Animated/src/components/AnimatedText.js",
"node_modules/react-native/Libraries/Text/Text.js",
"node_modules/react-native/Libraries/DeprecatedPropTypes/DeprecatedTextPropTypes.js",
"node_modules/react-native/Libraries/Animated/src/components/AnimatedView.js",
"node_modules/react-native/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js",
"node_modules/react-native/Libraries/Components/StatusBar/StatusBar.js",
"node_modules/react-native/Libraries/Utilities/warnOnce.js",
"node_modules/react-native/Libraries/ReactNative/AppContainer.js",
"node_modules/react-native/Libraries/ReactNative/I18nManager.js",
"node_modules/react-native/Libraries/Interaction/PanResponder.js",
"node_modules/react-native/Libraries/ReactNative/AppRegistry.js",
"node_modules/react-native/Libraries/ReactNative/renderApplication.js",
"node_modules/react-native/Libraries/Utilities/BackHandler.android.js",
"node_modules/react-native/Libraries/BugReporting/BugReporting.js",
"node_modules/react-native/Libraries/Utilities/SceneTracker.js",
"node_modules/react-native/Libraries/Linking/Linking.js",
"node_modules/react-native/Libraries/Network/NetInfo.js",
"node_modules/react-native/Libraries/Share/Share.js",
"node_modules/react-native-fs/FS.common.js",
"node_modules/react-native-keychain/index.js",
"node_modules/fbjs/lib/warning.js",
"node_modules/fbjs/lib/emptyFunction.js",
"node_modules/fbjs/lib/invariant.js",
"node_modules/fbjs/lib/emptyObject.js",
"node_modules/realm/lib/index.js",
"node_modules/realm/lib/user-methods.js",
"node_modules/realm/lib/errors.js",
"node_modules/realm/lib/permission-api.js",
"node_modules/realm/lib/extensions.js",
"node_modules/realm/lib/collection-methods.js",
"node_modules/create-react-class/index.js",
"node_modules/create-react-class/factory.js",
"node_modules/prop-types/index.js",
"node_modules/prop-types/factoryWithTypeCheckers.js",
"node_modules/prop-types/lib/ReactPropTypesSecret.js",
"node_modules/prop-types/checkPropTypes.js",
"node_modules/react-native-securerandom/index.js",
"node_modules/i18n-js/app/assets/javascripts/i18n.js",
"node_modules/react-native-languages/index.js",
"node_modules/react-native-camera/src/index.js",
"node_modules/react-native-camera/src/Camera.js",
"node_modules/react-native-camera/node_modules/prop-types/index.js",
"node_modules/react-native-camera/node_modules/prop-types/factoryWithTypeCheckers.js",
"node_modules/react-native-camera/node_modules/prop-types/lib/ReactPropTypesSecret.js",
"node_modules/react-native-camera/node_modules/prop-types/checkPropTypes.js",
"node_modules/react-native-camera/src/RNCamera.js",
"node_modules/react-native-camera/src/FaceDetector.js",
"node_modules/react-native-svg/index.js",
"node_modules/react-native-svg/elements/Rect.js",
"node_modules/react-native-svg/lib/extract/extractProps.js",
"node_modules/react-native-svg/lib/extract/extractFill.js",
"node_modules/react-native-svg/lib/extract/extractBrush.js",
"node_modules/react-native-svg/lib/extract/extractColor.js",
"node_modules/react-native-svg/lib/extract/extractOpacity.js",
"node_modules/react-native-svg/lib/extract/extractStroke.js",
"node_modules/react-native-svg/lib/extract/extractLengthList.js",
"node_modules/react-native-svg/lib/extract/extractClipPath.js",
"node_modules/react-native-svg/lib/extract/extractResponder.js",
"node_modules/react-native-svg/lib/extract/extractTransform.js",
"node_modules/react-native-svg/lib/Matrix2D.js",
"node_modules/react-native-svg/lib/extract/transform.js",
"node_modules/react-native-svg/elements/Shape.js",
"node_modules/react-native-svg/lib/SvgTouchableMixin.js",
"node_modules/react-native-svg/elements/Circle.js",
"node_modules/react-native-svg/elements/Ellipse.js",
"node_modules/react-native-svg/elements/Polygon.js",
"node_modules/react-native-svg/elements/Path.js",
"node_modules/react-native-svg/lib/extract/extractPolyPoints.js",
"node_modules/react-native-svg/elements/Polyline.js",
"node_modules/react-native-svg/elements/Line.js",
"node_modules/react-native-svg/elements/Svg.js",
"node_modules/react-native-svg/lib/extract/extractViewBox.js",
"node_modules/react-native-svg/elements/G.js",
"node_modules/react-native-svg/lib/extract/extractText.js",
"node_modules/react-native-svg/elements/Text.js",
"node_modules/react-native-svg/elements/TSpan.js",
"node_modules/react-native-svg/elements/TextPath.js",
"node_modules/react-native-svg/elements/Use.js",
"node_modules/react-native-svg/elements/Image.js",
"node_modules/react-native-svg/elements/Symbol.js",
"node_modules/react-native-svg/elements/Defs.js",
"node_modules/react-native-svg/elements/LinearGradient.js",
"node_modules/react-native-svg/lib/extract/extractGradient.js",
"node_modules/react-native-svg/lib/units.js",
"node_modules/react-native-svg/elements/RadialGradient.js",
"node_modules/react-native-svg/elements/Stop.js",
"node_modules/react-native-svg/elements/ClipPath.js",
"node_modules/react-native-svg/elements/Pattern.js",
"node_modules/react-native-svg/elements/Mask.js",
"node_modules/react-native-firebase/dist/index.js",
"node_modules/react-native-firebase/dist/modules/core/firebase.js",
"node_modules/react-native-firebase/dist/utils/apps.js",
"node_modules/react-native-firebase/dist/modules/core/app.js",
"node_modules/react-native-firebase/dist/utils/internals.js",
"node_modules/react-native-firebase/dist/modules/admob/index.js",
"node_modules/react-native-firebase/dist/utils/ModuleBase.js",
"node_modules/react-native-firebase/dist/utils/native.js",
"node_modules/react-native-firebase/dist/utils/events.js",
"node_modules/react-native-firebase/dist/utils/emitter/EventEmitter.js",
"node_modules/react-native-firebase/dist/utils/emitter/EventSubscriptionVendor.js",
"node_modules/react-native-firebase/dist/utils/emitter/EmitterSubscription.js",
"node_modules/react-native-firebase/dist/utils/emitter/EventSubscription.js",
"node_modules/react-native-firebase/dist/utils/log.js",
"node_modules/react-native-firebase/dist/modules/admob/Interstitial.js",
"node_modules/react-native-firebase/dist/modules/admob/AdRequest.js",
"node_modules/react-native-firebase/dist/utils/index.js",
"node_modules/react-native-firebase/dist/modules/admob/RewardedVideo.js",
"node_modules/react-native-firebase/dist/modules/admob/VideoOptions.js",
"node_modules/react-native-firebase/dist/modules/admob/Banner.js",
"node_modules/react-native-firebase/dist/modules/admob/AdMobComponent.js",
"node_modules/react-native-firebase/node_modules/prop-types/index.js",
"node_modules/react-native-firebase/node_modules/prop-types/factoryWithTypeCheckers.js",
"node_modules/react-native-firebase/node_modules/prop-types/lib/ReactPropTypesSecret.js",
"node_modules/react-native-firebase/node_modules/prop-types/checkPropTypes.js",
"node_modules/react-native-firebase/dist/modules/admob/EventTypes.js",
"node_modules/react-native-firebase/dist/modules/admob/NativeExpress.js",
"node_modules/react-native-firebase/dist/modules/auth/index.js",
"node_modules/react-native-firebase/dist/modules/auth/User.js",
"node_modules/react-native-firebase/dist/modules/auth/phone/ConfirmationResult.js",
"node_modules/react-native-firebase/dist/modules/auth/phone/PhoneAuthListener.js",
"node_modules/react-native-firebase/dist/modules/auth/providers/EmailAuthProvider.js",
"node_modules/react-native-firebase/dist/modules/auth/providers/PhoneAuthProvider.js",
"node_modules/react-native-firebase/dist/modules/auth/providers/GoogleAuthProvider.js",
"node_modules/react-native-firebase/dist/modules/auth/providers/GithubAuthProvider.js",
"node_modules/react-native-firebase/dist/modules/auth/providers/OAuthProvider.js",
"node_modules/react-native-firebase/dist/modules/auth/providers/TwitterAuthProvider.js",
"node_modules/react-native-firebase/dist/modules/auth/providers/FacebookAuthProvider.js",
"node_modules/react-native-firebase/dist/modules/analytics/index.js",
"node_modules/react-native-firebase/dist/modules/config/index.js",
"node_modules/react-native-firebase/dist/modules/crashlytics/index.js",
"node_modules/react-native-firebase/dist/modules/database/index.js",
"node_modules/react-native-firebase/dist/modules/database/Reference.js",
"node_modules/react-native-firebase/dist/modules/database/Query.js",
"node_modules/react-native-firebase/dist/modules/database/DataSnapshot.js",
"node_modules/react-native-firebase/dist/modules/database/OnDisconnect.js",
"node_modules/react-native-firebase/dist/utils/ReferenceBase.js",
"node_modules/react-native-firebase/dist/utils/SyncTree.js",
"node_modules/react-native-firebase/dist/modules/database/transaction.js",
"node_modules/react-native-firebase/dist/modules/firestore/index.js",
"node_modules/react-native-firebase/dist/modules/firestore/CollectionReference.js",
"node_modules/react-native-firebase/dist/modules/firestore/DocumentReference.js",
"node_modules/react-native-firebase/dist/modules/firestore/DocumentSnapshot.js",
"node_modules/react-native-firebase/dist/modules/firestore/FieldPath.js",
"node_modules/react-native-firebase/dist/modules/firestore/Path.js",
"node_modules/react-native-firebase/dist/modules/firestore/Blob.js",
"node_modules/react-native-firebase/dist/utils/Base64.js",
"node_modules/react-native-firebase/dist/modules/firestore/GeoPoint.js",
"node_modules/react-native-firebase/dist/modules/firestore/FieldValue.js",
"node_modules/react-native-firebase/dist/modules/firestore/Query.js",
"node_modules/react-native-firebase/dist/modules/firestore/QuerySnapshot.js",
"node_modules/react-native-firebase/dist/modules/firestore/DocumentChange.js",
"node_modules/react-native-firebase/dist/modules/firestore/WriteBatch.js",
"node_modules/react-native-firebase/dist/modules/firestore/TransactionHandler.js",
"node_modules/react-native-firebase/dist/modules/firestore/Transaction.js",
"node_modules/react-native-firebase/dist/modules/functions/index.js",
"node_modules/react-native-firebase/dist/modules/functions/HttpsError.js",
"node_modules/react-native-firebase/dist/modules/iid/index.js",
"node_modules/react-native-firebase/dist/modules/invites/index.js",
"node_modules/react-native-firebase/dist/modules/invites/Invitation.js",
"node_modules/react-native-firebase/dist/modules/invites/AndroidInvitation.js",
"node_modules/react-native-firebase/dist/modules/links/index.js",
"node_modules/react-native-firebase/dist/modules/links/DynamicLink.js",
"node_modules/react-native-firebase/dist/modules/links/AnalyticsParameters.js",
"node_modules/react-native-firebase/dist/modules/links/AndroidParameters.js",
"node_modules/react-native-firebase/dist/modules/links/IOSParameters.js",
"node_modules/react-native-firebase/dist/modules/links/ITunesParameters.js",
"node_modules/react-native-firebase/dist/modules/links/NavigationParameters.js",
"node_modules/react-native-firebase/dist/modules/links/SocialParameters.js",
"node_modules/react-native-firebase/dist/modules/messaging/index.js",
"node_modules/react-native-firebase/dist/modules/messaging/RemoteMessage.js",
"node_modules/react-native-firebase/dist/modules/notifications/index.js",
"node_modules/react-native-firebase/dist/modules/notifications/AndroidAction.js",
"node_modules/react-native-firebase/dist/modules/notifications/AndroidRemoteInput.js",
"node_modules/react-native-firebase/dist/modules/notifications/types.js",
"node_modules/react-native-firebase/dist/modules/notifications/AndroidChannel.js",
"node_modules/react-native-firebase/dist/modules/notifications/AndroidChannelGroup.js",
"node_modules/react-native-firebase/dist/modules/notifications/AndroidNotifications.js",
"node_modules/react-native-firebase/dist/modules/notifications/IOSNotifications.js",
"node_modules/react-native-firebase/dist/modules/notifications/Notification.js",
"node_modules/react-native-firebase/dist/modules/notifications/AndroidNotification.js",
"node_modules/react-native-firebase/dist/modules/notifications/IOSNotification.js",
"node_modules/react-native-firebase/dist/modules/perf/index.js",
"node_modules/react-native-firebase/dist/modules/perf/Trace.js",
"node_modules/react-native-firebase/dist/modules/perf/HttpMetric.js",
"node_modules/react-native-firebase/dist/modules/storage/index.js",
"node_modules/react-native-firebase/dist/modules/storage/reference.js",
"node_modules/react-native-firebase/dist/modules/storage/task.js",
"node_modules/react-native-firebase/dist/modules/utils/index.js",
"node_modules/react-native-firebase/dist/version.js",
"node_modules/react-navigation/src/react-navigation.js",
"node_modules/react-navigation/src/createNavigationContainer.js",
"node_modules/react-navigation/src/NavigationActions.js",
"node_modules/react-navigation/src/getNavigation.js",
"node_modules/react-navigation/src/routers/getNavigationActionCreators.js",
"node_modules/react-navigation/src/utils/invariant.js",
"node_modules/react-navigation/src/getChildNavigation.js",
"node_modules/react-navigation/src/getChildEventSubscriber.js",
"node_modules/react-navigation/src/getChildRouter.js",
"node_modules/react-navigation/src/utils/docsUrl.js",
"node_modules/react-navigation/src/routers/pathUtils.js",
"node_modules/path-to-regexp/index.js",
"node_modules/path-to-regexp/node_modules/isarray/index.js",
"node_modules/react-lifecycles-compat/react-lifecycles-compat.cjs.js",
"node_modules/react-navigation/src/StateUtils.js",
"node_modules/react-navigation/src/navigators/createNavigator.js",
"node_modules/react-navigation/src/navigators/createKeyboardAwareNavigator.js",
"node_modules/react-navigation/src/views/NavigationContext.js",
"node_modules/create-react-context/lib/index.js",
"node_modules/create-react-context/lib/implementation.js",
"node_modules/gud/index.js",
"node_modules/react-navigation-stack/dist/index.js",
"node_modules/react-navigation-stack/dist/navigators/createContainedStackNavigator.js",
"node_modules/react-navigation-stack/dist/navigators/createStackNavigator.js",
"node_modules/react-navigation-stack/dist/views/StackView/StackView.js",
"node_modules/react-navigation-stack/dist/views/StackView/StackViewLayout.js",
"node_modules/react-navigation-stack/dist/utils/clamp.js",
"node_modules/react-navigation-stack/dist/views/StackView/StackViewCard.js",
"node_modules/react-navigation-stack/dist/views/StackView/createPointerEventsContainer.js",
"node_modules/react-navigation-stack/dist/utils/invariant.js",
"node_modules/react-native-screens/src/screens.native.js",
"node_modules/react-navigation-stack/dist/views/Header/Header.js",
"node_modules/react-navigation-stack/dist/views/Header/HeaderTitle.js",
"node_modules/react-navigation-stack/dist/views/Header/HeaderBackButton.js",
"node_modules/react-navigation-stack/dist/views/TouchableItem.js",
"node_modules/react-navigation-stack/dist/views/assets/back-icon.png",
"node_modules/react-navigation-stack/dist/views/Header/ModularHeaderBackButton.js",
"node_modules/react-navigation-stack/dist/views/Header/HeaderStyleInterpolator.js",
"node_modules/react-navigation-stack/dist/utils/getSceneIndicesForInterpolationInputRange.js",
"node_modules/react-navigation-stack/dist/views/StackView/StackViewTransitionConfigs.js",
"node_modules/react-navigation-stack/dist/views/StackView/StackViewStyleInterpolator.js",
"node_modules/react-navigation-stack/dist/utils/ReactNativeFeatures.js",
"node_modules/react-navigation-stack/dist/views/Transitioner.js",
"node_modules/react-navigation-stack/dist/views/ScenesReducer.js",
"node_modules/react-navigation-stack/dist/utils/shallowEqual.js",
"node_modules/react-navigation/src/navigators/createContainedSwitchNavigator.js",
"node_modules/react-navigation/src/navigators/createSwitchNavigator.js",
"node_modules/react-navigation/src/routers/SwitchRouter.js",
"node_modules/react-navigation/src/routers/getScreenForRouteName.js",
"node_modules/react-is/index.js",
"node_modules/react-is/cjs/react-is.production.min.js",
"node_modules/react-navigation/src/routers/createConfigGetter.js",
"node_modules/react-navigation/src/routers/validateScreenOptions.js",
"node_modules/react-navigation/src/routers/StackActions.js",
"node_modules/react-navigation/src/routers/validateRouteConfigMap.js",
"node_modules/react-navigation/src/views/SwitchView/SwitchView.js",
"node_modules/react-navigation/src/views/SceneView.js",
"node_modules/react-navigation-drawer/dist/index.js",
"node_modules/react-navigation-drawer/dist/navigators/createDrawerNavigator.js",
"node_modules/react-navigation-drawer/dist/routers/DrawerRouter.js",
"node_modules/react-navigation-drawer/dist/routers/DrawerActions.js",
"node_modules/react-navigation-drawer/dist/views/DrawerView.js",
"node_modules/react-native-drawer-layout-polyfill/dist/index.android.js",
"node_modules/react-navigation-drawer/dist/views/DrawerSidebar.js",
"node_modules/react-navigation-drawer/dist/utils/invariant.js",
"node_modules/react-navigation-drawer/dist/views/DrawerNavigatorItems.js",
"node_modules/react-navigation-drawer/dist/views/TouchableItem.js",
"node_modules/react-navigation-tabs/src/index.js",
"node_modules/react-navigation-tabs/src/navigators/createBottomTabNavigator.js",
"node_modules/react-navigation-tabs/src/utils/createTabNavigator.js",
"node_modules/react-navigation-tabs/src/views/BottomTabBar.js",
"node_modules/react-navigation-tabs/src/views/CrossFadeIcon.js",
"node_modules/react-navigation-tabs/src/utils/withDimensions.js",
"node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js",
"node_modules/react-navigation-tabs/src/views/ResourceSavingScene.js",
"node_modules/react-navigation/src/routers/StackRouter.js",
"node_modules/react-navigation/src/routers/KeyGenerator.js",
"node_modules/react-navigation/src/routers/TabRouter.js",
"node_modules/react-navigation/src/utils/withDefaultValue.js",
"node_modules/react-navigation/src/views/NavigationEvents.js",
"node_modules/react-navigation/src/views/withNavigation.js",
"node_modules/react-navigation/src/views/withOrientation.js",
"resources/images/ui/dapp-store.png"];

View File

@ -1,37 +1,38 @@
(ns status-im.react-native.js-dependencies) (ns status-im.react-native.js-dependencies
(:require-macros [status-im.utils.js-require :as js-require]))
(def config (js/require "react-native-config")) (def config (js-require/js-require "react-native-config"))
(def fs (js/require "react-native-fs")) (def fs (js-require/js-require "react-native-fs"))
(def http-bridge (js/require "react-native-http-bridge")) (def http-bridge (js-require/js-require "react-native-http-bridge"))
(def keychain (js/require "react-native-keychain")) (def keychain (js-require/js-require "react-native-keychain"))
(def qr-code (js/require "react-native-qrcode")) (def qr-code (js-require/js-require "react-native-qrcode"))
(def react-native (js/require "react-native")) (def react-native (js/require "react-native"))
(def realm (js/require "realm")) (def realm (js/require "realm"))
(def webview-bridge (js/require "react-native-webview-bridge")) (def webview-bridge (js/require "react-native-webview-bridge"))
(def webview #js {:WebView #js {}}) (def webview #js {:WebView #js {}})
(def secure-random (.-generateSecureRandom (js/require "react-native-securerandom"))) (def securerandom (js-require/js-require "react-native-securerandom"))
(def EventEmmiter (js/require "react-native/Libraries/vendor/emitter/EventEmitter")) (defn secure-random [] (.-generateSecureRandom (securerandom)))
(def fetch (.-default (js/require "react-native-fetch-polyfill"))) (def fetch-polyfill (js-require/js-require "react-native-fetch-polyfill"))
(defn fetch [] (.-default (fetch-polyfill)))
(def i18n (js/require "i18n-js")) (def i18n (js/require "i18n-js"))
(def react-native-languages (.-default (js/require "react-native-languages"))) (def react-native-languages (.-default (js/require "react-native-languages")))
(def desktop-linking (.-DesktopLinking (.-NativeModules react-native))) (def desktop-linking (.-DesktopLinking (.-NativeModules react-native)))
(def desktop-menu (js/require "react-native-desktop-menu")) (def desktop-menu (js/require "react-native-desktop-menu"))
(def desktop-config (js/require "react-native-desktop-config")) (def desktop-config (js/require "react-native-desktop-config"))
(def desktop-shortcuts (js/require "react-native-desktop-shortcuts")) (def desktop-shortcuts (js/require "react-native-desktop-shortcuts"))
(def react-native-firebase #js {}) (def react-native-firebase (fn [] #js {}))
(def camera #js {:default #js {:constants {:Aspect "Portrait"}}}) (def camera (fn [] #js {:default #js {:constants {:Aspect "Portrait"}}}))
(def status-keycard #js {:default #js {}}) (def status-keycard (fn [] #js {:default #js {}}))
(def dialogs #js {}) (def dialogs (fn [] #js {}))
(def dismiss-keyboard #js {}) (def dismiss-keyboard (fn [] #js {}))
(def image-crop-picker #js {}) (def image-crop-picker (fn [] #js {}))
(def image-resizer #js {}) (def image-resizer (fn [] #js {}))
(def nfc #js {})
(def svg #js {}) (def svg #js {})
(def snoopy #js {}) (def snoopy (fn [] #js {}))
(def snoopy-filter #js {}) (def snoopy-filter (fn [] #js {}))
(def snoopy-bars #js {}) (def snoopy-bars (fn [] #js {}))
(def snoopy-buffer #js {}) (def snoopy-buffer (fn [] #js {}))
(def background-timer #js {:setTimeout (fn [cb ms] (js/setTimeout cb ms))}) (def background-timer (fn [] #js {:setTimeout (fn [cb ms] (js/setTimeout cb ms))}))
(def react-navigation (js/require "react-navigation")) (def react-navigation (js/require "react-navigation"))
(def react-native-shake #js {}) (def react-native-shake (fn [] #js {}))
(def react-native-mail #js {:mail (fn [])}) (def react-native-mail (fn [] #js {:mail (fn [])}))

View File

@ -1,35 +1,39 @@
(ns status-im.react-native.js-dependencies) (ns status-im.react-native.js-dependencies
(:require-macros [status-im.utils.js-require :as js-require]))
(def config (js/require "react-native-config")) (def config (js-require/js-require "react-native-config"))
(def fs (js/require "react-native-fs")) (def fs (js-require/js-require "react-native-fs"))
(def http-bridge (js/require "react-native-http-bridge")) (def http-bridge (js-require/js-require "react-native-http-bridge"))
(def keychain (js/require "react-native-keychain")) (def keychain (js-require/js-require "react-native-keychain"))
(def qr-code (js/require "react-native-qrcode")) (def qr-code (js-require/js-require "react-native-qrcode"))
(def react-native (js/require "react-native")) (def react-native (js/require "react-native"))
(def status-keycard (js/require "react-native-status-keycard")) (def status-keycard (js-require/js-require "react-native-status-keycard"))
(def realm (js/require "realm")) (def realm (js/require "realm"))
(def webview-bridge (js/require "react-native-webview-bridge")) (def webview-bridge (js-require/js-require "react-native-webview-bridge"))
(def webview (js/require "react-native-webview")) (def webview (js-require/js-require "react-native-webview"))
(def secure-random (.-generateSecureRandom (js/require "react-native-securerandom"))) (def securerandom (js-require/js-require "react-native-securerandom"))
(def EventEmmiter (js/require "react-native/Libraries/vendor/emitter/EventEmitter")) (defn secure-random [] (.-generateSecureRandom (securerandom)))
(def fetch (.-default (js/require "react-native-fetch-polyfill"))) (def fetch-polyfill (js-require/js-require "react-native-fetch-polyfill"))
(defn fetch [] (.-default (fetch-polyfill)))
(def i18n (js/require "i18n-js")) (def i18n (js/require "i18n-js"))
(def react-native-languages (.-default (js/require "react-native-languages"))) (def react-native-languages (.-default (js/require "react-native-languages")))
(def camera (js/require "react-native-camera")) (def camera (js-require/js-require "react-native-camera"))
(def dialogs (js/require "react-native-dialogs")) (def dialogs (js-require/js-require "react-native-dialogs"))
(def dismiss-keyboard (js/require "dismissKeyboard")) (def dismiss-keyboard (js-require/js-require "dismissKeyboard"))
(def image-crop-picker (js/require "react-native-image-crop-picker")) (def image-crop-picker (js-require/js-require "react-native-image-crop-picker"))
(def image-resizer (js/require "react-native-image-resizer")) (def image-resizer (js-require/js-require "react-native-image-resizer"))
(def svg (js/require "react-native-svg")) (def svg (js/require "react-native-svg"))
(def react-native-firebase (js/require "react-native-firebase")) (def react-native-firebase (js-require/js-require "react-native-firebase"))
(def snoopy (js/require "rn-snoopy")) (def snoopy (js-require/js-require "rn-snoopy"))
(def snoopy-filter (js/require "rn-snoopy/stream/filter")) (def snoopy-filter (js-require/js-require "rn-snoopy/stream/filter"))
(def snoopy-bars (js/require "rn-snoopy/stream/bars")) (def snoopy-bars (js-require/js-require "rn-snoopy/stream/bars"))
(def snoopy-buffer (js/require "rn-snoopy/stream/buffer")) (def snoopy-buffer (js-require/js-require "rn-snoopy/stream/buffer"))
(def background-timer (.-default (js/require "react-native-background-timer"))) (def background-timer-class (js-require/js-require "react-native-background-timer"))
(defn background-timer [] (.-default (background-timer-class)))
(def react-navigation (js/require "react-navigation")) (def react-navigation (js/require "react-navigation"))
(def react-native-shake (js/require "react-native-shake")) (def react-native-shake (js-require/js-require "react-native-shake"))
(def react-native-mail (.-default (js/require "react-native-mail"))) (def mail-class (js-require/js-require "react-native-mail"))
(defn react-native-mail [] (.-default (mail-class)))
(def desktop-linking #js {:addEventListener (fn [])}) (def desktop-linking #js {:addEventListener (fn [])})
(def desktop-menu #js {:addEventListener (fn [])}) (def desktop-menu #js {:addEventListener (fn [])})
(def desktop-config #js {:addEventListener (fn [])}) (def desktop-config #js {:addEventListener (fn [])})

View File

@ -15,4 +15,4 @@ if [ ! -z "$METRO_PID" ]; then
[[ $term == 'y' ]] && kill $METRO_PID [[ $term == 'y' ]] && kill $METRO_PID
fi fi
react-native start react-native start --config packager/config.js

View File

@ -29,7 +29,7 @@
(reagent/create-class (reagent/create-class
{:component-will-mount {:component-will-mount
(fn [] (fn []
(.addListener react/keyboard (.addListener (react/keyboard)
"keyboardDidShow" "keyboardDidShow"
(fn [e] (fn [e]
(let [h (.. e -endCoordinates -height)] (let [h (.. e -endCoordinates -height)]
@ -37,16 +37,16 @@
(when-not (= h @keyboard-height) (when-not (= h @keyboard-height)
(dispatch [:set :keyboard-height h]) (dispatch [:set :keyboard-height h])
(dispatch [:set :keyboard-max-height h]))))) (dispatch [:set :keyboard-max-height h])))))
(.addListener react/keyboard (.addListener (react/keyboard)
"keyboardDidHide" "keyboardDidHide"
(fn [_] (fn [_]
(dispatch [:show-tab-bar]) (dispatch [:show-tab-bar])
(when-not (zero? @keyboard-height) (when-not (zero? @keyboard-height)
(dispatch [:set :keyboard-height 0])))) (dispatch [:set :keyboard-height 0]))))
(.hide react/splash-screen) (.hide react/splash-screen)
(.addEventListener react/app-state "change" app-state-change-handler) (.addEventListener (react/app-state) "change" app-state-change-handler)
(.addEventListener rn-dependencies/react-native-languages "change" on-languages-change) (.addEventListener rn-dependencies/react-native-languages "change" on-languages-change)
(.addEventListener rn-dependencies/react-native-shake (.addEventListener (rn-dependencies/react-native-shake)
"ShakeEvent" "ShakeEvent"
on-shake)) on-shake))
:component-did-mount :component-did-mount
@ -54,10 +54,10 @@
(dispatch [:set-initial-props (reagent/props this)])) (dispatch [:set-initial-props (reagent/props this)]))
:component-will-unmount :component-will-unmount
(fn [] (fn []
(.stop react/http-bridge) (.stop (react/http-bridge))
(.removeEventListener react/app-state "change" app-state-change-handler) (.removeEventListener (react/app-state) "change" app-state-change-handler)
(.removeEventListener rn-dependencies/react-native-languages "change" on-languages-change) (.removeEventListener rn-dependencies/react-native-languages "change" on-languages-change)
(.removeEventListener rn-dependencies/react-native-shake (.removeEventListener (rn-dependencies/react-native-shake)
"ShakeEvent" "ShakeEvent"
on-shake)) on-shake))
:display-name "root" :display-name "root"

View File

@ -63,7 +63,7 @@
(defn check-if-phishing-url [{:keys [history history-index] :as browser}] (defn check-if-phishing-url [{:keys [history history-index] :as browser}]
(let [history-host (http/url-host (try (nth history history-index) (catch js/Error _)))] (let [history-host (http/url-host (try (nth history history-index) (catch js/Error _)))]
(cond-> browser history-host (assoc :unsafe? (js-dependencies/phishing-detect history-host))))) (cond-> browser history-host (assoc :unsafe? ((js-dependencies/phishing-detect) history-host)))))
(defn- content->hash [hex] (defn- content->hash [hex]
(when (and hex (not= hex "0x")) (when (and hex (not= hex "0x"))
@ -155,7 +155,7 @@
(defmethod storage-gateway :ipfs (defmethod storage-gateway :ipfs
[{:keys [hash]}] [{:keys [hash]}]
(let [base32hash (-> (.encode js-dependencies/hi-base32 (alphabase.base58/decode hash)) (let [base32hash (-> (.encode (js-dependencies/hi-base32) (alphabase.base58/decode hash))
(string/replace #"=" "") (string/replace #"=" "")
(string/lower-case))] (string/lower-case))]
(str base32hash ".infura.status.im"))) (str base32hash ".infura.status.im")))

View File

@ -401,7 +401,7 @@
{:on-press on-press-handler {:on-press on-press-handler
:style transactions-styles/command-request-image-touchable :style transactions-styles/command-request-image-touchable
:accessibility-label (request-button-label (:name command))} :accessibility-label (request-button-label (:name command))}
[react/animated-view {:style (transactions-styles/command-request-image-view command scale-anim-val)} [(react/animated-view) {:style (transactions-styles/command-request-image-view command scale-anim-val)}
(when command-icon (when command-icon
[react/icon command-icon transactions-styles/command-request-image])]]))}))) [react/icon command-icon transactions-styles/command-request-image])]]))})))

View File

@ -21,7 +21,7 @@
(string/replace text (string/replace text
#":([a-z_\-+0-9]*):" #":([a-z_\-+0-9]*):"
(fn [[original emoji-id]] (fn [[original emoji-id]]
(if-let [emoji-map (object/get (object/get dependencies/emojis "lib") emoji-id)] (if-let [emoji-map (object/get (object/get (dependencies/emojis) "lib") emoji-id)]
(object/get emoji-map "char") (object/get emoji-map "char")
original))))) original)))))

View File

@ -365,8 +365,17 @@
(def ^:private transport-keys [:content :content-type :message-type :clock-value :timestamp]) (def ^:private transport-keys [:content :content-type :message-type :clock-value :timestamp])
(defn remove-icon
"Coin's icon's resource is represented as a function,
can't be properly de/serialised and has to be removed."
[message]
(cond-> message
(get-in message [:content :params :coin :icon :source])
(update-in [:content :params :coin] dissoc :icon)))
(fx/defn upsert-and-send [{:keys [now] :as cofx} {:keys [chat-id from] :as message}] (fx/defn upsert-and-send [{:keys [now] :as cofx} {:keys [chat-id from] :as message}]
(let [send-record (protocol/map->Message (select-keys message transport-keys)) (let [message (remove-icon message)
send-record (protocol/map->Message (select-keys message transport-keys))
old-message-id (transport.utils/old-message-id send-record) old-message-id (transport.utils/old-message-id send-record)
wrapped-record (if (= (:message-type send-record) :group-user-message) wrapped-record (if (= (:message-type send-record) :group-user-message)
(wrap-group-message cofx chat-id send-record) (wrap-group-message cofx chat-id send-record)

View File

@ -222,8 +222,14 @@
(def ^:const status-create-address "status_createaddress") (def ^:const status-create-address "status_createaddress")
(def ^:const event-transfer-hash (def event-transfer-hash
(ethereum/sha3 "Transfer(address,address,uint256)")) (let [hash (atom nil)]
(fn []
(if @hash
@hash
(reset!
hash
(ethereum/sha3 "Transfer(address,address,uint256)"))))))
(def regx-emoji #"^((?:[\u261D\u26F9\u270A-\u270D]|\uD83C[\uDF85\uDFC2-\uDFC4\uDFC7\uDFCA-\uDFCC]|\uD83D[\uDC42\uDC43\uDC46-\uDC50\uDC66-\uDC69\uDC6E\uDC70-\uDC78\uDC7C\uDC81-\uDC83\uDC85-\uDC87\uDCAA\uDD74\uDD75\uDD7A\uDD90\uDD95\uDD96\uDE45-\uDE47\uDE4B-\uDE4F\uDEA3\uDEB4-\uDEB6\uDEC0\uDECC]|\uD83E[\uDD18-\uDD1C\uDD1E\uDD1F\uDD26\uDD30-\uDD39\uDD3D\uDD3E\uDDD1-\uDDDD])(?:\uD83C[\uDFFB-\uDFFF])?|(?:[\u231A\u231B\u23E9-\u23EC\u23F0\u23F3\u25FD\u25FE\u2614\u2615\u2648-\u2653\u267F\u2693\u26A1\u26AA\u26AB\u26BD\u26BE\u26C4\u26C5\u26CE\u26D4\u26EA\u26F2\u26F3\u26F5\u26FA\u26FD\u2705\u270A\u270B\u2728\u274C\u274E\u2753-\u2755\u2757\u2795-\u2797\u27B0\u27BF\u2B1B\u2B1C\u2B50\u2B55]|\uD83C[\uDC04\uDCCF\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF7C\uDF7E-\uDF93\uDFA0-\uDFCA\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF4\uDFF8-\uDFFF]|\uD83D[\uDC00-\uDC3E\uDC40\uDC42-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDD7A\uDD95\uDD96\uDDA4\uDDFB-\uDE4F\uDE80-\uDEC5\uDECC\uDED0-\uDED2\uDEEB\uDEEC\uDEF4-\uDEF8]|\uD83E[\uDD10-\uDD3A\uDD3C-\uDD3E\uDD40-\uDD45\uDD47-\uDD4C\uDD50-\uDD6B\uDD80-\uDD97\uDDC0\uDDD0-\uDDE6])|(?:[#\*0-9\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u231A\u231B\u2328\u23CF\u23E9-\u23F3\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB-\u25FE\u2600-\u2604\u260E\u2611\u2614\u2615\u2618\u261D\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u2648-\u2653\u2660\u2663\u2665\u2666\u2668\u267B\u267F\u2692-\u2697\u2699\u269B\u269C\u26A0\u26A1\u26AA\u26AB\u26B0\u26B1\u26BD\u26BE\u26C4\u26C5\u26C8\u26CE\u26CF\u26D1\u26D3\u26D4\u26E9\u26EA\u26F0-\u26F5\u26F7-\u26FA\u26FD\u2702\u2705\u2708-\u270D\u270F\u2712\u2714\u2716\u271D\u2721\u2728\u2733\u2734\u2744\u2747\u274C\u274E\u2753-\u2755\u2757\u2763\u2764\u2795-\u2797\u27A1\u27B0\u27BF\u2934\u2935\u2B05-\u2B07\u2B1B\u2B1C\u2B50\u2B55\u3030\u303D\u3297\u3299]|\uD83C[\uDC04\uDCCF\uDD70\uDD71\uDD7E\uDD7F\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE02\uDE1A\uDE2F\uDE32-\uDE3A\uDE50\uDE51\uDF00-\uDF21\uDF24-\uDF93\uDF96\uDF97\uDF99-\uDF9B\uDF9E-\uDFF0\uDFF3-\uDFF5\uDFF7-\uDFFF]|\uD83D[\uDC00-\uDCFD\uDCFF-\uDD3D\uDD49-\uDD4E\uDD50-\uDD67\uDD6F\uDD70\uDD73-\uDD7A\uDD87\uDD8A-\uDD8D\uDD90\uDD95\uDD96\uDDA4\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA-\uDE4F\uDE80-\uDEC5\uDECB-\uDED2\uDEE0-\uDEE5\uDEE9\uDEEB\uDEEC\uDEF0\uDEF3-\uDEF8]|\uD83E[\uDD10-\uDD3A\uDD3C-\uDD3E\uDD40-\uDD45\uDD47-\uDD4C\uDD50-\uDD6B\uDD80-\uDD97\uDDC0\uDDD0-\uDDE6])\uFE0F|[\t-\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF])+$") (def regx-emoji #"^((?:[\u261D\u26F9\u270A-\u270D]|\uD83C[\uDF85\uDFC2-\uDFC4\uDFC7\uDFCA-\uDFCC]|\uD83D[\uDC42\uDC43\uDC46-\uDC50\uDC66-\uDC69\uDC6E\uDC70-\uDC78\uDC7C\uDC81-\uDC83\uDC85-\uDC87\uDCAA\uDD74\uDD75\uDD7A\uDD90\uDD95\uDD96\uDE45-\uDE47\uDE4B-\uDE4F\uDEA3\uDEB4-\uDEB6\uDEC0\uDECC]|\uD83E[\uDD18-\uDD1C\uDD1E\uDD1F\uDD26\uDD30-\uDD39\uDD3D\uDD3E\uDDD1-\uDDDD])(?:\uD83C[\uDFFB-\uDFFF])?|(?:[\u231A\u231B\u23E9-\u23EC\u23F0\u23F3\u25FD\u25FE\u2614\u2615\u2648-\u2653\u267F\u2693\u26A1\u26AA\u26AB\u26BD\u26BE\u26C4\u26C5\u26CE\u26D4\u26EA\u26F2\u26F3\u26F5\u26FA\u26FD\u2705\u270A\u270B\u2728\u274C\u274E\u2753-\u2755\u2757\u2795-\u2797\u27B0\u27BF\u2B1B\u2B1C\u2B50\u2B55]|\uD83C[\uDC04\uDCCF\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE1A\uDE2F\uDE32-\uDE36\uDE38-\uDE3A\uDE50\uDE51\uDF00-\uDF20\uDF2D-\uDF35\uDF37-\uDF7C\uDF7E-\uDF93\uDFA0-\uDFCA\uDFCF-\uDFD3\uDFE0-\uDFF0\uDFF4\uDFF8-\uDFFF]|\uD83D[\uDC00-\uDC3E\uDC40\uDC42-\uDCFC\uDCFF-\uDD3D\uDD4B-\uDD4E\uDD50-\uDD67\uDD7A\uDD95\uDD96\uDDA4\uDDFB-\uDE4F\uDE80-\uDEC5\uDECC\uDED0-\uDED2\uDEEB\uDEEC\uDEF4-\uDEF8]|\uD83E[\uDD10-\uDD3A\uDD3C-\uDD3E\uDD40-\uDD45\uDD47-\uDD4C\uDD50-\uDD6B\uDD80-\uDD97\uDDC0\uDDD0-\uDDE6])|(?:[#\*0-9\xA9\xAE\u203C\u2049\u2122\u2139\u2194-\u2199\u21A9\u21AA\u231A\u231B\u2328\u23CF\u23E9-\u23F3\u23F8-\u23FA\u24C2\u25AA\u25AB\u25B6\u25C0\u25FB-\u25FE\u2600-\u2604\u260E\u2611\u2614\u2615\u2618\u261D\u2620\u2622\u2623\u2626\u262A\u262E\u262F\u2638-\u263A\u2640\u2642\u2648-\u2653\u2660\u2663\u2665\u2666\u2668\u267B\u267F\u2692-\u2697\u2699\u269B\u269C\u26A0\u26A1\u26AA\u26AB\u26B0\u26B1\u26BD\u26BE\u26C4\u26C5\u26C8\u26CE\u26CF\u26D1\u26D3\u26D4\u26E9\u26EA\u26F0-\u26F5\u26F7-\u26FA\u26FD\u2702\u2705\u2708-\u270D\u270F\u2712\u2714\u2716\u271D\u2721\u2728\u2733\u2734\u2744\u2747\u274C\u274E\u2753-\u2755\u2757\u2763\u2764\u2795-\u2797\u27A1\u27B0\u27BF\u2934\u2935\u2B05-\u2B07\u2B1B\u2B1C\u2B50\u2B55\u3030\u303D\u3297\u3299]|\uD83C[\uDC04\uDCCF\uDD70\uDD71\uDD7E\uDD7F\uDD8E\uDD91-\uDD9A\uDDE6-\uDDFF\uDE01\uDE02\uDE1A\uDE2F\uDE32-\uDE3A\uDE50\uDE51\uDF00-\uDF21\uDF24-\uDF93\uDF96\uDF97\uDF99-\uDF9B\uDF9E-\uDFF0\uDFF3-\uDFF5\uDFF7-\uDFFF]|\uD83D[\uDC00-\uDCFD\uDCFF-\uDD3D\uDD49-\uDD4E\uDD50-\uDD67\uDD6F\uDD70\uDD73-\uDD7A\uDD87\uDD8A-\uDD8D\uDD90\uDD95\uDD96\uDDA4\uDDA5\uDDA8\uDDB1\uDDB2\uDDBC\uDDC2-\uDDC4\uDDD1-\uDDD3\uDDDC-\uDDDE\uDDE1\uDDE3\uDDE8\uDDEF\uDDF3\uDDFA-\uDE4F\uDE80-\uDEC5\uDECB-\uDED2\uDEE0-\uDEE5\uDEE9\uDEEB\uDEEC\uDEF0\uDEF3-\uDEF8]|\uD83E[\uDD10-\uDD3A\uDD3C-\uDD3E\uDD40-\uDD45\uDD47-\uDD4C\uDD50-\uDD6B\uDD80-\uDD97\uDDC0\uDDD0-\uDDE6])\uFE0F|[\t-\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF])+$")
(def regx-rtl-characters #"[^\u0591-\u06EF\u06FA-\u07FF\u200F\u202B\u202E\uFB1D-\uFDFD\uFE70-\uFEFC]*?[\u0591-\u06EF\u06FA-\u07FF\u200F\u202B\u202E\uFB1D-\uFDFD\uFE70-\uFEFC]") (def regx-rtl-characters #"[^\u0591-\u06EF\u06FA-\u07FF\u200F\u202B\u202E\uFB1D-\uFDFD\uFE70-\uFEFC]*?[\u0591-\u06EF\u06FA-\u07FF\u200F\u202B\u202E\uFB1D-\uFDFD\uFE70-\uFEFC]")

View File

@ -66,7 +66,7 @@
(upsert-contact contact) (upsert-contact contact)
(mailserver/upsert-mailserver-topic (mailserver/upsert-mailserver-topic
{:chat-ids [public-key] {:chat-ids [public-key]
:topic transport.topic/discovery-topic-hash :topic (transport.topic/discovery-topic-hash)
:fetch? false}) :fetch? false})
(send-contact-request contact) (send-contact-request contact)
(mailserver/process-next-messages-request))))) (mailserver/process-next-messages-request)))))

View File

@ -66,7 +66,7 @@
128 public-key 128 public-key
nil)] nil)]
(when normalized-key (when normalized-key
(subs (.sha3 js-dependencies/Web3.prototype normalized-key #js {:encoding "hex"}) 26)))) (subs (.sha3 (js-dependencies/web3-prototype) normalized-key #js {:encoding "hex"}) 26))))
(defn public-key->new-contact [public-key] (defn public-key->new-contact [public-key]
{:name (gfycat/generate-gfy public-key) {:name (gfycat/generate-gfy public-key)

View File

@ -5,7 +5,8 @@
[status-im.constants :as constants] [status-im.constants :as constants]
[status-im.data-store.realm.core :as core] [status-im.data-store.realm.core :as core]
[status-im.utils.core :as utils] [status-im.utils.core :as utils]
[status-im.js-dependencies :as dependencies])) [status-im.js-dependencies :as dependencies]
[taoensso.timbre :as log]))
(defn- transform-message [{:keys [content] :as message}] (defn- transform-message [{:keys [content] :as message}]
(when-let [parsed-content (utils/safe-read-message-content content)] (when-let [parsed-content (utils/safe-read-message-content content)]
@ -78,7 +79,7 @@
(assoc cofx :get-stored-messages get-by-chat-id))) (assoc cofx :get-stored-messages get-by-chat-id)))
(defn- sha3 [s] (defn- sha3 [s]
(.sha3 dependencies/Web3.prototype s)) (.sha3 (dependencies/web3-prototype) s))
(re-frame/reg-cofx (re-frame/reg-cofx
:data-store/get-referenced-messages :data-store/get-referenced-messages

View File

@ -154,7 +154,7 @@
(open-realm (last schemas) file-name encryption-key)) (open-realm (last schemas) file-name encryption-key))
(defn keccak512-array [key] (defn keccak512-array [key]
(.array (.-keccak512 js-dependencies/js-sha3) key)) (.array (.-keccak512 (js-dependencies/js-sha3)) key))
(defn merge-Uint8Arrays [arr1 arr2] (defn merge-Uint8Arrays [arr1 arr2]
(let [arr1-length (.-length arr1) (let [arr1-length (.-length arr1)
@ -165,8 +165,9 @@
arr)) arr))
(defn db-encryption-key [password encryption-key] (defn db-encryption-key [password encryption-key]
(let [password-array (.encode (let [TextEncoder (.-TextEncoder (js-dependencies/text-encoding))
(new (.-TextEncoder js-dependencies/text-encoding)) password-array (.encode
(new TextEncoder)
password)] password)]
(keccak512-array (merge-Uint8Arrays encryption-key password-array)))) (keccak512-array (merge-Uint8Arrays encryption-key password-array))))

View File

@ -191,7 +191,7 @@
"status-im.transport.message.protocol")) "status-im.transport.message.protocol"))
(defn sha3 [s] (defn sha3 [s]
(.sha3 dependencies/Web3.prototype s)) (.sha3 (dependencies/web3-prototype) s))
(defn old-message-id (defn old-message-id
"Calculates the same `message-id` as was used in `0.9.31`" "Calculates the same `message-id` as was used in `0.9.31`"

View File

@ -24,14 +24,14 @@
(reagent/create-class (reagent/create-class
{:component-will-mount {:component-will-mount
(fn [] (fn []
(.addEventListener react/app-state "change" app-state-change-handler)) (.addEventListener (react/app-state) "change" app-state-change-handler))
:component-did-mount :component-did-mount
(fn [this] (fn [this]
(re-frame/dispatch [:set-initial-props (reagent/props this)])) (re-frame/dispatch [:set-initial-props (reagent/props this)]))
:component-will-unmount :component-will-unmount
(fn [] (fn []
(.stop react/http-bridge) (.stop (react/http-bridge))
(.removeEventListener react/app-state "change" app-state-change-handler)) (.removeEventListener (react/app-state) "change" app-state-change-handler))
:display-name "root" :display-name "root"
:reagent-render views/main}) :reagent-render views/main})
(reagent/create-class (reagent/create-class

View File

@ -11,14 +11,14 @@
"Status Android")) "Status Android"))
(defn respond! [request-id status-code data] (defn respond! [request-id status-code data]
(.respond react/http-bridge (.respond (react/http-bridge)
request-id request-id
status-code status-code
"application/json" "application/json"
(types/clj->json data))) (types/clj->json data)))
(defn start! [] (defn start! []
(.start react/http-bridge (.start (react/http-bridge)
port port
server-name server-name
(fn [req] (fn [req]
@ -33,4 +33,4 @@
(log/debug "Error: " e)))))) (log/debug "Error: " e))))))
(defn stop! [] (defn stop! []
(.stop react/http-bridge)) (.stop (react/http-bridge)))

View File

@ -4,54 +4,54 @@
[status-im.js-dependencies :as dependencies])) [status-im.js-dependencies :as dependencies]))
;; Utility functions for encoding ;; Utility functions for encoding
(def utils dependencies/web3-utils) (defn utils [] (dependencies/web3-utils))
(defn right-pad [x] (defn right-pad [x]
(let [len (count x) (let [len (count x)
to-pad (- 64 (mod len 64))] to-pad (- 64 (mod len 64))]
(if (= 64 to-pad) (if (= 64 to-pad)
x x
(.rightPad utils x (+ len to-pad))))) (.rightPad (utils) x (+ len to-pad)))))
(defn left-pad [x] (defn left-pad [x]
(let [len (count x) (let [len (count x)
to-pad (- 64 (mod len 64))] to-pad (- 64 (mod len 64))]
(if (= 64 to-pad) (if (= 64 to-pad)
x x
(.leftPad utils x (+ len to-pad))))) (.leftPad (utils) x (+ len to-pad)))))
(defn to-two-complement [x] (defn to-two-complement [x]
(when x (when x
(subs (.toTwosComplement utils x) 2))) (subs (.toTwosComplement (utils) x) 2)))
(defn from-utf8 [x] (defn from-utf8 [x]
(when x (when x
(subs (.fromUtf8 utils x) 2))) (subs (.fromUtf8 (utils) x) 2)))
(defn hex-to-boolean [x] (defn hex-to-boolean [x]
(= x "0x0")) (= x "0x0"))
(defn bytes-to-hex [x] (defn bytes-to-hex [x]
(when x (when x
(subs (.bytesToHex utils x) 2))) (subs (.bytesToHex (utils) x) 2)))
(defn number-to-hex [x] (defn number-to-hex [x]
(when x (when x
(subs (.numberToHex utils x) 2))) (subs (.numberToHex (utils) x) 2)))
(defn hex-to-utf8 [x] (defn hex-to-utf8 [x]
(.hexToUtf8 utils (str "0x" x))) (.hexToUtf8 (utils) (str "0x" x)))
(defn hex-to-number [x] (defn hex-to-number [x]
(when x (when x
(let [hex-x (str "0x" x)] (let [hex-x (str "0x" x)]
(try (try
(.hexToNumber utils hex-x) (.hexToNumber (utils) hex-x)
(catch :default err (catch :default err
(.hexToNumberString utils hex-x)))))) (.hexToNumberString (utils) hex-x))))))
(defn sha3 [s] (defn sha3 [s]
(.sha3 utils (str s))) (.sha3 (utils) (str s)))
(defn is-hex? [value] (defn is-hex? [value]
(when value (when value

View File

@ -49,7 +49,7 @@
(defn address? [s] (defn address? [s]
(when s (when s
(.isAddress dependencies/Web3.prototype s))) (.isAddress (dependencies/web3-prototype) s)))
(defn network->chain-id [network] (defn network->chain-id [network]
(get-in network [:config :NetworkId])) (get-in network [:config :NetworkId]))
@ -70,9 +70,9 @@
(defn sha3 (defn sha3
([s] ([s]
(.sha3 dependencies/Web3.prototype (str s))) (.sha3 (dependencies/web3-prototype) (str s)))
([s opts] ([s opts]
(.sha3 dependencies/Web3.prototype (str s) (clj->js opts)))) (.sha3 (dependencies/web3-prototype) (str s) (clj->js opts))))
(def default-transaction-gas (money/bignumber 21000)) (def default-transaction-gas (money/bignumber 21000))

View File

@ -7,15 +7,15 @@
(:require [clojure.string :as string] (:require [clojure.string :as string]
[status-im.js-dependencies :as dependencies])) [status-im.js-dependencies :as dependencies]))
(def utils dependencies/web3-utils) (defn utils [] (dependencies/web3-utils))
(defn address->checksum (defn address->checksum
"Converts an arbitrary case address to one with correct checksum case." "Converts an arbitrary case address to one with correct checksum case."
[address] [address]
(when address (when address
(.toChecksumAddress utils address))) (.toChecksumAddress (utils) address)))
(defn valid-address-checksum? (defn valid-address-checksum?
"Checks address checksum validity." "Checks address checksum validity."
[address] [address]
(.checkAddressChecksum utils address)) (.checkAddressChecksum (utils) address))

View File

@ -4,10 +4,19 @@
(defn token-icon-path (defn token-icon-path
[network symbol] [network symbol]
(let [s (str "./resources/images/tokens/" (name network) "/" (name symbol) ".png")] (let [s (str "./resources/images/tokens/" (name network) "/" (name symbol) ".png")
image (gensym)]
(if (.exists (io/file s)) (if (.exists (io/file s))
`(js/require ~s) `(let [~image (atom nil)]
`(js/require "./resources/images/tokens/default-token.png")))) (fn []
(or @~image
(reset! ~image (js/require ~s)))))
`(let [~image (atom nil)]
(fn []
(or
@~image
(reset! ~image
(js/require "./resources/images/tokens/default-token.png"))))))))
(defn- token->icon [network {:keys [icon symbol]}] (defn- token->icon [network {:keys [icon symbol]}]
;; Tokens can define their own icons. ;; Tokens can define their own icons.
@ -21,10 +30,19 @@
(mapv #(assoc-in % [:icon :source] (token->icon network %)) tokens)) (mapv #(assoc-in % [:icon :source] (token->icon network %)) tokens))
(defn network->icon [network] (defn network->icon [network]
(let [s (str "./resources/images/tokens/" (name network) "/0-native.png")] (let [s (str "./resources/images/tokens/" (name network) "/0-native.png")
image (gensym)]
(if (.exists (io/file s)) (if (.exists (io/file s))
`(js/require ~s) `(let [~image (atom nil)]
`(js/require "./resources/images/tokens/default-native.png")))) (fn []
(or @~image
(reset! ~image (js/require ~s)))))
`(let [~image (atom nil)]
(fn []
(or
@~image
(reset! ~image
(js/require "./resources/images/tokens/default-native.png"))))))))
(defmacro resolve-native-currency-icons (defmacro resolve-native-currency-icons
"In react-native arguments to require must be static strings. "In react-native arguments to require must be static strings.

View File

@ -7,10 +7,12 @@
{:border-color color :border-width 1 :border-radius 32}) {:border-color color :border-width 1 :border-radius 32})
(def default-native-currency (def default-native-currency
{:name "Native" (memoize
:symbol :ETH (fn []
:decimals 18 {:name "Native"
:icon {:source (js/require "./resources/images/tokens/default-native.png")}}) :symbol :ETH
:decimals 18
:icon {:source (js/require "./resources/images/tokens/default-native.png")}})))
(def all-native-currencies (def all-native-currencies
(ethereum.macros/resolve-native-currency-icons (ethereum.macros/resolve-native-currency-icons
@ -40,7 +42,7 @@
(set (map #(-> % val :symbol) all-native-currencies))) (set (map #(-> % val :symbol) all-native-currencies)))
(defn native-currency [chain] (defn native-currency [chain]
(-> (get all-native-currencies chain default-native-currency))) (-> (get all-native-currencies chain (default-native-currency))))
(defn ethereum? [symbol] (defn ethereum? [symbol]
(native-currency-symbols symbol)) (native-currency-symbols symbol))

View File

@ -184,7 +184,7 @@
(def CUD-url "https://chaos-unicorn-day.org") (def CUD-url "https://chaos-unicorn-day.org")
(defn open-chaos-unicorn-day-link [] (defn open-chaos-unicorn-day-link []
(.openURL react/linking CUD-url)) (.openURL (react/linking) CUD-url))
(handlers/register-handler-fx (handlers/register-handler-fx
:accounts.ui/chaos-mode-switched :accounts.ui/chaos-mode-switched

View File

@ -47,8 +47,8 @@
[tooltip/tooltip error (styles/error error)])]) [tooltip/tooltip error (styles/error error)])])
(defn touchable-opacity [{:keys [style on-press]} & children] (defn touchable-opacity [{:keys [style on-press]} & children]
(into [react/touchable-opacity (merge (when on-press {:on-press #(on-press {})}) (into [(react/touchable-opacity) (merge (when on-press {:on-press #(on-press {})})
(when style {:style style}))] children)) (when style {:style style}))] children))
(defn image [{:keys [source uri style]}] (defn image [{:keys [source uri style]}]
[react/image (merge {:style (merge {:width 100 :height 100} style)} {:source (if source source {:uri uri})})]) [react/image (merge {:style (merge {:width 100 :height 100} style)} {:source (if source source {:uri uri})})])
@ -57,7 +57,7 @@
[react/text (merge {:style {:color colors/white [react/text (merge {:style {:color colors/white
:text-decoration-line :underline} :text-decoration-line :underline}
:on-press (case open-in :on-press (case open-in
:device #(.openURL react/linking uri) :device #(.openURL (react/linking) uri)
:status #(re-frame/dispatch [:browser.ui/open-in-status-option-selected uri]) :status #(re-frame/dispatch [:browser.ui/open-in-status-option-selected uri])
#(re-frame/dispatch [:browser.ui/message-link-pressed uri]))} #(re-frame/dispatch [:browser.ui/message-link-pressed uri]))}
(when style {:style style})) (when style {:style style}))
@ -119,7 +119,7 @@
(apply abstract-view react/view o children)) (apply abstract-view react/view o children))
(defn scroll-view [o & children] (defn scroll-view [o & children]
(apply abstract-view react/scroll-view o children)) (apply abstract-view (react/scroll-view) o children))
(defn keyboard-avoiding-view [o & children] (defn keyboard-avoiding-view [o & children]
(apply abstract-view react/keyboard-avoiding-view o children)) (apply abstract-view react/keyboard-avoiding-view o children))
@ -158,4 +158,4 @@
:fly? :boolean :fly? :boolean
:interactive? :boolean :interactive? :boolean
:on-change :event}} :on-change :event}}
'map-link {:data map-link :properties {:text :string :lng :any :lat :any}}}) 'map-link {:data map-link :properties {:text :string :lng :any :lat :any}}})

View File

@ -14,7 +14,9 @@
(def mapview-html (slurp "resources/mapview/mapview.html")) (def mapview-html (slurp "resources/mapview/mapview.html"))
(def webview-class (def webview-class
(reagent/adapt-react-class (.-WebView js-dependencies/webview))) (memoize
(fn []
(reagent/adapt-react-class (.-WebView js-dependencies/webview)))))
(defn map-component (defn map-component
"creates a webview reagent component which cause webview to be updated only when style changes. "creates a webview reagent component which cause webview to be updated only when style changes.
@ -32,7 +34,7 @@
false))) false)))
:reagent-render :reagent-render
(fn [opts] (fn [opts]
[webview-class opts])})) [(webview-class) opts])}))
(defn- on-map-message [map-event on-change] (defn- on-map-message [map-event on-change]
(let [data (-> map-event (let [data (-> map-event
@ -69,7 +71,7 @@
:on-should-start-load-with-request #(let [url (.-url %)] :on-should-start-load-with-request #(let [url (.-url %)]
(if (string/starts-with? url "file") (if (string/starts-with? url "file")
true true
(do (.openURL react/linking url) false))) (do (.openURL (react/linking) url) false)))
:ref #(reset! webview %) :ref #(reset! webview %)
:on-message #(when on-change (on-map-message % on-change)) :on-message #(when on-change (on-map-message % on-change))
@ -78,4 +80,4 @@
(if (map? marker) (if (map? marker)
(str "update(" (types/clj->json (assoc marker :fly fly? :interactive interactive?)) ");") (str "update(" (types/clj->json (assoc marker :fly fly? :interactive interactive?)) ");")
(str "init(" (types/clj->json {:interactive interactive?}) ");")))} (str "init(" (types/clj->json {:interactive interactive?}) ");")))}
webview])) webview]))

View File

@ -220,7 +220,7 @@
:db (assoc db :group/selected-contacts #{})} :db (assoc db :group/selected-contacts #{})}
(mailserver/upsert-mailserver-topic (mailserver/upsert-mailserver-topic
{:chat-ids [chat-id] {:chat-ids [chat-id]
:topic transport.topic/discovery-topic-hash :topic (transport.topic/discovery-topic-hash)
:fetch? false}) :fetch? false})
(mailserver/process-next-messages-request)))) (mailserver/process-next-messages-request))))
@ -257,7 +257,7 @@
:events [event]}} :events [event]}}
(mailserver/upsert-mailserver-topic (mailserver/upsert-mailserver-topic
{:chat-ids [chat-id] {:chat-ids [chat-id]
:topic transport.topic/discovery-topic-hash :topic (transport.topic/discovery-topic-hash)
:fetch false}) :fetch false})
(mailserver/process-next-messages-request))))) (mailserver/process-next-messages-request)))))

View File

@ -2,11 +2,11 @@
(:require [re-frame.core :as re-frame] (:require [re-frame.core :as re-frame]
[status-im.react-native.js-dependencies :as js-dependencies] [status-im.react-native.js-dependencies :as js-dependencies]
[status-im.utils.config :as config] [status-im.utils.config :as config]
[status-im.utils.platform :as platform] [status-im.utils.platform :as platform]))
[taoensso.timbre :as log]))
(defonce keycard (.-default js-dependencies/status-keycard)) (defn keycard [] (.-default (js-dependencies/status-keycard)))
(defonce event-emitter (.-DeviceEventEmitter js-dependencies/react-native)) (defn event-emitter []
(.-DeviceEventEmitter js-dependencies/react-native))
(defn- error-object->map [object] (defn- error-object->map [object]
{:code (.-code object) {:code (.-code object)
@ -15,24 +15,24 @@
(defn check-nfc-support [] (defn check-nfc-support []
(when (and config/hardwallet-enabled? (when (and config/hardwallet-enabled?
platform/android?) platform/android?)
(.. keycard (.. (keycard)
nfcIsSupported nfcIsSupported
(then #(re-frame/dispatch [:hardwallet.callback/check-nfc-support-success %]))))) (then #(re-frame/dispatch [:hardwallet.callback/check-nfc-support-success %])))))
(defn check-nfc-enabled [] (defn check-nfc-enabled []
(when (and config/hardwallet-enabled? (when (and config/hardwallet-enabled?
platform/android?) platform/android?)
(.. keycard (.. (keycard)
nfcIsEnabled nfcIsEnabled
(then #(re-frame/dispatch [:hardwallet.callback/check-nfc-enabled-success %]))))) (then #(re-frame/dispatch [:hardwallet.callback/check-nfc-enabled-success %])))))
(defn open-nfc-settings [] (defn open-nfc-settings []
(when platform/android? (when platform/android?
(.openNfcSettings keycard))) (.openNfcSettings (keycard))))
(defn remove-event-listeners [] (defn remove-event-listeners []
(doseq [event ["keyCardOnConnected" "keyCardOnDisconnected"]] (doseq [event ["keyCardOnConnected" "keyCardOnDisconnected"]]
(.removeAllListeners event-emitter event))) (.removeAllListeners (event-emitter) event)))
(defn register-card-events [] (defn register-card-events []
(when (and config/hardwallet-enabled?) (when (and config/hardwallet-enabled?)
@ -41,38 +41,38 @@
(re-frame/dispatch [:hardwallet.callback/on-register-card-events (re-frame/dispatch [:hardwallet.callback/on-register-card-events
{:on-card-connected {:on-card-connected
(.addListener event-emitter (.addListener (event-emitter)
"keyCardOnConnected" "keyCardOnConnected"
#(re-frame/dispatch [:hardwallet.callback/on-card-connected %])) #(re-frame/dispatch [:hardwallet.callback/on-card-connected %]))
:on-card-disconnected :on-card-disconnected
(.addListener event-emitter (.addListener (event-emitter)
"keyCardOnDisconnected" "keyCardOnDisconnected"
#(re-frame/dispatch [:hardwallet.callback/on-card-disconnected %]))}]))) #(re-frame/dispatch [:hardwallet.callback/on-card-disconnected %]))}])))
(defn get-application-info [{:keys [pairing on-success]}] (defn get-application-info [{:keys [pairing on-success]}]
(.. keycard (.. (keycard)
(getApplicationInfo (str pairing)) (getApplicationInfo (str pairing))
(then #(re-frame/dispatch [:hardwallet.callback/on-get-application-info-success % on-success])) (then #(re-frame/dispatch [:hardwallet.callback/on-get-application-info-success % on-success]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-get-application-info-error (error-object->map %)])))) (catch #(re-frame/dispatch [:hardwallet.callback/on-get-application-info-error (error-object->map %)]))))
(defn install-applet [] (defn install-applet []
(when config/hardwallet-enabled? (when config/hardwallet-enabled?
(.. keycard (.. (keycard)
installApplet installApplet
(then #(re-frame/dispatch [:hardwallet.callback/on-install-applet-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-install-applet-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-install-applet-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-install-applet-error (error-object->map %)])))))
(defn init-card [pin] (defn init-card [pin]
(when config/hardwallet-enabled? (when config/hardwallet-enabled?
(.. keycard (.. (keycard)
(init pin) (init pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-init-card-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-init-card-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-init-card-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-init-card-error (error-object->map %)])))))
(defn install-applet-and-init-card [pin] (defn install-applet-and-init-card [pin]
(when config/hardwallet-enabled? (when config/hardwallet-enabled?
(.. keycard (.. (keycard)
(installAppletAndInitCard pin) (installAppletAndInitCard pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-install-applet-and-init-card-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-install-applet-and-init-card-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-install-applet-and-init-card-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-install-applet-and-init-card-error (error-object->map %)])))))
@ -80,7 +80,7 @@
(defn pair (defn pair
[{:keys [password]}] [{:keys [password]}]
(when password (when password
(.. keycard (.. (keycard)
(pair password) (pair password)
(then #(re-frame/dispatch [:hardwallet.callback/on-pairing-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-pairing-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-pairing-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-pairing-error (error-object->map %)])))))
@ -88,7 +88,7 @@
(defn generate-mnemonic (defn generate-mnemonic
[{:keys [pairing words]}] [{:keys [pairing words]}]
(when pairing (when pairing
(.. keycard (.. (keycard)
(generateMnemonic pairing words) (generateMnemonic pairing words)
(then #(re-frame/dispatch [:hardwallet.callback/on-generate-mnemonic-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-generate-mnemonic-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-generate-mnemonic-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-generate-mnemonic-error (error-object->map %)])))))
@ -96,7 +96,7 @@
(defn generate-and-load-key (defn generate-and-load-key
[{:keys [mnemonic pairing pin]}] [{:keys [mnemonic pairing pin]}]
(when pairing (when pairing
(.. keycard (.. (keycard)
(generateAndLoadKey mnemonic pairing pin) (generateAndLoadKey mnemonic pairing pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-generate-and-load-key-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-generate-and-load-key-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-generate-and-load-key-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-generate-and-load-key-error (error-object->map %)])))))
@ -104,7 +104,7 @@
(defn unblock-pin (defn unblock-pin
[{:keys [puk new-pin pairing]}] [{:keys [puk new-pin pairing]}]
(when (and pairing new-pin puk) (when (and pairing new-pin puk)
(.. keycard (.. (keycard)
(unblockPin pairing puk new-pin) (unblockPin pairing puk new-pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-unblock-pin-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-unblock-pin-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-unblock-pin-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-unblock-pin-error (error-object->map %)])))))
@ -112,7 +112,7 @@
(defn verify-pin (defn verify-pin
[{:keys [pin pairing]}] [{:keys [pin pairing]}]
(when (and pairing (not-empty pin)) (when (and pairing (not-empty pin))
(.. keycard (.. (keycard)
(verifyPin pairing pin) (verifyPin pairing pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-verify-pin-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-verify-pin-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-verify-pin-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-verify-pin-error (error-object->map %)])))))
@ -120,7 +120,7 @@
(defn change-pin (defn change-pin
[{:keys [current-pin new-pin pairing]}] [{:keys [current-pin new-pin pairing]}]
(when (and pairing current-pin new-pin) (when (and pairing current-pin new-pin)
(.. keycard (.. (keycard)
(changePin pairing current-pin new-pin) (changePin pairing current-pin new-pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-change-pin-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-change-pin-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-change-pin-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-change-pin-error (error-object->map %)])))))
@ -128,28 +128,28 @@
(defn unpair (defn unpair
[{:keys [pin pairing]}] [{:keys [pin pairing]}]
(when (and pairing pin) (when (and pairing pin)
(.. keycard (.. (keycard)
(unpair pairing pin) (unpair pairing pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-unpair-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-unpair-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-unpair-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-unpair-error (error-object->map %)])))))
(defn delete (defn delete
[] []
(.. keycard (.. (keycard)
(delete) (delete)
(then #(re-frame/dispatch [:hardwallet.callback/on-delete-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-delete-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-delete-error (error-object->map %)])))) (catch #(re-frame/dispatch [:hardwallet.callback/on-delete-error (error-object->map %)]))))
(defn remove-key (defn remove-key
[{:keys [pin pairing]}] [{:keys [pin pairing]}]
(.. keycard (.. (keycard)
(removeKey pairing pin) (removeKey pairing pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-remove-key-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-remove-key-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-remove-key-error (error-object->map %)])))) (catch #(re-frame/dispatch [:hardwallet.callback/on-remove-key-error (error-object->map %)]))))
(defn remove-key-with-unpair (defn remove-key-with-unpair
[{:keys [pin pairing]}] [{:keys [pin pairing]}]
(.. keycard (.. (keycard)
(removeKeyWithUnpair pairing pin) (removeKeyWithUnpair pairing pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-remove-key-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-remove-key-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-remove-key-error (error-object->map %)])))) (catch #(re-frame/dispatch [:hardwallet.callback/on-remove-key-error (error-object->map %)]))))
@ -157,7 +157,7 @@
(defn unpair-and-delete (defn unpair-and-delete
[{:keys [pin pairing]}] [{:keys [pin pairing]}]
(when (and pairing pin) (when (and pairing pin)
(.. keycard (.. (keycard)
(unpairAndDelete pairing pin) (unpairAndDelete pairing pin)
(then #(re-frame/dispatch [:hardwallet.callback/on-delete-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-delete-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-delete-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-delete-error (error-object->map %)])))))
@ -165,7 +165,7 @@
(defn get-keys (defn get-keys
[{:keys [pairing pin on-success]}] [{:keys [pairing pin on-success]}]
(when (and pairing (not-empty pin)) (when (and pairing (not-empty pin))
(.. keycard (.. (keycard)
(getKeys pairing pin) (getKeys pairing pin)
(then #(re-frame/dispatch [(or on-success :hardwallet.callback/on-get-keys-success) %])) (then #(re-frame/dispatch [(or on-success :hardwallet.callback/on-get-keys-success) %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-get-keys-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-get-keys-error (error-object->map %)])))))
@ -173,7 +173,7 @@
(defn sign (defn sign
[{:keys [pairing pin hash]}] [{:keys [pairing pin hash]}]
(when (and pairing pin hash) (when (and pairing pin hash)
(.. keycard (.. (keycard)
(sign pairing pin hash) (sign pairing pin hash)
(then #(re-frame/dispatch [:hardwallet.callback/on-sign-success %])) (then #(re-frame/dispatch [:hardwallet.callback/on-sign-success %]))
(catch #(re-frame/dispatch [:hardwallet.callback/on-sign-error (error-object->map %)]))))) (catch #(re-frame/dispatch [:hardwallet.callback/on-sign-error (error-object->map %)])))))

View File

@ -27,21 +27,21 @@
(reagent/create-class (reagent/create-class
{:component-will-mount {:component-will-mount
(fn [] (fn []
(.addListener react/keyboard (.addListener (react/keyboard)
"keyboardWillShow" "keyboardWillShow"
(fn [e] (fn [e]
(let [h (.. e -endCoordinates -height)] (let [h (.. e -endCoordinates -height)]
(when-not (= h @keyboard-height) (when-not (= h @keyboard-height)
(dispatch [:set :keyboard-height h]) (dispatch [:set :keyboard-height h])
(dispatch [:set :keyboard-max-height h]))))) (dispatch [:set :keyboard-max-height h])))))
(.addListener react/keyboard (.addListener (react/keyboard)
"keyboardWillHide" "keyboardWillHide"
#(when-not (= 0 @keyboard-height) #(when-not (= 0 @keyboard-height)
(dispatch [:set :keyboard-height 0]))) (dispatch [:set :keyboard-height 0])))
(.hide react/splash-screen) (.hide react/splash-screen)
(.addEventListener react/app-state "change" app-state-change-handler) (.addEventListener (react/app-state) "change" app-state-change-handler)
(.addEventListener rn-dependencies/react-native-languages "change" on-languages-change) (.addEventListener rn-dependencies/react-native-languages "change" on-languages-change)
(.addEventListener rn-dependencies/react-native-shake (.addEventListener (rn-dependencies/react-native-shake)
"ShakeEvent" "ShakeEvent"
on-shake)) on-shake))
:component-did-mount :component-did-mount
@ -49,10 +49,10 @@
(dispatch [:set-initial-props (reagent/props this)])) (dispatch [:set-initial-props (reagent/props this)]))
:component-will-unmount :component-will-unmount
(fn [] (fn []
(.stop react/http-bridge) (.stop (react/http-bridge))
(.removeEventListener react/app-state "change" app-state-change-handler) (.removeEventListener (react/app-state) "change" app-state-change-handler)
(.removeEventListener rn-dependencies/react-native-languages "change" on-languages-change) (.removeEventListener rn-dependencies/react-native-languages "change" on-languages-change)
(.removeEventListener rn-dependencies/react-native-shake (.removeEventListener (rn-dependencies/react-native-shake)
"ShakeEvent" "ShakeEvent"
on-shake)) on-shake))
:display-name "root" :display-name "root"

View File

@ -1,12 +1,14 @@
(ns status-im.js-dependencies) (ns status-im.js-dependencies
(:require-macros [status-im.utils.js-require :as js-require]))
(def Chance (js/require "chance")) (def Chance (js-require/js-require "chance"))
(def emojis (js/require "emojilib")) (def emojis (js-require/js-require "emojilib"))
(def phishing-detect (js/require "eth-phishing-detect")) (def phishing-detect (js-require/js-require "eth-phishing-detect"))
(def homoglyph-finder (js/require "homoglyph-finder")) (def homoglyph-finder (js-require/js-require "homoglyph-finder"))
(def identicon-js (js/require "identicon.js")) (def identicon-js (js-require/js-require "identicon.js"))
(def Web3 (js/require "web3")) (def Web3 (js-require/js-require "web3"))
(def text-encoding (js/require "text-encoding")) (defn web3-prototype [] (.-prototype (Web3)))
(def js-sha3 (js/require "js-sha3")) (def text-encoding (js-require/js-require "text-encoding"))
(def web3-utils (js/require "web3-utils")) (def js-sha3 (js-require/js-require "js-sha3"))
(def hi-base32 (js/require "hi-base32")) (def web3-utils (js-require/js-require "web3-utils"))
(def hi-base32 (js-require/js-require "hi-base32"))

View File

@ -517,7 +517,7 @@
[{:keys [db] :as cofx} chat-id] [{:keys [db] :as cofx} chat-id]
(let [{:keys [public?] :as chat} (get-in db [:chats chat-id]) (let [{:keys [public?] :as chat} (get-in db [:chats chat-id])
topic (if (and chat (not public?)) topic (if (and chat (not public?))
transport.topic/discovery-topic-hash (transport.topic/discovery-topic-hash)
(get-in db [:transport/chats chat-id :topic])) (get-in db [:transport/chats chat-id :topic]))
{:keys [chat-ids] :as mailserver-topic} (update (get-in db [:mailserver/topics topic]) {:keys [chat-ids] :as mailserver-topic} (update (get-in db [:mailserver/topics topic])
:chat-ids :chat-ids

View File

@ -5,7 +5,7 @@
[clojure.string :as string] [clojure.string :as string]
[status-im.utils.platform :as platform])) [status-im.utils.platform :as platform]))
(def status (defn status []
(when (exists? (.-NativeModules rn-dependencies/react-native)) (when (exists? (.-NativeModules rn-dependencies/react-native))
(.-Status (.-NativeModules rn-dependencies/react-native)))) (.-Status (.-NativeModules rn-dependencies/react-native))))
@ -20,20 +20,20 @@
(defn stop-node [] (defn stop-node []
(reset! node-started false) (reset! node-started false)
(when status (when (status)
(.stopNode status))) (.stopNode (status))))
(defn node-ready [] (defn node-ready []
(reset! node-started true)) (reset! node-started true))
(defn start-node [config] (defn start-node [config]
(when status (when (status)
(.startNode status config))) (.startNode (status) config)))
(defonce account-creation? (atom false)) (defonce account-creation? (atom false))
(defn create-account [password on-result] (defn create-account [password on-result]
(when status (when (status)
(let [callback (fn [data] (let [callback (fn [data]
(reset! account-creation? false) (reset! account-creation? false)
(on-result data))] (on-result data))]
@ -41,132 +41,132 @@
(fn [creation?] (fn [creation?]
(if-not creation? (if-not creation?
(do (do
(.createAccount status password callback) (.createAccount (status) password callback)
true) true)
false)))))) false))))))
(defn send-data-notification [{:keys [data-payload tokens] :as m} on-result] (defn send-data-notification [{:keys [data-payload tokens] :as m} on-result]
(when status (when (status)
(.sendDataNotification status data-payload tokens on-result))) (.sendDataNotification (status) data-payload tokens on-result)))
(defn send-logs [dbJson js-logs callback] (defn send-logs [dbJson js-logs callback]
(when status (when (status)
(.sendLogs status dbJson js-logs callback))) (.sendLogs (status) dbJson js-logs callback)))
(defn add-peer [enode on-result] (defn add-peer [enode on-result]
(when (and @node-started status) (when (and @node-started (status))
(.addPeer status enode on-result))) (.addPeer (status) enode on-result)))
(defn recover-account [passphrase password on-result] (defn recover-account [passphrase password on-result]
(when (and @node-started status) (when (and @node-started (status))
(.recoverAccount status passphrase password on-result))) (.recoverAccount (status) passphrase password on-result)))
(defn login [address password on-result] (defn login [address password on-result]
(when (and @node-started status) (when (and @node-started (status))
(.login status address password on-result))) (.login (status) address password on-result)))
(defn verify [address password on-result] (defn verify [address password on-result]
(when (and @node-started status) (when (and @node-started (status))
(.verify status address password on-result))) (.verify (status) address password on-result)))
(defn login-with-keycard [whisper-private-key encryption-public-key on-result] (defn login-with-keycard [whisper-private-key encryption-public-key on-result]
(when (and @node-started status) (when (and @node-started (status))
(.loginWithKeycard status whisper-private-key encryption-public-key on-result))) (.loginWithKeycard (status) whisper-private-key encryption-public-key on-result)))
(defn set-soft-input-mode [mode] (defn set-soft-input-mode [mode]
(when status (when (status)
(.setSoftInputMode status mode))) (.setSoftInputMode (status) mode)))
(defn clear-web-data [] (defn clear-web-data []
(when status (when (status)
(.clearCookies status) (.clearCookies (status))
(.clearStorageAPIs status))) (.clearStorageAPIs (status))))
(defn call-rpc [payload callback] (defn call-rpc [payload callback]
(when (and @node-started status) (when (and @node-started (status))
(.callRPC status payload callback))) (.callRPC (status) payload callback)))
(defn call-private-rpc [payload callback] (defn call-private-rpc [payload callback]
(when (and @node-started status) (when (and @node-started (status))
(.callPrivateRPC status payload callback))) (.callPrivateRPC (status) payload callback)))
(defn sign-message [rpcParams callback] (defn sign-message [rpcParams callback]
(when (and @node-started status) (when (and @node-started (status))
(.signMessage status rpcParams callback))) (.signMessage (status) rpcParams callback)))
(defn hash-transaction [rpcParams callback] (defn hash-transaction [rpcParams callback]
(when (and @node-started status) (when (and @node-started (status))
(.hashTransaction status rpcParams callback))) (.hashTransaction (status) rpcParams callback)))
(defn hash-message [message callback] (defn hash-message [message callback]
(when (and @node-started status) (when (and @node-started (status))
(.hashMessage status message callback))) (.hashMessage (status) message callback)))
(defn hash-typed-data [data callback] (defn hash-typed-data [data callback]
(when (and @node-started status) (when (and @node-started (status))
(.hashTypedData status data callback))) (.hashTypedData (status) data callback)))
(defn sign-typed-data [data password callback] (defn sign-typed-data [data password callback]
(when (and @node-started status) (when (and @node-started (status))
(.signTypedData status data password callback))) (.signTypedData (status) data password callback)))
(defn send-transaction [rpcParams password callback] (defn send-transaction [rpcParams password callback]
(when (and @node-started status) (when (and @node-started (status))
(.sendTransaction status rpcParams password callback))) (.sendTransaction (status) rpcParams password callback)))
(defn send-transaction-with-signature [rpcParams sig callback] (defn send-transaction-with-signature [rpcParams sig callback]
(when (and @node-started status) (when (and @node-started (status))
(.sendTransactionWithSignature status rpcParams sig callback))) (.sendTransactionWithSignature (status) rpcParams sig callback)))
(defn close-application [] (defn close-application []
(.closeApplication status)) (.closeApplication (status)))
(defn connection-change [{:keys [type expensive?]}] (defn connection-change [{:keys [type expensive?]}]
(.connectionChange status type expensive?)) (.connectionChange (status) type expensive?))
(defn app-state-change [state] (defn app-state-change [state]
(.appStateChange status state)) (.appStateChange (status) state))
(defn get-device-UUID [callback] (defn get-device-UUID [callback]
(.getDeviceUUID (.getDeviceUUID
status (status)
(fn [UUID] (fn [UUID]
(callback (string/upper-case UUID))))) (callback (string/upper-case UUID)))))
(defn set-blank-preview-flag [flag] (defn set-blank-preview-flag [flag]
(.setBlankPreviewFlag status flag)) (.setBlankPreviewFlag (status) flag))
(defn extract-group-membership-signatures [signature-pairs callback] (defn extract-group-membership-signatures [signature-pairs callback]
(when status (when (status)
(.extractGroupMembershipSignatures status signature-pairs callback))) (.extractGroupMembershipSignatures (status) signature-pairs callback)))
(defn sign-group-membership [content callback] (defn sign-group-membership [content callback]
(when status (when (status)
(.signGroupMembership status content callback))) (.signGroupMembership (status) content callback)))
(defn enable-installation [installation-id callback] (defn enable-installation [installation-id callback]
(when status (when (status)
(.enableInstallation status installation-id callback))) (.enableInstallation (status) installation-id callback)))
(defn disable-installation [installation-id callback] (defn disable-installation [installation-id callback]
(when status (when (status)
(.disableInstallation status installation-id callback))) (.disableInstallation (status) installation-id callback)))
(defn is24Hour [] (defn is24Hour []
(when status (when (status)
(.-is24Hour status))) (.-is24Hour (status))))
(defn update-mailservers [enodes on-result] (defn update-mailservers [enodes on-result]
(when status (when (status)
(.updateMailservers status enodes on-result))) (.updateMailservers (status) enodes on-result)))
(defn chaos-mode-update [on on-result] (defn chaos-mode-update [on on-result]
(when status (when (status)
(.chaosModeUpdate status on on-result))) (.chaosModeUpdate (status) on on-result)))
(defn get-nodes-from-contract [rpc-endpoint contract-address on-result] (defn get-nodes-from-contract [rpc-endpoint contract-address on-result]
(when status (when (status)
(.getNodesFromContract status rpc-endpoint contract-address on-result))) (.getNodesFromContract (status) rpc-endpoint contract-address on-result)))
(defn rooted-device? [callback] (defn rooted-device? [callback]
(cond (cond
@ -181,8 +181,8 @@
;; we check root on android ;; we check root on android
platform/android? platform/android?
(if status (if (status)
(.isDeviceRooted status callback) (.isDeviceRooted (status) callback)
;; if module isn't initialized we return true to avoid degrading security ;; if module isn't initialized we return true to avoid degrading security
(callback true)) (callback true))

View File

@ -4,8 +4,8 @@
[status-im.utils.platform :as platform])) [status-im.utils.platform :as platform]))
(defn is-connected? [callback] (defn is-connected? [callback]
(when react-components/net-info (when (react-components/net-info)
(.then (.fetch (.-isConnected react-components/net-info)) (.then (.fetch (.-isConnected (react-components/net-info)))
(fn [is-connected?] (fn [is-connected?]
(log/debug "Is connected?" is-connected?) (log/debug "Is connected?" is-connected?)
(callback is-connected?))))) (callback is-connected?)))))
@ -16,21 +16,21 @@
on-success #(callback {:type (:type info) :expensive? %})] on-success #(callback {:type (:type info) :expensive? %})]
(if platform/ios? (if platform/ios?
(on-success false) (on-success false)
(.. react-components/net-info (.. (react-components/net-info)
isConnectionExpensive isConnectionExpensive
(then on-success) (then on-success)
(catch (fn [error] (log/warn "isConnectionExpensive: " error)))))))) (catch (fn [error] (log/warn "isConnectionExpensive: " error))))))))
(defn net-info [callback] (defn net-info [callback]
(when react-components/net-info (when (react-components/net-info)
(.then (.getConnectionInfo react-components/net-info) (.then (.getConnectionInfo (react-components/net-info))
(wrap-net-info callback)))) (wrap-net-info callback))))
(defn add-connection-listener [listener] (defn add-connection-listener [listener]
(when react-components/net-info (when (react-components/net-info)
(.addEventListener (.-isConnected react-components/net-info) "connectionChange" listener))) (.addEventListener (.-isConnected (react-components/net-info)) "connectionChange" listener)))
(defn add-net-info-listener [listener] (defn add-net-info-listener [listener]
(when react-components/net-info (when (react-components/net-info)
(.addEventListener react-components/net-info "connectionChange" (.addEventListener (react-components/net-info) "connectionChange"
(wrap-net-info listener)))) (wrap-net-info listener))))

View File

@ -9,7 +9,7 @@
[status-im.utils.platform :as platform])) [status-im.utils.platform :as platform]))
(when-not platform/desktop? (when-not platform/desktop?
(def firebase (object/get rn/react-native-firebase "default"))) (def firebase (object/get (rn/react-native-firebase) "default")))
(defn message-handler-fn [] (defn message-handler-fn []
;; message-js is firebase.messaging.RemoteMessage: https://github.com/invertase/react-native-firebase-docs/blob/master/docs/messaging/reference/RemoteMessage.md ;; message-js is firebase.messaging.RemoteMessage: https://github.com/invertase/react-native-firebase-docs/blob/master/docs/messaging/reference/RemoteMessage.md

View File

@ -22,13 +22,13 @@
(when-not platform/desktop? (when-not platform/desktop?
(def firebase (object/get rn/react-native-firebase "default"))) (defn firebase [] (object/get (rn/react-native-firebase) "default")))
;; NOTE: Only need to explicitly request permissions on iOS. ;; NOTE: Only need to explicitly request permissions on iOS.
(defn request-permissions [] (defn request-permissions []
(if platform/desktop? (if platform/desktop?
(re-frame/dispatch [:notifications.callback/request-notifications-permissions-granted {}]) (re-frame/dispatch [:notifications.callback/request-notifications-permissions-granted {}])
(-> (.requestPermission (.messaging firebase)) (-> (.requestPermission (.messaging (firebase)))
(.then (.then
(fn [_] (fn [_]
(log/debug "notifications-granted") (log/debug "notifications-granted")
@ -52,7 +52,7 @@
(= (.-length to) pn-pubkey-hash-length))))) (= (.-length to) pn-pubkey-hash-length)))))
(defn sha3 [s] (defn sha3 [s]
(.sha3 dependencies/Web3.prototype s)) (.sha3 (dependencies/web3-prototype) s))
(defn anonymize-pubkey (defn anonymize-pubkey
[pubkey] [pubkey]
@ -163,12 +163,14 @@
(when-let [msg-id (:id decoded-payload)] (when-let [msg-id (:id decoded-payload)]
;; We must prefix the notification ID, otherwise it will ;; We must prefix the notification ID, otherwise it will
;; cause a crash in iOS ;; cause a crash in iOS
{:notificationId (str "hash:" msg-id)})))] {:notificationId (str "hash:" msg-id)})))
firebase (firebase)]
(firebase.notifications.Notification. (firebase.notifications.Notification.
native-notification (.notifications firebase)))) native-notification (.notifications firebase))))
(defn display-notification [{:keys [title body] :as params}] (defn display-notification [{:keys [title body] :as params}]
(let [notification (build-notification params)] (let [notification (build-notification params)
firebase (firebase)]
(when platform/android? (when platform/android?
(.. notification (.. notification
(-android.setChannelId channel-id) (-android.setChannelId channel-id)
@ -185,14 +187,15 @@
(log/debug "Display Notification error" title body error)))))) (log/debug "Display Notification error" title body error))))))
(defn get-fcm-token [] (defn get-fcm-token []
(-> (.getToken (.messaging firebase)) (-> (.getToken (.messaging (firebase)))
(.then (fn [x] (.then (fn [x]
(log/debug "get-fcm-token:" x) (log/debug "get-fcm-token:" x)
(re-frame/dispatch (re-frame/dispatch
[:notifications.callback/get-fcm-token-success x]))))) [:notifications.callback/get-fcm-token-success x])))))
(defn create-notification-channel [] (defn create-notification-channel []
(let [channel (firebase.notifications.Android.Channel. (let [firebase (firebase)
channel (firebase.notifications.Android.Channel.
channel-id channel-id
channel-name channel-name
firebase.notifications.Android.Importance.High)] firebase.notifications.Android.Importance.High)]
@ -272,7 +275,7 @@
It is only needed to handle PNs from legacy clients It is only needed to handle PNs from legacy clients
(which use firebase.notifications API)" (which use firebase.notifications API)"
(log/debug "Handle initial push notifications") (log/debug "Handle initial push notifications")
(.. firebase (.. (firebase)
notifications notifications
getInitialNotification getInitialNotification
(then (fn [event] (then (fn [event]
@ -282,7 +285,7 @@
(defn setup-token-refresh-callback [] (defn setup-token-refresh-callback []
(.onTokenRefresh (.onTokenRefresh
(.messaging firebase) (.messaging (firebase))
(fn [x] (fn [x]
(log/debug "onTokenRefresh:" x) (log/debug "onTokenRefresh:" x)
(re-frame/dispatch [:notifications.callback/get-fcm-token-success x])))) (re-frame/dispatch [:notifications.callback/get-fcm-token-success x]))))
@ -294,7 +297,7 @@
"we can remove this method" "we can remove this method"
(log/debug "calling onNotification") (log/debug "calling onNotification")
(.onNotification (.onNotification
(.notifications firebase) (.notifications (firebase))
(fn [message-js] (fn [message-js]
(log/debug "handle-on-notification-callback called") (log/debug "handle-on-notification-callback called")
(let [decoded-payload (decode-notification-payload message-js)] (let [decoded-payload (decode-notification-payload message-js)]
@ -306,7 +309,7 @@
(defn setup-on-message-callback [] (defn setup-on-message-callback []
(log/debug "calling onMessage") (log/debug "calling onMessage")
(.onMessage (.onMessage
(.messaging firebase) (.messaging (firebase))
(fn [message-js] (fn [message-js]
(log/debug "handle-on-message-callback called") (log/debug "handle-on-message-callback called")
(let [decoded-payload (decode-notification-payload message-js)] (let [decoded-payload (decode-notification-payload message-js)]
@ -318,7 +321,7 @@
(defn setup-on-notification-opened-callback [] (defn setup-on-notification-opened-callback []
(log/debug "setup-on-notification-opened-callback") (log/debug "setup-on-notification-opened-callback")
(.. firebase (.. (firebase)
notifications notifications
(onNotificationOpened handle-notification-open-event))) (onNotificationOpened handle-notification-open-event)))

View File

@ -6,7 +6,7 @@
(def ^:const privacy-policy-link "https://www.iubenda.com/privacy-policy/45710059") (def ^:const privacy-policy-link "https://www.iubenda.com/privacy-policy/45710059")
(defn open-privacy-policy-link! [] (defn open-privacy-policy-link! []
(.openURL react/linking privacy-policy-link)) (.openURL (react/linking) privacy-policy-link))
(re-frame/reg-fx (re-frame/reg-fx
:privacy-policy/open-privacy-policy-link :privacy-policy/open-privacy-policy-link

View File

@ -1,19 +1,27 @@
(ns status-im.react-native.resources) (ns status-im.react-native.resources
(:require-macros [status-im.utils.js-require :as js-require]))
(def ui (def ui
{:empty-hashtags (js/require "./resources/images/ui/empty-hashtags.png") {:empty-hashtags (js-require/js-require "./resources/images/ui/empty-hashtags.png")
:empty-recent (js/require "./resources/images/ui/empty-recent.png") :empty-recent (js-require/js-require "./resources/images/ui/empty-recent.png")
:analytics-image (js/require "./resources/images/ui/analytics-image.png") :analytics-image (js-require/js-require "./resources/images/ui/analytics-image.png")
:welcome-image (js/require "./resources/images/ui/welcome-image.png") :welcome-image (js-require/js-require "./resources/images/ui/welcome-image.png")
:lock (js/require "./resources/images/ui/lock.png") :lock (js-require/js-require "./resources/images/ui/lock.png")
:tribute-to-talk (js/require "./resources/images/ui/tribute-to-talk.png") :tribute-to-talk (js-require/js-require "./resources/images/ui/tribute-to-talk.png")
:wallet-welcome (js/require "./resources/images/ui/wallet-welcome.png") :wallet-welcome (js-require/js-require "./resources/images/ui/wallet-welcome.png")
:hardwallet-card (js/require "./resources/images/ui/hardwallet-card.png") :hardwallet-card (js-require/js-require "./resources/images/ui/hardwallet-card.png")
:secret-keys (js/require "./resources/images/ui/secret-keys.png") :secret-keys (js-require/js-require "./resources/images/ui/secret-keys.png")
:keycard-lock (js/require "./resources/images/ui/keycard-lock.png") :keycard-lock (js-require/js-require "./resources/images/ui/keycard-lock.png")
:hold-card-animation (try (js/require "./resources/images/ui/hold-card-animation.gif") :hold-card-animation (js-require/js-require "./resources/images/ui/hold-card-animation.gif")
(catch :default e)) :warning-sign (js-require/js-require "./resources/images/ui/warning-sign.png")
:warning-sign (js/require "./resources/images/ui/warning-sign.png") :phone-nfc-on (js-require/js-require "./resources/images/ui/phone-nfc-on.png")
:phone-nfc-on (js/require "./resources/images/ui/phone-nfc-on.png") :phone-nfc-off (js-require/js-require "./resources/images/ui/phone-nfc-off.png")
:phone-nfc-off (js/require "./resources/images/ui/phone-nfc-off.png") :dapp-store (js-require/js-require "./resources/images/ui/dapp-store.png")})
:dapp-store (js/require "./resources/images/ui/dapp-store.png")})
(def loaded-images (atom {}))
(defn get-image [k]
(if (contains? @loaded-images k)
(get @loaded-images k)
(get (swap! loaded-images assoc k
((get ui k))) k)))

View File

@ -86,7 +86,7 @@
topics (db :mailserver/topics) topics (db :mailserver/topics)
topic-hash (if (contains? topics partitioned-topic-hash) topic-hash (if (contains? topics partitioned-topic-hash)
partitioned-topic-hash partitioned-topic-hash
transport.topic/discovery-topic-hash)] (transport.topic/discovery-topic-hash))]
{:shh/post [{:web3 web3 {:shh/post [{:web3 web3
:success-event success-event :success-event success-event
:message (merge {:sig (accounts.db/current-public-key cofx) :message (merge {:sig (accounts.db/current-public-key cofx)

View File

@ -38,7 +38,7 @@
utils/get-topic)) utils/get-topic))
(def discovery-topic constants/contact-discovery) (def discovery-topic constants/contact-discovery)
(def discovery-topic-hash (utils/get-topic constants/contact-discovery)) (defn discovery-topic-hash [] (utils/get-topic constants/contact-discovery))
(defn public-key->discovery-topic (defn public-key->discovery-topic
[public-key] [public-key]
@ -50,10 +50,10 @@
[public-key] [public-key]
(if config/partitioned-topic-enabled? (if config/partitioned-topic-enabled?
(partitioned-topic-hash public-key) (partitioned-topic-hash public-key)
discovery-topic-hash)) (discovery-topic-hash)))
(defn discovery-topics [public-key] (defn discovery-topics [public-key]
[(partitioned-topic-hash public-key) discovery-topic-hash]) [(partitioned-topic-hash public-key) (discovery-topic-hash)])
(defn contains-topic? (defn contains-topic?
[available-topics topic] [available-topics topic]

View File

@ -4,18 +4,18 @@
[status-im.js-dependencies :as dependencies])) [status-im.js-dependencies :as dependencies]))
(defn from-utf8 [s] (defn from-utf8 [s]
(.fromUtf8 dependencies/Web3.prototype s)) (.fromUtf8 (dependencies/web3-prototype) s))
(defn to-ascii [s] (defn to-ascii [s]
(.toAscii dependencies/Web3.prototype s)) (.toAscii (dependencies/web3-prototype) s))
(defn to-utf8 [s] (defn to-utf8 [s]
(try (try
(.toUtf8 dependencies/Web3.prototype (str s)) (.toUtf8 (dependencies/web3-prototype) (str s))
(catch :default err nil))) (catch :default err nil)))
(defn sha3 [s] (defn sha3 [s]
(.sha3 dependencies/Web3.prototype s)) (.sha3 (dependencies/web3-prototype) s))
(defn old-message-id (defn old-message-id
[message] [message]

View File

@ -2,17 +2,17 @@
(:require [status-im.ethereum.core :as ethereum] (:require [status-im.ethereum.core :as ethereum]
[status-im.js-dependencies :as dependencies])) [status-im.js-dependencies :as dependencies]))
(def utils dependencies/web3-utils) (defn utils [] (dependencies/web3-utils))
(defn to-wei (defn to-wei
[s] [s]
(when s (when s
(.toWei utils s))) (.toWei (utils) s)))
(defn from-wei (defn from-wei
[s] [s]
(when s (when s
(.fromWei utils s))) (.fromWei (utils) s)))
(defn get-settings (defn get-settings
[db] [db]

View File

@ -6,31 +6,31 @@
([anim callback] (.start anim callback))) ([anim callback] (.start anim callback)))
(defn anim-loop [animation] (defn anim-loop [animation]
(.loop react/animated animation)) (.loop (react/animated) animation))
(defn interpolate [anim-value config] (defn interpolate [anim-value config]
(.interpolate anim-value (clj->js config))) (.interpolate anim-value (clj->js config)))
(defn timing [anim-value config] (defn timing [anim-value config]
(.timing react/animated anim-value (clj->js config))) (.timing (react/animated) anim-value (clj->js config)))
(defn spring [anim-value config] (defn spring [anim-value config]
(.spring react/animated anim-value (clj->js config))) (.spring (react/animated) anim-value (clj->js config)))
(defn decay [anim-value config] (defn decay [anim-value config]
(.decay react/animated anim-value (clj->js config))) (.decay (react/animated) anim-value (clj->js config)))
(defn anim-sequence [animations] (defn anim-sequence [animations]
(.sequence react/animated (clj->js animations))) (.sequence (react/animated) (clj->js animations)))
(defn parallel [animations] (defn parallel [animations]
(.parallel react/animated (clj->js animations))) (.parallel (react/animated) (clj->js animations)))
(defn anim-delay [duration] (defn anim-delay [duration]
(.delay react/animated duration)) (.delay (react/animated) duration))
(defn event [config] (defn event [config]
(.event react/animated (clj->js [nil, config]))) (.event (react/animated) (clj->js [nil, config])))
(defn add-listener [anim-value listener] (defn add-listener [anim-value listener]
(.addListener anim-value listener)) (.addListener anim-value listener))

View File

@ -107,7 +107,7 @@
(when platform/iphone-x? (when platform/iphone-x?
[react/view [react/view
{:style tabs.styles/ios-titles-cover}])] {:style tabs.styles/ios-titles-cover}])]
[react/safe-area-view {:flex 1}]]) [(react/safe-area-view) {:flex 1}]])
(defn tabs-animation-wrapper-android (defn tabs-animation-wrapper-android
[keyboard-shown? view-id content] [keyboard-shown? view-id content]
@ -134,13 +134,13 @@
:enter-pin-settings} view-id) :enter-pin-settings} view-id)
(if platform/ios? (if platform/ios?
[tabs-animation-wrapper-ios [tabs-animation-wrapper-ios
[react/animated-view [(react/animated-view)
{:style (tabs.styles/animated-container visible? keyboard-shown?)} {:style (tabs.styles/animated-container visible? keyboard-shown?)}
[tabs tab]]] [tabs tab]]]
[tabs-animation-wrapper-android [tabs-animation-wrapper-android
keyboard-shown? keyboard-shown?
view-id view-id
[react/animated-view [(react/animated-view)
{:style (tabs.styles/animated-container visible? keyboard-shown?)} {:style (tabs.styles/animated-container visible? keyboard-shown?)}
[tabs tab]]])))})) [tabs tab]]])))}))
@ -156,12 +156,12 @@
(when platform/android? (when platform/android?
(reset! (reset!
listeners listeners
[(.addListener react/keyboard "keyboardDidShow" [(.addListener (react/keyboard) "keyboardDidShow"
(fn [] (fn []
(reset! keyboard-shown? true) (reset! keyboard-shown? true)
(animate visible? (animate visible?
disappearance-duration 0))) disappearance-duration 0)))
(.addListener react/keyboard "keyboardDidHide" (.addListener (react/keyboard) "keyboardDidHide"
(fn [] (fn []
(reset! keyboard-shown? false) (reset! keyboard-shown? false)
(animate visible? appearance-duration (animate visible? appearance-duration

View File

@ -80,7 +80,7 @@
(defn swipe-pan-responder [opts] (defn swipe-pan-responder [opts]
(.create (.create
react/pan-responder (react/pan-responder)
(clj->js (clj->js
{:onMoveShouldSetPanResponder (fn [_ state] {:onMoveShouldSetPanResponder (fn [_ state]
(or (< 10 (js/Math.abs (.-dx state))) (or (< 10 (js/Math.abs (.-dx state)))
@ -110,8 +110,8 @@
{:on-press #(cancel opts on-cancel) {:on-press #(cancel opts on-cancel)
:style styles/container} :style styles/container}
[react/animated-view (styles/shadow opacity-value)]] [(react/animated-view) (styles/shadow opacity-value)]]
[react/animated-view [(react/animated-view)
{:style (styles/content-container height bottom-value)} {:style (styles/content-container height bottom-value)}
[react/view styles/content-header [react/view styles/content-header
[react/view styles/handle]] [react/view styles/handle]]

View File

@ -4,10 +4,10 @@
[clojure.walk :as walk] [clojure.walk :as walk]
[status-im.react-native.js-dependencies :as js-dependecies])) [status-im.react-native.js-dependencies :as js-dependecies]))
(def default-camera (.-default js-dependecies/camera)) (defn default-camera [] (.-default (js-dependecies/camera)))
(defn constants [t] (defn constants [t]
(-> default-camera (-> (default-camera)
(object/get "constants") (object/get "constants")
(object/get t) (object/get t)
(js->clj) (js->clj)
@ -18,15 +18,15 @@
(def torch-modes (constants "TorchMode")) (def torch-modes (constants "TorchMode"))
(defn set-torch [state] (defn set-torch [state]
(set! (.-torchMode default-camera) (get torch-modes state))) (set! (.-torchMode (default-camera)) (get torch-modes state)))
(defn request-access-ios [then else] (defn request-access-ios [then else]
(-> (.checkVideoAuthorizationStatus default-camera) (-> (.checkVideoAuthorizationStatus (default-camera))
(.then (fn [allowed?] (if allowed? (then) (else)))) (.then (fn [allowed?] (if allowed? (then) (else))))
(.catch else))) (.catch else)))
(defn camera [props] (defn camera [props]
(reagent/create-element default-camera (clj->js (merge {:inverted true} props)))) (reagent/create-element (default-camera) (clj->js (merge {:inverted true} props))))
(defn get-qr-code-data [code] (defn get-qr-code-data [code]
(.-data code)) (.-data code))

View File

@ -53,13 +53,13 @@
:top -3 :top -3
:height 3 :height 3
:background-color colors/white}} :background-color colors/white}}
[react/animated-view {:style (animated-bar-style blue-bar-left-margin [(react/animated-view) {:style (animated-bar-style blue-bar-left-margin
parent-width parent-width
colors/blue)}] colors/blue)}]
[react/animated-view {:style (assoc (animated-bar-style white-bar-left-margin [(react/animated-view) {:style (assoc (animated-bar-style white-bar-left-margin
parent-width parent-width
colors/white) colors/white)
:left (* 0.15 parent-width))}]])) :left (* 0.15 parent-width))}]]))
(defonce show-connected? (reagent/atom true)) (defonce show-connected? (reagent/atom true))
@ -108,15 +108,15 @@
connected? connecting? loading-indicator?] :as opts}] connected? connecting? loading-indicator?] :as opts}]
(when (or (not connected?) (when (or (not connected?)
@show-connected?) @show-connected?)
[react/animated-view {:style (styles/text-wrapper [(react/animated-view) {:style (styles/text-wrapper
(assoc opts (assoc opts
:height anim-height :height anim-height
:background-color (if connected? :background-color (if connected?
colors/green colors/green
colors/gray) colors/gray)
:opacity anim-opacity :opacity anim-opacity
:modal? (= view-id :chat-modal))) :modal? (= view-id :chat-modal)))
:accessibility-label :connection-status-text} :accessibility-label :connection-status-text}
(when connecting? (when connecting?
[react/activity-indicator {:animated true [react/activity-indicator {:animated true
:color colors/white :color colors/white

View File

@ -1,10 +1,10 @@
(ns status-im.ui.components.dialog (ns status-im.ui.components.dialog
(:require [status-im.react-native.js-dependencies :as rn-dependencies])) (:require [status-im.react-native.js-dependencies :as rn-dependencies]))
(def dialogs (.-default rn-dependencies/dialogs)) (defn dialogs [] (.-default (rn-dependencies/dialogs)))
(defn show [{:keys [title options cancel-text on-cancel]}] (defn show [{:keys [title options cancel-text on-cancel]}]
(.. dialogs (.. (dialogs)
(showPicker title nil (clj->js {:items (mapv #(select-keys % [:label]) (showPicker title nil (clj->js {:items (mapv #(select-keys % [:label])
options) options)
:negativeText cancel-text :negativeText cancel-text
@ -20,4 +20,4 @@
(filter #(= label (:label %))) (filter #(= label (:label %)))
first first
:action)] :action)]
(action))))))))) (action)))))))))

View File

@ -258,8 +258,8 @@
[name {:keys [color container-style accessibility-label width height] [name {:keys [color container-style accessibility-label width height]
:or {accessibility-label :icon}}] :or {accessibility-label :icon}}]
^{:key name} ^{:key name}
[react/animated-view {:style container-style [(react/animated-view) {:style container-style
:accessibility-label accessibility-label} :accessibility-label accessibility-label}
(if-let [icon-fn (get icons name)] (if-let [icon-fn (get icons name)]
(let [icon-vec (icon-fn (match-color color))] (let [icon-vec (icon-fn (match-color color))]
(if width (if width

View File

@ -62,7 +62,7 @@
(defn item-image (defn item-image
[{:keys [source style image-style]}] [{:keys [source style image-style]}]
[react/view {:style style} [react/view {:style style}
[react/image {:source source [react/image {:source (if (fn? source) (source) source)
:style (merge styles/item-image image-style)}]]) :style (merge styles/item-image image-style)}]])
(defn item-primary (defn item-primary
@ -220,7 +220,7 @@
[{:keys [data] :as props}] [{:keys [data] :as props}]
{:pre [(or (nil? data) {:pre [(or (nil? data)
(sequential? data))]} (sequential? data))]}
[flat-list-class [(flat-list-class)
(merge (base-list-props props) (merge (base-list-props props)
props props
{:data (wrap-data data)})]) {:data (wrap-data data)})])
@ -251,7 +251,7 @@
See https://facebook.github.io/react-native/docs/sectionlist.html" See https://facebook.github.io/react-native/docs/sectionlist.html"
[{:keys [sections render-section-header-fn render-section-footer-fn] :as props [{:keys [sections render-section-header-fn render-section-footer-fn] :as props
:or {render-section-header-fn default-render-section-header}}] :or {render-section-header-fn default-render-section-header}}]
[section-list-class [(section-list-class)
(merge (base-list-props props) (merge (base-list-props props)
props props
(when render-section-footer-fn (when render-section-footer-fn
@ -310,7 +310,7 @@
swipe-pan-responder (responder/swipe-pan-responder offset-x styles/delete-button-width id swiped?) swipe-pan-responder (responder/swipe-pan-responder offset-x styles/delete-button-width id swiped?)
swipe-pan-handler (responder/pan-handlers swipe-pan-responder)] swipe-pan-handler (responder/pan-handlers swipe-pan-responder)]
[react/view swipe-pan-handler [react/view swipe-pan-handler
[react/animated-view {:style {:flex 1 :right offset-x}} [(react/animated-view) {:style {:flex 1 :right offset-x}}
body body
[react/touchable-highlight {:style styles/delete-icon-highlight [react/touchable-highlight {:style styles/delete-icon-highlight
:on-press on-delete} :on-press on-delete}

View File

@ -41,13 +41,13 @@
:options [{:label (i18n/label :t/browsing-open-in-status) :options [{:label (i18n/label :t/browsing-open-in-status)
:action #(re-frame/dispatch [:browser.ui/open-in-status-option-selected link])} :action #(re-frame/dispatch [:browser.ui/open-in-status-option-selected link])}
{:label (i18n/label (platform-web-browser)) {:label (i18n/label (platform-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)}))
(defn browse-in-web-browser [link] (defn browse-in-web-browser [link]
(show {:title (i18n/label :t/browsing-title) (show {:title (i18n/label :t/browsing-title)
:options [{:label (i18n/label (platform-web-browser)) :options [{:label (i18n/label (platform-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)}))
(defn browse-dapp [link] (defn browse-dapp [link]

View File

@ -4,7 +4,7 @@
[status-im.ui.components.camera :as camera] [status-im.ui.components.camera :as camera]
[status-im.react-native.js-dependencies :as js-dependencies])) [status-im.react-native.js-dependencies :as js-dependencies]))
(def permissions-class (.-PermissionsAndroid js-dependencies/react-native)) (defn permissions-class [] (.-PermissionsAndroid js-dependencies/react-native))
(def permissions-map (def permissions-map
{:read-external-storage "android.permission.READ_EXTERNAL_STORAGE" {:read-external-storage "android.permission.READ_EXTERNAL_STORAGE"
@ -22,7 +22,7 @@
:as options}] :as options}]
(if platform/android? (if platform/android?
(let [permissions (mapv #(get permissions-map %) permissions)] (let [permissions (mapv #(get permissions-map %) permissions)]
(-> (.requestMultiple permissions-class (clj->js permissions)) (-> (.requestMultiple (permissions-class) (clj->js permissions))
(.then #(if (all-granted? (js->clj %)) (.then #(if (all-granted? (js->clj %))
(on-allowed) (on-allowed)
(on-denied))) (on-denied)))

View File

@ -8,16 +8,16 @@
(defn qr-code [props] (defn qr-code [props]
(reagent/create-element (reagent/create-element
rn-dependencies/qr-code (rn-dependencies/qr-code)
(clj->js (merge {:inverted true} props)))) (clj->js (merge {:inverted true} props))))
(defview qr-code-viewer-component [{:keys [style hint-style footer-style footer-button value hint legend]}] (defview qr-code-viewer-component [{:keys [style hint-style footer-style footer-button value hint legend]}]
(letsubs [{:keys [width]} [:dimensions/window] (letsubs [{:keys [width]} [:dimensions/window]
{:keys [disabled?]} [:tribute-to-talk/ui]] {:keys [disabled?]} [:tribute-to-talk/ui]]
[react/scroll-view {:content-container-style {:align-items :center [(react/scroll-view) {:content-container-style {:align-items :center
:margin-top 16 :margin-top 16
:justify-content :center} :justify-content :center}
:style (merge {:flex 1} style)} :style (merge {:flex 1} style)}
(when-not disabled? (when-not disabled?
[react/view {:style {:margin-horizontal 16}} [react/view {:style {:margin-horizontal 16}}
[tr-to-talk/enabled-note]]) [tr-to-talk/enabled-note]])

View File

@ -43,7 +43,7 @@
(fn [] (fn []
[react/view {:style style [react/view {:style style
:on-layout #(reset! width (-> % .-nativeEvent .-layout .-width))} :on-layout #(reset! width (-> % .-nativeEvent .-layout .-width))}
[react/web-view [(react/web-view)
{:java-script-enabled false {:java-script-enabled false
:third-party-cookies-enabled false :third-party-cookies-enabled false
:scroll-enabled false :scroll-enabled false

View File

@ -14,7 +14,7 @@
opacity-value (animation/create-value 0)] opacity-value (animation/create-value 0)]
{:component-did-mount (animations/animate-tooltip bottom-value bottom-anim-value opacity-value 10)} {:component-did-mount (animations/animate-tooltip bottom-value bottom-anim-value opacity-value 10)}
[react/view (merge styles/tooltip-container container-style) [react/view (merge styles/tooltip-container container-style)
[react/animated-view {:style (styles/tooltip-animated bottom-anim-value opacity-value)} [(react/animated-view) {:style (styles/tooltip-animated bottom-anim-value opacity-value)}
[react/view (styles/tooltip-text-container color) [react/view (styles/tooltip-text-container color)
[react/text {:style (styles/tooltip-text font-size)} label]] [react/text {:style (styles/tooltip-text font-size)} label]]
[vector-icons/icon :icons/tooltip-triangle {:color color :style styles/tooltip-triangle}]]])) [vector-icons/icon :icons/tooltip-triangle {:color color :style styles/tooltip-triangle}]]]))
@ -24,7 +24,7 @@
opacity-value (animation/create-value 0)] opacity-value (animation/create-value 0)]
{:component-did-mount (animations/animate-tooltip -150 bottom-anim-value opacity-value -10)} {:component-did-mount (animations/animate-tooltip -150 bottom-anim-value opacity-value -10)}
[react/view styles/bottom-tooltip-container [react/view styles/bottom-tooltip-container
[react/animated-view {:style (styles/tooltip-animated bottom-anim-value opacity-value)} [(react/animated-view) {:style (styles/tooltip-animated bottom-anim-value opacity-value)}
[vector-icons/icon :icons/tooltip-triangle {:color colors/gray [vector-icons/icon :icons/tooltip-triangle {:color colors/gray
:style styles/tooltip-triangle :style styles/tooltip-triangle
:container-style {:transform [{:rotate "180deg"}]}}] :container-style {:transform [{:rotate "180deg"}]}}]

View File

@ -6,9 +6,11 @@
[status-im.utils.config :as config])) [status-im.utils.config :as config]))
(def webview-bridge-class (def webview-bridge-class
(reagent/adapt-react-class (.-default js-dependencies/webview-bridge))) (memoize
(fn []
(reagent/adapt-react-class (.-default (js-dependencies/webview-bridge))))))
(def module (.-WebViewBridgeModule (.-NativeModules js-dependencies/react-native))) (defn module [] (.-WebViewBridgeModule (.-NativeModules js-dependencies/react-native)))
(defn webview-bridge [{:keys [dapp? dapp-name] :as opts}] (defn webview-bridge [{:keys [dapp? dapp-name] :as opts}]
(if (and config/cached-webviews-enabled? platform/android? dapp?) (if (and config/cached-webviews-enabled? platform/android? dapp?)
@ -19,10 +21,10 @@
;; unfortunately it's impossible to pass some initial params ;; unfortunately it's impossible to pass some initial params
;; to view, that's why we have to pass dapp-name to the module ;; to view, that's why we have to pass dapp-name to the module
;; before showing webview ;; before showing webview
(.setCurrentDapp module dapp-name (.setCurrentDapp (module) dapp-name
(fn [] (reset! dapp-name-sent? true)))) (fn [] (reset! dapp-name-sent? true))))
:reagent-render :reagent-render
(fn [opts] (fn [opts]
(when @dapp-name-sent? (when @dapp-name-sent?
[webview-bridge-class opts]))})) [(webview-bridge-class) opts]))}))
[webview-bridge-class opts])) [(webview-bridge-class) opts]))

View File

@ -45,7 +45,7 @@
[react/view {:flex 1} [react/view {:flex 1}
[status-bar/status-bar] [status-bar/status-bar]
[toolbar/simple-toolbar (i18n/label :t/about-app)] [toolbar/simple-toolbar (i18n/label :t/about-app)]
[react/scroll-view [(react/scroll-view)
[react/view [react/view
[profile.components/settings-item-separator] [profile.components/settings-item-separator]

View File

@ -54,7 +54,7 @@
[react/text {:style styles/account-creating-text} [react/text {:style styles/account-creating-text}
(i18n/label :t/creating-your-account)]]]) (i18n/label :t/creating-your-account)]]])
(when (#{:enter-password :confirm-password :enter-name} step) (when (#{:enter-password :confirm-password :enter-name} step)
[react/scroll-view {:flex 1} [(react/scroll-view) {:flex 1}
[react/view {:style styles/logo-container} [react/view {:style styles/logo-container}
[components.common/logo styles/logo]] [components.common/logo styles/logo]]
^{:key (str "step" step)} ^{:key (str "step" step)}

View File

@ -64,7 +64,7 @@
[react/keyboard-avoiding-view {:style ast/accounts-view} [react/keyboard-avoiding-view {:style ast/accounts-view}
[status-bar/status-bar] [status-bar/status-bar]
[login-toolbar can-navigate-back?] [login-toolbar can-navigate-back?]
[react/scroll-view styles/login-view [(react/scroll-view) styles/login-view
[react/view styles/login-badge-container [react/view styles/login-badge-container
[account-login-badge photo-path name] [account-login-badge photo-path name]
[react/view {:style styles/password-container [react/view {:style styles/password-container

View File

@ -45,7 +45,7 @@
[status-bar/status-bar] [status-bar/status-bar]
[react/keyboard-avoiding-view components.styles/flex [react/keyboard-avoiding-view components.styles/flex
[toolbar/simple-toolbar (i18n/label (if id :t/bootnode-details :t/add-bootnode))] [toolbar/simple-toolbar (i18n/label (if id :t/bootnode-details :t/add-bootnode))]
[react/scroll-view {:keyboard-should-persist-taps :handled} [(react/scroll-view) {:keyboard-should-persist-taps :handled}
[react/view styles/edit-bootnode-view [react/view styles/edit-bootnode-view
[text-input/text-input-with-label [text-input/text-input-with-label
{:label (i18n/label :t/name) {:label (i18n/label :t/name)

View File

@ -31,7 +31,7 @@
:image [react/view styles/browser-icon-container :image [react/view styles/browser-icon-container
[vector-icons/icon :main-icons/browser {:color colors/gray}]]}]]) [vector-icons/icon :main-icons/browser {:color colors/gray}]]}]])
(def dapp-image-data {:image (:dapp-store resources/ui) :width 768 :height 333}) (def dapp-image-data {:image (resources/get-image :dapp-store) :width 768 :height 333})
(def dapp-image (components.common/image-contain nil dapp-image-data)) (def dapp-image (components.common/image-contain nil dapp-image-data))
(def privacy-otions-visible? (reagent/atom true)) (def privacy-otions-visible? (reagent/atom true))
@ -95,7 +95,7 @@
[components/separator] [components/separator]
(if (empty? browsers) (if (empty? browsers)
[list-header true] [list-header true]
[react/scroll-view [(react/scroll-view)
[list-header false] [list-header false]
[list/flat-list {:data browsers [list/flat-list {:data browsers
:footer [react/view :footer [react/view
@ -103,4 +103,4 @@
:align-self :stretch}}] :align-self :stretch}}]
:key-fn :browser-id :key-fn :browser-id
:end-fill-color colors/white :end-fill-color colors/white
:render-fn list-item}]])])) :render-fn list-item}]])]))

View File

@ -74,8 +74,8 @@
(when @current-permission (when @current-permission
(let [{:keys [title description icon]} @current-permission] (let [{:keys [title description icon]} @current-permission]
[react/view styles/permissions-panel-container [react/view styles/permissions-panel-container
[react/animated-view {:style (styles/permissions-panel-background alpha-value)}] [(react/animated-view) {:style (styles/permissions-panel-background alpha-value)}]
[react/animated-view {:style (styles/permissions-panel bottom-anim-value)} [(react/animated-view) {:style (styles/permissions-panel bottom-anim-value)}
[react/view styles/permissions-panel-icons-container [react/view styles/permissions-panel-icons-container
(if dapp? (if dapp?
[chat-icon.screen/dapp-icon-permission dapp 48] [chat-icon.screen/dapp-icon-permission dapp 48]

View File

@ -9,16 +9,16 @@
(:require-macros [status-im.utils.views :as views])) (:require-macros [status-im.utils.views :as views]))
(views/defview view [{:keys [can-go-back?]}] (views/defview view [{:keys [can-go-back?]}]
[react/scroll-view {:keyboard-should-persist-taps :always [(react/scroll-view) {:keyboard-should-persist-taps :always
:bounces false :bounces false
:content-container-style styles/container} :content-container-style styles/container}
[react/view styles/container-root-view [react/view styles/container-root-view
[vector-icons/icon :main-icons/info {:color colors/red}] [vector-icons/icon :main-icons/info {:color colors/red}]
[react/text {:style styles/title-text} [react/text {:style styles/title-text}
(i18n/label :t/browsing-site-blocked-title)] (i18n/label :t/browsing-site-blocked-title)]
[react/nested-text {:style styles/description-text} [react/nested-text {:style styles/description-text}
(i18n/label :t/browsing-site-blocked-description1) (i18n/label :t/browsing-site-blocked-description1)
[{:on-press #(.openURL react/linking "status-im://chat/public/status") [{:on-press #(.openURL (react/linking) "status-im://chat/public/status")
:style styles/chat-link-text} :style styles/chat-link-text}
"#status"] "#status"]
(i18n/label :t/browsing-site-blocked-description2)] (i18n/label :t/browsing-site-blocked-description2)]

View File

@ -37,7 +37,7 @@
:display-name "container" :display-name "container"
:reagent-render :reagent-render
(fn [height & children] (fn [height & children]
[react/animated-view {:style (styles/bottom-info-container height)} [(react/animated-view) {:style (styles/bottom-info-container height)}
(into [react/view] children)])}))) (into [react/view] children)])})))
(defn- message-status-row [{:keys [photo-path name]} {:keys [public-key status]}] (defn- message-status-row [{:keys [photo-path name]} {:keys [public-key status]}]

View File

@ -31,9 +31,9 @@
bottom (+ input-height chat-input-margin) bottom (+ input-height chat-input-margin)
max-height (- chat-layout-height (when platform/ios? keyboard-height) input-height top-offset)] max-height (- chat-layout-height (when platform/ios? keyboard-height) input-height top-offset)]
[react/view style/overlap-container [react/view style/overlap-container
[react/animated-view {:style (style/expandable-container anim-value bottom max-height)} [(react/animated-view) {:style (style/expandable-container anim-value bottom max-height)}
(into [react/scroll-view {:keyboard-should-persist-taps :always (into [(react/scroll-view) {:keyboard-should-persist-taps :always
:on-content-size-change #(expandable-view-on-update anim-value %2) :on-content-size-change #(expandable-view-on-update anim-value %2)
:bounces false}] :bounces false}]
(when (or input-focused? (not messages-focused?)) (when (or input-focused? (not messages-focused?))
elements))]]))) elements))]])))

View File

@ -113,7 +113,7 @@
on-update (input-helper-view-on-update {:opacity-value opacity-value on-update (input-helper-view-on-update {:opacity-value opacity-value
:placeholder placeholder})] :placeholder placeholder})]
{:component-did-update on-update} {:component-did-update on-update}
[react/animated-view {:style (style/input-helper-view width opacity-value)} [(react/animated-view) {:style (style/input-helper-view width opacity-value)}
[react/text {:style (style/input-helper-text width)} [react/text {:style (style/input-helper-text width)}
placeholder]])) placeholder]]))
@ -131,7 +131,7 @@
set-container-width-fn #(reagent/set-state component {:container-width %}) set-container-width-fn #(reagent/set-state component {:container-width %})
{:keys [width]} (reagent/state component)] {:keys [width]} (reagent/state component)]
[react/view {:style style/input-root} [react/view {:style style/input-root}
[react/animated-view {:style style/input-animated} [(react/animated-view) {:style style/input-animated}
[invisible-input {:set-layout-width-fn set-layout-width-fn}] [invisible-input {:set-layout-width-fn set-layout-width-fn}]
(if platform/desktop? (if platform/desktop?
[basic-text-input-desktop {:set-container-width-fn set-container-width-fn [basic-text-input-desktop {:set-container-width-fn set-container-width-fn
@ -156,7 +156,7 @@
(defview reply-message [from message-text] (defview reply-message [from message-text]
(letsubs [username [:contacts/contact-name-by-identity from] (letsubs [username [:contacts/contact-name-by-identity from]
current-public-key [:account/public-key]] current-public-key [:account/public-key]]
[react/scroll-view {:style style/reply-message-content} [(react/scroll-view) {:style style/reply-message-content}
(chat-utils/format-reply-author from username current-public-key style/reply-message-author) (chat-utils/format-reply-author from username current-public-key style/reply-message-author)
[react/text {:style (message-style/style-message-text false)} message-text]])) [react/text {:style (message-style/style-message-text false)} message-text]]))

View File

@ -19,8 +19,8 @@
(letsubs [available-commands [:chats/available-commands]] (letsubs [available-commands [:chats/available-commands]]
[expandable/expandable-view {:key :suggestions} [expandable/expandable-view {:key :suggestions}
[react/view [react/view
[react/scroll-view {:keyboard-should-persist-taps :always [(react/scroll-view) {:keyboard-should-persist-taps :always
:bounces false} :bounces false}
(when (seq available-commands) (when (seq available-commands)
(map-indexed (map-indexed
(fn [i {:keys [type] :as command}] (fn [i {:keys [type] :as command}]

View File

@ -15,7 +15,7 @@
{:on-press (fn [_] {:on-press (fn [_]
(re-frame/dispatch (re-frame/dispatch
[:chat.ui/set-chat-ui-props {:messages-focused? true [:chat.ui/set-chat-ui-props {:messages-focused? true
:show-stickers? false}]) :show-stickers? false}])
(react/dismiss-keyboard!))} (react/dismiss-keyboard!))}
[react/view style/datemark-mobile [react/view style/datemark-mobile
[react/text {:style style/datemark-text} [react/text {:style style/datemark-text}

View File

@ -280,7 +280,7 @@
(when (= content-type constants/content-type-sticker) (when (= content-type constants/content-type-sticker)
(re-frame/dispatch [:stickers/open-sticker-pack (:pack content)])) (re-frame/dispatch [:stickers/open-sticker-pack (:pack content)]))
(re-frame/dispatch [:chat.ui/set-chat-ui-props {:messages-focused? true (re-frame/dispatch [:chat.ui/set-chat-ui-props {:messages-focused? true
:show-stickers? false}]) :show-stickers? false}])
(when-not platform/desktop? (when-not platform/desktop?
(react/dismiss-keyboard!))))) (react/dismiss-keyboard!)))))
:on-long-press #(when (or (= content-type constants/content-type-text) (= content-type constants/content-type-emoji)) :on-long-press #(when (or (= content-type constants/content-type-text) (= content-type constants/content-type-emoji))

View File

@ -30,16 +30,16 @@
[react/view {:style {:flex 1 :align-items :center :justify-content :center}} [react/view {:style {:flex 1 :align-items :center :justify-content :center}}
[vector-icons/icon :stickers-icons/stickers-big {:color colors/gray}] [vector-icons/icon :stickers-icons/stickers-big {:color colors/gray}]
[react/text {:style {:margin-top 8 :font-size 17}} (i18n/label :t/you-dont-have-stickers)] [react/text {:style {:margin-top 8 :font-size 17}} (i18n/label :t/you-dont-have-stickers)]
[react/touchable-opacity {:on-press #(do [(react/touchable-opacity) {:on-press #(do
(re-frame/dispatch [:stickers/load-packs]) (re-frame/dispatch [:stickers/load-packs])
(re-frame/dispatch [:navigate-to :stickers]))} (re-frame/dispatch [:navigate-to :stickers]))}
[react/view {:margin-top 6 :height 44 :justify-content :center} [react/view {:margin-top 6 :height 44 :justify-content :center}
[react/text {:style {:color colors/blue}} [react/text {:style {:color colors/blue}}
(i18n/label :t/get-stickers)]]]]) (i18n/label :t/get-stickers)]]]])
(defn- stickers-panel [stickers window-width] (defn- stickers-panel [stickers window-width]
[react/view {:width window-width :flex 1} [react/view {:width window-width :flex 1}
[react/scroll-view [(react/scroll-view)
[react/view {:style styles/stickers-panel} [react/view {:style styles/stickers-panel}
(for [{:keys [uri] :as sticker} stickers] (for [{:keys [uri] :as sticker} stickers]
^{:key uri} ^{:key uri}
@ -80,12 +80,12 @@
{:component-will-update (fn [_ [_ installed-packs selected-pack]] {:component-will-update (fn [_ [_ installed-packs selected-pack]]
(update-scroll-position @ref installed-packs selected-pack window-width)) (update-scroll-position @ref installed-packs selected-pack window-width))
:component-did-mount #(update-scroll-position @ref installed-packs selected-pack window-width)} :component-did-mount #(update-scroll-position @ref installed-packs selected-pack window-width)}
[react/scroll-view {:style {:flex 1} :horizontal true :paging-enabled true [(react/scroll-view) {:style {:flex 1} :horizontal true :paging-enabled true
:ref #(reset! ref %) :ref #(reset! ref %)
:shows-horizontal-scroll-indicator false :shows-horizontal-scroll-indicator false
:on-momentum-scroll-end #(on-scroll % installed-packs window-width) :on-momentum-scroll-end #(on-scroll % installed-packs window-width)
:scrollEventThrottle 8 :scrollEventThrottle 8
:on-scroll #(reset! scroll-x (.-nativeEvent.contentOffset.x %))} :on-scroll #(reset! scroll-x (.-nativeEvent.contentOffset.x %))}
^{:key "recent"} ^{:key "recent"}
[recent-stickers-panel window-width] [recent-stickers-panel window-width]
(for [{:keys [stickers id]} installed-packs] (for [{:keys [stickers id]} installed-packs]
@ -129,8 +129,8 @@
(do (do
(anim/set-value bottom-anim-value (styles/stickers-panel-height)) (anim/set-value bottom-anim-value (styles/stickers-panel-height))
(anim/set-value alpha-value 1)))} (anim/set-value alpha-value 1)))}
[react/animated-view {:style {:background-color :white :height (if input-focused? 0 bottom-anim-value) [(react/animated-view) {:style {:background-color :white :height (if input-focused? 0 bottom-anim-value)
:opacity alpha-value}} :opacity alpha-value}}
(cond (cond
(= selected-pack :recent) [stickers-paging-panel installed-packs selected-pack] (= selected-pack :recent) [stickers-paging-panel installed-packs selected-pack]
(not (seq installed-packs)) [no-stickers-yet-panel] (not (seq installed-packs)) [no-stickers-yet-panel]
@ -142,7 +142,7 @@
:selected? false :background-color colors/blue} :selected? false :background-color colors/blue}
[vector-icons/icon :main-icons/add {:width 20 :height 20 :color colors/white}]] [vector-icons/icon :main-icons/add {:width 20 :height 20 :color colors/white}]]
[react/view {:width 2}] [react/view {:width 2}]
[react/scroll-view {:horizontal true :style {:padding-left 2}} [(react/scroll-view) {:horizontal true :style {:padding-left 2}}
[react/view [react/view
[react/view {:style {:flex-direction :row}} [react/view {:style {:flex-direction :row}}
[pack-icon {:id :recent :background-color colors/white} [pack-icon {:id :recent :background-color colors/white}

View File

@ -38,7 +38,7 @@
{:style {:color (if outgoing colors/white colors/blue) {:style {:color (if outgoing colors/white colors/blue)
:text-decoration-line :underline} :text-decoration-line :underline}
:on-press (if platform/desktop? :on-press (if platform/desktop?
#(.openURL react/linking (http/normalize-url text)) #(.openURL (react/linking) (http/normalize-url text))
#(re-frame/dispatch [:browser.ui/message-link-pressed text]))}) #(re-frame/dispatch [:browser.ui/message-link-pressed text]))})
:tag (fn [text {:keys [outgoing]}] :tag (fn [text {:keys [outgoing]}]
{:style {:color (if outgoing colors/white colors/blue) {:style {:color (if outgoing colors/white colors/blue)

View File

@ -108,7 +108,7 @@
(react/dismiss-keyboard!)))} (react/dismiss-keyboard!)))}
(if platform/desktop? (if platform/desktop?
message-view message-view
[react/animated-view {:style (style/message-view-animated opacity)} [(react/animated-view) {:style (style/message-view-animated opacity)}
message-view])]])) message-view])]]))
(defn join-chat-button [chat-id] (defn join-chat-button [chat-id]
@ -371,10 +371,10 @@
(when (= chat-id current-chat-id) (when (= chat-id current-chat-id)
;; this scroll-view is a hack that allows us to use on-blur and on-focus on Android ;; this scroll-view is a hack that allows us to use on-blur and on-focus on Android
;; more details here: https://github.com/facebook/react-native/issues/11071 ;; more details here: https://github.com/facebook/react-native/issues/11071
[react/scroll-view {:scroll-enabled false [(react/scroll-view) {:scroll-enabled false
:style style/scroll-root :style style/scroll-root
:content-container-style style/scroll-root :content-container-style style/scroll-root
:keyboard-should-persist-taps :handled} :keyboard-should-persist-taps :handled}
^{:key current-chat-id} ^{:key current-chat-id}
[react/view {:style style/chat-view [react/view {:style style/chat-view
:on-layout (fn [e] :on-layout (fn [e]

View File

@ -23,7 +23,7 @@
[toolbar.view/toolbar nil [toolbar.view/toolbar nil
toolbar.view/default-nav-back toolbar.view/default-nav-back
(toolbar.view/content-title (i18n/label :t/contacts))] (toolbar.view/content-title (i18n/label :t/contacts))]
[react/scroll-view {:flex 1} [(react/scroll-view) {:flex 1}
[list.views/big-list-item [list.views/big-list-item
{:style {:margin-vertical 16} {:style {:margin-vertical 16}
:text (i18n/label :t/blocked-users) :text (i18n/label :t/blocked-users)
@ -43,8 +43,8 @@
:background-color colors/white} :background-color colors/white}
[status-bar/status-bar] [status-bar/status-bar]
[toolbar.view/simple-toolbar (i18n/label :t/blocked-users)] [toolbar.view/simple-toolbar (i18n/label :t/blocked-users)]
[react/scroll-view {:style {:background-color colors/white [(react/scroll-view) {:style {:background-color colors/white
:padding-vertical 8}} :padding-vertical 8}}
[list.views/flat-list [list.views/flat-list
{:data blocked-contacts {:data blocked-contacts
:key-fn :address :key-fn :address

View File

@ -59,7 +59,7 @@
{:style (styles/add-contact-button-text disable?)} {:style (styles/add-contact-button-text disable?)}
(i18n/label :start-chat)]]]]) (i18n/label :start-chat)]]]])
(when (seq contacts) [react/text {:style styles/new-contact-subtitle} (i18n/label :or-choose-a-contact)]) (when (seq contacts) [react/text {:style styles/new-contact-subtitle} (i18n/label :or-choose-a-contact)])
[react/scroll-view [(react/scroll-view)
[react/view {:style styles/suggested-contacts} [react/view {:style styles/suggested-contacts}
(doall (doall
(for [c contacts] (for [c contacts]
@ -120,7 +120,7 @@
(i18n/label :new-public-group-chat)]]]]) (i18n/label :new-public-group-chat)]]]])
[topic-input-placeholder] [topic-input-placeholder]
[react/text {:style styles/new-contact-subtitle} (i18n/label :selected-for-you)] [react/text {:style styles/new-contact-subtitle} (i18n/label :selected-for-you)]
[react/scroll-view [(react/scroll-view)
[react/view {:style styles/suggested-contacts} [react/view {:style styles/suggested-contacts}
(doall (doall
(for [topic public-chat/default-public-chats] (for [topic public-chat/default-public-chats]

View File

@ -242,19 +242,19 @@
(reset! messages-to-load load-step) (reset! messages-to-load load-step)
(reset! chat-id* chat-id)))] (reset! chat-id* chat-id)))]
[react/view {:style styles/messages-view} [react/view {:style styles/messages-view}
[react/scroll-view {:scrollEventThrottle 16 [(react/scroll-view) {:scrollEventThrottle 16
:headerHeight styles/messages-list-vertical-padding :headerHeight styles/messages-list-vertical-padding
:footerWidth styles/messages-list-vertical-padding :footerWidth styles/messages-list-vertical-padding
:enableArrayScrollingOptimization true :enableArrayScrollingOptimization true
:inverted true :inverted true
:on-scroll (fn [e] :on-scroll (fn [e]
(let [ne (.-nativeEvent e) (let [ne (.-nativeEvent e)
y (.-y (.-contentOffset ne))] y (.-y (.-contentOffset ne))]
(when (<= y 0) (when (<= y 0)
(when @scroll-timer (js/clearTimeout @scroll-timer)) (when @scroll-timer (js/clearTimeout @scroll-timer))
(reset! scroll-timer (js/setTimeout #(re-frame/dispatch [:chat.ui/load-more-messages]) 300))) (reset! scroll-timer (js/setTimeout #(re-frame/dispatch [:chat.ui/load-more-messages]) 300)))
(reset! scroll-height (+ y (.-height (.-layoutMeasurement ne)))))) (reset! scroll-height (+ y (.-height (.-layoutMeasurement ne))))))
:ref #(reset! scroll-ref %)} :ref #(reset! scroll-ref %)}
[react/view [react/view
(doall (doall
(for [{:keys [from content] :as message-obj} (take @messages-to-load messages)] (for [{:keys [from content] :as message-obj} (take @messages-to-load messages)]

View File

@ -161,7 +161,7 @@
(if logging-in? (if logging-in?
[components/activity-indicator {:animating true :color :white}] [components/activity-indicator {:animating true :color :white}]
[icons/icon :main-icons/add {:style {:tint-color :white}}])]]]] [icons/icon :main-icons/add {:style {:tint-color :white}}])]]]]
[react/scroll-view {:enableArrayScrollingOptimization true} [(react/scroll-view) {:enableArrayScrollingOptimization true}
[react/view [react/view
(for [[index chat] (map-indexed vector (or all-home-items chats))] (for [[index chat] (map-indexed vector (or all-home-items chats))]
^{:key (first chat)} ^{:key (first chat)}

View File

@ -168,7 +168,7 @@
preferred-mailserver-id) preferred-mailserver-id)
pfs? (:pfs? settings) pfs? (:pfs? settings)
connection-message (connection-status peers-count node-status mailserver-state disconnected)] connection-message (connection-status peers-count node-status mailserver-state disconnected)]
[react/scroll-view [(react/scroll-view)
[react/text {:style styles/advanced-settings-title} [react/text {:style styles/advanced-settings-title}
(i18n/label :advanced-settings)] (i18n/label :advanced-settings)]
@ -225,7 +225,7 @@
(views/letsubs [installations [:pairing/installations] (views/letsubs [installations [:pairing/installations]
installation-id [:pairing/installation-id] installation-id [:pairing/installation-id]
installation-name [:pairing/installation-name]] installation-name [:pairing/installation-name]]
[react/scroll-view [(react/scroll-view)
(installations-section (installations-section
installation-id installation-id
installation-name installation-name

View File

@ -32,7 +32,7 @@
[status-bar/status-bar] [status-bar/status-bar]
[react/keyboard-avoiding-view components.styles/flex [react/keyboard-avoiding-view components.styles/flex
[toolbar/simple-toolbar (i18n/label :t/extension) modal?] [toolbar/simple-toolbar (i18n/label :t/extension) modal?]
[react/scroll-view {:keyboard-should-persist-taps :handled} [(react/scroll-view) {:keyboard-should-persist-taps :handled}
[react/view styles/wrapper [react/view styles/wrapper
[react/view {:style {:border-radius 8 :margin 10 :padding 8 :background-color colors/red}} [react/view {:style {:border-radius 8 :margin 10 :padding 8 :background-color colors/red}}
[react/text {:style {:color colors/white}} [react/text {:style {:color colors/white}}
@ -91,7 +91,7 @@
[status-bar/status-bar] [status-bar/status-bar]
[react/keyboard-avoiding-view components.styles/flex [react/keyboard-avoiding-view components.styles/flex
[toolbar/simple-toolbar (i18n/label :t/extension-find)] [toolbar/simple-toolbar (i18n/label :t/extension-find)]
[react/scroll-view {:keyboard-should-persist-taps :handled} [(react/scroll-view) {:keyboard-should-persist-taps :handled}
[react/view styles/wrapper [react/view styles/wrapper
[text-input/text-input-with-label [text-input/text-input-with-label
{:label (i18n/label :t/extension-address) {:label (i18n/label :t/extension-address)

View File

@ -90,7 +90,7 @@
(list-selection/open-share {:message (i18n/label :t/get-status-at)}))) (list-selection/open-share {:message (i18n/label :t/get-status-at)})))
(defn toggle-list [contacts render-function] (defn toggle-list [contacts render-function]
[react/scroll-view {:flex 1} [(react/scroll-view) {:flex 1}
(if utils.platform/desktop? (if utils.platform/desktop?
(for [contact contacts] (for [contact contacts]
^{:key (:public-key contact)} ^{:key (:public-key contact)}
@ -152,7 +152,7 @@
{:selected (count contacts) {:selected (count contacts)
:max (dec constants/max-group-chat-participants)})] :max (dec constants/max-group-chat-participants)})]
[group-name-view] [group-name-view]
[react/scroll-view [(react/scroll-view)
[list/list-with-label {:flex 1} [list/list-with-label {:flex 1}
(i18n/label :t/members-title) (i18n/label :t/members-title)
[list/flat-list {:data contacts [list/flat-list {:data contacts

View File

@ -32,7 +32,7 @@
[common/separator] [common/separator]
[react/view styles/choose-authentication-method [react/view styles/choose-authentication-method
[react/view styles/lock-image-container [react/view styles/lock-image-container
[react/image {:source (:keycard-lock resources/ui) [react/image {:source (resources/get-image :keycard-lock)
:style styles/lock-image}]] :style styles/lock-image}]]
[react/text {:style styles/choose-authentication-method-text [react/text {:style styles/choose-authentication-method-text
:number-of-lines 3} :number-of-lines 3}

View File

@ -12,9 +12,9 @@
(defview application-info [visible?] (defview application-info [visible?]
(letsubs [info [:hardwallet-application-info] (letsubs [info [:hardwallet-application-info]
error [:hardwallet-application-info-error]] error [:hardwallet-application-info-error]]
[react/modal {:visible @visible? [(react/modal) {:visible @visible?
:transparent false :transparent false
:on-request-close #()} :on-request-close #()}
[react/view {:padding 20 [react/view {:padding 20
:justify-content :center} :justify-content :center}
[react/text {:style {:font-size 18 [react/text {:style {:font-size 18

View File

@ -16,7 +16,7 @@
(letsubs [card-read-in-progress? [:hardwallet/card-read-in-progress?]] (letsubs [card-read-in-progress? [:hardwallet/card-read-in-progress?]]
[react/view styles/nfc-enabled-container [react/view styles/nfc-enabled-container
[react/view [react/view
[react/image {:source (:hold-card-animation resources/ui) [react/image {:source (resources/get-image :hold-card-animation)
:style styles/phone-nfc-on-image}]] :style styles/phone-nfc-on-image}]]
[react/view styles/turn-nfc-text-container [react/view styles/turn-nfc-text-container
[react/text {:style styles/status-hardwallet-text [react/text {:style styles/status-hardwallet-text
@ -30,7 +30,7 @@
(defn nfc-disabled [] (defn nfc-disabled []
[react/view styles/nfc-disabled-container [react/view styles/nfc-disabled-container
[react/view [react/view
[react/image {:source (:phone-nfc-off resources/ui) [react/image {:source (resources/get-image :phone-nfc-off)
:style styles/phone-nfc-off-image}]] :style styles/phone-nfc-off-image}]]
[react/view styles/turn-nfc-text-container [react/view styles/turn-nfc-text-container
[react/text {:style styles/status-hardwallet-text [react/text {:style styles/status-hardwallet-text
@ -59,7 +59,7 @@
[nfc-disabled])] [nfc-disabled])]
(if (= setup-step :begin) (if (= setup-step :begin)
[react/view styles/bottom-container [react/view styles/bottom-container
[react/touchable-highlight {:on-press #(.openURL react/linking "https://hardwallet.status.im")} [react/touchable-highlight {:on-press #(.openURL (react/linking) "https://hardwallet.status.im")}
[react/view styles/product-info-container [react/view styles/product-info-container
[react/text {:style styles/product-info-text} [react/text {:style styles/product-info-text}
(i18n/label :t/product-information)] (i18n/label :t/product-information)]

View File

@ -73,7 +73,7 @@
(defn pin-view [{:keys [pin title-label description-label step status error-label (defn pin-view [{:keys [pin title-label description-label step status error-label
retry-counter]}] retry-counter]}]
(let [enabled? (not= status :verifying)] (let [enabled? (not= status :verifying)]
[react/scroll-view [(react/scroll-view)
[react/view styles/pin-container [react/view styles/pin-container
[react/view styles/center-container [react/view styles/center-container
[react/text {:style styles/center-title-text} [react/text {:style styles/center-title-text}

View File

@ -60,7 +60,7 @@
[react/view {:margin-top 71 [react/view {:margin-top 71
:flex 1 :flex 1
:align-items :center} :align-items :center}
[react/image {:source (:warning-sign resources/ui) [react/image {:source (resources/get-image :warning-sign)
:style {:width 160 :style {:width 160
:height 160}}]] :height 160}}]]
[react/view {:flex 1 [react/view {:flex 1
@ -99,7 +99,7 @@
[react/view {:margin-top 47 [react/view {:margin-top 47
:flex 1 :flex 1
:align-items :center} :align-items :center}
[react/image {:source (:hardwallet-card resources/ui) [react/image {:source (resources/get-image :hardwallet-card)
:style {:width 255 :style {:width 255
:height 160}}] :height 160}}]
(when paired-on (when paired-on
@ -115,7 +115,7 @@
[react/view [react/view
[action-row {:icon :main-icons/info [action-row {:icon :main-icons/info
:label :t/help-capitalized :label :t/help-capitalized
:on-press #(.openURL react/linking "https://hardwallet.status.im")}] :on-press #(.openURL (react/linking) "https://hardwallet.status.im")}]
(when pairing (when pairing
[react/view [react/view
[action-row {:icon :main-icons/add [action-row {:icon :main-icons/add

View File

@ -20,15 +20,15 @@
[status-im.ui.screens.hardwallet.setup.styles :as styles] [status-im.ui.screens.hardwallet.setup.styles :as styles]
[status-im.utils.security :as security])) [status-im.utils.security :as security]))
(defonce event-emitter (.-DeviceEventEmitter js-dependencies/react-native)) (defn event-emitter [] (.-DeviceEventEmitter js-dependencies/react-native))
(defview secret-keys [] (defview secret-keys []
(letsubs [secrets [:hardwallet-secrets]] (letsubs [secrets [:hardwallet-secrets]]
[react/view styles/secret-keys-container [react/view styles/secret-keys-container
[react/scroll-view [(react/scroll-view)
[react/view styles/secret-keys-inner-container [react/view styles/secret-keys-inner-container
[react/view [react/view
[react/image {:source (:secret-keys resources/ui) [react/image {:source (resources/get-image :secret-keys)
:style styles/secret-keys-image-container}]] :style styles/secret-keys-image-container}]]
[react/view styles/secret-keys-title-container [react/view styles/secret-keys-title-container
[react/text {:style styles/secret-keys-title-text [react/text {:style styles/secret-keys-title-text
@ -235,7 +235,7 @@
error [:hardwallet-setup-error] error [:hardwallet-setup-error]
width [:dimensions/window-width] width [:dimensions/window-width]
ref (atom nil)] ref (atom nil)]
[react/scroll-view [(react/scroll-view)
[react/view styles/enter-pair-code-container [react/view styles/enter-pair-code-container
[react/view styles/enter-pair-code-title-container [react/view styles/enter-pair-code-title-container
[react/view [react/view
@ -265,7 +265,7 @@
Used by 'Prepare', 'Pair', 'No slots', 'Card is linked' screens" Used by 'Prepare', 'Pair', 'No slots', 'Card is linked' screens"
[react/view styles/card-with-button-view-container [react/view styles/card-with-button-view-container
[react/view styles/hardwallet-card-image-container [react/view styles/hardwallet-card-image-container
[react/image {:source (:hardwallet-card resources/ui) [react/image {:source (resources/get-image :hardwallet-card)
:style styles/hardwallet-card-image}] :style styles/hardwallet-card-image}]
[react/view styles/center-text-container [react/view styles/center-text-container
[react/text {:style (assoc styles/center-text :padding-horizontal 60)} [react/text {:style (assoc styles/center-text :padding-horizontal 60)}
@ -282,12 +282,12 @@
(defn begin [] (defn begin []
[react/view styles/card-blank-container [react/view styles/card-blank-container
[react/scroll-view [(react/scroll-view)
[react/view styles/hardwallet-card-image-container [react/view styles/hardwallet-card-image-container
[react/text {:style styles/card-is-empty-text} [react/text {:style styles/card-is-empty-text}
(i18n/label :t/card-is-blank)] (i18n/label :t/card-is-blank)]
[react/view {:margin-top 15} [react/view {:margin-top 15}
[react/image {:source (:hardwallet-card resources/ui) [react/image {:source (resources/get-image :hardwallet-card)
:style styles/hardwallet-card-image}]] :style styles/hardwallet-card-image}]]
[react/view styles/card-is-empty-prepare-text [react/view styles/card-is-empty-prepare-text
[react/text {:style styles/center-text} [react/text {:style styles/center-text}
@ -323,20 +323,20 @@
:button-label :t/help-capitalized :button-label :t/help-capitalized
:show-icon? true :show-icon? true
:button-container-style {:background-color colors/white} :button-container-style {:background-color colors/white}
:on-press #(.openURL react/linking "https://hardwallet.status.im")}]) :on-press #(.openURL (react/linking) "https://hardwallet.status.im")}])
(defn card-already-linked [] (defn card-already-linked []
[card-with-button-view {:text-label :t/card-already-linked [card-with-button-view {:text-label :t/card-already-linked
:button-label :t/help-capitalized :button-label :t/help-capitalized
:show-icon? true :show-icon? true
:button-container-style {:background-color colors/white} :button-container-style {:background-color colors/white}
:on-press #(.openURL react/linking "https://hardwallet.status.im")}]) :on-press #(.openURL (react/linking) "https://hardwallet.status.im")}])
(defview error [] (defview error []
(letsubs [error [:hardwallet-setup-error]] (letsubs [error [:hardwallet-setup-error]]
[react/view styles/card-with-button-view-container [react/view styles/card-with-button-view-container
[react/view styles/hardwallet-card-image-container [react/view styles/hardwallet-card-image-container
[react/image {:source (:hardwallet-card resources/ui) [react/image {:source (resources/get-image :hardwallet-card)
:style styles/hardwallet-card-image}] :style styles/hardwallet-card-image}]
[react/view styles/center-text-container [react/view styles/center-text-container
[react/text {:style styles/center-text} [react/text {:style styles/center-text}
@ -380,7 +380,7 @@
(.removeListener @listener))) (.removeListener @listener)))
:component-did-mount (fn [] :component-did-mount (fn []
(reset! listener (reset! listener
(.addListener event-emitter (.addListener (event-emitter)
"keycardInstallationProgress" "keycardInstallationProgress"
(fn [params] (fn [params]
(when @progress-bar (when @progress-bar
@ -396,10 +396,10 @@
(i18n/label :t/taking-long-hold-phone-connected)]] (i18n/label :t/taking-long-hold-phone-connected)]]
[react/view styles/progress-bar-container [react/view styles/progress-bar-container
(if (contains? #{:blank :init} card-state) (if (contains? #{:blank :init} card-state)
[react/progress-bar {:styleAttr "Horizontal" [(react/progress-bar) {:styleAttr "Horizontal"
:indeterminate false :indeterminate false
:progress 0 :progress 0
:ref #(reset! progress-bar %)}] :ref #(reset! progress-bar %)}]
[react/activity-indicator {:animating true [react/activity-indicator {:animating true
:size :large}])]])) :size :large}])]]))

View File

@ -14,13 +14,13 @@
[status-bar/status-bar] [status-bar/status-bar]
[toolbar/simple-toolbar [toolbar/simple-toolbar
(i18n/label :t/help-center)] (i18n/label :t/help-center)]
[react/scroll-view [(react/scroll-view)
[react/view [react/view
[profile.components/settings-item-separator] [profile.components/settings-item-separator]
[profile.components/settings-item [profile.components/settings-item
{:label-kw :t/faq {:label-kw :t/faq
:accessibility-label :faq-button :accessibility-label :faq-button
:action-fn #(.openURL react/linking :action-fn #(.openURL (react/linking)
(if platform/desktop? (if platform/desktop?
"https://status.im/docs/FAQ-desktop.html" "https://status.im/docs/FAQ-desktop.html"
"https://status.im/docs/FAQs.html"))}] "https://status.im/docs/FAQs.html"))}]

View File

@ -24,11 +24,11 @@
(animation/start (animation/spring animated-offset-x {:toValue to-value}))))) (animation/start (animation/spring animated-offset-x {:toValue to-value})))))
(defn swipe-pan-responder [animated-offset-x end-offset-x chat-id swiped?] (defn swipe-pan-responder [animated-offset-x end-offset-x chat-id swiped?]
(.create react/pan-responder (.create (react/pan-responder)
(clj->js {:onMoveShouldSetPanResponder on-start (clj->js {:onMoveShouldSetPanResponder on-start
:onPanResponderMove (on-move animated-offset-x end-offset-x swiped?) :onPanResponderMove (on-move animated-offset-x end-offset-x swiped?)
:onPanResponderRelease (on-release animated-offset-x end-offset-x chat-id swiped?) :onPanResponderRelease (on-release animated-offset-x end-offset-x chat-id swiped?)
:onPanResponderTerminate (on-release animated-offset-x end-offset-x chat-id swiped?)}))) :onPanResponderTerminate (on-release animated-offset-x end-offset-x chat-id swiped?)})))
(defn pan-handlers [pan-responder] (defn pan-handlers [pan-responder]
(js->clj (.-panHandlers pan-responder))) (js->clj (.-panHandlers pan-responder)))

View File

@ -95,7 +95,7 @@
(let [{:keys [show? height]} @search-input-state] (let [{:keys [show? height]} @search-input-state]
(when (or show? (when (or show?
search-filter) search-filter)
[react/animated-view [(react/animated-view)
{:style {:height height}} {:style {:height height}}
[search-input search-filter [search-input search-filter
{:on-cancel #(do {:on-cancel #(do

View File

@ -40,7 +40,7 @@
[react/view {:style styles/welcome-image-container} [react/view {:style styles/welcome-image-container}
[components.common/image-contain [components.common/image-contain
{:container-style {}} {:container-style {}}
{:image (:welcome-image resources/ui) :width 750 :height 556}]] {:image (resources/get-image :welcome-image) :width 750 :height 556}]]
[react/i18n-text {:style styles/welcome-text :key :welcome-to-status}] [react/i18n-text {:style styles/welcome-text :key :welcome-to-status}]
[react/view [react/view
[react/i18n-text {:style styles/welcome-text-description [react/i18n-text {:style styles/welcome-text-description

View File

@ -33,7 +33,7 @@
[status-bar/status-bar] [status-bar/status-bar]
[react/keyboard-avoiding-view components.styles/flex [react/keyboard-avoiding-view components.styles/flex
[toolbar/simple-toolbar (i18n/label :t/add-network)] [toolbar/simple-toolbar (i18n/label :t/add-network)]
[react/scroll-view [(react/scroll-view)
[react/view styles/edit-network-view [react/view styles/edit-network-view
[text-input/text-input-with-label [text-input/text-input-with-label
{:label (i18n/label :t/name) {:label (i18n/label :t/name)

View File

@ -54,7 +54,7 @@
[status-bar/status-bar] [status-bar/status-bar]
[react/keyboard-avoiding-view components.styles/flex [react/keyboard-avoiding-view components.styles/flex
[toolbar/simple-toolbar (i18n/label (if id :t/mailserver-details :t/add-mailserver))] [toolbar/simple-toolbar (i18n/label (if id :t/mailserver-details :t/add-mailserver))]
[react/scroll-view {:keyboard-should-persist-taps :handled} [(react/scroll-view) {:keyboard-should-persist-taps :handled}
[react/view styles/edit-mailserver-view [react/view styles/edit-mailserver-view
[text-input/text-input-with-label [text-input/text-input-with-label
{:label (i18n/label :t/name) {:label (i18n/label :t/name)

View File

@ -146,7 +146,7 @@
:on-value-change (partial toggle-enabled! installation-id enabled?)}])]]]) :on-value-change (partial toggle-enabled! installation-id enabled?)}])]]])
(defn render-rows [installation-id installation-name installations] (defn render-rows [installation-id installation-name installations]
[react/scroll-view {:style styles/wrapper} [(react/scroll-view) {:style styles/wrapper}
[your-device installation-id installation-name] [your-device installation-id installation-name]
(when (seq installations) (when (seq installations)
[list/flat-list {:data installations [list/flat-list {:data installations
@ -156,7 +156,7 @@
(views/defview edit-installation-name [] (views/defview edit-installation-name []
[react/keyboard-avoiding-view styles/edit-installation [react/keyboard-avoiding-view styles/edit-installation
[react/scroll-view {:keyboard-should-persist-taps :handled} [(react/scroll-view) {:keyboard-should-persist-taps :handled}
[react/view [react/view
[react/text (i18n/label :t/pairing-please-set-a-name)]] [react/text (i18n/label :t/pairing-please-set-a-name)]]
[text-input/text-input-with-label [text-input/text-input-with-label
@ -179,7 +179,7 @@
(defn info-section [] (defn info-section []
[react/view {:style styles/info-section} [react/view {:style styles/info-section}
[react/touchable-highlight {:on-press #(.openURL react/linking "https://status.im/tutorials/pairing.html")} [react/touchable-highlight {:on-press #(.openURL (react/linking) "https://status.im/tutorials/pairing.html")}
[react/text {:style styles/info-section-text} (i18n/label :t/learn-more)]]]) [react/text {:style styles/info-section-text} (i18n/label :t/learn-more)]]])
(defn installations-list [installation-id installation-name installations] (defn installations-list [installation-id installation-name installations]
@ -197,7 +197,7 @@
[toolbar/toolbar {} [toolbar/toolbar {}
toolbar/default-nav-back toolbar/default-nav-back
[toolbar/content-title (i18n/label :t/devices)]] [toolbar/content-title (i18n/label :t/devices)]]
[react/scroll-view {:style {:background-color :white}} [(react/scroll-view) {:style {:background-color :white}}
(if (string/blank? installation-name) (if (string/blank? installation-name)
[edit-installation-name] [edit-installation-name]
[react/view [react/view

View File

@ -82,7 +82,7 @@
[react/view profile.components.styles/profile [react/view profile.components.styles/profile
[status-bar/status-bar] [status-bar/status-bar]
[profile-contact-toolbar] [profile-contact-toolbar]
[react/scroll-view [(react/scroll-view)
[react/view profile.components.styles/profile-form [react/view profile.components.styles/profile-form
[profile.components/profile-header [profile.components/profile-header
{:contact contact {:contact contact

View File

@ -105,7 +105,7 @@
(if editing? (if editing?
[group-chat-profile-edit-toolbar] [group-chat-profile-edit-toolbar]
[group-chat-profile-toolbar admin?]) [group-chat-profile-toolbar admin?])
[react/scroll-view [(react/scroll-view)
[react/view profile.components.styles/profile-form [react/view profile.components.styles/profile-form
[profile.components/profile-header [profile.components/profile-header
{:contact shown-chat {:contact shown-chat

View File

@ -36,11 +36,11 @@
:second-word (re-frame/dispatch [:my-profile/set-step :first-word]))) :second-word (re-frame/dispatch [:my-profile/set-step :first-word])))
(defn intro [] (defn intro []
[react/scroll-view {:style {:padding-horizontal 16} [(react/scroll-view) {:style {:padding-horizontal 16}
:content-container-style {:align-items :center :content-container-style {:align-items :center
:justify-content :center}} :justify-content :center}}
(when-not platform/desktop? (when-not platform/desktop?
[react/image {:source (:lock resources/ui) [react/image {:source (resources/get-image :lock)
:style styles/intro-image}]) :style styles/intro-image}])
[react/i18n-text {:style styles/intro-text [react/i18n-text {:style styles/intro-text
:key :your-data-belongs-to-you}] :key :your-data-belongs-to-you}]

View File

@ -34,7 +34,7 @@
[react/view {:style {:flex 1 [react/view {:style {:flex 1
:min-height 32}}] :min-height 32}}]
[react/image {:source (:tribute-to-talk resources/ui) [react/image {:source (resources/get-image :tribute-to-talk)
:style styles/intro-image}] :style styles/intro-image}]
[react/view {:style {:flex 1 [react/view {:style {:flex 1
:min-height 32}}] :min-height 32}}]
@ -67,7 +67,7 @@
(defn number-view (defn number-view
[numpad-symbol {:keys [on-press]}] [numpad-symbol {:keys [on-press]}]
[react/touchable-opacity [(react/touchable-opacity)
{:on-press #(on-press numpad-symbol)} {:on-press #(on-press numpad-symbol)}
[react/view {:style styles/number-container} [react/view {:style styles/number-container}
(if (= numpad-symbol :remove) (if (= numpad-symbol :remove)
@ -96,7 +96,7 @@
(defn set-snt-amount (defn set-snt-amount
[snt-amount] [snt-amount]
[react/scroll-view [(react/scroll-view)
{:content-container-style styles/set-snt-amount-container} {:content-container-style styles/set-snt-amount-container}
[react/view {:style (styles/horizontal-separator 16 32)}] [react/view {:style (styles/horizontal-separator 16 32)}]
[snt-amount-label snt-amount] [snt-amount-label snt-amount]
@ -109,7 +109,7 @@
(defn personalized-message (defn personalized-message
[message] [message]
[react/scroll-view [(react/scroll-view)
{:content-container-style styles/personalized-message-container} {:content-container-style styles/personalized-message-container}
[react/view {:style styles/personalized-message-title} [react/view {:style styles/personalized-message-title}
[react/nested-text {:style {:text-align :center}} [react/nested-text {:style {:text-align :center}}
@ -219,7 +219,7 @@
(defn edit (defn edit
[snt-amount message fiat-value] [snt-amount message fiat-value]
[react/scroll-view {:content-container-style styles/edit-container} [(react/scroll-view) {:content-container-style styles/edit-container}
[react/view {:style styles/edit-screen-top-row} [react/view {:style styles/edit-screen-top-row}
[react/view {:style {:flex-direction :row [react/view {:style {:flex-direction :row
:justify-content :flex-start :justify-content :flex-start
@ -312,8 +312,8 @@
(i18n/label :t/tribute-to-talk)] (i18n/label :t/tribute-to-talk)]
[react/text {:style styles/step-n} [react/text {:style styles/step-n}
(i18n/label :t/learn-more)]]]) (i18n/label :t/learn-more)]]])
[react/scroll-view {:content-container-style styles/learn-more-container} [(react/scroll-view) {:content-container-style styles/learn-more-container}
[react/image {:source (:tribute-to-talk resources/ui) [react/image {:source (resources/get-image :tribute-to-talk)
:style styles/learn-more-image}] :style styles/learn-more-image}]
[react/text {:style styles/learn-more-title-text} [react/text {:style styles/learn-more-title-text}
(i18n/label :t/tribute-to-talk)] (i18n/label :t/tribute-to-talk)]
@ -347,12 +347,11 @@
:t/tribute-to-talk-paywall-learn-more-3))]]]]) :t/tribute-to-talk-paywall-learn-more-3))]]]])
(defview tribute-to-talk [] (defview tribute-to-talk []
(letsubs [current-account [:account/account] (letsubs [{:keys [step snt-amount editing? message
{:keys [step snt-amount editing? message
fiat-value disable-button? state]} fiat-value disable-button? state]}
[:tribute-to-talk/ui]] [:tribute-to-talk/ui]]
[react/keyboard-avoiding-view {:style styles/container} [react/keyboard-avoiding-view {:style styles/container}
[react/safe-area-view {:style {:flex 1}} [(react/safe-area-view) {:style {:flex 1}}
[status-bar/status-bar] [status-bar/status-bar]
[toolbar/toolbar [toolbar/toolbar
nil nil

View File

@ -125,7 +125,7 @@
:action-fn #(re-frame/dispatch [:profile.ui/keycard-settings-button-pressed])}]) :action-fn #(re-frame/dispatch [:profile.ui/keycard-settings-button-pressed])}])
[profile.components/settings-item {:label-kw :t/notifications [profile.components/settings-item {:label-kw :t/notifications
:accessibility-label :notifications-button :accessibility-label :notifications-button
:action-fn #(.openURL react/linking "app-settings://notification/status-im")}] :action-fn #(.openURL (react/linking) "app-settings://notification/status-im")}]
[profile.components/settings-item-separator] [profile.components/settings-item-separator]
[profile.components/settings-item {:label-kw :t/mobile-network-settings [profile.components/settings-item {:label-kw :t/mobile-network-settings
:accessibility-label :notifications-button :accessibility-label :notifications-button
@ -311,7 +311,7 @@
[react/keyboard-avoiding-view {:style {:flex 1}} [react/keyboard-avoiding-view {:style {:flex 1}}
[status-bar/status-bar {:type :main}] [status-bar/status-bar {:type :main}]
[toolbar/simple-toolbar label] [toolbar/simple-toolbar label]
[react/scroll-view [(react/scroll-view)
[view]]])) [view]]]))
(defview my-profile [] (defview my-profile []
@ -343,8 +343,8 @@
(if editing? (if editing?
[my-profile-edit-toolbar on-show-edit] [my-profile-edit-toolbar on-show-edit]
[my-profile-toolbar]) [my-profile-toolbar])
[react/scroll-view {:ref #(reset! scroll %) [(react/scroll-view) {:ref #(reset! scroll %)
:keyboard-should-persist-taps :handled} :keyboard-should-persist-taps :handled}
[react/view profile.components.styles/profile-form [react/view profile.components.styles/profile-form
[profile.components/profile-header [profile.components/profile-header
{:contact current-account {:contact current-account

Some files were not shown because too many files have changed in this diff Show More