@chatui/core
Version:
The React library for Chatbot UI
65 lines (64 loc) • 2.94 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ErrorBoundary = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _react = _interopRequireDefault(require("react"));
var _excluded = ["FallbackComponent", "children"];
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2.default)(o), (0, _possibleConstructorReturn2.default)(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2.default)(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
var ErrorBoundary = exports.ErrorBoundary = /*#__PURE__*/function (_React$Component) {
function ErrorBoundary(props) {
var _this;
(0, _classCallCheck2.default)(this, ErrorBoundary);
_this = _callSuper(this, ErrorBoundary, [props]);
_this.state = {
error: null,
errorInfo: null
};
return _this;
}
(0, _inherits2.default)(ErrorBoundary, _React$Component);
return (0, _createClass2.default)(ErrorBoundary, [{
key: "componentDidCatch",
value: function componentDidCatch(error, errorInfo) {
var onError = this.props.onError;
if (onError) {
onError(error, errorInfo);
}
this.setState({
error: error,
errorInfo: errorInfo
});
}
}, {
key: "render",
value: function render() {
var _this$props = this.props,
FallbackComponent = _this$props.FallbackComponent,
children = _this$props.children,
rest = (0, _objectWithoutProperties2.default)(_this$props, _excluded);
var _this$state = this.state,
error = _this$state.error,
errorInfo = _this$state.errorInfo;
if (errorInfo) {
if (FallbackComponent) {
return /*#__PURE__*/_react.default.createElement(FallbackComponent, (0, _extends2.default)({
error: error,
errorInfo: errorInfo
}, rest));
}
return null;
}
return children;
}
}]);
}(_react.default.Component);
;