@polkadot/react-api
Version:
A collection of RxJs React components the Polkadot JS API
95 lines (75 loc) • 3.42 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = withObservable;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireDefault(require("react"));
var _rxjs = require("rxjs");
var _operators = require("rxjs/operators");
var _echo = _interopRequireDefault(require("../transform/echo"));
var _util = require("../util");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function withObservable(observable, {
callOnResult,
propName = 'value',
transform = _echo.default
} = {}) {
return (Inner, defaultProps = {}, render) => {
var _temp;
return _temp = class WithObservable extends _react.default.Component {
constructor(...args) {
super(...args);
this.isActive = true;
this.state = {
callResult: undefined,
callUpdated: false,
callUpdatedAt: 0,
subscriptions: []
};
this.triggerUpdate = (props, callResult) => {
try {
if (!this.isActive || (0, _util.isEqual)(callResult, this.state.callResult)) {
return;
}
(0, _util.triggerChange)(callResult, callOnResult, props.callOnResult || defaultProps.callOnResult);
this.setState({
callResult,
callUpdated: true,
callUpdatedAt: Date.now()
});
} catch (error) {
console.error(this.props, error);
}
};
}
componentDidMount() {
this.setState({
subscriptions: [observable.pipe((0, _operators.map)(transform), (0, _operators.catchError)(() => (0, _rxjs.of)(undefined))).subscribe(value => this.triggerUpdate(this.props, value)), (0, _util.intervalObservable)(this)]
});
}
componentWillUnmount() {
this.isActive = false;
this.state.subscriptions.forEach(subscription => subscription.unsubscribe());
}
render() {
const {
children
} = this.props;
const {
callUpdated,
callUpdatedAt,
callResult
} = this.state;
const _props = _objectSpread({}, defaultProps, {}, this.props, {
callUpdated,
callUpdatedAt,
[propName]: callResult
});
return _react.default.createElement(Inner, _props, render && render(callResult), children);
}
}, _temp;
};
}