-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathaccount~explorer.7034d86d2adef28ad57e.js
265 lines (207 loc) · 23.3 KB
/
account~explorer.7034d86d2adef28ad57e.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
(this["webpackJsonp"] = this["webpackJsonp"] || []).push([[21],{
/***/ 2849:
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
__webpack_require__.r(__webpack_exports__);
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "EquivalentValueComponent", function() { return EquivalentValueComponent; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "BalanceValueComponent", function() { return BalanceValueComponent; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "balanceToAsset", function() { return balanceToAsset; });
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getEquivalentValue", function() { return getEquivalentValue; });
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(395);
/* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
/* harmony import */ var _FormattedAsset__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(2117);
/* harmony import */ var _ChainTypes__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(1973);
/* harmony import */ var _BindToChainState__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(1974);
/* harmony import */ var _AssetWrapper__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(2097);
/* harmony import */ var common_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(562);
/* harmony import */ var alt_react__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(1854);
/* harmony import */ var stores_MarketsStore__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(2345);
/* harmony import */ var react_translate_component__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(1860);
/* harmony import */ var react_translate_component__WEBPACK_IMPORTED_MODULE_8___default = /*#__PURE__*/__webpack_require__.n(react_translate_component__WEBPACK_IMPORTED_MODULE_8__);
/* harmony import */ var counterpart__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(578);
/* harmony import */ var counterpart__WEBPACK_IMPORTED_MODULE_9___default = /*#__PURE__*/__webpack_require__.n(counterpart__WEBPACK_IMPORTED_MODULE_9__);
/* harmony import */ var _MarketStatsCheck__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(2347);
/* harmony import */ var common_market_utils__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(2344);
/* harmony import */ var bitshares_ui_style_guide__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(728);
/* harmony import */ var bitshares_ui_style_guide__WEBPACK_IMPORTED_MODULE_12___default = /*#__PURE__*/__webpack_require__.n(bitshares_ui_style_guide__WEBPACK_IMPORTED_MODULE_12__);
/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(824);
/* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_13___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_13__);
/* harmony import */ var bitsharesjs__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(410);
var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }();
var _get = function get(object, property, receiver) { if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { return get(parent, property, receiver); } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } };
function _objectWithoutProperties(obj, keys) { var target = {}; for (var i in obj) { if (keys.indexOf(i) >= 0) continue; if (!Object.prototype.hasOwnProperty.call(obj, i)) continue; target[i] = obj[i]; } return target; }
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; }
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
var getEquivalentValue = function getEquivalentValue(amount, toAsset, fromAsset) {
var fullPrecision = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null;
var coreAsset = arguments.length > 4 && arguments[4] !== undefined ? arguments[4] : null;
var allMarketStats = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : null;
try {
return common_market_utils__WEBPACK_IMPORTED_MODULE_11__["default"].convertValue(amount, toAsset, fromAsset, allMarketStats ? allMarketStats : stores_MarketsStore__WEBPACK_IMPORTED_MODULE_7__["default"].getState().allMarketStats, coreAsset ? coreAsset : bitsharesjs__WEBPACK_IMPORTED_MODULE_14__["ChainStore"].getAsset("1.3.0"), fullPrecision ? fullPrecision : true);
} catch (err) {
console.log(err);
}
};
/**
* Given an asset amount, displays the equivalent value in baseAsset if possible
*
* Expects three properties
* -'toAsset' which should be a asset id
* -'fromAsset' which is the asset id of the original asset amount
* -'amount' which is the amount to convert
* -'fullPrecision' boolean to tell if the amount uses the full precision of the asset
*/
var ValueComponent = function (_MarketStatsCheck) {
_inherits(ValueComponent, _MarketStatsCheck);
function ValueComponent(props) {
_classCallCheck(this, ValueComponent);
return _possibleConstructorReturn(this, (ValueComponent.__proto__ || Object.getPrototypeOf(ValueComponent)).call(this, props));
}
_createClass(ValueComponent, [{
key: "shouldComponentUpdate",
value: function shouldComponentUpdate(np) {
return _get(ValueComponent.prototype.__proto__ || Object.getPrototypeOf(ValueComponent.prototype), "shouldComponentUpdate", this).call(this, np) || !common_utils__WEBPACK_IMPORTED_MODULE_5__["default"].are_equal_shallow(np.pulsate, this.props.pulsate) || np.toAsset !== this.props.toAsset || np.fromAsset !== this.props.fromAsset || np.amount !== this.props.amount;
}
}, {
key: "render",
value: function render() {
var _props = this.props,
amount = _props.amount,
toAsset = _props.toAsset,
fromAsset = _props.fromAsset,
fullPrecision = _props.fullPrecision,
coreAsset = _props.coreAsset,
others = _objectWithoutProperties(_props, ["amount", "toAsset", "fromAsset", "fullPrecision", "coreAsset"]);
var toID = toAsset.get("id");
var toSymbol = toAsset.get("symbol");
var eqValue = getEquivalentValue(amount, toAsset, fromAsset, fullPrecision, coreAsset);
if (!eqValue && eqValue !== 0) {
return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(
bitshares_ui_style_guide__WEBPACK_IMPORTED_MODULE_12__["Tooltip"],
{
placement: "bottom",
title: counterpart__WEBPACK_IMPORTED_MODULE_9___default.a.translate("tooltip.no_price")
},
react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(
"div",
{
className: "tooltip inline-block",
style: { fontSize: "0.9rem" }
},
react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(react_translate_component__WEBPACK_IMPORTED_MODULE_8___default.a, { content: "account.no_price" })
)
);
}
return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(_FormattedAsset__WEBPACK_IMPORTED_MODULE_1__["default"], _extends({
noPrefix: true,
amount: eqValue,
asset: toID,
decimalOffset: toSymbol.indexOf("BTC") !== -1 ? 4 : this.props.fullDecimals ? 0 : this.props.noDecimals ? toAsset.get("precision") : toAsset.get("precision") - 2
}, others));
}
}]);
return ValueComponent;
}(_MarketStatsCheck__WEBPACK_IMPORTED_MODULE_10__["default"]);
ValueComponent.defaultProps = {
fullPrecision: true,
noDecimals: false,
fullDecimals: false,
hide_asset: false
};
ValueComponent = Object(_AssetWrapper__WEBPACK_IMPORTED_MODULE_4__["default"])(ValueComponent, {
propNames: ["toAsset", "fromAsset", "coreAsset"],
defaultProps: {
toAsset: "1.3.0",
coreAsset: "1.3.0"
}
});
var EquivalentValueComponent = function (_React$Component) {
_inherits(EquivalentValueComponent, _React$Component);
function EquivalentValueComponent() {
_classCallCheck(this, EquivalentValueComponent);
return _possibleConstructorReturn(this, (EquivalentValueComponent.__proto__ || Object.getPrototypeOf(EquivalentValueComponent)).apply(this, arguments));
}
_createClass(EquivalentValueComponent, [{
key: "render",
value: function render() {
var _props2 = this.props,
refCallback = _props2.refCallback,
others = _objectWithoutProperties(_props2, ["refCallback"]);
return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(ValueComponent, _extends({}, others, { ref: refCallback }));
}
}]);
return EquivalentValueComponent;
}(react__WEBPACK_IMPORTED_MODULE_0___default.a.Component);
EquivalentValueComponent = Object(alt_react__WEBPACK_IMPORTED_MODULE_6__["connect"])(EquivalentValueComponent, {
listenTo: function listenTo() {
return [stores_MarketsStore__WEBPACK_IMPORTED_MODULE_7__["default"]];
},
getProps: function getProps() {
return {
allMarketStats: stores_MarketsStore__WEBPACK_IMPORTED_MODULE_7__["default"].getState().allMarketStats
};
}
});
var balanceToAsset = function balanceToAsset(balance) {
var isBalanceObject = balance.getIn(["balance", "amount"]);
if (isBalanceObject || isBalanceObject === 0) {
return {
asset_id: balance.getIn(["balance", "asset_id"]),
amount: Number(balance.getIn(["balance", "amount"]))
};
} else {
return {
asset_id: balance.get("asset_type"),
amount: Number(balance.get("balance"))
};
}
};
var BalanceValueComponent = function (_React$Component2) {
_inherits(BalanceValueComponent, _React$Component2);
function BalanceValueComponent() {
_classCallCheck(this, BalanceValueComponent);
return _possibleConstructorReturn(this, (BalanceValueComponent.__proto__ || Object.getPrototypeOf(BalanceValueComponent)).apply(this, arguments));
}
_createClass(BalanceValueComponent, [{
key: "render",
value: function render() {
var _props3 = this.props,
balance = _props3.balance,
others = _objectWithoutProperties(_props3, ["balance"]);
var balanceAsset = balanceToAsset(balance);
var amount = balanceAsset.amount;
// override amount if desired
if (!!this.props.satoshis) {
amount = this.props.satoshis;
}
var fromAsset = balanceAsset.asset_id;
if (isNaN(amount)) return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(
"span",
null,
"--"
);
return react__WEBPACK_IMPORTED_MODULE_0___default.a.createElement(EquivalentValueComponent, _extends({
amount: amount,
fromAsset: fromAsset,
noDecimals: true,
fullPrecision: !!this.props.satoshis ? false : this.props.fullPrecision
}, others));
}
}]);
return BalanceValueComponent;
}(react__WEBPACK_IMPORTED_MODULE_0___default.a.Component);
BalanceValueComponent.propTypes = {
balance: _ChainTypes__WEBPACK_IMPORTED_MODULE_2__["default"].ChainObject.isRequired,
satoshis: prop_types__WEBPACK_IMPORTED_MODULE_13___default.a.number
};
BalanceValueComponent.defaultProps = {
satoshis: null
};
BalanceValueComponent = Object(_BindToChainState__WEBPACK_IMPORTED_MODULE_3__["default"])(BalanceValueComponent, {
keep_updating: true
});
/***/ })
}]);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"account~explorer.7034d86d2adef28ad57e.js","sources":["webpack:///app/components/Utility/EquivalentValueComponent.jsx"],"sourcesContent":["import React from \"react\";\nimport FormattedAsset from \"./FormattedAsset\";\nimport ChainTypes from \"./ChainTypes\";\nimport BindToChainState from \"./BindToChainState\";\nimport AssetWrapper from \"./AssetWrapper\";\nimport utils from \"common/utils\";\nimport {connect} from \"alt-react\";\nimport MarketsStore from \"stores/MarketsStore\";\nimport Translate from \"react-translate-component\";\nimport counterpart from \"counterpart\";\nimport MarketStatsCheck from \"./MarketStatsCheck\";\nimport MarketUtils from \"common/market_utils\";\nimport {Tooltip} from \"bitshares-ui-style-guide\";\nimport PropTypes from \"prop-types\";\nimport {ChainStore} from \"bitsharesjs\";\n\nconst getEquivalentValue = function(\n    amount,\n    toAsset,\n    fromAsset,\n    fullPrecision = null,\n    coreAsset = null,\n    allMarketStats = null\n) {\n    try {\n        return MarketUtils.convertValue(\n            amount,\n            toAsset,\n            fromAsset,\n            allMarketStats\n                ? allMarketStats\n                : MarketsStore.getState().allMarketStats,\n            coreAsset ? coreAsset : ChainStore.getAsset(\"1.3.0\"),\n            fullPrecision ? fullPrecision : true\n        );\n    } catch (err) {\n        console.log(err);\n    }\n};\n\n/**\n *  Given an asset amount, displays the equivalent value in baseAsset if possible\n *\n *  Expects three properties\n *  -'toAsset' which should be a asset id\n *  -'fromAsset' which is the asset id of the original asset amount\n *  -'amount' which is the amount to convert\n *  -'fullPrecision' boolean to tell if the amount uses the full precision of the asset\n */\nclass ValueComponent extends MarketStatsCheck {\n    static defaultProps = {\n        fullPrecision: true,\n        noDecimals: false,\n        fullDecimals: false,\n        hide_asset: false\n    };\n\n    constructor(props) {\n        super(props);\n    }\n\n    shouldComponentUpdate(np) {\n        return (\n            super.shouldComponentUpdate(np) ||\n            !utils.are_equal_shallow(np.pulsate, this.props.pulsate) ||\n            np.toAsset !== this.props.toAsset ||\n            np.fromAsset !== this.props.fromAsset ||\n            np.amount !== this.props.amount\n        );\n    }\n\n    render() {\n        let {\n            amount,\n            toAsset,\n            fromAsset,\n            fullPrecision,\n            coreAsset,\n            ...others\n        } = this.props;\n\n        let toID = toAsset.get(\"id\");\n        let toSymbol = toAsset.get(\"symbol\");\n\n        let eqValue = getEquivalentValue(\n            amount,\n            toAsset,\n            fromAsset,\n            fullPrecision,\n            coreAsset\n        );\n\n        if (!eqValue && eqValue !== 0) {\n            return (\n                <Tooltip\n                    placement=\"bottom\"\n                    title={counterpart.translate(\"tooltip.no_price\")}\n                >\n                    <div\n                        className=\"tooltip inline-block\"\n                        style={{fontSize: \"0.9rem\"}}\n                    >\n                        <Translate content=\"account.no_price\" />\n                    </div>\n                </Tooltip>\n            );\n        }\n\n        return (\n            <FormattedAsset\n                noPrefix\n                amount={eqValue}\n                asset={toID}\n                decimalOffset={\n                    toSymbol.indexOf(\"BTC\") !== -1\n                        ? 4\n                        : this.props.fullDecimals\n                            ? 0\n                            : this.props.noDecimals\n                                ? toAsset.get(\"precision\")\n                                : toAsset.get(\"precision\") - 2\n                }\n                {...others}\n            />\n        );\n    }\n}\nValueComponent = AssetWrapper(ValueComponent, {\n    propNames: [\"toAsset\", \"fromAsset\", \"coreAsset\"],\n    defaultProps: {\n        toAsset: \"1.3.0\",\n        coreAsset: \"1.3.0\"\n    }\n});\n\nclass EquivalentValueComponent extends React.Component {\n    render() {\n        let {refCallback, ...others} = this.props;\n\n        return <ValueComponent {...others} ref={refCallback} />;\n    }\n}\n\nEquivalentValueComponent = connect(\n    EquivalentValueComponent,\n    {\n        listenTo() {\n            return [MarketsStore];\n        },\n        getProps() {\n            return {\n                allMarketStats: MarketsStore.getState().allMarketStats\n            };\n        }\n    }\n);\n\nconst balanceToAsset = function(balance) {\n    const isBalanceObject = balance.getIn([\"balance\", \"amount\"]);\n    if (isBalanceObject || isBalanceObject === 0) {\n        return {\n            asset_id: balance.getIn([\"balance\", \"asset_id\"]),\n            amount: Number(balance.getIn([\"balance\", \"amount\"]))\n        };\n    } else {\n        return {\n            asset_id: balance.get(\"asset_type\"),\n            amount: Number(balance.get(\"balance\"))\n        };\n    }\n};\n\nclass BalanceValueComponent extends React.Component {\n    static propTypes = {\n        balance: ChainTypes.ChainObject.isRequired,\n        satoshis: PropTypes.number\n    };\n\n    static defaultProps = {\n        satoshis: null\n    };\n\n    render() {\n        const {balance, ...others} = this.props;\n        const balanceAsset = balanceToAsset(balance);\n        let amount = balanceAsset.amount;\n        // override amount if desired\n        if (!!this.props.satoshis) {\n            amount = this.props.satoshis;\n        }\n        let fromAsset = balanceAsset.asset_id;\n        if (isNaN(amount)) return <span>--</span>;\n        return (\n            <EquivalentValueComponent\n                amount={amount}\n                fromAsset={fromAsset}\n                noDecimals={true}\n                fullPrecision={\n                    !!this.props.satoshis ? false : this.props.fullPrecision\n                }\n                {...others}\n            />\n        );\n    }\n}\nBalanceValueComponent = BindToChainState(BalanceValueComponent, {\n    keep_updating: true\n});\n\nexport {\n    EquivalentValueComponent,\n    BalanceValueComponent,\n    balanceToAsset,\n    getEquivalentValue\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAOA;AAAA;AAAA;AACA;AAAA;AACA;AAUA;AACA;AACA;AACA;AACA;AACA;;;;;;;;;;AASA;;;AAQA;AAAA;AACA;AADA;AAEA;AACA;;;AACA;AACA;AAOA;;;AAEA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AASA;AACA;AACA;AACA;AACA;AAOA;AACA;AACA;AAAA;AACA;AACA;AAFA;AAIA;AAAA;AAAA;AACA;AACA;AAFA;AAIA;AAJA;AAJA;AAYA;AACA;AACA;AAEA;AACA;AACA;AACA;AAJA;AAgBA;;;;AA5EA;AACA;AADA;AAEA;AACA;AACA;AACA;AAJA;AACA;AA4EA;AACA;AACA;AACA;AACA;AAFA;AAFA;AACA;AAOA;;;;;;;;;;;AACA;AAAA;AAAA;AAAA;AACA;AAEA;AACA;;;;AALA;AACA;AAOA;AAGA;AACA;AACA;AACA;AACA;AACA;AADA;AAGA;AARA;AACA;AAWA;AACA;AACA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;AAFA;AAIA;AACA;AACA;AACA;;;;;;;;;;;AAUA;AAAA;AAAA;AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAAA;AAAA;AAAA;AAAA;AACA;AAEA;AACA;AACA;AACA;AAJA;AAUA;;;;AA/BA;AACA;AADA;AAEA;AACA;AAFA;AADA;AAOA;AADA;AACA;AA0BA;AACA;AADA;AACA;;;;;A","sourceRoot":""}