9346 lines
798 KiB
JavaScript
9346 lines
798 KiB
JavaScript
(function webpackUniversalModuleDefinition(root, factory) {
|
||
if(typeof exports === 'object' && typeof module === 'object')
|
||
module.exports = factory(require("react"), require("react-dom"));
|
||
else if(typeof define === 'function' && define.amd)
|
||
define(["react", "react-dom"], factory);
|
||
else if(typeof exports === 'object')
|
||
exports["ReactBootstrapTable2"] = factory(require("react"), require("react-dom"));
|
||
else
|
||
root["ReactBootstrapTable2"] = factory(root["React"], root["ReactDOM"]);
|
||
})(this, function(__WEBPACK_EXTERNAL_MODULE_0__, __WEBPACK_EXTERNAL_MODULE_17__) {
|
||
return /******/ (function(modules) { // webpackBootstrap
|
||
/******/ // The module cache
|
||
/******/ var installedModules = {};
|
||
/******/
|
||
/******/ // The require function
|
||
/******/ function __webpack_require__(moduleId) {
|
||
/******/
|
||
/******/ // Check if module is in cache
|
||
/******/ if(installedModules[moduleId]) {
|
||
/******/ return installedModules[moduleId].exports;
|
||
/******/ }
|
||
/******/ // Create a new module (and put it into the cache)
|
||
/******/ var module = installedModules[moduleId] = {
|
||
/******/ i: moduleId,
|
||
/******/ l: false,
|
||
/******/ exports: {}
|
||
/******/ };
|
||
/******/
|
||
/******/ // Execute the module function
|
||
/******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
|
||
/******/
|
||
/******/ // Flag the module as loaded
|
||
/******/ module.l = true;
|
||
/******/
|
||
/******/ // Return the exports of the module
|
||
/******/ return module.exports;
|
||
/******/ }
|
||
/******/
|
||
/******/
|
||
/******/ // expose the modules object (__webpack_modules__)
|
||
/******/ __webpack_require__.m = modules;
|
||
/******/
|
||
/******/ // expose the module cache
|
||
/******/ __webpack_require__.c = installedModules;
|
||
/******/
|
||
/******/ // define getter function for harmony exports
|
||
/******/ __webpack_require__.d = function(exports, name, getter) {
|
||
/******/ if(!__webpack_require__.o(exports, name)) {
|
||
/******/ Object.defineProperty(exports, name, {
|
||
/******/ configurable: false,
|
||
/******/ enumerable: true,
|
||
/******/ get: getter
|
||
/******/ });
|
||
/******/ }
|
||
/******/ };
|
||
/******/
|
||
/******/ // getDefaultExport function for compatibility with non-harmony modules
|
||
/******/ __webpack_require__.n = function(module) {
|
||
/******/ var getter = module && module.__esModule ?
|
||
/******/ function getDefault() { return module['default']; } :
|
||
/******/ function getModuleExports() { return module; };
|
||
/******/ __webpack_require__.d(getter, 'a', getter);
|
||
/******/ return getter;
|
||
/******/ };
|
||
/******/
|
||
/******/ // Object.prototype.hasOwnProperty.call
|
||
/******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
|
||
/******/
|
||
/******/ // __webpack_public_path__
|
||
/******/ __webpack_require__.p = "";
|
||
/******/
|
||
/******/ // Load entry module and return exports
|
||
/******/ return __webpack_require__(__webpack_require__.s = 22);
|
||
/******/ })
|
||
/************************************************************************/
|
||
/******/ ([
|
||
/* 0 */
|
||
/***/ (function(module, exports) {
|
||
|
||
module.exports = __WEBPACK_EXTERNAL_MODULE_0__;
|
||
|
||
/***/ }),
|
||
/* 1 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
/**
|
||
* Copyright (c) 2013-present, Facebook, Inc.
|
||
*
|
||
* This source code is licensed under the MIT license found in the
|
||
* LICENSE file in the root directory of this source tree.
|
||
*/
|
||
|
||
if (false) {
|
||
var ReactIs = require('react-is');
|
||
|
||
// By explicitly using `prop-types` you are opting into new development behavior.
|
||
// http://fb.me/prop-types-in-prod
|
||
var throwOnDirectAccess = true;
|
||
module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);
|
||
} else {
|
||
// By explicitly using `prop-types` you are opting into new production behavior.
|
||
// http://fb.me/prop-types-in-prod
|
||
module.exports = __webpack_require__(24)();
|
||
}
|
||
|
||
|
||
/***/ }),
|
||
/* 2 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _underscore = __webpack_require__(30);
|
||
|
||
var _underscore2 = _interopRequireDefault(_underscore);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function splitNested(str) {
|
||
return [str].join('.').replace(/\[/g, '.').replace(/\]/g, '').split('.');
|
||
} /* eslint no-empty: 0 */
|
||
/* eslint no-param-reassign: 0 */
|
||
/* eslint prefer-rest-params: 0 */
|
||
|
||
|
||
function get(target, field) {
|
||
var pathArray = splitNested(field);
|
||
var result = void 0;
|
||
try {
|
||
result = pathArray.reduce(function (curr, path) {
|
||
return curr[path];
|
||
}, target);
|
||
} catch (e) {}
|
||
return result;
|
||
}
|
||
|
||
function set(target, field, value) {
|
||
var safe = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false;
|
||
|
||
var pathArray = splitNested(field);
|
||
var level = 0;
|
||
pathArray.reduce(function (a, b) {
|
||
level += 1;
|
||
if (typeof a[b] === 'undefined') {
|
||
if (!safe) throw new Error(a + '.' + b + ' is undefined');
|
||
a[b] = {};
|
||
return a[b];
|
||
}
|
||
|
||
if (level === pathArray.length) {
|
||
a[b] = value;
|
||
return value;
|
||
}
|
||
return a[b];
|
||
}, target);
|
||
}
|
||
|
||
function isEmptyObject(obj) {
|
||
if (!_underscore2.default.isObject(obj)) return false;
|
||
|
||
var hasOwnProperty = Object.prototype.hasOwnProperty;
|
||
var keys = Object.keys(obj);
|
||
|
||
for (var i = 0; i < keys.length; i += 1) {
|
||
if (hasOwnProperty.call(obj, keys[i])) return false;
|
||
}
|
||
|
||
return true;
|
||
}
|
||
|
||
function isDefined(value) {
|
||
return typeof value !== 'undefined' && value !== null;
|
||
}
|
||
|
||
function sleep(fn, ms) {
|
||
return setTimeout(function () {
|
||
return fn();
|
||
}, ms);
|
||
}
|
||
|
||
function debounce(func, wait, immediate) {
|
||
var _this = this,
|
||
_arguments = arguments;
|
||
|
||
var timeout = void 0;
|
||
|
||
return function () {
|
||
var later = function later() {
|
||
timeout = null;
|
||
|
||
if (!immediate) {
|
||
func.apply(_this, _arguments);
|
||
}
|
||
};
|
||
|
||
var callNow = immediate && !timeout;
|
||
|
||
clearTimeout(timeout);
|
||
timeout = setTimeout(later, wait || 0);
|
||
|
||
if (callNow) {
|
||
func.apply(_this, _arguments);
|
||
}
|
||
};
|
||
}
|
||
|
||
exports.default = Object.assign(_underscore2.default, { get: get, set: set, isDefined: isDefined, isEmptyObject: isEmptyObject, sleep: sleep, debounce: debounce });
|
||
|
||
/***/ }),
|
||
/* 3 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.default = {
|
||
SORT_ASC: 'asc',
|
||
SORT_DESC: 'desc',
|
||
ROW_SELECT_SINGLE: 'radio',
|
||
ROW_SELECT_MULTIPLE: 'checkbox',
|
||
ROW_SELECT_DISABLED: 'ROW_SELECT_DISABLED',
|
||
CHECKBOX_STATUS_CHECKED: 'checked',
|
||
CHECKBOX_STATUS_INDETERMINATE: 'indeterminate',
|
||
CHECKBOX_STATUS_UNCHECKED: 'unchecked',
|
||
INDICATOR_POSITION_LEFT: 'left',
|
||
INDICATOR_POSITION_RIGHT: 'right',
|
||
TYPE_STRING: 'string',
|
||
TYPE_NUMBER: 'number',
|
||
TYPE_BOOLEAN: 'bool',
|
||
TYPE_DATE: 'date',
|
||
FILTERS_POSITION_INLINE: 'inline',
|
||
FILTERS_POSITION_TOP: 'top',
|
||
FILTERS_POSITION_BOTTOM: 'bottom'
|
||
};
|
||
|
||
/***/ }),
|
||
/* 4 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*!
|
||
Copyright (c) 2016 Jed Watson.
|
||
Licensed under the MIT License (MIT), see
|
||
http://jedwatson.github.io/classnames
|
||
*/
|
||
/* global define */
|
||
|
||
(function () {
|
||
'use strict';
|
||
|
||
var hasOwn = {}.hasOwnProperty;
|
||
|
||
function classNames () {
|
||
var classes = [];
|
||
|
||
for (var i = 0; i < arguments.length; i++) {
|
||
var arg = arguments[i];
|
||
if (!arg) continue;
|
||
|
||
var argType = typeof arg;
|
||
|
||
if (argType === 'string' || argType === 'number') {
|
||
classes.push(arg);
|
||
} else if (Array.isArray(arg)) {
|
||
classes.push(classNames.apply(null, arg));
|
||
} else if (argType === 'object') {
|
||
for (var key in arg) {
|
||
if (hasOwn.call(arg, key) && arg[key]) {
|
||
classes.push(key);
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
return classes.join(' ');
|
||
}
|
||
|
||
if (typeof module !== 'undefined' && module.exports) {
|
||
module.exports = classNames;
|
||
} else if (true) {
|
||
// register as 'classnames', consistent with npm package name
|
||
!(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = function () {
|
||
return classNames;
|
||
}.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),
|
||
__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
|
||
} else {
|
||
window.classNames = classNames;
|
||
}
|
||
}());
|
||
|
||
|
||
/***/ }),
|
||
/* 5 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.BootstrapContext = undefined;
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var BootstrapContext = exports.BootstrapContext = _react2.default.createContext({
|
||
bootstrap4: false
|
||
});
|
||
|
||
/***/ }),
|
||
/* 6 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.getRowByRowId = exports.matchRow = undefined;
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var matchRow = exports.matchRow = function matchRow(keyField, id) {
|
||
return function (row) {
|
||
return _utils2.default.get(row, keyField) === id;
|
||
};
|
||
};
|
||
|
||
var getRowByRowId = exports.getRowByRowId = function getRowByRowId(data, keyField, id) {
|
||
return data.find(matchRow(keyField, id));
|
||
};
|
||
|
||
/***/ }),
|
||
/* 7 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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 events = ['onClick', 'onDoubleClick', 'onMouseEnter', 'onMouseLeave', 'onContextMenu'];
|
||
|
||
exports.default = function (ExtendBase) {
|
||
return function (_ExtendBase) {
|
||
_inherits(CellEventDelegater, _ExtendBase);
|
||
|
||
function CellEventDelegater(props) {
|
||
_classCallCheck(this, CellEventDelegater);
|
||
|
||
var _this = _possibleConstructorReturn(this, (CellEventDelegater.__proto__ || Object.getPrototypeOf(CellEventDelegater)).call(this, props));
|
||
|
||
_this.createDefaultEventHandler = _this.createDefaultEventHandler.bind(_this);
|
||
return _this;
|
||
}
|
||
|
||
_createClass(CellEventDelegater, [{
|
||
key: 'createDefaultEventHandler',
|
||
value: function createDefaultEventHandler(cb) {
|
||
var _this2 = this;
|
||
|
||
return function (e) {
|
||
var _props = _this2.props,
|
||
column = _props.column,
|
||
columnIndex = _props.columnIndex,
|
||
index = _props.index;
|
||
|
||
cb(e, column, typeof columnIndex !== 'undefined' ? columnIndex : index);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'delegate',
|
||
value: function delegate() {
|
||
var _this3 = this;
|
||
|
||
var attrs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
||
|
||
var newAttrs = _extends({}, attrs);
|
||
Object.keys(attrs).forEach(function (attr) {
|
||
if (_utils2.default.contains(events, attr)) {
|
||
newAttrs[attr] = _this3.createDefaultEventHandler(attrs[attr]);
|
||
}
|
||
});
|
||
return newAttrs;
|
||
}
|
||
}]);
|
||
|
||
return CellEventDelegater;
|
||
}(ExtendBase);
|
||
};
|
||
|
||
/***/ }),
|
||
/* 8 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _operators = __webpack_require__(9);
|
||
|
||
var _operators2 = _interopRequireDefault(_operators);
|
||
|
||
var _selection = __webpack_require__(11);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
|
||
|
||
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; } /* eslint camelcase: 0 */
|
||
/* eslint react/prop-types: 0 */
|
||
|
||
|
||
var SelectionContext = _react2.default.createContext();
|
||
|
||
var SelectionProvider = function (_React$Component) {
|
||
_inherits(SelectionProvider, _React$Component);
|
||
|
||
function SelectionProvider(props) {
|
||
_classCallCheck(this, SelectionProvider);
|
||
|
||
var _this = _possibleConstructorReturn(this, (SelectionProvider.__proto__ || Object.getPrototypeOf(SelectionProvider)).call(this, props));
|
||
|
||
_this.handleRowSelect = function (rowKey, checked, rowIndex, e) {
|
||
var _this$props = _this.props,
|
||
data = _this$props.data,
|
||
keyField = _this$props.keyField,
|
||
_this$props$selectRow = _this$props.selectRow,
|
||
mode = _this$props$selectRow.mode,
|
||
onSelect = _this$props$selectRow.onSelect;
|
||
var ROW_SELECT_SINGLE = _const2.default.ROW_SELECT_SINGLE;
|
||
|
||
|
||
var currSelected = [].concat(_toConsumableArray(_this.selected));
|
||
|
||
var result = true;
|
||
if (onSelect) {
|
||
var row = _operators2.default.getRowByRowId(data, keyField, rowKey);
|
||
result = onSelect(row, checked, rowIndex, e);
|
||
}
|
||
|
||
if (result === true || result === undefined) {
|
||
if (mode === ROW_SELECT_SINGLE) {
|
||
// when select mode is radio
|
||
currSelected = [rowKey];
|
||
} else if (checked) {
|
||
// when select mode is checkbox
|
||
currSelected.push(rowKey);
|
||
} else {
|
||
currSelected = currSelected.filter(function (value) {
|
||
return value !== rowKey;
|
||
});
|
||
}
|
||
}
|
||
_this.selected = currSelected;
|
||
_this.forceUpdate();
|
||
};
|
||
|
||
_this.handleAllRowsSelect = function (e, isUnSelect) {
|
||
var _this$props2 = _this.props,
|
||
data = _this$props2.data,
|
||
keyField = _this$props2.keyField,
|
||
_this$props2$selectRo = _this$props2.selectRow,
|
||
onSelectAll = _this$props2$selectRo.onSelectAll,
|
||
nonSelectable = _this$props2$selectRo.nonSelectable;
|
||
var selected = _this.selected;
|
||
|
||
|
||
var currSelected = void 0;
|
||
|
||
if (!isUnSelect) {
|
||
currSelected = selected.concat(_operators2.default.selectableKeys(data, keyField, nonSelectable));
|
||
} else {
|
||
currSelected = selected.filter(function (s) {
|
||
return typeof data.find(function (d) {
|
||
return _utils2.default.get(d, keyField) === s;
|
||
}) === 'undefined';
|
||
});
|
||
}
|
||
|
||
var result = void 0;
|
||
if (onSelectAll) {
|
||
result = onSelectAll(!isUnSelect, _operators2.default.getSelectedRows(data, keyField, isUnSelect ? selected : currSelected), e);
|
||
if (Array.isArray(result)) {
|
||
currSelected = result;
|
||
}
|
||
}
|
||
_this.selected = currSelected;
|
||
_this.forceUpdate();
|
||
};
|
||
|
||
_this.selected = props.selectRow.selected || [];
|
||
return _this;
|
||
}
|
||
|
||
// exposed API
|
||
|
||
|
||
_createClass(SelectionProvider, [{
|
||
key: 'getSelected',
|
||
value: function getSelected() {
|
||
return this.selected;
|
||
}
|
||
}, {
|
||
key: 'UNSAFE_componentWillReceiveProps',
|
||
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
||
if (nextProps.selectRow) {
|
||
this.selected = nextProps.selectRow.selected || this.selected;
|
||
}
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _getSelectionSummary = (0, _selection.getSelectionSummary)(this.props.data, this.props.keyField, this.selected),
|
||
allRowsSelected = _getSelectionSummary.allRowsSelected,
|
||
allRowsNotSelected = _getSelectionSummary.allRowsNotSelected;
|
||
|
||
var checkedStatus = void 0;
|
||
|
||
// checkbox status depending on selected rows counts
|
||
if (allRowsSelected) checkedStatus = _const2.default.CHECKBOX_STATUS_CHECKED;else if (allRowsNotSelected) checkedStatus = _const2.default.CHECKBOX_STATUS_UNCHECKED;else checkedStatus = _const2.default.CHECKBOX_STATUS_INDETERMINATE;
|
||
|
||
return _react2.default.createElement(
|
||
SelectionContext.Provider,
|
||
{
|
||
value: _extends({}, this.props.selectRow, {
|
||
selected: this.selected,
|
||
onRowSelect: this.handleRowSelect,
|
||
onAllRowsSelect: this.handleAllRowsSelect,
|
||
allRowsSelected: allRowsSelected,
|
||
allRowsNotSelected: allRowsNotSelected,
|
||
checkedStatus: checkedStatus
|
||
})
|
||
},
|
||
this.props.children
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return SelectionProvider;
|
||
}(_react2.default.Component);
|
||
|
||
SelectionProvider.propTypes = {
|
||
children: _propTypes2.default.node.isRequired,
|
||
data: _propTypes2.default.array.isRequired,
|
||
keyField: _propTypes2.default.string.isRequired
|
||
};
|
||
exports.default = {
|
||
Provider: SelectionProvider,
|
||
Consumer: SelectionContext.Consumer
|
||
};
|
||
|
||
/***/ }),
|
||
/* 9 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _rows = __webpack_require__(6);
|
||
|
||
var rows = _interopRequireWildcard(_rows);
|
||
|
||
var _selection = __webpack_require__(11);
|
||
|
||
var selection = _interopRequireWildcard(_selection);
|
||
|
||
var _expand = __webpack_require__(36);
|
||
|
||
var expand = _interopRequireWildcard(_expand);
|
||
|
||
var _mutate = __webpack_require__(37);
|
||
|
||
var mutate = _interopRequireWildcard(_mutate);
|
||
|
||
var _sort = __webpack_require__(38);
|
||
|
||
var sort = _interopRequireWildcard(_sort);
|
||
|
||
var _type = __webpack_require__(39);
|
||
|
||
var type = _interopRequireWildcard(_type);
|
||
|
||
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) newObj[key] = obj[key]; } } newObj.default = obj; return newObj; } }
|
||
|
||
exports.default = _extends({}, rows, selection, expand, mutate, sort, type);
|
||
|
||
/***/ }),
|
||
/* 10 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _operators = __webpack_require__(9);
|
||
|
||
var _operators2 = _interopRequireDefault(_operators);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } }
|
||
|
||
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; } /* eslint camelcase: 0 */
|
||
/* eslint react/prop-types: 0 */
|
||
|
||
|
||
var RowExpandContext = _react2.default.createContext();
|
||
|
||
var RowExpandProvider = function (_React$Component) {
|
||
_inherits(RowExpandProvider, _React$Component);
|
||
|
||
function RowExpandProvider() {
|
||
var _ref;
|
||
|
||
var _temp, _this, _ret;
|
||
|
||
_classCallCheck(this, RowExpandProvider);
|
||
|
||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
|
||
args[_key] = arguments[_key];
|
||
}
|
||
|
||
return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = RowExpandProvider.__proto__ || Object.getPrototypeOf(RowExpandProvider)).call.apply(_ref, [this].concat(args))), _this), _this.state = { expanded: _this.props.expandRow.expanded || [],
|
||
isClosing: _this.props.expandRow.isClosing || [] }, _this.onClosed = function (closedRow) {
|
||
_this.setState({ isClosing: _this.state.isClosing.filter(function (value) {
|
||
return value !== closedRow;
|
||
}) });
|
||
}, _this.handleRowExpand = function (rowKey, expanded, rowIndex, e) {
|
||
var _this$props = _this.props,
|
||
data = _this$props.data,
|
||
keyField = _this$props.keyField,
|
||
_this$props$expandRow = _this$props.expandRow,
|
||
onExpand = _this$props$expandRow.onExpand,
|
||
onlyOneExpanding = _this$props$expandRow.onlyOneExpanding,
|
||
nonExpandable = _this$props$expandRow.nonExpandable;
|
||
|
||
if (nonExpandable && _utils2.default.contains(nonExpandable, rowKey)) {
|
||
return;
|
||
}
|
||
|
||
var currExpanded = [].concat(_toConsumableArray(_this.state.expanded));
|
||
var isClosing = [].concat(_toConsumableArray(_this.state.isClosing));
|
||
|
||
if (expanded) {
|
||
if (onlyOneExpanding) {
|
||
isClosing = isClosing.concat(currExpanded);
|
||
currExpanded = [rowKey];
|
||
} else currExpanded.push(rowKey);
|
||
} else {
|
||
isClosing.push(rowKey);
|
||
currExpanded = currExpanded.filter(function (value) {
|
||
return value !== rowKey;
|
||
});
|
||
}
|
||
|
||
if (onExpand) {
|
||
var row = _operators2.default.getRowByRowId(data, keyField, rowKey);
|
||
onExpand(row, expanded, rowIndex, e);
|
||
}
|
||
_this.setState(function () {
|
||
return { expanded: currExpanded, isClosing: isClosing };
|
||
});
|
||
}, _this.handleAllRowExpand = function (e, expandAll) {
|
||
var _this$props2 = _this.props,
|
||
data = _this$props2.data,
|
||
keyField = _this$props2.keyField,
|
||
_this$props2$expandRo = _this$props2.expandRow,
|
||
onExpandAll = _this$props2$expandRo.onExpandAll,
|
||
nonExpandable = _this$props2$expandRo.nonExpandable;
|
||
var expanded = _this.state.expanded;
|
||
|
||
|
||
var currExpanded = void 0;
|
||
|
||
if (expandAll) {
|
||
currExpanded = expanded.concat(_operators2.default.expandableKeys(data, keyField, nonExpandable));
|
||
} else {
|
||
currExpanded = expanded.filter(function (s) {
|
||
return typeof data.find(function (d) {
|
||
return _utils2.default.get(d, keyField) === s;
|
||
}) === 'undefined';
|
||
});
|
||
}
|
||
|
||
if (onExpandAll) {
|
||
onExpandAll(expandAll, _operators2.default.getExpandedRows(data, keyField, currExpanded), e);
|
||
}
|
||
|
||
_this.setState(function () {
|
||
return { expanded: currExpanded };
|
||
});
|
||
}, _temp), _possibleConstructorReturn(_this, _ret);
|
||
}
|
||
|
||
_createClass(RowExpandProvider, [{
|
||
key: 'UNSAFE_componentWillReceiveProps',
|
||
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
||
var _this2 = this;
|
||
|
||
if (nextProps.expandRow) {
|
||
var nextExpanded = nextProps.expandRow.expanded || this.state.expanded;
|
||
var isClosing = this.state.expanded.reduce(function (acc, cur) {
|
||
if (!_utils2.default.contains(nextExpanded, cur)) {
|
||
acc.push(cur);
|
||
}
|
||
return acc;
|
||
}, []);
|
||
this.setState(function () {
|
||
return {
|
||
expanded: nextExpanded,
|
||
isClosing: isClosing
|
||
};
|
||
});
|
||
} else {
|
||
this.setState(function () {
|
||
return {
|
||
expanded: _this2.state.expanded
|
||
};
|
||
});
|
||
}
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
data = _props.data,
|
||
keyField = _props.keyField;
|
||
|
||
return _react2.default.createElement(
|
||
RowExpandContext.Provider,
|
||
{
|
||
value: _extends({}, this.props.expandRow, {
|
||
nonExpandable: this.props.expandRow.nonExpandable,
|
||
expanded: this.state.expanded,
|
||
isClosing: this.state.isClosing,
|
||
onClosed: this.onClosed,
|
||
isAnyExpands: _operators2.default.isAnyExpands(data, keyField, this.state.expanded),
|
||
onRowExpand: this.handleRowExpand,
|
||
onAllRowExpand: this.handleAllRowExpand
|
||
})
|
||
},
|
||
this.props.children
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return RowExpandProvider;
|
||
}(_react2.default.Component);
|
||
|
||
RowExpandProvider.propTypes = {
|
||
children: _propTypes2.default.node.isRequired,
|
||
data: _propTypes2.default.array.isRequired,
|
||
keyField: _propTypes2.default.string.isRequired
|
||
};
|
||
exports.default = {
|
||
Provider: RowExpandProvider,
|
||
Consumer: RowExpandContext.Consumer
|
||
};
|
||
|
||
/***/ }),
|
||
/* 11 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.getSelectedRows = exports.unSelectableKeys = exports.selectableKeys = exports.getSelectionSummary = undefined;
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _rows = __webpack_require__(6);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var getSelectionSummary = exports.getSelectionSummary = function getSelectionSummary() {
|
||
var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
||
var keyField = arguments[1];
|
||
var selected = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
||
|
||
var allRowsSelected = data.length > 0;
|
||
var allRowsNotSelected = true;
|
||
|
||
var rowKeys = data.map(function (d) {
|
||
return _utils2.default.get(d, keyField);
|
||
});
|
||
|
||
var _loop = function _loop(i) {
|
||
var curr = rowKeys[i];
|
||
if (typeof selected.find(function (x) {
|
||
return x === curr;
|
||
}) === 'undefined') {
|
||
allRowsSelected = false;
|
||
} else {
|
||
allRowsNotSelected = false;
|
||
}
|
||
};
|
||
|
||
for (var i = 0; i < rowKeys.length; i += 1) {
|
||
_loop(i);
|
||
}
|
||
return {
|
||
allRowsSelected: allRowsSelected,
|
||
allRowsNotSelected: allRowsNotSelected
|
||
};
|
||
};
|
||
|
||
var selectableKeys = exports.selectableKeys = function selectableKeys() {
|
||
var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
||
var keyField = arguments[1];
|
||
var skips = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
||
|
||
if (skips.length === 0) {
|
||
return data.map(function (row) {
|
||
return _utils2.default.get(row, keyField);
|
||
});
|
||
}
|
||
return data.filter(function (row) {
|
||
return !_utils2.default.contains(skips, _utils2.default.get(row, keyField));
|
||
}).map(function (row) {
|
||
return _utils2.default.get(row, keyField);
|
||
});
|
||
};
|
||
|
||
var unSelectableKeys = exports.unSelectableKeys = function unSelectableKeys(selected) {
|
||
var skips = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : [];
|
||
|
||
if (skips.length === 0) {
|
||
return [];
|
||
}
|
||
return selected.filter(function (x) {
|
||
return _utils2.default.contains(skips, x);
|
||
});
|
||
};
|
||
|
||
var getSelectedRows = exports.getSelectedRows = function getSelectedRows() {
|
||
var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
|
||
var keyField = arguments[1];
|
||
var selected = arguments[2];
|
||
return selected.map(function (k) {
|
||
return (0, _rows.getRowByRowId)(data, keyField, k);
|
||
}).filter(function (x) {
|
||
return !!x;
|
||
});
|
||
};
|
||
|
||
/***/ }),
|
||
/* 12 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/require-default-props: 0 */
|
||
|
||
|
||
var RowTemplate = function RowTemplate(props) {
|
||
var renderContent = props.renderContent,
|
||
selectRow = props.selectRow,
|
||
expandRow = props.expandRow,
|
||
cellEl = props.cellEl,
|
||
rest = _objectWithoutProperties(props, ['renderContent', 'selectRow', 'expandRow', 'cellEl']);
|
||
|
||
var isRenderFunctionColumnInLeft = function isRenderFunctionColumnInLeft() {
|
||
var position = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _const2.default.INDICATOR_POSITION_LEFT;
|
||
return position === _const2.default.INDICATOR_POSITION_LEFT;
|
||
};
|
||
|
||
var childrens = renderContent() || [];
|
||
|
||
if (selectRow && selectRow.hideSelectColumn !== true) {
|
||
if (isRenderFunctionColumnInLeft(selectRow.selectColumnPosition)) {
|
||
childrens.unshift(_react2.default.createElement(cellEl, { key: 'selection' }));
|
||
} else {
|
||
childrens.push(_react2.default.createElement(cellEl, { key: 'selection' }));
|
||
}
|
||
}
|
||
|
||
if (expandRow.showExpandColumn) {
|
||
if (isRenderFunctionColumnInLeft(expandRow.expandColumnPosition)) {
|
||
childrens.unshift(_react2.default.createElement(cellEl, { key: 'expansion' }));
|
||
} else {
|
||
childrens.push(_react2.default.createElement(cellEl, { key: 'expansion' }));
|
||
}
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
'tr',
|
||
rest,
|
||
childrens
|
||
);
|
||
};
|
||
|
||
RowTemplate.propTypes = {
|
||
renderContent: _propTypes2.default.func.isRequired,
|
||
cellEl: _propTypes2.default.string.isRequired,
|
||
selectRow: _propTypes2.default.object,
|
||
expandRow: _propTypes2.default.object
|
||
};
|
||
|
||
exports.default = RowTemplate;
|
||
|
||
/***/ }),
|
||
/* 13 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _cell = __webpack_require__(46);
|
||
|
||
var _cell2 = _interopRequireDefault(_cell);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/prop-types: 0 */
|
||
/* eslint react/no-array-index-key: 0 */
|
||
/* eslint no-plusplus: 0 */
|
||
|
||
|
||
var RowPureContent = function (_React$Component) {
|
||
_inherits(RowPureContent, _React$Component);
|
||
|
||
function RowPureContent() {
|
||
_classCallCheck(this, RowPureContent);
|
||
|
||
return _possibleConstructorReturn(this, (RowPureContent.__proto__ || Object.getPrototypeOf(RowPureContent)).apply(this, arguments));
|
||
}
|
||
|
||
_createClass(RowPureContent, [{
|
||
key: 'shouldComponentUpdate',
|
||
value: function shouldComponentUpdate(nextProps) {
|
||
if (typeof nextProps.shouldUpdate !== 'undefined') {
|
||
return nextProps.shouldUpdate;
|
||
}
|
||
return true;
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
row = _props.row,
|
||
keyField = _props.keyField,
|
||
columns = _props.columns,
|
||
rowIndex = _props.rowIndex,
|
||
editable = _props.editable,
|
||
editingRowIdx = _props.editingRowIdx,
|
||
editingColIdx = _props.editingColIdx,
|
||
onStart = _props.onStart,
|
||
clickToEdit = _props.clickToEdit,
|
||
dbclickToEdit = _props.dbclickToEdit,
|
||
EditingCellComponent = _props.EditingCellComponent,
|
||
tabIndexStart = _props.tabIndexStart;
|
||
|
||
|
||
var tabIndex = tabIndexStart;
|
||
|
||
return columns.map(function (column, index) {
|
||
var dataField = column.dataField;
|
||
|
||
var content = _utils2.default.get(row, dataField);
|
||
if (rowIndex === editingRowIdx && index === editingColIdx) {
|
||
return _react2.default.createElement(EditingCellComponent, {
|
||
key: content + '-' + index + '-editing',
|
||
row: row,
|
||
rowIndex: rowIndex,
|
||
column: column,
|
||
columnIndex: index
|
||
});
|
||
}
|
||
// render cell
|
||
var cellTitle = void 0;
|
||
var cellStyle = {};
|
||
var cellAttrs = _extends({}, _utils2.default.isFunction(column.attrs) ? column.attrs(content, row, rowIndex, index) : column.attrs);
|
||
|
||
if (column.events) {
|
||
var events = Object.assign({}, column.events);
|
||
Object.keys(Object.assign({}, column.events)).forEach(function (key) {
|
||
var originFn = events[key];
|
||
events[key] = function () {
|
||
for (var _len = arguments.length, rest = Array(_len), _key = 0; _key < _len; _key++) {
|
||
rest[_key] = arguments[_key];
|
||
}
|
||
|
||
return originFn.apply(undefined, rest.concat([row, rowIndex]));
|
||
};
|
||
});
|
||
cellAttrs = _extends({}, cellAttrs, events);
|
||
}
|
||
|
||
var cellClasses = _utils2.default.isFunction(column.classes) ? column.classes(content, row, rowIndex, index) : column.classes;
|
||
|
||
if (column.style) {
|
||
cellStyle = _utils2.default.isFunction(column.style) ? column.style(content, row, rowIndex, index) : column.style;
|
||
cellStyle = Object.assign({}, cellStyle) || {};
|
||
}
|
||
|
||
if (column.title) {
|
||
cellTitle = _utils2.default.isFunction(column.title) ? column.title(content, row, rowIndex, index) : content;
|
||
cellAttrs.title = cellTitle;
|
||
}
|
||
|
||
if (column.align) {
|
||
cellStyle.textAlign = _utils2.default.isFunction(column.align) ? column.align(content, row, rowIndex, index) : column.align;
|
||
}
|
||
|
||
if (cellClasses) cellAttrs.className = cellClasses;
|
||
if (!_utils2.default.isEmptyObject(cellStyle)) cellAttrs.style = cellStyle;
|
||
|
||
var editableCell = _utils2.default.isDefined(column.editable) ? column.editable : true;
|
||
if (column.dataField === keyField || !editable) editableCell = false;
|
||
if (_utils2.default.isFunction(column.editable)) {
|
||
editableCell = column.editable(content, row, rowIndex, index);
|
||
}
|
||
|
||
if (tabIndexStart !== -1) {
|
||
cellAttrs.tabIndex = tabIndex++;
|
||
}
|
||
|
||
return _react2.default.createElement(_cell2.default, _extends({
|
||
key: content + '-' + index,
|
||
row: row,
|
||
editable: editableCell,
|
||
rowIndex: rowIndex,
|
||
columnIndex: index,
|
||
column: column,
|
||
onStart: onStart,
|
||
clickToEdit: clickToEdit,
|
||
dbclickToEdit: dbclickToEdit
|
||
}, cellAttrs));
|
||
});
|
||
}
|
||
}]);
|
||
|
||
return RowPureContent;
|
||
}(_react2.default.Component);
|
||
|
||
exports.default = RowPureContent;
|
||
|
||
/***/ }),
|
||
/* 14 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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 events = ['onClick', 'onDoubleClick', 'onMouseEnter', 'onMouseLeave', 'onContextMenu'];
|
||
|
||
exports.default = function (ExtendBase) {
|
||
return function (_ExtendBase) {
|
||
_inherits(RowEventDelegater, _ExtendBase);
|
||
|
||
function RowEventDelegater(props) {
|
||
_classCallCheck(this, RowEventDelegater);
|
||
|
||
var _this = _possibleConstructorReturn(this, (RowEventDelegater.__proto__ || Object.getPrototypeOf(RowEventDelegater)).call(this, props));
|
||
|
||
_this.clickNum = 0;
|
||
_this.createDefaultEventHandler = _this.createDefaultEventHandler.bind(_this);
|
||
_this.createClickEventHandler = _this.createClickEventHandler.bind(_this);
|
||
return _this;
|
||
}
|
||
|
||
_createClass(RowEventDelegater, [{
|
||
key: 'createClickEventHandler',
|
||
value: function createClickEventHandler(cb) {
|
||
var _this2 = this;
|
||
|
||
return function (e) {
|
||
var _props = _this2.props,
|
||
row = _props.row,
|
||
selected = _props.selected,
|
||
keyField = _props.keyField,
|
||
selectable = _props.selectable,
|
||
expandable = _props.expandable,
|
||
rowIndex = _props.rowIndex,
|
||
expanded = _props.expanded,
|
||
expandRow = _props.expandRow,
|
||
selectRow = _props.selectRow,
|
||
DELAY_FOR_DBCLICK = _props.DELAY_FOR_DBCLICK;
|
||
|
||
var clickFn = function clickFn() {
|
||
if (cb) {
|
||
cb(e, row, rowIndex);
|
||
}
|
||
var key = _utils2.default.get(row, keyField);
|
||
if (expandRow && expandable && !expandRow.expandByColumnOnly) {
|
||
if (selectRow.mode !== _const2.default.ROW_SELECT_DISABLED && selectRow.clickToExpand || selectRow.mode === _const2.default.ROW_SELECT_DISABLED) {
|
||
expandRow.onRowExpand(key, !expanded, rowIndex, e);
|
||
}
|
||
}
|
||
if (selectRow.clickToSelect && selectable) {
|
||
selectRow.onRowSelect(key, !selected, rowIndex, e);
|
||
}
|
||
};
|
||
|
||
if (DELAY_FOR_DBCLICK) {
|
||
_this2.clickNum += 1;
|
||
_utils2.default.debounce(function () {
|
||
if (_this2.clickNum === 1) {
|
||
clickFn();
|
||
}
|
||
_this2.clickNum = 0;
|
||
}, DELAY_FOR_DBCLICK)();
|
||
} else {
|
||
clickFn();
|
||
}
|
||
};
|
||
}
|
||
}, {
|
||
key: 'createDefaultEventHandler',
|
||
value: function createDefaultEventHandler(cb) {
|
||
var _this3 = this;
|
||
|
||
return function (e) {
|
||
var _props2 = _this3.props,
|
||
row = _props2.row,
|
||
rowIndex = _props2.rowIndex;
|
||
|
||
cb(e, row, rowIndex);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'delegate',
|
||
value: function delegate() {
|
||
var _this4 = this;
|
||
|
||
var attrs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
||
|
||
var newAttrs = _extends({}, attrs);
|
||
Object.keys(attrs).forEach(function (attr) {
|
||
if (_utils2.default.contains(events, attr)) {
|
||
newAttrs[attr] = _this4.createDefaultEventHandler(attrs[attr]);
|
||
}
|
||
});
|
||
return newAttrs;
|
||
}
|
||
}]);
|
||
|
||
return RowEventDelegater;
|
||
}(ExtendBase);
|
||
};
|
||
|
||
/***/ }),
|
||
/* 15 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/prop-types: 0 */
|
||
|
||
|
||
exports.default = function (ExtendBase) {
|
||
return function (_ExtendBase) {
|
||
_inherits(RowShouldUpdater, _ExtendBase);
|
||
|
||
function RowShouldUpdater() {
|
||
_classCallCheck(this, RowShouldUpdater);
|
||
|
||
return _possibleConstructorReturn(this, (RowShouldUpdater.__proto__ || Object.getPrototypeOf(RowShouldUpdater)).apply(this, arguments));
|
||
}
|
||
|
||
_createClass(RowShouldUpdater, [{
|
||
key: 'shouldUpdateByCellEditing',
|
||
value: function shouldUpdateByCellEditing(nextProps) {
|
||
if (!(this.props.clickToEdit || this.props.dbclickToEdit)) return false;
|
||
return nextProps.editingRowIdx === nextProps.rowIndex || this.props.editingRowIdx === nextProps.rowIndex && nextProps.editingRowIdx === null || this.props.editingRowIdx === nextProps.rowIndex;
|
||
}
|
||
}, {
|
||
key: 'shouldUpdatedBySelfProps',
|
||
value: function shouldUpdatedBySelfProps(nextProps) {
|
||
return this.props.className !== nextProps.className || !_utils2.default.isEqual(this.props.style, nextProps.style) || !_utils2.default.isEqual(this.props.attrs, nextProps.attrs);
|
||
}
|
||
|
||
// Only use for simple-row
|
||
|
||
}, {
|
||
key: 'shouldUpdateByColumnsForSimpleCheck',
|
||
value: function shouldUpdateByColumnsForSimpleCheck(nextProps) {
|
||
if (this.props.columns.length !== nextProps.columns.length) {
|
||
return true;
|
||
}
|
||
for (var i = 0; i < this.props.columns.length; i += 1) {
|
||
if (!_utils2.default.isEqual(this.props.columns[i], nextProps.columns[i])) {
|
||
return true;
|
||
}
|
||
}
|
||
return false;
|
||
}
|
||
}, {
|
||
key: 'shouldUpdatedByNormalProps',
|
||
value: function shouldUpdatedByNormalProps(nextProps) {
|
||
var shouldUpdate = this.props.rowIndex !== nextProps.rowIndex || this.props.editable !== nextProps.editable || !_utils2.default.isEqual(this.props.row, nextProps.row) || this.props.columns.length !== nextProps.columns.length;
|
||
|
||
return shouldUpdate;
|
||
}
|
||
}, {
|
||
key: 'shouldUpdateChild',
|
||
value: function shouldUpdateChild(nextProps) {
|
||
return this.shouldUpdateByCellEditing(nextProps) || this.shouldUpdatedByNormalProps(nextProps);
|
||
}
|
||
}, {
|
||
key: 'shouldRowContentUpdate',
|
||
value: function shouldRowContentUpdate(nextProps) {
|
||
return this.shouldUpdateChild(nextProps) || this.shouldUpdateByColumnsForSimpleCheck(nextProps);
|
||
}
|
||
}]);
|
||
|
||
return RowShouldUpdater;
|
||
}(ExtendBase);
|
||
};
|
||
|
||
/***/ }),
|
||
/* 16 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
exports.__esModule = true;
|
||
exports.default = exports.EXITING = exports.ENTERED = exports.ENTERING = exports.EXITED = exports.UNMOUNTED = void 0;
|
||
|
||
var PropTypes = _interopRequireWildcard(__webpack_require__(1));
|
||
|
||
var _react = _interopRequireDefault(__webpack_require__(0));
|
||
|
||
var _reactDom = _interopRequireDefault(__webpack_require__(17));
|
||
|
||
var _reactLifecyclesCompat = __webpack_require__(18);
|
||
|
||
var _PropTypes = __webpack_require__(19);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
|
||
|
||
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
||
|
||
function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
|
||
|
||
var UNMOUNTED = 'unmounted';
|
||
exports.UNMOUNTED = UNMOUNTED;
|
||
var EXITED = 'exited';
|
||
exports.EXITED = EXITED;
|
||
var ENTERING = 'entering';
|
||
exports.ENTERING = ENTERING;
|
||
var ENTERED = 'entered';
|
||
exports.ENTERED = ENTERED;
|
||
var EXITING = 'exiting';
|
||
/**
|
||
* The Transition component lets you describe a transition from one component
|
||
* state to another _over time_ with a simple declarative API. Most commonly
|
||
* it's used to animate the mounting and unmounting of a component, but can also
|
||
* be used to describe in-place transition states as well.
|
||
*
|
||
* By default the `Transition` component does not alter the behavior of the
|
||
* component it renders, it only tracks "enter" and "exit" states for the components.
|
||
* It's up to you to give meaning and effect to those states. For example we can
|
||
* add styles to a component when it enters or exits:
|
||
*
|
||
* ```jsx
|
||
* import Transition from 'react-transition-group/Transition';
|
||
*
|
||
* const duration = 300;
|
||
*
|
||
* const defaultStyle = {
|
||
* transition: `opacity ${duration}ms ease-in-out`,
|
||
* opacity: 0,
|
||
* }
|
||
*
|
||
* const transitionStyles = {
|
||
* entering: { opacity: 0 },
|
||
* entered: { opacity: 1 },
|
||
* };
|
||
*
|
||
* const Fade = ({ in: inProp }) => (
|
||
* <Transition in={inProp} timeout={duration}>
|
||
* {(state) => (
|
||
* <div style={{
|
||
* ...defaultStyle,
|
||
* ...transitionStyles[state]
|
||
* }}>
|
||
* I'm a fade Transition!
|
||
* </div>
|
||
* )}
|
||
* </Transition>
|
||
* );
|
||
* ```
|
||
*
|
||
* As noted the `Transition` component doesn't _do_ anything by itself to its child component.
|
||
* What it does do is track transition states over time so you can update the
|
||
* component (such as by adding styles or classes) when it changes states.
|
||
*
|
||
* There are 4 main states a Transition can be in:
|
||
* - `'entering'`
|
||
* - `'entered'`
|
||
* - `'exiting'`
|
||
* - `'exited'`
|
||
*
|
||
* Transition state is toggled via the `in` prop. When `true` the component begins the
|
||
* "Enter" stage. During this stage, the component will shift from its current transition state,
|
||
* to `'entering'` for the duration of the transition and then to the `'entered'` stage once
|
||
* it's complete. Let's take the following example:
|
||
*
|
||
* ```jsx
|
||
* state = { in: false };
|
||
*
|
||
* toggleEnterState = () => {
|
||
* this.setState({ in: true });
|
||
* }
|
||
*
|
||
* render() {
|
||
* return (
|
||
* <div>
|
||
* <Transition in={this.state.in} timeout={500} />
|
||
* <button onClick={this.toggleEnterState}>Click to Enter</button>
|
||
* </div>
|
||
* );
|
||
* }
|
||
* ```
|
||
*
|
||
* When the button is clicked the component will shift to the `'entering'` state and
|
||
* stay there for 500ms (the value of `timeout`) before it finally switches to `'entered'`.
|
||
*
|
||
* When `in` is `false` the same thing happens except the state moves from `'exiting'` to `'exited'`.
|
||
*
|
||
* ## Timing
|
||
*
|
||
* Timing is often the trickiest part of animation, mistakes can result in slight delays
|
||
* that are hard to pin down. A common example is when you want to add an exit transition,
|
||
* you should set the desired final styles when the state is `'exiting'`. That's when the
|
||
* transition to those styles will start and, if you matched the `timeout` prop with the
|
||
* CSS Transition duration, it will end exactly when the state changes to `'exited'`.
|
||
*
|
||
* > **Note**: For simpler transitions the `Transition` component might be enough, but
|
||
* > take into account that it's platform-agnostic, while the `CSSTransition` component
|
||
* > [forces reflows](https://github.com/reactjs/react-transition-group/blob/5007303e729a74be66a21c3e2205e4916821524b/src/CSSTransition.js#L208-L215)
|
||
* > in order to make more complex transitions more predictable. For example, even though
|
||
* > classes `example-enter` and `example-enter-active` are applied immediately one after
|
||
* > another, you can still transition from one to the other because of the forced reflow
|
||
* > (read [this issue](https://github.com/reactjs/react-transition-group/issues/159#issuecomment-322761171)
|
||
* > for more info). Take this into account when choosing between `Transition` and
|
||
* > `CSSTransition`.
|
||
*/
|
||
|
||
exports.EXITING = EXITING;
|
||
|
||
var Transition =
|
||
/*#__PURE__*/
|
||
function (_React$Component) {
|
||
_inheritsLoose(Transition, _React$Component);
|
||
|
||
function Transition(props, context) {
|
||
var _this;
|
||
|
||
_this = _React$Component.call(this, props, context) || this;
|
||
var parentGroup = context.transitionGroup; // In the context of a TransitionGroup all enters are really appears
|
||
|
||
var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;
|
||
var initialStatus;
|
||
_this.appearStatus = null;
|
||
|
||
if (props.in) {
|
||
if (appear) {
|
||
initialStatus = EXITED;
|
||
_this.appearStatus = ENTERING;
|
||
} else {
|
||
initialStatus = ENTERED;
|
||
}
|
||
} else {
|
||
if (props.unmountOnExit || props.mountOnEnter) {
|
||
initialStatus = UNMOUNTED;
|
||
} else {
|
||
initialStatus = EXITED;
|
||
}
|
||
}
|
||
|
||
_this.state = {
|
||
status: initialStatus
|
||
};
|
||
_this.nextCallback = null;
|
||
return _this;
|
||
}
|
||
|
||
var _proto = Transition.prototype;
|
||
|
||
_proto.getChildContext = function getChildContext() {
|
||
return {
|
||
transitionGroup: null // allows for nested Transitions
|
||
|
||
};
|
||
};
|
||
|
||
Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {
|
||
var nextIn = _ref.in;
|
||
|
||
if (nextIn && prevState.status === UNMOUNTED) {
|
||
return {
|
||
status: EXITED
|
||
};
|
||
}
|
||
|
||
return null;
|
||
}; // getSnapshotBeforeUpdate(prevProps) {
|
||
// let nextStatus = null
|
||
// if (prevProps !== this.props) {
|
||
// const { status } = this.state
|
||
// if (this.props.in) {
|
||
// if (status !== ENTERING && status !== ENTERED) {
|
||
// nextStatus = ENTERING
|
||
// }
|
||
// } else {
|
||
// if (status === ENTERING || status === ENTERED) {
|
||
// nextStatus = EXITING
|
||
// }
|
||
// }
|
||
// }
|
||
// return { nextStatus }
|
||
// }
|
||
|
||
|
||
_proto.componentDidMount = function componentDidMount() {
|
||
this.updateStatus(true, this.appearStatus);
|
||
};
|
||
|
||
_proto.componentDidUpdate = function componentDidUpdate(prevProps) {
|
||
var nextStatus = null;
|
||
|
||
if (prevProps !== this.props) {
|
||
var status = this.state.status;
|
||
|
||
if (this.props.in) {
|
||
if (status !== ENTERING && status !== ENTERED) {
|
||
nextStatus = ENTERING;
|
||
}
|
||
} else {
|
||
if (status === ENTERING || status === ENTERED) {
|
||
nextStatus = EXITING;
|
||
}
|
||
}
|
||
}
|
||
|
||
this.updateStatus(false, nextStatus);
|
||
};
|
||
|
||
_proto.componentWillUnmount = function componentWillUnmount() {
|
||
this.cancelNextCallback();
|
||
};
|
||
|
||
_proto.getTimeouts = function getTimeouts() {
|
||
var timeout = this.props.timeout;
|
||
var exit, enter, appear;
|
||
exit = enter = appear = timeout;
|
||
|
||
if (timeout != null && typeof timeout !== 'number') {
|
||
exit = timeout.exit;
|
||
enter = timeout.enter;
|
||
appear = timeout.appear;
|
||
}
|
||
|
||
return {
|
||
exit: exit,
|
||
enter: enter,
|
||
appear: appear
|
||
};
|
||
};
|
||
|
||
_proto.updateStatus = function updateStatus(mounting, nextStatus) {
|
||
if (mounting === void 0) {
|
||
mounting = false;
|
||
}
|
||
|
||
if (nextStatus !== null) {
|
||
// nextStatus will always be ENTERING or EXITING.
|
||
this.cancelNextCallback();
|
||
|
||
var node = _reactDom.default.findDOMNode(this);
|
||
|
||
if (nextStatus === ENTERING) {
|
||
this.performEnter(node, mounting);
|
||
} else {
|
||
this.performExit(node);
|
||
}
|
||
} else if (this.props.unmountOnExit && this.state.status === EXITED) {
|
||
this.setState({
|
||
status: UNMOUNTED
|
||
});
|
||
}
|
||
};
|
||
|
||
_proto.performEnter = function performEnter(node, mounting) {
|
||
var _this2 = this;
|
||
|
||
var enter = this.props.enter;
|
||
var appearing = this.context.transitionGroup ? this.context.transitionGroup.isMounting : mounting;
|
||
var timeouts = this.getTimeouts(); // no enter animation skip right to ENTERED
|
||
// if we are mounting and running this it means appear _must_ be set
|
||
|
||
if (!mounting && !enter) {
|
||
this.safeSetState({
|
||
status: ENTERED
|
||
}, function () {
|
||
_this2.props.onEntered(node);
|
||
});
|
||
return;
|
||
}
|
||
|
||
this.props.onEnter(node, appearing);
|
||
this.safeSetState({
|
||
status: ENTERING
|
||
}, function () {
|
||
_this2.props.onEntering(node, appearing); // FIXME: appear timeout?
|
||
|
||
|
||
_this2.onTransitionEnd(node, timeouts.enter, function () {
|
||
_this2.safeSetState({
|
||
status: ENTERED
|
||
}, function () {
|
||
_this2.props.onEntered(node, appearing);
|
||
});
|
||
});
|
||
});
|
||
};
|
||
|
||
_proto.performExit = function performExit(node) {
|
||
var _this3 = this;
|
||
|
||
var exit = this.props.exit;
|
||
var timeouts = this.getTimeouts(); // no exit animation skip right to EXITED
|
||
|
||
if (!exit) {
|
||
this.safeSetState({
|
||
status: EXITED
|
||
}, function () {
|
||
_this3.props.onExited(node);
|
||
});
|
||
return;
|
||
}
|
||
|
||
this.props.onExit(node);
|
||
this.safeSetState({
|
||
status: EXITING
|
||
}, function () {
|
||
_this3.props.onExiting(node);
|
||
|
||
_this3.onTransitionEnd(node, timeouts.exit, function () {
|
||
_this3.safeSetState({
|
||
status: EXITED
|
||
}, function () {
|
||
_this3.props.onExited(node);
|
||
});
|
||
});
|
||
});
|
||
};
|
||
|
||
_proto.cancelNextCallback = function cancelNextCallback() {
|
||
if (this.nextCallback !== null) {
|
||
this.nextCallback.cancel();
|
||
this.nextCallback = null;
|
||
}
|
||
};
|
||
|
||
_proto.safeSetState = function safeSetState(nextState, callback) {
|
||
// This shouldn't be necessary, but there are weird race conditions with
|
||
// setState callbacks and unmounting in testing, so always make sure that
|
||
// we can cancel any pending setState callbacks after we unmount.
|
||
callback = this.setNextCallback(callback);
|
||
this.setState(nextState, callback);
|
||
};
|
||
|
||
_proto.setNextCallback = function setNextCallback(callback) {
|
||
var _this4 = this;
|
||
|
||
var active = true;
|
||
|
||
this.nextCallback = function (event) {
|
||
if (active) {
|
||
active = false;
|
||
_this4.nextCallback = null;
|
||
callback(event);
|
||
}
|
||
};
|
||
|
||
this.nextCallback.cancel = function () {
|
||
active = false;
|
||
};
|
||
|
||
return this.nextCallback;
|
||
};
|
||
|
||
_proto.onTransitionEnd = function onTransitionEnd(node, timeout, handler) {
|
||
this.setNextCallback(handler);
|
||
|
||
if (node) {
|
||
if (this.props.addEndListener) {
|
||
this.props.addEndListener(node, this.nextCallback);
|
||
}
|
||
|
||
if (timeout != null) {
|
||
setTimeout(this.nextCallback, timeout);
|
||
}
|
||
} else {
|
||
setTimeout(this.nextCallback, 0);
|
||
}
|
||
};
|
||
|
||
_proto.render = function render() {
|
||
var status = this.state.status;
|
||
|
||
if (status === UNMOUNTED) {
|
||
return null;
|
||
}
|
||
|
||
var _this$props = this.props,
|
||
children = _this$props.children,
|
||
childProps = _objectWithoutPropertiesLoose(_this$props, ["children"]); // filter props for Transtition
|
||
|
||
|
||
delete childProps.in;
|
||
delete childProps.mountOnEnter;
|
||
delete childProps.unmountOnExit;
|
||
delete childProps.appear;
|
||
delete childProps.enter;
|
||
delete childProps.exit;
|
||
delete childProps.timeout;
|
||
delete childProps.addEndListener;
|
||
delete childProps.onEnter;
|
||
delete childProps.onEntering;
|
||
delete childProps.onEntered;
|
||
delete childProps.onExit;
|
||
delete childProps.onExiting;
|
||
delete childProps.onExited;
|
||
|
||
if (typeof children === 'function') {
|
||
return children(status, childProps);
|
||
}
|
||
|
||
var child = _react.default.Children.only(children);
|
||
|
||
return _react.default.cloneElement(child, childProps);
|
||
};
|
||
|
||
return Transition;
|
||
}(_react.default.Component);
|
||
|
||
Transition.contextTypes = {
|
||
transitionGroup: PropTypes.object
|
||
};
|
||
Transition.childContextTypes = {
|
||
transitionGroup: function transitionGroup() {}
|
||
};
|
||
Transition.propTypes = false ? {
|
||
/**
|
||
* A `function` child can be used instead of a React element.
|
||
* This function is called with the current transition status
|
||
* ('entering', 'entered', 'exiting', 'exited', 'unmounted'), which can be used
|
||
* to apply context specific props to a component.
|
||
*
|
||
* ```jsx
|
||
* <Transition timeout={150}>
|
||
* {(status) => (
|
||
* <MyComponent className={`fade fade-${status}`} />
|
||
* )}
|
||
* </Transition>
|
||
* ```
|
||
*/
|
||
children: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]).isRequired,
|
||
|
||
/**
|
||
* Show the component; triggers the enter or exit states
|
||
*/
|
||
in: PropTypes.bool,
|
||
|
||
/**
|
||
* By default the child component is mounted immediately along with
|
||
* the parent `Transition` component. If you want to "lazy mount" the component on the
|
||
* first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay
|
||
* mounted, even on "exited", unless you also specify `unmountOnExit`.
|
||
*/
|
||
mountOnEnter: PropTypes.bool,
|
||
|
||
/**
|
||
* By default the child component stays mounted after it reaches the `'exited'` state.
|
||
* Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.
|
||
*/
|
||
unmountOnExit: PropTypes.bool,
|
||
|
||
/**
|
||
* Normally a component is not transitioned if it is shown when the `<Transition>` component mounts.
|
||
* If you want to transition on the first mount set `appear` to `true`, and the
|
||
* component will transition in as soon as the `<Transition>` mounts.
|
||
*
|
||
* > Note: there are no specific "appear" states. `appear` only adds an additional `enter` transition.
|
||
*/
|
||
appear: PropTypes.bool,
|
||
|
||
/**
|
||
* Enable or disable enter transitions.
|
||
*/
|
||
enter: PropTypes.bool,
|
||
|
||
/**
|
||
* Enable or disable exit transitions.
|
||
*/
|
||
exit: PropTypes.bool,
|
||
|
||
/**
|
||
* The duration of the transition, in milliseconds.
|
||
* Required unless `addEndListener` is provided
|
||
*
|
||
* You may specify a single timeout for all transitions like: `timeout={500}`,
|
||
* or individually like:
|
||
*
|
||
* ```jsx
|
||
* timeout={{
|
||
* enter: 300,
|
||
* exit: 500,
|
||
* }}
|
||
* ```
|
||
*
|
||
* @type {number | { enter?: number, exit?: number }}
|
||
*/
|
||
timeout: function timeout(props) {
|
||
var pt = process.env.NODE_ENV !== "production" ? _PropTypes.timeoutsShape : {};;
|
||
if (!props.addEndListener) pt = pt.isRequired;
|
||
|
||
for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
|
||
args[_key - 1] = arguments[_key];
|
||
}
|
||
|
||
return pt.apply(void 0, [props].concat(args));
|
||
},
|
||
|
||
/**
|
||
* Add a custom transition end trigger. Called with the transitioning
|
||
* DOM node and a `done` callback. Allows for more fine grained transition end
|
||
* logic. **Note:** Timeouts are still used as a fallback if provided.
|
||
*
|
||
* ```jsx
|
||
* addEndListener={(node, done) => {
|
||
* // use the css transitionend event to mark the finish of a transition
|
||
* node.addEventListener('transitionend', done, false);
|
||
* }}
|
||
* ```
|
||
*/
|
||
addEndListener: PropTypes.func,
|
||
|
||
/**
|
||
* Callback fired before the "entering" status is applied. An extra parameter
|
||
* `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount
|
||
*
|
||
* @type Function(node: HtmlElement, isAppearing: bool) -> void
|
||
*/
|
||
onEnter: PropTypes.func,
|
||
|
||
/**
|
||
* Callback fired after the "entering" status is applied. An extra parameter
|
||
* `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount
|
||
*
|
||
* @type Function(node: HtmlElement, isAppearing: bool)
|
||
*/
|
||
onEntering: PropTypes.func,
|
||
|
||
/**
|
||
* Callback fired after the "entered" status is applied. An extra parameter
|
||
* `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount
|
||
*
|
||
* @type Function(node: HtmlElement, isAppearing: bool) -> void
|
||
*/
|
||
onEntered: PropTypes.func,
|
||
|
||
/**
|
||
* Callback fired before the "exiting" status is applied.
|
||
*
|
||
* @type Function(node: HtmlElement) -> void
|
||
*/
|
||
onExit: PropTypes.func,
|
||
|
||
/**
|
||
* Callback fired after the "exiting" status is applied.
|
||
*
|
||
* @type Function(node: HtmlElement) -> void
|
||
*/
|
||
onExiting: PropTypes.func,
|
||
|
||
/**
|
||
* Callback fired after the "exited" status is applied.
|
||
*
|
||
* @type Function(node: HtmlElement) -> void
|
||
*/
|
||
onExited: PropTypes.func // Name the function so it is clearer in the documentation
|
||
|
||
} : {};
|
||
|
||
function noop() {}
|
||
|
||
Transition.defaultProps = {
|
||
in: false,
|
||
mountOnEnter: false,
|
||
unmountOnExit: false,
|
||
appear: false,
|
||
enter: true,
|
||
exit: true,
|
||
onEnter: noop,
|
||
onEntering: noop,
|
||
onEntered: noop,
|
||
onExit: noop,
|
||
onExiting: noop,
|
||
onExited: noop
|
||
};
|
||
Transition.UNMOUNTED = 0;
|
||
Transition.EXITED = 1;
|
||
Transition.ENTERING = 2;
|
||
Transition.ENTERED = 3;
|
||
Transition.EXITING = 4;
|
||
|
||
var _default = (0, _reactLifecyclesCompat.polyfill)(Transition);
|
||
|
||
exports.default = _default;
|
||
|
||
/***/ }),
|
||
/* 17 */
|
||
/***/ (function(module, exports) {
|
||
|
||
module.exports = __WEBPACK_EXTERNAL_MODULE_17__;
|
||
|
||
/***/ }),
|
||
/* 18 */
|
||
/***/ (function(module, __webpack_exports__, __webpack_require__) {
|
||
|
||
"use strict";
|
||
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
|
||
/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "polyfill", function() { return polyfill; });
|
||
/**
|
||
* Copyright (c) 2013-present, Facebook, Inc.
|
||
*
|
||
* This source code is licensed under the MIT license found in the
|
||
* LICENSE file in the root directory of this source tree.
|
||
*/
|
||
|
||
function componentWillMount() {
|
||
// Call this.constructor.gDSFP to support sub-classes.
|
||
var state = this.constructor.getDerivedStateFromProps(this.props, this.state);
|
||
if (state !== null && state !== undefined) {
|
||
this.setState(state);
|
||
}
|
||
}
|
||
|
||
function componentWillReceiveProps(nextProps) {
|
||
// Call this.constructor.gDSFP to support sub-classes.
|
||
// Use the setState() updater to ensure state isn't stale in certain edge cases.
|
||
function updater(prevState) {
|
||
var state = this.constructor.getDerivedStateFromProps(nextProps, prevState);
|
||
return state !== null && state !== undefined ? state : null;
|
||
}
|
||
// Binding "this" is important for shallow renderer support.
|
||
this.setState(updater.bind(this));
|
||
}
|
||
|
||
function componentWillUpdate(nextProps, nextState) {
|
||
try {
|
||
var prevProps = this.props;
|
||
var prevState = this.state;
|
||
this.props = nextProps;
|
||
this.state = nextState;
|
||
this.__reactInternalSnapshotFlag = true;
|
||
this.__reactInternalSnapshot = this.getSnapshotBeforeUpdate(
|
||
prevProps,
|
||
prevState
|
||
);
|
||
} finally {
|
||
this.props = prevProps;
|
||
this.state = prevState;
|
||
}
|
||
}
|
||
|
||
// React may warn about cWM/cWRP/cWU methods being deprecated.
|
||
// Add a flag to suppress these warnings for this special case.
|
||
componentWillMount.__suppressDeprecationWarning = true;
|
||
componentWillReceiveProps.__suppressDeprecationWarning = true;
|
||
componentWillUpdate.__suppressDeprecationWarning = true;
|
||
|
||
function polyfill(Component) {
|
||
var prototype = Component.prototype;
|
||
|
||
if (!prototype || !prototype.isReactComponent) {
|
||
throw new Error('Can only polyfill class components');
|
||
}
|
||
|
||
if (
|
||
typeof Component.getDerivedStateFromProps !== 'function' &&
|
||
typeof prototype.getSnapshotBeforeUpdate !== 'function'
|
||
) {
|
||
return Component;
|
||
}
|
||
|
||
// If new component APIs are defined, "unsafe" lifecycles won't be called.
|
||
// Error if any of these lifecycles are present,
|
||
// Because they would work differently between older and newer (16.3+) versions of React.
|
||
var foundWillMountName = null;
|
||
var foundWillReceivePropsName = null;
|
||
var foundWillUpdateName = null;
|
||
if (typeof prototype.componentWillMount === 'function') {
|
||
foundWillMountName = 'componentWillMount';
|
||
} else if (typeof prototype.UNSAFE_componentWillMount === 'function') {
|
||
foundWillMountName = 'UNSAFE_componentWillMount';
|
||
}
|
||
if (typeof prototype.componentWillReceiveProps === 'function') {
|
||
foundWillReceivePropsName = 'componentWillReceiveProps';
|
||
} else if (typeof prototype.UNSAFE_componentWillReceiveProps === 'function') {
|
||
foundWillReceivePropsName = 'UNSAFE_componentWillReceiveProps';
|
||
}
|
||
if (typeof prototype.componentWillUpdate === 'function') {
|
||
foundWillUpdateName = 'componentWillUpdate';
|
||
} else if (typeof prototype.UNSAFE_componentWillUpdate === 'function') {
|
||
foundWillUpdateName = 'UNSAFE_componentWillUpdate';
|
||
}
|
||
if (
|
||
foundWillMountName !== null ||
|
||
foundWillReceivePropsName !== null ||
|
||
foundWillUpdateName !== null
|
||
) {
|
||
var componentName = Component.displayName || Component.name;
|
||
var newApiName =
|
||
typeof Component.getDerivedStateFromProps === 'function'
|
||
? 'getDerivedStateFromProps()'
|
||
: 'getSnapshotBeforeUpdate()';
|
||
|
||
throw Error(
|
||
'Unsafe legacy lifecycles will not be called for components using new component APIs.\n\n' +
|
||
componentName +
|
||
' uses ' +
|
||
newApiName +
|
||
' but also contains the following legacy lifecycles:' +
|
||
(foundWillMountName !== null ? '\n ' + foundWillMountName : '') +
|
||
(foundWillReceivePropsName !== null
|
||
? '\n ' + foundWillReceivePropsName
|
||
: '') +
|
||
(foundWillUpdateName !== null ? '\n ' + foundWillUpdateName : '') +
|
||
'\n\nThe above lifecycles should be removed. Learn more about this warning here:\n' +
|
||
'https://fb.me/react-async-component-lifecycle-hooks'
|
||
);
|
||
}
|
||
|
||
// React <= 16.2 does not support static getDerivedStateFromProps.
|
||
// As a workaround, use cWM and cWRP to invoke the new static lifecycle.
|
||
// Newer versions of React will ignore these lifecycles if gDSFP exists.
|
||
if (typeof Component.getDerivedStateFromProps === 'function') {
|
||
prototype.componentWillMount = componentWillMount;
|
||
prototype.componentWillReceiveProps = componentWillReceiveProps;
|
||
}
|
||
|
||
// React <= 16.2 does not support getSnapshotBeforeUpdate.
|
||
// As a workaround, use cWU to invoke the new lifecycle.
|
||
// Newer versions of React will ignore that lifecycle if gSBU exists.
|
||
if (typeof prototype.getSnapshotBeforeUpdate === 'function') {
|
||
if (typeof prototype.componentDidUpdate !== 'function') {
|
||
throw new Error(
|
||
'Cannot polyfill getSnapshotBeforeUpdate() for components that do not define componentDidUpdate() on the prototype'
|
||
);
|
||
}
|
||
|
||
prototype.componentWillUpdate = componentWillUpdate;
|
||
|
||
var componentDidUpdate = prototype.componentDidUpdate;
|
||
|
||
prototype.componentDidUpdate = function componentDidUpdatePolyfill(
|
||
prevProps,
|
||
prevState,
|
||
maybeSnapshot
|
||
) {
|
||
// 16.3+ will not execute our will-update method;
|
||
// It will pass a snapshot value to did-update though.
|
||
// Older versions will require our polyfilled will-update value.
|
||
// We need to handle both cases, but can't just check for the presence of "maybeSnapshot",
|
||
// Because for <= 15.x versions this might be a "prevContext" object.
|
||
// We also can't just check "__reactInternalSnapshot",
|
||
// Because get-snapshot might return a falsy value.
|
||
// So check for the explicit __reactInternalSnapshotFlag flag to determine behavior.
|
||
var snapshot = this.__reactInternalSnapshotFlag
|
||
? this.__reactInternalSnapshot
|
||
: maybeSnapshot;
|
||
|
||
componentDidUpdate.call(this, prevProps, prevState, snapshot);
|
||
};
|
||
}
|
||
|
||
return Component;
|
||
}
|
||
|
||
|
||
|
||
|
||
/***/ }),
|
||
/* 19 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
exports.__esModule = true;
|
||
exports.classNamesShape = exports.timeoutsShape = void 0;
|
||
|
||
var _propTypes = _interopRequireDefault(__webpack_require__(1));
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var timeoutsShape = false ? _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.shape({
|
||
enter: _propTypes.default.number,
|
||
exit: _propTypes.default.number
|
||
}).isRequired]) : null;
|
||
exports.timeoutsShape = timeoutsShape;
|
||
var classNamesShape = false ? _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.shape({
|
||
enter: _propTypes.default.string,
|
||
exit: _propTypes.default.string,
|
||
active: _propTypes.default.string
|
||
}), _propTypes.default.shape({
|
||
enter: _propTypes.default.string,
|
||
enterDone: _propTypes.default.string,
|
||
enterActive: _propTypes.default.string,
|
||
exit: _propTypes.default.string,
|
||
exitDone: _propTypes.default.string,
|
||
exitActive: _propTypes.default.string
|
||
})]) : null;
|
||
exports.classNamesShape = classNamesShape;
|
||
|
||
/***/ }),
|
||
/* 20 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
exports.__esModule = true;
|
||
exports.default = void 0;
|
||
|
||
var _propTypes = _interopRequireDefault(__webpack_require__(1));
|
||
|
||
var _react = _interopRequireDefault(__webpack_require__(0));
|
||
|
||
var _reactLifecyclesCompat = __webpack_require__(18);
|
||
|
||
var _ChildMapping = __webpack_require__(61);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
||
|
||
function _extends() { _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; }; return _extends.apply(this, arguments); }
|
||
|
||
function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
|
||
|
||
function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
||
|
||
var values = Object.values || function (obj) {
|
||
return Object.keys(obj).map(function (k) {
|
||
return obj[k];
|
||
});
|
||
};
|
||
|
||
var defaultProps = {
|
||
component: 'div',
|
||
childFactory: function childFactory(child) {
|
||
return child;
|
||
}
|
||
/**
|
||
* The `<TransitionGroup>` component manages a set of transition components
|
||
* (`<Transition>` and `<CSSTransition>`) in a list. Like with the transition
|
||
* components, `<TransitionGroup>` is a state machine for managing the mounting
|
||
* and unmounting of components over time.
|
||
*
|
||
* Consider the example below. As items are removed or added to the TodoList the
|
||
* `in` prop is toggled automatically by the `<TransitionGroup>`.
|
||
*
|
||
* Note that `<TransitionGroup>` does not define any animation behavior!
|
||
* Exactly _how_ a list item animates is up to the individual transition
|
||
* component. This means you can mix and match animations across different list
|
||
* items.
|
||
*/
|
||
|
||
};
|
||
|
||
var TransitionGroup =
|
||
/*#__PURE__*/
|
||
function (_React$Component) {
|
||
_inheritsLoose(TransitionGroup, _React$Component);
|
||
|
||
function TransitionGroup(props, context) {
|
||
var _this;
|
||
|
||
_this = _React$Component.call(this, props, context) || this;
|
||
|
||
var handleExited = _this.handleExited.bind(_assertThisInitialized(_assertThisInitialized(_this))); // Initial children should all be entering, dependent on appear
|
||
|
||
|
||
_this.state = {
|
||
handleExited: handleExited,
|
||
firstRender: true
|
||
};
|
||
return _this;
|
||
}
|
||
|
||
var _proto = TransitionGroup.prototype;
|
||
|
||
_proto.getChildContext = function getChildContext() {
|
||
return {
|
||
transitionGroup: {
|
||
isMounting: !this.appeared
|
||
}
|
||
};
|
||
};
|
||
|
||
_proto.componentDidMount = function componentDidMount() {
|
||
this.appeared = true;
|
||
this.mounted = true;
|
||
};
|
||
|
||
_proto.componentWillUnmount = function componentWillUnmount() {
|
||
this.mounted = false;
|
||
};
|
||
|
||
TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {
|
||
var prevChildMapping = _ref.children,
|
||
handleExited = _ref.handleExited,
|
||
firstRender = _ref.firstRender;
|
||
return {
|
||
children: firstRender ? (0, _ChildMapping.getInitialChildMapping)(nextProps, handleExited) : (0, _ChildMapping.getNextChildMapping)(nextProps, prevChildMapping, handleExited),
|
||
firstRender: false
|
||
};
|
||
};
|
||
|
||
_proto.handleExited = function handleExited(child, node) {
|
||
var currentChildMapping = (0, _ChildMapping.getChildMapping)(this.props.children);
|
||
if (child.key in currentChildMapping) return;
|
||
|
||
if (child.props.onExited) {
|
||
child.props.onExited(node);
|
||
}
|
||
|
||
if (this.mounted) {
|
||
this.setState(function (state) {
|
||
var children = _extends({}, state.children);
|
||
|
||
delete children[child.key];
|
||
return {
|
||
children: children
|
||
};
|
||
});
|
||
}
|
||
};
|
||
|
||
_proto.render = function render() {
|
||
var _this$props = this.props,
|
||
Component = _this$props.component,
|
||
childFactory = _this$props.childFactory,
|
||
props = _objectWithoutPropertiesLoose(_this$props, ["component", "childFactory"]);
|
||
|
||
var children = values(this.state.children).map(childFactory);
|
||
delete props.appear;
|
||
delete props.enter;
|
||
delete props.exit;
|
||
|
||
if (Component === null) {
|
||
return children;
|
||
}
|
||
|
||
return _react.default.createElement(Component, props, children);
|
||
};
|
||
|
||
return TransitionGroup;
|
||
}(_react.default.Component);
|
||
|
||
TransitionGroup.childContextTypes = {
|
||
transitionGroup: _propTypes.default.object.isRequired
|
||
};
|
||
TransitionGroup.propTypes = false ? {
|
||
/**
|
||
* `<TransitionGroup>` renders a `<div>` by default. You can change this
|
||
* behavior by providing a `component` prop.
|
||
* If you use React v16+ and would like to avoid a wrapping `<div>` element
|
||
* you can pass in `component={null}`. This is useful if the wrapping div
|
||
* borks your css styles.
|
||
*/
|
||
component: _propTypes.default.any,
|
||
|
||
/**
|
||
* A set of `<Transition>` components, that are toggled `in` and out as they
|
||
* leave. the `<TransitionGroup>` will inject specific transition props, so
|
||
* remember to spread them through if you are wrapping the `<Transition>` as
|
||
* with our `<Fade>` example.
|
||
*/
|
||
children: _propTypes.default.node,
|
||
|
||
/**
|
||
* A convenience prop that enables or disables appear animations
|
||
* for all children. Note that specifying this will override any defaults set
|
||
* on individual children Transitions.
|
||
*/
|
||
appear: _propTypes.default.bool,
|
||
|
||
/**
|
||
* A convenience prop that enables or disables enter animations
|
||
* for all children. Note that specifying this will override any defaults set
|
||
* on individual children Transitions.
|
||
*/
|
||
enter: _propTypes.default.bool,
|
||
|
||
/**
|
||
* A convenience prop that enables or disables exit animations
|
||
* for all children. Note that specifying this will override any defaults set
|
||
* on individual children Transitions.
|
||
*/
|
||
exit: _propTypes.default.bool,
|
||
|
||
/**
|
||
* You may need to apply reactive updates to a child as it is exiting.
|
||
* This is generally done by using `cloneElement` however in the case of an exiting
|
||
* child the element has already been removed and not accessible to the consumer.
|
||
*
|
||
* If you do need to update a child as it leaves you can provide a `childFactory`
|
||
* to wrap every child, even the ones that are leaving.
|
||
*
|
||
* @type Function(child: ReactElement) -> ReactElement
|
||
*/
|
||
childFactory: _propTypes.default.func
|
||
} : {};
|
||
TransitionGroup.defaultProps = defaultProps;
|
||
|
||
var _default = (0, _reactLifecyclesCompat.polyfill)(TransitionGroup);
|
||
|
||
exports.default = _default;
|
||
module.exports = exports["default"];
|
||
|
||
/***/ }),
|
||
/* 21 */
|
||
/***/ (function(module, exports) {
|
||
|
||
// Copyright Joyent, Inc. and other Node contributors.
|
||
//
|
||
// Permission is hereby granted, free of charge, to any person obtaining a
|
||
// copy of this software and associated documentation files (the
|
||
// "Software"), to deal in the Software without restriction, including
|
||
// without limitation the rights to use, copy, modify, merge, publish,
|
||
// distribute, sublicense, and/or sell copies of the Software, and to permit
|
||
// persons to whom the Software is furnished to do so, subject to the
|
||
// following conditions:
|
||
//
|
||
// The above copyright notice and this permission notice shall be included
|
||
// in all copies or substantial portions of the Software.
|
||
//
|
||
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
||
// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
|
||
// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
|
||
// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
|
||
// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
||
// USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||
|
||
function EventEmitter() {
|
||
this._events = this._events || {};
|
||
this._maxListeners = this._maxListeners || undefined;
|
||
}
|
||
module.exports = EventEmitter;
|
||
|
||
// Backwards-compat with node 0.10.x
|
||
EventEmitter.EventEmitter = EventEmitter;
|
||
|
||
EventEmitter.prototype._events = undefined;
|
||
EventEmitter.prototype._maxListeners = undefined;
|
||
|
||
// By default EventEmitters will print a warning if more than 10 listeners are
|
||
// added to it. This is a useful default which helps finding memory leaks.
|
||
EventEmitter.defaultMaxListeners = 10;
|
||
|
||
// Obviously not all Emitters should be limited to 10. This function allows
|
||
// that to be increased. Set to zero for unlimited.
|
||
EventEmitter.prototype.setMaxListeners = function(n) {
|
||
if (!isNumber(n) || n < 0 || isNaN(n))
|
||
throw TypeError('n must be a positive number');
|
||
this._maxListeners = n;
|
||
return this;
|
||
};
|
||
|
||
EventEmitter.prototype.emit = function(type) {
|
||
var er, handler, len, args, i, listeners;
|
||
|
||
if (!this._events)
|
||
this._events = {};
|
||
|
||
// If there is no 'error' event listener then throw.
|
||
if (type === 'error') {
|
||
if (!this._events.error ||
|
||
(isObject(this._events.error) && !this._events.error.length)) {
|
||
er = arguments[1];
|
||
if (er instanceof Error) {
|
||
throw er; // Unhandled 'error' event
|
||
} else {
|
||
// At least give some kind of context to the user
|
||
var err = new Error('Uncaught, unspecified "error" event. (' + er + ')');
|
||
err.context = er;
|
||
throw err;
|
||
}
|
||
}
|
||
}
|
||
|
||
handler = this._events[type];
|
||
|
||
if (isUndefined(handler))
|
||
return false;
|
||
|
||
if (isFunction(handler)) {
|
||
switch (arguments.length) {
|
||
// fast cases
|
||
case 1:
|
||
handler.call(this);
|
||
break;
|
||
case 2:
|
||
handler.call(this, arguments[1]);
|
||
break;
|
||
case 3:
|
||
handler.call(this, arguments[1], arguments[2]);
|
||
break;
|
||
// slower
|
||
default:
|
||
args = Array.prototype.slice.call(arguments, 1);
|
||
handler.apply(this, args);
|
||
}
|
||
} else if (isObject(handler)) {
|
||
args = Array.prototype.slice.call(arguments, 1);
|
||
listeners = handler.slice();
|
||
len = listeners.length;
|
||
for (i = 0; i < len; i++)
|
||
listeners[i].apply(this, args);
|
||
}
|
||
|
||
return true;
|
||
};
|
||
|
||
EventEmitter.prototype.addListener = function(type, listener) {
|
||
var m;
|
||
|
||
if (!isFunction(listener))
|
||
throw TypeError('listener must be a function');
|
||
|
||
if (!this._events)
|
||
this._events = {};
|
||
|
||
// To avoid recursion in the case that type === "newListener"! Before
|
||
// adding it to the listeners, first emit "newListener".
|
||
if (this._events.newListener)
|
||
this.emit('newListener', type,
|
||
isFunction(listener.listener) ?
|
||
listener.listener : listener);
|
||
|
||
if (!this._events[type])
|
||
// Optimize the case of one listener. Don't need the extra array object.
|
||
this._events[type] = listener;
|
||
else if (isObject(this._events[type]))
|
||
// If we've already got an array, just append.
|
||
this._events[type].push(listener);
|
||
else
|
||
// Adding the second element, need to change to array.
|
||
this._events[type] = [this._events[type], listener];
|
||
|
||
// Check for listener leak
|
||
if (isObject(this._events[type]) && !this._events[type].warned) {
|
||
if (!isUndefined(this._maxListeners)) {
|
||
m = this._maxListeners;
|
||
} else {
|
||
m = EventEmitter.defaultMaxListeners;
|
||
}
|
||
|
||
if (m && m > 0 && this._events[type].length > m) {
|
||
this._events[type].warned = true;
|
||
console.error('(node) warning: possible EventEmitter memory ' +
|
||
'leak detected. %d listeners added. ' +
|
||
'Use emitter.setMaxListeners() to increase limit.',
|
||
this._events[type].length);
|
||
if (typeof console.trace === 'function') {
|
||
// not supported in IE 10
|
||
console.trace();
|
||
}
|
||
}
|
||
}
|
||
|
||
return this;
|
||
};
|
||
|
||
EventEmitter.prototype.on = EventEmitter.prototype.addListener;
|
||
|
||
EventEmitter.prototype.once = function(type, listener) {
|
||
if (!isFunction(listener))
|
||
throw TypeError('listener must be a function');
|
||
|
||
var fired = false;
|
||
|
||
function g() {
|
||
this.removeListener(type, g);
|
||
|
||
if (!fired) {
|
||
fired = true;
|
||
listener.apply(this, arguments);
|
||
}
|
||
}
|
||
|
||
g.listener = listener;
|
||
this.on(type, g);
|
||
|
||
return this;
|
||
};
|
||
|
||
// emits a 'removeListener' event iff the listener was removed
|
||
EventEmitter.prototype.removeListener = function(type, listener) {
|
||
var list, position, length, i;
|
||
|
||
if (!isFunction(listener))
|
||
throw TypeError('listener must be a function');
|
||
|
||
if (!this._events || !this._events[type])
|
||
return this;
|
||
|
||
list = this._events[type];
|
||
length = list.length;
|
||
position = -1;
|
||
|
||
if (list === listener ||
|
||
(isFunction(list.listener) && list.listener === listener)) {
|
||
delete this._events[type];
|
||
if (this._events.removeListener)
|
||
this.emit('removeListener', type, listener);
|
||
|
||
} else if (isObject(list)) {
|
||
for (i = length; i-- > 0;) {
|
||
if (list[i] === listener ||
|
||
(list[i].listener && list[i].listener === listener)) {
|
||
position = i;
|
||
break;
|
||
}
|
||
}
|
||
|
||
if (position < 0)
|
||
return this;
|
||
|
||
if (list.length === 1) {
|
||
list.length = 0;
|
||
delete this._events[type];
|
||
} else {
|
||
list.splice(position, 1);
|
||
}
|
||
|
||
if (this._events.removeListener)
|
||
this.emit('removeListener', type, listener);
|
||
}
|
||
|
||
return this;
|
||
};
|
||
|
||
EventEmitter.prototype.removeAllListeners = function(type) {
|
||
var key, listeners;
|
||
|
||
if (!this._events)
|
||
return this;
|
||
|
||
// not listening for removeListener, no need to emit
|
||
if (!this._events.removeListener) {
|
||
if (arguments.length === 0)
|
||
this._events = {};
|
||
else if (this._events[type])
|
||
delete this._events[type];
|
||
return this;
|
||
}
|
||
|
||
// emit removeListener for all listeners on all events
|
||
if (arguments.length === 0) {
|
||
for (key in this._events) {
|
||
if (key === 'removeListener') continue;
|
||
this.removeAllListeners(key);
|
||
}
|
||
this.removeAllListeners('removeListener');
|
||
this._events = {};
|
||
return this;
|
||
}
|
||
|
||
listeners = this._events[type];
|
||
|
||
if (isFunction(listeners)) {
|
||
this.removeListener(type, listeners);
|
||
} else if (listeners) {
|
||
// LIFO order
|
||
while (listeners.length)
|
||
this.removeListener(type, listeners[listeners.length - 1]);
|
||
}
|
||
delete this._events[type];
|
||
|
||
return this;
|
||
};
|
||
|
||
EventEmitter.prototype.listeners = function(type) {
|
||
var ret;
|
||
if (!this._events || !this._events[type])
|
||
ret = [];
|
||
else if (isFunction(this._events[type]))
|
||
ret = [this._events[type]];
|
||
else
|
||
ret = this._events[type].slice();
|
||
return ret;
|
||
};
|
||
|
||
EventEmitter.prototype.listenerCount = function(type) {
|
||
if (this._events) {
|
||
var evlistener = this._events[type];
|
||
|
||
if (isFunction(evlistener))
|
||
return 1;
|
||
else if (evlistener)
|
||
return evlistener.length;
|
||
}
|
||
return 0;
|
||
};
|
||
|
||
EventEmitter.listenerCount = function(emitter, type) {
|
||
return emitter.listenerCount(type);
|
||
};
|
||
|
||
function isFunction(arg) {
|
||
return typeof arg === 'function';
|
||
}
|
||
|
||
function isNumber(arg) {
|
||
return typeof arg === 'number';
|
||
}
|
||
|
||
function isObject(arg) {
|
||
return typeof arg === 'object' && arg !== null;
|
||
}
|
||
|
||
function isUndefined(arg) {
|
||
return arg === void 0;
|
||
}
|
||
|
||
|
||
/***/ }),
|
||
/* 22 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _bootstrapTable = __webpack_require__(23);
|
||
|
||
var _bootstrapTable2 = _interopRequireDefault(_bootstrapTable);
|
||
|
||
var _contexts = __webpack_require__(66);
|
||
|
||
var _contexts2 = _interopRequireDefault(_contexts);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
exports.default = (0, _contexts2.default)(_bootstrapTable2.default);
|
||
|
||
/***/ }),
|
||
/* 23 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _classnames = __webpack_require__(4);
|
||
|
||
var _classnames2 = _interopRequireDefault(_classnames);
|
||
|
||
var _header = __webpack_require__(26);
|
||
|
||
var _header2 = _interopRequireDefault(_header);
|
||
|
||
var _filters = __webpack_require__(41);
|
||
|
||
var _filters2 = _interopRequireDefault(_filters);
|
||
|
||
var _caption = __webpack_require__(43);
|
||
|
||
var _caption2 = _interopRequireDefault(_caption);
|
||
|
||
var _body = __webpack_require__(44);
|
||
|
||
var _body2 = _interopRequireDefault(_body);
|
||
|
||
var _footer = __webpack_require__(62);
|
||
|
||
var _footer2 = _interopRequireDefault(_footer);
|
||
|
||
var _propsResolver = __webpack_require__(64);
|
||
|
||
var _propsResolver2 = _interopRequireDefault(_propsResolver);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
||
|
||
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; } /* eslint camelcase: 0 */
|
||
/* eslint arrow-body-style: 0 */
|
||
|
||
var BootstrapTable = function (_PropsBaseResolver) {
|
||
_inherits(BootstrapTable, _PropsBaseResolver);
|
||
|
||
function BootstrapTable(props) {
|
||
_classCallCheck(this, BootstrapTable);
|
||
|
||
var _this = _possibleConstructorReturn(this, (BootstrapTable.__proto__ || Object.getPrototypeOf(BootstrapTable)).call(this, props));
|
||
|
||
_this.getData = function () {
|
||
return _this.visibleRows();
|
||
};
|
||
|
||
_this.validateProps();
|
||
return _this;
|
||
}
|
||
|
||
_createClass(BootstrapTable, [{
|
||
key: 'UNSAFE_componentWillReceiveProps',
|
||
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
||
if (nextProps.onDataSizeChange && !nextProps.pagination) {
|
||
if (nextProps.data.length !== this.props.data.length) {
|
||
nextProps.onDataSizeChange({ dataSize: nextProps.data.length });
|
||
}
|
||
}
|
||
}
|
||
|
||
// Exposed APIs
|
||
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
loading = _props.loading,
|
||
overlay = _props.overlay;
|
||
|
||
if (overlay) {
|
||
var LoadingOverlay = overlay(loading);
|
||
return _react2.default.createElement(
|
||
LoadingOverlay,
|
||
null,
|
||
this.renderTable()
|
||
);
|
||
}
|
||
return this.renderTable();
|
||
}
|
||
}, {
|
||
key: 'renderTable',
|
||
value: function renderTable() {
|
||
var _props2 = this.props,
|
||
columns = _props2.columns,
|
||
keyField = _props2.keyField,
|
||
tabIndexCell = _props2.tabIndexCell,
|
||
id = _props2.id,
|
||
classes = _props2.classes,
|
||
bootstrap4 = _props2.bootstrap4,
|
||
striped = _props2.striped,
|
||
hover = _props2.hover,
|
||
bordered = _props2.bordered,
|
||
condensed = _props2.condensed,
|
||
noDataIndication = _props2.noDataIndication,
|
||
caption = _props2.caption,
|
||
rowStyle = _props2.rowStyle,
|
||
rowClasses = _props2.rowClasses,
|
||
wrapperClasses = _props2.wrapperClasses,
|
||
rowEvents = _props2.rowEvents,
|
||
selectRow = _props2.selectRow,
|
||
expandRow = _props2.expandRow,
|
||
cellEdit = _props2.cellEdit,
|
||
filterPosition = _props2.filterPosition;
|
||
|
||
|
||
var tableWrapperClass = (0, _classnames2.default)('react-bootstrap-table', wrapperClasses);
|
||
|
||
var tableClass = (0, _classnames2.default)('table', _defineProperty({
|
||
'table-striped': striped,
|
||
'table-hover': hover,
|
||
'table-bordered': bordered
|
||
}, bootstrap4 ? 'table-sm' : 'table-condensed', condensed), classes);
|
||
|
||
var hasFilters = columns.some(function (col) {
|
||
return col.filter || col.filterRenderer;
|
||
});
|
||
|
||
var hasFooter = _utils2.default.filter(columns, function (col) {
|
||
return _utils2.default.has(col, 'footer');
|
||
}).length > 0;
|
||
|
||
var tableCaption = caption && _react2.default.createElement(
|
||
_caption2.default,
|
||
{ bootstrap4: bootstrap4 },
|
||
caption
|
||
);
|
||
|
||
return _react2.default.createElement(
|
||
'div',
|
||
{ className: tableWrapperClass },
|
||
_react2.default.createElement(
|
||
'table',
|
||
{ id: id, className: tableClass },
|
||
tableCaption,
|
||
_react2.default.createElement(_header2.default, {
|
||
columns: columns,
|
||
className: this.props.headerClasses,
|
||
wrapperClasses: this.props.headerWrapperClasses,
|
||
sortField: this.props.sortField,
|
||
sortOrder: this.props.sortOrder,
|
||
onSort: this.props.onSort,
|
||
globalSortCaret: this.props.sort && this.props.sort.sortCaret,
|
||
onFilter: this.props.onFilter,
|
||
currFilters: this.props.currFilters,
|
||
onExternalFilter: this.props.onExternalFilter,
|
||
selectRow: selectRow,
|
||
expandRow: expandRow,
|
||
filterPosition: filterPosition
|
||
}),
|
||
hasFilters && filterPosition !== _const2.default.FILTERS_POSITION_INLINE && _react2.default.createElement(_filters2.default, {
|
||
columns: columns,
|
||
className: this.props.filtersClasses,
|
||
onSort: this.props.onSort,
|
||
onFilter: this.props.onFilter,
|
||
currFilters: this.props.currFilters,
|
||
filterPosition: this.props.filterPosition,
|
||
onExternalFilter: this.props.onExternalFilter,
|
||
selectRow: selectRow,
|
||
expandRow: expandRow
|
||
}),
|
||
_react2.default.createElement(_body2.default, {
|
||
className: this.props.bodyClasses,
|
||
data: this.getData(),
|
||
keyField: keyField,
|
||
tabIndexCell: tabIndexCell,
|
||
columns: columns,
|
||
isEmpty: this.isEmpty(),
|
||
visibleColumnSize: this.visibleColumnSize(),
|
||
noDataIndication: noDataIndication,
|
||
cellEdit: cellEdit,
|
||
selectRow: selectRow,
|
||
expandRow: expandRow,
|
||
rowStyle: rowStyle,
|
||
rowClasses: rowClasses,
|
||
rowEvents: rowEvents
|
||
}),
|
||
hasFooter && _react2.default.createElement(_footer2.default, {
|
||
data: this.getData(),
|
||
columns: columns,
|
||
selectRow: selectRow,
|
||
expandRow: expandRow,
|
||
className: this.props.footerClasses
|
||
})
|
||
)
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return BootstrapTable;
|
||
}((0, _propsResolver2.default)(_react.Component));
|
||
|
||
BootstrapTable.propTypes = {
|
||
keyField: _propTypes2.default.string.isRequired,
|
||
data: _propTypes2.default.array.isRequired,
|
||
columns: _propTypes2.default.array.isRequired,
|
||
bootstrap4: _propTypes2.default.bool,
|
||
remote: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.shape({
|
||
pagination: _propTypes2.default.bool
|
||
})]),
|
||
noDataIndication: _propTypes2.default.oneOfType([_propTypes2.default.node, _propTypes2.default.func]),
|
||
striped: _propTypes2.default.bool,
|
||
bordered: _propTypes2.default.bool,
|
||
hover: _propTypes2.default.bool,
|
||
tabIndexCell: _propTypes2.default.bool,
|
||
id: _propTypes2.default.string,
|
||
classes: _propTypes2.default.string,
|
||
headerClasses: _propTypes2.default.string,
|
||
bodyClasses: _propTypes2.default.string,
|
||
wrapperClasses: _propTypes2.default.string,
|
||
headerWrapperClasses: _propTypes2.default.string,
|
||
condensed: _propTypes2.default.bool,
|
||
caption: _propTypes2.default.oneOfType([_propTypes2.default.node, _propTypes2.default.string]),
|
||
pagination: _propTypes2.default.object,
|
||
filter: _propTypes2.default.object,
|
||
cellEdit: _propTypes2.default.object,
|
||
selectRow: _propTypes2.default.shape({
|
||
mode: _propTypes2.default.oneOf([_const2.default.ROW_SELECT_SINGLE, _const2.default.ROW_SELECT_MULTIPLE, _const2.default.ROW_SELECT_DISABLED]).isRequired,
|
||
clickToSelect: _propTypes2.default.bool,
|
||
clickToExpand: _propTypes2.default.bool,
|
||
clickToEdit: _propTypes2.default.bool,
|
||
hideSelectAll: _propTypes2.default.bool,
|
||
onSelect: _propTypes2.default.func,
|
||
onSelectAll: _propTypes2.default.func,
|
||
style: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
classes: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
nonSelectable: _propTypes2.default.array,
|
||
nonSelectableStyle: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
nonSelectableClasses: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
bgColor: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
hideSelectColumn: _propTypes2.default.bool,
|
||
selectionRenderer: _propTypes2.default.func,
|
||
selectionHeaderRenderer: _propTypes2.default.func,
|
||
headerColumnStyle: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
selectColumnStyle: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
selectColumnPosition: _propTypes2.default.oneOf([_const2.default.INDICATOR_POSITION_LEFT, _const2.default.INDICATOR_POSITION_RIGHT])
|
||
}),
|
||
expandRow: _propTypes2.default.shape({
|
||
renderer: _propTypes2.default.func,
|
||
expanded: _propTypes2.default.array,
|
||
onExpand: _propTypes2.default.func,
|
||
onExpandAll: _propTypes2.default.func,
|
||
nonExpandable: _propTypes2.default.array,
|
||
showExpandColumn: _propTypes2.default.bool,
|
||
onlyOneExpanding: _propTypes2.default.bool,
|
||
expandByColumnOnly: _propTypes2.default.bool,
|
||
expandColumnRenderer: _propTypes2.default.func,
|
||
expandHeaderColumnRenderer: _propTypes2.default.func,
|
||
expandColumnPosition: _propTypes2.default.oneOf([_const2.default.INDICATOR_POSITION_LEFT, _const2.default.INDICATOR_POSITION_RIGHT]),
|
||
className: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
parentClassName: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func])
|
||
}),
|
||
rowStyle: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
rowEvents: _propTypes2.default.object,
|
||
rowClasses: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
filtersClasses: _propTypes2.default.string,
|
||
filterPosition: _propTypes2.default.oneOf([_const2.default.FILTERS_POSITION_TOP, _const2.default.FILTERS_POSITION_INLINE, _const2.default.FILTERS_POSITION_BOTTOM]),
|
||
footerClasses: _propTypes2.default.string,
|
||
defaultSorted: _propTypes2.default.arrayOf(_propTypes2.default.shape({
|
||
dataField: _propTypes2.default.string.isRequired,
|
||
order: _propTypes2.default.oneOf([_const2.default.SORT_DESC, _const2.default.SORT_ASC]).isRequired
|
||
})),
|
||
sort: _propTypes2.default.shape({
|
||
dataField: _propTypes2.default.string,
|
||
order: _propTypes2.default.oneOf([_const2.default.SORT_DESC, _const2.default.SORT_ASC]),
|
||
sortFunc: _propTypes2.default.func,
|
||
sortCaret: _propTypes2.default.func
|
||
}),
|
||
defaultSortDirection: _propTypes2.default.oneOf([_const2.default.SORT_DESC, _const2.default.SORT_ASC]),
|
||
overlay: _propTypes2.default.func,
|
||
onTableChange: _propTypes2.default.func,
|
||
onSort: _propTypes2.default.func,
|
||
onFilter: _propTypes2.default.func,
|
||
onExternalFilter: _propTypes2.default.func,
|
||
onDataSizeChange: _propTypes2.default.func,
|
||
// Inject from toolkit
|
||
search: _propTypes2.default.shape({
|
||
searchText: _propTypes2.default.string,
|
||
searchContext: _propTypes2.default.func
|
||
}),
|
||
setDependencyModules: _propTypes2.default.func
|
||
};
|
||
|
||
BootstrapTable.defaultProps = {
|
||
bootstrap4: false,
|
||
remote: false,
|
||
striped: false,
|
||
bordered: true,
|
||
hover: false,
|
||
condensed: false,
|
||
noDataIndication: null,
|
||
selectRow: {
|
||
mode: _const2.default.ROW_SELECT_DISABLED,
|
||
selected: [],
|
||
hideSelectColumn: true
|
||
},
|
||
expandRow: {
|
||
renderer: undefined,
|
||
expanded: [],
|
||
nonExpandable: []
|
||
},
|
||
cellEdit: {
|
||
mode: null,
|
||
nonEditableRows: []
|
||
},
|
||
filterPosition: _const2.default.FILTERS_POSITION_INLINE
|
||
};
|
||
|
||
exports.default = BootstrapTable;
|
||
|
||
/***/ }),
|
||
/* 24 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
/**
|
||
* Copyright (c) 2013-present, Facebook, Inc.
|
||
*
|
||
* This source code is licensed under the MIT license found in the
|
||
* LICENSE file in the root directory of this source tree.
|
||
*/
|
||
|
||
|
||
|
||
var ReactPropTypesSecret = __webpack_require__(25);
|
||
|
||
function emptyFunction() {}
|
||
function emptyFunctionWithReset() {}
|
||
emptyFunctionWithReset.resetWarningCache = emptyFunction;
|
||
|
||
module.exports = function() {
|
||
function shim(props, propName, componentName, location, propFullName, secret) {
|
||
if (secret === ReactPropTypesSecret) {
|
||
// It is still safe when called from React.
|
||
return;
|
||
}
|
||
var err = new Error(
|
||
'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +
|
||
'Use PropTypes.checkPropTypes() to call them. ' +
|
||
'Read more at http://fb.me/use-check-prop-types'
|
||
);
|
||
err.name = 'Invariant Violation';
|
||
throw err;
|
||
};
|
||
shim.isRequired = shim;
|
||
function getShim() {
|
||
return shim;
|
||
};
|
||
// Important!
|
||
// Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.
|
||
var ReactPropTypes = {
|
||
array: shim,
|
||
bool: shim,
|
||
func: shim,
|
||
number: shim,
|
||
object: shim,
|
||
string: shim,
|
||
symbol: shim,
|
||
|
||
any: shim,
|
||
arrayOf: getShim,
|
||
element: shim,
|
||
elementType: shim,
|
||
instanceOf: getShim,
|
||
node: shim,
|
||
objectOf: getShim,
|
||
oneOf: getShim,
|
||
oneOfType: getShim,
|
||
shape: getShim,
|
||
exact: getShim,
|
||
|
||
checkPropTypes: emptyFunctionWithReset,
|
||
resetWarningCache: emptyFunction
|
||
};
|
||
|
||
ReactPropTypes.PropTypes = ReactPropTypes;
|
||
|
||
return ReactPropTypes;
|
||
};
|
||
|
||
|
||
/***/ }),
|
||
/* 25 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
/**
|
||
* Copyright (c) 2013-present, Facebook, Inc.
|
||
*
|
||
* This source code is licensed under the MIT license found in the
|
||
* LICENSE file in the root directory of this source tree.
|
||
*/
|
||
|
||
|
||
|
||
var ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';
|
||
|
||
module.exports = ReactPropTypesSecret;
|
||
|
||
|
||
/***/ }),
|
||
/* 26 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _headerCell = __webpack_require__(27);
|
||
|
||
var _headerCell2 = _interopRequireDefault(_headerCell);
|
||
|
||
var _selectionHeaderCell = __webpack_require__(33);
|
||
|
||
var _selectionHeaderCell2 = _interopRequireDefault(_selectionHeaderCell);
|
||
|
||
var _expandHeaderCell = __webpack_require__(34);
|
||
|
||
var _expandHeaderCell2 = _interopRequireDefault(_expandHeaderCell);
|
||
|
||
var _selectionHeaderCellConsumer = __webpack_require__(35);
|
||
|
||
var _selectionHeaderCellConsumer2 = _interopRequireDefault(_selectionHeaderCellConsumer);
|
||
|
||
var _expandHeaderCellConsumer = __webpack_require__(40);
|
||
|
||
var _expandHeaderCellConsumer2 = _interopRequireDefault(_expandHeaderCellConsumer);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
/* eslint react/require-default-props: 0 */
|
||
var Header = function Header(props) {
|
||
var className = props.className,
|
||
columns = props.columns,
|
||
onSort = props.onSort,
|
||
onFilter = props.onFilter,
|
||
sortField = props.sortField,
|
||
sortOrder = props.sortOrder,
|
||
selectRow = props.selectRow,
|
||
expandRow = props.expandRow,
|
||
currFilters = props.currFilters,
|
||
onExternalFilter = props.onExternalFilter,
|
||
filterPosition = props.filterPosition,
|
||
globalSortCaret = props.globalSortCaret,
|
||
wrapperClasses = props.wrapperClasses;
|
||
|
||
|
||
var SelectionHeaderCellComp = function SelectionHeaderCellComp() {
|
||
return null;
|
||
};
|
||
var ExpansionHeaderCellComp = function ExpansionHeaderCellComp() {
|
||
return null;
|
||
};
|
||
|
||
if (expandRow.showExpandColumn) {
|
||
ExpansionHeaderCellComp = (0, _expandHeaderCellConsumer2.default)(_expandHeaderCell2.default);
|
||
}
|
||
|
||
if (selectRow) {
|
||
SelectionHeaderCellComp = (0, _selectionHeaderCellConsumer2.default)(_selectionHeaderCell2.default);
|
||
}
|
||
|
||
var isRenderFunctionColumnInLeft = function isRenderFunctionColumnInLeft() {
|
||
var position = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _const2.default.INDICATOR_POSITION_LEFT;
|
||
return position === _const2.default.INDICATOR_POSITION_LEFT;
|
||
};
|
||
|
||
var childrens = [columns.map(function (column, i) {
|
||
var currSort = column.dataField === sortField;
|
||
var isLastSorting = column.dataField === sortField;
|
||
|
||
return _react2.default.createElement(_headerCell2.default, {
|
||
index: i,
|
||
key: column.dataField,
|
||
column: column,
|
||
onSort: onSort,
|
||
sorting: currSort,
|
||
sortOrder: sortOrder,
|
||
globalSortCaret: globalSortCaret,
|
||
isLastSorting: isLastSorting,
|
||
onFilter: onFilter,
|
||
currFilters: currFilters,
|
||
onExternalFilter: onExternalFilter,
|
||
filterPosition: filterPosition
|
||
});
|
||
})];
|
||
|
||
if (!selectRow.hideSelectColumn) {
|
||
if (isRenderFunctionColumnInLeft(selectRow.selectColumnPosition)) {
|
||
childrens.unshift(_react2.default.createElement(SelectionHeaderCellComp, { key: 'selection' }));
|
||
} else {
|
||
childrens.push(_react2.default.createElement(SelectionHeaderCellComp, { key: 'selection' }));
|
||
}
|
||
}
|
||
|
||
if (expandRow.showExpandColumn) {
|
||
if (isRenderFunctionColumnInLeft(expandRow.expandColumnPosition)) {
|
||
childrens.unshift(_react2.default.createElement(ExpansionHeaderCellComp, { key: 'expansion' }));
|
||
} else {
|
||
childrens.push(_react2.default.createElement(ExpansionHeaderCellComp, { key: 'expansion' }));
|
||
}
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
'thead',
|
||
{ className: wrapperClasses },
|
||
_react2.default.createElement(
|
||
'tr',
|
||
{ className: className },
|
||
childrens
|
||
)
|
||
);
|
||
};
|
||
|
||
Header.propTypes = {
|
||
columns: _propTypes2.default.array.isRequired,
|
||
onSort: _propTypes2.default.func,
|
||
onFilter: _propTypes2.default.func,
|
||
sortField: _propTypes2.default.string,
|
||
sortOrder: _propTypes2.default.string,
|
||
selectRow: _propTypes2.default.object,
|
||
currFilters: _propTypes2.default.object,
|
||
onExternalFilter: _propTypes2.default.func,
|
||
globalSortCaret: _propTypes2.default.func,
|
||
className: _propTypes2.default.string,
|
||
wrapperClasses: _propTypes2.default.string,
|
||
expandRow: _propTypes2.default.object,
|
||
filterPosition: _propTypes2.default.oneOf([_const2.default.FILTERS_POSITION_TOP, _const2.default.FILTERS_POSITION_INLINE, _const2.default.FILTERS_POSITION_BOTTOM])
|
||
};
|
||
|
||
exports.default = Header;
|
||
|
||
/***/ }),
|
||
/* 27 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _classnames = __webpack_require__(4);
|
||
|
||
var _classnames2 = _interopRequireDefault(_classnames);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
var _symbol = __webpack_require__(28);
|
||
|
||
var _symbol2 = _interopRequireDefault(_symbol);
|
||
|
||
var _caret = __webpack_require__(29);
|
||
|
||
var _caret2 = _interopRequireDefault(_caret);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _cellEventDelegater = __webpack_require__(7);
|
||
|
||
var _cellEventDelegater2 = _interopRequireDefault(_cellEventDelegater);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/require-default-props: 0 */
|
||
|
||
|
||
var HeaderCell = function (_eventDelegater) {
|
||
_inherits(HeaderCell, _eventDelegater);
|
||
|
||
function HeaderCell() {
|
||
_classCallCheck(this, HeaderCell);
|
||
|
||
return _possibleConstructorReturn(this, (HeaderCell.__proto__ || Object.getPrototypeOf(HeaderCell)).apply(this, arguments));
|
||
}
|
||
|
||
_createClass(HeaderCell, [{
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
column = _props.column,
|
||
index = _props.index,
|
||
onSort = _props.onSort,
|
||
sorting = _props.sorting,
|
||
sortOrder = _props.sortOrder,
|
||
isLastSorting = _props.isLastSorting,
|
||
onFilter = _props.onFilter,
|
||
currFilters = _props.currFilters,
|
||
filterPosition = _props.filterPosition,
|
||
onExternalFilter = _props.onExternalFilter,
|
||
globalSortCaret = _props.globalSortCaret;
|
||
var text = column.text,
|
||
sort = column.sort,
|
||
sortCaret = column.sortCaret,
|
||
filter = column.filter,
|
||
filterRenderer = column.filterRenderer,
|
||
headerTitle = column.headerTitle,
|
||
headerAlign = column.headerAlign,
|
||
headerFormatter = column.headerFormatter,
|
||
headerEvents = column.headerEvents,
|
||
headerClasses = column.headerClasses,
|
||
headerStyle = column.headerStyle,
|
||
headerAttrs = column.headerAttrs,
|
||
headerSortingClasses = column.headerSortingClasses,
|
||
headerSortingStyle = column.headerSortingStyle;
|
||
|
||
|
||
var sortCaretfunc = sortCaret || globalSortCaret;
|
||
|
||
var delegateEvents = this.delegate(headerEvents);
|
||
|
||
var customAttrs = _utils2.default.isFunction(headerAttrs) ? headerAttrs(column, index) : headerAttrs || {};
|
||
|
||
var cellAttrs = _extends({}, customAttrs, delegateEvents, {
|
||
tabIndex: _utils2.default.isDefined(customAttrs.tabIndex) ? customAttrs.tabIndex : 0
|
||
});
|
||
|
||
var sortSymbol = void 0;
|
||
var filterElm = void 0;
|
||
var cellStyle = {};
|
||
var cellClasses = _utils2.default.isFunction(headerClasses) ? headerClasses(column, index) : headerClasses;
|
||
|
||
if (headerStyle) {
|
||
cellStyle = _utils2.default.isFunction(headerStyle) ? headerStyle(column, index) : headerStyle;
|
||
cellStyle = cellStyle ? _extends({}, cellStyle) : cellStyle;
|
||
}
|
||
|
||
if (headerTitle) {
|
||
cellAttrs.title = _utils2.default.isFunction(headerTitle) ? headerTitle(column, index) : text;
|
||
}
|
||
|
||
if (headerAlign) {
|
||
cellStyle.textAlign = _utils2.default.isFunction(headerAlign) ? headerAlign(column, index) : headerAlign;
|
||
}
|
||
|
||
if (sort) {
|
||
var customClick = cellAttrs.onClick;
|
||
cellAttrs['aria-label'] = sorting ? text + ' sort ' + sortOrder : text + ' sortable';
|
||
cellAttrs.onKeyUp = function (e) {
|
||
if (e.key === 'Enter') {
|
||
onSort(column);
|
||
if (_utils2.default.isFunction(customClick)) customClick(e);
|
||
}
|
||
};
|
||
cellAttrs.onClick = function (e) {
|
||
onSort(column);
|
||
if (_utils2.default.isFunction(customClick)) customClick(e);
|
||
};
|
||
cellAttrs.className = (0, _classnames2.default)(cellAttrs.className, 'sortable');
|
||
|
||
if (sorting) {
|
||
sortSymbol = sortCaretfunc ? sortCaretfunc(sortOrder, column) : _react2.default.createElement(_caret2.default, { order: sortOrder });
|
||
|
||
// append customized classes or style if table was sorting based on the current column.
|
||
cellClasses = (0, _classnames2.default)(cellClasses, _utils2.default.isFunction(headerSortingClasses) ? headerSortingClasses(column, sortOrder, isLastSorting, index) : headerSortingClasses);
|
||
|
||
cellStyle = _extends({}, cellStyle, _utils2.default.isFunction(headerSortingStyle) ? headerSortingStyle(column, sortOrder, isLastSorting, index) : headerSortingStyle);
|
||
} else {
|
||
sortSymbol = sortCaretfunc ? sortCaretfunc(undefined, column) : _react2.default.createElement(_symbol2.default, null);
|
||
}
|
||
}
|
||
|
||
if (cellClasses) cellAttrs.className = (0, _classnames2.default)(cellAttrs.className, cellClasses);
|
||
if (!_utils2.default.isEmptyObject(cellStyle)) cellAttrs.style = cellStyle;
|
||
|
||
if (filterPosition === _const2.default.FILTERS_POSITION_INLINE) {
|
||
if (filterRenderer) {
|
||
var onCustomFilter = onExternalFilter(column, filter.props.type);
|
||
filterElm = filterRenderer(onCustomFilter, column);
|
||
} else if (filter) {
|
||
filterElm = _react2.default.createElement(filter.Filter, _extends({}, filter.props, {
|
||
filterState: currFilters[column.dataField],
|
||
onFilter: onFilter,
|
||
column: column
|
||
}));
|
||
}
|
||
}
|
||
|
||
var children = headerFormatter ? headerFormatter(column, index, { sortElement: sortSymbol, filterElement: filterElm }) : text;
|
||
|
||
if (headerFormatter) {
|
||
return _react2.default.createElement('th', cellAttrs, children);
|
||
}
|
||
|
||
return _react2.default.createElement('th', cellAttrs, children, sortSymbol, filterElm);
|
||
}
|
||
}]);
|
||
|
||
return HeaderCell;
|
||
}((0, _cellEventDelegater2.default)(_react2.default.Component));
|
||
|
||
HeaderCell.propTypes = {
|
||
column: _propTypes2.default.shape({
|
||
dataField: _propTypes2.default.string.isRequired,
|
||
text: _propTypes2.default.string.isRequired,
|
||
type: _propTypes2.default.oneOf([_const2.default.TYPE_STRING, _const2.default.TYPE_NUMBER, _const2.default.TYPE_BOOLEAN, _const2.default.TYPE_DATE]),
|
||
isDummyField: _propTypes2.default.bool,
|
||
hidden: _propTypes2.default.bool,
|
||
headerFormatter: _propTypes2.default.func,
|
||
formatter: _propTypes2.default.func,
|
||
formatExtraData: _propTypes2.default.any,
|
||
headerClasses: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
classes: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
headerStyle: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
style: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
headerTitle: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.func]),
|
||
title: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.func]),
|
||
headerEvents: _propTypes2.default.object,
|
||
events: _propTypes2.default.object,
|
||
headerAlign: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
align: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
headerAttrs: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
attrs: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
sort: _propTypes2.default.bool,
|
||
sortFunc: _propTypes2.default.func,
|
||
onSort: _propTypes2.default.func,
|
||
editor: _propTypes2.default.object,
|
||
editable: _propTypes2.default.oneOfType([_propTypes2.default.bool, _propTypes2.default.func]),
|
||
editCellStyle: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
editCellClasses: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
editorStyle: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func]),
|
||
editorClasses: _propTypes2.default.oneOfType([_propTypes2.default.string, _propTypes2.default.func]),
|
||
editorRenderer: _propTypes2.default.func,
|
||
validator: _propTypes2.default.func,
|
||
filter: _propTypes2.default.object,
|
||
filterRenderer: _propTypes2.default.func,
|
||
filterValue: _propTypes2.default.func,
|
||
searchable: _propTypes2.default.bool
|
||
}).isRequired,
|
||
index: _propTypes2.default.number.isRequired,
|
||
onSort: _propTypes2.default.func,
|
||
sorting: _propTypes2.default.bool,
|
||
sortOrder: _propTypes2.default.oneOf([_const2.default.SORT_ASC, _const2.default.SORT_DESC]),
|
||
sortCaret: _propTypes2.default.func,
|
||
isLastSorting: _propTypes2.default.bool,
|
||
onFilter: _propTypes2.default.func,
|
||
filterPosition: _propTypes2.default.oneOf([_const2.default.FILTERS_POSITION_INLINE, _const2.default.FILTERS_POSITION_BOTTOM, _const2.default.FILTERS_POSITION_TOP]),
|
||
currFilters: _propTypes2.default.object,
|
||
onExternalFilter: _propTypes2.default.func
|
||
};
|
||
|
||
exports.default = HeaderCell;
|
||
|
||
/***/ }),
|
||
/* 28 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _bootstrap = __webpack_require__(5);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var SortSymbol = function SortSymbol() {
|
||
return _react2.default.createElement(
|
||
_bootstrap.BootstrapContext.Consumer,
|
||
null,
|
||
function (_ref) {
|
||
var bootstrap4 = _ref.bootstrap4;
|
||
return bootstrap4 ? _react2.default.createElement('span', { className: 'order-4' }) : _react2.default.createElement(
|
||
'span',
|
||
{ className: 'order' },
|
||
_react2.default.createElement(
|
||
'span',
|
||
{ className: 'dropdown' },
|
||
_react2.default.createElement('span', { className: 'caret' })
|
||
),
|
||
_react2.default.createElement(
|
||
'span',
|
||
{ className: 'dropup' },
|
||
_react2.default.createElement('span', { className: 'caret' })
|
||
)
|
||
);
|
||
}
|
||
);
|
||
};
|
||
|
||
exports.default = SortSymbol;
|
||
|
||
/***/ }),
|
||
/* 29 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _classnames = __webpack_require__(4);
|
||
|
||
var _classnames2 = _interopRequireDefault(_classnames);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
var _bootstrap = __webpack_require__(5);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var SortCaret = function SortCaret(_ref) {
|
||
var order = _ref.order;
|
||
|
||
var orderClass = (0, _classnames2.default)('react-bootstrap-table-sort-order', {
|
||
dropup: order === _const2.default.SORT_ASC
|
||
});
|
||
|
||
return _react2.default.createElement(
|
||
_bootstrap.BootstrapContext.Consumer,
|
||
null,
|
||
function (_ref2) {
|
||
var bootstrap4 = _ref2.bootstrap4;
|
||
return bootstrap4 ? _react2.default.createElement('span', { className: 'caret-4-' + order }) : _react2.default.createElement(
|
||
'span',
|
||
{ className: orderClass },
|
||
_react2.default.createElement('span', { className: 'caret' })
|
||
);
|
||
}
|
||
);
|
||
};
|
||
|
||
SortCaret.propTypes = {
|
||
order: _propTypes2.default.oneOf([_const2.default.SORT_ASC, _const2.default.SORT_DESC]).isRequired
|
||
};
|
||
|
||
exports.default = SortCaret;
|
||
|
||
/***/ }),
|
||
/* 30 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
/* WEBPACK VAR INJECTION */(function(global, module) {var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;// Underscore.js 1.9.1
|
||
// http://underscorejs.org
|
||
// (c) 2009-2018 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors
|
||
// Underscore may be freely distributed under the MIT license.
|
||
|
||
(function() {
|
||
|
||
// Baseline setup
|
||
// --------------
|
||
|
||
// Establish the root object, `window` (`self`) in the browser, `global`
|
||
// on the server, or `this` in some virtual machines. We use `self`
|
||
// instead of `window` for `WebWorker` support.
|
||
var root = typeof self == 'object' && self.self === self && self ||
|
||
typeof global == 'object' && global.global === global && global ||
|
||
this ||
|
||
{};
|
||
|
||
// Save the previous value of the `_` variable.
|
||
var previousUnderscore = root._;
|
||
|
||
// Save bytes in the minified (but not gzipped) version:
|
||
var ArrayProto = Array.prototype, ObjProto = Object.prototype;
|
||
var SymbolProto = typeof Symbol !== 'undefined' ? Symbol.prototype : null;
|
||
|
||
// Create quick reference variables for speed access to core prototypes.
|
||
var push = ArrayProto.push,
|
||
slice = ArrayProto.slice,
|
||
toString = ObjProto.toString,
|
||
hasOwnProperty = ObjProto.hasOwnProperty;
|
||
|
||
// All **ECMAScript 5** native function implementations that we hope to use
|
||
// are declared here.
|
||
var nativeIsArray = Array.isArray,
|
||
nativeKeys = Object.keys,
|
||
nativeCreate = Object.create;
|
||
|
||
// Naked function reference for surrogate-prototype-swapping.
|
||
var Ctor = function(){};
|
||
|
||
// Create a safe reference to the Underscore object for use below.
|
||
var _ = function(obj) {
|
||
if (obj instanceof _) return obj;
|
||
if (!(this instanceof _)) return new _(obj);
|
||
this._wrapped = obj;
|
||
};
|
||
|
||
// Export the Underscore object for **Node.js**, with
|
||
// backwards-compatibility for their old module API. If we're in
|
||
// the browser, add `_` as a global object.
|
||
// (`nodeType` is checked to ensure that `module`
|
||
// and `exports` are not HTML elements.)
|
||
if (typeof exports != 'undefined' && !exports.nodeType) {
|
||
if (typeof module != 'undefined' && !module.nodeType && module.exports) {
|
||
exports = module.exports = _;
|
||
}
|
||
exports._ = _;
|
||
} else {
|
||
root._ = _;
|
||
}
|
||
|
||
// Current version.
|
||
_.VERSION = '1.9.1';
|
||
|
||
// Internal function that returns an efficient (for current engines) version
|
||
// of the passed-in callback, to be repeatedly applied in other Underscore
|
||
// functions.
|
||
var optimizeCb = function(func, context, argCount) {
|
||
if (context === void 0) return func;
|
||
switch (argCount == null ? 3 : argCount) {
|
||
case 1: return function(value) {
|
||
return func.call(context, value);
|
||
};
|
||
// The 2-argument case is omitted because we’re not using it.
|
||
case 3: return function(value, index, collection) {
|
||
return func.call(context, value, index, collection);
|
||
};
|
||
case 4: return function(accumulator, value, index, collection) {
|
||
return func.call(context, accumulator, value, index, collection);
|
||
};
|
||
}
|
||
return function() {
|
||
return func.apply(context, arguments);
|
||
};
|
||
};
|
||
|
||
var builtinIteratee;
|
||
|
||
// An internal function to generate callbacks that can be applied to each
|
||
// element in a collection, returning the desired result — either `identity`,
|
||
// an arbitrary callback, a property matcher, or a property accessor.
|
||
var cb = function(value, context, argCount) {
|
||
if (_.iteratee !== builtinIteratee) return _.iteratee(value, context);
|
||
if (value == null) return _.identity;
|
||
if (_.isFunction(value)) return optimizeCb(value, context, argCount);
|
||
if (_.isObject(value) && !_.isArray(value)) return _.matcher(value);
|
||
return _.property(value);
|
||
};
|
||
|
||
// External wrapper for our callback generator. Users may customize
|
||
// `_.iteratee` if they want additional predicate/iteratee shorthand styles.
|
||
// This abstraction hides the internal-only argCount argument.
|
||
_.iteratee = builtinIteratee = function(value, context) {
|
||
return cb(value, context, Infinity);
|
||
};
|
||
|
||
// Some functions take a variable number of arguments, or a few expected
|
||
// arguments at the beginning and then a variable number of values to operate
|
||
// on. This helper accumulates all remaining arguments past the function’s
|
||
// argument length (or an explicit `startIndex`), into an array that becomes
|
||
// the last argument. Similar to ES6’s "rest parameter".
|
||
var restArguments = function(func, startIndex) {
|
||
startIndex = startIndex == null ? func.length - 1 : +startIndex;
|
||
return function() {
|
||
var length = Math.max(arguments.length - startIndex, 0),
|
||
rest = Array(length),
|
||
index = 0;
|
||
for (; index < length; index++) {
|
||
rest[index] = arguments[index + startIndex];
|
||
}
|
||
switch (startIndex) {
|
||
case 0: return func.call(this, rest);
|
||
case 1: return func.call(this, arguments[0], rest);
|
||
case 2: return func.call(this, arguments[0], arguments[1], rest);
|
||
}
|
||
var args = Array(startIndex + 1);
|
||
for (index = 0; index < startIndex; index++) {
|
||
args[index] = arguments[index];
|
||
}
|
||
args[startIndex] = rest;
|
||
return func.apply(this, args);
|
||
};
|
||
};
|
||
|
||
// An internal function for creating a new object that inherits from another.
|
||
var baseCreate = function(prototype) {
|
||
if (!_.isObject(prototype)) return {};
|
||
if (nativeCreate) return nativeCreate(prototype);
|
||
Ctor.prototype = prototype;
|
||
var result = new Ctor;
|
||
Ctor.prototype = null;
|
||
return result;
|
||
};
|
||
|
||
var shallowProperty = function(key) {
|
||
return function(obj) {
|
||
return obj == null ? void 0 : obj[key];
|
||
};
|
||
};
|
||
|
||
var has = function(obj, path) {
|
||
return obj != null && hasOwnProperty.call(obj, path);
|
||
}
|
||
|
||
var deepGet = function(obj, path) {
|
||
var length = path.length;
|
||
for (var i = 0; i < length; i++) {
|
||
if (obj == null) return void 0;
|
||
obj = obj[path[i]];
|
||
}
|
||
return length ? obj : void 0;
|
||
};
|
||
|
||
// Helper for collection methods to determine whether a collection
|
||
// should be iterated as an array or as an object.
|
||
// Related: http://people.mozilla.org/~jorendorff/es6-draft.html#sec-tolength
|
||
// Avoids a very nasty iOS 8 JIT bug on ARM-64. #2094
|
||
var MAX_ARRAY_INDEX = Math.pow(2, 53) - 1;
|
||
var getLength = shallowProperty('length');
|
||
var isArrayLike = function(collection) {
|
||
var length = getLength(collection);
|
||
return typeof length == 'number' && length >= 0 && length <= MAX_ARRAY_INDEX;
|
||
};
|
||
|
||
// Collection Functions
|
||
// --------------------
|
||
|
||
// The cornerstone, an `each` implementation, aka `forEach`.
|
||
// Handles raw objects in addition to array-likes. Treats all
|
||
// sparse array-likes as if they were dense.
|
||
_.each = _.forEach = function(obj, iteratee, context) {
|
||
iteratee = optimizeCb(iteratee, context);
|
||
var i, length;
|
||
if (isArrayLike(obj)) {
|
||
for (i = 0, length = obj.length; i < length; i++) {
|
||
iteratee(obj[i], i, obj);
|
||
}
|
||
} else {
|
||
var keys = _.keys(obj);
|
||
for (i = 0, length = keys.length; i < length; i++) {
|
||
iteratee(obj[keys[i]], keys[i], obj);
|
||
}
|
||
}
|
||
return obj;
|
||
};
|
||
|
||
// Return the results of applying the iteratee to each element.
|
||
_.map = _.collect = function(obj, iteratee, context) {
|
||
iteratee = cb(iteratee, context);
|
||
var keys = !isArrayLike(obj) && _.keys(obj),
|
||
length = (keys || obj).length,
|
||
results = Array(length);
|
||
for (var index = 0; index < length; index++) {
|
||
var currentKey = keys ? keys[index] : index;
|
||
results[index] = iteratee(obj[currentKey], currentKey, obj);
|
||
}
|
||
return results;
|
||
};
|
||
|
||
// Create a reducing function iterating left or right.
|
||
var createReduce = function(dir) {
|
||
// Wrap code that reassigns argument variables in a separate function than
|
||
// the one that accesses `arguments.length` to avoid a perf hit. (#1991)
|
||
var reducer = function(obj, iteratee, memo, initial) {
|
||
var keys = !isArrayLike(obj) && _.keys(obj),
|
||
length = (keys || obj).length,
|
||
index = dir > 0 ? 0 : length - 1;
|
||
if (!initial) {
|
||
memo = obj[keys ? keys[index] : index];
|
||
index += dir;
|
||
}
|
||
for (; index >= 0 && index < length; index += dir) {
|
||
var currentKey = keys ? keys[index] : index;
|
||
memo = iteratee(memo, obj[currentKey], currentKey, obj);
|
||
}
|
||
return memo;
|
||
};
|
||
|
||
return function(obj, iteratee, memo, context) {
|
||
var initial = arguments.length >= 3;
|
||
return reducer(obj, optimizeCb(iteratee, context, 4), memo, initial);
|
||
};
|
||
};
|
||
|
||
// **Reduce** builds up a single result from a list of values, aka `inject`,
|
||
// or `foldl`.
|
||
_.reduce = _.foldl = _.inject = createReduce(1);
|
||
|
||
// The right-associative version of reduce, also known as `foldr`.
|
||
_.reduceRight = _.foldr = createReduce(-1);
|
||
|
||
// Return the first value which passes a truth test. Aliased as `detect`.
|
||
_.find = _.detect = function(obj, predicate, context) {
|
||
var keyFinder = isArrayLike(obj) ? _.findIndex : _.findKey;
|
||
var key = keyFinder(obj, predicate, context);
|
||
if (key !== void 0 && key !== -1) return obj[key];
|
||
};
|
||
|
||
// Return all the elements that pass a truth test.
|
||
// Aliased as `select`.
|
||
_.filter = _.select = function(obj, predicate, context) {
|
||
var results = [];
|
||
predicate = cb(predicate, context);
|
||
_.each(obj, function(value, index, list) {
|
||
if (predicate(value, index, list)) results.push(value);
|
||
});
|
||
return results;
|
||
};
|
||
|
||
// Return all the elements for which a truth test fails.
|
||
_.reject = function(obj, predicate, context) {
|
||
return _.filter(obj, _.negate(cb(predicate)), context);
|
||
};
|
||
|
||
// Determine whether all of the elements match a truth test.
|
||
// Aliased as `all`.
|
||
_.every = _.all = function(obj, predicate, context) {
|
||
predicate = cb(predicate, context);
|
||
var keys = !isArrayLike(obj) && _.keys(obj),
|
||
length = (keys || obj).length;
|
||
for (var index = 0; index < length; index++) {
|
||
var currentKey = keys ? keys[index] : index;
|
||
if (!predicate(obj[currentKey], currentKey, obj)) return false;
|
||
}
|
||
return true;
|
||
};
|
||
|
||
// Determine if at least one element in the object matches a truth test.
|
||
// Aliased as `any`.
|
||
_.some = _.any = function(obj, predicate, context) {
|
||
predicate = cb(predicate, context);
|
||
var keys = !isArrayLike(obj) && _.keys(obj),
|
||
length = (keys || obj).length;
|
||
for (var index = 0; index < length; index++) {
|
||
var currentKey = keys ? keys[index] : index;
|
||
if (predicate(obj[currentKey], currentKey, obj)) return true;
|
||
}
|
||
return false;
|
||
};
|
||
|
||
// Determine if the array or object contains a given item (using `===`).
|
||
// Aliased as `includes` and `include`.
|
||
_.contains = _.includes = _.include = function(obj, item, fromIndex, guard) {
|
||
if (!isArrayLike(obj)) obj = _.values(obj);
|
||
if (typeof fromIndex != 'number' || guard) fromIndex = 0;
|
||
return _.indexOf(obj, item, fromIndex) >= 0;
|
||
};
|
||
|
||
// Invoke a method (with arguments) on every item in a collection.
|
||
_.invoke = restArguments(function(obj, path, args) {
|
||
var contextPath, func;
|
||
if (_.isFunction(path)) {
|
||
func = path;
|
||
} else if (_.isArray(path)) {
|
||
contextPath = path.slice(0, -1);
|
||
path = path[path.length - 1];
|
||
}
|
||
return _.map(obj, function(context) {
|
||
var method = func;
|
||
if (!method) {
|
||
if (contextPath && contextPath.length) {
|
||
context = deepGet(context, contextPath);
|
||
}
|
||
if (context == null) return void 0;
|
||
method = context[path];
|
||
}
|
||
return method == null ? method : method.apply(context, args);
|
||
});
|
||
});
|
||
|
||
// Convenience version of a common use case of `map`: fetching a property.
|
||
_.pluck = function(obj, key) {
|
||
return _.map(obj, _.property(key));
|
||
};
|
||
|
||
// Convenience version of a common use case of `filter`: selecting only objects
|
||
// containing specific `key:value` pairs.
|
||
_.where = function(obj, attrs) {
|
||
return _.filter(obj, _.matcher(attrs));
|
||
};
|
||
|
||
// Convenience version of a common use case of `find`: getting the first object
|
||
// containing specific `key:value` pairs.
|
||
_.findWhere = function(obj, attrs) {
|
||
return _.find(obj, _.matcher(attrs));
|
||
};
|
||
|
||
// Return the maximum element (or element-based computation).
|
||
_.max = function(obj, iteratee, context) {
|
||
var result = -Infinity, lastComputed = -Infinity,
|
||
value, computed;
|
||
if (iteratee == null || typeof iteratee == 'number' && typeof obj[0] != 'object' && obj != null) {
|
||
obj = isArrayLike(obj) ? obj : _.values(obj);
|
||
for (var i = 0, length = obj.length; i < length; i++) {
|
||
value = obj[i];
|
||
if (value != null && value > result) {
|
||
result = value;
|
||
}
|
||
}
|
||
} else {
|
||
iteratee = cb(iteratee, context);
|
||
_.each(obj, function(v, index, list) {
|
||
computed = iteratee(v, index, list);
|
||
if (computed > lastComputed || computed === -Infinity && result === -Infinity) {
|
||
result = v;
|
||
lastComputed = computed;
|
||
}
|
||
});
|
||
}
|
||
return result;
|
||
};
|
||
|
||
// Return the minimum element (or element-based computation).
|
||
_.min = function(obj, iteratee, context) {
|
||
var result = Infinity, lastComputed = Infinity,
|
||
value, computed;
|
||
if (iteratee == null || typeof iteratee == 'number' && typeof obj[0] != 'object' && obj != null) {
|
||
obj = isArrayLike(obj) ? obj : _.values(obj);
|
||
for (var i = 0, length = obj.length; i < length; i++) {
|
||
value = obj[i];
|
||
if (value != null && value < result) {
|
||
result = value;
|
||
}
|
||
}
|
||
} else {
|
||
iteratee = cb(iteratee, context);
|
||
_.each(obj, function(v, index, list) {
|
||
computed = iteratee(v, index, list);
|
||
if (computed < lastComputed || computed === Infinity && result === Infinity) {
|
||
result = v;
|
||
lastComputed = computed;
|
||
}
|
||
});
|
||
}
|
||
return result;
|
||
};
|
||
|
||
// Shuffle a collection.
|
||
_.shuffle = function(obj) {
|
||
return _.sample(obj, Infinity);
|
||
};
|
||
|
||
// Sample **n** random values from a collection using the modern version of the
|
||
// [Fisher-Yates shuffle](http://en.wikipedia.org/wiki/Fisher–Yates_shuffle).
|
||
// If **n** is not specified, returns a single random element.
|
||
// The internal `guard` argument allows it to work with `map`.
|
||
_.sample = function(obj, n, guard) {
|
||
if (n == null || guard) {
|
||
if (!isArrayLike(obj)) obj = _.values(obj);
|
||
return obj[_.random(obj.length - 1)];
|
||
}
|
||
var sample = isArrayLike(obj) ? _.clone(obj) : _.values(obj);
|
||
var length = getLength(sample);
|
||
n = Math.max(Math.min(n, length), 0);
|
||
var last = length - 1;
|
||
for (var index = 0; index < n; index++) {
|
||
var rand = _.random(index, last);
|
||
var temp = sample[index];
|
||
sample[index] = sample[rand];
|
||
sample[rand] = temp;
|
||
}
|
||
return sample.slice(0, n);
|
||
};
|
||
|
||
// Sort the object's values by a criterion produced by an iteratee.
|
||
_.sortBy = function(obj, iteratee, context) {
|
||
var index = 0;
|
||
iteratee = cb(iteratee, context);
|
||
return _.pluck(_.map(obj, function(value, key, list) {
|
||
return {
|
||
value: value,
|
||
index: index++,
|
||
criteria: iteratee(value, key, list)
|
||
};
|
||
}).sort(function(left, right) {
|
||
var a = left.criteria;
|
||
var b = right.criteria;
|
||
if (a !== b) {
|
||
if (a > b || a === void 0) return 1;
|
||
if (a < b || b === void 0) return -1;
|
||
}
|
||
return left.index - right.index;
|
||
}), 'value');
|
||
};
|
||
|
||
// An internal function used for aggregate "group by" operations.
|
||
var group = function(behavior, partition) {
|
||
return function(obj, iteratee, context) {
|
||
var result = partition ? [[], []] : {};
|
||
iteratee = cb(iteratee, context);
|
||
_.each(obj, function(value, index) {
|
||
var key = iteratee(value, index, obj);
|
||
behavior(result, value, key);
|
||
});
|
||
return result;
|
||
};
|
||
};
|
||
|
||
// Groups the object's values by a criterion. Pass either a string attribute
|
||
// to group by, or a function that returns the criterion.
|
||
_.groupBy = group(function(result, value, key) {
|
||
if (has(result, key)) result[key].push(value); else result[key] = [value];
|
||
});
|
||
|
||
// Indexes the object's values by a criterion, similar to `groupBy`, but for
|
||
// when you know that your index values will be unique.
|
||
_.indexBy = group(function(result, value, key) {
|
||
result[key] = value;
|
||
});
|
||
|
||
// Counts instances of an object that group by a certain criterion. Pass
|
||
// either a string attribute to count by, or a function that returns the
|
||
// criterion.
|
||
_.countBy = group(function(result, value, key) {
|
||
if (has(result, key)) result[key]++; else result[key] = 1;
|
||
});
|
||
|
||
var reStrSymbol = /[^\ud800-\udfff]|[\ud800-\udbff][\udc00-\udfff]|[\ud800-\udfff]/g;
|
||
// Safely create a real, live array from anything iterable.
|
||
_.toArray = function(obj) {
|
||
if (!obj) return [];
|
||
if (_.isArray(obj)) return slice.call(obj);
|
||
if (_.isString(obj)) {
|
||
// Keep surrogate pair characters together
|
||
return obj.match(reStrSymbol);
|
||
}
|
||
if (isArrayLike(obj)) return _.map(obj, _.identity);
|
||
return _.values(obj);
|
||
};
|
||
|
||
// Return the number of elements in an object.
|
||
_.size = function(obj) {
|
||
if (obj == null) return 0;
|
||
return isArrayLike(obj) ? obj.length : _.keys(obj).length;
|
||
};
|
||
|
||
// Split a collection into two arrays: one whose elements all satisfy the given
|
||
// predicate, and one whose elements all do not satisfy the predicate.
|
||
_.partition = group(function(result, value, pass) {
|
||
result[pass ? 0 : 1].push(value);
|
||
}, true);
|
||
|
||
// Array Functions
|
||
// ---------------
|
||
|
||
// Get the first element of an array. Passing **n** will return the first N
|
||
// values in the array. Aliased as `head` and `take`. The **guard** check
|
||
// allows it to work with `_.map`.
|
||
_.first = _.head = _.take = function(array, n, guard) {
|
||
if (array == null || array.length < 1) return n == null ? void 0 : [];
|
||
if (n == null || guard) return array[0];
|
||
return _.initial(array, array.length - n);
|
||
};
|
||
|
||
// Returns everything but the last entry of the array. Especially useful on
|
||
// the arguments object. Passing **n** will return all the values in
|
||
// the array, excluding the last N.
|
||
_.initial = function(array, n, guard) {
|
||
return slice.call(array, 0, Math.max(0, array.length - (n == null || guard ? 1 : n)));
|
||
};
|
||
|
||
// Get the last element of an array. Passing **n** will return the last N
|
||
// values in the array.
|
||
_.last = function(array, n, guard) {
|
||
if (array == null || array.length < 1) return n == null ? void 0 : [];
|
||
if (n == null || guard) return array[array.length - 1];
|
||
return _.rest(array, Math.max(0, array.length - n));
|
||
};
|
||
|
||
// Returns everything but the first entry of the array. Aliased as `tail` and `drop`.
|
||
// Especially useful on the arguments object. Passing an **n** will return
|
||
// the rest N values in the array.
|
||
_.rest = _.tail = _.drop = function(array, n, guard) {
|
||
return slice.call(array, n == null || guard ? 1 : n);
|
||
};
|
||
|
||
// Trim out all falsy values from an array.
|
||
_.compact = function(array) {
|
||
return _.filter(array, Boolean);
|
||
};
|
||
|
||
// Internal implementation of a recursive `flatten` function.
|
||
var flatten = function(input, shallow, strict, output) {
|
||
output = output || [];
|
||
var idx = output.length;
|
||
for (var i = 0, length = getLength(input); i < length; i++) {
|
||
var value = input[i];
|
||
if (isArrayLike(value) && (_.isArray(value) || _.isArguments(value))) {
|
||
// Flatten current level of array or arguments object.
|
||
if (shallow) {
|
||
var j = 0, len = value.length;
|
||
while (j < len) output[idx++] = value[j++];
|
||
} else {
|
||
flatten(value, shallow, strict, output);
|
||
idx = output.length;
|
||
}
|
||
} else if (!strict) {
|
||
output[idx++] = value;
|
||
}
|
||
}
|
||
return output;
|
||
};
|
||
|
||
// Flatten out an array, either recursively (by default), or just one level.
|
||
_.flatten = function(array, shallow) {
|
||
return flatten(array, shallow, false);
|
||
};
|
||
|
||
// Return a version of the array that does not contain the specified value(s).
|
||
_.without = restArguments(function(array, otherArrays) {
|
||
return _.difference(array, otherArrays);
|
||
});
|
||
|
||
// Produce a duplicate-free version of the array. If the array has already
|
||
// been sorted, you have the option of using a faster algorithm.
|
||
// The faster algorithm will not work with an iteratee if the iteratee
|
||
// is not a one-to-one function, so providing an iteratee will disable
|
||
// the faster algorithm.
|
||
// Aliased as `unique`.
|
||
_.uniq = _.unique = function(array, isSorted, iteratee, context) {
|
||
if (!_.isBoolean(isSorted)) {
|
||
context = iteratee;
|
||
iteratee = isSorted;
|
||
isSorted = false;
|
||
}
|
||
if (iteratee != null) iteratee = cb(iteratee, context);
|
||
var result = [];
|
||
var seen = [];
|
||
for (var i = 0, length = getLength(array); i < length; i++) {
|
||
var value = array[i],
|
||
computed = iteratee ? iteratee(value, i, array) : value;
|
||
if (isSorted && !iteratee) {
|
||
if (!i || seen !== computed) result.push(value);
|
||
seen = computed;
|
||
} else if (iteratee) {
|
||
if (!_.contains(seen, computed)) {
|
||
seen.push(computed);
|
||
result.push(value);
|
||
}
|
||
} else if (!_.contains(result, value)) {
|
||
result.push(value);
|
||
}
|
||
}
|
||
return result;
|
||
};
|
||
|
||
// Produce an array that contains the union: each distinct element from all of
|
||
// the passed-in arrays.
|
||
_.union = restArguments(function(arrays) {
|
||
return _.uniq(flatten(arrays, true, true));
|
||
});
|
||
|
||
// Produce an array that contains every item shared between all the
|
||
// passed-in arrays.
|
||
_.intersection = function(array) {
|
||
var result = [];
|
||
var argsLength = arguments.length;
|
||
for (var i = 0, length = getLength(array); i < length; i++) {
|
||
var item = array[i];
|
||
if (_.contains(result, item)) continue;
|
||
var j;
|
||
for (j = 1; j < argsLength; j++) {
|
||
if (!_.contains(arguments[j], item)) break;
|
||
}
|
||
if (j === argsLength) result.push(item);
|
||
}
|
||
return result;
|
||
};
|
||
|
||
// Take the difference between one array and a number of other arrays.
|
||
// Only the elements present in just the first array will remain.
|
||
_.difference = restArguments(function(array, rest) {
|
||
rest = flatten(rest, true, true);
|
||
return _.filter(array, function(value){
|
||
return !_.contains(rest, value);
|
||
});
|
||
});
|
||
|
||
// Complement of _.zip. Unzip accepts an array of arrays and groups
|
||
// each array's elements on shared indices.
|
||
_.unzip = function(array) {
|
||
var length = array && _.max(array, getLength).length || 0;
|
||
var result = Array(length);
|
||
|
||
for (var index = 0; index < length; index++) {
|
||
result[index] = _.pluck(array, index);
|
||
}
|
||
return result;
|
||
};
|
||
|
||
// Zip together multiple lists into a single array -- elements that share
|
||
// an index go together.
|
||
_.zip = restArguments(_.unzip);
|
||
|
||
// Converts lists into objects. Pass either a single array of `[key, value]`
|
||
// pairs, or two parallel arrays of the same length -- one of keys, and one of
|
||
// the corresponding values. Passing by pairs is the reverse of _.pairs.
|
||
_.object = function(list, values) {
|
||
var result = {};
|
||
for (var i = 0, length = getLength(list); i < length; i++) {
|
||
if (values) {
|
||
result[list[i]] = values[i];
|
||
} else {
|
||
result[list[i][0]] = list[i][1];
|
||
}
|
||
}
|
||
return result;
|
||
};
|
||
|
||
// Generator function to create the findIndex and findLastIndex functions.
|
||
var createPredicateIndexFinder = function(dir) {
|
||
return function(array, predicate, context) {
|
||
predicate = cb(predicate, context);
|
||
var length = getLength(array);
|
||
var index = dir > 0 ? 0 : length - 1;
|
||
for (; index >= 0 && index < length; index += dir) {
|
||
if (predicate(array[index], index, array)) return index;
|
||
}
|
||
return -1;
|
||
};
|
||
};
|
||
|
||
// Returns the first index on an array-like that passes a predicate test.
|
||
_.findIndex = createPredicateIndexFinder(1);
|
||
_.findLastIndex = createPredicateIndexFinder(-1);
|
||
|
||
// Use a comparator function to figure out the smallest index at which
|
||
// an object should be inserted so as to maintain order. Uses binary search.
|
||
_.sortedIndex = function(array, obj, iteratee, context) {
|
||
iteratee = cb(iteratee, context, 1);
|
||
var value = iteratee(obj);
|
||
var low = 0, high = getLength(array);
|
||
while (low < high) {
|
||
var mid = Math.floor((low + high) / 2);
|
||
if (iteratee(array[mid]) < value) low = mid + 1; else high = mid;
|
||
}
|
||
return low;
|
||
};
|
||
|
||
// Generator function to create the indexOf and lastIndexOf functions.
|
||
var createIndexFinder = function(dir, predicateFind, sortedIndex) {
|
||
return function(array, item, idx) {
|
||
var i = 0, length = getLength(array);
|
||
if (typeof idx == 'number') {
|
||
if (dir > 0) {
|
||
i = idx >= 0 ? idx : Math.max(idx + length, i);
|
||
} else {
|
||
length = idx >= 0 ? Math.min(idx + 1, length) : idx + length + 1;
|
||
}
|
||
} else if (sortedIndex && idx && length) {
|
||
idx = sortedIndex(array, item);
|
||
return array[idx] === item ? idx : -1;
|
||
}
|
||
if (item !== item) {
|
||
idx = predicateFind(slice.call(array, i, length), _.isNaN);
|
||
return idx >= 0 ? idx + i : -1;
|
||
}
|
||
for (idx = dir > 0 ? i : length - 1; idx >= 0 && idx < length; idx += dir) {
|
||
if (array[idx] === item) return idx;
|
||
}
|
||
return -1;
|
||
};
|
||
};
|
||
|
||
// Return the position of the first occurrence of an item in an array,
|
||
// or -1 if the item is not included in the array.
|
||
// If the array is large and already in sort order, pass `true`
|
||
// for **isSorted** to use binary search.
|
||
_.indexOf = createIndexFinder(1, _.findIndex, _.sortedIndex);
|
||
_.lastIndexOf = createIndexFinder(-1, _.findLastIndex);
|
||
|
||
// Generate an integer Array containing an arithmetic progression. A port of
|
||
// the native Python `range()` function. See
|
||
// [the Python documentation](http://docs.python.org/library/functions.html#range).
|
||
_.range = function(start, stop, step) {
|
||
if (stop == null) {
|
||
stop = start || 0;
|
||
start = 0;
|
||
}
|
||
if (!step) {
|
||
step = stop < start ? -1 : 1;
|
||
}
|
||
|
||
var length = Math.max(Math.ceil((stop - start) / step), 0);
|
||
var range = Array(length);
|
||
|
||
for (var idx = 0; idx < length; idx++, start += step) {
|
||
range[idx] = start;
|
||
}
|
||
|
||
return range;
|
||
};
|
||
|
||
// Chunk a single array into multiple arrays, each containing `count` or fewer
|
||
// items.
|
||
_.chunk = function(array, count) {
|
||
if (count == null || count < 1) return [];
|
||
var result = [];
|
||
var i = 0, length = array.length;
|
||
while (i < length) {
|
||
result.push(slice.call(array, i, i += count));
|
||
}
|
||
return result;
|
||
};
|
||
|
||
// Function (ahem) Functions
|
||
// ------------------
|
||
|
||
// Determines whether to execute a function as a constructor
|
||
// or a normal function with the provided arguments.
|
||
var executeBound = function(sourceFunc, boundFunc, context, callingContext, args) {
|
||
if (!(callingContext instanceof boundFunc)) return sourceFunc.apply(context, args);
|
||
var self = baseCreate(sourceFunc.prototype);
|
||
var result = sourceFunc.apply(self, args);
|
||
if (_.isObject(result)) return result;
|
||
return self;
|
||
};
|
||
|
||
// Create a function bound to a given object (assigning `this`, and arguments,
|
||
// optionally). Delegates to **ECMAScript 5**'s native `Function.bind` if
|
||
// available.
|
||
_.bind = restArguments(function(func, context, args) {
|
||
if (!_.isFunction(func)) throw new TypeError('Bind must be called on a function');
|
||
var bound = restArguments(function(callArgs) {
|
||
return executeBound(func, bound, context, this, args.concat(callArgs));
|
||
});
|
||
return bound;
|
||
});
|
||
|
||
// Partially apply a function by creating a version that has had some of its
|
||
// arguments pre-filled, without changing its dynamic `this` context. _ acts
|
||
// as a placeholder by default, allowing any combination of arguments to be
|
||
// pre-filled. Set `_.partial.placeholder` for a custom placeholder argument.
|
||
_.partial = restArguments(function(func, boundArgs) {
|
||
var placeholder = _.partial.placeholder;
|
||
var bound = function() {
|
||
var position = 0, length = boundArgs.length;
|
||
var args = Array(length);
|
||
for (var i = 0; i < length; i++) {
|
||
args[i] = boundArgs[i] === placeholder ? arguments[position++] : boundArgs[i];
|
||
}
|
||
while (position < arguments.length) args.push(arguments[position++]);
|
||
return executeBound(func, bound, this, this, args);
|
||
};
|
||
return bound;
|
||
});
|
||
|
||
_.partial.placeholder = _;
|
||
|
||
// Bind a number of an object's methods to that object. Remaining arguments
|
||
// are the method names to be bound. Useful for ensuring that all callbacks
|
||
// defined on an object belong to it.
|
||
_.bindAll = restArguments(function(obj, keys) {
|
||
keys = flatten(keys, false, false);
|
||
var index = keys.length;
|
||
if (index < 1) throw new Error('bindAll must be passed function names');
|
||
while (index--) {
|
||
var key = keys[index];
|
||
obj[key] = _.bind(obj[key], obj);
|
||
}
|
||
});
|
||
|
||
// Memoize an expensive function by storing its results.
|
||
_.memoize = function(func, hasher) {
|
||
var memoize = function(key) {
|
||
var cache = memoize.cache;
|
||
var address = '' + (hasher ? hasher.apply(this, arguments) : key);
|
||
if (!has(cache, address)) cache[address] = func.apply(this, arguments);
|
||
return cache[address];
|
||
};
|
||
memoize.cache = {};
|
||
return memoize;
|
||
};
|
||
|
||
// Delays a function for the given number of milliseconds, and then calls
|
||
// it with the arguments supplied.
|
||
_.delay = restArguments(function(func, wait, args) {
|
||
return setTimeout(function() {
|
||
return func.apply(null, args);
|
||
}, wait);
|
||
});
|
||
|
||
// Defers a function, scheduling it to run after the current call stack has
|
||
// cleared.
|
||
_.defer = _.partial(_.delay, _, 1);
|
||
|
||
// Returns a function, that, when invoked, will only be triggered at most once
|
||
// during a given window of time. Normally, the throttled function will run
|
||
// as much as it can, without ever going more than once per `wait` duration;
|
||
// but if you'd like to disable the execution on the leading edge, pass
|
||
// `{leading: false}`. To disable execution on the trailing edge, ditto.
|
||
_.throttle = function(func, wait, options) {
|
||
var timeout, context, args, result;
|
||
var previous = 0;
|
||
if (!options) options = {};
|
||
|
||
var later = function() {
|
||
previous = options.leading === false ? 0 : _.now();
|
||
timeout = null;
|
||
result = func.apply(context, args);
|
||
if (!timeout) context = args = null;
|
||
};
|
||
|
||
var throttled = function() {
|
||
var now = _.now();
|
||
if (!previous && options.leading === false) previous = now;
|
||
var remaining = wait - (now - previous);
|
||
context = this;
|
||
args = arguments;
|
||
if (remaining <= 0 || remaining > wait) {
|
||
if (timeout) {
|
||
clearTimeout(timeout);
|
||
timeout = null;
|
||
}
|
||
previous = now;
|
||
result = func.apply(context, args);
|
||
if (!timeout) context = args = null;
|
||
} else if (!timeout && options.trailing !== false) {
|
||
timeout = setTimeout(later, remaining);
|
||
}
|
||
return result;
|
||
};
|
||
|
||
throttled.cancel = function() {
|
||
clearTimeout(timeout);
|
||
previous = 0;
|
||
timeout = context = args = null;
|
||
};
|
||
|
||
return throttled;
|
||
};
|
||
|
||
// Returns a function, that, as long as it continues to be invoked, will not
|
||
// be triggered. The function will be called after it stops being called for
|
||
// N milliseconds. If `immediate` is passed, trigger the function on the
|
||
// leading edge, instead of the trailing.
|
||
_.debounce = function(func, wait, immediate) {
|
||
var timeout, result;
|
||
|
||
var later = function(context, args) {
|
||
timeout = null;
|
||
if (args) result = func.apply(context, args);
|
||
};
|
||
|
||
var debounced = restArguments(function(args) {
|
||
if (timeout) clearTimeout(timeout);
|
||
if (immediate) {
|
||
var callNow = !timeout;
|
||
timeout = setTimeout(later, wait);
|
||
if (callNow) result = func.apply(this, args);
|
||
} else {
|
||
timeout = _.delay(later, wait, this, args);
|
||
}
|
||
|
||
return result;
|
||
});
|
||
|
||
debounced.cancel = function() {
|
||
clearTimeout(timeout);
|
||
timeout = null;
|
||
};
|
||
|
||
return debounced;
|
||
};
|
||
|
||
// Returns the first function passed as an argument to the second,
|
||
// allowing you to adjust arguments, run code before and after, and
|
||
// conditionally execute the original function.
|
||
_.wrap = function(func, wrapper) {
|
||
return _.partial(wrapper, func);
|
||
};
|
||
|
||
// Returns a negated version of the passed-in predicate.
|
||
_.negate = function(predicate) {
|
||
return function() {
|
||
return !predicate.apply(this, arguments);
|
||
};
|
||
};
|
||
|
||
// Returns a function that is the composition of a list of functions, each
|
||
// consuming the return value of the function that follows.
|
||
_.compose = function() {
|
||
var args = arguments;
|
||
var start = args.length - 1;
|
||
return function() {
|
||
var i = start;
|
||
var result = args[start].apply(this, arguments);
|
||
while (i--) result = args[i].call(this, result);
|
||
return result;
|
||
};
|
||
};
|
||
|
||
// Returns a function that will only be executed on and after the Nth call.
|
||
_.after = function(times, func) {
|
||
return function() {
|
||
if (--times < 1) {
|
||
return func.apply(this, arguments);
|
||
}
|
||
};
|
||
};
|
||
|
||
// Returns a function that will only be executed up to (but not including) the Nth call.
|
||
_.before = function(times, func) {
|
||
var memo;
|
||
return function() {
|
||
if (--times > 0) {
|
||
memo = func.apply(this, arguments);
|
||
}
|
||
if (times <= 1) func = null;
|
||
return memo;
|
||
};
|
||
};
|
||
|
||
// Returns a function that will be executed at most one time, no matter how
|
||
// often you call it. Useful for lazy initialization.
|
||
_.once = _.partial(_.before, 2);
|
||
|
||
_.restArguments = restArguments;
|
||
|
||
// Object Functions
|
||
// ----------------
|
||
|
||
// Keys in IE < 9 that won't be iterated by `for key in ...` and thus missed.
|
||
var hasEnumBug = !{toString: null}.propertyIsEnumerable('toString');
|
||
var nonEnumerableProps = ['valueOf', 'isPrototypeOf', 'toString',
|
||
'propertyIsEnumerable', 'hasOwnProperty', 'toLocaleString'];
|
||
|
||
var collectNonEnumProps = function(obj, keys) {
|
||
var nonEnumIdx = nonEnumerableProps.length;
|
||
var constructor = obj.constructor;
|
||
var proto = _.isFunction(constructor) && constructor.prototype || ObjProto;
|
||
|
||
// Constructor is a special case.
|
||
var prop = 'constructor';
|
||
if (has(obj, prop) && !_.contains(keys, prop)) keys.push(prop);
|
||
|
||
while (nonEnumIdx--) {
|
||
prop = nonEnumerableProps[nonEnumIdx];
|
||
if (prop in obj && obj[prop] !== proto[prop] && !_.contains(keys, prop)) {
|
||
keys.push(prop);
|
||
}
|
||
}
|
||
};
|
||
|
||
// Retrieve the names of an object's own properties.
|
||
// Delegates to **ECMAScript 5**'s native `Object.keys`.
|
||
_.keys = function(obj) {
|
||
if (!_.isObject(obj)) return [];
|
||
if (nativeKeys) return nativeKeys(obj);
|
||
var keys = [];
|
||
for (var key in obj) if (has(obj, key)) keys.push(key);
|
||
// Ahem, IE < 9.
|
||
if (hasEnumBug) collectNonEnumProps(obj, keys);
|
||
return keys;
|
||
};
|
||
|
||
// Retrieve all the property names of an object.
|
||
_.allKeys = function(obj) {
|
||
if (!_.isObject(obj)) return [];
|
||
var keys = [];
|
||
for (var key in obj) keys.push(key);
|
||
// Ahem, IE < 9.
|
||
if (hasEnumBug) collectNonEnumProps(obj, keys);
|
||
return keys;
|
||
};
|
||
|
||
// Retrieve the values of an object's properties.
|
||
_.values = function(obj) {
|
||
var keys = _.keys(obj);
|
||
var length = keys.length;
|
||
var values = Array(length);
|
||
for (var i = 0; i < length; i++) {
|
||
values[i] = obj[keys[i]];
|
||
}
|
||
return values;
|
||
};
|
||
|
||
// Returns the results of applying the iteratee to each element of the object.
|
||
// In contrast to _.map it returns an object.
|
||
_.mapObject = function(obj, iteratee, context) {
|
||
iteratee = cb(iteratee, context);
|
||
var keys = _.keys(obj),
|
||
length = keys.length,
|
||
results = {};
|
||
for (var index = 0; index < length; index++) {
|
||
var currentKey = keys[index];
|
||
results[currentKey] = iteratee(obj[currentKey], currentKey, obj);
|
||
}
|
||
return results;
|
||
};
|
||
|
||
// Convert an object into a list of `[key, value]` pairs.
|
||
// The opposite of _.object.
|
||
_.pairs = function(obj) {
|
||
var keys = _.keys(obj);
|
||
var length = keys.length;
|
||
var pairs = Array(length);
|
||
for (var i = 0; i < length; i++) {
|
||
pairs[i] = [keys[i], obj[keys[i]]];
|
||
}
|
||
return pairs;
|
||
};
|
||
|
||
// Invert the keys and values of an object. The values must be serializable.
|
||
_.invert = function(obj) {
|
||
var result = {};
|
||
var keys = _.keys(obj);
|
||
for (var i = 0, length = keys.length; i < length; i++) {
|
||
result[obj[keys[i]]] = keys[i];
|
||
}
|
||
return result;
|
||
};
|
||
|
||
// Return a sorted list of the function names available on the object.
|
||
// Aliased as `methods`.
|
||
_.functions = _.methods = function(obj) {
|
||
var names = [];
|
||
for (var key in obj) {
|
||
if (_.isFunction(obj[key])) names.push(key);
|
||
}
|
||
return names.sort();
|
||
};
|
||
|
||
// An internal function for creating assigner functions.
|
||
var createAssigner = function(keysFunc, defaults) {
|
||
return function(obj) {
|
||
var length = arguments.length;
|
||
if (defaults) obj = Object(obj);
|
||
if (length < 2 || obj == null) return obj;
|
||
for (var index = 1; index < length; index++) {
|
||
var source = arguments[index],
|
||
keys = keysFunc(source),
|
||
l = keys.length;
|
||
for (var i = 0; i < l; i++) {
|
||
var key = keys[i];
|
||
if (!defaults || obj[key] === void 0) obj[key] = source[key];
|
||
}
|
||
}
|
||
return obj;
|
||
};
|
||
};
|
||
|
||
// Extend a given object with all the properties in passed-in object(s).
|
||
_.extend = createAssigner(_.allKeys);
|
||
|
||
// Assigns a given object with all the own properties in the passed-in object(s).
|
||
// (https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object/assign)
|
||
_.extendOwn = _.assign = createAssigner(_.keys);
|
||
|
||
// Returns the first key on an object that passes a predicate test.
|
||
_.findKey = function(obj, predicate, context) {
|
||
predicate = cb(predicate, context);
|
||
var keys = _.keys(obj), key;
|
||
for (var i = 0, length = keys.length; i < length; i++) {
|
||
key = keys[i];
|
||
if (predicate(obj[key], key, obj)) return key;
|
||
}
|
||
};
|
||
|
||
// Internal pick helper function to determine if `obj` has key `key`.
|
||
var keyInObj = function(value, key, obj) {
|
||
return key in obj;
|
||
};
|
||
|
||
// Return a copy of the object only containing the whitelisted properties.
|
||
_.pick = restArguments(function(obj, keys) {
|
||
var result = {}, iteratee = keys[0];
|
||
if (obj == null) return result;
|
||
if (_.isFunction(iteratee)) {
|
||
if (keys.length > 1) iteratee = optimizeCb(iteratee, keys[1]);
|
||
keys = _.allKeys(obj);
|
||
} else {
|
||
iteratee = keyInObj;
|
||
keys = flatten(keys, false, false);
|
||
obj = Object(obj);
|
||
}
|
||
for (var i = 0, length = keys.length; i < length; i++) {
|
||
var key = keys[i];
|
||
var value = obj[key];
|
||
if (iteratee(value, key, obj)) result[key] = value;
|
||
}
|
||
return result;
|
||
});
|
||
|
||
// Return a copy of the object without the blacklisted properties.
|
||
_.omit = restArguments(function(obj, keys) {
|
||
var iteratee = keys[0], context;
|
||
if (_.isFunction(iteratee)) {
|
||
iteratee = _.negate(iteratee);
|
||
if (keys.length > 1) context = keys[1];
|
||
} else {
|
||
keys = _.map(flatten(keys, false, false), String);
|
||
iteratee = function(value, key) {
|
||
return !_.contains(keys, key);
|
||
};
|
||
}
|
||
return _.pick(obj, iteratee, context);
|
||
});
|
||
|
||
// Fill in a given object with default properties.
|
||
_.defaults = createAssigner(_.allKeys, true);
|
||
|
||
// Creates an object that inherits from the given prototype object.
|
||
// If additional properties are provided then they will be added to the
|
||
// created object.
|
||
_.create = function(prototype, props) {
|
||
var result = baseCreate(prototype);
|
||
if (props) _.extendOwn(result, props);
|
||
return result;
|
||
};
|
||
|
||
// Create a (shallow-cloned) duplicate of an object.
|
||
_.clone = function(obj) {
|
||
if (!_.isObject(obj)) return obj;
|
||
return _.isArray(obj) ? obj.slice() : _.extend({}, obj);
|
||
};
|
||
|
||
// Invokes interceptor with the obj, and then returns obj.
|
||
// The primary purpose of this method is to "tap into" a method chain, in
|
||
// order to perform operations on intermediate results within the chain.
|
||
_.tap = function(obj, interceptor) {
|
||
interceptor(obj);
|
||
return obj;
|
||
};
|
||
|
||
// Returns whether an object has a given set of `key:value` pairs.
|
||
_.isMatch = function(object, attrs) {
|
||
var keys = _.keys(attrs), length = keys.length;
|
||
if (object == null) return !length;
|
||
var obj = Object(object);
|
||
for (var i = 0; i < length; i++) {
|
||
var key = keys[i];
|
||
if (attrs[key] !== obj[key] || !(key in obj)) return false;
|
||
}
|
||
return true;
|
||
};
|
||
|
||
|
||
// Internal recursive comparison function for `isEqual`.
|
||
var eq, deepEq;
|
||
eq = function(a, b, aStack, bStack) {
|
||
// Identical objects are equal. `0 === -0`, but they aren't identical.
|
||
// See the [Harmony `egal` proposal](http://wiki.ecmascript.org/doku.php?id=harmony:egal).
|
||
if (a === b) return a !== 0 || 1 / a === 1 / b;
|
||
// `null` or `undefined` only equal to itself (strict comparison).
|
||
if (a == null || b == null) return false;
|
||
// `NaN`s are equivalent, but non-reflexive.
|
||
if (a !== a) return b !== b;
|
||
// Exhaust primitive checks
|
||
var type = typeof a;
|
||
if (type !== 'function' && type !== 'object' && typeof b != 'object') return false;
|
||
return deepEq(a, b, aStack, bStack);
|
||
};
|
||
|
||
// Internal recursive comparison function for `isEqual`.
|
||
deepEq = function(a, b, aStack, bStack) {
|
||
// Unwrap any wrapped objects.
|
||
if (a instanceof _) a = a._wrapped;
|
||
if (b instanceof _) b = b._wrapped;
|
||
// Compare `[[Class]]` names.
|
||
var className = toString.call(a);
|
||
if (className !== toString.call(b)) return false;
|
||
switch (className) {
|
||
// Strings, numbers, regular expressions, dates, and booleans are compared by value.
|
||
case '[object RegExp]':
|
||
// RegExps are coerced to strings for comparison (Note: '' + /a/i === '/a/i')
|
||
case '[object String]':
|
||
// Primitives and their corresponding object wrappers are equivalent; thus, `"5"` is
|
||
// equivalent to `new String("5")`.
|
||
return '' + a === '' + b;
|
||
case '[object Number]':
|
||
// `NaN`s are equivalent, but non-reflexive.
|
||
// Object(NaN) is equivalent to NaN.
|
||
if (+a !== +a) return +b !== +b;
|
||
// An `egal` comparison is performed for other numeric values.
|
||
return +a === 0 ? 1 / +a === 1 / b : +a === +b;
|
||
case '[object Date]':
|
||
case '[object Boolean]':
|
||
// Coerce dates and booleans to numeric primitive values. Dates are compared by their
|
||
// millisecond representations. Note that invalid dates with millisecond representations
|
||
// of `NaN` are not equivalent.
|
||
return +a === +b;
|
||
case '[object Symbol]':
|
||
return SymbolProto.valueOf.call(a) === SymbolProto.valueOf.call(b);
|
||
}
|
||
|
||
var areArrays = className === '[object Array]';
|
||
if (!areArrays) {
|
||
if (typeof a != 'object' || typeof b != 'object') return false;
|
||
|
||
// Objects with different constructors are not equivalent, but `Object`s or `Array`s
|
||
// from different frames are.
|
||
var aCtor = a.constructor, bCtor = b.constructor;
|
||
if (aCtor !== bCtor && !(_.isFunction(aCtor) && aCtor instanceof aCtor &&
|
||
_.isFunction(bCtor) && bCtor instanceof bCtor)
|
||
&& ('constructor' in a && 'constructor' in b)) {
|
||
return false;
|
||
}
|
||
}
|
||
// Assume equality for cyclic structures. The algorithm for detecting cyclic
|
||
// structures is adapted from ES 5.1 section 15.12.3, abstract operation `JO`.
|
||
|
||
// Initializing stack of traversed objects.
|
||
// It's done here since we only need them for objects and arrays comparison.
|
||
aStack = aStack || [];
|
||
bStack = bStack || [];
|
||
var length = aStack.length;
|
||
while (length--) {
|
||
// Linear search. Performance is inversely proportional to the number of
|
||
// unique nested structures.
|
||
if (aStack[length] === a) return bStack[length] === b;
|
||
}
|
||
|
||
// Add the first object to the stack of traversed objects.
|
||
aStack.push(a);
|
||
bStack.push(b);
|
||
|
||
// Recursively compare objects and arrays.
|
||
if (areArrays) {
|
||
// Compare array lengths to determine if a deep comparison is necessary.
|
||
length = a.length;
|
||
if (length !== b.length) return false;
|
||
// Deep compare the contents, ignoring non-numeric properties.
|
||
while (length--) {
|
||
if (!eq(a[length], b[length], aStack, bStack)) return false;
|
||
}
|
||
} else {
|
||
// Deep compare objects.
|
||
var keys = _.keys(a), key;
|
||
length = keys.length;
|
||
// Ensure that both objects contain the same number of properties before comparing deep equality.
|
||
if (_.keys(b).length !== length) return false;
|
||
while (length--) {
|
||
// Deep compare each member
|
||
key = keys[length];
|
||
if (!(has(b, key) && eq(a[key], b[key], aStack, bStack))) return false;
|
||
}
|
||
}
|
||
// Remove the first object from the stack of traversed objects.
|
||
aStack.pop();
|
||
bStack.pop();
|
||
return true;
|
||
};
|
||
|
||
// Perform a deep comparison to check if two objects are equal.
|
||
_.isEqual = function(a, b) {
|
||
return eq(a, b);
|
||
};
|
||
|
||
// Is a given array, string, or object empty?
|
||
// An "empty" object has no enumerable own-properties.
|
||
_.isEmpty = function(obj) {
|
||
if (obj == null) return true;
|
||
if (isArrayLike(obj) && (_.isArray(obj) || _.isString(obj) || _.isArguments(obj))) return obj.length === 0;
|
||
return _.keys(obj).length === 0;
|
||
};
|
||
|
||
// Is a given value a DOM element?
|
||
_.isElement = function(obj) {
|
||
return !!(obj && obj.nodeType === 1);
|
||
};
|
||
|
||
// Is a given value an array?
|
||
// Delegates to ECMA5's native Array.isArray
|
||
_.isArray = nativeIsArray || function(obj) {
|
||
return toString.call(obj) === '[object Array]';
|
||
};
|
||
|
||
// Is a given variable an object?
|
||
_.isObject = function(obj) {
|
||
var type = typeof obj;
|
||
return type === 'function' || type === 'object' && !!obj;
|
||
};
|
||
|
||
// Add some isType methods: isArguments, isFunction, isString, isNumber, isDate, isRegExp, isError, isMap, isWeakMap, isSet, isWeakSet.
|
||
_.each(['Arguments', 'Function', 'String', 'Number', 'Date', 'RegExp', 'Error', 'Symbol', 'Map', 'WeakMap', 'Set', 'WeakSet'], function(name) {
|
||
_['is' + name] = function(obj) {
|
||
return toString.call(obj) === '[object ' + name + ']';
|
||
};
|
||
});
|
||
|
||
// Define a fallback version of the method in browsers (ahem, IE < 9), where
|
||
// there isn't any inspectable "Arguments" type.
|
||
if (!_.isArguments(arguments)) {
|
||
_.isArguments = function(obj) {
|
||
return has(obj, 'callee');
|
||
};
|
||
}
|
||
|
||
// Optimize `isFunction` if appropriate. Work around some typeof bugs in old v8,
|
||
// IE 11 (#1621), Safari 8 (#1929), and PhantomJS (#2236).
|
||
var nodelist = root.document && root.document.childNodes;
|
||
if (typeof /./ != 'function' && typeof Int8Array != 'object' && typeof nodelist != 'function') {
|
||
_.isFunction = function(obj) {
|
||
return typeof obj == 'function' || false;
|
||
};
|
||
}
|
||
|
||
// Is a given object a finite number?
|
||
_.isFinite = function(obj) {
|
||
return !_.isSymbol(obj) && isFinite(obj) && !isNaN(parseFloat(obj));
|
||
};
|
||
|
||
// Is the given value `NaN`?
|
||
_.isNaN = function(obj) {
|
||
return _.isNumber(obj) && isNaN(obj);
|
||
};
|
||
|
||
// Is a given value a boolean?
|
||
_.isBoolean = function(obj) {
|
||
return obj === true || obj === false || toString.call(obj) === '[object Boolean]';
|
||
};
|
||
|
||
// Is a given value equal to null?
|
||
_.isNull = function(obj) {
|
||
return obj === null;
|
||
};
|
||
|
||
// Is a given variable undefined?
|
||
_.isUndefined = function(obj) {
|
||
return obj === void 0;
|
||
};
|
||
|
||
// Shortcut function for checking if an object has a given property directly
|
||
// on itself (in other words, not on a prototype).
|
||
_.has = function(obj, path) {
|
||
if (!_.isArray(path)) {
|
||
return has(obj, path);
|
||
}
|
||
var length = path.length;
|
||
for (var i = 0; i < length; i++) {
|
||
var key = path[i];
|
||
if (obj == null || !hasOwnProperty.call(obj, key)) {
|
||
return false;
|
||
}
|
||
obj = obj[key];
|
||
}
|
||
return !!length;
|
||
};
|
||
|
||
// Utility Functions
|
||
// -----------------
|
||
|
||
// Run Underscore.js in *noConflict* mode, returning the `_` variable to its
|
||
// previous owner. Returns a reference to the Underscore object.
|
||
_.noConflict = function() {
|
||
root._ = previousUnderscore;
|
||
return this;
|
||
};
|
||
|
||
// Keep the identity function around for default iteratees.
|
||
_.identity = function(value) {
|
||
return value;
|
||
};
|
||
|
||
// Predicate-generating functions. Often useful outside of Underscore.
|
||
_.constant = function(value) {
|
||
return function() {
|
||
return value;
|
||
};
|
||
};
|
||
|
||
_.noop = function(){};
|
||
|
||
// Creates a function that, when passed an object, will traverse that object’s
|
||
// properties down the given `path`, specified as an array of keys or indexes.
|
||
_.property = function(path) {
|
||
if (!_.isArray(path)) {
|
||
return shallowProperty(path);
|
||
}
|
||
return function(obj) {
|
||
return deepGet(obj, path);
|
||
};
|
||
};
|
||
|
||
// Generates a function for a given object that returns a given property.
|
||
_.propertyOf = function(obj) {
|
||
if (obj == null) {
|
||
return function(){};
|
||
}
|
||
return function(path) {
|
||
return !_.isArray(path) ? obj[path] : deepGet(obj, path);
|
||
};
|
||
};
|
||
|
||
// Returns a predicate for checking whether an object has a given set of
|
||
// `key:value` pairs.
|
||
_.matcher = _.matches = function(attrs) {
|
||
attrs = _.extendOwn({}, attrs);
|
||
return function(obj) {
|
||
return _.isMatch(obj, attrs);
|
||
};
|
||
};
|
||
|
||
// Run a function **n** times.
|
||
_.times = function(n, iteratee, context) {
|
||
var accum = Array(Math.max(0, n));
|
||
iteratee = optimizeCb(iteratee, context, 1);
|
||
for (var i = 0; i < n; i++) accum[i] = iteratee(i);
|
||
return accum;
|
||
};
|
||
|
||
// Return a random integer between min and max (inclusive).
|
||
_.random = function(min, max) {
|
||
if (max == null) {
|
||
max = min;
|
||
min = 0;
|
||
}
|
||
return min + Math.floor(Math.random() * (max - min + 1));
|
||
};
|
||
|
||
// A (possibly faster) way to get the current timestamp as an integer.
|
||
_.now = Date.now || function() {
|
||
return new Date().getTime();
|
||
};
|
||
|
||
// List of HTML entities for escaping.
|
||
var escapeMap = {
|
||
'&': '&',
|
||
'<': '<',
|
||
'>': '>',
|
||
'"': '"',
|
||
"'": ''',
|
||
'`': '`'
|
||
};
|
||
var unescapeMap = _.invert(escapeMap);
|
||
|
||
// Functions for escaping and unescaping strings to/from HTML interpolation.
|
||
var createEscaper = function(map) {
|
||
var escaper = function(match) {
|
||
return map[match];
|
||
};
|
||
// Regexes for identifying a key that needs to be escaped.
|
||
var source = '(?:' + _.keys(map).join('|') + ')';
|
||
var testRegexp = RegExp(source);
|
||
var replaceRegexp = RegExp(source, 'g');
|
||
return function(string) {
|
||
string = string == null ? '' : '' + string;
|
||
return testRegexp.test(string) ? string.replace(replaceRegexp, escaper) : string;
|
||
};
|
||
};
|
||
_.escape = createEscaper(escapeMap);
|
||
_.unescape = createEscaper(unescapeMap);
|
||
|
||
// Traverses the children of `obj` along `path`. If a child is a function, it
|
||
// is invoked with its parent as context. Returns the value of the final
|
||
// child, or `fallback` if any child is undefined.
|
||
_.result = function(obj, path, fallback) {
|
||
if (!_.isArray(path)) path = [path];
|
||
var length = path.length;
|
||
if (!length) {
|
||
return _.isFunction(fallback) ? fallback.call(obj) : fallback;
|
||
}
|
||
for (var i = 0; i < length; i++) {
|
||
var prop = obj == null ? void 0 : obj[path[i]];
|
||
if (prop === void 0) {
|
||
prop = fallback;
|
||
i = length; // Ensure we don't continue iterating.
|
||
}
|
||
obj = _.isFunction(prop) ? prop.call(obj) : prop;
|
||
}
|
||
return obj;
|
||
};
|
||
|
||
// Generate a unique integer id (unique within the entire client session).
|
||
// Useful for temporary DOM ids.
|
||
var idCounter = 0;
|
||
_.uniqueId = function(prefix) {
|
||
var id = ++idCounter + '';
|
||
return prefix ? prefix + id : id;
|
||
};
|
||
|
||
// By default, Underscore uses ERB-style template delimiters, change the
|
||
// following template settings to use alternative delimiters.
|
||
_.templateSettings = {
|
||
evaluate: /<%([\s\S]+?)%>/g,
|
||
interpolate: /<%=([\s\S]+?)%>/g,
|
||
escape: /<%-([\s\S]+?)%>/g
|
||
};
|
||
|
||
// When customizing `templateSettings`, if you don't want to define an
|
||
// interpolation, evaluation or escaping regex, we need one that is
|
||
// guaranteed not to match.
|
||
var noMatch = /(.)^/;
|
||
|
||
// Certain characters need to be escaped so that they can be put into a
|
||
// string literal.
|
||
var escapes = {
|
||
"'": "'",
|
||
'\\': '\\',
|
||
'\r': 'r',
|
||
'\n': 'n',
|
||
'\u2028': 'u2028',
|
||
'\u2029': 'u2029'
|
||
};
|
||
|
||
var escapeRegExp = /\\|'|\r|\n|\u2028|\u2029/g;
|
||
|
||
var escapeChar = function(match) {
|
||
return '\\' + escapes[match];
|
||
};
|
||
|
||
// JavaScript micro-templating, similar to John Resig's implementation.
|
||
// Underscore templating handles arbitrary delimiters, preserves whitespace,
|
||
// and correctly escapes quotes within interpolated code.
|
||
// NB: `oldSettings` only exists for backwards compatibility.
|
||
_.template = function(text, settings, oldSettings) {
|
||
if (!settings && oldSettings) settings = oldSettings;
|
||
settings = _.defaults({}, settings, _.templateSettings);
|
||
|
||
// Combine delimiters into one regular expression via alternation.
|
||
var matcher = RegExp([
|
||
(settings.escape || noMatch).source,
|
||
(settings.interpolate || noMatch).source,
|
||
(settings.evaluate || noMatch).source
|
||
].join('|') + '|$', 'g');
|
||
|
||
// Compile the template source, escaping string literals appropriately.
|
||
var index = 0;
|
||
var source = "__p+='";
|
||
text.replace(matcher, function(match, escape, interpolate, evaluate, offset) {
|
||
source += text.slice(index, offset).replace(escapeRegExp, escapeChar);
|
||
index = offset + match.length;
|
||
|
||
if (escape) {
|
||
source += "'+\n((__t=(" + escape + "))==null?'':_.escape(__t))+\n'";
|
||
} else if (interpolate) {
|
||
source += "'+\n((__t=(" + interpolate + "))==null?'':__t)+\n'";
|
||
} else if (evaluate) {
|
||
source += "';\n" + evaluate + "\n__p+='";
|
||
}
|
||
|
||
// Adobe VMs need the match returned to produce the correct offset.
|
||
return match;
|
||
});
|
||
source += "';\n";
|
||
|
||
// If a variable is not specified, place data values in local scope.
|
||
if (!settings.variable) source = 'with(obj||{}){\n' + source + '}\n';
|
||
|
||
source = "var __t,__p='',__j=Array.prototype.join," +
|
||
"print=function(){__p+=__j.call(arguments,'');};\n" +
|
||
source + 'return __p;\n';
|
||
|
||
var render;
|
||
try {
|
||
render = new Function(settings.variable || 'obj', '_', source);
|
||
} catch (e) {
|
||
e.source = source;
|
||
throw e;
|
||
}
|
||
|
||
var template = function(data) {
|
||
return render.call(this, data, _);
|
||
};
|
||
|
||
// Provide the compiled source as a convenience for precompilation.
|
||
var argument = settings.variable || 'obj';
|
||
template.source = 'function(' + argument + '){\n' + source + '}';
|
||
|
||
return template;
|
||
};
|
||
|
||
// Add a "chain" function. Start chaining a wrapped Underscore object.
|
||
_.chain = function(obj) {
|
||
var instance = _(obj);
|
||
instance._chain = true;
|
||
return instance;
|
||
};
|
||
|
||
// OOP
|
||
// ---------------
|
||
// If Underscore is called as a function, it returns a wrapped object that
|
||
// can be used OO-style. This wrapper holds altered versions of all the
|
||
// underscore functions. Wrapped objects may be chained.
|
||
|
||
// Helper function to continue chaining intermediate results.
|
||
var chainResult = function(instance, obj) {
|
||
return instance._chain ? _(obj).chain() : obj;
|
||
};
|
||
|
||
// Add your own custom functions to the Underscore object.
|
||
_.mixin = function(obj) {
|
||
_.each(_.functions(obj), function(name) {
|
||
var func = _[name] = obj[name];
|
||
_.prototype[name] = function() {
|
||
var args = [this._wrapped];
|
||
push.apply(args, arguments);
|
||
return chainResult(this, func.apply(_, args));
|
||
};
|
||
});
|
||
return _;
|
||
};
|
||
|
||
// Add all of the Underscore functions to the wrapper object.
|
||
_.mixin(_);
|
||
|
||
// Add all mutator Array functions to the wrapper.
|
||
_.each(['pop', 'push', 'reverse', 'shift', 'sort', 'splice', 'unshift'], function(name) {
|
||
var method = ArrayProto[name];
|
||
_.prototype[name] = function() {
|
||
var obj = this._wrapped;
|
||
method.apply(obj, arguments);
|
||
if ((name === 'shift' || name === 'splice') && obj.length === 0) delete obj[0];
|
||
return chainResult(this, obj);
|
||
};
|
||
});
|
||
|
||
// Add all accessor Array functions to the wrapper.
|
||
_.each(['concat', 'join', 'slice'], function(name) {
|
||
var method = ArrayProto[name];
|
||
_.prototype[name] = function() {
|
||
return chainResult(this, method.apply(this._wrapped, arguments));
|
||
};
|
||
});
|
||
|
||
// Extracts the result from a wrapped and chained object.
|
||
_.prototype.value = function() {
|
||
return this._wrapped;
|
||
};
|
||
|
||
// Provide unwrapping proxy for some methods used in engine operations
|
||
// such as arithmetic and JSON stringification.
|
||
_.prototype.valueOf = _.prototype.toJSON = _.prototype.value;
|
||
|
||
_.prototype.toString = function() {
|
||
return String(this._wrapped);
|
||
};
|
||
|
||
// AMD registration happens at the end for compatibility with AMD loaders
|
||
// that may not enforce next-turn semantics on modules. Even though general
|
||
// practice for AMD registration is to be anonymous, underscore registers
|
||
// as a named module because, like jQuery, it is a base library that is
|
||
// popular enough to be bundled in a third party lib, but not be part of
|
||
// an AMD load request. Those cases could generate an error when an
|
||
// anonymous define() is called outside of a loader request.
|
||
if (true) {
|
||
!(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = function() {
|
||
return _;
|
||
}.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__),
|
||
__WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__));
|
||
}
|
||
}());
|
||
|
||
/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(31), __webpack_require__(32)(module)))
|
||
|
||
/***/ }),
|
||
/* 31 */
|
||
/***/ (function(module, exports) {
|
||
|
||
var g;
|
||
|
||
// This works in non-strict mode
|
||
g = (function() {
|
||
return this;
|
||
})();
|
||
|
||
try {
|
||
// This works if eval is allowed (see CSP)
|
||
g = g || Function("return this")() || (1,eval)("this");
|
||
} catch(e) {
|
||
// This works if the window reference is available
|
||
if(typeof window === "object")
|
||
g = window;
|
||
}
|
||
|
||
// g can still be undefined, but nothing to do about it...
|
||
// We return undefined, instead of nothing here, so it's
|
||
// easier to handle this case. if(!global) { ...}
|
||
|
||
module.exports = g;
|
||
|
||
|
||
/***/ }),
|
||
/* 32 */
|
||
/***/ (function(module, exports) {
|
||
|
||
module.exports = function(module) {
|
||
if(!module.webpackPolyfill) {
|
||
module.deprecate = function() {};
|
||
module.paths = [];
|
||
// module.parent = undefined by default
|
||
if(!module.children) module.children = [];
|
||
Object.defineProperty(module, "loaded", {
|
||
enumerable: true,
|
||
get: function() {
|
||
return module.l;
|
||
}
|
||
});
|
||
Object.defineProperty(module, "id", {
|
||
enumerable: true,
|
||
get: function() {
|
||
return module.i;
|
||
}
|
||
});
|
||
module.webpackPolyfill = 1;
|
||
}
|
||
return module;
|
||
};
|
||
|
||
|
||
/***/ }),
|
||
/* 33 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.CheckBox = undefined;
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
var _bootstrap = __webpack_require__(5);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/require-default-props: 0 */
|
||
|
||
|
||
var CheckBox = exports.CheckBox = function CheckBox(_ref) {
|
||
var className = _ref.className,
|
||
checked = _ref.checked,
|
||
indeterminate = _ref.indeterminate;
|
||
return _react2.default.createElement('input', {
|
||
type: 'checkbox',
|
||
checked: checked,
|
||
className: className,
|
||
ref: function ref(input) {
|
||
if (input) input.indeterminate = indeterminate; // eslint-disable-line no-param-reassign
|
||
},
|
||
onChange: function onChange() {}
|
||
});
|
||
};
|
||
|
||
CheckBox.propTypes = {
|
||
checked: _propTypes2.default.bool.isRequired,
|
||
indeterminate: _propTypes2.default.bool.isRequired,
|
||
className: _propTypes2.default.string
|
||
};
|
||
|
||
var SelectionHeaderCell = function (_Component) {
|
||
_inherits(SelectionHeaderCell, _Component);
|
||
|
||
function SelectionHeaderCell() {
|
||
_classCallCheck(this, SelectionHeaderCell);
|
||
|
||
var _this = _possibleConstructorReturn(this, (SelectionHeaderCell.__proto__ || Object.getPrototypeOf(SelectionHeaderCell)).call(this));
|
||
|
||
_this.handleCheckBoxClick = _this.handleCheckBoxClick.bind(_this);
|
||
return _this;
|
||
}
|
||
|
||
/**
|
||
* avoid updating if button is
|
||
* 1. radio
|
||
* 2. status was not changed.
|
||
*/
|
||
|
||
|
||
_createClass(SelectionHeaderCell, [{
|
||
key: 'shouldComponentUpdate',
|
||
value: function shouldComponentUpdate(nextProps) {
|
||
var ROW_SELECT_SINGLE = _const2.default.ROW_SELECT_SINGLE;
|
||
var _props = this.props,
|
||
mode = _props.mode,
|
||
checkedStatus = _props.checkedStatus;
|
||
|
||
|
||
if (mode === ROW_SELECT_SINGLE) return false;
|
||
|
||
return nextProps.checkedStatus !== checkedStatus;
|
||
}
|
||
}, {
|
||
key: 'handleCheckBoxClick',
|
||
value: function handleCheckBoxClick(e) {
|
||
var _props2 = this.props,
|
||
onAllRowsSelect = _props2.onAllRowsSelect,
|
||
checkedStatus = _props2.checkedStatus;
|
||
|
||
var isUnSelect = checkedStatus === _const2.default.CHECKBOX_STATUS_CHECKED || checkedStatus === _const2.default.CHECKBOX_STATUS_INDETERMINATE;
|
||
|
||
onAllRowsSelect(e, isUnSelect);
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _this2 = this;
|
||
|
||
var CHECKBOX_STATUS_CHECKED = _const2.default.CHECKBOX_STATUS_CHECKED,
|
||
CHECKBOX_STATUS_INDETERMINATE = _const2.default.CHECKBOX_STATUS_INDETERMINATE,
|
||
ROW_SELECT_MULTIPLE = _const2.default.ROW_SELECT_MULTIPLE;
|
||
var _props3 = this.props,
|
||
mode = _props3.mode,
|
||
checkedStatus = _props3.checkedStatus,
|
||
selectionHeaderRenderer = _props3.selectionHeaderRenderer,
|
||
hideSelectAll = _props3.hideSelectAll,
|
||
headerColumnStyle = _props3.headerColumnStyle;
|
||
|
||
if (hideSelectAll) {
|
||
return _react2.default.createElement('th', { 'data-row-selection': true });
|
||
}
|
||
|
||
var checked = checkedStatus === CHECKBOX_STATUS_CHECKED;
|
||
|
||
var indeterminate = checkedStatus === CHECKBOX_STATUS_INDETERMINATE;
|
||
|
||
var attrs = {};
|
||
var content = void 0;
|
||
if (selectionHeaderRenderer || mode === ROW_SELECT_MULTIPLE) {
|
||
attrs.onClick = this.handleCheckBoxClick;
|
||
}
|
||
|
||
attrs.style = _utils2.default.isFunction(headerColumnStyle) ? headerColumnStyle(checkedStatus) : headerColumnStyle;
|
||
|
||
return _react2.default.createElement(
|
||
_bootstrap.BootstrapContext.Consumer,
|
||
null,
|
||
function (_ref2) {
|
||
var bootstrap4 = _ref2.bootstrap4;
|
||
|
||
if (selectionHeaderRenderer) {
|
||
content = selectionHeaderRenderer({
|
||
mode: mode,
|
||
checked: checked,
|
||
indeterminate: indeterminate
|
||
});
|
||
} else if (mode === ROW_SELECT_MULTIPLE) {
|
||
content = _react2.default.createElement(CheckBox, _extends({}, _this2.props, {
|
||
checked: checked,
|
||
className: bootstrap4 ? 'selection-input-4' : '',
|
||
indeterminate: indeterminate
|
||
}));
|
||
}
|
||
return _react2.default.createElement(
|
||
'th',
|
||
_extends({ className: 'selection-cell-header', 'data-row-selection': true }, attrs),
|
||
content
|
||
);
|
||
}
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return SelectionHeaderCell;
|
||
}(_react.Component);
|
||
|
||
SelectionHeaderCell.propTypes = {
|
||
mode: _propTypes2.default.string.isRequired,
|
||
checkedStatus: _propTypes2.default.string,
|
||
onAllRowsSelect: _propTypes2.default.func,
|
||
hideSelectAll: _propTypes2.default.bool,
|
||
selectionHeaderRenderer: _propTypes2.default.func,
|
||
headerColumnStyle: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func])
|
||
};
|
||
exports.default = SelectionHeaderCell;
|
||
|
||
/***/ }),
|
||
/* 34 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/require-default-props: 0 */
|
||
/* eslint no-nested-ternary: 0 */
|
||
|
||
|
||
var ExpansionHeaderCell = function (_Component) {
|
||
_inherits(ExpansionHeaderCell, _Component);
|
||
|
||
function ExpansionHeaderCell() {
|
||
_classCallCheck(this, ExpansionHeaderCell);
|
||
|
||
var _this = _possibleConstructorReturn(this, (ExpansionHeaderCell.__proto__ || Object.getPrototypeOf(ExpansionHeaderCell)).call(this));
|
||
|
||
_this.handleCheckBoxClick = _this.handleCheckBoxClick.bind(_this);
|
||
return _this;
|
||
}
|
||
|
||
_createClass(ExpansionHeaderCell, [{
|
||
key: 'handleCheckBoxClick',
|
||
value: function handleCheckBoxClick(e) {
|
||
var _props = this.props,
|
||
isAnyExpands = _props.isAnyExpands,
|
||
onAllRowExpand = _props.onAllRowExpand;
|
||
|
||
|
||
onAllRowExpand(e, !isAnyExpands);
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props2 = this.props,
|
||
isAnyExpands = _props2.isAnyExpands,
|
||
expandHeaderColumnRenderer = _props2.expandHeaderColumnRenderer;
|
||
|
||
var attrs = {
|
||
onClick: this.handleCheckBoxClick
|
||
};
|
||
|
||
return _react2.default.createElement(
|
||
'th',
|
||
_extends({ className: 'expand-cell-header', 'data-row-selection': true }, attrs),
|
||
expandHeaderColumnRenderer ? expandHeaderColumnRenderer({ isAnyExpands: isAnyExpands }) : isAnyExpands ? '(-)' : '(+)'
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return ExpansionHeaderCell;
|
||
}(_react.Component);
|
||
|
||
ExpansionHeaderCell.propTypes = {
|
||
isAnyExpands: _propTypes2.default.bool.isRequired,
|
||
onAllRowExpand: _propTypes2.default.func.isRequired,
|
||
expandHeaderColumnRenderer: _propTypes2.default.func
|
||
};
|
||
exports.default = ExpansionHeaderCell;
|
||
|
||
/***/ }),
|
||
/* 35 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _selectionContext = __webpack_require__(8);
|
||
|
||
var _selectionContext2 = _interopRequireDefault(_selectionContext);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
exports.default = function (Component) {
|
||
return function () {
|
||
return _react2.default.createElement(
|
||
_selectionContext2.default.Consumer,
|
||
null,
|
||
function (selectRow) {
|
||
return _react2.default.createElement(Component, selectRow);
|
||
}
|
||
);
|
||
};
|
||
};
|
||
|
||
/***/ }),
|
||
/* 36 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.getExpandedRows = exports.expandableKeys = exports.isAnyExpands = undefined;
|
||
|
||
var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _rows = __webpack_require__(6);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var isAnyExpands = exports.isAnyExpands = function isAnyExpands(data, keyField) {
|
||
var expanded = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
||
|
||
var _loop = function _loop(i) {
|
||
var rowKey = _utils2.default.get(data[i], keyField);
|
||
if (typeof expanded.find(function (x) {
|
||
return x === rowKey;
|
||
}) !== 'undefined') {
|
||
return {
|
||
v: true
|
||
};
|
||
}
|
||
};
|
||
|
||
for (var i = 0; i < data.length; i += 1) {
|
||
var _ret = _loop(i);
|
||
|
||
if ((typeof _ret === 'undefined' ? 'undefined' : _typeof(_ret)) === "object") return _ret.v;
|
||
}
|
||
return false;
|
||
};
|
||
|
||
var expandableKeys = exports.expandableKeys = function expandableKeys(data, keyField) {
|
||
var skips = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : [];
|
||
|
||
if (skips.length === 0) {
|
||
return data.map(function (row) {
|
||
return _utils2.default.get(row, keyField);
|
||
});
|
||
}
|
||
return data.filter(function (row) {
|
||
return !_utils2.default.contains(skips, _utils2.default.get(row, keyField));
|
||
}).map(function (row) {
|
||
return _utils2.default.get(row, keyField);
|
||
});
|
||
};
|
||
|
||
var getExpandedRows = exports.getExpandedRows = function getExpandedRows(data, keyField, expanded) {
|
||
return expanded.map(function (k) {
|
||
return (0, _rows.getRowByRowId)(data, keyField, k);
|
||
});
|
||
};
|
||
|
||
/***/ }),
|
||
/* 37 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.editCell = undefined;
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _rows = __webpack_require__(6);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var editCell = exports.editCell = function editCell(data, keyField, rowId, dataField, newValue) {
|
||
var row = (0, _rows.getRowByRowId)(data, keyField, rowId);
|
||
if (row) _utils2.default.set(row, dataField, newValue);
|
||
};
|
||
|
||
/***/ }),
|
||
/* 38 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.nextOrder = exports.sort = undefined;
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function _toConsumableArray(arr) { if (Array.isArray(arr)) { for (var i = 0, arr2 = Array(arr.length); i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } else { return Array.from(arr); } } /* eslint no-nested-ternary: 0 */
|
||
/* eslint no-lonely-if: 0 */
|
||
/* eslint no-underscore-dangle: 0 */
|
||
|
||
|
||
function comparator(a, b) {
|
||
var result = void 0;
|
||
if (typeof b === 'string') {
|
||
result = b.localeCompare(a);
|
||
} else {
|
||
result = a > b ? -1 : a < b ? 1 : 0;
|
||
}
|
||
return result;
|
||
}
|
||
|
||
var sort = exports.sort = function sort(data, sortOrder, _ref) {
|
||
var dataField = _ref.dataField,
|
||
sortFunc = _ref.sortFunc,
|
||
sortValue = _ref.sortValue;
|
||
|
||
var _data = [].concat(_toConsumableArray(data));
|
||
_data.sort(function (a, b) {
|
||
var result = void 0;
|
||
var valueA = _utils2.default.get(a, dataField);
|
||
var valueB = _utils2.default.get(b, dataField);
|
||
if (sortValue) {
|
||
valueA = sortValue(valueA, a);
|
||
valueB = sortValue(valueB, b);
|
||
} else {
|
||
valueA = _utils2.default.isDefined(valueA) ? valueA : '';
|
||
valueB = _utils2.default.isDefined(valueB) ? valueB : '';
|
||
}
|
||
|
||
if (sortFunc) {
|
||
result = sortFunc(valueA, valueB, sortOrder, dataField, a, b);
|
||
} else {
|
||
if (sortOrder === _const2.default.SORT_DESC) {
|
||
result = comparator(valueA, valueB);
|
||
} else {
|
||
result = comparator(valueB, valueA);
|
||
}
|
||
}
|
||
return result;
|
||
});
|
||
return _data;
|
||
};
|
||
|
||
var nextOrder = exports.nextOrder = function nextOrder(currentSortColumn, _ref2) {
|
||
var sortOrder = _ref2.sortOrder,
|
||
sortColumn = _ref2.sortColumn;
|
||
var defaultOrder = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : _const2.default.SORT_DESC;
|
||
|
||
if (!sortColumn || currentSortColumn.dataField !== sortColumn.dataField) return defaultOrder;
|
||
return sortOrder === _const2.default.SORT_DESC ? _const2.default.SORT_ASC : _const2.default.SORT_DESC;
|
||
};
|
||
|
||
/***/ }),
|
||
/* 39 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
exports.typeConvert = undefined;
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var typeConvert = exports.typeConvert = function typeConvert(type, value) {
|
||
if (type === _const2.default.TYPE_STRING) {
|
||
return String(value);
|
||
} else if (type === _const2.default.TYPE_NUMBER) {
|
||
return Number(value);
|
||
} else if (type === _const2.default.TYPE_BOOLEAN) {
|
||
if (typeof value === 'boolean') {
|
||
return value;
|
||
}
|
||
return value === 'true';
|
||
} else if (type === _const2.default.TYPE_DATE) {
|
||
return new Date(value);
|
||
}
|
||
return value;
|
||
};
|
||
|
||
/***/ }),
|
||
/* 40 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _rowExpandContext = __webpack_require__(10);
|
||
|
||
var _rowExpandContext2 = _interopRequireDefault(_rowExpandContext);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
exports.default = function (Component) {
|
||
return function () {
|
||
return _react2.default.createElement(
|
||
_rowExpandContext2.default.Consumer,
|
||
null,
|
||
function (expandRow) {
|
||
return _react2.default.createElement(Component, expandRow);
|
||
}
|
||
);
|
||
};
|
||
};
|
||
|
||
/***/ }),
|
||
/* 41 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _filtersCell = __webpack_require__(42);
|
||
|
||
var _filtersCell2 = _interopRequireDefault(_filtersCell);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
var _rowTemplate = __webpack_require__(12);
|
||
|
||
var _rowTemplate2 = _interopRequireDefault(_rowTemplate);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var Filters = function Filters(props) {
|
||
var columns = props.columns,
|
||
onFilter = props.onFilter,
|
||
currFilters = props.currFilters,
|
||
filterPosition = props.filterPosition,
|
||
onExternalFilter = props.onExternalFilter,
|
||
className = props.className,
|
||
selectRow = props.selectRow,
|
||
expandRow = props.expandRow;
|
||
|
||
|
||
function renderContent() {
|
||
var filterColumns = [];
|
||
var showFiltersRow = false;
|
||
|
||
columns.forEach(function (column, i) {
|
||
filterColumns.push(_react2.default.createElement(_filtersCell2.default, {
|
||
index: i,
|
||
key: column.dataField,
|
||
column: column,
|
||
currFilters: currFilters,
|
||
onExternalFilter: onExternalFilter,
|
||
onFilter: onFilter
|
||
}));
|
||
|
||
if (column.filterRenderer || column.filter) {
|
||
if (!showFiltersRow) {
|
||
showFiltersRow = true;
|
||
}
|
||
}
|
||
});
|
||
return filterColumns;
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
'tbody',
|
||
{
|
||
className: className,
|
||
style: {
|
||
display: filterPosition === _const2.default.FILTERS_POSITION_TOP ? 'table-header-group' : 'table-footer-group'
|
||
}
|
||
},
|
||
_react2.default.createElement(_rowTemplate2.default, {
|
||
renderContent: renderContent,
|
||
selectRow: selectRow,
|
||
expandRow: expandRow,
|
||
cellEl: 'td'
|
||
})
|
||
);
|
||
}; /* eslint react/require-default-props: 0 */
|
||
|
||
|
||
Filters.propTypes = {
|
||
columns: _propTypes2.default.array.isRequired,
|
||
onFilter: _propTypes2.default.func,
|
||
filterPosition: _propTypes2.default.oneOf([_const2.default.FILTERS_POSITION_TOP, _const2.default.FILTERS_POSITION_INLINE, _const2.default.FILTERS_POSITION_BOTTOM]),
|
||
currFilters: _propTypes2.default.object,
|
||
onExternalFilter: _propTypes2.default.func,
|
||
className: _propTypes2.default.string,
|
||
selectRow: _propTypes2.default.object,
|
||
expandRow: _propTypes2.default.object
|
||
};
|
||
|
||
Filters.defaultProps = {
|
||
position: _const2.default.FILTERS_POSITION_TOP
|
||
};
|
||
|
||
exports.default = Filters;
|
||
|
||
/***/ }),
|
||
/* 42 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var FiltersCell = function FiltersCell(props) {
|
||
var index = props.index,
|
||
column = props.column,
|
||
onExternalFilter = props.onExternalFilter,
|
||
currFilters = props.currFilters,
|
||
onFilter = props.onFilter;
|
||
var filterRenderer = column.filterRenderer,
|
||
filter = column.filter;
|
||
|
||
var filterElm = void 0;
|
||
var cellAttrs = {};
|
||
var cellStyle = {};
|
||
cellAttrs.style = cellStyle;
|
||
if (column.headerAlign) {
|
||
cellStyle.textAlign = _utils2.default.isFunction(column.headerAlign) ? column.headerAlign(column, index) : column.headerAlign;
|
||
}
|
||
if (column.filterRenderer) {
|
||
var onCustomFilter = onExternalFilter(column, filter.props.type);
|
||
filterElm = filterRenderer(onCustomFilter, column);
|
||
} else if (filter) {
|
||
filterElm = _react2.default.createElement(filter.Filter, _extends({}, filter.props, {
|
||
filterState: currFilters[column.dataField],
|
||
onFilter: onFilter,
|
||
column: column
|
||
}));
|
||
}
|
||
return _react2.default.createElement('th', cellAttrs, filterElm);
|
||
};
|
||
|
||
FiltersCell.propTypes = {
|
||
index: _propTypes2.default.number.isRequired,
|
||
column: _propTypes2.default.object.isRequired,
|
||
currFilters: _propTypes2.default.object.isRequired,
|
||
onFilter: _propTypes2.default.func,
|
||
onExternalFilter: _propTypes2.default.func
|
||
};
|
||
|
||
FiltersCell.defaultProps = {
|
||
onFilter: function onFilter() {},
|
||
onExternalFilter: function onExternalFilter() {}
|
||
};
|
||
|
||
exports.default = FiltersCell;
|
||
|
||
/***/ }),
|
||
/* 43 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
/* eslint react/require-default-props: 0 */
|
||
var Caption = function Caption(props) {
|
||
if (!props.children) return null;
|
||
|
||
var caption = props.bootstrap4 ? _react2.default.createElement(
|
||
'caption',
|
||
{ style: { captionSide: 'top' } },
|
||
props.children
|
||
) : _react2.default.createElement(
|
||
'caption',
|
||
null,
|
||
props.children
|
||
);
|
||
|
||
return caption;
|
||
};
|
||
|
||
Caption.propTypes = {
|
||
children: _propTypes2.default.oneOfType([_propTypes2.default.node, _propTypes2.default.string]),
|
||
bootstrap4: _propTypes2.default.bool
|
||
};
|
||
|
||
exports.default = Caption;
|
||
|
||
/***/ }),
|
||
/* 44 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _simpleRow = __webpack_require__(45);
|
||
|
||
var _simpleRow2 = _interopRequireDefault(_simpleRow);
|
||
|
||
var _aggregateRow = __webpack_require__(47);
|
||
|
||
var _aggregateRow2 = _interopRequireDefault(_aggregateRow);
|
||
|
||
var _rowSection = __webpack_require__(50);
|
||
|
||
var _rowSection2 = _interopRequireDefault(_rowSection);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
var _rowConsumer = __webpack_require__(51);
|
||
|
||
var _rowConsumer2 = _interopRequireDefault(_rowConsumer);
|
||
|
||
var _rowConsumer3 = __webpack_require__(52);
|
||
|
||
var _rowConsumer4 = _interopRequireDefault(_rowConsumer3);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/prop-types: 0 */
|
||
/* eslint react/require-default-props: 0 */
|
||
|
||
var Body = function (_React$Component) {
|
||
_inherits(Body, _React$Component);
|
||
|
||
function Body(props) {
|
||
_classCallCheck(this, Body);
|
||
|
||
var _this = _possibleConstructorReturn(this, (Body.__proto__ || Object.getPrototypeOf(Body)).call(this, props));
|
||
|
||
var keyField = props.keyField,
|
||
cellEdit = props.cellEdit,
|
||
selectRow = props.selectRow,
|
||
expandRow = props.expandRow;
|
||
|
||
// Construct Editing Cell Component
|
||
|
||
if (cellEdit.createContext) {
|
||
_this.EditingCell = cellEdit.createEditingCell(_utils2.default, cellEdit.options.onStartEdit);
|
||
}
|
||
|
||
// Construct Row Component
|
||
var RowComponent = _simpleRow2.default;
|
||
var selectRowEnabled = selectRow.mode !== _const2.default.ROW_SELECT_DISABLED;
|
||
var expandRowEnabled = !!expandRow.renderer;
|
||
|
||
if (expandRowEnabled) {
|
||
RowComponent = (0, _rowConsumer4.default)(_aggregateRow2.default);
|
||
}
|
||
|
||
if (selectRowEnabled) {
|
||
RowComponent = (0, _rowConsumer2.default)(expandRowEnabled ? RowComponent : _aggregateRow2.default);
|
||
}
|
||
|
||
if (cellEdit.createContext) {
|
||
RowComponent = cellEdit.withRowLevelCellEdit(RowComponent, selectRowEnabled, keyField, _utils2.default);
|
||
}
|
||
_this.RowComponent = RowComponent;
|
||
return _this;
|
||
}
|
||
|
||
_createClass(Body, [{
|
||
key: 'render',
|
||
value: function render() {
|
||
var _this2 = this;
|
||
|
||
var _props = this.props,
|
||
columns = _props.columns,
|
||
data = _props.data,
|
||
tabIndexCell = _props.tabIndexCell,
|
||
keyField = _props.keyField,
|
||
isEmpty = _props.isEmpty,
|
||
noDataIndication = _props.noDataIndication,
|
||
visibleColumnSize = _props.visibleColumnSize,
|
||
cellEdit = _props.cellEdit,
|
||
selectRow = _props.selectRow,
|
||
rowStyle = _props.rowStyle,
|
||
rowClasses = _props.rowClasses,
|
||
rowEvents = _props.rowEvents,
|
||
expandRow = _props.expandRow,
|
||
className = _props.className;
|
||
|
||
|
||
var content = void 0;
|
||
|
||
if (isEmpty) {
|
||
var indication = _utils2.default.isFunction(noDataIndication) ? noDataIndication() : noDataIndication;
|
||
if (!indication) {
|
||
return null;
|
||
}
|
||
content = _react2.default.createElement(_rowSection2.default, { content: indication, colSpan: visibleColumnSize });
|
||
} else {
|
||
var selectRowEnabled = selectRow.mode !== _const2.default.ROW_SELECT_DISABLED;
|
||
var expandRowEnabled = !!expandRow.renderer;
|
||
|
||
var additionalRowProps = {};
|
||
|
||
if (cellEdit.createContext) {
|
||
additionalRowProps.EditingCellComponent = this.EditingCell;
|
||
}
|
||
|
||
if (selectRowEnabled || expandRowEnabled) {
|
||
additionalRowProps.expandRow = expandRow;
|
||
additionalRowProps.selectRow = selectRow;
|
||
}
|
||
|
||
content = data.map(function (row, index) {
|
||
var key = _utils2.default.get(row, keyField);
|
||
var baseRowProps = _extends({
|
||
key: key,
|
||
row: row,
|
||
tabIndexCell: tabIndexCell,
|
||
columns: columns,
|
||
keyField: keyField,
|
||
cellEdit: cellEdit,
|
||
value: key,
|
||
rowIndex: index,
|
||
visibleColumnSize: visibleColumnSize,
|
||
attrs: rowEvents || {}
|
||
}, additionalRowProps);
|
||
|
||
baseRowProps.style = _utils2.default.isFunction(rowStyle) ? rowStyle(row, index) : rowStyle;
|
||
baseRowProps.className = _utils2.default.isFunction(rowClasses) ? rowClasses(row, index) : rowClasses;
|
||
|
||
return _react2.default.createElement(_this2.RowComponent, baseRowProps);
|
||
});
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
'tbody',
|
||
{ className: className },
|
||
content
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return Body;
|
||
}(_react2.default.Component);
|
||
|
||
Body.propTypes = {
|
||
keyField: _propTypes2.default.string.isRequired,
|
||
data: _propTypes2.default.array.isRequired,
|
||
columns: _propTypes2.default.array.isRequired,
|
||
selectRow: _propTypes2.default.object
|
||
};
|
||
|
||
exports.default = Body;
|
||
|
||
/***/ }),
|
||
/* 45 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _rowPureContent = __webpack_require__(13);
|
||
|
||
var _rowPureContent2 = _interopRequireDefault(_rowPureContent);
|
||
|
||
var _eventDelegater = __webpack_require__(14);
|
||
|
||
var _eventDelegater2 = _interopRequireDefault(_eventDelegater);
|
||
|
||
var _shouldUpdater2 = __webpack_require__(15);
|
||
|
||
var _shouldUpdater3 = _interopRequireDefault(_shouldUpdater2);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/prop-types: 0 */
|
||
/* eslint react/no-array-index-key: 0 */
|
||
|
||
|
||
var SimpleRow = function (_shouldUpdater) {
|
||
_inherits(SimpleRow, _shouldUpdater);
|
||
|
||
function SimpleRow(props) {
|
||
_classCallCheck(this, SimpleRow);
|
||
|
||
var _this = _possibleConstructorReturn(this, (SimpleRow.__proto__ || Object.getPrototypeOf(SimpleRow)).call(this, props));
|
||
|
||
_this.shouldUpdateRowContent = false;
|
||
return _this;
|
||
}
|
||
|
||
_createClass(SimpleRow, [{
|
||
key: 'shouldComponentUpdate',
|
||
value: function shouldComponentUpdate(nextProps) {
|
||
this.shouldUpdateRowContent = false;
|
||
this.shouldUpdateRowContent = this.shouldRowContentUpdate(nextProps);
|
||
if (this.shouldUpdateRowContent) return true;
|
||
|
||
return this.shouldUpdatedBySelfProps(nextProps);
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
className = _props.className,
|
||
style = _props.style,
|
||
attrs = _props.attrs,
|
||
visibleColumnSize = _props.visibleColumnSize,
|
||
tabIndexCell = _props.tabIndexCell,
|
||
rest = _objectWithoutProperties(_props, ['className', 'style', 'attrs', 'visibleColumnSize', 'tabIndexCell']);
|
||
|
||
var trAttrs = this.delegate(attrs);
|
||
var tabIndexStart = this.props.rowIndex * visibleColumnSize + 1;
|
||
|
||
return _react2.default.createElement(
|
||
'tr',
|
||
_extends({ style: style, className: className }, trAttrs),
|
||
_react2.default.createElement(_rowPureContent2.default, _extends({
|
||
shouldUpdate: this.shouldUpdateRowContent,
|
||
tabIndexStart: tabIndexCell ? tabIndexStart : -1
|
||
}, rest))
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return SimpleRow;
|
||
}((0, _shouldUpdater3.default)((0, _eventDelegater2.default)(_react.Component)));
|
||
|
||
SimpleRow.propTypes = {
|
||
row: _propTypes2.default.object.isRequired,
|
||
rowIndex: _propTypes2.default.number.isRequired,
|
||
columns: _propTypes2.default.array.isRequired,
|
||
style: _propTypes2.default.object,
|
||
className: _propTypes2.default.string,
|
||
attrs: _propTypes2.default.object
|
||
};
|
||
|
||
SimpleRow.defaultProps = {
|
||
editable: true,
|
||
style: {},
|
||
className: null,
|
||
attrs: {}
|
||
};
|
||
|
||
exports.default = SimpleRow;
|
||
|
||
/***/ }),
|
||
/* 46 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _cellEventDelegater = __webpack_require__(7);
|
||
|
||
var _cellEventDelegater2 = _interopRequireDefault(_cellEventDelegater);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/prop-types: 0 */
|
||
|
||
|
||
var Cell = function (_eventDelegater) {
|
||
_inherits(Cell, _eventDelegater);
|
||
|
||
function Cell(props) {
|
||
_classCallCheck(this, Cell);
|
||
|
||
var _this = _possibleConstructorReturn(this, (Cell.__proto__ || Object.getPrototypeOf(Cell)).call(this, props));
|
||
|
||
_this.createHandleEditingCell = function (originFunc) {
|
||
return function (e) {
|
||
var _this$props = _this.props,
|
||
onStart = _this$props.onStart,
|
||
rowIndex = _this$props.rowIndex,
|
||
columnIndex = _this$props.columnIndex,
|
||
clickToEdit = _this$props.clickToEdit,
|
||
dbclickToEdit = _this$props.dbclickToEdit;
|
||
|
||
if ((clickToEdit || dbclickToEdit) && _utils2.default.isFunction(originFunc)) {
|
||
originFunc(e);
|
||
}
|
||
if (onStart) {
|
||
onStart(rowIndex, columnIndex);
|
||
}
|
||
};
|
||
};
|
||
|
||
_this.createHandleEditingCell = _this.createHandleEditingCell.bind(_this);
|
||
return _this;
|
||
}
|
||
|
||
_createClass(Cell, [{
|
||
key: 'shouldComponentUpdate',
|
||
value: function shouldComponentUpdate(nextProps) {
|
||
var shouldUpdate = false;
|
||
if (nextProps.column.isDummyField) {
|
||
shouldUpdate = !_utils2.default.isEqual(this.props.row, nextProps.row);
|
||
} else {
|
||
shouldUpdate = _utils2.default.get(this.props.row, this.props.column.dataField) !== _utils2.default.get(nextProps.row, nextProps.column.dataField);
|
||
}
|
||
|
||
if (shouldUpdate) return true;
|
||
|
||
// if (nextProps.formatter)
|
||
|
||
shouldUpdate = (nextProps.column.formatter ? !_utils2.default.isEqual(this.props.row, nextProps.row) : false) || this.props.column.hidden !== nextProps.column.hidden || this.props.column.isDummyField !== nextProps.column.isDummyField || this.props.rowIndex !== nextProps.rowIndex || this.props.columnIndex !== nextProps.columnIndex || this.props.className !== nextProps.className || this.props.title !== nextProps.title || this.props.editable !== nextProps.editable || this.props.clickToEdit !== nextProps.clickToEdit || this.props.dbclickToEdit !== nextProps.dbclickToEdit || !_utils2.default.isEqual(this.props.style, nextProps.style) || !_utils2.default.isEqual(this.props.column.formatExtraData, nextProps.column.formatExtraData) || !_utils2.default.isEqual(this.props.column.events, nextProps.column.events) || !_utils2.default.isEqual(this.props.column.attrs, nextProps.column.attrs) || this.props.tabIndex !== nextProps.tabIndex;
|
||
return shouldUpdate;
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
row = _props.row,
|
||
rowIndex = _props.rowIndex,
|
||
column = _props.column,
|
||
columnIndex = _props.columnIndex,
|
||
onStart = _props.onStart,
|
||
editable = _props.editable,
|
||
clickToEdit = _props.clickToEdit,
|
||
dbclickToEdit = _props.dbclickToEdit,
|
||
rest = _objectWithoutProperties(_props, ['row', 'rowIndex', 'column', 'columnIndex', 'onStart', 'editable', 'clickToEdit', 'dbclickToEdit']);
|
||
|
||
var dataField = column.dataField,
|
||
formatter = column.formatter,
|
||
formatExtraData = column.formatExtraData;
|
||
|
||
var attrs = this.delegate(_extends({}, rest));
|
||
var content = column.isDummyField ? null : _utils2.default.get(row, dataField);
|
||
|
||
if (formatter) {
|
||
content = column.formatter(content, row, rowIndex, formatExtraData);
|
||
}
|
||
|
||
if (clickToEdit && editable) {
|
||
attrs.onClick = this.createHandleEditingCell(attrs.onClick);
|
||
} else if (dbclickToEdit && editable) {
|
||
attrs.onDoubleClick = this.createHandleEditingCell(attrs.onDoubleClick);
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
'td',
|
||
attrs,
|
||
typeof content === 'boolean' ? '' + content : content
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return Cell;
|
||
}((0, _cellEventDelegater2.default)(_react.Component));
|
||
|
||
Cell.propTypes = {
|
||
row: _propTypes2.default.object.isRequired,
|
||
rowIndex: _propTypes2.default.number.isRequired,
|
||
column: _propTypes2.default.object.isRequired,
|
||
columnIndex: _propTypes2.default.number.isRequired
|
||
};
|
||
|
||
exports.default = Cell;
|
||
|
||
/***/ }),
|
||
/* 47 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _expandCell = __webpack_require__(48);
|
||
|
||
var _expandCell2 = _interopRequireDefault(_expandCell);
|
||
|
||
var _selectionCell = __webpack_require__(49);
|
||
|
||
var _selectionCell2 = _interopRequireDefault(_selectionCell);
|
||
|
||
var _shouldUpdater2 = __webpack_require__(15);
|
||
|
||
var _shouldUpdater3 = _interopRequireDefault(_shouldUpdater2);
|
||
|
||
var _eventDelegater = __webpack_require__(14);
|
||
|
||
var _eventDelegater2 = _interopRequireDefault(_eventDelegater);
|
||
|
||
var _rowPureContent = __webpack_require__(13);
|
||
|
||
var _rowPureContent2 = _interopRequireDefault(_rowPureContent);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint class-methods-use-this: 0 */
|
||
/* eslint react/prop-types: 0 */
|
||
/* eslint no-plusplus: 0 */
|
||
|
||
|
||
var RowAggregator = function (_shouldUpdater) {
|
||
_inherits(RowAggregator, _shouldUpdater);
|
||
|
||
function RowAggregator(props) {
|
||
_classCallCheck(this, RowAggregator);
|
||
|
||
var _this = _possibleConstructorReturn(this, (RowAggregator.__proto__ || Object.getPrototypeOf(RowAggregator)).call(this, props));
|
||
|
||
_this.clickNum = 0;
|
||
_this.shouldUpdateRowContent = false;
|
||
_this.createClickEventHandler = _this.createClickEventHandler.bind(_this);
|
||
return _this;
|
||
}
|
||
|
||
_createClass(RowAggregator, [{
|
||
key: 'shouldComponentUpdate',
|
||
value: function shouldComponentUpdate(nextProps) {
|
||
if (this.props.selected !== nextProps.selected || this.props.expanded !== nextProps.expanded || this.props.expandable !== nextProps.expandable || this.props.selectable !== nextProps.selectable || this.props.selectRow.hideSelectColumn !== nextProps.selectRow.hideSelectColumn || this.shouldUpdatedBySelfProps(nextProps)) {
|
||
this.shouldUpdateRowContent = this.shouldRowContentUpdate(nextProps);
|
||
return true;
|
||
}
|
||
this.shouldUpdateRowContent = this.shouldRowContentUpdate(nextProps);
|
||
|
||
return this.shouldUpdateRowContent;
|
||
}
|
||
}, {
|
||
key: 'isRenderFunctionColumnInLeft',
|
||
value: function isRenderFunctionColumnInLeft() {
|
||
var position = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : _const2.default.INDICATOR_POSITION_LEFT;
|
||
|
||
return position === _const2.default.INDICATOR_POSITION_LEFT;
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
row = _props.row,
|
||
columns = _props.columns,
|
||
keyField = _props.keyField,
|
||
rowIndex = _props.rowIndex,
|
||
style = _props.style,
|
||
className = _props.className,
|
||
attrs = _props.attrs,
|
||
selectRow = _props.selectRow,
|
||
expandRow = _props.expandRow,
|
||
expanded = _props.expanded,
|
||
expandable = _props.expandable,
|
||
selected = _props.selected,
|
||
selectable = _props.selectable,
|
||
visibleColumnSize = _props.visibleColumnSize,
|
||
tabIndexCell = _props.tabIndexCell,
|
||
rest = _objectWithoutProperties(_props, ['row', 'columns', 'keyField', 'rowIndex', 'style', 'className', 'attrs', 'selectRow', 'expandRow', 'expanded', 'expandable', 'selected', 'selectable', 'visibleColumnSize', 'tabIndexCell']);
|
||
|
||
var key = _utils2.default.get(row, keyField);
|
||
var hideSelectColumn = selectRow.hideSelectColumn,
|
||
selectColumnPosition = selectRow.selectColumnPosition,
|
||
clickToSelect = selectRow.clickToSelect;
|
||
var showExpandColumn = expandRow.showExpandColumn,
|
||
expandColumnPosition = expandRow.expandColumnPosition;
|
||
|
||
|
||
var newAttrs = this.delegate(_extends({}, attrs));
|
||
if (clickToSelect || !!expandRow.renderer) {
|
||
newAttrs.onClick = this.createClickEventHandler(newAttrs.onClick);
|
||
}
|
||
|
||
var tabIndexStart = rowIndex * visibleColumnSize + 1;
|
||
|
||
var childrens = [_react2.default.createElement(_rowPureContent2.default, _extends({
|
||
key: 'row',
|
||
row: row,
|
||
columns: columns,
|
||
keyField: keyField,
|
||
rowIndex: rowIndex,
|
||
shouldUpdate: this.shouldUpdateRowContent,
|
||
tabIndexStart: tabIndexCell ? tabIndexStart : -1
|
||
}, rest))];
|
||
|
||
if (!hideSelectColumn) {
|
||
var selectCell = _react2.default.createElement(_selectionCell2.default, _extends({}, selectRow, {
|
||
key: 'selection-cell',
|
||
rowKey: key,
|
||
rowIndex: rowIndex,
|
||
selected: selected,
|
||
disabled: !selectable,
|
||
tabIndex: tabIndexCell ? tabIndexStart++ : -1
|
||
}));
|
||
if (this.isRenderFunctionColumnInLeft(selectColumnPosition)) {
|
||
childrens.unshift(selectCell);
|
||
} else {
|
||
childrens.push(selectCell);
|
||
}
|
||
}
|
||
|
||
if (showExpandColumn) {
|
||
var expandCell = _react2.default.createElement(_expandCell2.default, _extends({}, expandRow, {
|
||
key: 'expand-cell',
|
||
rowKey: key,
|
||
rowIndex: rowIndex,
|
||
expanded: expanded,
|
||
expandable: expandable,
|
||
tabIndex: tabIndexCell ? tabIndexStart++ : -1
|
||
}));
|
||
if (this.isRenderFunctionColumnInLeft(expandColumnPosition)) {
|
||
childrens.unshift(expandCell);
|
||
} else {
|
||
childrens.push(expandCell);
|
||
}
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
'tr',
|
||
_extends({
|
||
style: style,
|
||
className: className
|
||
}, newAttrs),
|
||
childrens
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return RowAggregator;
|
||
}((0, _shouldUpdater3.default)((0, _eventDelegater2.default)(_react2.default.Component)));
|
||
|
||
RowAggregator.propTypes = {
|
||
attrs: _propTypes2.default.object,
|
||
style: _propTypes2.default.object
|
||
};
|
||
RowAggregator.defaultProps = {
|
||
attrs: {},
|
||
style: {}
|
||
};
|
||
exports.default = RowAggregator;
|
||
|
||
/***/ }),
|
||
/* 48 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint
|
||
react/require-default-props: 0
|
||
jsx-a11y/no-noninteractive-element-interactions: 0
|
||
*/
|
||
/* eslint no-nested-ternary: 0 */
|
||
|
||
|
||
var ExpandCell = function (_Component) {
|
||
_inherits(ExpandCell, _Component);
|
||
|
||
function ExpandCell() {
|
||
_classCallCheck(this, ExpandCell);
|
||
|
||
var _this = _possibleConstructorReturn(this, (ExpandCell.__proto__ || Object.getPrototypeOf(ExpandCell)).call(this));
|
||
|
||
_this.handleClick = _this.handleClick.bind(_this);
|
||
return _this;
|
||
}
|
||
|
||
_createClass(ExpandCell, [{
|
||
key: 'shouldComponentUpdate',
|
||
value: function shouldComponentUpdate(nextProps) {
|
||
var shouldUpdate = this.props.rowIndex !== nextProps.rowIndex || this.props.expanded !== nextProps.expanded || this.props.rowKey !== nextProps.rowKey || this.props.tabIndex !== nextProps.tabIndex;
|
||
|
||
return shouldUpdate;
|
||
}
|
||
}, {
|
||
key: 'handleClick',
|
||
value: function handleClick(e) {
|
||
var _props = this.props,
|
||
rowKey = _props.rowKey,
|
||
expanded = _props.expanded,
|
||
onRowExpand = _props.onRowExpand,
|
||
rowIndex = _props.rowIndex;
|
||
|
||
e.stopPropagation();
|
||
onRowExpand(rowKey, !expanded, rowIndex, e);
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props2 = this.props,
|
||
expanded = _props2.expanded,
|
||
expandable = _props2.expandable,
|
||
expandColumnRenderer = _props2.expandColumnRenderer,
|
||
tabIndex = _props2.tabIndex,
|
||
rowKey = _props2.rowKey;
|
||
|
||
var attrs = {};
|
||
if (tabIndex !== -1) attrs.tabIndex = tabIndex;
|
||
|
||
return _react2.default.createElement(
|
||
'td',
|
||
_extends({ className: 'expand-cell', onClick: this.handleClick }, attrs),
|
||
expandColumnRenderer ? expandColumnRenderer({
|
||
expandable: expandable,
|
||
expanded: expanded,
|
||
rowKey: rowKey
|
||
}) : expandable ? expanded ? '(-)' : '(+)' : ''
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return ExpandCell;
|
||
}(_react.Component);
|
||
|
||
ExpandCell.propTypes = {
|
||
rowKey: _propTypes2.default.any,
|
||
expanded: _propTypes2.default.bool.isRequired,
|
||
expandable: _propTypes2.default.bool.isRequired,
|
||
onRowExpand: _propTypes2.default.func.isRequired,
|
||
expandColumnRenderer: _propTypes2.default.func,
|
||
rowIndex: _propTypes2.default.number,
|
||
tabIndex: _propTypes2.default.number
|
||
};
|
||
exports.default = ExpandCell;
|
||
|
||
/***/ }),
|
||
/* 49 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _bootstrap = __webpack_require__(5);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint
|
||
react/require-default-props: 0
|
||
jsx-a11y/no-noninteractive-element-interactions: 0
|
||
*/
|
||
|
||
|
||
var SelectionCell = function (_Component) {
|
||
_inherits(SelectionCell, _Component);
|
||
|
||
function SelectionCell() {
|
||
_classCallCheck(this, SelectionCell);
|
||
|
||
var _this = _possibleConstructorReturn(this, (SelectionCell.__proto__ || Object.getPrototypeOf(SelectionCell)).call(this));
|
||
|
||
_this.handleClick = _this.handleClick.bind(_this);
|
||
return _this;
|
||
}
|
||
|
||
_createClass(SelectionCell, [{
|
||
key: 'shouldComponentUpdate',
|
||
value: function shouldComponentUpdate(nextProps) {
|
||
var shouldUpdate = this.props.rowIndex !== nextProps.rowIndex || this.props.selected !== nextProps.selected || this.props.disabled !== nextProps.disabled || this.props.rowKey !== nextProps.rowKey || this.props.tabIndex !== nextProps.tabIndex || this.props.selectColumnStyle !== nextProps.selectColumnStyle;
|
||
|
||
return shouldUpdate;
|
||
}
|
||
}, {
|
||
key: 'handleClick',
|
||
value: function handleClick(e) {
|
||
var _props = this.props,
|
||
inputType = _props.mode,
|
||
rowKey = _props.rowKey,
|
||
selected = _props.selected,
|
||
onRowSelect = _props.onRowSelect,
|
||
disabled = _props.disabled,
|
||
rowIndex = _props.rowIndex;
|
||
|
||
e.stopPropagation();
|
||
if (disabled) return;
|
||
|
||
var checked = inputType === _const2.default.ROW_SELECT_SINGLE ? true : !selected;
|
||
|
||
onRowSelect(rowKey, checked, rowIndex, e);
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _this2 = this;
|
||
|
||
var _props2 = this.props,
|
||
rowKey = _props2.rowKey,
|
||
inputType = _props2.mode,
|
||
selected = _props2.selected,
|
||
disabled = _props2.disabled,
|
||
tabIndex = _props2.tabIndex,
|
||
rowIndex = _props2.rowIndex,
|
||
selectionRenderer = _props2.selectionRenderer,
|
||
selectColumnStyle = _props2.selectColumnStyle;
|
||
|
||
|
||
var attrs = {};
|
||
if (tabIndex !== -1) attrs.tabIndex = tabIndex;
|
||
|
||
attrs.style = _utils2.default.isFunction(selectColumnStyle) ? selectColumnStyle({
|
||
checked: selected,
|
||
disabled: disabled,
|
||
rowIndex: rowIndex,
|
||
rowKey: rowKey
|
||
}) : selectColumnStyle;
|
||
|
||
return _react2.default.createElement(
|
||
_bootstrap.BootstrapContext.Consumer,
|
||
null,
|
||
function (_ref) {
|
||
var bootstrap4 = _ref.bootstrap4;
|
||
return _react2.default.createElement(
|
||
'td',
|
||
_extends({ className: 'selection-cell', onClick: _this2.handleClick }, attrs),
|
||
selectionRenderer ? selectionRenderer({
|
||
mode: inputType,
|
||
checked: selected,
|
||
disabled: disabled,
|
||
rowIndex: rowIndex
|
||
}) : _react2.default.createElement('input', {
|
||
type: inputType,
|
||
checked: selected,
|
||
disabled: disabled,
|
||
className: bootstrap4 ? 'selection-input-4' : '',
|
||
onChange: function onChange() {}
|
||
})
|
||
);
|
||
}
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return SelectionCell;
|
||
}(_react.Component);
|
||
|
||
SelectionCell.propTypes = {
|
||
mode: _propTypes2.default.string.isRequired,
|
||
rowKey: _propTypes2.default.any,
|
||
selected: _propTypes2.default.bool,
|
||
onRowSelect: _propTypes2.default.func,
|
||
disabled: _propTypes2.default.bool,
|
||
rowIndex: _propTypes2.default.number,
|
||
tabIndex: _propTypes2.default.number,
|
||
clickToSelect: _propTypes2.default.bool,
|
||
selectionRenderer: _propTypes2.default.func,
|
||
selectColumnStyle: _propTypes2.default.oneOfType([_propTypes2.default.object, _propTypes2.default.func])
|
||
};
|
||
exports.default = SelectionCell;
|
||
|
||
/***/ }),
|
||
/* 50 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var RowSection = function RowSection(_ref) {
|
||
var content = _ref.content,
|
||
colSpan = _ref.colSpan;
|
||
return _react2.default.createElement(
|
||
'tr',
|
||
null,
|
||
_react2.default.createElement(
|
||
'td',
|
||
{
|
||
'data-toggle': 'collapse',
|
||
colSpan: colSpan,
|
||
className: 'react-bs-table-no-data'
|
||
},
|
||
content
|
||
)
|
||
);
|
||
};
|
||
|
||
RowSection.propTypes = {
|
||
content: _propTypes2.default.any,
|
||
colSpan: _propTypes2.default.number
|
||
};
|
||
|
||
RowSection.defaultProps = {
|
||
content: null,
|
||
colSpan: 1
|
||
};
|
||
|
||
exports.default = RowSection;
|
||
|
||
/***/ }),
|
||
/* 51 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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; }; /* eslint react/prop-types: 0 */
|
||
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _classnames = __webpack_require__(4);
|
||
|
||
var _classnames2 = _interopRequireDefault(_classnames);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _selectionContext = __webpack_require__(8);
|
||
|
||
var _selectionContext2 = _interopRequireDefault(_selectionContext);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
exports.default = function (Component) {
|
||
var renderWithSelection = function renderWithSelection(props, selectRow) {
|
||
var key = props.value;
|
||
var selected = _utils2.default.contains(selectRow.selected, key);
|
||
var selectable = !selectRow.nonSelectable || !_utils2.default.contains(selectRow.nonSelectable, key);
|
||
var notSelectable = _utils2.default.contains(selectRow.nonSelectable, key);
|
||
|
||
var style = props.style,
|
||
className = props.className;
|
||
|
||
|
||
if (selected) {
|
||
var selectedStyle = _utils2.default.isFunction(selectRow.style) ? selectRow.style(props.row, props.rowIndex) : selectRow.style;
|
||
|
||
var selectedClasses = _utils2.default.isFunction(selectRow.classes) ? selectRow.classes(props.row, props.rowIndex) : selectRow.classes;
|
||
|
||
style = _extends({}, style, selectedStyle);
|
||
className = (0, _classnames2.default)(className, selectedClasses) || undefined;
|
||
|
||
if (selectRow.bgColor) {
|
||
style = style || {};
|
||
style.backgroundColor = _utils2.default.isFunction(selectRow.bgColor) ? selectRow.bgColor(props.row, props.rowIndex) : selectRow.bgColor;
|
||
}
|
||
}
|
||
|
||
if (notSelectable) {
|
||
var notSelectableStyle = _utils2.default.isFunction(selectRow.nonSelectableStyle) ? selectRow.nonSelectableStyle(props.row, props.rowIndex) : selectRow.nonSelectableStyle;
|
||
|
||
var notSelectableClasses = _utils2.default.isFunction(selectRow.nonSelectableClasses) ? selectRow.nonSelectableClasses(props.row, props.rowIndex) : selectRow.nonSelectableClasses;
|
||
|
||
style = _extends({}, style, notSelectableStyle);
|
||
className = (0, _classnames2.default)(className, notSelectableClasses) || undefined;
|
||
}
|
||
|
||
return _react2.default.createElement(Component, _extends({}, props, {
|
||
style: style,
|
||
className: className,
|
||
selectRow: selectRow,
|
||
selected: selected,
|
||
selectable: selectable
|
||
}));
|
||
};
|
||
|
||
function withConsumer(props) {
|
||
return _react2.default.createElement(
|
||
_selectionContext2.default.Consumer,
|
||
null,
|
||
function (selectRow) {
|
||
return renderWithSelection(props, selectRow);
|
||
}
|
||
);
|
||
}
|
||
|
||
withConsumer.displayName = 'WithSelectionRowConsumer';
|
||
return withConsumer;
|
||
};
|
||
|
||
/***/ }),
|
||
/* 52 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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; }; /* eslint react/prop-types: 0 */
|
||
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _classnames = __webpack_require__(4);
|
||
|
||
var _classnames2 = _interopRequireDefault(_classnames);
|
||
|
||
var _expandRow = __webpack_require__(53);
|
||
|
||
var _expandRow2 = _interopRequireDefault(_expandRow);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _rowExpandContext = __webpack_require__(10);
|
||
|
||
var _rowExpandContext2 = _interopRequireDefault(_rowExpandContext);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
exports.default = function (Component) {
|
||
var renderWithExpansion = function renderWithExpansion(props, expandRow) {
|
||
var parentClassName = '';
|
||
var className = '';
|
||
var key = props.value;
|
||
|
||
var expanded = _utils2.default.contains(expandRow.expanded, key);
|
||
var isClosing = _utils2.default.contains(expandRow.isClosing, key);
|
||
var expandable = !expandRow.nonExpandable || !_utils2.default.contains(expandRow.nonExpandable, key);
|
||
if (expanded) {
|
||
parentClassName = _utils2.default.isFunction(expandRow.parentClassName) ? expandRow.parentClassName(expanded, props.row, props.rowIndex) : expandRow.parentClassName || '';
|
||
|
||
className = _utils2.default.isFunction(expandRow.className) ? expandRow.className(expanded, props.row, props.rowIndex) : expandRow.className || '';
|
||
}
|
||
|
||
return [_react2.default.createElement(Component, _extends({}, props, {
|
||
key: key,
|
||
expanded: expanded,
|
||
expandable: expandable,
|
||
expandRow: _extends({}, expandRow),
|
||
className: (0, _classnames2.default)(props.className, parentClassName)
|
||
})), expanded || isClosing ? _react2.default.createElement(
|
||
_expandRow2.default,
|
||
{
|
||
key: key + '-expanding',
|
||
colSpan: props.visibleColumnSize,
|
||
expanded: expanded,
|
||
onClosed: function onClosed() {
|
||
return expandRow.onClosed(key);
|
||
},
|
||
className: className
|
||
},
|
||
expandRow.renderer(props.row, props.rowIndex)
|
||
) : null];
|
||
};
|
||
return function (props) {
|
||
return _react2.default.createElement(
|
||
_rowExpandContext2.default.Consumer,
|
||
null,
|
||
function (expandRow) {
|
||
return renderWithExpansion(props, expandRow);
|
||
}
|
||
);
|
||
};
|
||
};
|
||
|
||
/***/ }),
|
||
/* 53 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _classnames = __webpack_require__(4);
|
||
|
||
var _classnames2 = _interopRequireDefault(_classnames);
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _reactTransitionGroup = __webpack_require__(54);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; }
|
||
|
||
var ExpandRow = function ExpandRow(_ref) {
|
||
var children = _ref.children,
|
||
expanded = _ref.expanded,
|
||
onClosed = _ref.onClosed,
|
||
className = _ref.className,
|
||
rest = _objectWithoutProperties(_ref, ['children', 'expanded', 'onClosed', 'className']);
|
||
|
||
return _react2.default.createElement(
|
||
'tr',
|
||
null,
|
||
_react2.default.createElement(
|
||
'td',
|
||
_extends({ className: (0, _classnames2.default)('reset-expansion-style', className) }, rest),
|
||
_react2.default.createElement(
|
||
_reactTransitionGroup.CSSTransition,
|
||
{
|
||
appear: true,
|
||
'in': expanded,
|
||
timeout: 400,
|
||
classNames: 'row-expand-slide',
|
||
onExited: onClosed
|
||
},
|
||
_react2.default.createElement(
|
||
'div',
|
||
null,
|
||
_react2.default.createElement(
|
||
'div',
|
||
{ className: 'row-expansion-style' },
|
||
children
|
||
)
|
||
)
|
||
)
|
||
)
|
||
);
|
||
};
|
||
|
||
ExpandRow.propTypes = {
|
||
children: _propTypes2.default.node,
|
||
expanded: _propTypes2.default.bool,
|
||
onClosed: _propTypes2.default.func,
|
||
className: _propTypes2.default.string
|
||
};
|
||
|
||
ExpandRow.defaultProps = {
|
||
children: null,
|
||
expanded: false,
|
||
onClosed: null,
|
||
className: ''
|
||
};
|
||
|
||
exports.default = ExpandRow;
|
||
|
||
/***/ }),
|
||
/* 54 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
var _CSSTransition = _interopRequireDefault(__webpack_require__(55));
|
||
|
||
var _ReplaceTransition = _interopRequireDefault(__webpack_require__(60));
|
||
|
||
var _TransitionGroup = _interopRequireDefault(__webpack_require__(20));
|
||
|
||
var _Transition = _interopRequireDefault(__webpack_require__(16));
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
module.exports = {
|
||
Transition: _Transition.default,
|
||
TransitionGroup: _TransitionGroup.default,
|
||
ReplaceTransition: _ReplaceTransition.default,
|
||
CSSTransition: _CSSTransition.default
|
||
};
|
||
|
||
/***/ }),
|
||
/* 55 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
exports.__esModule = true;
|
||
exports.default = void 0;
|
||
|
||
var PropTypes = _interopRequireWildcard(__webpack_require__(1));
|
||
|
||
var _addClass = _interopRequireDefault(__webpack_require__(56));
|
||
|
||
var _removeClass = _interopRequireDefault(__webpack_require__(59));
|
||
|
||
var _react = _interopRequireDefault(__webpack_require__(0));
|
||
|
||
var _Transition = _interopRequireDefault(__webpack_require__(16));
|
||
|
||
var _PropTypes = __webpack_require__(19);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }
|
||
|
||
function _extends() { _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; }; return _extends.apply(this, arguments); }
|
||
|
||
function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
|
||
|
||
var addClass = function addClass(node, classes) {
|
||
return node && classes && classes.split(' ').forEach(function (c) {
|
||
return (0, _addClass.default)(node, c);
|
||
});
|
||
};
|
||
|
||
var removeClass = function removeClass(node, classes) {
|
||
return node && classes && classes.split(' ').forEach(function (c) {
|
||
return (0, _removeClass.default)(node, c);
|
||
});
|
||
};
|
||
/**
|
||
* A `Transition` component using CSS transitions and animations.
|
||
* It's inspired by the excellent [ng-animate](http://www.nganimate.org/) library.
|
||
*
|
||
* `CSSTransition` applies a pair of class names during the `appear`, `enter`,
|
||
* and `exit` stages of the transition. The first class is applied and then a
|
||
* second "active" class in order to activate the css animation. After the animation,
|
||
* matching `done` class names are applied to persist the animation state.
|
||
*
|
||
* When the `in` prop is toggled to `true` the Component will get
|
||
* the `example-enter` CSS class and the `example-enter-active` CSS class
|
||
* added in the next tick. This is a convention based on the `classNames` prop.
|
||
*/
|
||
|
||
|
||
var CSSTransition =
|
||
/*#__PURE__*/
|
||
function (_React$Component) {
|
||
_inheritsLoose(CSSTransition, _React$Component);
|
||
|
||
function CSSTransition() {
|
||
var _this;
|
||
|
||
for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
|
||
args[_key] = arguments[_key];
|
||
}
|
||
|
||
_this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;
|
||
|
||
_this.onEnter = function (node, appearing) {
|
||
var _this$getClassNames = _this.getClassNames(appearing ? 'appear' : 'enter'),
|
||
className = _this$getClassNames.className;
|
||
|
||
_this.removeClasses(node, 'exit');
|
||
|
||
addClass(node, className);
|
||
|
||
if (_this.props.onEnter) {
|
||
_this.props.onEnter(node, appearing);
|
||
}
|
||
};
|
||
|
||
_this.onEntering = function (node, appearing) {
|
||
var _this$getClassNames2 = _this.getClassNames(appearing ? 'appear' : 'enter'),
|
||
activeClassName = _this$getClassNames2.activeClassName;
|
||
|
||
_this.reflowAndAddClass(node, activeClassName);
|
||
|
||
if (_this.props.onEntering) {
|
||
_this.props.onEntering(node, appearing);
|
||
}
|
||
};
|
||
|
||
_this.onEntered = function (node, appearing) {
|
||
var _this$getClassNames3 = _this.getClassNames('enter'),
|
||
doneClassName = _this$getClassNames3.doneClassName;
|
||
|
||
_this.removeClasses(node, appearing ? 'appear' : 'enter');
|
||
|
||
addClass(node, doneClassName);
|
||
|
||
if (_this.props.onEntered) {
|
||
_this.props.onEntered(node, appearing);
|
||
}
|
||
};
|
||
|
||
_this.onExit = function (node) {
|
||
var _this$getClassNames4 = _this.getClassNames('exit'),
|
||
className = _this$getClassNames4.className;
|
||
|
||
_this.removeClasses(node, 'appear');
|
||
|
||
_this.removeClasses(node, 'enter');
|
||
|
||
addClass(node, className);
|
||
|
||
if (_this.props.onExit) {
|
||
_this.props.onExit(node);
|
||
}
|
||
};
|
||
|
||
_this.onExiting = function (node) {
|
||
var _this$getClassNames5 = _this.getClassNames('exit'),
|
||
activeClassName = _this$getClassNames5.activeClassName;
|
||
|
||
_this.reflowAndAddClass(node, activeClassName);
|
||
|
||
if (_this.props.onExiting) {
|
||
_this.props.onExiting(node);
|
||
}
|
||
};
|
||
|
||
_this.onExited = function (node) {
|
||
var _this$getClassNames6 = _this.getClassNames('exit'),
|
||
doneClassName = _this$getClassNames6.doneClassName;
|
||
|
||
_this.removeClasses(node, 'exit');
|
||
|
||
addClass(node, doneClassName);
|
||
|
||
if (_this.props.onExited) {
|
||
_this.props.onExited(node);
|
||
}
|
||
};
|
||
|
||
_this.getClassNames = function (type) {
|
||
var classNames = _this.props.classNames;
|
||
var className = typeof classNames !== 'string' ? classNames[type] : classNames + '-' + type;
|
||
var activeClassName = typeof classNames !== 'string' ? classNames[type + 'Active'] : className + '-active';
|
||
var doneClassName = typeof classNames !== 'string' ? classNames[type + 'Done'] : className + '-done';
|
||
return {
|
||
className: className,
|
||
activeClassName: activeClassName,
|
||
doneClassName: doneClassName
|
||
};
|
||
};
|
||
|
||
return _this;
|
||
}
|
||
|
||
var _proto = CSSTransition.prototype;
|
||
|
||
_proto.removeClasses = function removeClasses(node, type) {
|
||
var _this$getClassNames7 = this.getClassNames(type),
|
||
className = _this$getClassNames7.className,
|
||
activeClassName = _this$getClassNames7.activeClassName,
|
||
doneClassName = _this$getClassNames7.doneClassName;
|
||
|
||
className && removeClass(node, className);
|
||
activeClassName && removeClass(node, activeClassName);
|
||
doneClassName && removeClass(node, doneClassName);
|
||
};
|
||
|
||
_proto.reflowAndAddClass = function reflowAndAddClass(node, className) {
|
||
// This is for to force a repaint,
|
||
// which is necessary in order to transition styles when adding a class name.
|
||
if (className) {
|
||
/* eslint-disable no-unused-expressions */
|
||
node && node.scrollTop;
|
||
/* eslint-enable no-unused-expressions */
|
||
|
||
addClass(node, className);
|
||
}
|
||
};
|
||
|
||
_proto.render = function render() {
|
||
var props = _extends({}, this.props);
|
||
|
||
delete props.classNames;
|
||
return _react.default.createElement(_Transition.default, _extends({}, props, {
|
||
onEnter: this.onEnter,
|
||
onEntered: this.onEntered,
|
||
onEntering: this.onEntering,
|
||
onExit: this.onExit,
|
||
onExiting: this.onExiting,
|
||
onExited: this.onExited
|
||
}));
|
||
};
|
||
|
||
return CSSTransition;
|
||
}(_react.default.Component);
|
||
|
||
CSSTransition.propTypes = false ? _extends({}, _Transition.default.propTypes, {
|
||
/**
|
||
* The animation classNames applied to the component as it enters, exits or has finished the transition.
|
||
* A single name can be provided and it will be suffixed for each stage: e.g.
|
||
*
|
||
* `classNames="fade"` applies `fade-enter`, `fade-enter-active`, `fade-enter-done`,
|
||
* `fade-exit`, `fade-exit-active`, `fade-exit-done`, `fade-appear`, and `fade-appear-active`.
|
||
* Each individual classNames can also be specified independently like:
|
||
*
|
||
* ```js
|
||
* classNames={{
|
||
* appear: 'my-appear',
|
||
* appearActive: 'my-active-appear',
|
||
* enter: 'my-enter',
|
||
* enterActive: 'my-active-enter',
|
||
* enterDone: 'my-done-enter',
|
||
* exit: 'my-exit',
|
||
* exitActive: 'my-active-exit',
|
||
* exitDone: 'my-done-exit',
|
||
* }}
|
||
* ```
|
||
*
|
||
* If you want to set these classes using CSS Modules:
|
||
*
|
||
* ```js
|
||
* import styles from './styles.css';
|
||
* ```
|
||
*
|
||
* you might want to use camelCase in your CSS file, that way could simply spread
|
||
* them instead of listing them one by one:
|
||
*
|
||
* ```js
|
||
* classNames={{ ...styles }}
|
||
* ```
|
||
*
|
||
* @type {string | {
|
||
* appear?: string,
|
||
* appearActive?: string,
|
||
* enter?: string,
|
||
* enterActive?: string,
|
||
* enterDone?: string,
|
||
* exit?: string,
|
||
* exitActive?: string,
|
||
* exitDone?: string,
|
||
* }}
|
||
*/
|
||
classNames: _PropTypes.classNamesShape,
|
||
|
||
/**
|
||
* A `<Transition>` callback fired immediately after the 'enter' or 'appear' class is
|
||
* applied.
|
||
*
|
||
* @type Function(node: HtmlElement, isAppearing: bool)
|
||
*/
|
||
onEnter: PropTypes.func,
|
||
|
||
/**
|
||
* A `<Transition>` callback fired immediately after the 'enter-active' or
|
||
* 'appear-active' class is applied.
|
||
*
|
||
* @type Function(node: HtmlElement, isAppearing: bool)
|
||
*/
|
||
onEntering: PropTypes.func,
|
||
|
||
/**
|
||
* A `<Transition>` callback fired immediately after the 'enter' or
|
||
* 'appear' classes are **removed** and the `done` class is added to the DOM node.
|
||
*
|
||
* @type Function(node: HtmlElement, isAppearing: bool)
|
||
*/
|
||
onEntered: PropTypes.func,
|
||
|
||
/**
|
||
* A `<Transition>` callback fired immediately after the 'exit' class is
|
||
* applied.
|
||
*
|
||
* @type Function(node: HtmlElement)
|
||
*/
|
||
onExit: PropTypes.func,
|
||
|
||
/**
|
||
* A `<Transition>` callback fired immediately after the 'exit-active' is applied.
|
||
*
|
||
* @type Function(node: HtmlElement)
|
||
*/
|
||
onExiting: PropTypes.func,
|
||
|
||
/**
|
||
* A `<Transition>` callback fired immediately after the 'exit' classes
|
||
* are **removed** and the `exit-done` class is added to the DOM node.
|
||
*
|
||
* @type Function(node: HtmlElement)
|
||
*/
|
||
onExited: PropTypes.func
|
||
}) : {};
|
||
var _default = CSSTransition;
|
||
exports.default = _default;
|
||
module.exports = exports["default"];
|
||
|
||
/***/ }),
|
||
/* 56 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
var _interopRequireDefault = __webpack_require__(57);
|
||
|
||
exports.__esModule = true;
|
||
exports.default = addClass;
|
||
|
||
var _hasClass = _interopRequireDefault(__webpack_require__(58));
|
||
|
||
function addClass(element, className) {
|
||
if (element.classList) element.classList.add(className);else if (!(0, _hasClass.default)(element, className)) if (typeof element.className === 'string') element.className = element.className + ' ' + className;else element.setAttribute('class', (element.className && element.className.baseVal || '') + ' ' + className);
|
||
}
|
||
|
||
module.exports = exports["default"];
|
||
|
||
/***/ }),
|
||
/* 57 */
|
||
/***/ (function(module, exports) {
|
||
|
||
function _interopRequireDefault(obj) {
|
||
return obj && obj.__esModule ? obj : {
|
||
"default": obj
|
||
};
|
||
}
|
||
|
||
module.exports = _interopRequireDefault;
|
||
|
||
/***/ }),
|
||
/* 58 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
exports.__esModule = true;
|
||
exports.default = hasClass;
|
||
|
||
function hasClass(element, className) {
|
||
if (element.classList) return !!className && element.classList.contains(className);else return (" " + (element.className.baseVal || element.className) + " ").indexOf(" " + className + " ") !== -1;
|
||
}
|
||
|
||
module.exports = exports["default"];
|
||
|
||
/***/ }),
|
||
/* 59 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
function replaceClassName(origClass, classToRemove) {
|
||
return origClass.replace(new RegExp('(^|\\s)' + classToRemove + '(?:\\s|$)', 'g'), '$1').replace(/\s+/g, ' ').replace(/^\s*|\s*$/g, '');
|
||
}
|
||
|
||
module.exports = function removeClass(element, className) {
|
||
if (element.classList) element.classList.remove(className);else if (typeof element.className === 'string') element.className = replaceClassName(element.className, className);else element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));
|
||
};
|
||
|
||
/***/ }),
|
||
/* 60 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
exports.__esModule = true;
|
||
exports.default = void 0;
|
||
|
||
var _propTypes = _interopRequireDefault(__webpack_require__(1));
|
||
|
||
var _react = _interopRequireDefault(__webpack_require__(0));
|
||
|
||
var _reactDom = __webpack_require__(17);
|
||
|
||
var _TransitionGroup = _interopRequireDefault(__webpack_require__(20));
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
|
||
|
||
function _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }
|
||
|
||
/**
|
||
* The `<ReplaceTransition>` component is a specialized `Transition` component
|
||
* that animates between two children.
|
||
*
|
||
* ```jsx
|
||
* <ReplaceTransition in>
|
||
* <Fade><div>I appear first</div></Fade>
|
||
* <Fade><div>I replace the above</div></Fade>
|
||
* </ReplaceTransition>
|
||
* ```
|
||
*/
|
||
var ReplaceTransition =
|
||
/*#__PURE__*/
|
||
function (_React$Component) {
|
||
_inheritsLoose(ReplaceTransition, _React$Component);
|
||
|
||
function ReplaceTransition() {
|
||
var _this;
|
||
|
||
for (var _len = arguments.length, _args = new Array(_len), _key = 0; _key < _len; _key++) {
|
||
_args[_key] = arguments[_key];
|
||
}
|
||
|
||
_this = _React$Component.call.apply(_React$Component, [this].concat(_args)) || this;
|
||
|
||
_this.handleEnter = function () {
|
||
for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
|
||
args[_key2] = arguments[_key2];
|
||
}
|
||
|
||
return _this.handleLifecycle('onEnter', 0, args);
|
||
};
|
||
|
||
_this.handleEntering = function () {
|
||
for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {
|
||
args[_key3] = arguments[_key3];
|
||
}
|
||
|
||
return _this.handleLifecycle('onEntering', 0, args);
|
||
};
|
||
|
||
_this.handleEntered = function () {
|
||
for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {
|
||
args[_key4] = arguments[_key4];
|
||
}
|
||
|
||
return _this.handleLifecycle('onEntered', 0, args);
|
||
};
|
||
|
||
_this.handleExit = function () {
|
||
for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {
|
||
args[_key5] = arguments[_key5];
|
||
}
|
||
|
||
return _this.handleLifecycle('onExit', 1, args);
|
||
};
|
||
|
||
_this.handleExiting = function () {
|
||
for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {
|
||
args[_key6] = arguments[_key6];
|
||
}
|
||
|
||
return _this.handleLifecycle('onExiting', 1, args);
|
||
};
|
||
|
||
_this.handleExited = function () {
|
||
for (var _len7 = arguments.length, args = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {
|
||
args[_key7] = arguments[_key7];
|
||
}
|
||
|
||
return _this.handleLifecycle('onExited', 1, args);
|
||
};
|
||
|
||
return _this;
|
||
}
|
||
|
||
var _proto = ReplaceTransition.prototype;
|
||
|
||
_proto.handleLifecycle = function handleLifecycle(handler, idx, originalArgs) {
|
||
var _child$props;
|
||
|
||
var children = this.props.children;
|
||
|
||
var child = _react.default.Children.toArray(children)[idx];
|
||
|
||
if (child.props[handler]) (_child$props = child.props)[handler].apply(_child$props, originalArgs);
|
||
if (this.props[handler]) this.props[handler]((0, _reactDom.findDOMNode)(this));
|
||
};
|
||
|
||
_proto.render = function render() {
|
||
var _this$props = this.props,
|
||
children = _this$props.children,
|
||
inProp = _this$props.in,
|
||
props = _objectWithoutPropertiesLoose(_this$props, ["children", "in"]);
|
||
|
||
var _React$Children$toArr = _react.default.Children.toArray(children),
|
||
first = _React$Children$toArr[0],
|
||
second = _React$Children$toArr[1];
|
||
|
||
delete props.onEnter;
|
||
delete props.onEntering;
|
||
delete props.onEntered;
|
||
delete props.onExit;
|
||
delete props.onExiting;
|
||
delete props.onExited;
|
||
return _react.default.createElement(_TransitionGroup.default, props, inProp ? _react.default.cloneElement(first, {
|
||
key: 'first',
|
||
onEnter: this.handleEnter,
|
||
onEntering: this.handleEntering,
|
||
onEntered: this.handleEntered
|
||
}) : _react.default.cloneElement(second, {
|
||
key: 'second',
|
||
onEnter: this.handleExit,
|
||
onEntering: this.handleExiting,
|
||
onEntered: this.handleExited
|
||
}));
|
||
};
|
||
|
||
return ReplaceTransition;
|
||
}(_react.default.Component);
|
||
|
||
ReplaceTransition.propTypes = false ? {
|
||
in: _propTypes.default.bool.isRequired,
|
||
children: function children(props, propName) {
|
||
if (_react.default.Children.count(props[propName]) !== 2) return new Error("\"" + propName + "\" must be exactly two transition components.");
|
||
return null;
|
||
}
|
||
} : {};
|
||
var _default = ReplaceTransition;
|
||
exports.default = _default;
|
||
module.exports = exports["default"];
|
||
|
||
/***/ }),
|
||
/* 61 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
exports.__esModule = true;
|
||
exports.getChildMapping = getChildMapping;
|
||
exports.mergeChildMappings = mergeChildMappings;
|
||
exports.getInitialChildMapping = getInitialChildMapping;
|
||
exports.getNextChildMapping = getNextChildMapping;
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
/**
|
||
* Given `this.props.children`, return an object mapping key to child.
|
||
*
|
||
* @param {*} children `this.props.children`
|
||
* @return {object} Mapping of key to child
|
||
*/
|
||
function getChildMapping(children, mapFn) {
|
||
var mapper = function mapper(child) {
|
||
return mapFn && (0, _react.isValidElement)(child) ? mapFn(child) : child;
|
||
};
|
||
|
||
var result = Object.create(null);
|
||
if (children) _react.Children.map(children, function (c) {
|
||
return c;
|
||
}).forEach(function (child) {
|
||
// run the map function here instead so that the key is the computed one
|
||
result[child.key] = mapper(child);
|
||
});
|
||
return result;
|
||
}
|
||
/**
|
||
* When you're adding or removing children some may be added or removed in the
|
||
* same render pass. We want to show *both* since we want to simultaneously
|
||
* animate elements in and out. This function takes a previous set of keys
|
||
* and a new set of keys and merges them with its best guess of the correct
|
||
* ordering. In the future we may expose some of the utilities in
|
||
* ReactMultiChild to make this easy, but for now React itself does not
|
||
* directly have this concept of the union of prevChildren and nextChildren
|
||
* so we implement it here.
|
||
*
|
||
* @param {object} prev prev children as returned from
|
||
* `ReactTransitionChildMapping.getChildMapping()`.
|
||
* @param {object} next next children as returned from
|
||
* `ReactTransitionChildMapping.getChildMapping()`.
|
||
* @return {object} a key set that contains all keys in `prev` and all keys
|
||
* in `next` in a reasonable order.
|
||
*/
|
||
|
||
|
||
function mergeChildMappings(prev, next) {
|
||
prev = prev || {};
|
||
next = next || {};
|
||
|
||
function getValueForKey(key) {
|
||
return key in next ? next[key] : prev[key];
|
||
} // For each key of `next`, the list of keys to insert before that key in
|
||
// the combined list
|
||
|
||
|
||
var nextKeysPending = Object.create(null);
|
||
var pendingKeys = [];
|
||
|
||
for (var prevKey in prev) {
|
||
if (prevKey in next) {
|
||
if (pendingKeys.length) {
|
||
nextKeysPending[prevKey] = pendingKeys;
|
||
pendingKeys = [];
|
||
}
|
||
} else {
|
||
pendingKeys.push(prevKey);
|
||
}
|
||
}
|
||
|
||
var i;
|
||
var childMapping = {};
|
||
|
||
for (var nextKey in next) {
|
||
if (nextKeysPending[nextKey]) {
|
||
for (i = 0; i < nextKeysPending[nextKey].length; i++) {
|
||
var pendingNextKey = nextKeysPending[nextKey][i];
|
||
childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);
|
||
}
|
||
}
|
||
|
||
childMapping[nextKey] = getValueForKey(nextKey);
|
||
} // Finally, add the keys which didn't appear before any key in `next`
|
||
|
||
|
||
for (i = 0; i < pendingKeys.length; i++) {
|
||
childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);
|
||
}
|
||
|
||
return childMapping;
|
||
}
|
||
|
||
function getProp(child, prop, props) {
|
||
return props[prop] != null ? props[prop] : child.props[prop];
|
||
}
|
||
|
||
function getInitialChildMapping(props, onExited) {
|
||
return getChildMapping(props.children, function (child) {
|
||
return (0, _react.cloneElement)(child, {
|
||
onExited: onExited.bind(null, child),
|
||
in: true,
|
||
appear: getProp(child, 'appear', props),
|
||
enter: getProp(child, 'enter', props),
|
||
exit: getProp(child, 'exit', props)
|
||
});
|
||
});
|
||
}
|
||
|
||
function getNextChildMapping(nextProps, prevChildMapping, onExited) {
|
||
var nextChildMapping = getChildMapping(nextProps.children);
|
||
var children = mergeChildMappings(prevChildMapping, nextChildMapping);
|
||
Object.keys(children).forEach(function (key) {
|
||
var child = children[key];
|
||
if (!(0, _react.isValidElement)(child)) return;
|
||
var hasPrev = key in prevChildMapping;
|
||
var hasNext = key in nextChildMapping;
|
||
var prevChild = prevChildMapping[key];
|
||
var isLeaving = (0, _react.isValidElement)(prevChild) && !prevChild.props.in; // item is new (entering)
|
||
|
||
if (hasNext && (!hasPrev || isLeaving)) {
|
||
// console.log('entering', key)
|
||
children[key] = (0, _react.cloneElement)(child, {
|
||
onExited: onExited.bind(null, child),
|
||
in: true,
|
||
exit: getProp(child, 'exit', nextProps),
|
||
enter: getProp(child, 'enter', nextProps)
|
||
});
|
||
} else if (!hasNext && hasPrev && !isLeaving) {
|
||
// item is old (exiting)
|
||
// console.log('leaving', key)
|
||
children[key] = (0, _react.cloneElement)(child, {
|
||
in: false
|
||
});
|
||
} else if (hasNext && hasPrev && (0, _react.isValidElement)(prevChild)) {
|
||
// item hasn't changed transition states
|
||
// copy over the last transition props;
|
||
// console.log('unchanged', key)
|
||
children[key] = (0, _react.cloneElement)(child, {
|
||
onExited: onExited.bind(null, child),
|
||
in: prevChild.props.in,
|
||
exit: getProp(child, 'exit', nextProps),
|
||
enter: getProp(child, 'enter', nextProps)
|
||
});
|
||
}
|
||
});
|
||
return children;
|
||
}
|
||
|
||
/***/ }),
|
||
/* 62 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
var _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _rowTemplate = __webpack_require__(12);
|
||
|
||
var _rowTemplate2 = _interopRequireDefault(_rowTemplate);
|
||
|
||
var _footerCell = __webpack_require__(63);
|
||
|
||
var _footerCell2 = _interopRequireDefault(_footerCell);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
var Footer = function Footer(props) {
|
||
var data = props.data,
|
||
className = props.className,
|
||
columns = props.columns,
|
||
selectRow = props.selectRow,
|
||
expandRow = props.expandRow;
|
||
|
||
|
||
function renderContent() {
|
||
return columns.map(function (column, i) {
|
||
if (column.footer === undefined || column.footer === null) {
|
||
return false;
|
||
}
|
||
|
||
var columnData = _utils2.default.pluck(data, column.dataField);
|
||
|
||
return _react2.default.createElement(_footerCell2.default, {
|
||
index: i,
|
||
key: column.dataField,
|
||
column: column,
|
||
columnData: columnData
|
||
});
|
||
});
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
'tfoot',
|
||
null,
|
||
_react2.default.createElement(_rowTemplate2.default, {
|
||
renderContent: renderContent,
|
||
selectRow: selectRow,
|
||
expandRow: expandRow,
|
||
className: className,
|
||
cellEl: 'th'
|
||
})
|
||
);
|
||
}; /* eslint react/require-default-props: 0 */
|
||
|
||
|
||
Footer.propTypes = {
|
||
data: _propTypes2.default.array,
|
||
className: _propTypes2.default.string,
|
||
columns: _propTypes2.default.array,
|
||
selectRow: _propTypes2.default.object,
|
||
expandRow: _propTypes2.default.object
|
||
};
|
||
|
||
exports.default = Footer;
|
||
|
||
/***/ }),
|
||
/* 63 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _classnames = __webpack_require__(4);
|
||
|
||
var _classnames2 = _interopRequireDefault(_classnames);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _cellEventDelegater = __webpack_require__(7);
|
||
|
||
var _cellEventDelegater2 = _interopRequireDefault(_cellEventDelegater);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/require-default-props: 0 */
|
||
|
||
|
||
var FooterCell = function (_eventDelegater) {
|
||
_inherits(FooterCell, _eventDelegater);
|
||
|
||
function FooterCell() {
|
||
_classCallCheck(this, FooterCell);
|
||
|
||
return _possibleConstructorReturn(this, (FooterCell.__proto__ || Object.getPrototypeOf(FooterCell)).apply(this, arguments));
|
||
}
|
||
|
||
_createClass(FooterCell, [{
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
index = _props.index,
|
||
column = _props.column,
|
||
columnData = _props.columnData;
|
||
var footer = column.footer,
|
||
footerTitle = column.footerTitle,
|
||
footerAlign = column.footerAlign,
|
||
footerFormatter = column.footerFormatter,
|
||
footerEvents = column.footerEvents,
|
||
footerClasses = column.footerClasses,
|
||
footerStyle = column.footerStyle,
|
||
footerAttrs = column.footerAttrs;
|
||
|
||
|
||
var delegateEvents = this.delegate(footerEvents);
|
||
var cellAttrs = _extends({}, _utils2.default.isFunction(footerAttrs) ? footerAttrs(column, index) : footerAttrs, delegateEvents);
|
||
|
||
var text = '';
|
||
if (_utils2.default.isString(footer)) {
|
||
text = footer;
|
||
} else if (_utils2.default.isFunction(footer)) {
|
||
text = footer(columnData, column, index);
|
||
}
|
||
|
||
var cellStyle = {};
|
||
var cellClasses = _utils2.default.isFunction(footerClasses) ? footerClasses(column, index) : footerClasses;
|
||
|
||
if (footerStyle) {
|
||
cellStyle = _utils2.default.isFunction(footerStyle) ? footerStyle(column, index) : footerStyle;
|
||
cellStyle = cellStyle ? _extends({}, cellStyle) : cellStyle;
|
||
}
|
||
|
||
if (footerTitle) {
|
||
cellAttrs.title = _utils2.default.isFunction(footerTitle) ? footerTitle(column, index) : text;
|
||
}
|
||
|
||
if (footerAlign) {
|
||
cellStyle.textAlign = _utils2.default.isFunction(footerAlign) ? footerAlign(column, index) : footerAlign;
|
||
}
|
||
|
||
if (cellClasses) cellAttrs.className = (0, _classnames2.default)(cellAttrs.className, cellClasses);
|
||
if (!_utils2.default.isEmptyObject(cellStyle)) cellAttrs.style = cellStyle;
|
||
|
||
var children = footerFormatter ? footerFormatter(column, index) : text;
|
||
|
||
return _react2.default.createElement('th', cellAttrs, children);
|
||
}
|
||
}]);
|
||
|
||
return FooterCell;
|
||
}((0, _cellEventDelegater2.default)(_react2.default.Component));
|
||
|
||
FooterCell.propTypes = {
|
||
columnData: _propTypes2.default.array,
|
||
index: _propTypes2.default.number,
|
||
column: _propTypes2.default.object
|
||
};
|
||
|
||
exports.default = FooterCell;
|
||
|
||
/***/ }),
|
||
/* 64 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _columnResolver = __webpack_require__(65);
|
||
|
||
var _columnResolver2 = _interopRequireDefault(_columnResolver);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; }
|
||
|
||
exports.default = function (ExtendBase) {
|
||
return function (_ColumnResolver) {
|
||
_inherits(TableResolver, _ColumnResolver);
|
||
|
||
function TableResolver() {
|
||
_classCallCheck(this, TableResolver);
|
||
|
||
return _possibleConstructorReturn(this, (TableResolver.__proto__ || Object.getPrototypeOf(TableResolver)).apply(this, arguments));
|
||
}
|
||
|
||
_createClass(TableResolver, [{
|
||
key: 'validateProps',
|
||
value: function validateProps() {
|
||
var keyField = this.props.keyField;
|
||
|
||
if (!keyField) {
|
||
throw new Error('Please specify a field as key via keyField');
|
||
}
|
||
if (this.visibleColumnSize(false) <= 0) {
|
||
throw new Error('No visible columns detected');
|
||
}
|
||
}
|
||
}, {
|
||
key: 'isEmpty',
|
||
value: function isEmpty() {
|
||
return this.props.data.length === 0;
|
||
}
|
||
}, {
|
||
key: 'visibleRows',
|
||
value: function visibleRows() {
|
||
var _props = this.props,
|
||
data = _props.data,
|
||
hiddenRows = _props.hiddenRows,
|
||
keyField = _props.keyField;
|
||
|
||
if (!hiddenRows || hiddenRows.length === 0) return data;
|
||
return data.filter(function (row) {
|
||
var key = _utils2.default.get(row, keyField);
|
||
return !_utils2.default.contains(hiddenRows, key);
|
||
});
|
||
}
|
||
}]);
|
||
|
||
return TableResolver;
|
||
}((0, _columnResolver2.default)(ExtendBase));
|
||
};
|
||
|
||
/***/ }),
|
||
/* 65 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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; }; }();
|
||
|
||
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; }
|
||
|
||
exports.default = function (ExtendBase) {
|
||
return function (_ExtendBase) {
|
||
_inherits(ColumnResolver, _ExtendBase);
|
||
|
||
function ColumnResolver() {
|
||
_classCallCheck(this, ColumnResolver);
|
||
|
||
return _possibleConstructorReturn(this, (ColumnResolver.__proto__ || Object.getPrototypeOf(ColumnResolver)).apply(this, arguments));
|
||
}
|
||
|
||
_createClass(ColumnResolver, [{
|
||
key: "visibleColumnSize",
|
||
value: function visibleColumnSize() {
|
||
var includeSelectColumn = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : true;
|
||
|
||
var columnLen = void 0;
|
||
if (this.props.columnToggle && this.props.columnToggle.toggles) {
|
||
var columns = this.props.columnToggle.toggles;
|
||
columnLen = Object.keys(columns).filter(function (name) {
|
||
return columns[name];
|
||
}).length;
|
||
} else {
|
||
columnLen = this.props.columns.filter(function (c) {
|
||
return !c.hidden;
|
||
}).length;
|
||
}
|
||
if (!includeSelectColumn) return columnLen;
|
||
if (this.props.selectRow && !this.props.selectRow.hideSelectColumn) {
|
||
columnLen += 1;
|
||
}
|
||
if (this.props.expandRow && this.props.expandRow.showExpandColumn) {
|
||
columnLen += 1;
|
||
}
|
||
return columnLen;
|
||
}
|
||
}]);
|
||
|
||
return ColumnResolver;
|
||
}(ExtendBase);
|
||
};
|
||
|
||
/***/ }),
|
||
/* 66 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _events = __webpack_require__(21);
|
||
|
||
var _events2 = _interopRequireDefault(_events);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
var _dataContext = __webpack_require__(67);
|
||
|
||
var _dataContext2 = _interopRequireDefault(_dataContext);
|
||
|
||
var _columnContext = __webpack_require__(68);
|
||
|
||
var _columnContext2 = _interopRequireDefault(_columnContext);
|
||
|
||
var _sortContext = __webpack_require__(69);
|
||
|
||
var _sortContext2 = _interopRequireDefault(_sortContext);
|
||
|
||
var _selectionContext = __webpack_require__(8);
|
||
|
||
var _selectionContext2 = _interopRequireDefault(_selectionContext);
|
||
|
||
var _rowExpandContext = __webpack_require__(10);
|
||
|
||
var _rowExpandContext2 = _interopRequireDefault(_rowExpandContext);
|
||
|
||
var _remoteResolver2 = __webpack_require__(70);
|
||
|
||
var _remoteResolver3 = _interopRequireDefault(_remoteResolver2);
|
||
|
||
var _bootstrap = __webpack_require__(5);
|
||
|
||
var _operators = __webpack_require__(9);
|
||
|
||
var _operators2 = _interopRequireDefault(_operators);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint camelcase: 0 */
|
||
/* eslint no-return-assign: 0 */
|
||
/* eslint no-param-reassign: 0 */
|
||
/* eslint class-methods-use-this: 0 */
|
||
|
||
|
||
var withContext = function withContext(Base) {
|
||
return function (_remoteResolver) {
|
||
_inherits(BootstrapTableContainer, _remoteResolver);
|
||
|
||
function BootstrapTableContainer(props) {
|
||
_classCallCheck(this, BootstrapTableContainer);
|
||
|
||
var _this = _possibleConstructorReturn(this, (BootstrapTableContainer.__proto__ || Object.getPrototypeOf(BootstrapTableContainer)).call(this, props));
|
||
|
||
_this.DataContext = (0, _dataContext2.default)();
|
||
|
||
if (props.registerExposedAPI) {
|
||
var exposedAPIEmitter = new _events2.default();
|
||
exposedAPIEmitter.on('get.table.data', function (payload) {
|
||
return payload.result = _this.table.getData();
|
||
});
|
||
exposedAPIEmitter.on('get.selected.rows', function (payload) {
|
||
return payload.result = _this.selectionContext.getSelected();
|
||
});
|
||
exposedAPIEmitter.on('get.filtered.rows', function (payload) {
|
||
if (_this.searchContext) {
|
||
payload.result = _this.searchContext.getSearched();
|
||
} else if (_this.filterContext) {
|
||
payload.result = _this.filterContext.getFiltered();
|
||
} else {
|
||
payload.result = _this.table.getData();
|
||
}
|
||
});
|
||
props.registerExposedAPI(exposedAPIEmitter);
|
||
}
|
||
|
||
if (props.columns.filter(function (col) {
|
||
return col.sort;
|
||
}).length > 0) {
|
||
_this.SortContext = (0, _sortContext2.default)(_operators2.default, _this.isRemoteSort, _this.handleRemoteSortChange);
|
||
}
|
||
|
||
if (props.columnToggle || props.columns.filter(function (col) {
|
||
return col.hidden;
|
||
}).length > 0) {
|
||
_this.ColumnManagementContext = (0, _columnContext2.default)();
|
||
}
|
||
|
||
if (props.selectRow) {
|
||
_this.SelectionContext = _selectionContext2.default;
|
||
}
|
||
|
||
if (props.expandRow) {
|
||
_this.RowExpandContext = _rowExpandContext2.default;
|
||
}
|
||
|
||
if (props.cellEdit && props.cellEdit.createContext) {
|
||
_this.CellEditContext = props.cellEdit.createContext(_utils2.default, _operators2.default, _this.isRemoteCellEdit, _this.handleRemoteCellChange);
|
||
}
|
||
|
||
if (props.filter) {
|
||
_this.FilterContext = props.filter.createContext(_utils2.default, _this.isRemoteFiltering, _this.handleRemoteFilterChange);
|
||
}
|
||
|
||
if (props.pagination) {
|
||
_this.PaginationContext = props.pagination.createContext();
|
||
}
|
||
|
||
if (props.search && props.search.searchContext) {
|
||
_this.SearchContext = props.search.searchContext(_utils2.default, _this.isRemoteSearch, _this.handleRemoteSearchChange);
|
||
}
|
||
|
||
if (props.setDependencyModules) {
|
||
props.setDependencyModules(_utils2.default);
|
||
}
|
||
|
||
if (props.setPaginationRemoteEmitter) {
|
||
props.setPaginationRemoteEmitter(_this.remoteEmitter);
|
||
}
|
||
return _this;
|
||
}
|
||
|
||
_createClass(BootstrapTableContainer, [{
|
||
key: 'UNSAFE_componentWillReceiveProps',
|
||
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
||
if (nextProps.columns.filter(function (col) {
|
||
return col.sort;
|
||
}).length <= 0) {
|
||
this.SortContext = null;
|
||
} else if (!this.SortContext) {
|
||
this.SortContext = (0, _sortContext2.default)(_operators2.default, this.isRemoteSort, this.handleRemoteSortChange);
|
||
}
|
||
if (!nextProps.pagination && this.props.pagination) {
|
||
this.PaginationContext = null;
|
||
}
|
||
if (nextProps.pagination && !this.props.pagination) {
|
||
this.PaginationContext = nextProps.pagination.createContext(this.isRemotePagination, this.handleRemotePageChange);
|
||
}
|
||
if (!nextProps.cellEdit && this.props.cellEdit) {
|
||
this.CellEditContext = null;
|
||
}
|
||
if (nextProps.cellEdit && !this.props.cellEdit) {
|
||
this.CellEditContext = nextProps.cellEdit.createContext(_utils2.default, _operators2.default, this.isRemoteCellEdit, this.handleRemoteCellChange);
|
||
}
|
||
}
|
||
}, {
|
||
key: 'renderBase',
|
||
value: function renderBase() {
|
||
var _this2 = this;
|
||
|
||
return function (rootProps, filterProps, searchProps, sortProps, paginationProps, columnToggleProps) {
|
||
return _react2.default.createElement(Base, _extends({
|
||
ref: function ref(n) {
|
||
return _this2.table = n;
|
||
}
|
||
}, _this2.props, sortProps, filterProps, searchProps, paginationProps, columnToggleProps, {
|
||
data: rootProps.getData(filterProps, searchProps, sortProps, paginationProps)
|
||
}));
|
||
};
|
||
}
|
||
}, {
|
||
key: 'renderWithColumnManagementCtx',
|
||
value: function renderWithColumnManagementCtx(base, baseProps) {
|
||
var _this3 = this;
|
||
|
||
return function (rootProps, filterProps, searchProps, sortProps, paginationProps) {
|
||
return _react2.default.createElement(
|
||
_this3.ColumnManagementContext.Provider,
|
||
_extends({}, baseProps, {
|
||
toggles: _this3.props.columnToggle ? _this3.props.columnToggle.toggles : null
|
||
}),
|
||
_react2.default.createElement(
|
||
_this3.ColumnManagementContext.Consumer,
|
||
null,
|
||
function (columnToggleProps) {
|
||
return base(rootProps, filterProps, searchProps, sortProps, paginationProps, columnToggleProps);
|
||
}
|
||
)
|
||
);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'renderWithSelectionCtx',
|
||
value: function renderWithSelectionCtx(base, baseProps) {
|
||
var _this4 = this;
|
||
|
||
return function (rootProps, filterProps, searchProps, sortProps, paginationProps) {
|
||
return _react2.default.createElement(
|
||
_this4.SelectionContext.Provider,
|
||
_extends({}, baseProps, {
|
||
ref: function ref(n) {
|
||
return _this4.selectionContext = n;
|
||
},
|
||
selectRow: _this4.props.selectRow,
|
||
data: rootProps.getData(filterProps, searchProps, sortProps, paginationProps)
|
||
}),
|
||
base(rootProps, filterProps, searchProps, sortProps, paginationProps)
|
||
);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'renderWithRowExpandCtx',
|
||
value: function renderWithRowExpandCtx(base, baseProps) {
|
||
var _this5 = this;
|
||
|
||
return function (rootProps, filterProps, searchProps, sortProps, paginationProps) {
|
||
return _react2.default.createElement(
|
||
_this5.RowExpandContext.Provider,
|
||
_extends({}, baseProps, {
|
||
ref: function ref(n) {
|
||
return _this5.rowExpandContext = n;
|
||
},
|
||
expandRow: _this5.props.expandRow,
|
||
data: rootProps.getData(filterProps, searchProps, sortProps, paginationProps)
|
||
}),
|
||
base(rootProps, filterProps, searchProps, sortProps, paginationProps)
|
||
);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'renderWithPaginationCtx',
|
||
value: function renderWithPaginationCtx(base) {
|
||
var _this6 = this;
|
||
|
||
return function (rootProps, filterProps, searchProps, sortProps) {
|
||
return _react2.default.createElement(
|
||
_this6.PaginationContext.Provider,
|
||
{
|
||
ref: function ref(n) {
|
||
return _this6.paginationContext = n;
|
||
},
|
||
pagination: _this6.props.pagination,
|
||
data: rootProps.getData(filterProps, searchProps, sortProps),
|
||
bootstrap4: _this6.props.bootstrap4,
|
||
isRemotePagination: _this6.isRemotePagination,
|
||
remoteEmitter: _this6.remoteEmitter,
|
||
onDataSizeChange: _this6.props.onDataSizeChange
|
||
},
|
||
_react2.default.createElement(
|
||
_this6.PaginationContext.Consumer,
|
||
null,
|
||
function (paginationProps) {
|
||
return base(rootProps, filterProps, searchProps, sortProps, paginationProps);
|
||
}
|
||
)
|
||
);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'renderWithSortCtx',
|
||
value: function renderWithSortCtx(base, baseProps) {
|
||
var _this7 = this;
|
||
|
||
return function (rootProps, filterProps, searchProps) {
|
||
return _react2.default.createElement(
|
||
_this7.SortContext.Provider,
|
||
_extends({}, baseProps, {
|
||
ref: function ref(n) {
|
||
return _this7.sortContext = n;
|
||
},
|
||
defaultSorted: _this7.props.defaultSorted,
|
||
defaultSortDirection: _this7.props.defaultSortDirection,
|
||
sort: _this7.props.sort,
|
||
data: rootProps.getData(filterProps, searchProps)
|
||
}),
|
||
_react2.default.createElement(
|
||
_this7.SortContext.Consumer,
|
||
null,
|
||
function (sortProps) {
|
||
return base(rootProps, filterProps, searchProps, sortProps);
|
||
}
|
||
)
|
||
);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'renderWithSearchCtx',
|
||
value: function renderWithSearchCtx(base, baseProps) {
|
||
var _this8 = this;
|
||
|
||
return function (rootProps, filterProps) {
|
||
return _react2.default.createElement(
|
||
_this8.SearchContext.Provider,
|
||
_extends({}, baseProps, {
|
||
ref: function ref(n) {
|
||
return _this8.searchContext = n;
|
||
},
|
||
data: rootProps.getData(filterProps),
|
||
searchText: _this8.props.search.searchText,
|
||
dataChangeListener: _this8.props.dataChangeListener
|
||
}),
|
||
_react2.default.createElement(
|
||
_this8.SearchContext.Consumer,
|
||
null,
|
||
function (searchProps) {
|
||
return base(rootProps, filterProps, searchProps);
|
||
}
|
||
)
|
||
);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'renderWithFilterCtx',
|
||
value: function renderWithFilterCtx(base, baseProps) {
|
||
var _this9 = this;
|
||
|
||
return function (rootProps) {
|
||
return _react2.default.createElement(
|
||
_this9.FilterContext.Provider,
|
||
_extends({}, baseProps, {
|
||
ref: function ref(n) {
|
||
return _this9.filterContext = n;
|
||
},
|
||
data: rootProps.getData(),
|
||
dataChangeListener: _this9.props.dataChangeListener
|
||
}),
|
||
_react2.default.createElement(
|
||
_this9.FilterContext.Consumer,
|
||
null,
|
||
function (filterProps) {
|
||
return base(rootProps, filterProps);
|
||
}
|
||
)
|
||
);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'renderWithCellEditCtx',
|
||
value: function renderWithCellEditCtx(base, baseProps) {
|
||
var _this10 = this;
|
||
|
||
return function (rootProps) {
|
||
return _react2.default.createElement(
|
||
_this10.CellEditContext.Provider,
|
||
_extends({}, baseProps, {
|
||
ref: function ref(n) {
|
||
return _this10.cellEditContext = n;
|
||
},
|
||
selectRow: _this10.props.selectRow,
|
||
cellEdit: _this10.props.cellEdit,
|
||
data: rootProps.getData()
|
||
}),
|
||
base(rootProps)
|
||
);
|
||
};
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var _props = this.props,
|
||
keyField = _props.keyField,
|
||
columns = _props.columns,
|
||
bootstrap4 = _props.bootstrap4;
|
||
|
||
var baseProps = { keyField: keyField, columns: columns };
|
||
|
||
var base = this.renderBase();
|
||
|
||
if (this.ColumnManagementContext) {
|
||
base = this.renderWithColumnManagementCtx(base, baseProps);
|
||
}
|
||
|
||
if (this.SelectionContext) {
|
||
base = this.renderWithSelectionCtx(base, baseProps);
|
||
}
|
||
|
||
if (this.RowExpandContext) {
|
||
base = this.renderWithRowExpandCtx(base, baseProps);
|
||
}
|
||
|
||
if (this.PaginationContext) {
|
||
base = this.renderWithPaginationCtx(base, baseProps);
|
||
}
|
||
|
||
if (this.SortContext) {
|
||
base = this.renderWithSortCtx(base, baseProps);
|
||
}
|
||
|
||
if (this.SearchContext) {
|
||
base = this.renderWithSearchCtx(base, baseProps);
|
||
}
|
||
|
||
if (this.FilterContext) {
|
||
base = this.renderWithFilterCtx(base, baseProps);
|
||
}
|
||
|
||
if (this.CellEditContext) {
|
||
base = this.renderWithCellEditCtx(base, baseProps);
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
_bootstrap.BootstrapContext.Provider,
|
||
{ value: { bootstrap4: bootstrap4 } },
|
||
_react2.default.createElement(
|
||
this.DataContext.Provider,
|
||
_extends({}, baseProps, {
|
||
data: this.props.data
|
||
}),
|
||
_react2.default.createElement(
|
||
this.DataContext.Consumer,
|
||
null,
|
||
base
|
||
)
|
||
)
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return BootstrapTableContainer;
|
||
}((0, _remoteResolver3.default)(_react.Component));
|
||
};
|
||
|
||
exports.default = withContext;
|
||
|
||
/***/ }),
|
||
/* 67 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint camelcase: 0 */
|
||
|
||
|
||
exports.default = function () {
|
||
var DataContext = _react2.default.createContext();
|
||
|
||
var DataProvider = function (_Component) {
|
||
_inherits(DataProvider, _Component);
|
||
|
||
function DataProvider() {
|
||
var _ref;
|
||
|
||
var _temp, _this, _ret;
|
||
|
||
_classCallCheck(this, DataProvider);
|
||
|
||
for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) {
|
||
args[_key] = arguments[_key];
|
||
}
|
||
|
||
return _ret = (_temp = (_this = _possibleConstructorReturn(this, (_ref = DataProvider.__proto__ || Object.getPrototypeOf(DataProvider)).call.apply(_ref, [this].concat(args))), _this), _this.state = { data: _this.props.data }, _this.getData = function (filterProps, searchProps, sortProps, paginationProps) {
|
||
if (paginationProps) return paginationProps.data;else if (sortProps) return sortProps.data;else if (searchProps) return searchProps.data;else if (filterProps) return filterProps.data;
|
||
return _this.props.data;
|
||
}, _temp), _possibleConstructorReturn(_this, _ret);
|
||
}
|
||
|
||
_createClass(DataProvider, [{
|
||
key: 'UNSAFE_componentWillReceiveProps',
|
||
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
||
this.setState(function () {
|
||
return { data: nextProps.data };
|
||
});
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
return _react2.default.createElement(
|
||
DataContext.Provider,
|
||
{
|
||
value: {
|
||
data: this.state.data,
|
||
getData: this.getData
|
||
}
|
||
},
|
||
this.props.children
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return DataProvider;
|
||
}(_react.Component);
|
||
|
||
DataProvider.propTypes = {
|
||
data: _propTypes2.default.array.isRequired,
|
||
children: _propTypes2.default.node.isRequired
|
||
};
|
||
|
||
return {
|
||
Provider: DataProvider,
|
||
Consumer: DataContext.Consumer
|
||
};
|
||
};
|
||
|
||
/***/ }),
|
||
/* 68 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint react/prop-types: 0 */
|
||
/* eslint react/prefer-stateless-function: 0 */
|
||
|
||
|
||
exports.default = function () {
|
||
var ColumnManagementContext = _react2.default.createContext();
|
||
|
||
var ColumnManagementProvider = function (_React$Component) {
|
||
_inherits(ColumnManagementProvider, _React$Component);
|
||
|
||
function ColumnManagementProvider() {
|
||
_classCallCheck(this, ColumnManagementProvider);
|
||
|
||
return _possibleConstructorReturn(this, (ColumnManagementProvider.__proto__ || Object.getPrototypeOf(ColumnManagementProvider)).apply(this, arguments));
|
||
}
|
||
|
||
_createClass(ColumnManagementProvider, [{
|
||
key: 'render',
|
||
value: function render() {
|
||
var toggleColumn = void 0;
|
||
var _props = this.props,
|
||
columns = _props.columns,
|
||
toggles = _props.toggles;
|
||
|
||
if (toggles) {
|
||
toggleColumn = columns.filter(function (column) {
|
||
return toggles[column.dataField];
|
||
});
|
||
} else {
|
||
toggleColumn = columns.filter(function (column) {
|
||
return !column.hidden;
|
||
});
|
||
}
|
||
return _react2.default.createElement(
|
||
ColumnManagementContext.Provider,
|
||
{ value: { columns: toggleColumn } },
|
||
this.props.children
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return ColumnManagementProvider;
|
||
}(_react2.default.Component);
|
||
|
||
ColumnManagementProvider.propTypes = {
|
||
columns: _propTypes2.default.array.isRequired,
|
||
toggles: _propTypes2.default.object
|
||
};
|
||
ColumnManagementProvider.defaultProps = {
|
||
toggles: null
|
||
};
|
||
|
||
|
||
return {
|
||
Provider: ColumnManagementProvider,
|
||
Consumer: ColumnManagementContext.Consumer
|
||
};
|
||
};
|
||
|
||
/***/ }),
|
||
/* 69 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _react = __webpack_require__(0);
|
||
|
||
var _react2 = _interopRequireDefault(_react);
|
||
|
||
var _propTypes = __webpack_require__(1);
|
||
|
||
var _propTypes2 = _interopRequireDefault(_propTypes);
|
||
|
||
var _const = __webpack_require__(3);
|
||
|
||
var _const2 = _interopRequireDefault(_const);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; } /* eslint camelcase: 0 */
|
||
/* eslint react/require-default-props: 0 */
|
||
|
||
|
||
exports.default = function (dataOperator, isRemoteSort, handleSortChange) {
|
||
var SortContext = _react2.default.createContext();
|
||
|
||
var SortProvider = function (_React$Component) {
|
||
_inherits(SortProvider, _React$Component);
|
||
|
||
function SortProvider(props) {
|
||
_classCallCheck(this, SortProvider);
|
||
|
||
var _this = _possibleConstructorReturn(this, (SortProvider.__proto__ || Object.getPrototypeOf(SortProvider)).call(this, props));
|
||
|
||
_initialiseProps.call(_this);
|
||
|
||
var sortOrder = void 0;
|
||
var sortColumn = void 0;
|
||
var defaultSorted = props.defaultSorted,
|
||
defaultSortDirection = props.defaultSortDirection,
|
||
sort = props.sort;
|
||
|
||
|
||
if (defaultSorted && defaultSorted.length > 0) {
|
||
sortOrder = defaultSorted[0].order || defaultSortDirection;
|
||
sortColumn = _this.initSort(defaultSorted[0].dataField, sortOrder);
|
||
} else if (sort && sort.dataField && sort.order) {
|
||
sortOrder = sort.order;
|
||
sortColumn = _this.initSort(sort.dataField, sortOrder);
|
||
}
|
||
_this.state = { sortOrder: sortOrder, sortColumn: sortColumn };
|
||
return _this;
|
||
}
|
||
|
||
_createClass(SortProvider, [{
|
||
key: 'componentDidMount',
|
||
value: function componentDidMount() {
|
||
var _state = this.state,
|
||
sortOrder = _state.sortOrder,
|
||
sortColumn = _state.sortColumn;
|
||
|
||
if (isRemoteSort() && sortOrder && sortColumn) {
|
||
handleSortChange(sortColumn.dataField, sortOrder);
|
||
}
|
||
}
|
||
}, {
|
||
key: 'UNSAFE_componentWillReceiveProps',
|
||
value: function UNSAFE_componentWillReceiveProps(nextProps) {
|
||
var sort = nextProps.sort,
|
||
columns = nextProps.columns;
|
||
|
||
if (sort && sort.dataField && sort.order) {
|
||
this.setState({
|
||
sortOrder: sort.order,
|
||
sortColumn: columns.find(function (col) {
|
||
return col.dataField === sort.dataField;
|
||
})
|
||
});
|
||
}
|
||
}
|
||
}, {
|
||
key: 'initSort',
|
||
value: function initSort(sortField, sortOrder) {
|
||
var sortColumn = void 0;
|
||
var columns = this.props.columns;
|
||
|
||
var sortColumns = columns.filter(function (col) {
|
||
return col.dataField === sortField;
|
||
});
|
||
if (sortColumns.length > 0) {
|
||
sortColumn = sortColumns[0];
|
||
|
||
if (sortColumn.onSort) {
|
||
sortColumn.onSort(sortField, sortOrder);
|
||
}
|
||
}
|
||
return sortColumn;
|
||
}
|
||
}, {
|
||
key: 'render',
|
||
value: function render() {
|
||
var data = this.props.data;
|
||
var sort = this.props.sort;
|
||
var _state2 = this.state,
|
||
sortOrder = _state2.sortOrder,
|
||
sortColumn = _state2.sortColumn;
|
||
|
||
if (!isRemoteSort() && sortColumn) {
|
||
var sortFunc = sortColumn.sortFunc ? sortColumn.sortFunc : sort && sort.sortFunc;
|
||
data = dataOperator.sort(data, sortOrder, _extends({}, sortColumn, { sortFunc: sortFunc }));
|
||
}
|
||
|
||
return _react2.default.createElement(
|
||
SortContext.Provider,
|
||
{
|
||
value: {
|
||
data: data,
|
||
sortOrder: sortOrder,
|
||
onSort: this.handleSort,
|
||
sortField: sortColumn ? sortColumn.dataField : null
|
||
}
|
||
},
|
||
this.props.children
|
||
);
|
||
}
|
||
}]);
|
||
|
||
return SortProvider;
|
||
}(_react2.default.Component);
|
||
|
||
SortProvider.propTypes = {
|
||
data: _propTypes2.default.array.isRequired,
|
||
columns: _propTypes2.default.array.isRequired,
|
||
children: _propTypes2.default.node.isRequired,
|
||
defaultSorted: _propTypes2.default.arrayOf(_propTypes2.default.shape({
|
||
dataField: _propTypes2.default.string.isRequired,
|
||
order: _propTypes2.default.oneOf([_const2.default.SORT_DESC, _const2.default.SORT_ASC]).isRequired
|
||
})),
|
||
sort: _propTypes2.default.shape({
|
||
dataField: _propTypes2.default.string,
|
||
order: _propTypes2.default.oneOf([_const2.default.SORT_DESC, _const2.default.SORT_ASC]),
|
||
sortFunc: _propTypes2.default.func
|
||
}),
|
||
defaultSortDirection: _propTypes2.default.oneOf([_const2.default.SORT_DESC, _const2.default.SORT_ASC])
|
||
};
|
||
|
||
var _initialiseProps = function _initialiseProps() {
|
||
var _this2 = this;
|
||
|
||
this.handleSort = function (column) {
|
||
var sortOrder = dataOperator.nextOrder(column, _this2.state, _this2.props.defaultSortDirection);
|
||
|
||
if (column.onSort) {
|
||
column.onSort(column.dataField, sortOrder);
|
||
}
|
||
|
||
if (isRemoteSort()) {
|
||
handleSortChange(column.dataField, sortOrder);
|
||
}
|
||
_this2.setState(function () {
|
||
return {
|
||
sortOrder: sortOrder,
|
||
sortColumn: column
|
||
};
|
||
});
|
||
};
|
||
};
|
||
|
||
return {
|
||
Provider: SortProvider,
|
||
Consumer: SortContext.Consumer
|
||
};
|
||
};
|
||
|
||
/***/ }),
|
||
/* 70 */
|
||
/***/ (function(module, exports, __webpack_require__) {
|
||
|
||
"use strict";
|
||
|
||
|
||
Object.defineProperty(exports, "__esModule", {
|
||
value: true
|
||
});
|
||
|
||
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 _events = __webpack_require__(21);
|
||
|
||
var _events2 = _interopRequireDefault(_events);
|
||
|
||
var _utils = __webpack_require__(2);
|
||
|
||
var _utils2 = _interopRequireDefault(_utils);
|
||
|
||
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
||
|
||
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; }
|
||
|
||
exports.default = function (ExtendBase) {
|
||
return function (_ExtendBase) {
|
||
_inherits(RemoteResolver, _ExtendBase);
|
||
|
||
function RemoteResolver(props) {
|
||
_classCallCheck(this, RemoteResolver);
|
||
|
||
var _this = _possibleConstructorReturn(this, (RemoteResolver.__proto__ || Object.getPrototypeOf(RemoteResolver)).call(this, props));
|
||
|
||
_this.getNewestState = function () {
|
||
var state = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
||
|
||
var sortOrder = void 0;
|
||
var sortField = void 0;
|
||
var page = void 0;
|
||
var sizePerPage = void 0;
|
||
var searchText = void 0;
|
||
var filters = {};
|
||
|
||
if (_this.sortContext) {
|
||
sortOrder = _this.sortContext.state.sortOrder;
|
||
sortField = _this.sortContext.state.sortColumn ? _this.sortContext.state.sortColumn.dataField : null;
|
||
}
|
||
|
||
if (_this.filterContext) {
|
||
filters = _this.filterContext.currFilters;
|
||
}
|
||
|
||
if (_this.paginationContext) {
|
||
page = _this.paginationContext.currPage;
|
||
sizePerPage = _this.paginationContext.currSizePerPage;
|
||
}
|
||
|
||
if (_this.searchContext) {
|
||
searchText = _this.props.search.searchText;
|
||
}
|
||
|
||
return _extends({
|
||
sortOrder: sortOrder,
|
||
sortField: sortField,
|
||
filters: filters,
|
||
page: page,
|
||
sizePerPage: sizePerPage,
|
||
searchText: searchText
|
||
}, state, {
|
||
data: _this.props.data
|
||
});
|
||
};
|
||
|
||
_this.isRemoteSearch = function () {
|
||
var remote = _this.props.remote;
|
||
|
||
return remote === true || _utils2.default.isObject(remote) && remote.search || _this.isRemotePagination();
|
||
};
|
||
|
||
_this.isRemotePagination = function () {
|
||
var e = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
||
var remote = _this.props.remote;
|
||
|
||
e.result = remote === true || _utils2.default.isObject(remote) && remote.pagination;
|
||
return e.result;
|
||
};
|
||
|
||
_this.isRemoteFiltering = function () {
|
||
var remote = _this.props.remote;
|
||
|
||
return remote === true || _utils2.default.isObject(remote) && remote.filter || _this.isRemotePagination();
|
||
};
|
||
|
||
_this.isRemoteSort = function () {
|
||
var remote = _this.props.remote;
|
||
|
||
return remote === true || _utils2.default.isObject(remote) && remote.sort || _this.isRemotePagination();
|
||
};
|
||
|
||
_this.isRemoteCellEdit = function () {
|
||
var remote = _this.props.remote;
|
||
|
||
return remote === true || _utils2.default.isObject(remote) && remote.cellEdit;
|
||
};
|
||
|
||
_this.handleRemotePageChange = function (page, sizePerPage) {
|
||
_this.props.onTableChange('pagination', _this.getNewestState({ page: page, sizePerPage: sizePerPage }));
|
||
};
|
||
|
||
_this.handleRemoteFilterChange = function (filters) {
|
||
var newState = { filters: filters };
|
||
if (_this.isRemotePagination()) {
|
||
var options = _this.props.pagination.options || {};
|
||
newState.page = _utils2.default.isDefined(options.pageStartIndex) ? options.pageStartIndex : 1;
|
||
}
|
||
_this.props.onTableChange('filter', _this.getNewestState(newState));
|
||
};
|
||
|
||
_this.handleRemoteSortChange = function (sortField, sortOrder) {
|
||
_this.props.onTableChange('sort', _this.getNewestState({ sortField: sortField, sortOrder: sortOrder }));
|
||
};
|
||
|
||
_this.handleRemoteCellChange = function (rowId, dataField, newValue) {
|
||
var cellEdit = { rowId: rowId, dataField: dataField, newValue: newValue };
|
||
_this.props.onTableChange('cellEdit', _this.getNewestState({ cellEdit: cellEdit }));
|
||
};
|
||
|
||
_this.handleRemoteSearchChange = function (searchText) {
|
||
_this.props.onTableChange('search', _this.getNewestState({ searchText: searchText }));
|
||
};
|
||
|
||
_this.remoteEmitter = new _events2.default();
|
||
_this.remoteEmitter.on('paginationChange', _this.handleRemotePageChange);
|
||
_this.remoteEmitter.on('isRemotePagination', _this.isRemotePagination);
|
||
return _this;
|
||
}
|
||
|
||
return RemoteResolver;
|
||
}(ExtendBase);
|
||
};
|
||
|
||
/***/ })
|
||
/******/ ]);
|
||
});
|
||
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap 211acdaea2936f46fea6","webpack:///external {\"root\":\"React\",\"commonjs2\":\"react\",\"commonjs\":\"react\",\"amd\":\"react\"}","webpack:///./packages/react-bootstrap-table2/node_modules/prop-types/index.js","webpack:///./packages/react-bootstrap-table2/src/utils.js","webpack:///./packages/react-bootstrap-table2/src/const.js","webpack:///./packages/react-bootstrap-table2/node_modules/classnames/index.js","webpack:///./packages/react-bootstrap-table2/src/contexts/bootstrap.js","webpack:///./packages/react-bootstrap-table2/src/store/rows.js","webpack:///./packages/react-bootstrap-table2/src/cell-event-delegater.js","webpack:///./packages/react-bootstrap-table2/src/contexts/selection-context.js","webpack:///./packages/react-bootstrap-table2/src/store/operators.js","webpack:///./packages/react-bootstrap-table2/src/contexts/row-expand-context.js","webpack:///./packages/react-bootstrap-table2/src/store/selection.js","webpack:///./packages/react-bootstrap-table2/src/row/row-template.js","webpack:///./packages/react-bootstrap-table2/src/row/row-pure-content.js","webpack:///./packages/react-bootstrap-table2/src/row/event-delegater.js","webpack:///./packages/react-bootstrap-table2/src/row/should-updater.js","webpack:///./packages/react-bootstrap-table2/node_modules/react-transition-group/Transition.js","webpack:///external {\"root\":\"ReactDOM\",\"commonjs2\":\"react-dom\",\"commonjs\":\"react-dom\",\"amd\":\"react-dom\"}","webpack:///./packages/react-bootstrap-table2/node_modules/react-lifecycles-compat/react-lifecycles-compat.es.js","webpack:///./packages/react-bootstrap-table2/node_modules/react-transition-group/utils/PropTypes.js","webpack:///./packages/react-bootstrap-table2/node_modules/react-transition-group/TransitionGroup.js","webpack:///./node_modules/events/events.js","webpack:///./packages/react-bootstrap-table2/index.js","webpack:///./packages/react-bootstrap-table2/src/bootstrap-table.js","webpack:///./packages/react-bootstrap-table2/node_modules/prop-types/factoryWithThrowingShims.js","webpack:///./packages/react-bootstrap-table2/node_modules/prop-types/lib/ReactPropTypesSecret.js","webpack:///./packages/react-bootstrap-table2/src/header.js","webpack:///./packages/react-bootstrap-table2/src/header-cell.js","webpack:///./packages/react-bootstrap-table2/src/sort/symbol.js","webpack:///./packages/react-bootstrap-table2/src/sort/caret.js","webpack:///./packages/react-bootstrap-table2/node_modules/underscore/underscore.js","webpack:///(webpack)/buildin/global.js","webpack:///(webpack)/buildin/module.js","webpack:///./packages/react-bootstrap-table2/src/row-selection/selection-header-cell.js","webpack:///./packages/react-bootstrap-table2/src/row-expand/expand-header-cell.js","webpack:///./packages/react-bootstrap-table2/src/row-selection/selection-header-cell-consumer.js","webpack:///./packages/react-bootstrap-table2/src/store/expand.js","webpack:///./packages/react-bootstrap-table2/src/store/mutate.js","webpack:///./packages/react-bootstrap-table2/src/store/sort.js","webpack:///./packages/react-bootstrap-table2/src/store/type.js","webpack:///./packages/react-bootstrap-table2/src/row-expand/expand-header-cell-consumer.js","webpack:///./packages/react-bootstrap-table2/src/filters.js","webpack:///./packages/react-bootstrap-table2/src/filters-cell.js","webpack:///./packages/react-bootstrap-table2/src/caption.js","webpack:///./packages/react-bootstrap-table2/src/body.js","webpack:///./packages/react-bootstrap-table2/src/row/simple-row.js","webpack:///./packages/react-bootstrap-table2/src/cell.js","webpack:///./packages/react-bootstrap-table2/src/row/aggregate-row.js","webpack:///./packages/react-bootstrap-table2/src/row-expand/expand-cell.js","webpack:///./packages/react-bootstrap-table2/src/row-selection/selection-cell.js","webpack:///./packages/react-bootstrap-table2/src/row/row-section.js","webpack:///./packages/react-bootstrap-table2/src/row-selection/row-consumer.js","webpack:///./packages/react-bootstrap-table2/src/row-expand/row-consumer.js","webpack:///./packages/react-bootstrap-table2/src/row-expand/expand-row.js","webpack:///./packages/react-bootstrap-table2/node_modules/react-transition-group/index.js","webpack:///./packages/react-bootstrap-table2/node_modules/react-transition-group/CSSTransition.js","webpack:///./packages/react-bootstrap-table2/node_modules/dom-helpers/class/addClass.js","webpack:///./packages/react-bootstrap-table2/node_modules/@babel/runtime/helpers/interopRequireDefault.js","webpack:///./packages/react-bootstrap-table2/node_modules/dom-helpers/class/hasClass.js","webpack:///./packages/react-bootstrap-table2/node_modules/dom-helpers/class/removeClass.js","webpack:///./packages/react-bootstrap-table2/node_modules/react-transition-group/ReplaceTransition.js","webpack:///./packages/react-bootstrap-table2/node_modules/react-transition-group/utils/ChildMapping.js","webpack:///./packages/react-bootstrap-table2/src/footer.js","webpack:///./packages/react-bootstrap-table2/src/footer-cell.js","webpack:///./packages/react-bootstrap-table2/src/props-resolver/index.js","webpack:///./packages/react-bootstrap-table2/src/props-resolver/column-resolver.js","webpack:///./packages/react-bootstrap-table2/src/contexts/index.js","webpack:///./packages/react-bootstrap-table2/src/contexts/data-context.js","webpack:///./packages/react-bootstrap-table2/src/contexts/column-context.js","webpack:///./packages/react-bootstrap-table2/src/contexts/sort-context.js","webpack:///./packages/react-bootstrap-table2/src/props-resolver/remote-resolver.js"],"names":["splitNested","str","join","replace","split","get","target","field","pathArray","result","reduce","curr","path","e","set","value","safe","level","a","b","Error","length","isEmptyObject","obj","isObject","hasOwnProperty","Object","prototype","keys","i","call","isDefined","sleep","fn","ms","setTimeout","debounce","func","wait","immediate","timeout","later","apply","callNow","clearTimeout","assign","SORT_ASC","SORT_DESC","ROW_SELECT_SINGLE","ROW_SELECT_MULTIPLE","ROW_SELECT_DISABLED","CHECKBOX_STATUS_CHECKED","CHECKBOX_STATUS_INDETERMINATE","CHECKBOX_STATUS_UNCHECKED","INDICATOR_POSITION_LEFT","INDICATOR_POSITION_RIGHT","TYPE_STRING","TYPE_NUMBER","TYPE_BOOLEAN","TYPE_DATE","FILTERS_POSITION_INLINE","FILTERS_POSITION_TOP","FILTERS_POSITION_BOTTOM","BootstrapContext","createContext","bootstrap4","matchRow","keyField","id","row","getRowByRowId","data","find","events","props","createDefaultEventHandler","bind","cb","column","columnIndex","index","attrs","newAttrs","forEach","attr","contains","ExtendBase","SelectionContext","SelectionProvider","handleRowSelect","rowKey","checked","rowIndex","selectRow","mode","onSelect","currSelected","selected","undefined","push","filter","forceUpdate","handleAllRowsSelect","isUnSelect","onSelectAll","nonSelectable","concat","selectableKeys","d","s","getSelectedRows","Array","isArray","nextProps","allRowsSelected","allRowsNotSelected","checkedStatus","onRowSelect","onAllRowsSelect","children","Component","propTypes","node","isRequired","array","string","Provider","Consumer","rows","selection","expand","mutate","sort","type","RowExpandContext","RowExpandProvider","state","expanded","expandRow","isClosing","onClosed","closedRow","setState","handleRowExpand","onExpand","onlyOneExpanding","nonExpandable","currExpanded","handleAllRowExpand","expandAll","onExpandAll","expandableKeys","getExpandedRows","nextExpanded","acc","cur","isAnyExpands","onRowExpand","onAllRowExpand","getSelectionSummary","rowKeys","map","x","skips","unSelectableKeys","k","RowTemplate","renderContent","cellEl","rest","isRenderFunctionColumnInLeft","position","childrens","hideSelectColumn","selectColumnPosition","unshift","createElement","key","showExpandColumn","expandColumnPosition","object","RowPureContent","shouldUpdate","columns","editable","editingRowIdx","editingColIdx","onStart","clickToEdit","dbclickToEdit","EditingCellComponent","tabIndexStart","tabIndex","dataField","content","cellTitle","cellStyle","cellAttrs","isFunction","originFn","cellClasses","classes","style","title","align","textAlign","className","editableCell","clickNum","createClickEventHandler","selectable","expandable","DELAY_FOR_DBCLICK","clickFn","expandByColumnOnly","clickToExpand","clickToSelect","isEqual","shouldUpdateByCellEditing","shouldUpdatedByNormalProps","shouldUpdateChild","shouldUpdateByColumnsForSimpleCheck","BootstrapTable","getData","visibleRows","validateProps","onDataSizeChange","pagination","dataSize","loading","overlay","LoadingOverlay","renderTable","tabIndexCell","striped","hover","bordered","condensed","noDataIndication","caption","rowStyle","rowClasses","wrapperClasses","rowEvents","cellEdit","filterPosition","tableWrapperClass","tableClass","hasFilters","some","col","filterRenderer","hasFooter","has","tableCaption","headerClasses","headerWrapperClasses","sortField","sortOrder","onSort","sortCaret","onFilter","currFilters","onExternalFilter","filtersClasses","bodyClasses","isEmpty","visibleColumnSize","footerClasses","bool","remote","oneOfType","shape","oneOf","hideSelectAll","nonSelectableStyle","nonSelectableClasses","bgColor","selectionRenderer","selectionHeaderRenderer","headerColumnStyle","selectColumnStyle","renderer","expandColumnRenderer","expandHeaderColumnRenderer","parentClassName","defaultSorted","arrayOf","order","sortFunc","defaultSortDirection","onTableChange","search","searchText","searchContext","setDependencyModules","defaultProps","nonEditableRows","Header","globalSortCaret","SelectionHeaderCellComp","ExpansionHeaderCellComp","currSort","isLastSorting","HeaderCell","sorting","text","headerTitle","headerAlign","headerFormatter","headerEvents","headerStyle","headerAttrs","headerSortingClasses","headerSortingStyle","sortCaretfunc","delegateEvents","delegate","customAttrs","sortSymbol","filterElm","customClick","onClick","onKeyUp","onCustomFilter","sortElement","filterElement","isDummyField","hidden","formatter","formatExtraData","any","editor","editCellStyle","editCellClasses","editorStyle","editorClasses","editorRenderer","validator","filterValue","searchable","number","SortSymbol","SortCaret","orderClass","dropup","CheckBox","indeterminate","input","SelectionHeaderCell","handleCheckBoxClick","ExpansionHeaderCell","editCell","rowId","newValue","comparator","localeCompare","sortValue","_data","valueA","valueB","nextOrder","currentSortColumn","sortColumn","defaultOrder","typeConvert","String","Number","Date","Filters","filterColumns","showFiltersRow","display","FiltersCell","Caption","captionSide","Body","EditingCell","createEditingCell","options","onStartEdit","RowComponent","selectRowEnabled","expandRowEnabled","withRowLevelCellEdit","indication","additionalRowProps","baseRowProps","SimpleRow","shouldUpdateRowContent","shouldRowContentUpdate","shouldUpdatedBySelfProps","trAttrs","Cell","createHandleEditingCell","originFunc","onDoubleClick","RowAggregator","selectCell","expandCell","ExpandCell","handleClick","stopPropagation","SelectionCell","disabled","inputType","RowSection","colSpan","renderWithSelection","notSelectable","selectedStyle","selectedClasses","backgroundColor","notSelectableStyle","notSelectableClasses","withConsumer","displayName","renderWithExpansion","ExpandRow","Footer","footer","columnData","pluck","FooterCell","footerTitle","footerAlign","footerFormatter","footerEvents","footerStyle","footerAttrs","isString","hiddenRows","includeSelectColumn","columnLen","columnToggle","toggles","name","c","withContext","DataContext","registerExposedAPI","exposedAPIEmitter","on","payload","table","selectionContext","getSelected","getSearched","filterContext","getFiltered","SortContext","isRemoteSort","handleRemoteSortChange","ColumnManagementContext","CellEditContext","isRemoteCellEdit","handleRemoteCellChange","FilterContext","isRemoteFiltering","handleRemoteFilterChange","PaginationContext","SearchContext","isRemoteSearch","handleRemoteSearchChange","setPaginationRemoteEmitter","remoteEmitter","isRemotePagination","handleRemotePageChange","rootProps","filterProps","searchProps","sortProps","paginationProps","columnToggleProps","n","base","baseProps","rowExpandContext","paginationContext","sortContext","dataChangeListener","cellEditContext","renderBase","renderWithColumnManagementCtx","renderWithSelectionCtx","renderWithRowExpandCtx","renderWithPaginationCtx","renderWithSortCtx","renderWithSearchCtx","renderWithFilterCtx","renderWithCellEditCtx","DataProvider","ColumnManagementProvider","toggleColumn","dataOperator","handleSortChange","SortProvider","initSort","sortColumns","handleSort","getNewestState","page","sizePerPage","filters","currPage","currSizePerPage","newState","pageStartIndex"],"mappings":"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;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,8CAA8C;;AAE9C;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA,IAAI;AACJ;AACA;AACA,gBAAgB,SAAS;AACzB;AACA;AACA;AACA;AACA,UAAU;AACV;AACA;AACA;AACA;AACA;AACA,eAAe;AACf;;;AAGA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,OAAO;AACP;AACA;AACA,KAAK;AACL;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;;AAEA;AACA;AACA,sCAAsC;AACtC;;AAEA;AACA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL,+CAA+C;;;AAG/C;AACA;AACA;AACA,SAAS;AACT;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;;AAEA;AACA;;AAEA;AACA,sCAAsC;;AAEtC;AACA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA,SAAS;AACT;AACA,SAAS;AACT,OAAO;AACP,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,8EAA8E;;;AAG9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0BAA0B,IAAI;AAC9B,QAAQ;AACR,iCAAiC,aAAa,OAAO,EAAE;AACvD;AACA;AACA;AACA;AACA;;AAEA;AACA,wBAAwB;AACxB;AACA;;AAEA;AACA;AACA;AACA,gBAAgB,KAAK;AACrB;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,0EAA0E,IAAI;AAC9E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,UAAU;AACtB;AACA;AACA;AACA;;AAEA,0FAA0F,aAAa;AACvG;AACA;;AAEA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB;AACrB;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA,CAAC;;AAED;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA,2B;;;;;;ACzlBA,gD;;;;;;;;ACAA;AAAA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEQ;;;;;;;;AC7JR;;AAEA;AACA;;AAEA;;AAEA,sCAAsC,uCAAuC,gBAAgB;;AAE7F;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD,0C;;;;;;;AC1BA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA,sCAAsC,uCAAuC,gBAAgB;;AAE7F,0DAA0D,+BAA+B,iBAAiB,sCAAsC,YAAY,YAAY,uBAAuB,OAAO,qBAAqB,0CAA0C,2BAA2B,EAAE,eAAe;;AAEjT,qBAAqB,gDAAgD,gBAAgB,sBAAsB,OAAO,2BAA2B,0BAA0B,yDAAyD,2BAA2B,EAAE,EAAE,EAAE,eAAe,GAAG,wCAAwC;;AAE3T,+CAA+C,0DAA0D,2CAA2C,iCAAiC;;AAErL,uCAAuC,uBAAuB,uFAAuF,EAAE,aAAa;;AAEpK;AACA;AACA;AACA,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA,sGAAsG;;;AAGtG;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,kCAAkC;;AAElC;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iCAAiC,KAAK;AACtC;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;;AAEA;;AAEA;AACA,oC;;;;;;ACxMA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,iBAAiB;AACjB,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA,eAAe,SAAS;AACxB;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA,GAAG;AACH,oBAAoB,SAAS;AAC7B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;;;;;;;;;;;;;AC7SA;;;;AACA;;;;;;kBAEe,iD;;;;;;;;;;;;;;;ACAf;;;;AACA;;;;AACA;;;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;;;;;;;+eAdA;AACA;;IAeMwI,c;;;AACJ,0BAAYpJ,KAAZ,EAAmB;AAAA;;AAAA,gIACXA,KADW;;AAAA,UAcnBqJ,OAdmB,GAcT,YAAM;AACd,aAAO,MAAKC,WAAL,EAAP;AACD,KAhBkB;;AAEjB,UAAKC,aAAL;AAFiB;AAGlB;;;;qDAEgChH,S,EAAW;AAC1C,UAAIA,UAAUiH,gBAAV,IAA8B,CAACjH,UAAUkH,UAA7C,EAAyD;AACvD,YAAIlH,UAAU1C,IAAV,CAAelD,MAAf,KAA0B,KAAKqD,KAAL,CAAWH,IAAX,CAAgBlD,MAA9C,EAAsD;AACpD4F,oBAAUiH,gBAAV,CAA2B,EAAEE,UAAUnH,UAAU1C,IAAV,CAAelD,MAA3B,EAA3B;AACD;AACF;AACF;;AAED;;;;6BAKS;AAAA,mBACsB,KAAKqD,KAD3B;AAAA,UACC2J,OADD,UACCA,OADD;AAAA,UACUC,OADV,UACUA,OADV;;AAEP,UAAIA,OAAJ,EAAa;AACX,YAAMC,iBAAiBD,QAAQD,OAAR,CAAvB;AACA,eACE;AAAC,wBAAD;AAAA;AACI,eAAKG,WAAL;AADJ,SADF;AAKD;AACD,aAAO,KAAKA,WAAL,EAAP;AACD;;;kCAEa;AAAA,oBAsBR,KAAK9J,KAtBG;AAAA,UAEV6G,OAFU,WAEVA,OAFU;AAAA,UAGVpH,QAHU,WAGVA,QAHU;AAAA,UAIVsK,YAJU,WAIVA,YAJU;AAAA,UAKVrK,EALU,WAKVA,EALU;AAAA,UAMVqI,OANU,WAMVA,OANU;AAAA,UAOVxI,UAPU,WAOVA,UAPU;AAAA,UAQVyK,OARU,WAQVA,OARU;AAAA,UASVC,KATU,WASVA,KATU;AAAA,UAUVC,QAVU,WAUVA,QAVU;AAAA,UAWVC,SAXU,WAWVA,SAXU;AAAA,UAYVC,gBAZU,WAYVA,gBAZU;AAAA,UAaVC,OAbU,WAaVA,OAbU;AAAA,UAcVC,QAdU,WAcVA,QAdU;AAAA,UAeVC,UAfU,WAeVA,UAfU;AAAA,UAgBVC,cAhBU,WAgBVA,cAhBU;AAAA,UAiBVC,SAjBU,WAiBVA,SAjBU;AAAA,UAkBVtJ,SAlBU,WAkBVA,SAlBU;AAAA,UAmBV6C,SAnBU,WAmBVA,SAnBU;AAAA,UAoBV0G,QApBU,WAoBVA,QApBU;AAAA,UAqBVC,cArBU,WAqBVA,cArBU;;;AAwBZ,UAAMC,oBAAoB,0BAAG,uBAAH,EAA4BJ,cAA5B,CAA1B;;AAEA,UAAMK,aAAa,0BAAG,OAAH;AACjB,yBAAiBb,OADA;AAEjB,uBAAeC,KAFE;AAGjB,0BAAkBC;AAHD,SAIhB3K,aAAa,UAAb,GAA0B,iBAJV,EAI8B4K,SAJ9B,GAKhBpC,OALgB,CAAnB;;AAOA,UAAM+C,aAAajE,QAAQkE,IAAR,CAAa;AAAA,eAAOC,IAAItJ,MAAJ,IAAcsJ,IAAIC,cAAzB;AAAA,OAAb,CAAnB;;AAEA,UAAMC,YAAY,gBAAExJ,MAAF,CAASmF,OAAT,EAAkB;AAAA,eAAO,gBAAEsE,GAAF,CAAMH,GAAN,EAAW,QAAX,CAAP;AAAA,OAAlB,EAA+CrO,MAA/C,GAAwD,CAA1E;;AAEA,UAAMyO,eACJf,WAAW;AAAA;AAAA,UAAS,YAAa9K,UAAtB;AAAqC8K;AAArC,OADb;;AAIA,aACE;AAAA;AAAA,UAAK,WAAYO,iBAAjB;AACE;AAAA;AAAA,YAAO,IAAKlL,EAAZ,EAAiB,WAAYmL,UAA7B;AACIO,sBADJ;AAEE;AACE,qBAAUvE,OADZ;AAEE,uBAAY,KAAK7G,KAAL,CAAWqL,aAFzB;AAGE,4BAAiB,KAAKrL,KAAL,CAAWsL,oBAH9B;AAIE,uBAAY,KAAKtL,KAAL,CAAWuL,SAJzB;AAKE,uBAAY,KAAKvL,KAAL,CAAWwL,SALzB;AAME,oBAAS,KAAKxL,KAAL,CAAWyL,MANtB;AAOE,6BAAkB,KAAKzL,KAAL,CAAW0D,IAAX,IAAmB,KAAK1D,KAAL,CAAW0D,IAAX,CAAgBgI,SAPvD;AAQE,sBAAW,KAAK1L,KAAL,CAAW2L,QARxB;AASE,yBAAc,KAAK3L,KAAL,CAAW4L,WAT3B;AAUE,8BAAmB,KAAK5L,KAAL,CAAW6L,gBAVhC;AAWE,uBAAY1K,SAXd;AAYE,uBAAY6C,SAZd;AAaE,4BAAiB2G;AAbnB,YAFF;AAiBGG,wBAAcH,mBAAmB,gBAAMzL,uBAAvC,IACC;AACE,qBAAU2H,OADZ;AAEE,uBAAY,KAAK7G,KAAL,CAAW8L,cAFzB;AAGE,oBAAS,KAAK9L,KAAL,CAAWyL,MAHtB;AAIE,sBAAW,KAAKzL,KAAL,CAAW2L,QAJxB;AAKE,yBAAc,KAAK3L,KAAL,CAAW4L,WAL3B;AAME,4BAAiB,KAAK5L,KAAL,CAAW2K,cAN9B;AAOE,8BAAmB,KAAK3K,KAAL,CAAW6L,gBAPhC;AAQE,uBAAY1K,SARd;AASE,uBAAY6C;AATd,YAlBJ;AA8BE;AACE,uBAAY,KAAKhE,KAAL,CAAW+L,WADzB;AAEE,kBAAO,KAAK1C,OAAL,EAFT;AAGE,sBAAW5J,QAHb;AAIE,0BAAesK,YAJjB;AAKE,qBAAUlD,OALZ;AAME,qBAAU,KAAKmF,OAAL,EANZ;AAOE,+BAAoB,KAAKC,iBAAL,EAPtB;AAQE,8BAAmB7B,gBARrB;AASE,sBAAWM,QATb;AAUE,uBAAYvJ,SAVd;AAWE,uBAAY6C,SAXd;AAYE,sBAAWsG,QAZb;AAaE,wBAAaC,UAbf;AAcE,uBAAYE;AAdd,YA9BF;AA8CGS,uBACC;AACE,kBAAO,KAAK7B,OAAL,EADT;AAEE,qBAAUxC,OAFZ;AAGE,uBAAY1F,SAHd;AAIE,uBAAY6C,SAJd;AAKE,uBAAY,KAAKhE,KAAL,CAAWkM;AALzB;AA/CJ;AADF,OADF;AA4DD;;;;EArI0B,8C;;AAwI7B9C,eAAerG,SAAf,GAA2B;AACzBtD,YAAU,oBAAU0D,MAAV,CAAiBF,UADF;AAEzBpD,QAAM,oBAAUqD,KAAV,CAAgBD,UAFG;AAGzB4D,WAAS,oBAAU3D,KAAV,CAAgBD,UAHA;AAIzB1D,cAAY,oBAAU4M,IAJG;AAKzBC,UAAQ,oBAAUC,SAAV,CAAoB,CAAC,oBAAUF,IAAX,EAAiB,oBAAUG,KAAV,CAAgB;AAC3D7C,gBAAY,oBAAU0C;AADqC,GAAhB,CAAjB,CAApB,CALiB;AAQzB/B,oBAAkB,oBAAUiC,SAAV,CAAoB,CAAC,oBAAUrJ,IAAX,EAAiB,oBAAUrF,IAA3B,CAApB,CARO;AASzBqM,WAAS,oBAAUmC,IATM;AAUzBjC,YAAU,oBAAUiC,IAVK;AAWzBlC,SAAO,oBAAUkC,IAXQ;AAYzBpC,gBAAc,oBAAUoC,IAZC;AAazBzM,MAAI,oBAAUyD,MAbW;AAczB4E,WAAS,oBAAU5E,MAdM;AAezBkI,iBAAe,oBAAUlI,MAfA;AAgBzB4I,eAAa,oBAAU5I,MAhBE;AAiBzBqH,kBAAgB,oBAAUrH,MAjBD;AAkBzBmI,wBAAsB,oBAAUnI,MAlBP;AAmBzBgH,aAAW,oBAAUgC,IAnBI;AAoBzB9B,WAAS,oBAAUgC,SAAV,CAAoB,CAC3B,oBAAUrJ,IADiB,EAE3B,oBAAUG,MAFiB,CAApB,CApBgB;AAwBzBsG,cAAY,oBAAU/C,MAxBG;AAyBzBhF,UAAQ,oBAAUgF,MAzBO;AA0BzBgE,YAAU,oBAAUhE,MA1BK;AA2BzBvF,aAAW,oBAAUmL,KAAV,CAAgB;AACzBlL,UAAM,oBAAUmL,KAAV,CAAgB,CACpB,gBAAMjO,iBADc,EAEpB,gBAAMC,mBAFc,EAGpB,gBAAMC,mBAHc,CAAhB,EAIHyE,UALsB;AAMzB6F,mBAAe,oBAAUqD,IANA;AAOzBtD,mBAAe,oBAAUsD,IAPA;AAQzBjF,iBAAa,oBAAUiF,IARE;AASzBK,mBAAe,oBAAUL,IATA;AAUzB9K,cAAU,oBAAU1D,IAVK;AAWzBmE,iBAAa,oBAAUnE,IAXE;AAYzBqK,WAAO,oBAAUqE,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CAZkB;AAazBoK,aAAS,oBAAUsE,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAbgB;AAczBoE,mBAAe,oBAAUmB,KAdA;AAezBuJ,wBAAoB,oBAAUJ,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAfK;AAgBzB+O,0BAAsB,oBAAUL,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAhBG;AAiBzBgP,aAAS,oBAAUN,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAjBgB;AAkBzBwI,sBAAkB,oBAAUgG,IAlBH;AAmBzBS,uBAAmB,oBAAUjP,IAnBJ;AAoBzBkP,6BAAyB,oBAAUlP,IApBV;AAqBzBmP,uBAAmB,oBAAUT,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CArBM;AAsBzBoP,uBAAmB,oBAAUV,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CAtBM;AAuBzByI,0BAAsB,oBAAUmG,KAAV,CAAgB,CACpC,gBAAM3N,uBAD8B,EAEpC,gBAAMC,wBAF8B,CAAhB;AAvBG,GAAhB,CA3Bc;AAuDzBmF,aAAW,oBAAUsI,KAAV,CAAgB;AACzBU,cAAU,oBAAUrP,IADK;AAEzBoG,cAAU,oBAAUb,KAFK;AAGzBoB,cAAU,oBAAU3G,IAHK;AAIzBiH,iBAAa,oBAAUjH,IAJE;AAKzB6G,mBAAe,oBAAUtB,KALA;AAMzBsD,sBAAkB,oBAAU2F,IANH;AAOzB5H,sBAAkB,oBAAU4H,IAPH;AAQzBvD,wBAAoB,oBAAUuD,IARL;AASzBc,0BAAsB,oBAAUtP,IATP;AAUzBuP,gCAA4B,oBAAUvP,IAVb;AAWzB8I,0BAAsB,oBAAU8F,KAAV,CAAgB,CACpC,gBAAM3N,uBAD8B,EAEpC,gBAAMC,wBAF8B,CAAhB,CAXG;AAezBuJ,eAAW,oBAAUiE,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAfc;AAgBzBwP,qBAAiB,oBAAUd,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB;AAhBQ,GAAhB,CAvDc;AAyEzB2M,YAAU,oBAAU+B,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CAzEe;AA0EzB8M,aAAW,oBAAU/D,MA1EI;AA2EzB6D,cAAY,oBAAU8B,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CA3Ea;AA4EzBmO,kBAAgB,oBAAU3I,MA5ED;AA6EzBwH,kBAAgB,oBAAU4B,KAAV,CAAgB,CAC9B,gBAAMpN,oBADwB,EAE9B,gBAAMD,uBAFwB,EAG9B,gBAAME,uBAHwB,CAAhB,CA7ES;AAkFzB8M,iBAAe,oBAAU/I,MAlFA;AAmFzBiK,iBAAe,oBAAUC,OAAV,CAAkB,oBAAUf,KAAV,CAAgB;AAC/C/E,eAAW,oBAAUpE,MAAV,CAAiBF,UADmB;AAE/CqK,WAAO,oBAAUf,KAAV,CAAgB,CAAC,gBAAMlO,SAAP,EAAkB,gBAAMD,QAAxB,CAAhB,EAAmD6E;AAFX,GAAhB,CAAlB,CAnFU;AAuFzBS,QAAM,oBAAU4I,KAAV,CAAgB;AACpB/E,eAAW,oBAAUpE,MADD;AAEpBmK,WAAO,oBAAUf,KAAV,CAAgB,CAAC,gBAAMlO,SAAP,EAAkB,gBAAMD,QAAxB,CAAhB,CAFa;AAGpBmP,cAAU,oBAAU5P,IAHA;AAIpB+N,eAAW,oBAAU/N;AAJD,GAAhB,CAvFmB;AA6FzB6P,wBAAsB,oBAAUjB,KAAV,CAAgB,CAAC,gBAAMlO,SAAP,EAAkB,gBAAMD,QAAxB,CAAhB,CA7FG;AA8FzBwL,WAAS,oBAAUjM,IA9FM;AA+FzB8P,iBAAe,oBAAU9P,IA/FA;AAgGzB8N,UAAQ,oBAAU9N,IAhGO;AAiGzBgO,YAAU,oBAAUhO,IAjGK;AAkGzBkO,oBAAkB,oBAAUlO,IAlGH;AAmGzB6L,oBAAkB,oBAAU7L,IAnGH;AAoGzB;AACA+P,UAAQ,oBAAUpB,KAAV,CAAgB;AACtBqB,gBAAY,oBAAUxK,MADA;AAEtByK,mBAAe,oBAAUjQ;AAFH,GAAhB,CArGiB;AAyGzBkQ,wBAAsB,oBAAUlQ;AAzGP,CAA3B;;AA4GAyL,eAAe0E,YAAf,GAA8B;AAC5BvO,cAAY,KADgB;AAE5B6M,UAAQ,KAFoB;AAG5BpC,WAAS,KAHmB;AAI5BE,YAAU,IAJkB;AAK5BD,SAAO,KALqB;AAM5BE,aAAW,KANiB;AAO5BC,oBAAkB,IAPU;AAQ5BjJ,aAAW;AACTC,UAAM,gBAAM5C,mBADH;AAET+C,cAAU,EAFD;AAGT4E,sBAAkB;AAHT,GARiB;AAa5BnC,aAAW;AACTgJ,cAAUxL,SADD;AAETuC,cAAU,EAFD;AAGTS,mBAAe;AAHN,GAbiB;AAkB5BkG,YAAU;AACRtJ,UAAM,IADE;AAER2M,qBAAiB;AAFT,GAlBkB;AAsB5BpD,kBAAgB,gBAAMzL;AAtBM,CAA9B;;kBAyBekK,c;;;;;;;AC7Rf;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;;;;;;;AC/DA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;;AAEA;;;;;;;;;;;;;;ACVA;;;;AACA;;;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;AATA;AAWA,IAAM4E,SAAS,SAATA,MAAS,CAAChO,KAAD,EAAW;AAAA,MAEtBoI,SAFsB,GAepBpI,KAfoB,CAEtBoI,SAFsB;AAAA,MAGtBvB,OAHsB,GAepB7G,KAfoB,CAGtB6G,OAHsB;AAAA,MAItB4E,MAJsB,GAepBzL,KAfoB,CAItByL,MAJsB;AAAA,MAKtBE,QALsB,GAepB3L,KAfoB,CAKtB2L,QALsB;AAAA,MAMtBJ,SANsB,GAepBvL,KAfoB,CAMtBuL,SANsB;AAAA,MAOtBC,SAPsB,GAepBxL,KAfoB,CAOtBwL,SAPsB;AAAA,MAQtBrK,SARsB,GAepBnB,KAfoB,CAQtBmB,SARsB;AAAA,MAStB6C,SATsB,GAepBhE,KAfoB,CAStBgE,SATsB;AAAA,MAUtB4H,WAVsB,GAepB5L,KAfoB,CAUtB4L,WAVsB;AAAA,MAWtBC,gBAXsB,GAepB7L,KAfoB,CAWtB6L,gBAXsB;AAAA,MAYtBlB,cAZsB,GAepB3K,KAfoB,CAYtB2K,cAZsB;AAAA,MAatBsD,eAbsB,GAepBjO,KAfoB,CAatBiO,eAbsB;AAAA,MActBzD,cAdsB,GAepBxK,KAfoB,CActBwK,cAdsB;;;AAiBxB,MAAI0D,0BAA0B;AAAA,WAAM,IAAN;AAAA,GAA9B;AACA,MAAIC,0BAA0B;AAAA,WAAM,IAAN;AAAA,GAA9B;;AAEA,MAAInK,UAAUwC,gBAAd,EAAgC;AAC9B2H,8BAA0B,mEAA1B;AACD;;AAED,MAAIhN,SAAJ,EAAe;AACb+M,8BAA0B,yEAA1B;AACD;;AAED,MAAMlI,+BAA+B,SAA/BA,4BAA+B;AAAA,QACnCC,QADmC,uEACxB,gBAAMrH,uBADkB;AAAA,WAEhCqH,aAAa,gBAAMrH,uBAFa;AAAA,GAArC;;AAIA,MAAMsH,YAAY,CAChBW,QAAQtB,GAAR,CAAY,UAACnF,MAAD,EAASjD,CAAT,EAAe;AACzB,QAAMiR,WAAWhO,OAAOmH,SAAP,KAAqBgE,SAAtC;AACA,QAAM8C,gBAAgBjO,OAAOmH,SAAP,KAAqBgE,SAA3C;;AAEA,WACE;AACE,aAAQpO,CADV;AAEE,WAAMiD,OAAOmH,SAFf;AAGE,cAASnH,MAHX;AAIE,cAASqL,MAJX;AAKE,eAAU2C,QALZ;AAME,iBAAY5C,SANd;AAOE,uBAAkByC,eAPpB;AAQE,qBAAgBI,aARlB;AASE,gBAAW1C,QATb;AAUE,mBAAcC,WAVhB;AAWE,wBAAmBC,gBAXrB;AAYE,sBAAiBlB;AAZnB,MADF;AAeD,GAnBD,CADgB,CAAlB;;AAuBA,MAAI,CAACxJ,UAAUgF,gBAAf,EAAiC;AAC/B,QAAIH,6BAA6B7E,UAAUiF,oBAAvC,CAAJ,EAAkE;AAChEF,gBAAUG,OAAV,CAAkB,8BAAC,uBAAD,IAAyB,KAAI,WAA7B,GAAlB;AACD,KAFD,MAEO;AACLH,gBAAUzE,IAAV,CAAe,8BAAC,uBAAD,IAAyB,KAAI,WAA7B,GAAf;AACD;AACF;;AAED,MAAIuC,UAAUwC,gBAAd,EAAgC;AAC9B,QAAIR,6BAA6BhC,UAAUyC,oBAAvC,CAAJ,EAAkE;AAChEP,gBAAUG,OAAV,CAAkB,8BAAC,uBAAD,IAAyB,KAAI,WAA7B,GAAlB;AACD,KAFD,MAEO;AACLH,gBAAUzE,IAAV,CAAe,8BAAC,uBAAD,IAAyB,KAAI,WAA7B,GAAf;AACD;AACF;;AAED,SACE;AAAA;AAAA,MAAO,WAAY+I,cAAnB;AACE;AAAA;AAAA,QAAI,WAAYpC,SAAhB;AACIlC;AADJ;AADF,GADF;AAOD,CA9ED;;AAgFA8H,OAAOjL,SAAP,GAAmB;AACjB8D,WAAS,oBAAU3D,KAAV,CAAgBD,UADR;AAEjBwI,UAAQ,oBAAU9N,IAFD;AAGjBgO,YAAU,oBAAUhO,IAHH;AAIjB4N,aAAW,oBAAUpI,MAJJ;AAKjBqI,aAAW,oBAAUrI,MALJ;AAMjBhC,aAAW,oBAAUuF,MANJ;AAOjBkF,eAAa,oBAAUlF,MAPN;AAQjBmF,oBAAkB,oBAAUlO,IARX;AASjBsQ,mBAAiB,oBAAUtQ,IATV;AAUjByK,aAAW,oBAAUjF,MAVJ;AAWjBqH,kBAAgB,oBAAUrH,MAXT;AAYjBa,aAAW,oBAAU0C,MAZJ;AAajBiE,kBAAgB,oBAAU4B,KAAV,CAAgB,CAC9B,gBAAMpN,oBADwB,EAE9B,gBAAMD,uBAFwB,EAG9B,gBAAME,uBAHwB,CAAhB;AAbC,CAAnB;;kBAoBe4O,M;;;;;;;;;;;;;;;;;AC9Gf;;;;AACA;;;;AACA;;;;AAEA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;;;;;+eATA;;;IAYMM,U;;;;;;;;;;;6BACK;AAAA,mBAaH,KAAKtO,KAbF;AAAA,UAELI,MAFK,UAELA,MAFK;AAAA,UAGLE,KAHK,UAGLA,KAHK;AAAA,UAILmL,MAJK,UAILA,MAJK;AAAA,UAKL8C,OALK,UAKLA,OALK;AAAA,UAML/C,SANK,UAMLA,SANK;AAAA,UAOL6C,aAPK,UAOLA,aAPK;AAAA,UAQL1C,QARK,UAQLA,QARK;AAAA,UASLC,WATK,UASLA,WATK;AAAA,UAULjB,cAVK,UAULA,cAVK;AAAA,UAWLkB,gBAXK,UAWLA,gBAXK;AAAA,UAYLoC,eAZK,UAYLA,eAZK;AAAA,UAgBLO,IAhBK,GA8BHpO,MA9BG,CAgBLoO,IAhBK;AAAA,UAiBL9K,IAjBK,GA8BHtD,MA9BG,CAiBLsD,IAjBK;AAAA,UAkBLgI,SAlBK,GA8BHtL,MA9BG,CAkBLsL,SAlBK;AAAA,UAmBLhK,MAnBK,GA8BHtB,MA9BG,CAmBLsB,MAnBK;AAAA,UAoBLuJ,cApBK,GA8BH7K,MA9BG,CAoBL6K,cApBK;AAAA,UAqBLwD,WArBK,GA8BHrO,MA9BG,CAqBLqO,WArBK;AAAA,UAsBLC,WAtBK,GA8BHtO,MA9BG,CAsBLsO,WAtBK;AAAA,UAuBLC,eAvBK,GA8BHvO,MA9BG,CAuBLuO,eAvBK;AAAA,UAwBLC,YAxBK,GA8BHxO,MA9BG,CAwBLwO,YAxBK;AAAA,UAyBLvD,aAzBK,GA8BHjL,MA9BG,CAyBLiL,aAzBK;AAAA,UA0BLwD,WA1BK,GA8BHzO,MA9BG,CA0BLyO,WA1BK;AAAA,UA2BLC,WA3BK,GA8BH1O,MA9BG,CA2BL0O,WA3BK;AAAA,UA4BLC,oBA5BK,GA8BH3O,MA9BG,CA4BL2O,oBA5BK;AAAA,UA6BLC,kBA7BK,GA8BH5O,MA9BG,CA6BL4O,kBA7BK;;;AAgCP,UAAMC,gBAAgBvD,aAAauC,eAAnC;;AAEA,UAAMiB,iBAAiB,KAAKC,QAAL,CAAcP,YAAd,CAAvB;;AAEA,UAAMQ,cAAc,gBAAExH,UAAF,CAAakH,WAAb,IAChBA,YAAY1O,MAAZ,EAAoBE,KAApB,CADgB,GAEfwO,eAAe,EAFpB;;AAIA,UAAMnH,yBACDyH,WADC,EAEDF,cAFC;AAGJ5H,kBAAU,gBAAEjK,SAAF,CAAY+R,YAAY9H,QAAxB,IAAoC8H,YAAY9H,QAAhD,GAA2D;AAHjE,QAAN;;AAMA,UAAI+H,mBAAJ;AACA,UAAIC,kBAAJ;AACA,UAAI5H,YAAY,EAAhB;AACA,UAAII,cAAc,gBAAEF,UAAF,CAAayD,aAAb,IAA8BA,cAAcjL,MAAd,EAAsBE,KAAtB,CAA9B,GAA6D+K,aAA/E;;AAEA,UAAIwD,WAAJ,EAAiB;AACfnH,oBAAY,gBAAEE,UAAF,CAAaiH,WAAb,IAA4BA,YAAYzO,MAAZ,EAAoBE,KAApB,CAA5B,GAAyDuO,WAArE;AACAnH,oBAAYA,yBAAiBA,SAAjB,IAA+BA,SAA3C;AACD;;AAED,UAAI+G,WAAJ,EAAiB;AACf9G,kBAAUM,KAAV,GAAkB,gBAAEL,UAAF,CAAa6G,WAAb,IAA4BA,YAAYrO,MAAZ,EAAoBE,KAApB,CAA5B,GAAyDkO,IAA3E;AACD;;AAED,UAAIE,WAAJ,EAAiB;AACfhH,kBAAUS,SAAV,GAAsB,gBAAEP,UAAF,CAAa8G,WAAb,IAA4BA,YAAYtO,MAAZ,EAAoBE,KAApB,CAA5B,GAAyDoO,WAA/E;AACD;;AAED,UAAIhL,IAAJ,EAAU;AACR,YAAM6L,cAAc5H,UAAU6H,OAA9B;AACA7H,kBAAU,YAAV,IAA0B4G,UAAaC,IAAb,cAA0BhD,SAA1B,GAA2CgD,IAA3C,cAA1B;AACA7G,kBAAU8H,OAAV,GAAoB,UAACtT,CAAD,EAAO;AACzB,cAAIA,EAAEoK,GAAF,KAAU,OAAd,EAAuB;AACrBkF,mBAAOrL,MAAP;AACA,gBAAI,gBAAEwH,UAAF,CAAa2H,WAAb,CAAJ,EAA+BA,YAAYpT,CAAZ;AAChC;AACF,SALD;AAMAwL,kBAAU6H,OAAV,GAAoB,UAACrT,CAAD,EAAO;AACzBsP,iBAAOrL,MAAP;AACA,cAAI,gBAAEwH,UAAF,CAAa2H,WAAb,CAAJ,EAA+BA,YAAYpT,CAAZ;AAChC,SAHD;AAIAwL,kBAAUS,SAAV,GAAsB,0BAAGT,UAAUS,SAAb,EAAwB,UAAxB,CAAtB;;AAEA,YAAImG,OAAJ,EAAa;AACXc,uBAAaJ,gBACXA,cAAczD,SAAd,EAAyBpL,MAAzB,CADW,GAEX,iDAAW,OAAQoL,SAAnB,GAFF;;AAIA;AACA1D,wBAAc,0BACZA,WADY,EAEZ,gBAAEF,UAAF,CAAamH,oBAAb,IACIA,qBAAqB3O,MAArB,EAA6BoL,SAA7B,EAAwC6C,aAAxC,EAAuD/N,KAAvD,CADJ,GAEIyO,oBAJQ,CAAd;;AAOArH,mCACKA,SADL,EAEK,gBAAEE,UAAF,CAAaoH,kBAAb,IACCA,mBAAmB5O,MAAnB,EAA2BoL,SAA3B,EAAsC6C,aAAtC,EAAqD/N,KAArD,CADD,GAEC0O,kBAJN;AAMD,SAnBD,MAmBO;AACLK,uBAAaJ,gBAAgBA,cAAczN,SAAd,EAAyBpB,MAAzB,CAAhB,GAAmD,qDAAhE;AACD;AACF;;AAED,UAAI0H,WAAJ,EAAiBH,UAAUS,SAAV,GAAsB,0BAAGT,UAAUS,SAAb,EAAwBN,WAAxB,CAAtB;AACjB,UAAI,CAAC,gBAAElL,aAAF,CAAgB8K,SAAhB,CAAL,EAAiCC,UAAUK,KAAV,GAAkBN,SAAlB;;AAEjC,UAAIiD,mBAAmB,gBAAMzL,uBAA7B,EAAsD;AACpD,YAAI+L,cAAJ,EAAoB;AAClB,cAAMyE,iBAAiB7D,iBAAiBzL,MAAjB,EAAyBsB,OAAO1B,KAAP,CAAa2D,IAAtC,CAAvB;AACA2L,sBAAYrE,eAAeyE,cAAf,EAA+BtP,MAA/B,CAAZ;AACD,SAHD,MAGO,IAAIsB,MAAJ,EAAY;AACjB4N,sBACE,8BAAC,MAAD,CAAQ,MAAR,eACO5N,OAAO1B,KADd;AAEE,yBAAc4L,YAAYxL,OAAOmH,SAAnB,CAFhB;AAGE,sBAAWoE,QAHb;AAIE,oBAASvL;AAJX,aADF;AAQD;AACF;;AAED,UAAMyC,WAAW8L,kBACfA,gBAAgBvO,MAAhB,EAAwBE,KAAxB,EAA+B,EAAEqP,aAAaN,UAAf,EAA2BO,eAAeN,SAA1C,EAA/B,CADe,GAEfd,IAFF;;AAIA,UAAIG,eAAJ,EAAqB;AACnB,eAAO,gBAAMrI,aAAN,CAAoB,IAApB,EAA0BqB,SAA1B,EAAqC9E,QAArC,CAAP;AACD;;AAED,aAAO,gBAAMyD,aAAN,CAAoB,IAApB,EAA0BqB,SAA1B,EAAqC9E,QAArC,EAA+CwM,UAA/C,EAA2DC,SAA3D,CAAP;AACD;;;;EApIsB,kCAAe,gBAAMxM,SAArB,C;;AAuIzBwL,WAAWvL,SAAX,GAAuB;AACrB3C,UAAQ,oBAAUkM,KAAV,CAAgB;AACtB/E,eAAW,oBAAUpE,MAAV,CAAiBF,UADN;AAEtBuL,UAAM,oBAAUrL,MAAV,CAAiBF,UAFD;AAGtBU,UAAM,oBAAU4I,KAAV,CAAgB,CACpB,gBAAMzN,WADc,EAEpB,gBAAMC,WAFc,EAGpB,gBAAMC,YAHc,EAIpB,gBAAMC,SAJc,CAAhB,CAHgB;AAStB4Q,kBAAc,oBAAU1D,IATF;AAUtB2D,YAAQ,oBAAU3D,IAVI;AAWtBwC,qBAAiB,oBAAUhR,IAXL;AAYtBoS,eAAW,oBAAUpS,IAZC;AAatBqS,qBAAiB,oBAAUC,GAbL;AActB5E,mBAAe,oBAAUgB,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAdO;AAetBoK,aAAS,oBAAUsE,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAfa;AAgBtBkR,iBAAa,oBAAUxC,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CAhBS;AAiBtBqK,WAAO,oBAAUqE,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CAjBe;AAkBtB8Q,iBAAa,oBAAUpC,SAAV,CAAoB,CAAC,oBAAUF,IAAX,EAAiB,oBAAUxO,IAA3B,CAApB,CAlBS;AAmBtBsK,WAAO,oBAAUoE,SAAV,CAAoB,CAAC,oBAAUF,IAAX,EAAiB,oBAAUxO,IAA3B,CAApB,CAnBe;AAoBtBiR,kBAAc,oBAAUlI,MApBF;AAqBtB3G,YAAQ,oBAAU2G,MArBI;AAsBtBgI,iBAAa,oBAAUrC,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAtBS;AAuBtBuK,WAAO,oBAAUmE,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAvBe;AAwBtBmR,iBAAa,oBAAUzC,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CAxBS;AAyBtB4C,WAAO,oBAAU8L,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CAzBe;AA0BtB+F,UAAM,oBAAUyI,IA1BM;AA2BtBoB,cAAU,oBAAU5P,IA3BE;AA4BtB8N,YAAQ,oBAAU9N,IA5BI;AA6BtBuS,YAAQ,oBAAUxJ,MA7BI;AA8BtBI,cAAU,oBAAUuF,SAAV,CAAoB,CAAC,oBAAUF,IAAX,EAAiB,oBAAUxO,IAA3B,CAApB,CA9BY;AA+BtBwS,mBAAe,oBAAU9D,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CA/BO;AAgCtByS,qBAAiB,oBAAU/D,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAhCK;AAiCtB0S,iBAAa,oBAAUhE,SAAV,CAAoB,CAAC,oBAAU3F,MAAX,EAAmB,oBAAU/I,IAA7B,CAApB,CAjCS;AAkCtB2S,mBAAe,oBAAUjE,SAAV,CAAoB,CAAC,oBAAUlJ,MAAX,EAAmB,oBAAUxF,IAA7B,CAApB,CAlCO;AAmCtB4S,oBAAgB,oBAAU5S,IAnCJ;AAoCtB6S,eAAW,oBAAU7S,IApCC;AAqCtB+D,YAAQ,oBAAUgF,MArCI;AAsCtBuE,oBAAgB,oBAAUtN,IAtCJ;AAuCtB8S,iBAAa,oBAAU9S,IAvCD;AAwCtB+S,gBAAY,oBAAUvE;AAxCA,GAAhB,EAyCLlJ,UA1CkB;AA2CrB3C,SAAO,oBAAUqQ,MAAV,CAAiB1N,UA3CH;AA4CrBwI,UAAQ,oBAAU9N,IA5CG;AA6CrB4Q,WAAS,oBAAUpC,IA7CE;AA8CrBX,aAAW,oBAAUe,KAAV,CAAgB,CAAC,gBAAMnO,QAAP,EAAiB,gBAAMC,SAAvB,CAAhB,CA9CU;AA+CrBqN,aAAW,oBAAU/N,IA/CA;AAgDrB0Q,iBAAe,oBAAUlC,IAhDJ;AAiDrBR,YAAU,oBAAUhO,IAjDC;AAkDrBgN,kBAAgB,oBAAU4B,KAAV,CAAgB,CAAC,gBAAMrN,uBAAP,EAC9B,gBAAME,uBADwB,EACC,gBAAMD,oBADP,CAAhB,CAlDK;AAoDrByM,eAAa,oBAAUlF,MApDF;AAqDrBmF,oBAAkB,oBAAUlO;AArDP,CAAvB;;kBAwDe2Q,U;;;;;;;;;;;;;AC3Mf;;;;AACA;;;;AAEA,IAAMsC,aAAa,SAAbA,UAAa;AAAA,SACjB;AAAA,gCAAkB,QAAlB;AAAA;AAEI;AAAA,UAAGrR,UAAH,QAAGA,UAAH;AAAA,aAAqBA,aACnB,wCAAM,WAAU,SAAhB,GADmB,GAGnB;AAAA;AAAA,UAAM,WAAU,OAAhB;AACE;AAAA;AAAA,YAAM,WAAU,UAAhB;AACE,kDAAM,WAAU,OAAhB;AADF,SADF;AAIE;AAAA;AAAA,YAAM,WAAU,QAAhB;AACE,kDAAM,WAAU,OAAhB;AADF;AAJF,OAHF;AAAA;AAFJ,GADiB;AAAA,CAAnB;;kBAmBeqR,U;;;;;;;;;;;;;ACtBf;;;;AACA;;;;AACA;;;;AAEA;;;;AACA;;;;AAGA,IAAMC,YAAY,SAAZA,SAAY,OAAe;AAAA,MAAZvD,KAAY,QAAZA,KAAY;;AAC/B,MAAMwD,aAAa,0BAAG,kCAAH,EAAuC;AACxDC,YAAQzD,UAAU,gBAAMlP;AADgC,GAAvC,CAAnB;;AAIA,SACE;AAAA,gCAAkB,QAAlB;AAAA;AAEI;AAAA,UAAGmB,UAAH,SAAGA,UAAH;AAAA,aAAqBA,aACnB,wCAAM,wBAAuB+N,KAA7B,GADmB,GAGnB;AAAA;AAAA,UAAM,WAAYwD,UAAlB;AACE,gDAAM,WAAU,OAAhB;AADF,OAHF;AAAA;AAFJ,GADF;AAaD,CAlBD;;AAoBAD,UAAU9N,SAAV,GAAsB;AACpBuK,SAAO,oBAAUf,KAAV,CAAgB,CAAC,gBAAMnO,QAAP,EAAiB,gBAAMC,SAAvB,CAAhB,EAAmD4E;AADtC,CAAtB;;kBAIe4N,S;;;;;;sDChCf;AACA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,gBAAgB;AAC5B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,oBAAoB;AACzC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sCAAsC,YAAY;AAClD;AACA;AACA,KAAK;AACL;AACA,uCAAuC,YAAY;AACnD;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,gBAAgB;AACvC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,8BAA8B;AAC1C;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,gBAAgB;AACvC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,gBAAgB;AACvC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,YAAY;AACtD;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,YAAY;AACtD;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,WAAW;AAClC;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;;AAEA;AACA;AACA;AACA,kDAAkD;AAClD,GAAG;;AAEH;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA,wCAAwC;AACxC,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,8CAA8C,YAAY;AAC1D;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,8CAA8C,YAAY;AAC1D;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA,8CAA8C,YAAY;AAC1D;AACA;AACA;AACA,iBAAiB,gBAAgB;AACjC;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;AACA;AACA;AACA;;AAEA,uBAAuB,gBAAgB;AACvC;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,6CAA6C,YAAY;AACzD;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,YAAY,8BAA8B;AAC1C;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,sDAAsD;AACtD;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,SAAS;AACT;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA,0CAA0C,0BAA0B;AACpE;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,qBAAqB,cAAc;AACnC;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,qBAAqB,YAAY;AACjC;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;;AAEH;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,OAAO,eAAe;AACtB;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA;;AAEA;AACA,KAAK;;AAEL;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;;AAEA;AACA,qBAAqB,eAAe;AACpC;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,uBAAuB,gBAAgB;AACvC;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,yCAAyC,YAAY;AACrD;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,yBAAyB,gBAAgB;AACzC;AACA;AACA;AACA,uBAAuB,OAAO;AAC9B;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,yCAAyC,YAAY;AACrD;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,yCAAyC,YAAY;AACrD;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,qDAAqD;AACrD;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;AACA;;;AAGA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,6EAA6E;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,0BAA0B;AAC1B;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA,mBAAmB,OAAO;AAC1B;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA,eAAe;AACf,cAAc;AACd,cAAc;AACd,gBAAgB;AAChB,gBAAgB;AAChB,gBAAgB;AAChB;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,mBAAmB,YAAY;AAC/B;AACA;AACA;AACA,mBAAmB;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,4BAA4B;;AAE5B;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA,OAAO;AACP;AACA,OAAO;AACP,qBAAqB;AACrB;;AAEA;AACA;AACA,KAAK;AACL,iBAAiB;;AAEjB;AACA,kDAAkD,EAAE,iBAAiB;;AAErE;AACA,wBAAwB,8BAA8B;AACtD,2BAA2B;;AAE3B;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA,kDAAkD,iBAAiB;;AAEnE;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;;AAEH;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AAAA;AACL;AACA,CAAC;;;;;;;;AC3pDD;;AAEA;AACA;AACA;AACA,CAAC;;AAED;AACA;AACA;AACA,CAAC;AACD;AACA;AACA;AACA;;AAEA;AACA;AACA,4CAA4C;;AAE5C;;;;;;;ACpBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;;;;;;;;;;;;;;;;;;;ACpBA;;;;AACA;;;;AACA;;;;AACA;;AACA;;;;;;;;;;+eALA;;;AAOO,IAAMG,8BAAW,SAAXA,QAAW;AAAA,MAAG5I,SAAH,QAAGA,SAAH;AAAA,MAAcnH,OAAd,QAAcA,OAAd;AAAA,MAAuBgQ,aAAvB,QAAuBA,aAAvB;AAAA,SACtB;AACE,UAAK,UADP;AAEE,aAAUhQ,OAFZ;AAGE,eA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EAAuE,aAAa;AACpF;AACA;;AAEA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA,2BAA2B;;AAE3B;AACA,wEAAwE;AACxE;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,CAAC;;AAED,8CAA6E;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB;AAClB;AACA;AACA,YAAY;AACZ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA,oC;;;;;;;ACvSA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;AACA,0DAA0D,yJAAyJ;AACnN;;AAEA,oC;;;;;;ACbA;AACA;AACA;AACA;AACA;;AAEA,wC;;;;;;;ACNA;;AAEA;AACA;;AAEA;AACA,qFAAqF;AACrF;;AAEA,oC;;;;;;;ACTA;;AAEA;AACA;AACA;;AAEA;AACA,6DAA6D,mHAAmH;AAChL,E;;;;;;;ACRA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;;AAEA;;AAEA,sCAAsC,uCAAuC,gBAAgB;;AAE7F,0DAA0D,+BAA+B,iBAAiB,sCAAsC,YAAY,YAAY,uBAAuB,OAAO,qBAAqB,0CAA0C,2BAA2B,EAAE,eAAe;;AAEjT,+CAA+C,0DAA0D,2CAA2C,iCAAiC;;AAErL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA,wEAAwE,aAAa;AACrF;AACA;;AAEA;;AAEA;AACA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;AACA;;AAEA;AACA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;AACA;;AAEA;AACA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;AACA;;AAEA;AACA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;AACA;;AAEA;AACA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;AACA;;AAEA;AACA,4EAA4E,eAAe;AAC3F;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;;AAEA;AACA;;AAEA;;AAEA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;AACA;AACA,KAAK;AACL;;AAEA;AACA,CAAC;;AAED;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AACD;AACA;AACA,oC;;;;;;;ACrJA;;AAEA;AACA;AACA;AACA;AACA;;AAEA;;AAEA;AACA;AACA;AACA,WAAW,EAAE;AACb,YAAY,OAAO;AACnB;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA,GAAG;AACH;AACA;AACA,GAAG;AACH;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,WAAW,OAAO;AAClB;AACA,WAAW,OAAO;AAClB;AACA,YAAY,OAAO;AACnB;AACA;;;AAGA;AACA;AACA;;AAEA;AACA;AACA,GAAG;AACH;;;AAGA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL;AACA;AACA;;AAEA;AACA;;AAEA;AACA;AACA,iBAAiB,qCAAqC;AACtD;AACA;AACA;AACA;;AAEA;AACA,GAAG;;;AAGH,aAAa,wBAAwB;AACrC;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,KAAK;AACL,GAAG;AACH;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iFAAiF;;AAEjF;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA,OAAO;AACP,KAAK;AACL;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,OAAO;AACP;AACA,GAAG;AACH;AACA,C;;;;;;;;;;;;;ACpJA;;;;AACA;;;;AAEA;;;;AACA;;;;AACA;;;;;;AAEA,IAAMC,SAAS,SAATA,MAAS,CAACzV,KAAD,EAAW;AAAA,MAChBH,IADgB,GACmCG,KADnC,CAChBH,IADgB;AAAA,MACVuI,SADU,GACmCpI,KADnC,CACVoI,SADU;AAAA,MACCvB,OADD,GACmC7G,KADnC,CACC6G,OADD;AAAA,MACU1F,SADV,GACmCnB,KADnC,CACUmB,SADV;AAAA,MACqB6C,SADrB,GACmChE,KADnC,CACqBgE,SADrB;;;AAGxB,WAAS6B,aAAT,GAAyB;AACvB,WAAOgB,QAAQtB,GAAR,CAAY,UAACnF,MAAD,EAASjD,CAAT,EAAe;AAChC,UAAIiD,OAAOsV,MAAP,KAAkBlU,SAAlB,IAA+BpB,OAAOsV,MAAP,KAAkB,IAArD,EAA2D;AACzD,eAAO,KAAP;AACD;;AAED,UAAMC,aAAa,gBAAEC,KAAF,CAAQ/V,IAAR,EAAcO,OAAOmH,SAArB,CAAnB;;AAEA,aACE;AACE,eAAQpK,CADV;AAEE,aAAMiD,OAAOmH,SAFf;AAGE,gBAASnH,MAHX;AAIE,oBAAauV;AAJf,QADF;AAQD,KAfM,CAAP;AAgBD;;AAED,SACE;AAAA;AAAA;AACE;AACE,qBAAgB9P,aADlB;AAEE,iBAAY1E,SAFd;AAGE,iBAAY6C,SAHd;AAIE,iBAAYoE,SAJd;AAKE,cAAO;AALT;AADF,GADF;AAWD,CAjCD,C,CARA;;;AA2CAqN,OAAO1S,SAAP,GAAmB;AACjBlD,QAAM,oBAAUqD,KADC;AAEjBkF,aAAW,oBAAUjF,MAFJ;AAGjB0D,WAAS,oBAAU3D,KAHF;AAIjB/B,aAAW,oBAAUuF,MAJJ;AAKjB1C,aAAW,oBAAU0C;AALJ,CAAnB;;kBAQe+O,M;;;;;;;;;;;;;;;;;AClDf;;;;AACA;;;;AACA;;;;AAEA;;;;AACA;;;;;;;;;;+eANA;;;IAQMI,U;;;;;;;;;;;6BACK;AAAA,mBAC+B,KAAK7V,KADpC;AAAA,UACCM,KADD,UACCA,KADD;AAAA,UACQF,MADR,UACQA,MADR;AAAA,UACgBuV,UADhB,UACgBA,UADhB;AAAA,UAILD,MAJK,GAYHtV,MAZG,CAILsV,MAJK;AAAA,UAKLI,WALK,GAYH1V,MAZG,CAKL0V,WALK;AAAA,UAMLC,WANK,GAYH3V,MAZG,CAML2V,WANK;AAAA,UAOLC,eAPK,GAYH5V,MAZG,CAOL4V,eAPK;AAAA,UAQLC,YARK,GAYH7V,MAZG,CAQL6V,YARK;AAAA,UASL/J,aATK,GAYH9L,MAZG,CASL8L,aATK;AAAA,UAULgK,WAVK,GAYH9V,MAZG,CAUL8V,WAVK;AAAA,UAWLC,WAXK,GAYH/V,MAZG,CAWL+V,WAXK;;;AAcP,UAAMjH,iBAAiB,KAAKC,QAAL,CAAc8G,YAAd,CAAvB;AACA,UAAMtO,yBACA,gBAAEC,UAAF,CAAauO,WAAb,IAA4BA,YAAY/V,MAAZ,EAAoBE,KAApB,CAA5B,GAAyD6V,WADzD,EAEDjH,cAFC,CAAN;;AAMA,UAAIV,OAAO,EAAX;AACA,UAAI,gBAAE4H,QAAF,CAAWV,MAAX,CAAJ,EAAwB;AACtBlH,eAAOkH,MAAP;AACD,OAFD,MAEO,IAAI,gBAAE9N,UAAF,CAAa8N,MAAb,CAAJ,EAA0B;AAC/BlH,eAAOkH,OAAOC,UAAP,EAAmBvV,MAAnB,EAA2BE,KAA3B,CAAP;AACD;;AAED,UAAIoH,YAAY,EAAhB;AACA,UAAMI,cAAc,gBAAEF,UAAF,CAAasE,aAAb,IAA8BA,cAAc9L,MAAd,EAAsBE,KAAtB,CAA9B,GAA6D4L,aAAjF;;AAEA,UAAIgK,WAAJ,EAAiB;AACfxO,oBAAY,gBAAEE,UAAF,CAAasO,WAAb,IAA4BA,YAAY9V,MAAZ,EAAoBE,KAApB,CAA5B,GAAyD4V,WAArE;AACAxO,oBAAYA,yBAAiBA,SAAjB,IAA+BA,SAA3C;AACD;;AAED,UAAIoO,WAAJ,EAAiB;AACfnO,kBAAUM,KAAV,GAAkB,gBAAEL,UAAF,CAAakO,WAAb,IAA4BA,YAAY1V,MAAZ,EAAoBE,KAApB,CAA5B,GAAyDkO,IAA3E;AACD;;AAED,UAAIuH,WAAJ,EAAiB;AACfrO,kBAAUS,SAAV,GAAsB,gBAAEP,UAAF,CAAamO,WAAb,IAA4BA,YAAY3V,MAAZ,EAAoBE,KAApB,CAA5B,GAAyDyV,WAA/E;AACD;;AAED,UAAIjO,WAAJ,EAAiBH,UAAUS,SAAV,GAAsB,0BAAGT,UAAUS,SAAb,EAAwBN,WAAxB,CAAtB;AACjB,UAAI,CAAC,gBAAElL,aAAF,CAAgB8K,SAAhB,CAAL,EAAiCC,UAAUK,KAAV,GAAkBN,SAAlB;;AAEjC,UAAM7E,WAAWmT,kBAAkBA,gBAAgB5V,MAAhB,EAAwBE,KAAxB,CAAlB,GAAmDkO,IAApE;;AAEA,aAAO,gBAAMlI,aAAN,CAAoB,IAApB,EAA0BqB,SAA1B,EAAqC9E,QAArC,CAAP;AACD;;;;EAnDsB,kCAAe,gBAAMC,SAArB,C;;AAsDzB+S,WAAW9S,SAAX,GAAuB;AACrB4S,cAAY,oBAAUzS,KADD;AAErB5C,SAAO,oBAAUqQ,MAFI;AAGrBvQ,UAAQ,oBAAUsG;AAHG,CAAvB;;kBAMemP,U;;;;;;;;;;;;;;;ACpEf;;;;AACA;;;;;;;;;;;;kBAEe;AAAA;AAAA;;AAAA;AAAA;;AAAA;AAAA;;AAAA;AAAA;AAAA,sCAEK;AAAA,YACNpW,QADM,GACO,KAAKO,KADZ,CACNP,QADM;;AAEd,YAAI,CAACA,QAAL,EAAe;AACb,gBAAM,IAAI/C,KAAJ,CAAU,4CAAV,CAAN;AACD;AACD,YAAI,KAAKuP,iBAAL,CAAuB,KAAvB,KAAiC,CAArC,EAAwC;AACtC,gBAAM,IAAIvP,KAAJ,CAAU,6BAAV,CAAN;AACD;AACF;AAVU;AAAA;AAAA,gCAYD;AACR,eAAO,KAAKsD,KAAL,CAAWH,IAAX,CAAgBlD,MAAhB,KAA2B,CAAlC;AACD;AAdU;AAAA;AAAA,oCAgBG;AAAA,qBAC2B,KAAKqD,KADhC;AAAA,YACJH,IADI,UACJA,IADI;AAAA,YACEwW,UADF,UACEA,UADF;AAAA,YACc5W,QADd,UACcA,QADd;;AAEZ,YAAI,CAAC4W,UAAD,IAAeA,WAAW1Z,MAAX,KAAsB,CAAzC,EAA4C,OAAOkD,IAAP;AAC5C,eAAOA,KAAK6B,MAAL,CAAY,UAAC/B,GAAD,EAAS;AAC1B,cAAM4G,MAAM,gBAAE5K,GAAF,CAAMgE,GAAN,EAAWF,QAAX,CAAZ;AACA,iBAAO,CAAC,gBAAEkB,QAAF,CAAW0V,UAAX,EAAuB9P,GAAvB,CAAR;AACD,SAHM,CAAP;AAID;AAvBU;;AAAA;AAAA,IACe,8BAAe3F,UAAf,CADf;AAAA,C;;;;;;;;;;;;;;;;;;;;;kBCHA;AAAA;AAAA;;AAAA;AAAA;;AAAA;AAAA;;AAAA;AAAA;AAAA,0CAEmC;AAAA,YAA5B0V,mBAA4B,uEAAN,IAAM;;AAC5C,YAAIC,kBAAJ;AACA,YAAI,KAAKvW,KAAL,CAAWwW,YAAX,IAA2B,KAAKxW,KAAL,CAAWwW,YAAX,CAAwBC,OAAvD,EAAgE;AAC9D,cAAM5P,UAAU,KAAK7G,KAAL,CAAWwW,YAAX,CAAwBC,OAAxC;AACAF,sBAAYvZ,OAAOE,IAAP,CAAY2J,OAAZ,EAAqBnF,MAArB,CAA4B;AAAA,mBAAQmF,QAAQ6P,IAAR,CAAR;AAAA,WAA5B,EAAmD/Z,MAA/D;AACD,SAHD,MAGO;AACL4Z,sBAAY,KAAKvW,KAAL,CAAW6G,OAAX,CAAmBnF,MAAnB,CAA0B;AAAA,mBAAK,CAACiV,EAAE7G,MAAR;AAAA,WAA1B,EAA0CnT,MAAtD;AACD;AACD,YAAI,CAAC2Z,mBAAL,EAA0B,OAAOC,SAAP;AAC1B,YAAI,KAAKvW,KAAL,CAAWmB,SAAX,IAAwB,CAAC,KAAKnB,KAAL,CAAWmB,SAAX,CAAqBgF,gBAAlD,EAAoE;AAClEoQ,uBAAa,CAAb;AACD;AACD,YAAI,KAAKvW,KAAL,CAAWgE,SAAX,IAAwB,KAAKhE,KAAL,CAAWgE,SAAX,CAAqBwC,gBAAjD,EAAmE;AACjE+P,uBAAa,CAAb;AACD;AACD,eAAOA,SAAP;AACD;AAlBU;;AAAA;AAAA,IACgB3V,UADhB;AAAA,C;;;;;;;;;;;;;;;;;ACIf;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;AACA;;;;;;;;;;+eAdA;AACA;AACA;AACA;;;AAaA,IAAMgW,cAAc,SAAdA,WAAc;AAAA;AAAA;;AAEhB,qCAAY5W,KAAZ,EAAmB;AAAA;;AAAA,oJACXA,KADW;;AAEjB,YAAK6W,WAAL,GAAmB,4BAAnB;;AAEA,UAAI7W,MAAM8W,kBAAV,EAA8B;AAC5B,YAAMC,oBAAoB,sBAA1B;AACAA,0BAAkBC,EAAlB,CAAqB,gBAArB,EAAuC;AAAA,iBAAWC,QAAQlb,MAAR,GAAiB,MAAKmb,KAAL,CAAW7N,OAAX,EAA5B;AAAA,SAAvC;AACA0N,0BAAkBC,EAAlB,CAAqB,mBAArB,EAA0C;AAAA,iBAAWC,QAAQlb,MAAR,GAAiB,MAAKob,gBAAL,CAAsBC,WAAtB,EAA5B;AAAA,SAA1C;AACAL,0BAAkBC,EAAlB,CAAqB,mBAArB,EAA0C,UAACC,OAAD,EAAa;AACrD,cAAI,MAAKrJ,aAAT,EAAwB;AACtBqJ,oBAAQlb,MAAR,GAAiB,MAAK6R,aAAL,CAAmByJ,WAAnB,EAAjB;AACD,WAFD,MAEO,IAAI,MAAKC,aAAT,EAAwB;AAC7BL,oBAAQlb,MAAR,GAAiB,MAAKub,aAAL,CAAmBC,WAAnB,EAAjB;AACD,WAFM,MAEA;AACLN,oBAAQlb,MAAR,GAAiB,MAAKmb,KAAL,CAAW7N,OAAX,EAAjB;AACD;AACF,SARD;AASArJ,cAAM8W,kBAAN,CAAyBC,iBAAzB;AACD;;AAED,UAAI/W,MAAM6G,OAAN,CAAcnF,MAAd,CAAqB;AAAA,eAAOsJ,IAAItH,IAAX;AAAA,OAArB,EAAsC/G,MAAtC,GAA+C,CAAnD,EAAsD;AACpD,cAAK6a,WAAL,GAAmB,gDACH,MAAKC,YADF,EACgB,MAAKC,sBADrB,CAAnB;AAED;;AAED,UACE1X,MAAMwW,YAAN,IACAxW,MAAM6G,OAAN,CAAcnF,MAAd,CAAqB;AAAA,eAAOsJ,IAAI8E,MAAX;AAAA,OAArB,EAAwCnT,MAAxC,GAAiD,CAFnD,EAGE;AACA,cAAKgb,uBAAL,GAA+B,8BAA/B;AACD;;AAED,UAAI3X,MAAMmB,SAAV,EAAqB;AACnB,cAAKN,gBAAL;AACD;;AAED,UAAIb,MAAMgE,SAAV,EAAqB;AACnB,cAAKJ,gBAAL;AACD;;AAED,UAAI5D,MAAM0K,QAAN,IAAkB1K,MAAM0K,QAAN,CAAepL,aAArC,EAAoD;AAClD,cAAKsY,eAAL,GAAuB5X,MAAM0K,QAAN,CAAepL,aAAf,uCACJ,MAAKuY,gBADD,EACmB,MAAKC,sBADxB,CAAvB;AAED;;AAED,UAAI9X,MAAM0B,MAAV,EAAkB;AAChB,cAAKqW,aAAL,GAAqB/X,MAAM0B,MAAN,CAAapC,aAAb,kBAChB,MAAK0Y,iBADW,EACQ,MAAKC,wBADb,CAArB;AAED;;AAED,UAAIjY,MAAMyJ,UAAV,EAAsB;AACpB,cAAKyO,iBAAL,GAAyBlY,MAAMyJ,UAAN,CAAiBnK,aAAjB,EAAzB;AACD;;AAED,UAAIU,MAAM0N,MAAN,IAAgB1N,MAAM0N,MAAN,CAAaE,aAAjC,EAAgD;AAC9C,cAAKuK,aAAL,GAAqBnY,MAAM0N,MAAN,CAAaE,aAAb,kBAChB,MAAKwK,cADW,EACK,MAAKC,wBADV,CAArB;AAED;;AAED,UAAIrY,MAAM6N,oBAAV,EAAgC;AAC9B7N,cAAM6N,oBAAN;AACD;;AAED,UAAI7N,MAAMsY,0BAAV,EAAsC;AACpCtY,cAAMsY,0BAAN,CAAiC,MAAKC,aAAtC;AACD;AAjEgB;AAkElB;;AApEe;AAAA;AAAA,uDAsEiBhW,SAtEjB,EAsE4B;AAC1C,YAAIA,UAAUsE,OAAV,CAAkBnF,MAAlB,CAAyB;AAAA,iBAAOsJ,IAAItH,IAAX;AAAA,SAAzB,EAA0C/G,MAA1C,IAAoD,CAAxD,EAA2D;AACzD,eAAK6a,WAAL,GAAmB,IAAnB;AACD,SAFD,MAEO,IAAI,CAAC,KAAKA,WAAV,EAAuB;AAC5B,eAAKA,WAAL,GAAmB,gDACH,KAAKC,YADF,EACgB,KAAKC,sBADrB,CAAnB;AAED;AACD,YAAI,CAACnV,UAAUkH,UAAX,IAAyB,KAAKzJ,KAAL,CAAWyJ,UAAxC,EAAoD;AAClD,eAAKyO,iBAAL,GAAyB,IAAzB;AACD;AACD,YAAI3V,UAAUkH,UAAV,IAAwB,CAAC,KAAKzJ,KAAL,CAAWyJ,UAAxC,EAAoD;AAClD,eAAKyO,iBAAL,GAAyB3V,UAAUkH,UAAV,CAAqBnK,aAArB,CACvB,KAAKkZ,kBADkB,EACE,KAAKC,sBADP,CAAzB;AAED;AACD,YAAI,CAAClW,UAAUmI,QAAX,IAAuB,KAAK1K,KAAL,CAAW0K,QAAtC,EAAgD;AAC9C,eAAKkN,eAAL,GAAuB,IAAvB;AACD;AACD,YAAIrV,UAAUmI,QAAV,IAAsB,CAAC,KAAK1K,KAAL,CAAW0K,QAAtC,EAAgD;AAC9C,eAAKkN,eAAL,GAAuBrV,UAAUmI,QAAV,CAAmBpL,aAAnB,uCACJ,KAAKuY,gBADD,EACmB,KAAKC,sBADxB,CAAvB;AAED;AACF;AA3Fe;AAAA;AAAA,mCA6FH;AAAA;;AACX,eAAO,UACLY,SADK,EAELC,WAFK,EAGLC,WAHK,EAILC,SAJK,EAKLC,eALK,EAMLC,iBANK;AAAA,iBAQL,8BAAC,IAAD;AACE,iBAAM;AAAA,qBAAK,OAAK7B,KAAL,GAAa8B,CAAlB;AAAA;AADR,aAEO,OAAKhZ,KAFZ,EAGO6Y,SAHP,EAIOF,WAJP,EAKOC,WALP,EAMOE,eANP,EAOOC,iBAPP;AAQE,kBAAOL,UAAUrP,OAAV,CAAkBsP,WAAlB,EAA+BC,WAA/B,EAA4CC,SAA5C,EAAuDC,eAAvD;AART,aARK;AAAA,SAAP;AAmBD;AAjHe;AAAA;AAAA,oDAmHcG,IAnHd,EAmHoBC,SAnHpB,EAmH+B;AAAA;;AAC7C,eAAO,UACLR,SADK,EAELC,WAFK,EAGLC,WAHK,EAILC,SAJK,EAKLC,eALK;AAAA,iBAOL;AAAA,mBAAM,uBAAN,CAA8B,QAA9B;AAAA,yBACOI,SADP;AAEE,uBAAU,OAAKlZ,KAAL,CAAWwW,YAAX,GAA0B,OAAKxW,KAAL,CAAWwW,YAAX,CAAwBC,OAAlD,GAA4D;AAFxE;AAIE;AAAA,qBAAM,uBAAN,CAA8B,QAA9B;AAAA;AAEI;AAAA,uBAAqBwC,KACnBP,SADmB,EAEnBC,WAFmB,EAGnBC,WAHmB,EAInBC,SAJmB,EAKnBC,eALmB,EAMnBC,iBANmB,CAArB;AAAA;AAFJ;AAJF,WAPK;AAAA,SAAP;AAyBD;AA7Ie;AAAA;AAAA,6CA+IOE,IA/IP,EA+IaC,SA/Ib,EA+IwB;AAAA;;AACtC,eAAO,UACLR,SADK,EAELC,WAFK,EAGLC,WAHK,EAILC,SAJK,EAKLC,eALK;AAAA,iBAOL;AAAA,mBAAM,gBAAN,CAAuB,QAAvB;AAAA,yBACOI,SADP;AAEE,mBAAM;AAAA,uBAAK,OAAK/B,gBAAL,GAAwB6B,CAA7B;AAAA,eAFR;AAGE,yBAAY,OAAKhZ,KAAL,CAAWmB,SAHzB;AAIE,oBAAOuX,UAAUrP,OAAV,CAAkBsP,WAAlB,EAA+BC,WAA/B,EAA4CC,SAA5C,EAAuDC,eAAvD;AAJT;AAOIG,iBACEP,SADF,EAEEC,WAFF,EAGEC,WAHF,EAIEC,SAJF,EAKEC,eALF;AAPJ,WAPK;AAAA,SAAP;AAwBD;AAxKe;AAAA;AAAA,6CA0KOG,IA1KP,EA0KaC,SA1Kb,EA0KwB;AAAA;;AACtC,eAAO,UACLR,SADK,EAELC,WAFK,EAGLC,WAHK,EAILC,SAJK,EAKLC,eALK;AAAA,iBAOL;AAAA,mBAAM,gBAAN,CAAuB,QAAvB;AAAA,yBACOI,SADP;AAEE,mBAAM;AAAA,uBAAK,OAAKC,gBAAL,GAAwBH,CAA7B;AAAA,eAFR;AAGE,yBAAY,OAAKhZ,KAAL,CAAWgE,SAHzB;AAIE,oBAAO0U,UAAUrP,OAAV,CAAkBsP,WAAlB,EAA+BC,WAA/B,EAA4CC,SAA5C,EAAuDC,eAAvD;AAJT;AAOIG,iBACEP,SADF,EAEEC,WAFF,EAGEC,WAHF,EAIEC,SAJF,EAKEC,eALF;AAPJ,WAPK;AAAA,SAAP;AAwBD;AAnMe;AAAA;AAAA,8CAqMQG,IArMR,EAqMc;AAAA;;AAC5B,eAAO,UACLP,SADK,EAELC,WAFK,EAGLC,WAHK,EAILC,SAJK;AAAA,iBAML;AAAA,mBAAM,iBAAN,CAAwB,QAAxB;AAAA;AACE,mBAAM;AAAA,uBAAK,OAAKO,iBAAL,GAAyBJ,CAA9B;AAAA,eADR;AAEE,0BAAa,OAAKhZ,KAAL,CAAWyJ,UAF1B;AAGE,oBAAOiP,UAAUrP,OAAV,CAAkBsP,WAAlB,EAA+BC,WAA/B,EAA4CC,SAA5C,CAHT;AAIE,0BAAa,OAAK7Y,KAAL,CAAWT,UAJ1B;AAKE,kCAAqB,OAAKiZ,kBAL5B;AAME,6BAAgB,OAAKD,aANvB;AAOE,gCAAmB,OAAKvY,KAAL,CAAWwJ;AAPhC;AASE;AAAA,qBAAM,iBAAN,CAAwB,QAAxB;AAAA;AAEI;AAAA,uBAAmByP,KACjBP,SADiB,EAEjBC,WAFiB,EAGjBC,WAHiB,EAIjBC,SAJiB,EAKjBC,eALiB,CAAnB;AAAA;AAFJ;AATF,WANK;AAAA,SAAP;AA4BD;AAlOe;AAAA;AAAA,wCAoOEG,IApOF,EAoOQC,SApOR,EAoOmB;AAAA;;AACjC,eAAO,UACLR,SADK,EAELC,WAFK,EAGLC,WAHK;AAAA,iBAKL;AAAA,mBAAM,WAAN,CAAkB,QAAlB;AAAA,yBACOM,SADP;AAEE,mBAAM;AAAA,uBAAK,OAAKG,WAAL,GAAmBL,CAAxB;AAAA,eAFR;AAGE,6BAAgB,OAAKhZ,KAAL,CAAWoN,aAH7B;AAIE,oCAAuB,OAAKpN,KAAL,CAAWwN,oBAJpC;AAKE,oBAAO,OAAKxN,KAAL,CAAW0D,IALpB;AAME,oBAAOgV,UAAUrP,OAAV,CAAkBsP,WAAlB,EAA+BC,WAA/B;AANT;AAQE;AAAA,qBAAM,WAAN,CAAkB,QAAlB;AAAA;AAEI;AAAA,uBAAaK,KACXP,SADW,EAEXC,WAFW,EAGXC,WAHW,EAIXC,SAJW,CAAb;AAAA;AAFJ;AARF,WALK;AAAA,SAAP;AAyBD;AA9Pe;AAAA;AAAA,0CAgQII,IAhQJ,EAgQUC,SAhQV,EAgQqB;AAAA;;AACnC,eAAO,UACLR,SADK,EAELC,WAFK;AAAA,iBAIL;AAAA,mBAAM,aAAN,CAAoB,QAApB;AAAA,yBACOO,SADP;AAEE,mBAAM;AAAA,uBAAK,OAAKtL,aAAL,GAAqBoL,CAA1B;AAAA,eAFR;AAGE,oBAAON,UAAUrP,OAAV,CAAkBsP,WAAlB,CAHT;AAIE,0BAAa,OAAK3Y,KAAL,CAAW0N,MAAX,CAAkBC,UAJjC;AAKE,kCAAqB,OAAK3N,KAAL,CAAWsZ;AALlC;AAOE;AAAA,qBAAM,aAAN,CAAoB,QAApB;AAAA;AAEI;AAAA,uBAAeL,KACbP,SADa,EAEbC,WAFa,EAGbC,WAHa,CAAf;AAAA;AAFJ;AAPF,WAJK;AAAA,SAAP;AAsBD;AAvRe;AAAA;AAAA,0CAyRIK,IAzRJ,EAyRUC,SAzRV,EAyRqB;AAAA;;AACnC,eAAO;AAAA,iBACL;AAAA,mBAAM,aAAN,CAAoB,QAApB;AAAA,yBACOA,SADP;AAEE,mBAAM;AAAA,uBAAK,OAAK5B,aAAL,GAAqB0B,CAA1B;AAAA,eAFR;AAGE,oBAAON,UAAUrP,OAAV,EAHT;AAIE,kCAAqB,OAAKrJ,KAAL,CAAWsZ;AAJlC;AAME;AAAA,qBAAM,aAAN,CAAoB,QAApB;AAAA;AAEI;AAAA,uBAAeL,KACbP,SADa,EAEbC,WAFa,CAAf;AAAA;AAFJ;AANF,WADK;AAAA,SAAP;AAiBD;AA3Se;AAAA;AAAA,4CA6SMM,IA7SN,EA6SYC,SA7SZ,EA6SuB;AAAA;;AACrC,eAAO;AAAA,iBACL;AAAA,oBAAM,eAAN,CAAsB,QAAtB;AAAA,yBACOA,SADP;AAEE,mBAAM;AAAA,uBAAK,QAAKK,eAAL,GAAuBP,CAA5B;AAAA,eAFR;AAGE,yBAAY,QAAKhZ,KAAL,CAAWmB,SAHzB;AAIE,wBAAW,QAAKnB,KAAL,CAAW0K,QAJxB;AAKE,oBAAOgO,UAAUrP,OAAV;AALT;AAOI4P,iBAAKP,SAAL;AAPJ,WADK;AAAA,SAAP;AAWD;AAzTe;AAAA;AAAA,+BA2TP;AAAA,qBACmC,KAAK1Y,KADxC;AAAA,YACCP,QADD,UACCA,QADD;AAAA,YACWoH,OADX,UACWA,OADX;AAAA,YACoBtH,UADpB,UACoBA,UADpB;;AAEP,YAAM2Z,YAAY,EAAEzZ,kBAAF,EAAYoH,gBAAZ,EAAlB;;AAEA,YAAIoS,OAAO,KAAKO,UAAL,EAAX;;AAEA,YAAI,KAAK7B,uBAAT,EAAkC;AAChCsB,iBAAO,KAAKQ,6BAAL,CAAmCR,IAAnC,EAAyCC,SAAzC,CAAP;AACD;;AAED,YAAI,KAAKrY,gBAAT,EAA2B;AACzBoY,iBAAO,KAAKS,sBAAL,CAA4BT,IAA5B,EAAkCC,SAAlC,CAAP;AACD;;AAED,YAAI,KAAKtV,gBAAT,EAA2B;AACzBqV,iBAAO,KAAKU,sBAAL,CAA4BV,IAA5B,EAAkCC,SAAlC,CAAP;AACD;;AAED,YAAI,KAAKhB,iBAAT,EAA4B;AAC1Be,iBAAO,KAAKW,uBAAL,CAA6BX,IAA7B,EAAmCC,SAAnC,CAAP;AACD;;AAED,YAAI,KAAK1B,WAAT,EAAsB;AACpByB,iBAAO,KAAKY,iBAAL,CAAuBZ,IAAvB,EAA6BC,SAA7B,CAAP;AACD;;AAED,YAAI,KAAKf,aAAT,EAAwB;AACtBc,iBAAO,KAAKa,mBAAL,CAAyBb,IAAzB,EAA+BC,SAA/B,CAAP;AACD;;AAED,YAAI,KAAKnB,aAAT,EAAwB;AACtBkB,iBAAO,KAAKc,mBAAL,CAAyBd,IAAzB,EAA+BC,SAA/B,CAAP;AACD;;AAED,YAAI,KAAKtB,eAAT,EAA0B;AACxBqB,iBAAO,KAAKe,qBAAL,CAA2Bf,IAA3B,EAAiCC,SAAjC,CAAP;AACD;;AAED,eACE;AAAA,sCAAkB,QAAlB;AAAA,YAA2B,OAAQ,EAAE3Z,sBAAF,EAAnC;AACE;AAAA,iBAAM,WAAN,CAAkB,QAAlB;AAAA,yBACO2Z,SADP;AAEE,oBAAO,KAAKlZ,KAAL,CAAWH;AAFpB;AAIE;AAAA,mBAAM,WAAN,CAAkB,QAAlB;AAAA;AAEIoZ;AAFJ;AAJF;AADF,SADF;AAcD;AA/We;;AAAA;AAAA,IACoB,+CADpB;AAAA,CAApB;;kBAkXerC,W;;;;;;;;;;;;;;;ACjYf;;;;AACA;;;;;;;;;;+eAFA;;;kBAIe,YAAM;AACnB,MAAMC,cAAc,gBAAMvX,aAAN,EAApB;;AADmB,MAGb2a,YAHa;AAAA;;AAAA;AAAA;;AAAA;;AAAA;;AAAA;AAAA;AAAA;;AAAA,oMASjBnW,KATiB,GAST,EAAEjE,MAAM,MAAKG,KAAL,CAAWH,IAAnB,EATS,QAWjBwJ,OAXiB,GAWP,UAACsP,WAAD,EAAcC,WAAd,EAA2BC,SAA3B,EAAsCC,eAAtC,EAA0D;AAClE,YAAIA,eAAJ,EAAqB,OAAOA,gBAAgBjZ,IAAvB,CAArB,KACK,IAAIgZ,SAAJ,EAAe,OAAOA,UAAUhZ,IAAjB,CAAf,KACA,IAAI+Y,WAAJ,EAAiB,OAAOA,YAAY/Y,IAAnB,CAAjB,KACA,IAAI8Y,WAAJ,EAAiB,OAAOA,YAAY9Y,IAAnB;AACtB,eAAO,MAAKG,KAAL,CAAWH,IAAlB;AACD,OAjBgB;AAAA;;AAAA;AAAA;AAAA,uDAmBgB0C,SAnBhB,EAmB2B;AAC1C,aAAK6B,QAAL,CAAc;AAAA,iBAAO,EAAEvE,MAAM0C,UAAU1C,IAAlB,EAAP;AAAA,SAAd;AACD;AArBgB;AAAA;AAAA,+BAuBR;AACP,eACE;AAAC,qBAAD,CAAa,QAAb;AAAA;AACE,mBAAQ;AACNA,oBAAM,KAAKiE,KAAL,CAAWjE,IADX;AAENwJ,uBAAS,KAAKA;AAFR;AADV;AAMI,eAAKrJ,KAAL,CAAW6C;AANf,SADF;AAUD;AAlCgB;;AAAA;AAAA;;AAGboX,cAHa,CAIVlX,SAJU,GAIE;AACjBlD,UAAM,oBAAUqD,KAAV,CAAgBD,UADL;AAEjBJ,cAAU,oBAAUG,IAAV,CAAeC;AAFR,GAJF;;AAoCnB,SAAO;AACLG,cAAU6W,YADL;AAEL5W,cAAUwT,YAAYxT;AAFjB,GAAP;AAID,C;;;;;;;;;;;;;;;AC1CD;;;;AACA;;;;;;;;;;+eAHA;AACA;;;kBAIe,YAAM;AACnB,MAAMsU,0BAA0B,gBAAMrY,aAAN,EAAhC;;AADmB,MAGb4a,wBAHa;AAAA;;AAAA;AAAA;;AAAA;AAAA;;AAAA;AAAA;AAAA,+BAaR;AACP,YAAIC,qBAAJ;AADO,qBAEsB,KAAKna,KAF3B;AAAA,YAEC6G,OAFD,UAECA,OAFD;AAAA,YAEU4P,OAFV,UAEUA,OAFV;;AAGP,YAAIA,OAAJ,EAAa;AACX0D,yBAAetT,QAAQnF,MAAR,CAAe;AAAA,mBAAU+U,QAAQrW,OAAOmH,SAAf,CAAV;AAAA,WAAf,CAAf;AACD,SAFD,MAEO;AACL4S,yBAAetT,QAAQnF,MAAR,CAAe;AAAA,mBAAU,CAACtB,OAAO0P,MAAlB;AAAA,WAAf,CAAf;AACD;AACD,eACE;AAAC,iCAAD,CAAyB,QAAzB;AAAA,YAAkC,OAAQ,EAAEjJ,SAASsT,YAAX,EAA1C;AACI,eAAKna,KAAL,CAAW6C;AADf,SADF;AAKD;AA1BgB;;AAAA;AAAA,IAGoB,gBAAMC,SAH1B;;AAGboX,0BAHa,CAIVnX,SAJU,GAIE;AACjB8D,aAAS,oBAAU3D,KAAV,CAAgBD,UADR;AAEjBwT,aAAS,oBAAU/P;AAFF,GAJF;AAGbwT,0BAHa,CASVpM,YATU,GASK;AACpB2I,aAAS;AADW,GATL;;;AA6BnB,SAAO;AACLrT,cAAU8W,wBADL;AAEL7W,cAAUsU,wBAAwBtU;AAF7B,GAAP;AAID,C;;;;;;;;;;;;;;;;;ACpCD;;;;AACA;;;;AACA;;;;;;;;;;+eAJA;AACA;;;kBAKe,UACb+W,YADa,EAEb3C,YAFa,EAGb4C,gBAHa,EAIV;AACH,MAAM7C,cAAc,gBAAMlY,aAAN,EAApB;;AADG,MAGGgb,YAHH;AAAA;;AAoBD,0BAAYta,KAAZ,EAAmB;AAAA;;AAAA,8HACXA,KADW;;AAAA;;AAEjB,UAAIwL,kBAAJ;AACA,UAAIyG,mBAAJ;AAHiB,UAIT7E,aAJS,GAIqCpN,KAJrC,CAIToN,aAJS;AAAA,UAIMI,oBAJN,GAIqCxN,KAJrC,CAIMwN,oBAJN;AAAA,UAI4B9J,IAJ5B,GAIqC1D,KAJrC,CAI4B0D,IAJ5B;;;AAMjB,UAAI0J,iBAAiBA,cAAczQ,MAAd,GAAuB,CAA5C,EAA+C;AAC7C6O,oBAAY4B,cAAc,CAAd,EAAiBE,KAAjB,IAA0BE,oBAAtC;AACAyE,qBAAa,MAAKsI,QAAL,CAAcnN,cAAc,CAAd,EAAiB7F,SAA/B,EAA0CiE,SAA1C,CAAb;AACD,OAHD,MAGO,IAAI9H,QAAQA,KAAK6D,SAAb,IAA0B7D,KAAK4J,KAAnC,EAA0C;AAC/C9B,oBAAY9H,KAAK4J,KAAjB;AACA2E,qBAAa,MAAKsI,QAAL,CAAc7W,KAAK6D,SAAnB,EAA8BiE,SAA9B,CAAb;AACD;AACD,YAAK1H,KAAL,GAAa,EAAE0H,oBAAF,EAAayG,sBAAb,EAAb;AAbiB;AAclB;;AAlCA;AAAA;AAAA,0CAoCmB;AAAA,qBACgB,KAAKnO,KADrB;AAAA,YACV0H,SADU,UACVA,SADU;AAAA,YACCyG,UADD,UACCA,UADD;;AAElB,YAAIwF,kBAAkBjM,SAAlB,IAA+ByG,UAAnC,EAA+C;AAC7CoI,2BAAiBpI,WAAW1K,SAA5B,EAAuCiE,SAAvC;AACD;AACF;AAzCA;AAAA;AAAA,uDA2CgCjJ,SA3ChC,EA2C2C;AAAA,YAClCmB,IADkC,GAChBnB,SADgB,CAClCmB,IADkC;AAAA,YAC5BmD,OAD4B,GAChBtE,SADgB,CAC5BsE,OAD4B;;AAE1C,YAAInD,QAAQA,KAAK6D,SAAb,IAA0B7D,KAAK4J,KAAnC,EAA0C;AACxC,eAAKlJ,QAAL,CAAc;AACZoH,uBAAW9H,KAAK4J,KADJ;AAEZ2E,wBAAYpL,QAAQ/G,IAAR,CAAa;AAAA,qBAAOkL,IAAIzD,SAAJ,KAAkB7D,KAAK6D,SAA9B;AAAA,aAAb;AAFA,WAAd;AAID;AACF;AAnDA;AAAA;AAAA,+BAqDQgE,SArDR,EAqDmBC,SArDnB,EAqD8B;AAC7B,YAAIyG,mBAAJ;AAD6B,YAErBpL,OAFqB,GAET,KAAK7G,KAFI,CAErB6G,OAFqB;;AAG7B,YAAM2T,cAAc3T,QAAQnF,MAAR,CAAe;AAAA,iBAAOsJ,IAAIzD,SAAJ,KAAkBgE,SAAzB;AAAA,SAAf,CAApB;AACA,YAAIiP,YAAY7d,MAAZ,GAAqB,CAAzB,EAA4B;AAC1BsV,uBAAauI,YAAY,CAAZ,CAAb;;AAEA,cAAIvI,WAAWxG,MAAf,EAAuB;AACrBwG,uBAAWxG,MAAX,CAAkBF,SAAlB,EAA6BC,SAA7B;AACD;AACF;AACD,eAAOyG,UAAP;AACD;AAjEA;AAAA;AAAA,+BAmFQ;AAAA,YACDpS,IADC,GACQ,KAAKG,KADb,CACDH,IADC;AAAA,YAEC6D,IAFD,GAEU,KAAK1D,KAFf,CAEC0D,IAFD;AAAA,sBAG2B,KAAKI,KAHhC;AAAA,YAGC0H,SAHD,WAGCA,SAHD;AAAA,YAGYyG,UAHZ,WAGYA,UAHZ;;AAIP,YAAI,CAACwF,cAAD,IAAmBxF,UAAvB,EAAmC;AACjC,cAAM1E,WAAW0E,WAAW1E,QAAX,GAAsB0E,WAAW1E,QAAjC,GAA6C7J,QAAQA,KAAK6J,QAA3E;AACA1N,iBAAOua,aAAa1W,IAAb,CAAkB7D,IAAlB,EAAwB2L,SAAxB,eAAwCyG,UAAxC,IAAoD1E,kBAApD,IAAP;AACD;;AAED,eACE;AAAC,qBAAD,CAAa,QAAb;AAAA;AACE,mBAAQ;AACN1N,wBADM;AAEN2L,kCAFM;AAGNC,sBAAQ,KAAKgP,UAHP;AAINlP,yBAAW0G,aAAaA,WAAW1K,SAAxB,GAAoC;AAJzC;AADV;AAQI,eAAKvH,KAAL,CAAW6C;AARf,SADF;AAYD;AAxGA;;AAAA;AAAA,IAGwB,gBAAMC,SAH9B;;AAGGwX,cAHH,CAIMvX,SAJN,GAIkB;AACjBlD,UAAM,oBAAUqD,KAAV,CAAgBD,UADL;AAEjB4D,aAAS,oBAAU3D,KAAV,CAAgBD,UAFR;AAGjBJ,cAAU,oBAAUG,IAAV,CAAeC,UAHR;AAIjBmK,mBAAe,oBAAUC,OAAV,CAAkB,oBAAUf,KAAV,CAAgB;AAC/C/E,iBAAW,oBAAUpE,MAAV,CAAiBF,UADmB;AAE/CqK,aAAO,oBAAUf,KAAV,CAAgB,CAAC,gBAAMlO,SAAP,EAAkB,gBAAMD,QAAxB,CAAhB,EAAmD6E;AAFX,KAAhB,CAAlB,CAJE;AAQjBS,UAAM,oBAAU4I,KAAV,CAAgB;AACpB/E,iBAAW,oBAAUpE,MADD;AAEpBmK,aAAO,oBAAUf,KAAV,CAAgB,CAAC,gBAAMlO,SAAP,EAAkB,gBAAMD,QAAxB,CAAhB,CAFa;AAGpBmP,gBAAU,oBAAU5P;AAHA,KAAhB,CARW;AAajB6P,0BAAsB,oBAAUjB,KAAV,CAAgB,CAAC,gBAAMlO,SAAP,EAAkB,gBAAMD,QAAxB,CAAhB;AAbL,GAJlB;;AAAA;AAAA;;AAAA,SAmEDqc,UAnEC,GAmEY,UAACra,MAAD,EAAY;AACvB,UAAMoL,YAAY4O,aAAarI,SAAb,CAAuB3R,MAAvB,EAA+B,OAAK0D,KAApC,EAA2C,OAAK9D,KAAL,CAAWwN,oBAAtD,CAAlB;;AAEA,UAAIpN,OAAOqL,MAAX,EAAmB;AACjBrL,eAAOqL,MAAP,CAAcrL,OAAOmH,SAArB,EAAgCiE,SAAhC;AACD;;AAED,UAAIiM,cAAJ,EAAoB;AAClB4C,yBAAiBja,OAAOmH,SAAxB,EAAmCiE,SAAnC;AACD;AACD,aAAKpH,QAAL,CAAc;AAAA,eAAO;AACnBoH,8BADmB;AAEnByG,sBAAY7R;AAFO,SAAP;AAAA,OAAd;AAID,KAjFA;AAAA;;AA0GH,SAAO;AACLgD,cAAUkX,YADL;AAELjX,cAAUmU,YAAYnU;AAFjB,GAAP;AAID,C;;;;;;;;;;;;;;;ACxHD;;;;AACA;;;;;;;;;;;;kBAEe;AAAA;AAAA;;AAEX,4BAAYrD,KAAZ,EAAmB;AAAA;;AAAA,kIACXA,KADW;;AAAA,YAOnB0a,cAPmB,GAOF,YAAgB;AAAA,YAAf5W,KAAe,uEAAP,EAAO;;AAC/B,YAAI0H,kBAAJ;AACA,YAAID,kBAAJ;AACA,YAAIoP,aAAJ;AACA,YAAIC,oBAAJ;AACA,YAAIjN,mBAAJ;AACA,YAAIkN,UAAU,EAAd;;AAEA,YAAI,MAAKxB,WAAT,EAAsB;AACpB7N,sBAAY,MAAK6N,WAAL,CAAiBvV,KAAjB,CAAuB0H,SAAnC;AACAD,sBAAY,MAAK8N,WAAL,CAAiBvV,KAAjB,CAAuBmO,UAAvB,GACV,MAAKoH,WAAL,CAAiBvV,KAAjB,CAAuBmO,UAAvB,CAAkC1K,SADxB,GAEV,IAFF;AAGD;;AAED,YAAI,MAAK+P,aAAT,EAAwB;AACtBuD,oBAAU,MAAKvD,aAAL,CAAmB1L,WAA7B;AACD;;AAED,YAAI,MAAKwN,iBAAT,EAA4B;AAC1BuB,iBAAO,MAAKvB,iBAAL,CAAuB0B,QAA9B;AACAF,wBAAc,MAAKxB,iBAAL,CAAuB2B,eAArC;AACD;;AAED,YAAI,MAAKnN,aAAT,EAAwB;AACtBD,uBAAa,MAAK3N,KAAL,CAAW0N,MAAX,CAAkBC,UAA/B;AACD;;AAED;AACEnC,8BADF;AAEED,8BAFF;AAGEsP,0BAHF;AAIEF,oBAJF;AAKEC,kCALF;AAMEjN;AANF,WAOK7J,KAPL;AAQEjE,gBAAM,MAAKG,KAAL,CAAWH;AARnB;AAUD,OA7CkB;;AAAA,YA+CnBuY,cA/CmB,GA+CF,YAAM;AAAA,YACbhM,MADa,GACF,MAAKpM,KADH,CACboM,MADa;;AAErB,eAAOA,WAAW,IAAX,IAAoB,gBAAEtP,QAAF,CAAWsP,MAAX,KAAsBA,OAAOsB,MAAjD,IAA4D,MAAK8K,kBAAL,EAAnE;AACD,OAlDkB;;AAAA,YAoDnBA,kBApDmB,GAoDE,YAAY;AAAA,YAAXrc,CAAW,uEAAP,EAAO;AAAA,YACvBiQ,MADuB,GACZ,MAAKpM,KADO,CACvBoM,MADuB;;AAE/BjQ,UAAEJ,MAAF,GAAYqQ,WAAW,IAAX,IAAoB,gBAAEtP,QAAF,CAAWsP,MAAX,KAAsBA,OAAO3C,UAA7D;AACA,eAAOtN,EAAEJ,MAAT;AACD,OAxDkB;;AAAA,YA0DnBic,iBA1DmB,GA0DC,YAAM;AAAA,YAChB5L,MADgB,GACL,MAAKpM,KADA,CAChBoM,MADgB;;AAExB,eAAOA,WAAW,IAAX,IAAoB,gBAAEtP,QAAF,CAAWsP,MAAX,KAAsBA,OAAO1K,MAAjD,IAA4D,MAAK8W,kBAAL,EAAnE;AACD,OA7DkB;;AAAA,YA+DnBf,YA/DmB,GA+DJ,YAAM;AAAA,YACXrL,MADW,GACA,MAAKpM,KADL,CACXoM,MADW;;AAEnB,eAAOA,WAAW,IAAX,IAAoB,gBAAEtP,QAAF,CAAWsP,MAAX,KAAsBA,OAAO1I,IAAjD,IAA0D,MAAK8U,kBAAL,EAAjE;AACD,OAlEkB;;AAAA,YAoEnBX,gBApEmB,GAoEA,YAAM;AAAA,YACfzL,MADe,GACJ,MAAKpM,KADD,CACfoM,MADe;;AAEvB,eAAOA,WAAW,IAAX,IAAoB,gBAAEtP,QAAF,CAAWsP,MAAX,KAAsBA,OAAO1B,QAAxD;AACD,OAvEkB;;AAAA,YAyEnB+N,sBAzEmB,GAyEM,UAACkC,IAAD,EAAOC,WAAP,EAAuB;AAC9C,cAAK5a,KAAL,CAAWyN,aAAX,CAAyB,YAAzB,EAAuC,MAAKiN,cAAL,CAAoB,EAAEC,UAAF,EAAQC,wBAAR,EAApB,CAAvC;AACD,OA3EkB;;AAAA,YA6EnB3C,wBA7EmB,GA6EQ,UAAC4C,OAAD,EAAa;AACtC,YAAMG,WAAW,EAAEH,gBAAF,EAAjB;AACA,YAAI,MAAKrC,kBAAL,EAAJ,EAA+B;AAC7B,cAAMvF,UAAU,MAAKjT,KAAL,CAAWyJ,UAAX,CAAsBwJ,OAAtB,IAAiC,EAAjD;AACA+H,mBAASL,IAAT,GAAgB,gBAAEtd,SAAF,CAAY4V,QAAQgI,cAApB,IAAsChI,QAAQgI,cAA9C,GAA+D,CAA/E;AACD;AACD,cAAKjb,KAAL,CAAWyN,aAAX,CAAyB,QAAzB,EAAmC,MAAKiN,cAAL,CAAoBM,QAApB,CAAnC;AACD,OApFkB;;AAAA,YAsFnBtD,sBAtFmB,GAsFM,UAACnM,SAAD,EAAYC,SAAZ,EAA0B;AACjD,cAAKxL,KAAL,CAAWyN,aAAX,CAAyB,MAAzB,EAAiC,MAAKiN,cAAL,CAAoB,EAAEnP,oBAAF,EAAaC,oBAAb,EAApB,CAAjC;AACD,OAxFkB;;AAAA,YA0FnBsM,sBA1FmB,GA0FM,UAACvG,KAAD,EAAQhK,SAAR,EAAmBiK,QAAnB,EAAgC;AACvD,YAAM9G,WAAW,EAAE6G,YAAF,EAAShK,oBAAT,EAAoBiK,kBAApB,EAAjB;AACA,cAAKxR,KAAL,CAAWyN,aAAX,CAAyB,UAAzB,EAAqC,MAAKiN,cAAL,CAAoB,EAAEhQ,kBAAF,EAApB,CAArC;AACD,OA7FkB;;AAAA,YA+FnB2N,wBA/FmB,GA+FQ,UAAC1K,UAAD,EAAgB;AACzC,cAAK3N,KAAL,CAAWyN,aAAX,CAAyB,QAAzB,EAAmC,MAAKiN,cAAL,CAAoB,EAAE/M,sBAAF,EAApB,CAAnC;AACD,OAjGkB;;AAEjB,YAAK4K,aAAL,GAAqB,sBAArB;AACA,YAAKA,aAAL,CAAmBvB,EAAnB,CAAsB,kBAAtB,EAA0C,MAAKyB,sBAA/C;AACA,YAAKF,aAAL,CAAmBvB,EAAnB,CAAsB,oBAAtB,EAA4C,MAAKwB,kBAAjD;AAJiB;AAKlB;;AAPU;AAAA,IACgB5X,UADhB;AAAA,C","file":"react-bootstrap-table2/dist/react-bootstrap-table-next.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"react\"), require(\"react-dom\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"react\", \"react-dom\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"ReactBootstrapTable2\"] = factory(require(\"react\"), require(\"react-dom\"));\n\telse\n\t\troot[\"ReactBootstrapTable2\"] = factory(root[\"React\"], root[\"ReactDOM\"]);\n})(this, function(__WEBPACK_EXTERNAL_MODULE_0__, __WEBPACK_EXTERNAL_MODULE_17__) {\nreturn \n\n\n// WEBPACK FOOTER //\n// webpack/universalModuleDefinition"," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, {\n \t\t\t\tconfigurable: false,\n \t\t\t\tenumerable: true,\n \t\t\t\tget: getter\n \t\t\t});\n \t\t}\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 22);\n\n\n\n// WEBPACK FOOTER //\n// webpack/bootstrap 211acdaea2936f46fea6","module.exports = __WEBPACK_EXTERNAL_MODULE_0__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"root\":\"React\",\"commonjs2\":\"react\",\"commonjs\":\"react\",\"amd\":\"react\"}\n// module id = 0\n// module chunks = 0 1","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nif (process.env.NODE_ENV !== 'production') {\n  var ReactIs = require('react-is');\n\n  // By explicitly using `prop-types` you are opting into new development behavior.\n  // http://fb.me/prop-types-in-prod\n  var throwOnDirectAccess = true;\n  module.exports = require('./factoryWithTypeCheckers')(ReactIs.isElement, throwOnDirectAccess);\n} else {\n  // By explicitly using `prop-types` you are opting into new production behavior.\n  // http://fb.me/prop-types-in-prod\n  module.exports = require('./factoryWithThrowingShims')();\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/prop-types/index.js\n// module id = 1\n// module chunks = 0 1","/* eslint no-empty: 0 */\n/* eslint no-param-reassign: 0 */\n/* eslint prefer-rest-params: 0 */\nimport _ from 'underscore';\n\nfunction splitNested(str) {\n  return [str]\n    .join('.')\n    .replace(/\\[/g, '.')\n    .replace(/\\]/g, '')\n    .split('.');\n}\n\nfunction get(target, field) {\n  const pathArray = splitNested(field);\n  let result;\n  try {\n    result = pathArray.reduce((curr, path) => curr[path], target);\n  } catch (e) {}\n  return result;\n}\n\nfunction set(target, field, value, safe = false) {\n  const pathArray = splitNested(field);\n  let level = 0;\n  pathArray.reduce((a, b) => {\n    level += 1;\n    if (typeof a[b] === 'undefined') {\n      if (!safe) throw new Error(`${a}.${b} is undefined`);\n      a[b] = {};\n      return a[b];\n    }\n\n    if (level === pathArray.length) {\n      a[b] = value;\n      return value;\n    }\n    return a[b];\n  }, target);\n}\n\nfunction isEmptyObject(obj) {\n  if (!_.isObject(obj)) return false;\n\n  const hasOwnProperty = Object.prototype.hasOwnProperty;\n  const keys = Object.keys(obj);\n\n  for (let i = 0; i < keys.length; i += 1) {\n    if (hasOwnProperty.call(obj, keys[i])) return false;\n  }\n\n  return true;\n}\n\nfunction isDefined(value) {\n  return typeof value !== 'undefined' && value !== null;\n}\n\nfunction sleep(fn, ms) {\n  return setTimeout(() => fn(), ms);\n}\n\nfunction debounce(func, wait, immediate) {\n  let timeout;\n\n  return () => {\n    const later = () => {\n      timeout = null;\n\n      if (!immediate) {\n        func.apply(this, arguments);\n      }\n    };\n\n    const callNow = immediate && !timeout;\n\n    clearTimeout(timeout);\n    timeout = setTimeout(later, wait || 0);\n\n    if (callNow) {\n      func.apply(this, arguments);\n    }\n  };\n}\n\nexport default Object.assign(_, { get, set, isDefined, isEmptyObject, sleep, debounce });\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/utils.js","export default {\n  SORT_ASC: 'asc',\n  SORT_DESC: 'desc',\n  ROW_SELECT_SINGLE: 'radio',\n  ROW_SELECT_MULTIPLE: 'checkbox',\n  ROW_SELECT_DISABLED: 'ROW_SELECT_DISABLED',\n  CHECKBOX_STATUS_CHECKED: 'checked',\n  CHECKBOX_STATUS_INDETERMINATE: 'indeterminate',\n  CHECKBOX_STATUS_UNCHECKED: 'unchecked',\n  INDICATOR_POSITION_LEFT: 'left',\n  INDICATOR_POSITION_RIGHT: 'right',\n  TYPE_STRING: 'string',\n  TYPE_NUMBER: 'number',\n  TYPE_BOOLEAN: 'bool',\n  TYPE_DATE: 'date',\n  FILTERS_POSITION_INLINE: 'inline',\n  FILTERS_POSITION_TOP: 'top',\n  FILTERS_POSITION_BOTTOM: 'bottom'\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/const.js","/*!\n  Copyright (c) 2016 Jed Watson.\n  Licensed under the MIT License (MIT), see\n  http://jedwatson.github.io/classnames\n*/\n/* global define */\n\n(function () {\n\t'use strict';\n\n\tvar hasOwn = {}.hasOwnProperty;\n\n\tfunction classNames () {\n\t\tvar classes = [];\n\n\t\tfor (var i = 0; i < arguments.length; i++) {\n\t\t\tvar arg = arguments[i];\n\t\t\tif (!arg) continue;\n\n\t\t\tvar argType = typeof arg;\n\n\t\t\tif (argType === 'string' || argType === 'number') {\n\t\t\t\tclasses.push(arg);\n\t\t\t} else if (Array.isArray(arg)) {\n\t\t\t\tclasses.push(classNames.apply(null, arg));\n\t\t\t} else if (argType === 'object') {\n\t\t\t\tfor (var key in arg) {\n\t\t\t\t\tif (hasOwn.call(arg, key) && arg[key]) {\n\t\t\t\t\t\tclasses.push(key);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\n\t\treturn classes.join(' ');\n\t}\n\n\tif (typeof module !== 'undefined' && module.exports) {\n\t\tmodule.exports = classNames;\n\t} else if (typeof define === 'function' && typeof define.amd === 'object' && define.amd) {\n\t\t// register as 'classnames', consistent with npm package name\n\t\tdefine('classnames', [], function () {\n\t\t\treturn classNames;\n\t\t});\n\t} else {\n\t\twindow.classNames = classNames;\n\t}\n}());\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/classnames/index.js\n// module id = 4\n// module chunks = 0 1","import React from 'react';\n\nexport const BootstrapContext = React.createContext({\n  bootstrap4: false\n});\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/contexts/bootstrap.js","import _ from '../utils';\n\nexport const matchRow = (keyField, id) => row => _.get(row, keyField) === id;\n\nexport const getRowByRowId = (data, keyField, id) => data.find(matchRow(keyField, id));\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/store/rows.js","import _ from './utils';\n\nconst events = [\n  'onClick',\n  'onDoubleClick',\n  'onMouseEnter',\n  'onMouseLeave',\n  'onContextMenu'\n];\n\nexport default ExtendBase =>\n  class CellEventDelegater extends ExtendBase {\n    constructor(props) {\n      super(props);\n      this.createDefaultEventHandler = this.createDefaultEventHandler.bind(this);\n    }\n\n    createDefaultEventHandler(cb) {\n      return (e) => {\n        const { column, columnIndex, index } = this.props;\n        cb(e, column, typeof columnIndex !== 'undefined' ? columnIndex : index);\n      };\n    }\n\n    delegate(attrs = {}) {\n      const newAttrs = { ...attrs };\n      Object.keys(attrs).forEach((attr) => {\n        if (_.contains(events, attr)) {\n          newAttrs[attr] = this.createDefaultEventHandler(attrs[attr]);\n        }\n      });\n      return newAttrs;\n    }\n  };\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/cell-event-delegater.js","/* eslint camelcase: 0 */\n/* eslint react/prop-types: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Const from '../const';\nimport _ from '../utils';\n\nimport dataOperator from '../store/operators';\nimport { getSelectionSummary } from '../store/selection';\n\nconst SelectionContext = React.createContext();\nclass SelectionProvider extends React.Component {\n  static propTypes = {\n    children: PropTypes.node.isRequired,\n    data: PropTypes.array.isRequired,\n    keyField: PropTypes.string.isRequired\n  }\n\n  constructor(props) {\n    super(props);\n    this.selected = props.selectRow.selected || [];\n  }\n\n  // exposed API\n  getSelected() {\n    return this.selected;\n  }\n\n  UNSAFE_componentWillReceiveProps(nextProps) {\n    if (nextProps.selectRow) {\n      this.selected = nextProps.selectRow.selected || this.selected;\n    }\n  }\n\n  handleRowSelect = (rowKey, checked, rowIndex, e) => {\n    const { data, keyField, selectRow: { mode, onSelect } } = this.props;\n    const { ROW_SELECT_SINGLE } = Const;\n\n    let currSelected = [...this.selected];\n\n    let result = true;\n    if (onSelect) {\n      const row = dataOperator.getRowByRowId(data, keyField, rowKey);\n      result = onSelect(row, checked, rowIndex, e);\n    }\n\n    if (result === true || result === undefined) {\n      if (mode === ROW_SELECT_SINGLE) { // when select mode is radio\n        currSelected = [rowKey];\n      } else if (checked) { // when select mode is checkbox\n        currSelected.push(rowKey);\n      } else {\n        currSelected = currSelected.filter(value => value !== rowKey);\n      }\n    }\n    this.selected = currSelected;\n    this.forceUpdate();\n  }\n\n  handleAllRowsSelect = (e, isUnSelect) => {\n    const {\n      data,\n      keyField,\n      selectRow: {\n        onSelectAll,\n        nonSelectable\n      }\n    } = this.props;\n    const { selected } = this;\n\n    let currSelected;\n\n    if (!isUnSelect) {\n      currSelected = selected.concat(dataOperator.selectableKeys(data, keyField, nonSelectable));\n    } else {\n      currSelected = selected.filter(s => typeof data.find(d => _.get(d, keyField) === s) === 'undefined');\n    }\n\n    let result;\n    if (onSelectAll) {\n      result = onSelectAll(\n        !isUnSelect,\n        dataOperator.getSelectedRows(\n          data,\n          keyField,\n          isUnSelect ? selected : currSelected\n        ),\n        e\n      );\n      if (Array.isArray(result)) {\n        currSelected = result;\n      }\n    }\n    this.selected = currSelected;\n    this.forceUpdate();\n  }\n\n  render() {\n    const {\n      allRowsSelected,\n      allRowsNotSelected\n    } = getSelectionSummary(\n      this.props.data,\n      this.props.keyField,\n      this.selected\n    );\n\n    let checkedStatus;\n\n    // checkbox status depending on selected rows counts\n    if (allRowsSelected) checkedStatus = Const.CHECKBOX_STATUS_CHECKED;\n    else if (allRowsNotSelected) checkedStatus = Const.CHECKBOX_STATUS_UNCHECKED;\n    else checkedStatus = Const.CHECKBOX_STATUS_INDETERMINATE;\n\n    return (\n      <SelectionContext.Provider\n        value={ {\n          ...this.props.selectRow,\n          selected: this.selected,\n          onRowSelect: this.handleRowSelect,\n          onAllRowsSelect: this.handleAllRowsSelect,\n          allRowsSelected,\n          allRowsNotSelected,\n          checkedStatus\n        } }\n      >\n        { this.props.children }\n      </SelectionContext.Provider>\n    );\n  }\n}\n\nexport default {\n  Provider: SelectionProvider,\n  Consumer: SelectionContext.Consumer\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/contexts/selection-context.js","import * as rows from './rows';\nimport * as selection from './selection';\nimport * as expand from './expand';\nimport * as mutate from './mutate';\nimport * as sort from './sort';\nimport * as type from './type';\n\nexport default {\n  ...rows,\n  ...selection,\n  ...expand,\n  ...mutate,\n  ...sort,\n  ...type\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/store/operators.js","/* eslint camelcase: 0 */\n/* eslint react/prop-types: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport dataOperator from '../store/operators';\nimport _ from '../utils';\n\nconst RowExpandContext = React.createContext();\n\nclass RowExpandProvider extends React.Component {\n  static propTypes = {\n    children: PropTypes.node.isRequired,\n    data: PropTypes.array.isRequired,\n    keyField: PropTypes.string.isRequired\n  };\n\n  state = { expanded: this.props.expandRow.expanded || [],\n    isClosing: this.props.expandRow.isClosing || [] };\n\n  onClosed = (closedRow) => {\n    this.setState({ isClosing: this.state.isClosing.filter(value => value !== closedRow) });\n  };\n\n  UNSAFE_componentWillReceiveProps(nextProps) {\n    if (nextProps.expandRow) {\n      const nextExpanded = nextProps.expandRow.expanded || this.state.expanded;\n      const isClosing = this.state.expanded.reduce((acc, cur) => {\n        if (!_.contains(nextExpanded, cur)) {\n          acc.push(cur);\n        }\n        return acc;\n      }, []);\n      this.setState(() => ({\n        expanded: nextExpanded,\n        isClosing\n      }));\n    } else {\n      this.setState(() => ({\n        expanded: this.state.expanded\n      }));\n    }\n  }\n\n  handleRowExpand = (rowKey, expanded, rowIndex, e) => {\n    const { data, keyField, expandRow: { onExpand, onlyOneExpanding, nonExpandable } } = this.props;\n    if (nonExpandable && _.contains(nonExpandable, rowKey)) {\n      return;\n    }\n\n    let currExpanded = [...this.state.expanded];\n    let isClosing = [...this.state.isClosing];\n\n    if (expanded) {\n      if (onlyOneExpanding) {\n        isClosing = isClosing.concat(currExpanded);\n        currExpanded = [rowKey];\n      } else currExpanded.push(rowKey);\n    } else {\n      isClosing.push(rowKey);\n      currExpanded = currExpanded.filter(value => value !== rowKey);\n    }\n\n    if (onExpand) {\n      const row = dataOperator.getRowByRowId(data, keyField, rowKey);\n      onExpand(row, expanded, rowIndex, e);\n    }\n    this.setState(() => ({ expanded: currExpanded, isClosing }));\n  };\n\n  handleAllRowExpand = (e, expandAll) => {\n    const {\n      data,\n      keyField,\n      expandRow: {\n        onExpandAll,\n        nonExpandable\n      }\n    } = this.props;\n    const { expanded } = this.state;\n\n    let currExpanded;\n\n    if (expandAll) {\n      currExpanded = expanded.concat(dataOperator.expandableKeys(data, keyField, nonExpandable));\n    } else {\n      currExpanded = expanded.filter(s => typeof data.find(d => _.get(d, keyField) === s) === 'undefined');\n    }\n\n    if (onExpandAll) {\n      onExpandAll(expandAll, dataOperator.getExpandedRows(data, keyField, currExpanded), e);\n    }\n\n    this.setState(() => ({ expanded: currExpanded }));\n  };\n\n  render() {\n    const { data, keyField } = this.props;\n    return (\n      <RowExpandContext.Provider\n        value={ {\n          ...this.props.expandRow,\n          nonExpandable: this.props.expandRow.nonExpandable,\n          expanded: this.state.expanded,\n          isClosing: this.state.isClosing,\n          onClosed: this.onClosed,\n          isAnyExpands: dataOperator.isAnyExpands(data, keyField, this.state.expanded),\n          onRowExpand: this.handleRowExpand,\n          onAllRowExpand: this.handleAllRowExpand\n        } }\n      >\n        { this.props.children }\n      </RowExpandContext.Provider>\n    );\n  }\n}\n\nexport default {\n  Provider: RowExpandProvider,\n  Consumer: RowExpandContext.Consumer\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/contexts/row-expand-context.js","import _ from '../utils';\nimport { getRowByRowId } from './rows';\n\nexport const getSelectionSummary = (\n  data = [],\n  keyField,\n  selected = []\n) => {\n  let allRowsSelected = data.length > 0;\n  let allRowsNotSelected = true;\n\n  const rowKeys = data.map(d => _.get(d, keyField));\n  for (let i = 0; i < rowKeys.length; i += 1) {\n    const curr = rowKeys[i];\n    if (typeof selected.find(x => x === curr) === 'undefined') {\n      allRowsSelected = false;\n    } else {\n      allRowsNotSelected = false;\n    }\n  }\n  return {\n    allRowsSelected,\n    allRowsNotSelected\n  };\n};\n\nexport const selectableKeys = (data = [], keyField, skips = []) => {\n  if (skips.length === 0) {\n    return data.map(row => _.get(row, keyField));\n  }\n  return data\n    .filter(row => !_.contains(skips, _.get(row, keyField)))\n    .map(row => _.get(row, keyField));\n};\n\nexport const unSelectableKeys = (selected, skips = []) => {\n  if (skips.length === 0) {\n    return [];\n  }\n  return selected.filter(x => _.contains(skips, x));\n};\n\nexport const getSelectedRows = (data = [], keyField, selected) =>\n  selected.map(k => getRowByRowId(data, keyField, k)).filter(x => !!x);\n\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/store/selection.js","/* eslint react/require-default-props: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nimport Const from '../const';\n\nconst RowTemplate = (props) => {\n  const {\n    renderContent,\n    selectRow,\n    expandRow,\n    cellEl,\n    ...rest\n  } = props;\n\n  const isRenderFunctionColumnInLeft = (\n    position = Const.INDICATOR_POSITION_LEFT\n  ) => position === Const.INDICATOR_POSITION_LEFT;\n\n  const childrens = renderContent() || [];\n\n  if (selectRow && selectRow.hideSelectColumn !== true) {\n    if (isRenderFunctionColumnInLeft(selectRow.selectColumnPosition)) {\n      childrens.unshift(React.createElement(cellEl, { key: 'selection' }));\n    } else {\n      childrens.push(React.createElement(cellEl, { key: 'selection' }));\n    }\n  }\n\n  if (expandRow.showExpandColumn) {\n    if (isRenderFunctionColumnInLeft(expandRow.expandColumnPosition)) {\n      childrens.unshift(React.createElement(cellEl, { key: 'expansion' }));\n    } else {\n      childrens.push(React.createElement(cellEl, { key: 'expansion' }));\n    }\n  }\n\n  return <tr { ...rest }>{ childrens }</tr>;\n};\n\nRowTemplate.propTypes = {\n  renderContent: PropTypes.func.isRequired,\n  cellEl: PropTypes.string.isRequired,\n  selectRow: PropTypes.object,\n  expandRow: PropTypes.object\n};\n\nexport default RowTemplate;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row/row-template.js","/* eslint react/prop-types: 0 */\n/* eslint react/no-array-index-key: 0 */\n/* eslint no-plusplus: 0 */\nimport React from 'react';\n\nimport _ from '../utils';\nimport Cell from '../cell';\n\nexport default class RowPureContent extends React.Component {\n  shouldComponentUpdate(nextProps) {\n    if (typeof nextProps.shouldUpdate !== 'undefined') {\n      return nextProps.shouldUpdate;\n    }\n    return true;\n  }\n\n  render() {\n    const {\n      row,\n      keyField,\n      columns,\n      rowIndex,\n      editable,\n      editingRowIdx,\n      editingColIdx,\n      onStart,\n      clickToEdit,\n      dbclickToEdit,\n      EditingCellComponent,\n      tabIndexStart\n    } = this.props;\n\n    let tabIndex = tabIndexStart;\n\n    return columns.map((column, index) => {\n      const { dataField } = column;\n      const content = _.get(row, dataField);\n      if (rowIndex === editingRowIdx && index === editingColIdx) {\n        return (\n          <EditingCellComponent\n            key={ `${content}-${index}-editing` }\n            row={ row }\n            rowIndex={ rowIndex }\n            column={ column }\n            columnIndex={ index }\n          />\n        );\n      }\n      // render cell\n      let cellTitle;\n      let cellStyle = {};\n      let cellAttrs = {\n        ..._.isFunction(column.attrs)\n          ? column.attrs(content, row, rowIndex, index)\n          : column.attrs\n      };\n\n      if (column.events) {\n        const events = Object.assign({}, column.events);\n        Object.keys(Object.assign({}, column.events)).forEach((key) => {\n          const originFn = events[key];\n          events[key] = (...rest) => originFn(...rest, row, rowIndex);\n        });\n        cellAttrs = { ...cellAttrs, ...events };\n      }\n\n      const cellClasses = _.isFunction(column.classes)\n        ? column.classes(content, row, rowIndex, index)\n        : column.classes;\n\n      if (column.style) {\n        cellStyle = _.isFunction(column.style)\n          ? column.style(content, row, rowIndex, index)\n          : column.style;\n        cellStyle = Object.assign({}, cellStyle) || {};\n      }\n\n      if (column.title) {\n        cellTitle = _.isFunction(column.title)\n          ? column.title(content, row, rowIndex, index)\n          : content;\n        cellAttrs.title = cellTitle;\n      }\n\n      if (column.align) {\n        cellStyle.textAlign =\n          _.isFunction(column.align)\n            ? column.align(content, row, rowIndex, index)\n            : column.align;\n      }\n\n      if (cellClasses) cellAttrs.className = cellClasses;\n      if (!_.isEmptyObject(cellStyle)) cellAttrs.style = cellStyle;\n\n      let editableCell = _.isDefined(column.editable) ? column.editable : true;\n      if (column.dataField === keyField || !editable) editableCell = false;\n      if (_.isFunction(column.editable)) {\n        editableCell = column.editable(content, row, rowIndex, index);\n      }\n\n      if (tabIndexStart !== -1) {\n        cellAttrs.tabIndex = tabIndex++;\n      }\n\n      return (\n        <Cell\n          key={ `${content}-${index}` }\n          row={ row }\n          editable={ editableCell }\n          rowIndex={ rowIndex }\n          columnIndex={ index }\n          column={ column }\n          onStart={ onStart }\n          clickToEdit={ clickToEdit }\n          dbclickToEdit={ dbclickToEdit }\n          { ...cellAttrs }\n        />\n      );\n    });\n  }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row/row-pure-content.js","import _ from '../utils';\nimport Const from '../const';\n\nconst events = [\n  'onClick',\n  'onDoubleClick',\n  'onMouseEnter',\n  'onMouseLeave',\n  'onContextMenu'\n];\n\nexport default ExtendBase =>\n  class RowEventDelegater extends ExtendBase {\n    constructor(props) {\n      super(props);\n      this.clickNum = 0;\n      this.createDefaultEventHandler = this.createDefaultEventHandler.bind(this);\n      this.createClickEventHandler = this.createClickEventHandler.bind(this);\n    }\n\n    createClickEventHandler(cb) {\n      return (e) => {\n        const {\n          row,\n          selected,\n          keyField,\n          selectable,\n          expandable,\n          rowIndex,\n          expanded,\n          expandRow,\n          selectRow,\n          DELAY_FOR_DBCLICK\n        } = this.props;\n        const clickFn = () => {\n          if (cb) {\n            cb(e, row, rowIndex);\n          }\n          const key = _.get(row, keyField);\n          if (expandRow && expandable && !expandRow.expandByColumnOnly) {\n            if (\n              (selectRow.mode !== Const.ROW_SELECT_DISABLED && selectRow.clickToExpand) ||\n              selectRow.mode === Const.ROW_SELECT_DISABLED\n            ) {\n              expandRow.onRowExpand(key, !expanded, rowIndex, e);\n            }\n          }\n          if (selectRow.clickToSelect && selectable) {\n            selectRow.onRowSelect(key, !selected, rowIndex, e);\n          }\n        };\n\n        if (DELAY_FOR_DBCLICK) {\n          this.clickNum += 1;\n          _.debounce(() => {\n            if (this.clickNum === 1) {\n              clickFn();\n            }\n            this.clickNum = 0;\n          }, DELAY_FOR_DBCLICK)();\n        } else {\n          clickFn();\n        }\n      };\n    }\n\n    createDefaultEventHandler(cb) {\n      return (e) => {\n        const { row, rowIndex } = this.props;\n        cb(e, row, rowIndex);\n      };\n    }\n\n    delegate(attrs = {}) {\n      const newAttrs = { ...attrs };\n      Object.keys(attrs).forEach((attr) => {\n        if (_.contains(events, attr)) {\n          newAttrs[attr] = this.createDefaultEventHandler(attrs[attr]);\n        }\n      });\n      return newAttrs;\n    }\n  };\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row/event-delegater.js","/* eslint react/prop-types: 0 */\nimport _ from '../utils';\n\nexport default ExtendBase =>\n  class RowShouldUpdater extends ExtendBase {\n    shouldUpdateByCellEditing(nextProps) {\n      if (!(this.props.clickToEdit || this.props.dbclickToEdit)) return false;\n      return (\n        nextProps.editingRowIdx === nextProps.rowIndex ||\n        (this.props.editingRowIdx === nextProps.rowIndex &&\n        nextProps.editingRowIdx === null) ||\n        this.props.editingRowIdx === nextProps.rowIndex\n      );\n    }\n\n    shouldUpdatedBySelfProps(nextProps) {\n      return (\n        this.props.className !== nextProps.className ||\n        !_.isEqual(this.props.style, nextProps.style) ||\n        !_.isEqual(this.props.attrs, nextProps.attrs)\n      );\n    }\n\n    // Only use for simple-row\n    shouldUpdateByColumnsForSimpleCheck(nextProps) {\n      if (this.props.columns.length !== nextProps.columns.length) {\n        return true;\n      }\n      for (let i = 0; i < this.props.columns.length; i += 1) {\n        if (!_.isEqual(this.props.columns[i], nextProps.columns[i])) {\n          return true;\n        }\n      }\n      return false;\n    }\n\n    shouldUpdatedByNormalProps(nextProps) {\n      const shouldUpdate =\n        this.props.rowIndex !== nextProps.rowIndex ||\n        this.props.editable !== nextProps.editable ||\n        !_.isEqual(this.props.row, nextProps.row) ||\n        this.props.columns.length !== nextProps.columns.length;\n\n      return shouldUpdate;\n    }\n\n    shouldUpdateChild(nextProps) {\n      return this.shouldUpdateByCellEditing(nextProps) ||\n        this.shouldUpdatedByNormalProps(nextProps);\n    }\n\n    shouldRowContentUpdate(nextProps) {\n      return this.shouldUpdateChild(nextProps) ||\n        this.shouldUpdateByColumnsForSimpleCheck(nextProps);\n    }\n  };\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row/should-updater.js","\"use strict\";\n\nexports.__esModule = true;\nexports.default = exports.EXITING = exports.ENTERED = exports.ENTERING = exports.EXITED = exports.UNMOUNTED = void 0;\n\nvar PropTypes = _interopRequireWildcard(require(\"prop-types\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _reactDom = _interopRequireDefault(require(\"react-dom\"));\n\nvar _reactLifecyclesCompat = require(\"react-lifecycles-compat\");\n\nvar _PropTypes = require(\"./utils/PropTypes\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar UNMOUNTED = 'unmounted';\nexports.UNMOUNTED = UNMOUNTED;\nvar EXITED = 'exited';\nexports.EXITED = EXITED;\nvar ENTERING = 'entering';\nexports.ENTERING = ENTERING;\nvar ENTERED = 'entered';\nexports.ENTERED = ENTERED;\nvar EXITING = 'exiting';\n/**\n * The Transition component lets you describe a transition from one component\n * state to another _over time_ with a simple declarative API. Most commonly\n * it's used to animate the mounting and unmounting of a component, but can also\n * be used to describe in-place transition states as well.\n *\n * By default the `Transition` component does not alter the behavior of the\n * component it renders, it only tracks \"enter\" and \"exit\" states for the components.\n * It's up to you to give meaning and effect to those states. For example we can\n * add styles to a component when it enters or exits:\n *\n * ```jsx\n * import Transition from 'react-transition-group/Transition';\n *\n * const duration = 300;\n *\n * const defaultStyle = {\n *   transition: `opacity ${duration}ms ease-in-out`,\n *   opacity: 0,\n * }\n *\n * const transitionStyles = {\n *   entering: { opacity: 0 },\n *   entered:  { opacity: 1 },\n * };\n *\n * const Fade = ({ in: inProp }) => (\n *   <Transition in={inProp} timeout={duration}>\n *     {(state) => (\n *       <div style={{\n *         ...defaultStyle,\n *         ...transitionStyles[state]\n *       }}>\n *         I'm a fade Transition!\n *       </div>\n *     )}\n *   </Transition>\n * );\n * ```\n *\n * As noted the `Transition` component doesn't _do_ anything by itself to its child component.\n * What it does do is track transition states over time so you can update the\n * component (such as by adding styles or classes) when it changes states.\n *\n * There are 4 main states a Transition can be in:\n *  - `'entering'`\n *  - `'entered'`\n *  - `'exiting'`\n *  - `'exited'`\n *\n * Transition state is toggled via the `in` prop. When `true` the component begins the\n * \"Enter\" stage. During this stage, the component will shift from its current transition state,\n * to `'entering'` for the duration of the transition and then to the `'entered'` stage once\n * it's complete. Let's take the following example:\n *\n * ```jsx\n * state = { in: false };\n *\n * toggleEnterState = () => {\n *   this.setState({ in: true });\n * }\n *\n * render() {\n *   return (\n *     <div>\n *       <Transition in={this.state.in} timeout={500} />\n *       <button onClick={this.toggleEnterState}>Click to Enter</button>\n *     </div>\n *   );\n * }\n * ```\n *\n * When the button is clicked the component will shift to the `'entering'` state and\n * stay there for 500ms (the value of `timeout`) before it finally switches to `'entered'`.\n *\n * When `in` is `false` the same thing happens except the state moves from `'exiting'` to `'exited'`.\n *\n * ## Timing\n *\n * Timing is often the trickiest part of animation, mistakes can result in slight delays\n * that are hard to pin down. A common example is when you want to add an exit transition,\n * you should set the desired final styles when the state is `'exiting'`. That's when the\n * transition to those styles will start and, if you matched the `timeout` prop with the\n * CSS Transition duration, it will end exactly when the state changes to `'exited'`.\n *\n * > **Note**: For simpler transitions the `Transition` component might be enough, but\n * > take into account that it's platform-agnostic, while the `CSSTransition` component\n * > [forces reflows](https://github.com/reactjs/react-transition-group/blob/5007303e729a74be66a21c3e2205e4916821524b/src/CSSTransition.js#L208-L215)\n * > in order to make more complex transitions more predictable. For example, even though\n * > classes `example-enter` and `example-enter-active` are applied immediately one after\n * > another, you can still transition from one to the other because of the forced reflow\n * > (read [this issue](https://github.com/reactjs/react-transition-group/issues/159#issuecomment-322761171)\n * > for more info). Take this into account when choosing between `Transition` and\n * > `CSSTransition`.\n */\n\nexports.EXITING = EXITING;\n\nvar Transition =\n/*#__PURE__*/\nfunction (_React$Component) {\n  _inheritsLoose(Transition, _React$Component);\n\n  function Transition(props, context) {\n    var _this;\n\n    _this = _React$Component.call(this, props, context) || this;\n    var parentGroup = context.transitionGroup; // In the context of a TransitionGroup all enters are really appears\n\n    var appear = parentGroup && !parentGroup.isMounting ? props.enter : props.appear;\n    var initialStatus;\n    _this.appearStatus = null;\n\n    if (props.in) {\n      if (appear) {\n        initialStatus = EXITED;\n        _this.appearStatus = ENTERING;\n      } else {\n        initialStatus = ENTERED;\n      }\n    } else {\n      if (props.unmountOnExit || props.mountOnEnter) {\n        initialStatus = UNMOUNTED;\n      } else {\n        initialStatus = EXITED;\n      }\n    }\n\n    _this.state = {\n      status: initialStatus\n    };\n    _this.nextCallback = null;\n    return _this;\n  }\n\n  var _proto = Transition.prototype;\n\n  _proto.getChildContext = function getChildContext() {\n    return {\n      transitionGroup: null // allows for nested Transitions\n\n    };\n  };\n\n  Transition.getDerivedStateFromProps = function getDerivedStateFromProps(_ref, prevState) {\n    var nextIn = _ref.in;\n\n    if (nextIn && prevState.status === UNMOUNTED) {\n      return {\n        status: EXITED\n      };\n    }\n\n    return null;\n  }; // getSnapshotBeforeUpdate(prevProps) {\n  //   let nextStatus = null\n  //   if (prevProps !== this.props) {\n  //     const { status } = this.state\n  //     if (this.props.in) {\n  //       if (status !== ENTERING && status !== ENTERED) {\n  //         nextStatus = ENTERING\n  //       }\n  //     } else {\n  //       if (status === ENTERING || status === ENTERED) {\n  //         nextStatus = EXITING\n  //       }\n  //     }\n  //   }\n  //   return { nextStatus }\n  // }\n\n\n  _proto.componentDidMount = function componentDidMount() {\n    this.updateStatus(true, this.appearStatus);\n  };\n\n  _proto.componentDidUpdate = function componentDidUpdate(prevProps) {\n    var nextStatus = null;\n\n    if (prevProps !== this.props) {\n      var status = this.state.status;\n\n      if (this.props.in) {\n        if (status !== ENTERING && status !== ENTERED) {\n          nextStatus = ENTERING;\n        }\n      } else {\n        if (status === ENTERING || status === ENTERED) {\n          nextStatus = EXITING;\n        }\n      }\n    }\n\n    this.updateStatus(false, nextStatus);\n  };\n\n  _proto.componentWillUnmount = function componentWillUnmount() {\n    this.cancelNextCallback();\n  };\n\n  _proto.getTimeouts = function getTimeouts() {\n    var timeout = this.props.timeout;\n    var exit, enter, appear;\n    exit = enter = appear = timeout;\n\n    if (timeout != null && typeof timeout !== 'number') {\n      exit = timeout.exit;\n      enter = timeout.enter;\n      appear = timeout.appear;\n    }\n\n    return {\n      exit: exit,\n      enter: enter,\n      appear: appear\n    };\n  };\n\n  _proto.updateStatus = function updateStatus(mounting, nextStatus) {\n    if (mounting === void 0) {\n      mounting = false;\n    }\n\n    if (nextStatus !== null) {\n      // nextStatus will always be ENTERING or EXITING.\n      this.cancelNextCallback();\n\n      var node = _reactDom.default.findDOMNode(this);\n\n      if (nextStatus === ENTERING) {\n        this.performEnter(node, mounting);\n      } else {\n        this.performExit(node);\n      }\n    } else if (this.props.unmountOnExit && this.state.status === EXITED) {\n      this.setState({\n        status: UNMOUNTED\n      });\n    }\n  };\n\n  _proto.performEnter = function performEnter(node, mounting) {\n    var _this2 = this;\n\n    var enter = this.props.enter;\n    var appearing = this.context.transitionGroup ? this.context.transitionGroup.isMounting : mounting;\n    var timeouts = this.getTimeouts(); // no enter animation skip right to ENTERED\n    // if we are mounting and running this it means appear _must_ be set\n\n    if (!mounting && !enter) {\n      this.safeSetState({\n        status: ENTERED\n      }, function () {\n        _this2.props.onEntered(node);\n      });\n      return;\n    }\n\n    this.props.onEnter(node, appearing);\n    this.safeSetState({\n      status: ENTERING\n    }, function () {\n      _this2.props.onEntering(node, appearing); // FIXME: appear timeout?\n\n\n      _this2.onTransitionEnd(node, timeouts.enter, function () {\n        _this2.safeSetState({\n          status: ENTERED\n        }, function () {\n          _this2.props.onEntered(node, appearing);\n        });\n      });\n    });\n  };\n\n  _proto.performExit = function performExit(node) {\n    var _this3 = this;\n\n    var exit = this.props.exit;\n    var timeouts = this.getTimeouts(); // no exit animation skip right to EXITED\n\n    if (!exit) {\n      this.safeSetState({\n        status: EXITED\n      }, function () {\n        _this3.props.onExited(node);\n      });\n      return;\n    }\n\n    this.props.onExit(node);\n    this.safeSetState({\n      status: EXITING\n    }, function () {\n      _this3.props.onExiting(node);\n\n      _this3.onTransitionEnd(node, timeouts.exit, function () {\n        _this3.safeSetState({\n          status: EXITED\n        }, function () {\n          _this3.props.onExited(node);\n        });\n      });\n    });\n  };\n\n  _proto.cancelNextCallback = function cancelNextCallback() {\n    if (this.nextCallback !== null) {\n      this.nextCallback.cancel();\n      this.nextCallback = null;\n    }\n  };\n\n  _proto.safeSetState = function safeSetState(nextState, callback) {\n    // This shouldn't be necessary, but there are weird race conditions with\n    // setState callbacks and unmounting in testing, so always make sure that\n    // we can cancel any pending setState callbacks after we unmount.\n    callback = this.setNextCallback(callback);\n    this.setState(nextState, callback);\n  };\n\n  _proto.setNextCallback = function setNextCallback(callback) {\n    var _this4 = this;\n\n    var active = true;\n\n    this.nextCallback = function (event) {\n      if (active) {\n        active = false;\n        _this4.nextCallback = null;\n        callback(event);\n      }\n    };\n\n    this.nextCallback.cancel = function () {\n      active = false;\n    };\n\n    return this.nextCallback;\n  };\n\n  _proto.onTransitionEnd = function onTransitionEnd(node, timeout, handler) {\n    this.setNextCallback(handler);\n\n    if (node) {\n      if (this.props.addEndListener) {\n        this.props.addEndListener(node, this.nextCallback);\n      }\n\n      if (timeout != null) {\n        setTimeout(this.nextCallback, timeout);\n      }\n    } else {\n      setTimeout(this.nextCallback, 0);\n    }\n  };\n\n  _proto.render = function render() {\n    var status = this.state.status;\n\n    if (status === UNMOUNTED) {\n      return null;\n    }\n\n    var _this$props = this.props,\n        children = _this$props.children,\n        childProps = _objectWithoutPropertiesLoose(_this$props, [\"children\"]); // filter props for Transtition\n\n\n    delete childProps.in;\n    delete childProps.mountOnEnter;\n    delete childProps.unmountOnExit;\n    delete childProps.appear;\n    delete childProps.enter;\n    delete childProps.exit;\n    delete childProps.timeout;\n    delete childProps.addEndListener;\n    delete childProps.onEnter;\n    delete childProps.onEntering;\n    delete childProps.onEntered;\n    delete childProps.onExit;\n    delete childProps.onExiting;\n    delete childProps.onExited;\n\n    if (typeof children === 'function') {\n      return children(status, childProps);\n    }\n\n    var child = _react.default.Children.only(children);\n\n    return _react.default.cloneElement(child, childProps);\n  };\n\n  return Transition;\n}(_react.default.Component);\n\nTransition.contextTypes = {\n  transitionGroup: PropTypes.object\n};\nTransition.childContextTypes = {\n  transitionGroup: function transitionGroup() {}\n};\nTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /**\n   * A `function` child can be used instead of a React element.\n   * This function is called with the current transition status\n   * ('entering', 'entered', 'exiting', 'exited', 'unmounted'), which can be used\n   * to apply context specific props to a component.\n   *\n   * ```jsx\n   * <Transition timeout={150}>\n   *   {(status) => (\n   *     <MyComponent className={`fade fade-${status}`} />\n   *   )}\n   * </Transition>\n   * ```\n   */\n  children: PropTypes.oneOfType([PropTypes.func.isRequired, PropTypes.element.isRequired]).isRequired,\n\n  /**\n   * Show the component; triggers the enter or exit states\n   */\n  in: PropTypes.bool,\n\n  /**\n   * By default the child component is mounted immediately along with\n   * the parent `Transition` component. If you want to \"lazy mount\" the component on the\n   * first `in={true}` you can set `mountOnEnter`. After the first enter transition the component will stay\n   * mounted, even on \"exited\", unless you also specify `unmountOnExit`.\n   */\n  mountOnEnter: PropTypes.bool,\n\n  /**\n   * By default the child component stays mounted after it reaches the `'exited'` state.\n   * Set `unmountOnExit` if you'd prefer to unmount the component after it finishes exiting.\n   */\n  unmountOnExit: PropTypes.bool,\n\n  /**\n   * Normally a component is not transitioned if it is shown when the `<Transition>` component mounts.\n   * If you want to transition on the first mount set `appear` to `true`, and the\n   * component will transition in as soon as the `<Transition>` mounts.\n   *\n   * > Note: there are no specific \"appear\" states. `appear` only adds an additional `enter` transition.\n   */\n  appear: PropTypes.bool,\n\n  /**\n   * Enable or disable enter transitions.\n   */\n  enter: PropTypes.bool,\n\n  /**\n   * Enable or disable exit transitions.\n   */\n  exit: PropTypes.bool,\n\n  /**\n   * The duration of the transition, in milliseconds.\n   * Required unless `addEndListener` is provided\n   *\n   * You may specify a single timeout for all transitions like: `timeout={500}`,\n   * or individually like:\n   *\n   * ```jsx\n   * timeout={{\n   *  enter: 300,\n   *  exit: 500,\n   * }}\n   * ```\n   *\n   * @type {number | { enter?: number, exit?: number }}\n   */\n  timeout: function timeout(props) {\n    var pt = process.env.NODE_ENV !== \"production\" ? _PropTypes.timeoutsShape : {};;\n    if (!props.addEndListener) pt = pt.isRequired;\n\n    for (var _len = arguments.length, args = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n      args[_key - 1] = arguments[_key];\n    }\n\n    return pt.apply(void 0, [props].concat(args));\n  },\n\n  /**\n   * Add a custom transition end trigger. Called with the transitioning\n   * DOM node and a `done` callback. Allows for more fine grained transition end\n   * logic. **Note:** Timeouts are still used as a fallback if provided.\n   *\n   * ```jsx\n   * addEndListener={(node, done) => {\n   *   // use the css transitionend event to mark the finish of a transition\n   *   node.addEventListener('transitionend', done, false);\n   * }}\n   * ```\n   */\n  addEndListener: PropTypes.func,\n\n  /**\n   * Callback fired before the \"entering\" status is applied. An extra parameter\n   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool) -> void\n   */\n  onEnter: PropTypes.func,\n\n  /**\n   * Callback fired after the \"entering\" status is applied. An extra parameter\n   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool)\n   */\n  onEntering: PropTypes.func,\n\n  /**\n   * Callback fired after the \"entered\" status is applied. An extra parameter\n   * `isAppearing` is supplied to indicate if the enter stage is occurring on the initial mount\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool) -> void\n   */\n  onEntered: PropTypes.func,\n\n  /**\n   * Callback fired before the \"exiting\" status is applied.\n   *\n   * @type Function(node: HtmlElement) -> void\n   */\n  onExit: PropTypes.func,\n\n  /**\n   * Callback fired after the \"exiting\" status is applied.\n   *\n   * @type Function(node: HtmlElement) -> void\n   */\n  onExiting: PropTypes.func,\n\n  /**\n   * Callback fired after the \"exited\" status is applied.\n   *\n   * @type Function(node: HtmlElement) -> void\n   */\n  onExited: PropTypes.func // Name the function so it is clearer in the documentation\n\n} : {};\n\nfunction noop() {}\n\nTransition.defaultProps = {\n  in: false,\n  mountOnEnter: false,\n  unmountOnExit: false,\n  appear: false,\n  enter: true,\n  exit: true,\n  onEnter: noop,\n  onEntering: noop,\n  onEntered: noop,\n  onExit: noop,\n  onExiting: noop,\n  onExited: noop\n};\nTransition.UNMOUNTED = 0;\nTransition.EXITED = 1;\nTransition.ENTERING = 2;\nTransition.ENTERED = 3;\nTransition.EXITING = 4;\n\nvar _default = (0, _reactLifecyclesCompat.polyfill)(Transition);\n\nexports.default = _default;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/react-transition-group/Transition.js\n// module id = 16\n// module chunks = 0 1","module.exports = __WEBPACK_EXTERNAL_MODULE_17__;\n\n\n//////////////////\n// WEBPACK FOOTER\n// external {\"root\":\"ReactDOM\",\"commonjs2\":\"react-dom\",\"commonjs\":\"react-dom\",\"amd\":\"react-dom\"}\n// module id = 17\n// module chunks = 0 1","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\nfunction componentWillMount() {\n  // Call this.constructor.gDSFP to support sub-classes.\n  var state = this.constructor.getDerivedStateFromProps(this.props, this.state);\n  if (state !== null && state !== undefined) {\n    this.setState(state);\n  }\n}\n\nfunction componentWillReceiveProps(nextProps) {\n  // Call this.constructor.gDSFP to support sub-classes.\n  // Use the setState() updater to ensure state isn't stale in certain edge cases.\n  function updater(prevState) {\n    var state = this.constructor.getDerivedStateFromProps(nextProps, prevState);\n    return state !== null && state !== undefined ? state : null;\n  }\n  // Binding \"this\" is important for shallow renderer support.\n  this.setState(updater.bind(this));\n}\n\nfunction componentWillUpdate(nextProps, nextState) {\n  try {\n    var prevProps = this.props;\n    var prevState = this.state;\n    this.props = nextProps;\n    this.state = nextState;\n    this.__reactInternalSnapshotFlag = true;\n    this.__reactInternalSnapshot = this.getSnapshotBeforeUpdate(\n      prevProps,\n      prevState\n    );\n  } finally {\n    this.props = prevProps;\n    this.state = prevState;\n  }\n}\n\n// React may warn about cWM/cWRP/cWU methods being deprecated.\n// Add a flag to suppress these warnings for this special case.\ncomponentWillMount.__suppressDeprecationWarning = true;\ncomponentWillReceiveProps.__suppressDeprecationWarning = true;\ncomponentWillUpdate.__suppressDeprecationWarning = true;\n\nfunction polyfill(Component) {\n  var prototype = Component.prototype;\n\n  if (!prototype || !prototype.isReactComponent) {\n    throw new Error('Can only polyfill class components');\n  }\n\n  if (\n    typeof Component.getDerivedStateFromProps !== 'function' &&\n    typeof prototype.getSnapshotBeforeUpdate !== 'function'\n  ) {\n    return Component;\n  }\n\n  // If new component APIs are defined, \"unsafe\" lifecycles won't be called.\n  // Error if any of these lifecycles are present,\n  // Because they would work differently between older and newer (16.3+) versions of React.\n  var foundWillMountName = null;\n  var foundWillReceivePropsName = null;\n  var foundWillUpdateName = null;\n  if (typeof prototype.componentWillMount === 'function') {\n    foundWillMountName = 'componentWillMount';\n  } else if (typeof prototype.UNSAFE_componentWillMount === 'function') {\n    foundWillMountName = 'UNSAFE_componentWillMount';\n  }\n  if (typeof prototype.componentWillReceiveProps === 'function') {\n    foundWillReceivePropsName = 'componentWillReceiveProps';\n  } else if (typeof prototype.UNSAFE_componentWillReceiveProps === 'function') {\n    foundWillReceivePropsName = 'UNSAFE_componentWillReceiveProps';\n  }\n  if (typeof prototype.componentWillUpdate === 'function') {\n    foundWillUpdateName = 'componentWillUpdate';\n  } else if (typeof prototype.UNSAFE_componentWillUpdate === 'function') {\n    foundWillUpdateName = 'UNSAFE_componentWillUpdate';\n  }\n  if (\n    foundWillMountName !== null ||\n    foundWillReceivePropsName !== null ||\n    foundWillUpdateName !== null\n  ) {\n    var componentName = Component.displayName || Component.name;\n    var newApiName =\n      typeof Component.getDerivedStateFromProps === 'function'\n        ? 'getDerivedStateFromProps()'\n        : 'getSnapshotBeforeUpdate()';\n\n    throw Error(\n      'Unsafe legacy lifecycles will not be called for components using new component APIs.\\n\\n' +\n        componentName +\n        ' uses ' +\n        newApiName +\n        ' but also contains the following legacy lifecycles:' +\n        (foundWillMountName !== null ? '\\n  ' + foundWillMountName : '') +\n        (foundWillReceivePropsName !== null\n          ? '\\n  ' + foundWillReceivePropsName\n          : '') +\n        (foundWillUpdateName !== null ? '\\n  ' + foundWillUpdateName : '') +\n        '\\n\\nThe above lifecycles should be removed. Learn more about this warning here:\\n' +\n        'https://fb.me/react-async-component-lifecycle-hooks'\n    );\n  }\n\n  // React <= 16.2 does not support static getDerivedStateFromProps.\n  // As a workaround, use cWM and cWRP to invoke the new static lifecycle.\n  // Newer versions of React will ignore these lifecycles if gDSFP exists.\n  if (typeof Component.getDerivedStateFromProps === 'function') {\n    prototype.componentWillMount = componentWillMount;\n    prototype.componentWillReceiveProps = componentWillReceiveProps;\n  }\n\n  // React <= 16.2 does not support getSnapshotBeforeUpdate.\n  // As a workaround, use cWU to invoke the new lifecycle.\n  // Newer versions of React will ignore that lifecycle if gSBU exists.\n  if (typeof prototype.getSnapshotBeforeUpdate === 'function') {\n    if (typeof prototype.componentDidUpdate !== 'function') {\n      throw new Error(\n        'Cannot polyfill getSnapshotBeforeUpdate() for components that do not define componentDidUpdate() on the prototype'\n      );\n    }\n\n    prototype.componentWillUpdate = componentWillUpdate;\n\n    var componentDidUpdate = prototype.componentDidUpdate;\n\n    prototype.componentDidUpdate = function componentDidUpdatePolyfill(\n      prevProps,\n      prevState,\n      maybeSnapshot\n    ) {\n      // 16.3+ will not execute our will-update method;\n      // It will pass a snapshot value to did-update though.\n      // Older versions will require our polyfilled will-update value.\n      // We need to handle both cases, but can't just check for the presence of \"maybeSnapshot\",\n      // Because for <= 15.x versions this might be a \"prevContext\" object.\n      // We also can't just check \"__reactInternalSnapshot\",\n      // Because get-snapshot might return a falsy value.\n      // So check for the explicit __reactInternalSnapshotFlag flag to determine behavior.\n      var snapshot = this.__reactInternalSnapshotFlag\n        ? this.__reactInternalSnapshot\n        : maybeSnapshot;\n\n      componentDidUpdate.call(this, prevProps, prevState, snapshot);\n    };\n  }\n\n  return Component;\n}\n\nexport { polyfill };\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/react-lifecycles-compat/react-lifecycles-compat.es.js\n// module id = 18\n// module chunks = 0 1","\"use strict\";\n\nexports.__esModule = true;\nexports.classNamesShape = exports.timeoutsShape = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nvar timeoutsShape = process.env.NODE_ENV !== 'production' ? _propTypes.default.oneOfType([_propTypes.default.number, _propTypes.default.shape({\n  enter: _propTypes.default.number,\n  exit: _propTypes.default.number\n}).isRequired]) : null;\nexports.timeoutsShape = timeoutsShape;\nvar classNamesShape = process.env.NODE_ENV !== 'production' ? _propTypes.default.oneOfType([_propTypes.default.string, _propTypes.default.shape({\n  enter: _propTypes.default.string,\n  exit: _propTypes.default.string,\n  active: _propTypes.default.string\n}), _propTypes.default.shape({\n  enter: _propTypes.default.string,\n  enterDone: _propTypes.default.string,\n  enterActive: _propTypes.default.string,\n  exit: _propTypes.default.string,\n  exitDone: _propTypes.default.string,\n  exitActive: _propTypes.default.string\n})]) : null;\nexports.classNamesShape = classNamesShape;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/react-transition-group/utils/PropTypes.js\n// module id = 19\n// module chunks = 0 1","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _reactLifecyclesCompat = require(\"react-lifecycles-compat\");\n\nvar _ChildMapping = require(\"./utils/ChildMapping\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _extends() { _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; }; return _extends.apply(this, arguments); }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nvar values = Object.values || function (obj) {\n  return Object.keys(obj).map(function (k) {\n    return obj[k];\n  });\n};\n\nvar defaultProps = {\n  component: 'div',\n  childFactory: function childFactory(child) {\n    return child;\n  }\n  /**\n   * The `<TransitionGroup>` component manages a set of transition components\n   * (`<Transition>` and `<CSSTransition>`) in a list. Like with the transition\n   * components, `<TransitionGroup>` is a state machine for managing the mounting\n   * and unmounting of components over time.\n   *\n   * Consider the example below. As items are removed or added to the TodoList the\n   * `in` prop is toggled automatically by the `<TransitionGroup>`.\n   *\n   * Note that `<TransitionGroup>`  does not define any animation behavior!\n   * Exactly _how_ a list item animates is up to the individual transition\n   * component. This means you can mix and match animations across different list\n   * items.\n   */\n\n};\n\nvar TransitionGroup =\n/*#__PURE__*/\nfunction (_React$Component) {\n  _inheritsLoose(TransitionGroup, _React$Component);\n\n  function TransitionGroup(props, context) {\n    var _this;\n\n    _this = _React$Component.call(this, props, context) || this;\n\n    var handleExited = _this.handleExited.bind(_assertThisInitialized(_assertThisInitialized(_this))); // Initial children should all be entering, dependent on appear\n\n\n    _this.state = {\n      handleExited: handleExited,\n      firstRender: true\n    };\n    return _this;\n  }\n\n  var _proto = TransitionGroup.prototype;\n\n  _proto.getChildContext = function getChildContext() {\n    return {\n      transitionGroup: {\n        isMounting: !this.appeared\n      }\n    };\n  };\n\n  _proto.componentDidMount = function componentDidMount() {\n    this.appeared = true;\n    this.mounted = true;\n  };\n\n  _proto.componentWillUnmount = function componentWillUnmount() {\n    this.mounted = false;\n  };\n\n  TransitionGroup.getDerivedStateFromProps = function getDerivedStateFromProps(nextProps, _ref) {\n    var prevChildMapping = _ref.children,\n        handleExited = _ref.handleExited,\n        firstRender = _ref.firstRender;\n    return {\n      children: firstRender ? (0, _ChildMapping.getInitialChildMapping)(nextProps, handleExited) : (0, _ChildMapping.getNextChildMapping)(nextProps, prevChildMapping, handleExited),\n      firstRender: false\n    };\n  };\n\n  _proto.handleExited = function handleExited(child, node) {\n    var currentChildMapping = (0, _ChildMapping.getChildMapping)(this.props.children);\n    if (child.key in currentChildMapping) return;\n\n    if (child.props.onExited) {\n      child.props.onExited(node);\n    }\n\n    if (this.mounted) {\n      this.setState(function (state) {\n        var children = _extends({}, state.children);\n\n        delete children[child.key];\n        return {\n          children: children\n        };\n      });\n    }\n  };\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        Component = _this$props.component,\n        childFactory = _this$props.childFactory,\n        props = _objectWithoutPropertiesLoose(_this$props, [\"component\", \"childFactory\"]);\n\n    var children = values(this.state.children).map(childFactory);\n    delete props.appear;\n    delete props.enter;\n    delete props.exit;\n\n    if (Component === null) {\n      return children;\n    }\n\n    return _react.default.createElement(Component, props, children);\n  };\n\n  return TransitionGroup;\n}(_react.default.Component);\n\nTransitionGroup.childContextTypes = {\n  transitionGroup: _propTypes.default.object.isRequired\n};\nTransitionGroup.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  /**\n   * `<TransitionGroup>` renders a `<div>` by default. You can change this\n   * behavior by providing a `component` prop.\n   * If you use React v16+ and would like to avoid a wrapping `<div>` element\n   * you can pass in `component={null}`. This is useful if the wrapping div\n   * borks your css styles.\n   */\n  component: _propTypes.default.any,\n\n  /**\n   * A set of `<Transition>` components, that are toggled `in` and out as they\n   * leave. the `<TransitionGroup>` will inject specific transition props, so\n   * remember to spread them through if you are wrapping the `<Transition>` as\n   * with our `<Fade>` example.\n   */\n  children: _propTypes.default.node,\n\n  /**\n   * A convenience prop that enables or disables appear animations\n   * for all children. Note that specifying this will override any defaults set\n   * on individual children Transitions.\n   */\n  appear: _propTypes.default.bool,\n\n  /**\n   * A convenience prop that enables or disables enter animations\n   * for all children. Note that specifying this will override any defaults set\n   * on individual children Transitions.\n   */\n  enter: _propTypes.default.bool,\n\n  /**\n   * A convenience prop that enables or disables exit animations\n   * for all children. Note that specifying this will override any defaults set\n   * on individual children Transitions.\n   */\n  exit: _propTypes.default.bool,\n\n  /**\n   * You may need to apply reactive updates to a child as it is exiting.\n   * This is generally done by using `cloneElement` however in the case of an exiting\n   * child the element has already been removed and not accessible to the consumer.\n   *\n   * If you do need to update a child as it leaves you can provide a `childFactory`\n   * to wrap every child, even the ones that are leaving.\n   *\n   * @type Function(child: ReactElement) -> ReactElement\n   */\n  childFactory: _propTypes.default.func\n} : {};\nTransitionGroup.defaultProps = defaultProps;\n\nvar _default = (0, _reactLifecyclesCompat.polyfill)(TransitionGroup);\n\nexports.default = _default;\nmodule.exports = exports[\"default\"];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/react-transition-group/TransitionGroup.js\n// module id = 20\n// module chunks = 0 1","// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nfunction EventEmitter() {\n  this._events = this._events || {};\n  this._maxListeners = this._maxListeners || undefined;\n}\nmodule.exports = EventEmitter;\n\n// Backwards-compat with node 0.10.x\nEventEmitter.EventEmitter = EventEmitter;\n\nEventEmitter.prototype._events = undefined;\nEventEmitter.prototype._maxListeners = undefined;\n\n// By default EventEmitters will print a warning if more than 10 listeners are\n// added to it. This is a useful default which helps finding memory leaks.\nEventEmitter.defaultMaxListeners = 10;\n\n// Obviously not all Emitters should be limited to 10. This function allows\n// that to be increased. Set to zero for unlimited.\nEventEmitter.prototype.setMaxListeners = function(n) {\n  if (!isNumber(n) || n < 0 || isNaN(n))\n    throw TypeError('n must be a positive number');\n  this._maxListeners = n;\n  return this;\n};\n\nEventEmitter.prototype.emit = function(type) {\n  var er, handler, len, args, i, listeners;\n\n  if (!this._events)\n    this._events = {};\n\n  // If there is no 'error' event listener then throw.\n  if (type === 'error') {\n    if (!this._events.error ||\n        (isObject(this._events.error) && !this._events.error.length)) {\n      er = arguments[1];\n      if (er instanceof Error) {\n        throw er; // Unhandled 'error' event\n      } else {\n        // At least give some kind of context to the user\n        var err = new Error('Uncaught, unspecified \"error\" event. (' + er + ')');\n        err.context = er;\n        throw err;\n      }\n    }\n  }\n\n  handler = this._events[type];\n\n  if (isUndefined(handler))\n    return false;\n\n  if (isFunction(handler)) {\n    switch (arguments.length) {\n      // fast cases\n      case 1:\n        handler.call(this);\n        break;\n      case 2:\n        handler.call(this, arguments[1]);\n        break;\n      case 3:\n        handler.call(this, arguments[1], arguments[2]);\n        break;\n      // slower\n      default:\n        args = Array.prototype.slice.call(arguments, 1);\n        handler.apply(this, args);\n    }\n  } else if (isObject(handler)) {\n    args = Array.prototype.slice.call(arguments, 1);\n    listeners = handler.slice();\n    len = listeners.length;\n    for (i = 0; i < len; i++)\n      listeners[i].apply(this, args);\n  }\n\n  return true;\n};\n\nEventEmitter.prototype.addListener = function(type, listener) {\n  var m;\n\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  if (!this._events)\n    this._events = {};\n\n  // To avoid recursion in the case that type === \"newListener\"! Before\n  // adding it to the listeners, first emit \"newListener\".\n  if (this._events.newListener)\n    this.emit('newListener', type,\n              isFunction(listener.listener) ?\n              listener.listener : listener);\n\n  if (!this._events[type])\n    // Optimize the case of one listener. Don't need the extra array object.\n    this._events[type] = listener;\n  else if (isObject(this._events[type]))\n    // If we've already got an array, just append.\n    this._events[type].push(listener);\n  else\n    // Adding the second element, need to change to array.\n    this._events[type] = [this._events[type], listener];\n\n  // Check for listener leak\n  if (isObject(this._events[type]) && !this._events[type].warned) {\n    if (!isUndefined(this._maxListeners)) {\n      m = this._maxListeners;\n    } else {\n      m = EventEmitter.defaultMaxListeners;\n    }\n\n    if (m && m > 0 && this._events[type].length > m) {\n      this._events[type].warned = true;\n      console.error('(node) warning: possible EventEmitter memory ' +\n                    'leak detected. %d listeners added. ' +\n                    'Use emitter.setMaxListeners() to increase limit.',\n                    this._events[type].length);\n      if (typeof console.trace === 'function') {\n        // not supported in IE 10\n        console.trace();\n      }\n    }\n  }\n\n  return this;\n};\n\nEventEmitter.prototype.on = EventEmitter.prototype.addListener;\n\nEventEmitter.prototype.once = function(type, listener) {\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  var fired = false;\n\n  function g() {\n    this.removeListener(type, g);\n\n    if (!fired) {\n      fired = true;\n      listener.apply(this, arguments);\n    }\n  }\n\n  g.listener = listener;\n  this.on(type, g);\n\n  return this;\n};\n\n// emits a 'removeListener' event iff the listener was removed\nEventEmitter.prototype.removeListener = function(type, listener) {\n  var list, position, length, i;\n\n  if (!isFunction(listener))\n    throw TypeError('listener must be a function');\n\n  if (!this._events || !this._events[type])\n    return this;\n\n  list = this._events[type];\n  length = list.length;\n  position = -1;\n\n  if (list === listener ||\n      (isFunction(list.listener) && list.listener === listener)) {\n    delete this._events[type];\n    if (this._events.removeListener)\n      this.emit('removeListener', type, listener);\n\n  } else if (isObject(list)) {\n    for (i = length; i-- > 0;) {\n      if (list[i] === listener ||\n          (list[i].listener && list[i].listener === listener)) {\n        position = i;\n        break;\n      }\n    }\n\n    if (position < 0)\n      return this;\n\n    if (list.length === 1) {\n      list.length = 0;\n      delete this._events[type];\n    } else {\n      list.splice(position, 1);\n    }\n\n    if (this._events.removeListener)\n      this.emit('removeListener', type, listener);\n  }\n\n  return this;\n};\n\nEventEmitter.prototype.removeAllListeners = function(type) {\n  var key, listeners;\n\n  if (!this._events)\n    return this;\n\n  // not listening for removeListener, no need to emit\n  if (!this._events.removeListener) {\n    if (arguments.length === 0)\n      this._events = {};\n    else if (this._events[type])\n      delete this._events[type];\n    return this;\n  }\n\n  // emit removeListener for all listeners on all events\n  if (arguments.length === 0) {\n    for (key in this._events) {\n      if (key === 'removeListener') continue;\n      this.removeAllListeners(key);\n    }\n    this.removeAllListeners('removeListener');\n    this._events = {};\n    return this;\n  }\n\n  listeners = this._events[type];\n\n  if (isFunction(listeners)) {\n    this.removeListener(type, listeners);\n  } else if (listeners) {\n    // LIFO order\n    while (listeners.length)\n      this.removeListener(type, listeners[listeners.length - 1]);\n  }\n  delete this._events[type];\n\n  return this;\n};\n\nEventEmitter.prototype.listeners = function(type) {\n  var ret;\n  if (!this._events || !this._events[type])\n    ret = [];\n  else if (isFunction(this._events[type]))\n    ret = [this._events[type]];\n  else\n    ret = this._events[type].slice();\n  return ret;\n};\n\nEventEmitter.prototype.listenerCount = function(type) {\n  if (this._events) {\n    var evlistener = this._events[type];\n\n    if (isFunction(evlistener))\n      return 1;\n    else if (evlistener)\n      return evlistener.length;\n  }\n  return 0;\n};\n\nEventEmitter.listenerCount = function(emitter, type) {\n  return emitter.listenerCount(type);\n};\n\nfunction isFunction(arg) {\n  return typeof arg === 'function';\n}\n\nfunction isNumber(arg) {\n  return typeof arg === 'number';\n}\n\nfunction isObject(arg) {\n  return typeof arg === 'object' && arg !== null;\n}\n\nfunction isUndefined(arg) {\n  return arg === void 0;\n}\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./node_modules/events/events.js\n// module id = 21\n// module chunks = 0 1","import BootstrapTable from './src/bootstrap-table';\nimport withContext from './src/contexts';\n\nexport default withContext(BootstrapTable);\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/index.js","/* eslint camelcase: 0 */\n/* eslint arrow-body-style: 0 */\n\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport cs from 'classnames';\n\nimport Header from './header';\nimport Filters from './filters';\nimport Caption from './caption';\nimport Body from './body';\nimport Footer from './footer';\nimport PropsBaseResolver from './props-resolver';\nimport Const from './const';\nimport _ from './utils';\n\nclass BootstrapTable extends PropsBaseResolver(Component) {\n  constructor(props) {\n    super(props);\n    this.validateProps();\n  }\n\n  UNSAFE_componentWillReceiveProps(nextProps) {\n    if (nextProps.onDataSizeChange && !nextProps.pagination) {\n      if (nextProps.data.length !== this.props.data.length) {\n        nextProps.onDataSizeChange({ dataSize: nextProps.data.length });\n      }\n    }\n  }\n\n  // Exposed APIs\n  getData = () => {\n    return this.visibleRows();\n  }\n\n  render() {\n    const { loading, overlay } = this.props;\n    if (overlay) {\n      const LoadingOverlay = overlay(loading);\n      return (\n        <LoadingOverlay>\n          { this.renderTable() }\n        </LoadingOverlay>\n      );\n    }\n    return this.renderTable();\n  }\n\n  renderTable() {\n    const {\n      columns,\n      keyField,\n      tabIndexCell,\n      id,\n      classes,\n      bootstrap4,\n      striped,\n      hover,\n      bordered,\n      condensed,\n      noDataIndication,\n      caption,\n      rowStyle,\n      rowClasses,\n      wrapperClasses,\n      rowEvents,\n      selectRow,\n      expandRow,\n      cellEdit,\n      filterPosition\n    } = this.props;\n\n    const tableWrapperClass = cs('react-bootstrap-table', wrapperClasses);\n\n    const tableClass = cs('table', {\n      'table-striped': striped,\n      'table-hover': hover,\n      'table-bordered': bordered,\n      [bootstrap4 ? 'table-sm' : 'table-condensed']: condensed\n    }, classes);\n\n    const hasFilters = columns.some(col => col.filter || col.filterRenderer);\n\n    const hasFooter = _.filter(columns, col => _.has(col, 'footer')).length > 0;\n\n    const tableCaption = (\n      caption && <Caption bootstrap4={ bootstrap4 }>{ caption }</Caption>\n    );\n\n    return (\n      <div className={ tableWrapperClass }>\n        <table id={ id } className={ tableClass }>\n          { tableCaption }\n          <Header\n            columns={ columns }\n            className={ this.props.headerClasses }\n            wrapperClasses={ this.props.headerWrapperClasses }\n            sortField={ this.props.sortField }\n            sortOrder={ this.props.sortOrder }\n            onSort={ this.props.onSort }\n            globalSortCaret={ this.props.sort && this.props.sort.sortCaret }\n            onFilter={ this.props.onFilter }\n            currFilters={ this.props.currFilters }\n            onExternalFilter={ this.props.onExternalFilter }\n            selectRow={ selectRow }\n            expandRow={ expandRow }\n            filterPosition={ filterPosition }\n          />\n          {hasFilters && filterPosition !== Const.FILTERS_POSITION_INLINE && (\n            <Filters\n              columns={ columns }\n              className={ this.props.filtersClasses }\n              onSort={ this.props.onSort }\n              onFilter={ this.props.onFilter }\n              currFilters={ this.props.currFilters }\n              filterPosition={ this.props.filterPosition }\n              onExternalFilter={ this.props.onExternalFilter }\n              selectRow={ selectRow }\n              expandRow={ expandRow }\n            />\n          )}\n          <Body\n            className={ this.props.bodyClasses }\n            data={ this.getData() }\n            keyField={ keyField }\n            tabIndexCell={ tabIndexCell }\n            columns={ columns }\n            isEmpty={ this.isEmpty() }\n            visibleColumnSize={ this.visibleColumnSize() }\n            noDataIndication={ noDataIndication }\n            cellEdit={ cellEdit }\n            selectRow={ selectRow }\n            expandRow={ expandRow }\n            rowStyle={ rowStyle }\n            rowClasses={ rowClasses }\n            rowEvents={ rowEvents }\n          />\n          {hasFooter && (\n            <Footer\n              data={ this.getData() }\n              columns={ columns }\n              selectRow={ selectRow }\n              expandRow={ expandRow }\n              className={ this.props.footerClasses }\n            />\n          )}\n        </table>\n      </div>\n    );\n  }\n}\n\nBootstrapTable.propTypes = {\n  keyField: PropTypes.string.isRequired,\n  data: PropTypes.array.isRequired,\n  columns: PropTypes.array.isRequired,\n  bootstrap4: PropTypes.bool,\n  remote: PropTypes.oneOfType([PropTypes.bool, PropTypes.shape({\n    pagination: PropTypes.bool\n  })]),\n  noDataIndication: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),\n  striped: PropTypes.bool,\n  bordered: PropTypes.bool,\n  hover: PropTypes.bool,\n  tabIndexCell: PropTypes.bool,\n  id: PropTypes.string,\n  classes: PropTypes.string,\n  headerClasses: PropTypes.string,\n  bodyClasses: PropTypes.string,\n  wrapperClasses: PropTypes.string,\n  headerWrapperClasses: PropTypes.string,\n  condensed: PropTypes.bool,\n  caption: PropTypes.oneOfType([\n    PropTypes.node,\n    PropTypes.string\n  ]),\n  pagination: PropTypes.object,\n  filter: PropTypes.object,\n  cellEdit: PropTypes.object,\n  selectRow: PropTypes.shape({\n    mode: PropTypes.oneOf([\n      Const.ROW_SELECT_SINGLE,\n      Const.ROW_SELECT_MULTIPLE,\n      Const.ROW_SELECT_DISABLED\n    ]).isRequired,\n    clickToSelect: PropTypes.bool,\n    clickToExpand: PropTypes.bool,\n    clickToEdit: PropTypes.bool,\n    hideSelectAll: PropTypes.bool,\n    onSelect: PropTypes.func,\n    onSelectAll: PropTypes.func,\n    style: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    classes: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    nonSelectable: PropTypes.array,\n    nonSelectableStyle: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    nonSelectableClasses: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    bgColor: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    hideSelectColumn: PropTypes.bool,\n    selectionRenderer: PropTypes.func,\n    selectionHeaderRenderer: PropTypes.func,\n    headerColumnStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    selectColumnStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    selectColumnPosition: PropTypes.oneOf([\n      Const.INDICATOR_POSITION_LEFT,\n      Const.INDICATOR_POSITION_RIGHT\n    ])\n  }),\n  expandRow: PropTypes.shape({\n    renderer: PropTypes.func,\n    expanded: PropTypes.array,\n    onExpand: PropTypes.func,\n    onExpandAll: PropTypes.func,\n    nonExpandable: PropTypes.array,\n    showExpandColumn: PropTypes.bool,\n    onlyOneExpanding: PropTypes.bool,\n    expandByColumnOnly: PropTypes.bool,\n    expandColumnRenderer: PropTypes.func,\n    expandHeaderColumnRenderer: PropTypes.func,\n    expandColumnPosition: PropTypes.oneOf([\n      Const.INDICATOR_POSITION_LEFT,\n      Const.INDICATOR_POSITION_RIGHT\n    ]),\n    className: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    parentClassName: PropTypes.oneOfType([PropTypes.string, PropTypes.func])\n  }),\n  rowStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n  rowEvents: PropTypes.object,\n  rowClasses: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n  filtersClasses: PropTypes.string,\n  filterPosition: PropTypes.oneOf([\n    Const.FILTERS_POSITION_TOP,\n    Const.FILTERS_POSITION_INLINE,\n    Const.FILTERS_POSITION_BOTTOM\n  ]),\n  footerClasses: PropTypes.string,\n  defaultSorted: PropTypes.arrayOf(PropTypes.shape({\n    dataField: PropTypes.string.isRequired,\n    order: PropTypes.oneOf([Const.SORT_DESC, Const.SORT_ASC]).isRequired\n  })),\n  sort: PropTypes.shape({\n    dataField: PropTypes.string,\n    order: PropTypes.oneOf([Const.SORT_DESC, Const.SORT_ASC]),\n    sortFunc: PropTypes.func,\n    sortCaret: PropTypes.func\n  }),\n  defaultSortDirection: PropTypes.oneOf([Const.SORT_DESC, Const.SORT_ASC]),\n  overlay: PropTypes.func,\n  onTableChange: PropTypes.func,\n  onSort: PropTypes.func,\n  onFilter: PropTypes.func,\n  onExternalFilter: PropTypes.func,\n  onDataSizeChange: PropTypes.func,\n  // Inject from toolkit\n  search: PropTypes.shape({\n    searchText: PropTypes.string,\n    searchContext: PropTypes.func\n  }),\n  setDependencyModules: PropTypes.func\n};\n\nBootstrapTable.defaultProps = {\n  bootstrap4: false,\n  remote: false,\n  striped: false,\n  bordered: true,\n  hover: false,\n  condensed: false,\n  noDataIndication: null,\n  selectRow: {\n    mode: Const.ROW_SELECT_DISABLED,\n    selected: [],\n    hideSelectColumn: true\n  },\n  expandRow: {\n    renderer: undefined,\n    expanded: [],\n    nonExpandable: []\n  },\n  cellEdit: {\n    mode: null,\n    nonEditableRows: []\n  },\n  filterPosition: Const.FILTERS_POSITION_INLINE\n};\n\nexport default BootstrapTable;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/bootstrap-table.js","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = require('./lib/ReactPropTypesSecret');\n\nfunction emptyFunction() {}\nfunction emptyFunctionWithReset() {}\nemptyFunctionWithReset.resetWarningCache = emptyFunction;\n\nmodule.exports = function() {\n  function shim(props, propName, componentName, location, propFullName, secret) {\n    if (secret === ReactPropTypesSecret) {\n      // It is still safe when called from React.\n      return;\n    }\n    var err = new Error(\n      'Calling PropTypes validators directly is not supported by the `prop-types` package. ' +\n      'Use PropTypes.checkPropTypes() to call them. ' +\n      'Read more at http://fb.me/use-check-prop-types'\n    );\n    err.name = 'Invariant Violation';\n    throw err;\n  };\n  shim.isRequired = shim;\n  function getShim() {\n    return shim;\n  };\n  // Important!\n  // Keep this list in sync with production version in `./factoryWithTypeCheckers.js`.\n  var ReactPropTypes = {\n    array: shim,\n    bool: shim,\n    func: shim,\n    number: shim,\n    object: shim,\n    string: shim,\n    symbol: shim,\n\n    any: shim,\n    arrayOf: getShim,\n    element: shim,\n    elementType: shim,\n    instanceOf: getShim,\n    node: shim,\n    objectOf: getShim,\n    oneOf: getShim,\n    oneOfType: getShim,\n    shape: getShim,\n    exact: getShim,\n\n    checkPropTypes: emptyFunctionWithReset,\n    resetWarningCache: emptyFunction\n  };\n\n  ReactPropTypes.PropTypes = ReactPropTypes;\n\n  return ReactPropTypes;\n};\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/prop-types/factoryWithThrowingShims.js\n// module id = 24\n// module chunks = 0 1","/**\n * Copyright (c) 2013-present, Facebook, Inc.\n *\n * This source code is licensed under the MIT license found in the\n * LICENSE file in the root directory of this source tree.\n */\n\n'use strict';\n\nvar ReactPropTypesSecret = 'SECRET_DO_NOT_PASS_THIS_OR_YOU_WILL_BE_FIRED';\n\nmodule.exports = ReactPropTypesSecret;\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/prop-types/lib/ReactPropTypesSecret.js\n// module id = 25\n// module chunks = 0 1","/* eslint react/require-default-props: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nimport HeaderCell from './header-cell';\nimport SelectionHeaderCell from './row-selection/selection-header-cell';\nimport ExpandHeaderCell from './row-expand/expand-header-cell';\nimport withHeaderSelection from './row-selection/selection-header-cell-consumer';\nimport withHeaderExpansion from './row-expand/expand-header-cell-consumer';\nimport Const from './const';\n\nconst Header = (props) => {\n  const {\n    className,\n    columns,\n    onSort,\n    onFilter,\n    sortField,\n    sortOrder,\n    selectRow,\n    expandRow,\n    currFilters,\n    onExternalFilter,\n    filterPosition,\n    globalSortCaret,\n    wrapperClasses\n  } = props;\n\n  let SelectionHeaderCellComp = () => null;\n  let ExpansionHeaderCellComp = () => null;\n\n  if (expandRow.showExpandColumn) {\n    ExpansionHeaderCellComp = withHeaderExpansion(ExpandHeaderCell);\n  }\n\n  if (selectRow) {\n    SelectionHeaderCellComp = withHeaderSelection(SelectionHeaderCell);\n  }\n\n  const isRenderFunctionColumnInLeft = (\n    position = Const.INDICATOR_POSITION_LEFT\n  ) => position === Const.INDICATOR_POSITION_LEFT;\n\n  const childrens = [\n    columns.map((column, i) => {\n      const currSort = column.dataField === sortField;\n      const isLastSorting = column.dataField === sortField;\n\n      return (\n        <HeaderCell\n          index={ i }\n          key={ column.dataField }\n          column={ column }\n          onSort={ onSort }\n          sorting={ currSort }\n          sortOrder={ sortOrder }\n          globalSortCaret={ globalSortCaret }\n          isLastSorting={ isLastSorting }\n          onFilter={ onFilter }\n          currFilters={ currFilters }\n          onExternalFilter={ onExternalFilter }\n          filterPosition={ filterPosition }\n        />);\n    })\n  ];\n\n  if (!selectRow.hideSelectColumn) {\n    if (isRenderFunctionColumnInLeft(selectRow.selectColumnPosition)) {\n      childrens.unshift(<SelectionHeaderCellComp key=\"selection\" />);\n    } else {\n      childrens.push(<SelectionHeaderCellComp key=\"selection\" />);\n    }\n  }\n\n  if (expandRow.showExpandColumn) {\n    if (isRenderFunctionColumnInLeft(expandRow.expandColumnPosition)) {\n      childrens.unshift(<ExpansionHeaderCellComp key=\"expansion\" />);\n    } else {\n      childrens.push(<ExpansionHeaderCellComp key=\"expansion\" />);\n    }\n  }\n\n  return (\n    <thead className={ wrapperClasses }>\n      <tr className={ className }>\n        { childrens }\n      </tr>\n    </thead>\n  );\n};\n\nHeader.propTypes = {\n  columns: PropTypes.array.isRequired,\n  onSort: PropTypes.func,\n  onFilter: PropTypes.func,\n  sortField: PropTypes.string,\n  sortOrder: PropTypes.string,\n  selectRow: PropTypes.object,\n  currFilters: PropTypes.object,\n  onExternalFilter: PropTypes.func,\n  globalSortCaret: PropTypes.func,\n  className: PropTypes.string,\n  wrapperClasses: PropTypes.string,\n  expandRow: PropTypes.object,\n  filterPosition: PropTypes.oneOf([\n    Const.FILTERS_POSITION_TOP,\n    Const.FILTERS_POSITION_INLINE,\n    Const.FILTERS_POSITION_BOTTOM\n  ])\n};\n\nexport default Header;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/header.js","/* eslint react/require-default-props: 0 */\nimport React from 'react';\nimport cs from 'classnames';\nimport PropTypes from 'prop-types';\n\nimport Const from './const';\nimport SortSymbol from './sort/symbol';\nimport SortCaret from './sort/caret';\nimport _ from './utils';\nimport eventDelegater from './cell-event-delegater';\n\n\nclass HeaderCell extends eventDelegater(React.Component) {\n  render() {\n    const {\n      column,\n      index,\n      onSort,\n      sorting,\n      sortOrder,\n      isLastSorting,\n      onFilter,\n      currFilters,\n      filterPosition,\n      onExternalFilter,\n      globalSortCaret\n    } = this.props;\n\n    const {\n      text,\n      sort,\n      sortCaret,\n      filter,\n      filterRenderer,\n      headerTitle,\n      headerAlign,\n      headerFormatter,\n      headerEvents,\n      headerClasses,\n      headerStyle,\n      headerAttrs,\n      headerSortingClasses,\n      headerSortingStyle\n    } = column;\n\n    const sortCaretfunc = sortCaret || globalSortCaret;\n\n    const delegateEvents = this.delegate(headerEvents);\n\n    const customAttrs = _.isFunction(headerAttrs)\n      ? headerAttrs(column, index)\n      : (headerAttrs || {});\n\n    const cellAttrs = {\n      ...customAttrs,\n      ...delegateEvents,\n      tabIndex: _.isDefined(customAttrs.tabIndex) ? customAttrs.tabIndex : 0\n    };\n\n    let sortSymbol;\n    let filterElm;\n    let cellStyle = {};\n    let cellClasses = _.isFunction(headerClasses) ? headerClasses(column, index) : headerClasses;\n\n    if (headerStyle) {\n      cellStyle = _.isFunction(headerStyle) ? headerStyle(column, index) : headerStyle;\n      cellStyle = cellStyle ? { ...cellStyle } : cellStyle;\n    }\n\n    if (headerTitle) {\n      cellAttrs.title = _.isFunction(headerTitle) ? headerTitle(column, index) : text;\n    }\n\n    if (headerAlign) {\n      cellStyle.textAlign = _.isFunction(headerAlign) ? headerAlign(column, index) : headerAlign;\n    }\n\n    if (sort) {\n      const customClick = cellAttrs.onClick;\n      cellAttrs['aria-label'] = sorting ? `${text} sort ${sortOrder}` : `${text} sortable`;\n      cellAttrs.onKeyUp = (e) => {\n        if (e.key === 'Enter') {\n          onSort(column);\n          if (_.isFunction(customClick)) customClick(e);\n        }\n      };\n      cellAttrs.onClick = (e) => {\n        onSort(column);\n        if (_.isFunction(customClick)) customClick(e);\n      };\n      cellAttrs.className = cs(cellAttrs.className, 'sortable');\n\n      if (sorting) {\n        sortSymbol = sortCaretfunc ?\n          sortCaretfunc(sortOrder, column) :\n          <SortCaret order={ sortOrder } />;\n\n        // append customized classes or style if table was sorting based on the current column.\n        cellClasses = cs(\n          cellClasses,\n          _.isFunction(headerSortingClasses)\n            ? headerSortingClasses(column, sortOrder, isLastSorting, index)\n            : headerSortingClasses\n        );\n\n        cellStyle = {\n          ...cellStyle,\n          ..._.isFunction(headerSortingStyle)\n            ? headerSortingStyle(column, sortOrder, isLastSorting, index)\n            : headerSortingStyle\n        };\n      } else {\n        sortSymbol = sortCaretfunc ? sortCaretfunc(undefined, column) : <SortSymbol />;\n      }\n    }\n\n    if (cellClasses) cellAttrs.className = cs(cellAttrs.className, cellClasses);\n    if (!_.isEmptyObject(cellStyle)) cellAttrs.style = cellStyle;\n\n    if (filterPosition === Const.FILTERS_POSITION_INLINE) {\n      if (filterRenderer) {\n        const onCustomFilter = onExternalFilter(column, filter.props.type);\n        filterElm = filterRenderer(onCustomFilter, column);\n      } else if (filter) {\n        filterElm = (\n          <filter.Filter\n            { ...filter.props }\n            filterState={ currFilters[column.dataField] }\n            onFilter={ onFilter }\n            column={ column }\n          />\n        );\n      }\n    }\n\n    const children = headerFormatter ?\n      headerFormatter(column, index, { sortElement: sortSymbol, filterElement: filterElm }) :\n      text;\n\n    if (headerFormatter) {\n      return React.createElement('th', cellAttrs, children);\n    }\n\n    return React.createElement('th', cellAttrs, children, sortSymbol, filterElm);\n  }\n}\n\nHeaderCell.propTypes = {\n  column: PropTypes.shape({\n    dataField: PropTypes.string.isRequired,\n    text: PropTypes.string.isRequired,\n    type: PropTypes.oneOf([\n      Const.TYPE_STRING,\n      Const.TYPE_NUMBER,\n      Const.TYPE_BOOLEAN,\n      Const.TYPE_DATE\n    ]),\n    isDummyField: PropTypes.bool,\n    hidden: PropTypes.bool,\n    headerFormatter: PropTypes.func,\n    formatter: PropTypes.func,\n    formatExtraData: PropTypes.any,\n    headerClasses: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    classes: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    headerStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    style: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    headerTitle: PropTypes.oneOfType([PropTypes.bool, PropTypes.func]),\n    title: PropTypes.oneOfType([PropTypes.bool, PropTypes.func]),\n    headerEvents: PropTypes.object,\n    events: PropTypes.object,\n    headerAlign: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    align: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    headerAttrs: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    attrs: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    sort: PropTypes.bool,\n    sortFunc: PropTypes.func,\n    onSort: PropTypes.func,\n    editor: PropTypes.object,\n    editable: PropTypes.oneOfType([PropTypes.bool, PropTypes.func]),\n    editCellStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    editCellClasses: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    editorStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.func]),\n    editorClasses: PropTypes.oneOfType([PropTypes.string, PropTypes.func]),\n    editorRenderer: PropTypes.func,\n    validator: PropTypes.func,\n    filter: PropTypes.object,\n    filterRenderer: PropTypes.func,\n    filterValue: PropTypes.func,\n    searchable: PropTypes.bool\n  }).isRequired,\n  index: PropTypes.number.isRequired,\n  onSort: PropTypes.func,\n  sorting: PropTypes.bool,\n  sortOrder: PropTypes.oneOf([Const.SORT_ASC, Const.SORT_DESC]),\n  sortCaret: PropTypes.func,\n  isLastSorting: PropTypes.bool,\n  onFilter: PropTypes.func,\n  filterPosition: PropTypes.oneOf([Const.FILTERS_POSITION_INLINE,\n    Const.FILTERS_POSITION_BOTTOM, Const.FILTERS_POSITION_TOP]),\n  currFilters: PropTypes.object,\n  onExternalFilter: PropTypes.func\n};\n\nexport default HeaderCell;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/header-cell.js","import React from 'react';\nimport { BootstrapContext } from '../contexts/bootstrap';\n\nconst SortSymbol = () => (\n  <BootstrapContext.Consumer>\n    {\n      ({ bootstrap4 }) => (bootstrap4 ? (\n        <span className=\"order-4\" />\n      ) : (\n        <span className=\"order\">\n          <span className=\"dropdown\">\n            <span className=\"caret\" />\n          </span>\n          <span className=\"dropup\">\n            <span className=\"caret\" />\n          </span>\n        </span>\n      ))\n    }\n  </BootstrapContext.Consumer>\n);\n\nexport default SortSymbol;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/sort/symbol.js","import React from 'react';\nimport cs from 'classnames';\nimport PropTypes from 'prop-types';\n\nimport Const from '../const';\nimport { BootstrapContext } from '../contexts/bootstrap';\n\n\nconst SortCaret = ({ order }) => {\n  const orderClass = cs('react-bootstrap-table-sort-order', {\n    dropup: order === Const.SORT_ASC\n  });\n\n  return (\n    <BootstrapContext.Consumer>\n      {\n        ({ bootstrap4 }) => (bootstrap4 ? (\n          <span className={ `caret-4-${order}` } />\n        ) : (\n          <span className={ orderClass }>\n            <span className=\"caret\" />\n          </span>\n        ))\n      }\n    </BootstrapContext.Consumer>\n  );\n};\n\nSortCaret.propTypes = {\n  order: PropTypes.oneOf([Const.SORT_ASC, Const.SORT_DESC]).isRequired\n};\n\nexport default SortCaret;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/sort/caret.js","//     Underscore.js 1.9.1\n//     http://underscorejs.org\n//     (c) 2009-2018 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n//     Underscore may be freely distributed under the MIT license.\n\n(function() {\n\n  // Baseline setup\n  // --------------\n\n  // Establish the root object, `window` (`self`) in the browser, `global`\n  // on the server, or `this` in some virtual machines. We use `self`\n  // instead of `window` for `WebWorker` support.\n  var root = typeof self == 'object' && self.self === self && self ||\n            typeof global == 'object' && global.global === global && global ||\n            this ||\n            {};\n\n  // Save the previous value of the `_` variable.\n  var previousUnderscore = root._;\n\n  // Save bytes in the minified (but not gzipped) version:\n  var ArrayProto = Array.prototype, ObjProto = Object.prototype;\n  var SymbolProto = typeof Symbol !== 'undefined' ? Symbol.prototype : null;\n\n  // Create quick reference variables for speed access to core prototypes.\n  var push = ArrayProto.push,\n      slice = ArrayProto.slice,\n      toString = ObjProto.toString,\n      hasOwnProperty = ObjProto.hasOwnProperty;\n\n  // All **ECMAScript 5** native function implementations that we hope to use\n  // are declared here.\n  var nativeIsArray = Array.isArray,\n      nativeKeys = Object.keys,\n      nativeCreate = Object.create;\n\n  // Naked function reference for surrogate-prototype-swapping.\n  var Ctor = function(){};\n\n  // Create a safe reference to the Underscore object for use below.\n  var _ = function(obj) {\n    if (obj instanceof _) return obj;\n    if (!(this instanceof _)) return new _(obj);\n    this._wrapped = obj;\n  };\n\n  // Export the Underscore object for **Node.js**, with\n  // backwards-compatibility for their old module API. If we're in\n  // the browser, add `_` as a global object.\n  // (`nodeType` is checked to ensure that `module`\n  // and `exports` are not HTML elements.)\n  if (typeof exports != 'undefined' && !exports.nodeType) {\n    if (typeof module != 'undefined' && !module.nodeType && module.exports) {\n      exports = module.exports = _;\n    }\n    exports._ = _;\n  } else {\n    root._ = _;\n  }\n\n  // Current version.\n  _.VERSION = '1.9.1';\n\n  // Internal function that returns an efficient (for current engines) version\n  // of the passed-in callback, to be repeatedly applied in other Underscore\n  // functions.\n  var optimizeCb = function(func, context, argCount) {\n    if (context === void 0) return func;\n    switch (argCount == null ? 3 : argCount) {\n      case 1: return function(value) {\n        return func.call(context, value);\n      };\n      // The 2-argument case is omitted because we’re not using it.\n      case 3: return function(value, index, collection) {\n        return func.call(context, value, index, collection);\n      };\n      case 4: return function(accumulator, value, index, collection) {\n        return func.call(context, accumulator, value, index, collection);\n      };\n    }\n    return function() {\n      return func.apply(context, arguments);\n    };\n  };\n\n  var builtinIteratee;\n\n  // An internal function to generate callbacks that can be applied to each\n  // element in a collection, returning the desired result — either `identity`,\n  // an arbitrary callback, a property matcher, or a property accessor.\n  var cb = function(value, context, argCount) {\n    if (_.iteratee !== builtinIteratee) return _.iteratee(value, context);\n    if (value == null) return _.identity;\n    if (_.isFunction(value)) return optimizeCb(value, context, argCount);\n    if (_.isObject(value) && !_.isArray(value)) return _.matcher(value);\n    return _.property(value);\n  };\n\n  // External wrapper for our callback generator. Users may customize\n  // `_.iteratee` if they want additional predicate/iteratee shorthand styles.\n  // This abstraction hides the internal-only argCount argument.\n  _.iteratee = builtinIteratee = function(value, context) {\n    return cb(value, context, Infinity);\n  };\n\n  // Some functions take a variable number of arguments, or a few expected\n  // arguments at the beginning and then a variable number of values to operate\n  // on. This helper accumulates all remaining arguments past the function’s\n  // argument length (or an explicit `startIndex`), into an array that becomes\n  // the last argument. Similar to ES6’s \"rest parameter\".\n  var restArguments = function(func, startIndex) {\n    startIndex = startIndex == null ? func.length - 1 : +startIndex;\n    return function() {\n      var length = Math.max(arguments.length - startIndex, 0),\n          rest = Array(length),\n          index = 0;\n      for (; index < length; index++) {\n        rest[index] = arguments[index + startIndex];\n      }\n      switch (startIndex) {\n        case 0: return func.call(this, rest);\n        case 1: return func.call(this, arguments[0], rest);\n        case 2: return func.call(this, arguments[0], arguments[1], rest);\n      }\n      var args = Array(startIndex + 1);\n      for (index = 0; index < startIndex; index++) {\n        args[index] = arguments[index];\n      }\n      args[startIndex] = rest;\n      return func.apply(this, args);\n    };\n  };\n\n  // An internal function for creating a new object that inherits from another.\n  var baseCreate = function(prototype) {\n    if (!_.isObject(prototype)) return {};\n    if (nativeCreate) return nativeCreate(prototype);\n    Ctor.prototype = prototype;\n    var result = new Ctor;\n    Ctor.prototype = null;\n    return result;\n  };\n\n  var shallowProperty = function(key) {\n    return function(obj) {\n      return obj == null ? void 0 : obj[key];\n    };\n  };\n\n  var has = function(obj, path) {\n    return obj != null && hasOwnProperty.call(obj, path);\n  }\n\n  var deepGet = function(obj, path) {\n    var length = path.length;\n    for (var i = 0; i < length; i++) {\n      if (obj == null) return void 0;\n      obj = obj[path[i]];\n    }\n    return length ? obj : void 0;\n  };\n\n  // Helper for collection methods to determine whether a collection\n  // should be iterated as an array or as an object.\n  // Related: http://people.mozilla.org/~jorendorff/es6-draft.html#sec-tolength\n  // Avoids a very nasty iOS 8 JIT bug on ARM-64. #2094\n  var MAX_ARRAY_INDEX = Math.pow(2, 53) - 1;\n  var getLength = shallowProperty('length');\n  var isArrayLike = function(collection) {\n    var length = getLength(collection);\n    return typeof length == 'number' && length >= 0 && length <= MAX_ARRAY_INDEX;\n  };\n\n  // Collection Functions\n  // --------------------\n\n  // The cornerstone, an `each` implementation, aka `forEach`.\n  // Handles raw objects in addition to array-likes. Treats all\n  // sparse array-likes as if they were dense.\n  _.each = _.forEach = function(obj, iteratee, context) {\n    iteratee = optimizeCb(iteratee, context);\n    var i, length;\n    if (isArrayLike(obj)) {\n      for (i = 0, length = obj.length; i < length; i++) {\n        iteratee(obj[i], i, obj);\n      }\n    } else {\n      var keys = _.keys(obj);\n      for (i = 0, length = keys.length; i < length; i++) {\n        iteratee(obj[keys[i]], keys[i], obj);\n      }\n    }\n    return obj;\n  };\n\n  // Return the results of applying the iteratee to each element.\n  _.map = _.collect = function(obj, iteratee, context) {\n    iteratee = cb(iteratee, context);\n    var keys = !isArrayLike(obj) && _.keys(obj),\n        length = (keys || obj).length,\n        results = Array(length);\n    for (var index = 0; index < length; index++) {\n      var currentKey = keys ? keys[index] : index;\n      results[index] = iteratee(obj[currentKey], currentKey, obj);\n    }\n    return results;\n  };\n\n  // Create a reducing function iterating left or right.\n  var createReduce = function(dir) {\n    // Wrap code that reassigns argument variables in a separate function than\n    // the one that accesses `arguments.length` to avoid a perf hit. (#1991)\n    var reducer = function(obj, iteratee, memo, initial) {\n      var keys = !isArrayLike(obj) && _.keys(obj),\n          length = (keys || obj).length,\n          index = dir > 0 ? 0 : length - 1;\n      if (!initial) {\n        memo = obj[keys ? keys[index] : index];\n        index += dir;\n      }\n      for (; index >= 0 && index < length; index += dir) {\n        var currentKey = keys ? keys[index] : index;\n        memo = iteratee(memo, obj[currentKey], currentKey, obj);\n      }\n      return memo;\n    };\n\n    return function(obj, iteratee, memo, context) {\n      var initial = arguments.length >= 3;\n      return reducer(obj, optimizeCb(iteratee, context, 4), memo, initial);\n    };\n  };\n\n  // **Reduce** builds up a single result from a list of values, aka `inject`,\n  // or `foldl`.\n  _.reduce = _.foldl = _.inject = createReduce(1);\n\n  // The right-associative version of reduce, also known as `foldr`.\n  _.reduceRight = _.foldr = createReduce(-1);\n\n  // Return the first value which passes a truth test. Aliased as `detect`.\n  _.find = _.detect = function(obj, predicate, context) {\n    var keyFinder = isArrayLike(obj) ? _.findIndex : _.findKey;\n    var key = keyFinder(obj, predicate, context);\n    if (key !== void 0 && key !== -1) return obj[key];\n  };\n\n  // Return all the elements that pass a truth test.\n  // Aliased as `select`.\n  _.filter = _.select = function(obj, predicate, context) {\n    var results = [];\n    predicate = cb(predicate, context);\n    _.each(obj, function(value, index, list) {\n      if (predicate(value, index, list)) results.push(value);\n    });\n    return results;\n  };\n\n  // Return all the elements for which a truth test fails.\n  _.reject = function(obj, predicate, context) {\n    return _.filter(obj, _.negate(cb(predicate)), context);\n  };\n\n  // Determine whether all of the elements match a truth test.\n  // Aliased as `all`.\n  _.every = _.all = function(obj, predicate, context) {\n    predicate = cb(predicate, context);\n    var keys = !isArrayLike(obj) && _.keys(obj),\n        length = (keys || obj).length;\n    for (var index = 0; index < length; index++) {\n      var currentKey = keys ? keys[index] : index;\n      if (!predicate(obj[currentKey], currentKey, obj)) return false;\n    }\n    return true;\n  };\n\n  // Determine if at least one element in the object matches a truth test.\n  // Aliased as `any`.\n  _.some = _.any = function(obj, predicate, context) {\n    predicate = cb(predicate, context);\n    var keys = !isArrayLike(obj) && _.keys(obj),\n        length = (keys || obj).length;\n    for (var index = 0; index < length; index++) {\n      var currentKey = keys ? keys[index] : index;\n      if (predicate(obj[currentKey], currentKey, obj)) return true;\n    }\n    return false;\n  };\n\n  // Determine if the array or object contains a given item (using `===`).\n  // Aliased as `includes` and `include`.\n  _.contains = _.includes = _.include = function(obj, item, fromIndex, guard) {\n    if (!isArrayLike(obj)) obj = _.values(obj);\n    if (typeof fromIndex != 'number' || guard) fromIndex = 0;\n    return _.indexOf(obj, item, fromIndex) >= 0;\n  };\n\n  // Invoke a method (with arguments) on every item in a collection.\n  _.invoke = restArguments(function(obj, path, args) {\n    var contextPath, func;\n    if (_.isFunction(path)) {\n      func = path;\n    } else if (_.isArray(path)) {\n      contextPath = path.slice(0, -1);\n      path = path[path.length - 1];\n    }\n    return _.map(obj, function(context) {\n      var method = func;\n      if (!method) {\n        if (contextPath && contextPath.length) {\n          context = deepGet(context, contextPath);\n        }\n        if (context == null) return void 0;\n        method = context[path];\n      }\n      return method == null ? method : method.apply(context, args);\n    });\n  });\n\n  // Convenience version of a common use case of `map`: fetching a property.\n  _.pluck = function(obj, key) {\n    return _.map(obj, _.property(key));\n  };\n\n  // Convenience version of a common use case of `filter`: selecting only objects\n  // containing specific `key:value` pairs.\n  _.where = function(obj, attrs) {\n    return _.filter(obj, _.matcher(attrs));\n  };\n\n  // Convenience version of a common use case of `find`: getting the first object\n  // containing specific `key:value` pairs.\n  _.findWhere = function(obj, attrs) {\n    return _.find(obj, _.matcher(attrs));\n  };\n\n  // Return the maximum element (or element-based computation).\n  _.max = function(obj, iteratee, context) {\n    var result = -Infinity, lastComputed = -Infinity,\n        value, computed;\n    if (iteratee == null || typeof iteratee == 'number' && typeof obj[0] != 'object' && obj != null) {\n      obj = isArrayLike(obj) ? obj : _.values(obj);\n      for (var i = 0, length = obj.length; i < length; i++) {\n        value = obj[i];\n        if (value != null && value > result) {\n          result = value;\n        }\n      }\n    } else {\n      iteratee = cb(iteratee, context);\n      _.each(obj, function(v, index, list) {\n        computed = iteratee(v, index, list);\n        if (computed > lastComputed || computed === -Infinity && result === -Infinity) {\n          result = v;\n          lastComputed = computed;\n        }\n      });\n    }\n    return result;\n  };\n\n  // Return the minimum element (or element-based computation).\n  _.min = function(obj, iteratee, context) {\n    var result = Infinity, lastComputed = Infinity,\n        value, computed;\n    if (iteratee == null || typeof iteratee == 'number' && typeof obj[0] != 'object' && obj != null) {\n      obj = isArrayLike(obj) ? obj : _.values(obj);\n      for (var i = 0, length = obj.length; i < length; i++) {\n        value = obj[i];\n        if (value != null && value < result) {\n          result = value;\n        }\n      }\n    } else {\n      iteratee = cb(iteratee, context);\n      _.each(obj, function(v, index, list) {\n        computed = iteratee(v, index, list);\n        if (computed < lastComputed || computed === Infinity && result === Infinity) {\n          result = v;\n          lastComputed = computed;\n        }\n      });\n    }\n    return result;\n  };\n\n  // Shuffle a collection.\n  _.shuffle = function(obj) {\n    return _.sample(obj, Infinity);\n  };\n\n  // Sample **n** random values from a collection using the modern version of the\n  // [Fisher-Yates shuffle](http://en.wikipedia.org/wiki/Fisher–Yates_shuffle).\n  // If **n** is not specified, returns a single random element.\n  // The internal `guard` argument allows it to work with `map`.\n  _.sample = function(obj, n, guard) {\n    if (n == null || guard) {\n      if (!isArrayLike(obj)) obj = _.values(obj);\n      return obj[_.random(obj.length - 1)];\n    }\n    var sample = isArrayLike(obj) ? _.clone(obj) : _.values(obj);\n    var length = getLength(sample);\n    n = Math.max(Math.min(n, length), 0);\n    var last = length - 1;\n    for (var index = 0; index < n; index++) {\n      var rand = _.random(index, last);\n      var temp = sample[index];\n      sample[index] = sample[rand];\n      sample[rand] = temp;\n    }\n    return sample.slice(0, n);\n  };\n\n  // Sort the object's values by a criterion produced by an iteratee.\n  _.sortBy = function(obj, iteratee, context) {\n    var index = 0;\n    iteratee = cb(iteratee, context);\n    return _.pluck(_.map(obj, function(value, key, list) {\n      return {\n        value: value,\n        index: index++,\n        criteria: iteratee(value, key, list)\n      };\n    }).sort(function(left, right) {\n      var a = left.criteria;\n      var b = right.criteria;\n      if (a !== b) {\n        if (a > b || a === void 0) return 1;\n        if (a < b || b === void 0) return -1;\n      }\n      return left.index - right.index;\n    }), 'value');\n  };\n\n  // An internal function used for aggregate \"group by\" operations.\n  var group = function(behavior, partition) {\n    return function(obj, iteratee, context) {\n      var result = partition ? [[], []] : {};\n      iteratee = cb(iteratee, context);\n      _.each(obj, function(value, index) {\n        var key = iteratee(value, index, obj);\n        behavior(result, value, key);\n      });\n      return result;\n    };\n  };\n\n  // Groups the object's values by a criterion. Pass either a string attribute\n  // to group by, or a function that returns the criterion.\n  _.groupBy = group(function(result, value, key) {\n    if (has(result, key)) result[key].push(value); else result[key] = [value];\n  });\n\n  // Indexes the object's values by a criterion, similar to `groupBy`, but for\n  // when you know that your index values will be unique.\n  _.indexBy = group(function(result, value, key) {\n    result[key] = value;\n  });\n\n  // Counts instances of an object that group by a certain criterion. Pass\n  // either a string attribute to count by, or a function that returns the\n  // criterion.\n  _.countBy = group(function(result, value, key) {\n    if (has(result, key)) result[key]++; else result[key] = 1;\n  });\n\n  var reStrSymbol = /[^\\ud800-\\udfff]|[\\ud800-\\udbff][\\udc00-\\udfff]|[\\ud800-\\udfff]/g;\n  // Safely create a real, live array from anything iterable.\n  _.toArray = function(obj) {\n    if (!obj) return [];\n    if (_.isArray(obj)) return slice.call(obj);\n    if (_.isString(obj)) {\n      // Keep surrogate pair characters together\n      return obj.match(reStrSymbol);\n    }\n    if (isArrayLike(obj)) return _.map(obj, _.identity);\n    return _.values(obj);\n  };\n\n  // Return the number of elements in an object.\n  _.size = function(obj) {\n    if (obj == null) return 0;\n    return isArrayLike(obj) ? obj.length : _.keys(obj).length;\n  };\n\n  // Split a collection into two arrays: one whose elements all satisfy the given\n  // predicate, and one whose elements all do not satisfy the predicate.\n  _.partition = group(function(result, value, pass) {\n    result[pass ? 0 : 1].push(value);\n  }, true);\n\n  // Array Functions\n  // ---------------\n\n  // Get the first element of an array. Passing **n** will return the first N\n  // values in the array. Aliased as `head` and `take`. The **guard** check\n  // allows it to work with `_.map`.\n  _.first = _.head = _.take = function(array, n, guard) {\n    if (array == null || array.length < 1) return n == null ? void 0 : [];\n    if (n == null || guard) return array[0];\n    return _.initial(array, array.length - n);\n  };\n\n  // Returns everything but the last entry of the array. Especially useful on\n  // the arguments object. Passing **n** will return all the values in\n  // the array, excluding the last N.\n  _.initial = function(array, n, guard) {\n    return slice.call(array, 0, Math.max(0, array.length - (n == null || guard ? 1 : n)));\n  };\n\n  // Get the last element of an array. Passing **n** will return the last N\n  // values in the array.\n  _.last = function(array, n, guard) {\n    if (array == null || array.length < 1) return n == null ? void 0 : [];\n    if (n == null || guard) return array[array.length - 1];\n    return _.rest(array, Math.max(0, array.length - n));\n  };\n\n  // Returns everything but the first entry of the array. Aliased as `tail` and `drop`.\n  // Especially useful on the arguments object. Passing an **n** will return\n  // the rest N values in the array.\n  _.rest = _.tail = _.drop = function(array, n, guard) {\n    return slice.call(array, n == null || guard ? 1 : n);\n  };\n\n  // Trim out all falsy values from an array.\n  _.compact = function(array) {\n    return _.filter(array, Boolean);\n  };\n\n  // Internal implementation of a recursive `flatten` function.\n  var flatten = function(input, shallow, strict, output) {\n    output = output || [];\n    var idx = output.length;\n    for (var i = 0, length = getLength(input); i < length; i++) {\n      var value = input[i];\n      if (isArrayLike(value) && (_.isArray(value) || _.isArguments(value))) {\n        // Flatten current level of array or arguments object.\n        if (shallow) {\n          var j = 0, len = value.length;\n          while (j < len) output[idx++] = value[j++];\n        } else {\n          flatten(value, shallow, strict, output);\n          idx = output.length;\n        }\n      } else if (!strict) {\n        output[idx++] = value;\n      }\n    }\n    return output;\n  };\n\n  // Flatten out an array, either recursively (by default), or just one level.\n  _.flatten = function(array, shallow) {\n    return flatten(array, shallow, false);\n  };\n\n  // Return a version of the array that does not contain the specified value(s).\n  _.without = restArguments(function(array, otherArrays) {\n    return _.difference(array, otherArrays);\n  });\n\n  // Produce a duplicate-free version of the array. If the array has already\n  // been sorted, you have the option of using a faster algorithm.\n  // The faster algorithm will not work with an iteratee if the iteratee\n  // is not a one-to-one function, so providing an iteratee will disable\n  // the faster algorithm.\n  // Aliased as `unique`.\n  _.uniq = _.unique = function(array, isSorted, iteratee, context) {\n    if (!_.isBoolean(isSorted)) {\n      context = iteratee;\n      iteratee = isSorted;\n      isSorted = false;\n    }\n    if (iteratee != null) iteratee = cb(iteratee, context);\n    var result = [];\n    var seen = [];\n    for (var i = 0, length = getLength(array); i < length; i++) {\n      var value = array[i],\n          computed = iteratee ? iteratee(value, i, array) : value;\n      if (isSorted && !iteratee) {\n        if (!i || seen !== computed) result.push(value);\n        seen = computed;\n      } else if (iteratee) {\n        if (!_.contains(seen, computed)) {\n          seen.push(computed);\n          result.push(value);\n        }\n      } else if (!_.contains(result, value)) {\n        result.push(value);\n      }\n    }\n    return result;\n  };\n\n  // Produce an array that contains the union: each distinct element from all of\n  // the passed-in arrays.\n  _.union = restArguments(function(arrays) {\n    return _.uniq(flatten(arrays, true, true));\n  });\n\n  // Produce an array that contains every item shared between all the\n  // passed-in arrays.\n  _.intersection = function(array) {\n    var result = [];\n    var argsLength = arguments.length;\n    for (var i = 0, length = getLength(array); i < length; i++) {\n      var item = array[i];\n      if (_.contains(result, item)) continue;\n      var j;\n      for (j = 1; j < argsLength; j++) {\n        if (!_.contains(arguments[j], item)) break;\n      }\n      if (j === argsLength) result.push(item);\n    }\n    return result;\n  };\n\n  // Take the difference between one array and a number of other arrays.\n  // Only the elements present in just the first array will remain.\n  _.difference = restArguments(function(array, rest) {\n    rest = flatten(rest, true, true);\n    return _.filter(array, function(value){\n      return !_.contains(rest, value);\n    });\n  });\n\n  // Complement of _.zip. Unzip accepts an array of arrays and groups\n  // each array's elements on shared indices.\n  _.unzip = function(array) {\n    var length = array && _.max(array, getLength).length || 0;\n    var result = Array(length);\n\n    for (var index = 0; index < length; index++) {\n      result[index] = _.pluck(array, index);\n    }\n    return result;\n  };\n\n  // Zip together multiple lists into a single array -- elements that share\n  // an index go together.\n  _.zip = restArguments(_.unzip);\n\n  // Converts lists into objects. Pass either a single array of `[key, value]`\n  // pairs, or two parallel arrays of the same length -- one of keys, and one of\n  // the corresponding values. Passing by pairs is the reverse of _.pairs.\n  _.object = function(list, values) {\n    var result = {};\n    for (var i = 0, length = getLength(list); i < length; i++) {\n      if (values) {\n        result[list[i]] = values[i];\n      } else {\n        result[list[i][0]] = list[i][1];\n      }\n    }\n    return result;\n  };\n\n  // Generator function to create the findIndex and findLastIndex functions.\n  var createPredicateIndexFinder = function(dir) {\n    return function(array, predicate, context) {\n      predicate = cb(predicate, context);\n      var length = getLength(array);\n      var index = dir > 0 ? 0 : length - 1;\n      for (; index >= 0 && index < length; index += dir) {\n        if (predicate(array[index], index, array)) return index;\n      }\n      return -1;\n    };\n  };\n\n  // Returns the first index on an array-like that passes a predicate test.\n  _.findIndex = createPredicateIndexFinder(1);\n  _.findLastIndex = createPredicateIndexFinder(-1);\n\n  // Use a comparator function to figure out the smallest index at which\n  // an object should be inserted so as to maintain order. Uses binary search.\n  _.sortedIndex = function(array, obj, iteratee, context) {\n    iteratee = cb(iteratee, context, 1);\n    var value = iteratee(obj);\n    var low = 0, high = getLength(array);\n    while (low < high) {\n      var mid = Math.floor((low + high) / 2);\n      if (iteratee(array[mid]) < value) low = mid + 1; else high = mid;\n    }\n    return low;\n  };\n\n  // Generator function to create the indexOf and lastIndexOf functions.\n  var createIndexFinder = function(dir, predicateFind, sortedIndex) {\n    return function(array, item, idx) {\n      var i = 0, length = getLength(array);\n      if (typeof idx == 'number') {\n        if (dir > 0) {\n          i = idx >= 0 ? idx : Math.max(idx + length, i);\n        } else {\n          length = idx >= 0 ? Math.min(idx + 1, length) : idx + length + 1;\n        }\n      } else if (sortedIndex && idx && length) {\n        idx = sortedIndex(array, item);\n        return array[idx] === item ? idx : -1;\n      }\n      if (item !== item) {\n        idx = predicateFind(slice.call(array, i, length), _.isNaN);\n        return idx >= 0 ? idx + i : -1;\n      }\n      for (idx = dir > 0 ? i : length - 1; idx >= 0 && idx < length; idx += dir) {\n        if (array[idx] === item) return idx;\n      }\n      return -1;\n    };\n  };\n\n  // Return the position of the first occurrence of an item in an array,\n  // or -1 if the item is not included in the array.\n  // If the array is large and already in sort order, pass `true`\n  // for **isSorted** to use binary search.\n  _.indexOf = createIndexFinder(1, _.findIndex, _.sortedIndex);\n  _.lastIndexOf = createIndexFinder(-1, _.findLastIndex);\n\n  // Generate an integer Array containing an arithmetic progression. A port of\n  // the native Python `range()` function. See\n  // [the Python documentation](http://docs.python.org/library/functions.html#range).\n  _.range = function(start, stop, step) {\n    if (stop == null) {\n      stop = start || 0;\n      start = 0;\n    }\n    if (!step) {\n      step = stop < start ? -1 : 1;\n    }\n\n    var length = Math.max(Math.ceil((stop - start) / step), 0);\n    var range = Array(length);\n\n    for (var idx = 0; idx < length; idx++, start += step) {\n      range[idx] = start;\n    }\n\n    return range;\n  };\n\n  // Chunk a single array into multiple arrays, each containing `count` or fewer\n  // items.\n  _.chunk = function(array, count) {\n    if (count == null || count < 1) return [];\n    var result = [];\n    var i = 0, length = array.length;\n    while (i < length) {\n      result.push(slice.call(array, i, i += count));\n    }\n    return result;\n  };\n\n  // Function (ahem) Functions\n  // ------------------\n\n  // Determines whether to execute a function as a constructor\n  // or a normal function with the provided arguments.\n  var executeBound = function(sourceFunc, boundFunc, context, callingContext, args) {\n    if (!(callingContext instanceof boundFunc)) return sourceFunc.apply(context, args);\n    var self = baseCreate(sourceFunc.prototype);\n    var result = sourceFunc.apply(self, args);\n    if (_.isObject(result)) return result;\n    return self;\n  };\n\n  // Create a function bound to a given object (assigning `this`, and arguments,\n  // optionally). Delegates to **ECMAScript 5**'s native `Function.bind` if\n  // available.\n  _.bind = restArguments(function(func, context, args) {\n    if (!_.isFunction(func)) throw new TypeError('Bind must be called on a function');\n    var bound = restArguments(function(callArgs) {\n      return executeBound(func, bound, context, this, args.concat(callArgs));\n    });\n    return bound;\n  });\n\n  // Partially apply a function by creating a version that has had some of its\n  // arguments pre-filled, without changing its dynamic `this` context. _ acts\n  // as a placeholder by default, allowing any combination of arguments to be\n  // pre-filled. Set `_.partial.placeholder` for a custom placeholder argument.\n  _.partial = restArguments(function(func, boundArgs) {\n    var placeholder = _.partial.placeholder;\n    var bound = function() {\n      var position = 0, length = boundArgs.length;\n      var args = Array(length);\n      for (var i = 0; i < length; i++) {\n        args[i] = boundArgs[i] === placeholder ? arguments[position++] : boundArgs[i];\n      }\n      while (position < arguments.length) args.push(arguments[position++]);\n      return executeBound(func, bound, this, this, args);\n    };\n    return bound;\n  });\n\n  _.partial.placeholder = _;\n\n  // Bind a number of an object's methods to that object. Remaining arguments\n  // are the method names to be bound. Useful for ensuring that all callbacks\n  // defined on an object belong to it.\n  _.bindAll = restArguments(function(obj, keys) {\n    keys = flatten(keys, false, false);\n    var index = keys.length;\n    if (index < 1) throw new Error('bindAll must be passed function names');\n    while (index--) {\n      var key = keys[index];\n      obj[key] = _.bind(obj[key], obj);\n    }\n  });\n\n  // Memoize an expensive function by storing its results.\n  _.memoize = function(func, hasher) {\n    var memoize = function(key) {\n      var cache = memoize.cache;\n      var address = '' + (hasher ? hasher.apply(this, arguments) : key);\n      if (!has(cache, address)) cache[address] = func.apply(this, arguments);\n      return cache[address];\n    };\n    memoize.cache = {};\n    return memoize;\n  };\n\n  // Delays a function for the given number of milliseconds, and then calls\n  // it with the arguments supplied.\n  _.delay = restArguments(function(func, wait, args) {\n    return setTimeout(function() {\n      return func.apply(null, args);\n    }, wait);\n  });\n\n  // Defers a function, scheduling it to run after the current call stack has\n  // cleared.\n  _.defer = _.partial(_.delay, _, 1);\n\n  // Returns a function, that, when invoked, will only be triggered at most once\n  // during a given window of time. Normally, the throttled function will run\n  // as much as it can, without ever going more than once per `wait` duration;\n  // but if you'd like to disable the execution on the leading edge, pass\n  // `{leading: false}`. To disable execution on the trailing edge, ditto.\n  _.throttle = function(func, wait, options) {\n    var timeout, context, args, result;\n    var previous = 0;\n    if (!options) options = {};\n\n    var later = function() {\n      previous = options.leading === false ? 0 : _.now();\n      timeout = null;\n      result = func.apply(context, args);\n      if (!timeout) context = args = null;\n    };\n\n    var throttled = function() {\n      var now = _.now();\n      if (!previous && options.leading === false) previous = now;\n      var remaining = wait - (now - previous);\n      context = this;\n      args = arguments;\n      if (remaining <= 0 || remaining > wait) {\n        if (timeout) {\n          clearTimeout(timeout);\n          timeout = null;\n        }\n        previous = now;\n        result = func.apply(context, args);\n        if (!timeout) context = args = null;\n      } else if (!timeout && options.trailing !== false) {\n        timeout = setTimeout(later, remaining);\n      }\n      return result;\n    };\n\n    throttled.cancel = function() {\n      clearTimeout(timeout);\n      previous = 0;\n      timeout = context = args = null;\n    };\n\n    return throttled;\n  };\n\n  // Returns a function, that, as long as it continues to be invoked, will not\n  // be triggered. The function will be called after it stops being called for\n  // N milliseconds. If `immediate` is passed, trigger the function on the\n  // leading edge, instead of the trailing.\n  _.debounce = function(func, wait, immediate) {\n    var timeout, result;\n\n    var later = function(context, args) {\n      timeout = null;\n      if (args) result = func.apply(context, args);\n    };\n\n    var debounced = restArguments(function(args) {\n      if (timeout) clearTimeout(timeout);\n      if (immediate) {\n        var callNow = !timeout;\n        timeout = setTimeout(later, wait);\n        if (callNow) result = func.apply(this, args);\n      } else {\n        timeout = _.delay(later, wait, this, args);\n      }\n\n      return result;\n    });\n\n    debounced.cancel = function() {\n      clearTimeout(timeout);\n      timeout = null;\n    };\n\n    return debounced;\n  };\n\n  // Returns the first function passed as an argument to the second,\n  // allowing you to adjust arguments, run code before and after, and\n  // conditionally execute the original function.\n  _.wrap = function(func, wrapper) {\n    return _.partial(wrapper, func);\n  };\n\n  // Returns a negated version of the passed-in predicate.\n  _.negate = function(predicate) {\n    return function() {\n      return !predicate.apply(this, arguments);\n    };\n  };\n\n  // Returns a function that is the composition of a list of functions, each\n  // consuming the return value of the function that follows.\n  _.compose = function() {\n    var args = arguments;\n    var start = args.length - 1;\n    return function() {\n      var i = start;\n      var result = args[start].apply(this, arguments);\n      while (i--) result = args[i].call(this, result);\n      return result;\n    };\n  };\n\n  // Returns a function that will only be executed on and after the Nth call.\n  _.after = function(times, func) {\n    return function() {\n      if (--times < 1) {\n        return func.apply(this, arguments);\n      }\n    };\n  };\n\n  // Returns a function that will only be executed up to (but not including) the Nth call.\n  _.before = function(times, func) {\n    var memo;\n    return function() {\n      if (--times > 0) {\n        memo = func.apply(this, arguments);\n      }\n      if (times <= 1) func = null;\n      return memo;\n    };\n  };\n\n  // Returns a function that will be executed at most one time, no matter how\n  // often you call it. Useful for lazy initialization.\n  _.once = _.partial(_.before, 2);\n\n  _.restArguments = restArguments;\n\n  // Object Functions\n  // ----------------\n\n  // Keys in IE < 9 that won't be iterated by `for key in ...` and thus missed.\n  var hasEnumBug = !{toString: null}.propertyIsEnumerable('toString');\n  var nonEnumerableProps = ['valueOf', 'isPrototypeOf', 'toString',\n    'propertyIsEnumerable', 'hasOwnProperty', 'toLocaleString'];\n\n  var collectNonEnumProps = function(obj, keys) {\n    var nonEnumIdx = nonEnumerableProps.length;\n    var constructor = obj.constructor;\n    var proto = _.isFunction(constructor) && constructor.prototype || ObjProto;\n\n    // Constructor is a special case.\n    var prop = 'constructor';\n    if (has(obj, prop) && !_.contains(keys, prop)) keys.push(prop);\n\n    while (nonEnumIdx--) {\n      prop = nonEnumerableProps[nonEnumIdx];\n      if (prop in obj && obj[prop] !== proto[prop] && !_.contains(keys, prop)) {\n        keys.push(prop);\n      }\n    }\n  };\n\n  // Retrieve the names of an object's own properties.\n  // Delegates to **ECMAScript 5**'s native `Object.keys`.\n  _.keys = function(obj) {\n    if (!_.isObject(obj)) return [];\n    if (nativeKeys) return nativeKeys(obj);\n    var keys = [];\n    for (var key in obj) if (has(obj, key)) keys.push(key);\n    // Ahem, IE < 9.\n    if (hasEnumBug) collectNonEnumProps(obj, keys);\n    return keys;\n  };\n\n  // Retrieve all the property names of an object.\n  _.allKeys = function(obj) {\n    if (!_.isObject(obj)) return [];\n    var keys = [];\n    for (var key in obj) keys.push(key);\n    // Ahem, IE < 9.\n    if (hasEnumBug) collectNonEnumProps(obj, keys);\n    return keys;\n  };\n\n  // Retrieve the values of an object's properties.\n  _.values = function(obj) {\n    var keys = _.keys(obj);\n    var length = keys.length;\n    var values = Array(length);\n    for (var i = 0; i < length; i++) {\n      values[i] = obj[keys[i]];\n    }\n    return values;\n  };\n\n  // Returns the results of applying the iteratee to each element of the object.\n  // In contrast to _.map it returns an object.\n  _.mapObject = function(obj, iteratee, context) {\n    iteratee = cb(iteratee, context);\n    var keys = _.keys(obj),\n        length = keys.length,\n        results = {};\n    for (var index = 0; index < length; index++) {\n      var currentKey = keys[index];\n      results[currentKey] = iteratee(obj[currentKey], currentKey, obj);\n    }\n    return results;\n  };\n\n  // Convert an object into a list of `[key, value]` pairs.\n  // The opposite of _.object.\n  _.pairs = function(obj) {\n    var keys = _.keys(obj);\n    var length = keys.length;\n    var pairs = Array(length);\n    for (var i = 0; i < length; i++) {\n      pairs[i] = [keys[i], obj[keys[i]]];\n    }\n    return pairs;\n  };\n\n  // Invert the keys and values of an object. The values must be serializable.\n  _.invert = function(obj) {\n    var result = {};\n    var keys = _.keys(obj);\n    for (var i = 0, length = keys.length; i < length; i++) {\n      result[obj[keys[i]]] = keys[i];\n    }\n    return result;\n  };\n\n  // Return a sorted list of the function names available on the object.\n  // Aliased as `methods`.\n  _.functions = _.methods = function(obj) {\n    var names = [];\n    for (var key in obj) {\n      if (_.isFunction(obj[key])) names.push(key);\n    }\n    return names.sort();\n  };\n\n  // An internal function for creating assigner functions.\n  var createAssigner = function(keysFunc, defaults) {\n    return function(obj) {\n      var length = arguments.length;\n      if (defaults) obj = Object(obj);\n      if (length < 2 || obj == null) return obj;\n      for (var index = 1; index < length; index++) {\n        var source = arguments[index],\n            keys = keysFunc(source),\n            l = keys.length;\n        for (var i = 0; i < l; i++) {\n          var key = keys[i];\n          if (!defaults || obj[key] === void 0) obj[key] = source[key];\n        }\n      }\n      return obj;\n    };\n  };\n\n  // Extend a given object with all the properties in passed-in object(s).\n  _.extend = createAssigner(_.allKeys);\n\n  // Assigns a given object with all the own properties in the passed-in object(s).\n  // (https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object/assign)\n  _.extendOwn = _.assign = createAssigner(_.keys);\n\n  // Returns the first key on an object that passes a predicate test.\n  _.findKey = function(obj, predicate, context) {\n    predicate = cb(predicate, context);\n    var keys = _.keys(obj), key;\n    for (var i = 0, length = keys.length; i < length; i++) {\n      key = keys[i];\n      if (predicate(obj[key], key, obj)) return key;\n    }\n  };\n\n  // Internal pick helper function to determine if `obj` has key `key`.\n  var keyInObj = function(value, key, obj) {\n    return key in obj;\n  };\n\n  // Return a copy of the object only containing the whitelisted properties.\n  _.pick = restArguments(function(obj, keys) {\n    var result = {}, iteratee = keys[0];\n    if (obj == null) return result;\n    if (_.isFunction(iteratee)) {\n      if (keys.length > 1) iteratee = optimizeCb(iteratee, keys[1]);\n      keys = _.allKeys(obj);\n    } else {\n      iteratee = keyInObj;\n      keys = flatten(keys, false, false);\n      obj = Object(obj);\n    }\n    for (var i = 0, length = keys.length; i < length; i++) {\n      var key = keys[i];\n      var value = obj[key];\n      if (iteratee(value, key, obj)) result[key] = value;\n    }\n    return result;\n  });\n\n  // Return a copy of the object without the blacklisted properties.\n  _.omit = restArguments(function(obj, keys) {\n    var iteratee = keys[0], context;\n    if (_.isFunction(iteratee)) {\n      iteratee = _.negate(iteratee);\n      if (keys.length > 1) context = keys[1];\n    } else {\n      keys = _.map(flatten(keys, false, false), String);\n      iteratee = function(value, key) {\n        return !_.contains(keys, key);\n      };\n    }\n    return _.pick(obj, iteratee, context);\n  });\n\n  // Fill in a given object with default properties.\n  _.defaults = createAssigner(_.allKeys, true);\n\n  // Creates an object that inherits from the given prototype object.\n  // If additional properties are provided then they will be added to the\n  // created object.\n  _.create = function(prototype, props) {\n    var result = baseCreate(prototype);\n    if (props) _.extendOwn(result, props);\n    return result;\n  };\n\n  // Create a (shallow-cloned) duplicate of an object.\n  _.clone = function(obj) {\n    if (!_.isObject(obj)) return obj;\n    return _.isArray(obj) ? obj.slice() : _.extend({}, obj);\n  };\n\n  // Invokes interceptor with the obj, and then returns obj.\n  // The primary purpose of this method is to \"tap into\" a method chain, in\n  // order to perform operations on intermediate results within the chain.\n  _.tap = function(obj, interceptor) {\n    interceptor(obj);\n    return obj;\n  };\n\n  // Returns whether an object has a given set of `key:value` pairs.\n  _.isMatch = function(object, attrs) {\n    var keys = _.keys(attrs), length = keys.length;\n    if (object == null) return !length;\n    var obj = Object(object);\n    for (var i = 0; i < length; i++) {\n      var key = keys[i];\n      if (attrs[key] !== obj[key] || !(key in obj)) return false;\n    }\n    return true;\n  };\n\n\n  // Internal recursive comparison function for `isEqual`.\n  var eq, deepEq;\n  eq = function(a, b, aStack, bStack) {\n    // Identical objects are equal. `0 === -0`, but they aren't identical.\n    // See the [Harmony `egal` proposal](http://wiki.ecmascript.org/doku.php?id=harmony:egal).\n    if (a === b) return a !== 0 || 1 / a === 1 / b;\n    // `null` or `undefined` only equal to itself (strict comparison).\n    if (a == null || b == null) return false;\n    // `NaN`s are equivalent, but non-reflexive.\n    if (a !== a) return b !== b;\n    // Exhaust primitive checks\n    var type = typeof a;\n    if (type !== 'function' && type !== 'object' && typeof b != 'object') return false;\n    return deepEq(a, b, aStack, bStack);\n  };\n\n  // Internal recursive comparison function for `isEqual`.\n  deepEq = function(a, b, aStack, bStack) {\n    // Unwrap any wrapped objects.\n    if (a instanceof _) a = a._wrapped;\n    if (b instanceof _) b = b._wrapped;\n    // Compare `[[Class]]` names.\n    var className = toString.call(a);\n    if (className !== toString.call(b)) return false;\n    switch (className) {\n      // Strings, numbers, regular expressions, dates, and booleans are compared by value.\n      case '[object RegExp]':\n      // RegExps are coerced to strings for comparison (Note: '' + /a/i === '/a/i')\n      case '[object String]':\n        // Primitives and their corresponding object wrappers are equivalent; thus, `\"5\"` is\n        // equivalent to `new String(\"5\")`.\n        return '' + a === '' + b;\n      case '[object Number]':\n        // `NaN`s are equivalent, but non-reflexive.\n        // Object(NaN) is equivalent to NaN.\n        if (+a !== +a) return +b !== +b;\n        // An `egal` comparison is performed for other numeric values.\n        return +a === 0 ? 1 / +a === 1 / b : +a === +b;\n      case '[object Date]':\n      case '[object Boolean]':\n        // Coerce dates and booleans to numeric primitive values. Dates are compared by their\n        // millisecond representations. Note that invalid dates with millisecond representations\n        // of `NaN` are not equivalent.\n        return +a === +b;\n      case '[object Symbol]':\n        return SymbolProto.valueOf.call(a) === SymbolProto.valueOf.call(b);\n    }\n\n    var areArrays = className === '[object Array]';\n    if (!areArrays) {\n      if (typeof a != 'object' || typeof b != 'object') return false;\n\n      // Objects with different constructors are not equivalent, but `Object`s or `Array`s\n      // from different frames are.\n      var aCtor = a.constructor, bCtor = b.constructor;\n      if (aCtor !== bCtor && !(_.isFunction(aCtor) && aCtor instanceof aCtor &&\n                               _.isFunction(bCtor) && bCtor instanceof bCtor)\n                          && ('constructor' in a && 'constructor' in b)) {\n        return false;\n      }\n    }\n    // Assume equality for cyclic structures. The algorithm for detecting cyclic\n    // structures is adapted from ES 5.1 section 15.12.3, abstract operation `JO`.\n\n    // Initializing stack of traversed objects.\n    // It's done here since we only need them for objects and arrays comparison.\n    aStack = aStack || [];\n    bStack = bStack || [];\n    var length = aStack.length;\n    while (length--) {\n      // Linear search. Performance is inversely proportional to the number of\n      // unique nested structures.\n      if (aStack[length] === a) return bStack[length] === b;\n    }\n\n    // Add the first object to the stack of traversed objects.\n    aStack.push(a);\n    bStack.push(b);\n\n    // Recursively compare objects and arrays.\n    if (areArrays) {\n      // Compare array lengths to determine if a deep comparison is necessary.\n      length = a.length;\n      if (length !== b.length) return false;\n      // Deep compare the contents, ignoring non-numeric properties.\n      while (length--) {\n        if (!eq(a[length], b[length], aStack, bStack)) return false;\n      }\n    } else {\n      // Deep compare objects.\n      var keys = _.keys(a), key;\n      length = keys.length;\n      // Ensure that both objects contain the same number of properties before comparing deep equality.\n      if (_.keys(b).length !== length) return false;\n      while (length--) {\n        // Deep compare each member\n        key = keys[length];\n        if (!(has(b, key) && eq(a[key], b[key], aStack, bStack))) return false;\n      }\n    }\n    // Remove the first object from the stack of traversed objects.\n    aStack.pop();\n    bStack.pop();\n    return true;\n  };\n\n  // Perform a deep comparison to check if two objects are equal.\n  _.isEqual = function(a, b) {\n    return eq(a, b);\n  };\n\n  // Is a given array, string, or object empty?\n  // An \"empty\" object has no enumerable own-properties.\n  _.isEmpty = function(obj) {\n    if (obj == null) return true;\n    if (isArrayLike(obj) && (_.isArray(obj) || _.isString(obj) || _.isArguments(obj))) return obj.length === 0;\n    return _.keys(obj).length === 0;\n  };\n\n  // Is a given value a DOM element?\n  _.isElement = function(obj) {\n    return !!(obj && obj.nodeType === 1);\n  };\n\n  // Is a given value an array?\n  // Delegates to ECMA5's native Array.isArray\n  _.isArray = nativeIsArray || function(obj) {\n    return toString.call(obj) === '[object Array]';\n  };\n\n  // Is a given variable an object?\n  _.isObject = function(obj) {\n    var type = typeof obj;\n    return type === 'function' || type === 'object' && !!obj;\n  };\n\n  // Add some isType methods: isArguments, isFunction, isString, isNumber, isDate, isRegExp, isError, isMap, isWeakMap, isSet, isWeakSet.\n  _.each(['Arguments', 'Function', 'String', 'Number', 'Date', 'RegExp', 'Error', 'Symbol', 'Map', 'WeakMap', 'Set', 'WeakSet'], function(name) {\n    _['is' + name] = function(obj) {\n      return toString.call(obj) === '[object ' + name + ']';\n    };\n  });\n\n  // Define a fallback version of the method in browsers (ahem, IE < 9), where\n  // there isn't any inspectable \"Arguments\" type.\n  if (!_.isArguments(arguments)) {\n    _.isArguments = function(obj) {\n      return has(obj, 'callee');\n    };\n  }\n\n  // Optimize `isFunction` if appropriate. Work around some typeof bugs in old v8,\n  // IE 11 (#1621), Safari 8 (#1929), and PhantomJS (#2236).\n  var nodelist = root.document && root.document.childNodes;\n  if (typeof /./ != 'function' && typeof Int8Array != 'object' && typeof nodelist != 'function') {\n    _.isFunction = function(obj) {\n      return typeof obj == 'function' || false;\n    };\n  }\n\n  // Is a given object a finite number?\n  _.isFinite = function(obj) {\n    return !_.isSymbol(obj) && isFinite(obj) && !isNaN(parseFloat(obj));\n  };\n\n  // Is the given value `NaN`?\n  _.isNaN = function(obj) {\n    return _.isNumber(obj) && isNaN(obj);\n  };\n\n  // Is a given value a boolean?\n  _.isBoolean = function(obj) {\n    return obj === true || obj === false || toString.call(obj) === '[object Boolean]';\n  };\n\n  // Is a given value equal to null?\n  _.isNull = function(obj) {\n    return obj === null;\n  };\n\n  // Is a given variable undefined?\n  _.isUndefined = function(obj) {\n    return obj === void 0;\n  };\n\n  // Shortcut function for checking if an object has a given property directly\n  // on itself (in other words, not on a prototype).\n  _.has = function(obj, path) {\n    if (!_.isArray(path)) {\n      return has(obj, path);\n    }\n    var length = path.length;\n    for (var i = 0; i < length; i++) {\n      var key = path[i];\n      if (obj == null || !hasOwnProperty.call(obj, key)) {\n        return false;\n      }\n      obj = obj[key];\n    }\n    return !!length;\n  };\n\n  // Utility Functions\n  // -----------------\n\n  // Run Underscore.js in *noConflict* mode, returning the `_` variable to its\n  // previous owner. Returns a reference to the Underscore object.\n  _.noConflict = function() {\n    root._ = previousUnderscore;\n    return this;\n  };\n\n  // Keep the identity function around for default iteratees.\n  _.identity = function(value) {\n    return value;\n  };\n\n  // Predicate-generating functions. Often useful outside of Underscore.\n  _.constant = function(value) {\n    return function() {\n      return value;\n    };\n  };\n\n  _.noop = function(){};\n\n  // Creates a function that, when passed an object, will traverse that object’s\n  // properties down the given `path`, specified as an array of keys or indexes.\n  _.property = function(path) {\n    if (!_.isArray(path)) {\n      return shallowProperty(path);\n    }\n    return function(obj) {\n      return deepGet(obj, path);\n    };\n  };\n\n  // Generates a function for a given object that returns a given property.\n  _.propertyOf = function(obj) {\n    if (obj == null) {\n      return function(){};\n    }\n    return function(path) {\n      return !_.isArray(path) ? obj[path] : deepGet(obj, path);\n    };\n  };\n\n  // Returns a predicate for checking whether an object has a given set of\n  // `key:value` pairs.\n  _.matcher = _.matches = function(attrs) {\n    attrs = _.extendOwn({}, attrs);\n    return function(obj) {\n      return _.isMatch(obj, attrs);\n    };\n  };\n\n  // Run a function **n** times.\n  _.times = function(n, iteratee, context) {\n    var accum = Array(Math.max(0, n));\n    iteratee = optimizeCb(iteratee, context, 1);\n    for (var i = 0; i < n; i++) accum[i] = iteratee(i);\n    return accum;\n  };\n\n  // Return a random integer between min and max (inclusive).\n  _.random = function(min, max) {\n    if (max == null) {\n      max = min;\n      min = 0;\n    }\n    return min + Math.floor(Math.random() * (max - min + 1));\n  };\n\n  // A (possibly faster) way to get the current timestamp as an integer.\n  _.now = Date.now || function() {\n    return new Date().getTime();\n  };\n\n  // List of HTML entities for escaping.\n  var escapeMap = {\n    '&': '&amp;',\n    '<': '&lt;',\n    '>': '&gt;',\n    '\"': '&quot;',\n    \"'\": '&#x27;',\n    '`': '&#x60;'\n  };\n  var unescapeMap = _.invert(escapeMap);\n\n  // Functions for escaping and unescaping strings to/from HTML interpolation.\n  var createEscaper = function(map) {\n    var escaper = function(match) {\n      return map[match];\n    };\n    // Regexes for identifying a key that needs to be escaped.\n    var source = '(?:' + _.keys(map).join('|') + ')';\n    var testRegexp = RegExp(source);\n    var replaceRegexp = RegExp(source, 'g');\n    return function(string) {\n      string = string == null ? '' : '' + string;\n      return testRegexp.test(string) ? string.replace(replaceRegexp, escaper) : string;\n    };\n  };\n  _.escape = createEscaper(escapeMap);\n  _.unescape = createEscaper(unescapeMap);\n\n  // Traverses the children of `obj` along `path`. If a child is a function, it\n  // is invoked with its parent as context. Returns the value of the final\n  // child, or `fallback` if any child is undefined.\n  _.result = function(obj, path, fallback) {\n    if (!_.isArray(path)) path = [path];\n    var length = path.length;\n    if (!length) {\n      return _.isFunction(fallback) ? fallback.call(obj) : fallback;\n    }\n    for (var i = 0; i < length; i++) {\n      var prop = obj == null ? void 0 : obj[path[i]];\n      if (prop === void 0) {\n        prop = fallback;\n        i = length; // Ensure we don't continue iterating.\n      }\n      obj = _.isFunction(prop) ? prop.call(obj) : prop;\n    }\n    return obj;\n  };\n\n  // Generate a unique integer id (unique within the entire client session).\n  // Useful for temporary DOM ids.\n  var idCounter = 0;\n  _.uniqueId = function(prefix) {\n    var id = ++idCounter + '';\n    return prefix ? prefix + id : id;\n  };\n\n  // By default, Underscore uses ERB-style template delimiters, change the\n  // following template settings to use alternative delimiters.\n  _.templateSettings = {\n    evaluate: /<%([\\s\\S]+?)%>/g,\n    interpolate: /<%=([\\s\\S]+?)%>/g,\n    escape: /<%-([\\s\\S]+?)%>/g\n  };\n\n  // When customizing `templateSettings`, if you don't want to define an\n  // interpolation, evaluation or escaping regex, we need one that is\n  // guaranteed not to match.\n  var noMatch = /(.)^/;\n\n  // Certain characters need to be escaped so that they can be put into a\n  // string literal.\n  var escapes = {\n    \"'\": \"'\",\n    '\\\\': '\\\\',\n    '\\r': 'r',\n    '\\n': 'n',\n    '\\u2028': 'u2028',\n    '\\u2029': 'u2029'\n  };\n\n  var escapeRegExp = /\\\\|'|\\r|\\n|\\u2028|\\u2029/g;\n\n  var escapeChar = function(match) {\n    return '\\\\' + escapes[match];\n  };\n\n  // JavaScript micro-templating, similar to John Resig's implementation.\n  // Underscore templating handles arbitrary delimiters, preserves whitespace,\n  // and correctly escapes quotes within interpolated code.\n  // NB: `oldSettings` only exists for backwards compatibility.\n  _.template = function(text, settings, oldSettings) {\n    if (!settings && oldSettings) settings = oldSettings;\n    settings = _.defaults({}, settings, _.templateSettings);\n\n    // Combine delimiters into one regular expression via alternation.\n    var matcher = RegExp([\n      (settings.escape || noMatch).source,\n      (settings.interpolate || noMatch).source,\n      (settings.evaluate || noMatch).source\n    ].join('|') + '|$', 'g');\n\n    // Compile the template source, escaping string literals appropriately.\n    var index = 0;\n    var source = \"__p+='\";\n    text.replace(matcher, function(match, escape, interpolate, evaluate, offset) {\n      source += text.slice(index, offset).replace(escapeRegExp, escapeChar);\n      index = offset + match.length;\n\n      if (escape) {\n        source += \"'+\\n((__t=(\" + escape + \"))==null?'':_.escape(__t))+\\n'\";\n      } else if (interpolate) {\n        source += \"'+\\n((__t=(\" + interpolate + \"))==null?'':__t)+\\n'\";\n      } else if (evaluate) {\n        source += \"';\\n\" + evaluate + \"\\n__p+='\";\n      }\n\n      // Adobe VMs need the match returned to produce the correct offset.\n      return match;\n    });\n    source += \"';\\n\";\n\n    // If a variable is not specified, place data values in local scope.\n    if (!settings.variable) source = 'with(obj||{}){\\n' + source + '}\\n';\n\n    source = \"var __t,__p='',__j=Array.prototype.join,\" +\n      \"print=function(){__p+=__j.call(arguments,'');};\\n\" +\n      source + 'return __p;\\n';\n\n    var render;\n    try {\n      render = new Function(settings.variable || 'obj', '_', source);\n    } catch (e) {\n      e.source = source;\n      throw e;\n    }\n\n    var template = function(data) {\n      return render.call(this, data, _);\n    };\n\n    // Provide the compiled source as a convenience for precompilation.\n    var argument = settings.variable || 'obj';\n    template.source = 'function(' + argument + '){\\n' + source + '}';\n\n    return template;\n  };\n\n  // Add a \"chain\" function. Start chaining a wrapped Underscore object.\n  _.chain = function(obj) {\n    var instance = _(obj);\n    instance._chain = true;\n    return instance;\n  };\n\n  // OOP\n  // ---------------\n  // If Underscore is called as a function, it returns a wrapped object that\n  // can be used OO-style. This wrapper holds altered versions of all the\n  // underscore functions. Wrapped objects may be chained.\n\n  // Helper function to continue chaining intermediate results.\n  var chainResult = function(instance, obj) {\n    return instance._chain ? _(obj).chain() : obj;\n  };\n\n  // Add your own custom functions to the Underscore object.\n  _.mixin = function(obj) {\n    _.each(_.functions(obj), function(name) {\n      var func = _[name] = obj[name];\n      _.prototype[name] = function() {\n        var args = [this._wrapped];\n        push.apply(args, arguments);\n        return chainResult(this, func.apply(_, args));\n      };\n    });\n    return _;\n  };\n\n  // Add all of the Underscore functions to the wrapper object.\n  _.mixin(_);\n\n  // Add all mutator Array functions to the wrapper.\n  _.each(['pop', 'push', 'reverse', 'shift', 'sort', 'splice', 'unshift'], function(name) {\n    var method = ArrayProto[name];\n    _.prototype[name] = function() {\n      var obj = this._wrapped;\n      method.apply(obj, arguments);\n      if ((name === 'shift' || name === 'splice') && obj.length === 0) delete obj[0];\n      return chainResult(this, obj);\n    };\n  });\n\n  // Add all accessor Array functions to the wrapper.\n  _.each(['concat', 'join', 'slice'], function(name) {\n    var method = ArrayProto[name];\n    _.prototype[name] = function() {\n      return chainResult(this, method.apply(this._wrapped, arguments));\n    };\n  });\n\n  // Extracts the result from a wrapped and chained object.\n  _.prototype.value = function() {\n    return this._wrapped;\n  };\n\n  // Provide unwrapping proxy for some methods used in engine operations\n  // such as arithmetic and JSON stringification.\n  _.prototype.valueOf = _.prototype.toJSON = _.prototype.value;\n\n  _.prototype.toString = function() {\n    return String(this._wrapped);\n  };\n\n  // AMD registration happens at the end for compatibility with AMD loaders\n  // that may not enforce next-turn semantics on modules. Even though general\n  // practice for AMD registration is to be anonymous, underscore registers\n  // as a named module because, like jQuery, it is a base library that is\n  // popular enough to be bundled in a third party lib, but not be part of\n  // an AMD load request. Those cases could generate an error when an\n  // anonymous define() is called outside of a loader request.\n  if (typeof define == 'function' && define.amd) {\n    define('underscore', [], function() {\n      return _;\n    });\n  }\n}());\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/underscore/underscore.js\n// module id = 30\n// module chunks = 0 1","var g;\r\n\r\n// This works in non-strict mode\r\ng = (function() {\r\n\treturn this;\r\n})();\r\n\r\ntry {\r\n\t// This works if eval is allowed (see CSP)\r\n\tg = g || Function(\"return this\")() || (1,eval)(\"this\");\r\n} catch(e) {\r\n\t// This works if the window reference is available\r\n\tif(typeof window === \"object\")\r\n\t\tg = window;\r\n}\r\n\r\n// g can still be undefined, but nothing to do about it...\r\n// We return undefined, instead of nothing here, so it's\r\n// easier to handle this case. if(!global) { ...}\r\n\r\nmodule.exports = g;\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/global.js\n// module id = 31\n// module chunks = 0 1","module.exports = function(module) {\r\n\tif(!module.webpackPolyfill) {\r\n\t\tmodule.deprecate = function() {};\r\n\t\tmodule.paths = [];\r\n\t\t// module.parent = undefined by default\r\n\t\tif(!module.children) module.children = [];\r\n\t\tObject.defineProperty(module, \"loaded\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.l;\r\n\t\t\t}\r\n\t\t});\r\n\t\tObject.defineProperty(module, \"id\", {\r\n\t\t\tenumerable: true,\r\n\t\t\tget: function() {\r\n\t\t\t\treturn module.i;\r\n\t\t\t}\r\n\t\t});\r\n\t\tmodule.webpackPolyfill = 1;\r\n\t}\r\n\treturn module;\r\n};\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// (webpack)/buildin/module.js\n// module id = 32\n// module chunks = 0 1","/* eslint react/require-default-props: 0 */\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport Const from '../const';\nimport { BootstrapContext } from '../contexts/bootstrap';\nimport _ from '../utils';\n\nexport const CheckBox = ({ className, checked, indeterminate }) => (\n  <input\n    type=\"checkbox\"\n    checked={ checked }\n    className={ className }\n    ref={ (input) => {\n      if (input) input.indeterminate = indeterminate; // eslint-disable-line no-param-reassign\n    } }\n    onChange={ () => {} }\n  />\n);\n\nCheckBox.propTypes = {\n  checked: PropTypes.bool.isRequired,\n  indeterminate: PropTypes.bool.isRequired,\n  className: PropTypes.string\n};\n\nexport default class SelectionHeaderCell extends Component {\n  static propTypes = {\n    mode: PropTypes.string.isRequired,\n    checkedStatus: PropTypes.string,\n    onAllRowsSelect: PropTypes.func,\n    hideSelectAll: PropTypes.bool,\n    selectionHeaderRenderer: PropTypes.func,\n    headerColumnStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.func])\n  }\n\n  constructor() {\n    super();\n    this.handleCheckBoxClick = this.handleCheckBoxClick.bind(this);\n  }\n\n  /**\n   * avoid updating if button is\n   * 1. radio\n   * 2. status was not changed.\n   */\n  shouldComponentUpdate(nextProps) {\n    const { ROW_SELECT_SINGLE } = Const;\n    const { mode, checkedStatus } = this.props;\n\n    if (mode === ROW_SELECT_SINGLE) return false;\n\n    return nextProps.checkedStatus !== checkedStatus;\n  }\n\n  handleCheckBoxClick(e) {\n    const { onAllRowsSelect, checkedStatus } = this.props;\n    const isUnSelect =\n      checkedStatus === Const.CHECKBOX_STATUS_CHECKED ||\n      checkedStatus === Const.CHECKBOX_STATUS_INDETERMINATE;\n\n    onAllRowsSelect(e, isUnSelect);\n  }\n\n  render() {\n    const {\n      CHECKBOX_STATUS_CHECKED, CHECKBOX_STATUS_INDETERMINATE, ROW_SELECT_MULTIPLE\n    } = Const;\n\n    const {\n      mode,\n      checkedStatus,\n      selectionHeaderRenderer,\n      hideSelectAll,\n      headerColumnStyle\n    } = this.props;\n    if (hideSelectAll) {\n      return <th data-row-selection />;\n    }\n\n    const checked = checkedStatus === CHECKBOX_STATUS_CHECKED;\n\n    const indeterminate = checkedStatus === CHECKBOX_STATUS_INDETERMINATE;\n\n    const attrs = {};\n    let content;\n    if (selectionHeaderRenderer || mode === ROW_SELECT_MULTIPLE) {\n      attrs.onClick = this.handleCheckBoxClick;\n    }\n\n    attrs.style = _.isFunction(headerColumnStyle) ?\n      headerColumnStyle(checkedStatus) :\n      headerColumnStyle;\n\n    return (\n      <BootstrapContext.Consumer>\n        {\n          ({ bootstrap4 }) => {\n            if (selectionHeaderRenderer) {\n              content = selectionHeaderRenderer({\n                mode,\n                checked,\n                indeterminate\n              });\n            } else if (mode === ROW_SELECT_MULTIPLE) {\n              content = (\n                <CheckBox\n                  { ...this.props }\n                  checked={ checked }\n                  className={ bootstrap4 ? 'selection-input-4' : '' }\n                  indeterminate={ indeterminate }\n                />\n              );\n            }\n            return (\n              <th className=\"selection-cell-header\" data-row-selection { ...attrs }>{ content }</th>\n            );\n          }\n        }\n      </BootstrapContext.Consumer>\n    );\n  }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-selection/selection-header-cell.js","/* eslint react/require-default-props: 0 */\n/* eslint no-nested-ternary: 0 */\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\n\nexport default class ExpansionHeaderCell extends Component {\n  static propTypes = {\n    isAnyExpands: PropTypes.bool.isRequired,\n    onAllRowExpand: PropTypes.func.isRequired,\n    expandHeaderColumnRenderer: PropTypes.func\n  }\n\n  constructor() {\n    super();\n    this.handleCheckBoxClick = this.handleCheckBoxClick.bind(this);\n  }\n\n  handleCheckBoxClick(e) {\n    const { isAnyExpands, onAllRowExpand } = this.props;\n\n    onAllRowExpand(e, !isAnyExpands);\n  }\n\n  render() {\n    const { isAnyExpands, expandHeaderColumnRenderer } = this.props;\n    const attrs = {\n      onClick: this.handleCheckBoxClick\n    };\n\n    return (\n      <th className=\"expand-cell-header\" data-row-selection { ...attrs }>\n        {\n          expandHeaderColumnRenderer ?\n            expandHeaderColumnRenderer({ isAnyExpands }) :\n            (isAnyExpands ? '(-)' : '(+)')\n        }\n      </th>\n    );\n  }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-expand/expand-header-cell.js","import React from 'react';\nimport SelectionContext from '../contexts/selection-context';\n\nexport default Component => () => (\n  <SelectionContext.Consumer>\n    { selectRow => <Component { ...selectRow } /> }\n  </SelectionContext.Consumer>\n);\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-selection/selection-header-cell-consumer.js","import _ from '../utils';\nimport { getRowByRowId } from './rows';\n\nexport const isAnyExpands = (\n  data,\n  keyField,\n  expanded = []\n) => {\n  for (let i = 0; i < data.length; i += 1) {\n    const rowKey = _.get(data[i], keyField);\n    if (typeof expanded.find(x => x === rowKey) !== 'undefined') {\n      return true;\n    }\n  }\n  return false;\n};\n\nexport const expandableKeys = (data, keyField, skips = []) => {\n  if (skips.length === 0) {\n    return data.map(row => _.get(row, keyField));\n  }\n  return data\n    .filter(row => !_.contains(skips, _.get(row, keyField)))\n    .map(row => _.get(row, keyField));\n};\n\nexport const getExpandedRows = (data, keyField, expanded) =>\n  expanded.map(k => getRowByRowId(data, keyField, k));\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/store/expand.js","import _ from '../utils';\nimport { getRowByRowId } from './rows';\n\nexport const editCell = (data, keyField, rowId, dataField, newValue) => {\n  const row = getRowByRowId(data, keyField, rowId);\n  if (row) _.set(row, dataField, newValue);\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/store/mutate.js","/* eslint no-nested-ternary: 0 */\n/* eslint no-lonely-if: 0 */\n/* eslint no-underscore-dangle: 0 */\nimport _ from '../utils';\nimport Const from '../const';\n\nfunction comparator(a, b) {\n  let result;\n  if (typeof b === 'string') {\n    result = b.localeCompare(a);\n  } else {\n    result = a > b ? -1 : ((a < b) ? 1 : 0);\n  }\n  return result;\n}\n\nexport const sort = (data, sortOrder, { dataField, sortFunc, sortValue }) => {\n  const _data = [...data];\n  _data.sort((a, b) => {\n    let result;\n    let valueA = _.get(a, dataField);\n    let valueB = _.get(b, dataField);\n    if (sortValue) {\n      valueA = sortValue(valueA, a);\n      valueB = sortValue(valueB, b);\n    } else {\n      valueA = _.isDefined(valueA) ? valueA : '';\n      valueB = _.isDefined(valueB) ? valueB : '';\n    }\n\n    if (sortFunc) {\n      result = sortFunc(valueA, valueB, sortOrder, dataField, a, b);\n    } else {\n      if (sortOrder === Const.SORT_DESC) {\n        result = comparator(valueA, valueB);\n      } else {\n        result = comparator(valueB, valueA);\n      }\n    }\n    return result;\n  });\n  return _data;\n};\n\nexport const nextOrder = (\n  currentSortColumn,\n  { sortOrder, sortColumn },\n  defaultOrder = Const.SORT_DESC\n) => {\n  if (!sortColumn || currentSortColumn.dataField !== sortColumn.dataField) return defaultOrder;\n  return sortOrder === Const.SORT_DESC ? Const.SORT_ASC : Const.SORT_DESC;\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/store/sort.js","import Const from '../const';\n\nexport const typeConvert = (type, value) => {\n  if (type === Const.TYPE_STRING) {\n    return String(value);\n  } else if (type === Const.TYPE_NUMBER) {\n    return Number(value);\n  } else if (type === Const.TYPE_BOOLEAN) {\n    if (typeof value === 'boolean') {\n      return value;\n    }\n    return value === 'true';\n  } else if (type === Const.TYPE_DATE) {\n    return new Date(value);\n  }\n  return value;\n};\n\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/store/type.js","import React from 'react';\nimport ExpansionContext from '../contexts/row-expand-context';\n\nexport default Component => () => (\n  <ExpansionContext.Consumer>\n    { expandRow => <Component { ...expandRow } /> }\n  </ExpansionContext.Consumer>\n);\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-expand/expand-header-cell-consumer.js","/* eslint react/require-default-props: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nimport FiltersCell from './filters-cell';\nimport Const from './const';\nimport RowTemplate from './row/row-template';\n\nconst Filters = (props) => {\n  const {\n    columns,\n    onFilter,\n    currFilters,\n    filterPosition,\n    onExternalFilter,\n    className,\n    selectRow,\n    expandRow\n  } = props;\n\n  function renderContent() {\n    const filterColumns = [];\n    let showFiltersRow = false;\n\n    columns.forEach((column, i) => {\n      filterColumns.push(<FiltersCell\n        index={ i }\n        key={ column.dataField }\n        column={ column }\n        currFilters={ currFilters }\n        onExternalFilter={ onExternalFilter }\n        onFilter={ onFilter }\n      />);\n\n      if (column.filterRenderer || column.filter) {\n        if (!showFiltersRow) {\n          showFiltersRow = true;\n        }\n      }\n    });\n    return filterColumns;\n  }\n\n  return (\n    <tbody\n      className={ className }\n      style={ {\n        display:\n        filterPosition === Const.FILTERS_POSITION_TOP\n          ? 'table-header-group'\n          : 'table-footer-group'\n      } }\n    >\n      <RowTemplate\n        renderContent={ renderContent }\n        selectRow={ selectRow }\n        expandRow={ expandRow }\n        cellEl=\"td\"\n      />\n    </tbody>\n  );\n};\n\nFilters.propTypes = {\n  columns: PropTypes.array.isRequired,\n  onFilter: PropTypes.func,\n  filterPosition: PropTypes.oneOf([\n    Const.FILTERS_POSITION_TOP,\n    Const.FILTERS_POSITION_INLINE,\n    Const.FILTERS_POSITION_BOTTOM\n  ]),\n  currFilters: PropTypes.object,\n  onExternalFilter: PropTypes.func,\n  className: PropTypes.string,\n  selectRow: PropTypes.object,\n  expandRow: PropTypes.object\n};\n\nFilters.defaultProps = {\n  position: Const.FILTERS_POSITION_TOP\n};\n\nexport default Filters;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/filters.js","import React from 'react';\nimport PropTypes from 'prop-types';\nimport _ from './utils';\n\nconst FiltersCell = (props) => {\n  const {\n    index, column, onExternalFilter,\n    currFilters, onFilter\n  } = props;\n  const { filterRenderer, filter } = column;\n  let filterElm;\n  const cellAttrs = {};\n  const cellStyle = {};\n  cellAttrs.style = cellStyle;\n  if (column.headerAlign) {\n    cellStyle.textAlign = _.isFunction(column.headerAlign)\n      ? column.headerAlign(column, index)\n      : column.headerAlign;\n  }\n  if (column.filterRenderer) {\n    const onCustomFilter = onExternalFilter(column, filter.props.type);\n    filterElm = filterRenderer(onCustomFilter, column);\n  } else if (filter) {\n    filterElm = (\n      <filter.Filter\n        { ...filter.props }\n        filterState={ currFilters[column.dataField] }\n        onFilter={ onFilter }\n        column={ column }\n      />\n    );\n  }\n  return React.createElement('th', cellAttrs, filterElm);\n};\n\nFiltersCell.propTypes = {\n  index: PropTypes.number.isRequired,\n  column: PropTypes.object.isRequired,\n  currFilters: PropTypes.object.isRequired,\n  onFilter: PropTypes.func,\n  onExternalFilter: PropTypes.func\n};\n\nFiltersCell.defaultProps = {\n  onFilter: () => { },\n  onExternalFilter: () => { }\n};\n\nexport default FiltersCell;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/filters-cell.js","/* eslint react/require-default-props: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nconst Caption = (props) => {\n  if (!props.children) return null;\n\n  const caption = props.bootstrap4 ? (\n    <caption style={ { captionSide: 'top' } }>{props.children}</caption>\n  ) : (\n    <caption>{props.children}</caption>\n  );\n\n  return caption;\n};\n\nCaption.propTypes = {\n  children: PropTypes.oneOfType([\n    PropTypes.node,\n    PropTypes.string\n  ]),\n  bootstrap4: PropTypes.bool\n};\n\nexport default Caption;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/caption.js","/* eslint react/prop-types: 0 */\n/* eslint react/require-default-props: 0 */\n\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nimport _ from './utils';\nimport SimpleRow from './row/simple-row';\nimport RowAggregator from './row/aggregate-row';\nimport RowSection from './row/row-section';\nimport Const from './const';\nimport withRowSelection from './row-selection/row-consumer';\nimport withRowExpansion from './row-expand/row-consumer';\n\nclass Body extends React.Component {\n  constructor(props) {\n    super(props);\n    const {\n      keyField,\n      cellEdit,\n      selectRow,\n      expandRow\n    } = props;\n\n    // Construct Editing Cell Component\n    if (cellEdit.createContext) {\n      this.EditingCell = cellEdit.createEditingCell(_, cellEdit.options.onStartEdit);\n    }\n\n    // Construct Row Component\n    let RowComponent = SimpleRow;\n    const selectRowEnabled = selectRow.mode !== Const.ROW_SELECT_DISABLED;\n    const expandRowEnabled = !!expandRow.renderer;\n\n    if (expandRowEnabled) {\n      RowComponent = withRowExpansion(RowAggregator);\n    }\n\n    if (selectRowEnabled) {\n      RowComponent = withRowSelection(expandRowEnabled ? RowComponent : RowAggregator);\n    }\n\n    if (cellEdit.createContext) {\n      RowComponent = cellEdit.withRowLevelCellEdit(RowComponent, selectRowEnabled, keyField, _);\n    }\n    this.RowComponent = RowComponent;\n  }\n\n  render() {\n    const {\n      columns,\n      data,\n      tabIndexCell,\n      keyField,\n      isEmpty,\n      noDataIndication,\n      visibleColumnSize,\n      cellEdit,\n      selectRow,\n      rowStyle,\n      rowClasses,\n      rowEvents,\n      expandRow,\n      className\n    } = this.props;\n\n    let content;\n\n    if (isEmpty) {\n      const indication = _.isFunction(noDataIndication) ? noDataIndication() : noDataIndication;\n      if (!indication) {\n        return null;\n      }\n      content = <RowSection content={ indication } colSpan={ visibleColumnSize } />;\n    } else {\n      const selectRowEnabled = selectRow.mode !== Const.ROW_SELECT_DISABLED;\n      const expandRowEnabled = !!expandRow.renderer;\n\n      const additionalRowProps = {};\n\n      if (cellEdit.createContext) {\n        additionalRowProps.EditingCellComponent = this.EditingCell;\n      }\n\n      if (selectRowEnabled || expandRowEnabled) {\n        additionalRowProps.expandRow = expandRow;\n        additionalRowProps.selectRow = selectRow;\n      }\n\n      content = data.map((row, index) => {\n        const key = _.get(row, keyField);\n        const baseRowProps = {\n          key,\n          row,\n          tabIndexCell,\n          columns,\n          keyField,\n          cellEdit,\n          value: key,\n          rowIndex: index,\n          visibleColumnSize,\n          attrs: rowEvents || {},\n          ...additionalRowProps\n        };\n\n        baseRowProps.style = _.isFunction(rowStyle) ? rowStyle(row, index) : rowStyle;\n        baseRowProps.className = (_.isFunction(rowClasses) ? rowClasses(row, index) : rowClasses);\n\n        return <this.RowComponent { ...baseRowProps } />;\n      });\n    }\n\n    return (\n      <tbody className={ className }>{ content }</tbody>\n    );\n  }\n}\n\nBody.propTypes = {\n  keyField: PropTypes.string.isRequired,\n  data: PropTypes.array.isRequired,\n  columns: PropTypes.array.isRequired,\n  selectRow: PropTypes.object\n};\n\nexport default Body;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/body.js","/* eslint react/prop-types: 0 */\n/* eslint react/no-array-index-key: 0 */\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\n\nimport RowPureContent from './row-pure-content';\nimport eventDelegater from './event-delegater';\nimport shouldUpdater from './should-updater';\n\nclass SimpleRow extends shouldUpdater(eventDelegater(Component)) {\n  constructor(props) {\n    super(props);\n    this.shouldUpdateRowContent = false;\n  }\n\n  shouldComponentUpdate(nextProps) {\n    this.shouldUpdateRowContent = false;\n    this.shouldUpdateRowContent = this.shouldRowContentUpdate(nextProps);\n    if (this.shouldUpdateRowContent) return true;\n\n    return this.shouldUpdatedBySelfProps(nextProps);\n  }\n\n  render() {\n    const {\n      className,\n      style,\n      attrs,\n      visibleColumnSize,\n      tabIndexCell,\n      ...rest\n    } = this.props;\n    const trAttrs = this.delegate(attrs);\n    const tabIndexStart = (this.props.rowIndex * visibleColumnSize) + 1;\n\n    return (\n      <tr style={ style } className={ className } { ...trAttrs }>\n        <RowPureContent\n          shouldUpdate={ this.shouldUpdateRowContent }\n          tabIndexStart={ tabIndexCell ? tabIndexStart : -1 }\n          { ...rest }\n        />\n      </tr>\n    );\n  }\n}\n\nSimpleRow.propTypes = {\n  row: PropTypes.object.isRequired,\n  rowIndex: PropTypes.number.isRequired,\n  columns: PropTypes.array.isRequired,\n  style: PropTypes.object,\n  className: PropTypes.string,\n  attrs: PropTypes.object\n};\n\nSimpleRow.defaultProps = {\n  editable: true,\n  style: {},\n  className: null,\n  attrs: {}\n};\n\nexport default SimpleRow;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row/simple-row.js","/* eslint react/prop-types: 0 */\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\n\nimport eventDelegater from './cell-event-delegater';\nimport _ from './utils';\n\nclass Cell extends eventDelegater(Component) {\n  constructor(props) {\n    super(props);\n    this.createHandleEditingCell = this.createHandleEditingCell.bind(this);\n  }\n\n  shouldComponentUpdate(nextProps) {\n    let shouldUpdate = false;\n    if (nextProps.column.isDummyField) {\n      shouldUpdate = !_.isEqual(this.props.row, nextProps.row);\n    } else {\n      shouldUpdate =\n        _.get(this.props.row, this.props.column.dataField)\n          !== _.get(nextProps.row, nextProps.column.dataField);\n    }\n\n    if (shouldUpdate) return true;\n\n    // if (nextProps.formatter)\n\n    shouldUpdate =\n      (nextProps.column.formatter ? !_.isEqual(this.props.row, nextProps.row) : false) ||\n      this.props.column.hidden !== nextProps.column.hidden ||\n      this.props.column.isDummyField !== nextProps.column.isDummyField ||\n      this.props.rowIndex !== nextProps.rowIndex ||\n      this.props.columnIndex !== nextProps.columnIndex ||\n      this.props.className !== nextProps.className ||\n      this.props.title !== nextProps.title ||\n      this.props.editable !== nextProps.editable ||\n      this.props.clickToEdit !== nextProps.clickToEdit ||\n      this.props.dbclickToEdit !== nextProps.dbclickToEdit ||\n      !_.isEqual(this.props.style, nextProps.style) ||\n      !_.isEqual(this.props.column.formatExtraData, nextProps.column.formatExtraData) ||\n      !_.isEqual(this.props.column.events, nextProps.column.events) ||\n      !_.isEqual(this.props.column.attrs, nextProps.column.attrs) ||\n      this.props.tabIndex !== nextProps.tabIndex;\n    return shouldUpdate;\n  }\n\n  createHandleEditingCell = originFunc => (e) => {\n    const { onStart, rowIndex, columnIndex, clickToEdit, dbclickToEdit } = this.props;\n    if ((clickToEdit || dbclickToEdit) && _.isFunction(originFunc)) {\n      originFunc(e);\n    }\n    if (onStart) {\n      onStart(rowIndex, columnIndex);\n    }\n  }\n\n  render() {\n    const {\n      row,\n      rowIndex,\n      column,\n      columnIndex,\n      onStart,\n      editable,\n      clickToEdit,\n      dbclickToEdit,\n      ...rest\n    } = this.props;\n    const {\n      dataField,\n      formatter,\n      formatExtraData\n    } = column;\n    const attrs = this.delegate({ ...rest });\n    let content = column.isDummyField ? null : _.get(row, dataField);\n\n    if (formatter) {\n      content = column.formatter(content, row, rowIndex, formatExtraData);\n    }\n\n    if (clickToEdit && editable) {\n      attrs.onClick = this.createHandleEditingCell(attrs.onClick);\n    } else if (dbclickToEdit && editable) {\n      attrs.onDoubleClick = this.createHandleEditingCell(attrs.onDoubleClick);\n    }\n\n    return (\n      <td { ...attrs }>\n        { typeof content === 'boolean' ? `${content}` : content }\n      </td>\n    );\n  }\n}\n\nCell.propTypes = {\n  row: PropTypes.object.isRequired,\n  rowIndex: PropTypes.number.isRequired,\n  column: PropTypes.object.isRequired,\n  columnIndex: PropTypes.number.isRequired\n};\n\nexport default Cell;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/cell.js","/* eslint class-methods-use-this: 0 */\n/* eslint react/prop-types: 0 */\n/* eslint no-plusplus: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport _ from '../utils';\nimport ExpandCell from '../row-expand/expand-cell';\nimport SelectionCell from '../row-selection/selection-cell';\nimport shouldUpdater from './should-updater';\nimport eventDelegater from './event-delegater';\nimport RowPureContent from './row-pure-content';\nimport Const from '../const';\n\nexport default class RowAggregator extends shouldUpdater(eventDelegater(React.Component)) {\n  static propTypes = {\n    attrs: PropTypes.object,\n    style: PropTypes.object\n  }\n\n  static defaultProps = {\n    attrs: {},\n    style: {}\n  }\n\n  constructor(props) {\n    super(props);\n    this.clickNum = 0;\n    this.shouldUpdateRowContent = false;\n    this.createClickEventHandler = this.createClickEventHandler.bind(this);\n  }\n\n  shouldComponentUpdate(nextProps) {\n    if (\n      this.props.selected !== nextProps.selected ||\n      this.props.expanded !== nextProps.expanded ||\n      this.props.expandable !== nextProps.expandable ||\n      this.props.selectable !== nextProps.selectable ||\n      this.props.selectRow.hideSelectColumn !== nextProps.selectRow.hideSelectColumn ||\n      this.shouldUpdatedBySelfProps(nextProps)\n    ) {\n      this.shouldUpdateRowContent = this.shouldRowContentUpdate(nextProps);\n      return true;\n    }\n    this.shouldUpdateRowContent = this.shouldRowContentUpdate(nextProps);\n\n    return this.shouldUpdateRowContent;\n  }\n\n  isRenderFunctionColumnInLeft(\n    position = Const.INDICATOR_POSITION_LEFT\n  ) {\n    return position === Const.INDICATOR_POSITION_LEFT;\n  }\n\n  render() {\n    const {\n      row,\n      columns,\n      keyField,\n      rowIndex,\n      style,\n      className,\n      attrs,\n      selectRow,\n      expandRow,\n      expanded,\n      expandable,\n      selected,\n      selectable,\n      visibleColumnSize,\n      tabIndexCell,\n      ...rest\n    } = this.props;\n    const key = _.get(row, keyField);\n    const { hideSelectColumn, selectColumnPosition, clickToSelect } = selectRow;\n    const { showExpandColumn, expandColumnPosition } = expandRow;\n\n    const newAttrs = this.delegate({ ...attrs });\n    if (clickToSelect || !!expandRow.renderer) {\n      newAttrs.onClick = this.createClickEventHandler(newAttrs.onClick);\n    }\n\n    let tabIndexStart = (rowIndex * visibleColumnSize) + 1;\n\n    const childrens = [(\n      <RowPureContent\n        key=\"row\"\n        row={ row }\n        columns={ columns }\n        keyField={ keyField }\n        rowIndex={ rowIndex }\n        shouldUpdate={ this.shouldUpdateRowContent }\n        tabIndexStart={ tabIndexCell ? tabIndexStart : -1 }\n        { ...rest }\n      />\n    )];\n\n    if (!hideSelectColumn) {\n      const selectCell = (\n        <SelectionCell\n          { ...selectRow }\n          key=\"selection-cell\"\n          rowKey={ key }\n          rowIndex={ rowIndex }\n          selected={ selected }\n          disabled={ !selectable }\n          tabIndex={ tabIndexCell ? tabIndexStart++ : -1 }\n        />\n      );\n      if (this.isRenderFunctionColumnInLeft(selectColumnPosition)) {\n        childrens.unshift(selectCell);\n      } else {\n        childrens.push(selectCell);\n      }\n    }\n\n    if (showExpandColumn) {\n      const expandCell = (\n        <ExpandCell\n          { ...expandRow }\n          key=\"expand-cell\"\n          rowKey={ key }\n          rowIndex={ rowIndex }\n          expanded={ expanded }\n          expandable={ expandable }\n          tabIndex={ tabIndexCell ? tabIndexStart++ : -1 }\n        />\n      );\n      if (this.isRenderFunctionColumnInLeft(expandColumnPosition)) {\n        childrens.unshift(expandCell);\n      } else {\n        childrens.push(expandCell);\n      }\n    }\n\n    return (\n      <tr\n        style={ style }\n        className={ className }\n        { ...newAttrs }\n      >\n        { childrens }\n      </tr>\n    );\n  }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row/aggregate-row.js","/* eslint\n  react/require-default-props: 0\n  jsx-a11y/no-noninteractive-element-interactions: 0\n*/\n/* eslint no-nested-ternary: 0 */\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\n\nexport default class ExpandCell extends Component {\n  static propTypes = {\n    rowKey: PropTypes.any,\n    expanded: PropTypes.bool.isRequired,\n    expandable: PropTypes.bool.isRequired,\n    onRowExpand: PropTypes.func.isRequired,\n    expandColumnRenderer: PropTypes.func,\n    rowIndex: PropTypes.number,\n    tabIndex: PropTypes.number\n  }\n\n  constructor() {\n    super();\n    this.handleClick = this.handleClick.bind(this);\n  }\n\n  shouldComponentUpdate(nextProps) {\n    const shouldUpdate =\n      this.props.rowIndex !== nextProps.rowIndex ||\n      this.props.expanded !== nextProps.expanded ||\n      this.props.rowKey !== nextProps.rowKey ||\n      this.props.tabIndex !== nextProps.tabIndex;\n\n    return shouldUpdate;\n  }\n\n  handleClick(e) {\n    const { rowKey, expanded, onRowExpand, rowIndex } = this.props;\n    e.stopPropagation();\n    onRowExpand(rowKey, !expanded, rowIndex, e);\n  }\n\n  render() {\n    const { expanded, expandable, expandColumnRenderer, tabIndex, rowKey } = this.props;\n    const attrs = {};\n    if (tabIndex !== -1) attrs.tabIndex = tabIndex;\n\n    return (\n      <td className=\"expand-cell\" onClick={ this.handleClick } { ...attrs }>\n        {\n          expandColumnRenderer ? expandColumnRenderer({\n            expandable,\n            expanded,\n            rowKey\n          }) : (expandable ? (expanded ? '(-)' : '(+)') : '')\n        }\n      </td>\n    );\n  }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-expand/expand-cell.js","/* eslint\n  react/require-default-props: 0\n  jsx-a11y/no-noninteractive-element-interactions: 0\n*/\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\nimport Const from '../const';\nimport _ from '../utils';\nimport { BootstrapContext } from '../contexts/bootstrap';\n\nexport default class SelectionCell extends Component {\n  static propTypes = {\n    mode: PropTypes.string.isRequired,\n    rowKey: PropTypes.any,\n    selected: PropTypes.bool,\n    onRowSelect: PropTypes.func,\n    disabled: PropTypes.bool,\n    rowIndex: PropTypes.number,\n    tabIndex: PropTypes.number,\n    clickToSelect: PropTypes.bool,\n    selectionRenderer: PropTypes.func,\n    selectColumnStyle: PropTypes.oneOfType([PropTypes.object, PropTypes.func])\n  }\n\n  constructor() {\n    super();\n    this.handleClick = this.handleClick.bind(this);\n  }\n\n  shouldComponentUpdate(nextProps) {\n    const shouldUpdate =\n      this.props.rowIndex !== nextProps.rowIndex ||\n      this.props.selected !== nextProps.selected ||\n      this.props.disabled !== nextProps.disabled ||\n      this.props.rowKey !== nextProps.rowKey ||\n      this.props.tabIndex !== nextProps.tabIndex ||\n      this.props.selectColumnStyle !== nextProps.selectColumnStyle;\n\n    return shouldUpdate;\n  }\n\n  handleClick(e) {\n    const {\n      mode: inputType,\n      rowKey,\n      selected,\n      onRowSelect,\n      disabled,\n      rowIndex\n    } = this.props;\n    e.stopPropagation();\n    if (disabled) return;\n\n    const checked = inputType === Const.ROW_SELECT_SINGLE\n      ? true\n      : !selected;\n\n    onRowSelect(rowKey, checked, rowIndex, e);\n  }\n\n  render() {\n    const {\n      rowKey,\n      mode: inputType,\n      selected,\n      disabled,\n      tabIndex,\n      rowIndex,\n      selectionRenderer,\n      selectColumnStyle\n    } = this.props;\n\n    const attrs = {};\n    if (tabIndex !== -1) attrs.tabIndex = tabIndex;\n\n    attrs.style = _.isFunction(selectColumnStyle) ?\n      selectColumnStyle({\n        checked: selected,\n        disabled,\n        rowIndex,\n        rowKey\n      }) :\n      selectColumnStyle;\n\n    return (\n      <BootstrapContext.Consumer>\n        {\n          ({ bootstrap4 }) => (\n            <td className=\"selection-cell\" onClick={ this.handleClick } { ...attrs }>\n              {\n                selectionRenderer ? selectionRenderer({\n                  mode: inputType,\n                  checked: selected,\n                  disabled,\n                  rowIndex\n                }) : (\n                  <input\n                    type={ inputType }\n                    checked={ selected }\n                    disabled={ disabled }\n                    className={ bootstrap4 ? 'selection-input-4' : '' }\n                    onChange={ () => {} }\n                  />\n                )\n              }\n            </td>\n          )\n        }\n      </BootstrapContext.Consumer>\n    );\n  }\n}\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-selection/selection-cell.js","import React from 'react';\nimport PropTypes from 'prop-types';\n\nconst RowSection = ({ content, colSpan }) => (\n  <tr>\n    <td\n      data-toggle=\"collapse\"\n      colSpan={ colSpan }\n      className=\"react-bs-table-no-data\"\n    >\n      { content }\n    </td>\n  </tr>\n);\n\nRowSection.propTypes = {\n  content: PropTypes.any,\n  colSpan: PropTypes.number\n};\n\nRowSection.defaultProps = {\n  content: null,\n  colSpan: 1\n};\n\nexport default RowSection;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row/row-section.js","/* eslint react/prop-types: 0 */\nimport React from 'react';\nimport cs from 'classnames';\nimport _ from '../utils';\nimport SelectionContext from '../contexts/selection-context';\n\nexport default (Component) => {\n  const renderWithSelection = (props, selectRow) => {\n    const key = props.value;\n    const selected = _.contains(selectRow.selected, key);\n    const selectable = !selectRow.nonSelectable || !_.contains(selectRow.nonSelectable, key);\n    const notSelectable = _.contains(selectRow.nonSelectable, key);\n\n    let {\n      style,\n      className\n    } = props;\n\n    if (selected) {\n      const selectedStyle = _.isFunction(selectRow.style)\n        ? selectRow.style(props.row, props.rowIndex)\n        : selectRow.style;\n\n      const selectedClasses = _.isFunction(selectRow.classes)\n        ? selectRow.classes(props.row, props.rowIndex)\n        : selectRow.classes;\n\n      style = {\n        ...style,\n        ...selectedStyle\n      };\n      className = cs(className, selectedClasses) || undefined;\n\n      if (selectRow.bgColor) {\n        style = style || {};\n        style.backgroundColor = _.isFunction(selectRow.bgColor)\n          ? selectRow.bgColor(props.row, props.rowIndex)\n          : selectRow.bgColor;\n      }\n    }\n\n    if (notSelectable) {\n      const notSelectableStyle = _.isFunction(selectRow.nonSelectableStyle)\n        ? selectRow.nonSelectableStyle(props.row, props.rowIndex)\n        : selectRow.nonSelectableStyle;\n\n      const notSelectableClasses = _.isFunction(selectRow.nonSelectableClasses)\n        ? selectRow.nonSelectableClasses(props.row, props.rowIndex)\n        : selectRow.nonSelectableClasses;\n\n      style = {\n        ...style,\n        ...notSelectableStyle\n      };\n      className = cs(className, notSelectableClasses) || undefined;\n    }\n\n    return (\n      <Component\n        { ...props }\n        style={ style }\n        className={ className }\n        selectRow={ selectRow }\n        selected={ selected }\n        selectable={ selectable }\n      />\n    );\n  };\n\n  function withConsumer(props) {\n    return (\n      <SelectionContext.Consumer>\n        { selectRow => renderWithSelection(props, selectRow) }\n      </SelectionContext.Consumer>\n    );\n  }\n\n  withConsumer.displayName = 'WithSelectionRowConsumer';\n  return withConsumer;\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-selection/row-consumer.js","/* eslint react/prop-types: 0 */\nimport React from 'react';\nimport cs from 'classnames';\nimport ExpandRow from './expand-row';\nimport _ from '../utils';\nimport ExpansionContext from '../contexts/row-expand-context';\n\nexport default (Component) => {\n  const renderWithExpansion = (props, expandRow) => {\n    let parentClassName = '';\n    let className = '';\n    const key = props.value;\n\n    const expanded = _.contains(expandRow.expanded, key);\n    const isClosing = _.contains(expandRow.isClosing, key);\n    const expandable = !expandRow.nonExpandable || !_.contains(expandRow.nonExpandable, key);\n    if (expanded) {\n      parentClassName = _.isFunction(expandRow.parentClassName) ?\n        expandRow.parentClassName(expanded, props.row, props.rowIndex) :\n        (expandRow.parentClassName || '');\n\n      className = _.isFunction(expandRow.className) ?\n        expandRow.className(expanded, props.row, props.rowIndex) :\n        (expandRow.className || '');\n    }\n\n    return [\n      <Component\n        { ...props }\n        key={ key }\n        expanded={ expanded }\n        expandable={ expandable }\n        expandRow={ { ...expandRow } }\n        className={ cs(props.className, parentClassName) }\n      />,\n      expanded || isClosing ? <ExpandRow\n        key={ `${key}-expanding` }\n        colSpan={ props.visibleColumnSize }\n        expanded={ expanded }\n        onClosed={ () => expandRow.onClosed(key) }\n        className={ className }\n      >\n        { expandRow.renderer(props.row, props.rowIndex) }\n      </ExpandRow> : null\n    ];\n  };\n  return props => (\n    <ExpansionContext.Consumer>\n      { expandRow => renderWithExpansion(props, expandRow) }\n    </ExpansionContext.Consumer>\n  );\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-expand/row-consumer.js","import cs from 'classnames';\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport { CSSTransition } from 'react-transition-group';\n\nconst ExpandRow = ({ children, expanded, onClosed, className, ...rest }) => (\n  <tr>\n    <td className={ cs('reset-expansion-style', className) } { ...rest }>\n      <CSSTransition\n        appear\n        in={ expanded }\n        timeout={ 400 }\n        classNames=\"row-expand-slide\"\n        onExited={ onClosed }\n      >\n        <div>\n          <div className=\"row-expansion-style\">\n            { children }\n          </div>\n        </div>\n      </CSSTransition>\n    </td>\n  </tr>\n);\n\nExpandRow.propTypes = {\n  children: PropTypes.node,\n  expanded: PropTypes.bool,\n  onClosed: PropTypes.func,\n  className: PropTypes.string\n};\n\nExpandRow.defaultProps = {\n  children: null,\n  expanded: false,\n  onClosed: null,\n  className: ''\n};\n\nexport default ExpandRow;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/row-expand/expand-row.js","\"use strict\";\n\nvar _CSSTransition = _interopRequireDefault(require(\"./CSSTransition\"));\n\nvar _ReplaceTransition = _interopRequireDefault(require(\"./ReplaceTransition\"));\n\nvar _TransitionGroup = _interopRequireDefault(require(\"./TransitionGroup\"));\n\nvar _Transition = _interopRequireDefault(require(\"./Transition\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nmodule.exports = {\n  Transition: _Transition.default,\n  TransitionGroup: _TransitionGroup.default,\n  ReplaceTransition: _ReplaceTransition.default,\n  CSSTransition: _CSSTransition.default\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/react-transition-group/index.js\n// module id = 54\n// module chunks = 0 1","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar PropTypes = _interopRequireWildcard(require(\"prop-types\"));\n\nvar _addClass = _interopRequireDefault(require(\"dom-helpers/class/addClass\"));\n\nvar _removeClass = _interopRequireDefault(require(\"dom-helpers/class/removeClass\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _Transition = _interopRequireDefault(require(\"./Transition\"));\n\nvar _PropTypes = require(\"./utils/PropTypes\");\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } else { var newObj = {}; if (obj != null) { for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = Object.defineProperty && Object.getOwnPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : {}; if (desc.get || desc.set) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj.default = obj; return newObj; } }\n\nfunction _extends() { _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; }; return _extends.apply(this, arguments); }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\nvar addClass = function addClass(node, classes) {\n  return node && classes && classes.split(' ').forEach(function (c) {\n    return (0, _addClass.default)(node, c);\n  });\n};\n\nvar removeClass = function removeClass(node, classes) {\n  return node && classes && classes.split(' ').forEach(function (c) {\n    return (0, _removeClass.default)(node, c);\n  });\n};\n/**\n * A `Transition` component using CSS transitions and animations.\n * It's inspired by the excellent [ng-animate](http://www.nganimate.org/) library.\n *\n * `CSSTransition` applies a pair of class names during the `appear`, `enter`,\n * and `exit` stages of the transition. The first class is applied and then a\n * second \"active\" class in order to activate the css animation. After the animation,\n * matching `done` class names are applied to persist the animation state.\n *\n * When the `in` prop is toggled to `true` the Component will get\n * the `example-enter` CSS class and the `example-enter-active` CSS class\n * added in the next tick. This is a convention based on the `classNames` prop.\n */\n\n\nvar CSSTransition =\n/*#__PURE__*/\nfunction (_React$Component) {\n  _inheritsLoose(CSSTransition, _React$Component);\n\n  function CSSTransition() {\n    var _this;\n\n    for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {\n      args[_key] = arguments[_key];\n    }\n\n    _this = _React$Component.call.apply(_React$Component, [this].concat(args)) || this;\n\n    _this.onEnter = function (node, appearing) {\n      var _this$getClassNames = _this.getClassNames(appearing ? 'appear' : 'enter'),\n          className = _this$getClassNames.className;\n\n      _this.removeClasses(node, 'exit');\n\n      addClass(node, className);\n\n      if (_this.props.onEnter) {\n        _this.props.onEnter(node, appearing);\n      }\n    };\n\n    _this.onEntering = function (node, appearing) {\n      var _this$getClassNames2 = _this.getClassNames(appearing ? 'appear' : 'enter'),\n          activeClassName = _this$getClassNames2.activeClassName;\n\n      _this.reflowAndAddClass(node, activeClassName);\n\n      if (_this.props.onEntering) {\n        _this.props.onEntering(node, appearing);\n      }\n    };\n\n    _this.onEntered = function (node, appearing) {\n      var _this$getClassNames3 = _this.getClassNames('enter'),\n          doneClassName = _this$getClassNames3.doneClassName;\n\n      _this.removeClasses(node, appearing ? 'appear' : 'enter');\n\n      addClass(node, doneClassName);\n\n      if (_this.props.onEntered) {\n        _this.props.onEntered(node, appearing);\n      }\n    };\n\n    _this.onExit = function (node) {\n      var _this$getClassNames4 = _this.getClassNames('exit'),\n          className = _this$getClassNames4.className;\n\n      _this.removeClasses(node, 'appear');\n\n      _this.removeClasses(node, 'enter');\n\n      addClass(node, className);\n\n      if (_this.props.onExit) {\n        _this.props.onExit(node);\n      }\n    };\n\n    _this.onExiting = function (node) {\n      var _this$getClassNames5 = _this.getClassNames('exit'),\n          activeClassName = _this$getClassNames5.activeClassName;\n\n      _this.reflowAndAddClass(node, activeClassName);\n\n      if (_this.props.onExiting) {\n        _this.props.onExiting(node);\n      }\n    };\n\n    _this.onExited = function (node) {\n      var _this$getClassNames6 = _this.getClassNames('exit'),\n          doneClassName = _this$getClassNames6.doneClassName;\n\n      _this.removeClasses(node, 'exit');\n\n      addClass(node, doneClassName);\n\n      if (_this.props.onExited) {\n        _this.props.onExited(node);\n      }\n    };\n\n    _this.getClassNames = function (type) {\n      var classNames = _this.props.classNames;\n      var className = typeof classNames !== 'string' ? classNames[type] : classNames + '-' + type;\n      var activeClassName = typeof classNames !== 'string' ? classNames[type + 'Active'] : className + '-active';\n      var doneClassName = typeof classNames !== 'string' ? classNames[type + 'Done'] : className + '-done';\n      return {\n        className: className,\n        activeClassName: activeClassName,\n        doneClassName: doneClassName\n      };\n    };\n\n    return _this;\n  }\n\n  var _proto = CSSTransition.prototype;\n\n  _proto.removeClasses = function removeClasses(node, type) {\n    var _this$getClassNames7 = this.getClassNames(type),\n        className = _this$getClassNames7.className,\n        activeClassName = _this$getClassNames7.activeClassName,\n        doneClassName = _this$getClassNames7.doneClassName;\n\n    className && removeClass(node, className);\n    activeClassName && removeClass(node, activeClassName);\n    doneClassName && removeClass(node, doneClassName);\n  };\n\n  _proto.reflowAndAddClass = function reflowAndAddClass(node, className) {\n    // This is for to force a repaint,\n    // which is necessary in order to transition styles when adding a class name.\n    if (className) {\n      /* eslint-disable no-unused-expressions */\n      node && node.scrollTop;\n      /* eslint-enable no-unused-expressions */\n\n      addClass(node, className);\n    }\n  };\n\n  _proto.render = function render() {\n    var props = _extends({}, this.props);\n\n    delete props.classNames;\n    return _react.default.createElement(_Transition.default, _extends({}, props, {\n      onEnter: this.onEnter,\n      onEntered: this.onEntered,\n      onEntering: this.onEntering,\n      onExit: this.onExit,\n      onExiting: this.onExiting,\n      onExited: this.onExited\n    }));\n  };\n\n  return CSSTransition;\n}(_react.default.Component);\n\nCSSTransition.propTypes = process.env.NODE_ENV !== \"production\" ? _extends({}, _Transition.default.propTypes, {\n  /**\n   * The animation classNames applied to the component as it enters, exits or has finished the transition.\n   * A single name can be provided and it will be suffixed for each stage: e.g.\n   *\n   * `classNames=\"fade\"` applies `fade-enter`, `fade-enter-active`, `fade-enter-done`,\n   * `fade-exit`, `fade-exit-active`, `fade-exit-done`, `fade-appear`, and `fade-appear-active`.\n   * Each individual classNames can also be specified independently like:\n   *\n   * ```js\n   * classNames={{\n   *  appear: 'my-appear',\n   *  appearActive: 'my-active-appear',\n   *  enter: 'my-enter',\n   *  enterActive: 'my-active-enter',\n   *  enterDone: 'my-done-enter',\n   *  exit: 'my-exit',\n   *  exitActive: 'my-active-exit',\n   *  exitDone: 'my-done-exit',\n   * }}\n   * ```\n   *\n   * If you want to set these classes using CSS Modules:\n   *\n   * ```js\n   * import styles from './styles.css';\n   * ```\n   *\n   * you might want to use camelCase in your CSS file, that way could simply spread\n   * them instead of listing them one by one:\n   *\n   * ```js\n   * classNames={{ ...styles }}\n   * ```\n   *\n   * @type {string | {\n   *  appear?: string,\n   *  appearActive?: string,\n   *  enter?: string,\n   *  enterActive?: string,\n   *  enterDone?: string,\n   *  exit?: string,\n   *  exitActive?: string,\n   *  exitDone?: string,\n   * }}\n   */\n  classNames: _PropTypes.classNamesShape,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'enter' or 'appear' class is\n   * applied.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool)\n   */\n  onEnter: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'enter-active' or\n   * 'appear-active' class is applied.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool)\n   */\n  onEntering: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'enter' or\n   * 'appear' classes are **removed** and the `done` class is added to the DOM node.\n   *\n   * @type Function(node: HtmlElement, isAppearing: bool)\n   */\n  onEntered: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'exit' class is\n   * applied.\n   *\n   * @type Function(node: HtmlElement)\n   */\n  onExit: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'exit-active' is applied.\n   *\n   * @type Function(node: HtmlElement)\n   */\n  onExiting: PropTypes.func,\n\n  /**\n   * A `<Transition>` callback fired immediately after the 'exit' classes\n   * are **removed** and the `exit-done` class is added to the DOM node.\n   *\n   * @type Function(node: HtmlElement)\n   */\n  onExited: PropTypes.func\n}) : {};\nvar _default = CSSTransition;\nexports.default = _default;\nmodule.exports = exports[\"default\"];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/react-transition-group/CSSTransition.js\n// module id = 55\n// module chunks = 0 1","\"use strict\";\n\nvar _interopRequireDefault = require(\"@babel/runtime/helpers/interopRequireDefault\");\n\nexports.__esModule = true;\nexports.default = addClass;\n\nvar _hasClass = _interopRequireDefault(require(\"./hasClass\"));\n\nfunction addClass(element, className) {\n  if (element.classList) element.classList.add(className);else if (!(0, _hasClass.default)(element, className)) if (typeof element.className === 'string') element.className = element.className + ' ' + className;else element.setAttribute('class', (element.className && element.className.baseVal || '') + ' ' + className);\n}\n\nmodule.exports = exports[\"default\"];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/dom-helpers/class/addClass.js\n// module id = 56\n// module chunks = 0 1","function _interopRequireDefault(obj) {\n  return obj && obj.__esModule ? obj : {\n    \"default\": obj\n  };\n}\n\nmodule.exports = _interopRequireDefault;\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/@babel/runtime/helpers/interopRequireDefault.js\n// module id = 57\n// module chunks = 0 1","\"use strict\";\n\nexports.__esModule = true;\nexports.default = hasClass;\n\nfunction hasClass(element, className) {\n  if (element.classList) return !!className && element.classList.contains(className);else return (\" \" + (element.className.baseVal || element.className) + \" \").indexOf(\" \" + className + \" \") !== -1;\n}\n\nmodule.exports = exports[\"default\"];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/dom-helpers/class/hasClass.js\n// module id = 58\n// module chunks = 0 1","'use strict';\n\nfunction replaceClassName(origClass, classToRemove) {\n  return origClass.replace(new RegExp('(^|\\\\s)' + classToRemove + '(?:\\\\s|$)', 'g'), '$1').replace(/\\s+/g, ' ').replace(/^\\s*|\\s*$/g, '');\n}\n\nmodule.exports = function removeClass(element, className) {\n  if (element.classList) element.classList.remove(className);else if (typeof element.className === 'string') element.className = replaceClassName(element.className, className);else element.setAttribute('class', replaceClassName(element.className && element.className.baseVal || '', className));\n};\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/dom-helpers/class/removeClass.js\n// module id = 59\n// module chunks = 0 1","\"use strict\";\n\nexports.__esModule = true;\nexports.default = void 0;\n\nvar _propTypes = _interopRequireDefault(require(\"prop-types\"));\n\nvar _react = _interopRequireDefault(require(\"react\"));\n\nvar _reactDom = require(\"react-dom\");\n\nvar _TransitionGroup = _interopRequireDefault(require(\"./TransitionGroup\"));\n\nfunction _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }\n\nfunction _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }\n\nfunction _inheritsLoose(subClass, superClass) { subClass.prototype = Object.create(superClass.prototype); subClass.prototype.constructor = subClass; subClass.__proto__ = superClass; }\n\n/**\n * The `<ReplaceTransition>` component is a specialized `Transition` component\n * that animates between two children.\n *\n * ```jsx\n * <ReplaceTransition in>\n *   <Fade><div>I appear first</div></Fade>\n *   <Fade><div>I replace the above</div></Fade>\n * </ReplaceTransition>\n * ```\n */\nvar ReplaceTransition =\n/*#__PURE__*/\nfunction (_React$Component) {\n  _inheritsLoose(ReplaceTransition, _React$Component);\n\n  function ReplaceTransition() {\n    var _this;\n\n    for (var _len = arguments.length, _args = new Array(_len), _key = 0; _key < _len; _key++) {\n      _args[_key] = arguments[_key];\n    }\n\n    _this = _React$Component.call.apply(_React$Component, [this].concat(_args)) || this;\n\n    _this.handleEnter = function () {\n      for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {\n        args[_key2] = arguments[_key2];\n      }\n\n      return _this.handleLifecycle('onEnter', 0, args);\n    };\n\n    _this.handleEntering = function () {\n      for (var _len3 = arguments.length, args = new Array(_len3), _key3 = 0; _key3 < _len3; _key3++) {\n        args[_key3] = arguments[_key3];\n      }\n\n      return _this.handleLifecycle('onEntering', 0, args);\n    };\n\n    _this.handleEntered = function () {\n      for (var _len4 = arguments.length, args = new Array(_len4), _key4 = 0; _key4 < _len4; _key4++) {\n        args[_key4] = arguments[_key4];\n      }\n\n      return _this.handleLifecycle('onEntered', 0, args);\n    };\n\n    _this.handleExit = function () {\n      for (var _len5 = arguments.length, args = new Array(_len5), _key5 = 0; _key5 < _len5; _key5++) {\n        args[_key5] = arguments[_key5];\n      }\n\n      return _this.handleLifecycle('onExit', 1, args);\n    };\n\n    _this.handleExiting = function () {\n      for (var _len6 = arguments.length, args = new Array(_len6), _key6 = 0; _key6 < _len6; _key6++) {\n        args[_key6] = arguments[_key6];\n      }\n\n      return _this.handleLifecycle('onExiting', 1, args);\n    };\n\n    _this.handleExited = function () {\n      for (var _len7 = arguments.length, args = new Array(_len7), _key7 = 0; _key7 < _len7; _key7++) {\n        args[_key7] = arguments[_key7];\n      }\n\n      return _this.handleLifecycle('onExited', 1, args);\n    };\n\n    return _this;\n  }\n\n  var _proto = ReplaceTransition.prototype;\n\n  _proto.handleLifecycle = function handleLifecycle(handler, idx, originalArgs) {\n    var _child$props;\n\n    var children = this.props.children;\n\n    var child = _react.default.Children.toArray(children)[idx];\n\n    if (child.props[handler]) (_child$props = child.props)[handler].apply(_child$props, originalArgs);\n    if (this.props[handler]) this.props[handler]((0, _reactDom.findDOMNode)(this));\n  };\n\n  _proto.render = function render() {\n    var _this$props = this.props,\n        children = _this$props.children,\n        inProp = _this$props.in,\n        props = _objectWithoutPropertiesLoose(_this$props, [\"children\", \"in\"]);\n\n    var _React$Children$toArr = _react.default.Children.toArray(children),\n        first = _React$Children$toArr[0],\n        second = _React$Children$toArr[1];\n\n    delete props.onEnter;\n    delete props.onEntering;\n    delete props.onEntered;\n    delete props.onExit;\n    delete props.onExiting;\n    delete props.onExited;\n    return _react.default.createElement(_TransitionGroup.default, props, inProp ? _react.default.cloneElement(first, {\n      key: 'first',\n      onEnter: this.handleEnter,\n      onEntering: this.handleEntering,\n      onEntered: this.handleEntered\n    }) : _react.default.cloneElement(second, {\n      key: 'second',\n      onEnter: this.handleExit,\n      onEntering: this.handleExiting,\n      onEntered: this.handleExited\n    }));\n  };\n\n  return ReplaceTransition;\n}(_react.default.Component);\n\nReplaceTransition.propTypes = process.env.NODE_ENV !== \"production\" ? {\n  in: _propTypes.default.bool.isRequired,\n  children: function children(props, propName) {\n    if (_react.default.Children.count(props[propName]) !== 2) return new Error(\"\\\"\" + propName + \"\\\" must be exactly two transition components.\");\n    return null;\n  }\n} : {};\nvar _default = ReplaceTransition;\nexports.default = _default;\nmodule.exports = exports[\"default\"];\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/react-transition-group/ReplaceTransition.js\n// module id = 60\n// module chunks = 0 1","\"use strict\";\n\nexports.__esModule = true;\nexports.getChildMapping = getChildMapping;\nexports.mergeChildMappings = mergeChildMappings;\nexports.getInitialChildMapping = getInitialChildMapping;\nexports.getNextChildMapping = getNextChildMapping;\n\nvar _react = require(\"react\");\n\n/**\n * Given `this.props.children`, return an object mapping key to child.\n *\n * @param {*} children `this.props.children`\n * @return {object} Mapping of key to child\n */\nfunction getChildMapping(children, mapFn) {\n  var mapper = function mapper(child) {\n    return mapFn && (0, _react.isValidElement)(child) ? mapFn(child) : child;\n  };\n\n  var result = Object.create(null);\n  if (children) _react.Children.map(children, function (c) {\n    return c;\n  }).forEach(function (child) {\n    // run the map function here instead so that the key is the computed one\n    result[child.key] = mapper(child);\n  });\n  return result;\n}\n/**\n * When you're adding or removing children some may be added or removed in the\n * same render pass. We want to show *both* since we want to simultaneously\n * animate elements in and out. This function takes a previous set of keys\n * and a new set of keys and merges them with its best guess of the correct\n * ordering. In the future we may expose some of the utilities in\n * ReactMultiChild to make this easy, but for now React itself does not\n * directly have this concept of the union of prevChildren and nextChildren\n * so we implement it here.\n *\n * @param {object} prev prev children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @param {object} next next children as returned from\n * `ReactTransitionChildMapping.getChildMapping()`.\n * @return {object} a key set that contains all keys in `prev` and all keys\n * in `next` in a reasonable order.\n */\n\n\nfunction mergeChildMappings(prev, next) {\n  prev = prev || {};\n  next = next || {};\n\n  function getValueForKey(key) {\n    return key in next ? next[key] : prev[key];\n  } // For each key of `next`, the list of keys to insert before that key in\n  // the combined list\n\n\n  var nextKeysPending = Object.create(null);\n  var pendingKeys = [];\n\n  for (var prevKey in prev) {\n    if (prevKey in next) {\n      if (pendingKeys.length) {\n        nextKeysPending[prevKey] = pendingKeys;\n        pendingKeys = [];\n      }\n    } else {\n      pendingKeys.push(prevKey);\n    }\n  }\n\n  var i;\n  var childMapping = {};\n\n  for (var nextKey in next) {\n    if (nextKeysPending[nextKey]) {\n      for (i = 0; i < nextKeysPending[nextKey].length; i++) {\n        var pendingNextKey = nextKeysPending[nextKey][i];\n        childMapping[nextKeysPending[nextKey][i]] = getValueForKey(pendingNextKey);\n      }\n    }\n\n    childMapping[nextKey] = getValueForKey(nextKey);\n  } // Finally, add the keys which didn't appear before any key in `next`\n\n\n  for (i = 0; i < pendingKeys.length; i++) {\n    childMapping[pendingKeys[i]] = getValueForKey(pendingKeys[i]);\n  }\n\n  return childMapping;\n}\n\nfunction getProp(child, prop, props) {\n  return props[prop] != null ? props[prop] : child.props[prop];\n}\n\nfunction getInitialChildMapping(props, onExited) {\n  return getChildMapping(props.children, function (child) {\n    return (0, _react.cloneElement)(child, {\n      onExited: onExited.bind(null, child),\n      in: true,\n      appear: getProp(child, 'appear', props),\n      enter: getProp(child, 'enter', props),\n      exit: getProp(child, 'exit', props)\n    });\n  });\n}\n\nfunction getNextChildMapping(nextProps, prevChildMapping, onExited) {\n  var nextChildMapping = getChildMapping(nextProps.children);\n  var children = mergeChildMappings(prevChildMapping, nextChildMapping);\n  Object.keys(children).forEach(function (key) {\n    var child = children[key];\n    if (!(0, _react.isValidElement)(child)) return;\n    var hasPrev = key in prevChildMapping;\n    var hasNext = key in nextChildMapping;\n    var prevChild = prevChildMapping[key];\n    var isLeaving = (0, _react.isValidElement)(prevChild) && !prevChild.props.in; // item is new (entering)\n\n    if (hasNext && (!hasPrev || isLeaving)) {\n      // console.log('entering', key)\n      children[key] = (0, _react.cloneElement)(child, {\n        onExited: onExited.bind(null, child),\n        in: true,\n        exit: getProp(child, 'exit', nextProps),\n        enter: getProp(child, 'enter', nextProps)\n      });\n    } else if (!hasNext && hasPrev && !isLeaving) {\n      // item is old (exiting)\n      // console.log('leaving', key)\n      children[key] = (0, _react.cloneElement)(child, {\n        in: false\n      });\n    } else if (hasNext && hasPrev && (0, _react.isValidElement)(prevChild)) {\n      // item hasn't changed transition states\n      // copy over the last transition props;\n      // console.log('unchanged', key)\n      children[key] = (0, _react.cloneElement)(child, {\n        onExited: onExited.bind(null, child),\n        in: prevChild.props.in,\n        exit: getProp(child, 'exit', nextProps),\n        enter: getProp(child, 'enter', nextProps)\n      });\n    }\n  });\n  return children;\n}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./packages/react-bootstrap-table2/node_modules/react-transition-group/utils/ChildMapping.js\n// module id = 61\n// module chunks = 0 1","/* eslint react/require-default-props: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nimport RowTemplate from './row/row-template';\nimport FooterCell from './footer-cell';\nimport _ from './utils';\n\nconst Footer = (props) => {\n  const { data, className, columns, selectRow, expandRow } = props;\n\n  function renderContent() {\n    return columns.map((column, i) => {\n      if (column.footer === undefined || column.footer === null) {\n        return false;\n      }\n\n      const columnData = _.pluck(data, column.dataField);\n\n      return (\n        <FooterCell\n          index={ i }\n          key={ column.dataField }\n          column={ column }\n          columnData={ columnData }\n        />\n      );\n    });\n  }\n\n  return (\n    <tfoot>\n      <RowTemplate\n        renderContent={ renderContent }\n        selectRow={ selectRow }\n        expandRow={ expandRow }\n        className={ className }\n        cellEl=\"th\"\n      />\n    </tfoot>\n  );\n};\n\nFooter.propTypes = {\n  data: PropTypes.array,\n  className: PropTypes.string,\n  columns: PropTypes.array,\n  selectRow: PropTypes.object,\n  expandRow: PropTypes.object\n};\n\nexport default Footer;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/footer.js","/* eslint react/require-default-props: 0 */\nimport React from 'react';\nimport cs from 'classnames';\nimport PropTypes from 'prop-types';\n\nimport _ from './utils';\nimport eventDelegater from './cell-event-delegater';\n\nclass FooterCell extends eventDelegater(React.Component) {\n  render() {\n    const { index, column, columnData } = this.props;\n\n    const {\n      footer,\n      footerTitle,\n      footerAlign,\n      footerFormatter,\n      footerEvents,\n      footerClasses,\n      footerStyle,\n      footerAttrs\n    } = column;\n\n    const delegateEvents = this.delegate(footerEvents);\n    const cellAttrs = {\n      ...(_.isFunction(footerAttrs) ? footerAttrs(column, index) : footerAttrs),\n      ...delegateEvents\n    };\n\n\n    let text = '';\n    if (_.isString(footer)) {\n      text = footer;\n    } else if (_.isFunction(footer)) {\n      text = footer(columnData, column, index);\n    }\n\n    let cellStyle = {};\n    const cellClasses = _.isFunction(footerClasses) ? footerClasses(column, index) : footerClasses;\n\n    if (footerStyle) {\n      cellStyle = _.isFunction(footerStyle) ? footerStyle(column, index) : footerStyle;\n      cellStyle = cellStyle ? { ...cellStyle } : cellStyle;\n    }\n\n    if (footerTitle) {\n      cellAttrs.title = _.isFunction(footerTitle) ? footerTitle(column, index) : text;\n    }\n\n    if (footerAlign) {\n      cellStyle.textAlign = _.isFunction(footerAlign) ? footerAlign(column, index) : footerAlign;\n    }\n\n    if (cellClasses) cellAttrs.className = cs(cellAttrs.className, cellClasses);\n    if (!_.isEmptyObject(cellStyle)) cellAttrs.style = cellStyle;\n\n    const children = footerFormatter ? footerFormatter(column, index) : text;\n\n    return React.createElement('th', cellAttrs, children);\n  }\n}\n\nFooterCell.propTypes = {\n  columnData: PropTypes.array,\n  index: PropTypes.number,\n  column: PropTypes.object\n};\n\nexport default FooterCell;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/footer-cell.js","import _ from '../utils';\nimport ColumnResolver from './column-resolver';\n\nexport default ExtendBase =>\n  class TableResolver extends ColumnResolver(ExtendBase) {\n    validateProps() {\n      const { keyField } = this.props;\n      if (!keyField) {\n        throw new Error('Please specify a field as key via keyField');\n      }\n      if (this.visibleColumnSize(false) <= 0) {\n        throw new Error('No visible columns detected');\n      }\n    }\n\n    isEmpty() {\n      return this.props.data.length === 0;\n    }\n\n    visibleRows() {\n      const { data, hiddenRows, keyField } = this.props;\n      if (!hiddenRows || hiddenRows.length === 0) return data;\n      return data.filter((row) => {\n        const key = _.get(row, keyField);\n        return !_.contains(hiddenRows, key);\n      });\n    }\n  };\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/props-resolver/index.js","export default ExtendBase =>\n  class ColumnResolver extends ExtendBase {\n    visibleColumnSize(includeSelectColumn = true) {\n      let columnLen;\n      if (this.props.columnToggle && this.props.columnToggle.toggles) {\n        const columns = this.props.columnToggle.toggles;\n        columnLen = Object.keys(columns).filter(name => columns[name]).length;\n      } else {\n        columnLen = this.props.columns.filter(c => !c.hidden).length;\n      }\n      if (!includeSelectColumn) return columnLen;\n      if (this.props.selectRow && !this.props.selectRow.hideSelectColumn) {\n        columnLen += 1;\n      }\n      if (this.props.expandRow && this.props.expandRow.showExpandColumn) {\n        columnLen += 1;\n      }\n      return columnLen;\n    }\n  };\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/props-resolver/column-resolver.js","/* eslint camelcase: 0 */\n/* eslint no-return-assign: 0 */\n/* eslint no-param-reassign: 0 */\n/* eslint class-methods-use-this: 0 */\nimport React, { Component } from 'react';\nimport EventEmitter from 'events';\nimport _ from '../utils';\nimport createDataContext from './data-context';\nimport createColumnMgtContext from './column-context';\nimport createSortContext from './sort-context';\nimport SelectionContext from './selection-context';\nimport RowExpandContext from './row-expand-context';\nimport remoteResolver from '../props-resolver/remote-resolver';\nimport { BootstrapContext } from './bootstrap';\nimport dataOperator from '../store/operators';\n\nconst withContext = Base =>\n  class BootstrapTableContainer extends remoteResolver(Component) {\n    constructor(props) {\n      super(props);\n      this.DataContext = createDataContext();\n\n      if (props.registerExposedAPI) {\n        const exposedAPIEmitter = new EventEmitter();\n        exposedAPIEmitter.on('get.table.data', payload => payload.result = this.table.getData());\n        exposedAPIEmitter.on('get.selected.rows', payload => payload.result = this.selectionContext.getSelected());\n        exposedAPIEmitter.on('get.filtered.rows', (payload) => {\n          if (this.searchContext) {\n            payload.result = this.searchContext.getSearched();\n          } else if (this.filterContext) {\n            payload.result = this.filterContext.getFiltered();\n          } else {\n            payload.result = this.table.getData();\n          }\n        });\n        props.registerExposedAPI(exposedAPIEmitter);\n      }\n\n      if (props.columns.filter(col => col.sort).length > 0) {\n        this.SortContext = createSortContext(\n          dataOperator, this.isRemoteSort, this.handleRemoteSortChange);\n      }\n\n      if (\n        props.columnToggle ||\n        props.columns.filter(col => col.hidden).length > 0\n      ) {\n        this.ColumnManagementContext = createColumnMgtContext();\n      }\n\n      if (props.selectRow) {\n        this.SelectionContext = SelectionContext;\n      }\n\n      if (props.expandRow) {\n        this.RowExpandContext = RowExpandContext;\n      }\n\n      if (props.cellEdit && props.cellEdit.createContext) {\n        this.CellEditContext = props.cellEdit.createContext(\n          _, dataOperator, this.isRemoteCellEdit, this.handleRemoteCellChange);\n      }\n\n      if (props.filter) {\n        this.FilterContext = props.filter.createContext(\n          _, this.isRemoteFiltering, this.handleRemoteFilterChange);\n      }\n\n      if (props.pagination) {\n        this.PaginationContext = props.pagination.createContext();\n      }\n\n      if (props.search && props.search.searchContext) {\n        this.SearchContext = props.search.searchContext(\n          _, this.isRemoteSearch, this.handleRemoteSearchChange);\n      }\n\n      if (props.setDependencyModules) {\n        props.setDependencyModules(_);\n      }\n\n      if (props.setPaginationRemoteEmitter) {\n        props.setPaginationRemoteEmitter(this.remoteEmitter);\n      }\n    }\n\n    UNSAFE_componentWillReceiveProps(nextProps) {\n      if (nextProps.columns.filter(col => col.sort).length <= 0) {\n        this.SortContext = null;\n      } else if (!this.SortContext) {\n        this.SortContext = createSortContext(\n          dataOperator, this.isRemoteSort, this.handleRemoteSortChange);\n      }\n      if (!nextProps.pagination && this.props.pagination) {\n        this.PaginationContext = null;\n      }\n      if (nextProps.pagination && !this.props.pagination) {\n        this.PaginationContext = nextProps.pagination.createContext(\n          this.isRemotePagination, this.handleRemotePageChange);\n      }\n      if (!nextProps.cellEdit && this.props.cellEdit) {\n        this.CellEditContext = null;\n      }\n      if (nextProps.cellEdit && !this.props.cellEdit) {\n        this.CellEditContext = nextProps.cellEdit.createContext(\n          _, dataOperator, this.isRemoteCellEdit, this.handleRemoteCellChange);\n      }\n    }\n\n    renderBase() {\n      return (\n        rootProps,\n        filterProps,\n        searchProps,\n        sortProps,\n        paginationProps,\n        columnToggleProps\n      ) => (\n        <Base\n          ref={ n => this.table = n }\n          { ...this.props }\n          { ...sortProps }\n          { ...filterProps }\n          { ...searchProps }\n          { ...paginationProps }\n          { ...columnToggleProps }\n          data={ rootProps.getData(filterProps, searchProps, sortProps, paginationProps) }\n        />\n      );\n    }\n\n    renderWithColumnManagementCtx(base, baseProps) {\n      return (\n        rootProps,\n        filterProps,\n        searchProps,\n        sortProps,\n        paginationProps\n      ) => (\n        <this.ColumnManagementContext.Provider\n          { ...baseProps }\n          toggles={ this.props.columnToggle ? this.props.columnToggle.toggles : null }\n        >\n          <this.ColumnManagementContext.Consumer>\n            {\n              columnToggleProps => base(\n                rootProps,\n                filterProps,\n                searchProps,\n                sortProps,\n                paginationProps,\n                columnToggleProps\n              )\n            }\n          </this.ColumnManagementContext.Consumer>\n        </this.ColumnManagementContext.Provider>\n      );\n    }\n\n    renderWithSelectionCtx(base, baseProps) {\n      return (\n        rootProps,\n        filterProps,\n        searchProps,\n        sortProps,\n        paginationProps\n      ) => (\n        <this.SelectionContext.Provider\n          { ...baseProps }\n          ref={ n => this.selectionContext = n }\n          selectRow={ this.props.selectRow }\n          data={ rootProps.getData(filterProps, searchProps, sortProps, paginationProps) }\n        >\n          {\n            base(\n              rootProps,\n              filterProps,\n              searchProps,\n              sortProps,\n              paginationProps\n            )\n          }\n        </this.SelectionContext.Provider>\n      );\n    }\n\n    renderWithRowExpandCtx(base, baseProps) {\n      return (\n        rootProps,\n        filterProps,\n        searchProps,\n        sortProps,\n        paginationProps\n      ) => (\n        <this.RowExpandContext.Provider\n          { ...baseProps }\n          ref={ n => this.rowExpandContext = n }\n          expandRow={ this.props.expandRow }\n          data={ rootProps.getData(filterProps, searchProps, sortProps, paginationProps) }\n        >\n          {\n            base(\n              rootProps,\n              filterProps,\n              searchProps,\n              sortProps,\n              paginationProps\n            )\n          }\n        </this.RowExpandContext.Provider>\n      );\n    }\n\n    renderWithPaginationCtx(base) {\n      return (\n        rootProps,\n        filterProps,\n        searchProps,\n        sortProps\n      ) => (\n        <this.PaginationContext.Provider\n          ref={ n => this.paginationContext = n }\n          pagination={ this.props.pagination }\n          data={ rootProps.getData(filterProps, searchProps, sortProps) }\n          bootstrap4={ this.props.bootstrap4 }\n          isRemotePagination={ this.isRemotePagination }\n          remoteEmitter={ this.remoteEmitter }\n          onDataSizeChange={ this.props.onDataSizeChange }\n        >\n          <this.PaginationContext.Consumer>\n            {\n              paginationProps => base(\n                rootProps,\n                filterProps,\n                searchProps,\n                sortProps,\n                paginationProps\n              )\n            }\n          </this.PaginationContext.Consumer>\n        </this.PaginationContext.Provider>\n      );\n    }\n\n    renderWithSortCtx(base, baseProps) {\n      return (\n        rootProps,\n        filterProps,\n        searchProps\n      ) => (\n        <this.SortContext.Provider\n          { ...baseProps }\n          ref={ n => this.sortContext = n }\n          defaultSorted={ this.props.defaultSorted }\n          defaultSortDirection={ this.props.defaultSortDirection }\n          sort={ this.props.sort }\n          data={ rootProps.getData(filterProps, searchProps) }\n        >\n          <this.SortContext.Consumer>\n            {\n              sortProps => base(\n                rootProps,\n                filterProps,\n                searchProps,\n                sortProps,\n              )\n            }\n          </this.SortContext.Consumer>\n        </this.SortContext.Provider>\n      );\n    }\n\n    renderWithSearchCtx(base, baseProps) {\n      return (\n        rootProps,\n        filterProps\n      ) => (\n        <this.SearchContext.Provider\n          { ...baseProps }\n          ref={ n => this.searchContext = n }\n          data={ rootProps.getData(filterProps) }\n          searchText={ this.props.search.searchText }\n          dataChangeListener={ this.props.dataChangeListener }\n        >\n          <this.SearchContext.Consumer>\n            {\n              searchProps => base(\n                rootProps,\n                filterProps,\n                searchProps\n              )\n            }\n          </this.SearchContext.Consumer>\n        </this.SearchContext.Provider>\n      );\n    }\n\n    renderWithFilterCtx(base, baseProps) {\n      return rootProps => (\n        <this.FilterContext.Provider\n          { ...baseProps }\n          ref={ n => this.filterContext = n }\n          data={ rootProps.getData() }\n          dataChangeListener={ this.props.dataChangeListener }\n        >\n          <this.FilterContext.Consumer>\n            {\n              filterProps => base(\n                rootProps,\n                filterProps\n              )\n            }\n          </this.FilterContext.Consumer>\n        </this.FilterContext.Provider>\n      );\n    }\n\n    renderWithCellEditCtx(base, baseProps) {\n      return rootProps => (\n        <this.CellEditContext.Provider\n          { ...baseProps }\n          ref={ n => this.cellEditContext = n }\n          selectRow={ this.props.selectRow }\n          cellEdit={ this.props.cellEdit }\n          data={ rootProps.getData() }\n        >\n          { base(rootProps) }\n        </this.CellEditContext.Provider>\n      );\n    }\n\n    render() {\n      const { keyField, columns, bootstrap4 } = this.props;\n      const baseProps = { keyField, columns };\n\n      let base = this.renderBase();\n\n      if (this.ColumnManagementContext) {\n        base = this.renderWithColumnManagementCtx(base, baseProps);\n      }\n\n      if (this.SelectionContext) {\n        base = this.renderWithSelectionCtx(base, baseProps);\n      }\n\n      if (this.RowExpandContext) {\n        base = this.renderWithRowExpandCtx(base, baseProps);\n      }\n\n      if (this.PaginationContext) {\n        base = this.renderWithPaginationCtx(base, baseProps);\n      }\n\n      if (this.SortContext) {\n        base = this.renderWithSortCtx(base, baseProps);\n      }\n\n      if (this.SearchContext) {\n        base = this.renderWithSearchCtx(base, baseProps);\n      }\n\n      if (this.FilterContext) {\n        base = this.renderWithFilterCtx(base, baseProps);\n      }\n\n      if (this.CellEditContext) {\n        base = this.renderWithCellEditCtx(base, baseProps);\n      }\n\n      return (\n        <BootstrapContext.Provider value={ { bootstrap4 } }>\n          <this.DataContext.Provider\n            { ...baseProps }\n            data={ this.props.data }\n          >\n            <this.DataContext.Consumer>\n              {\n                base\n              }\n            </this.DataContext.Consumer>\n          </this.DataContext.Provider>\n        </BootstrapContext.Provider>\n      );\n    }\n  };\n\nexport default withContext;\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/contexts/index.js","/* eslint camelcase: 0 */\nimport React, { Component } from 'react';\nimport PropTypes from 'prop-types';\n\nexport default () => {\n  const DataContext = React.createContext();\n\n  class DataProvider extends Component {\n    static propTypes = {\n      data: PropTypes.array.isRequired,\n      children: PropTypes.node.isRequired\n    }\n\n    state = { data: this.props.data };\n\n    getData = (filterProps, searchProps, sortProps, paginationProps) => {\n      if (paginationProps) return paginationProps.data;\n      else if (sortProps) return sortProps.data;\n      else if (searchProps) return searchProps.data;\n      else if (filterProps) return filterProps.data;\n      return this.props.data;\n    }\n\n    UNSAFE_componentWillReceiveProps(nextProps) {\n      this.setState(() => ({ data: nextProps.data }));\n    }\n\n    render() {\n      return (\n        <DataContext.Provider\n          value={ {\n            data: this.state.data,\n            getData: this.getData\n          } }\n        >\n          { this.props.children }\n        </DataContext.Provider>\n      );\n    }\n  }\n  return {\n    Provider: DataProvider,\n    Consumer: DataContext.Consumer\n  };\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/contexts/data-context.js","/* eslint react/prop-types: 0 */\n/* eslint react/prefer-stateless-function: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\n\nexport default () => {\n  const ColumnManagementContext = React.createContext();\n\n  class ColumnManagementProvider extends React.Component {\n    static propTypes = {\n      columns: PropTypes.array.isRequired,\n      toggles: PropTypes.object\n    }\n\n    static defaultProps = {\n      toggles: null\n    }\n\n    render() {\n      let toggleColumn;\n      const { columns, toggles } = this.props;\n      if (toggles) {\n        toggleColumn = columns.filter(column => toggles[column.dataField]);\n      } else {\n        toggleColumn = columns.filter(column => !column.hidden);\n      }\n      return (\n        <ColumnManagementContext.Provider value={ { columns: toggleColumn } }>\n          { this.props.children }\n        </ColumnManagementContext.Provider>\n      );\n    }\n  }\n\n  return {\n    Provider: ColumnManagementProvider,\n    Consumer: ColumnManagementContext.Consumer\n  };\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/contexts/column-context.js","/* eslint camelcase: 0 */\n/* eslint react/require-default-props: 0 */\nimport React from 'react';\nimport PropTypes from 'prop-types';\nimport Const from '../const';\n\nexport default (\n  dataOperator,\n  isRemoteSort,\n  handleSortChange\n) => {\n  const SortContext = React.createContext();\n\n  class SortProvider extends React.Component {\n    static propTypes = {\n      data: PropTypes.array.isRequired,\n      columns: PropTypes.array.isRequired,\n      children: PropTypes.node.isRequired,\n      defaultSorted: PropTypes.arrayOf(PropTypes.shape({\n        dataField: PropTypes.string.isRequired,\n        order: PropTypes.oneOf([Const.SORT_DESC, Const.SORT_ASC]).isRequired\n      })),\n      sort: PropTypes.shape({\n        dataField: PropTypes.string,\n        order: PropTypes.oneOf([Const.SORT_DESC, Const.SORT_ASC]),\n        sortFunc: PropTypes.func\n      }),\n      defaultSortDirection: PropTypes.oneOf([Const.SORT_DESC, Const.SORT_ASC])\n    }\n\n    constructor(props) {\n      super(props);\n      let sortOrder;\n      let sortColumn;\n      const { defaultSorted, defaultSortDirection, sort } = props;\n\n      if (defaultSorted && defaultSorted.length > 0) {\n        sortOrder = defaultSorted[0].order || defaultSortDirection;\n        sortColumn = this.initSort(defaultSorted[0].dataField, sortOrder);\n      } else if (sort && sort.dataField && sort.order) {\n        sortOrder = sort.order;\n        sortColumn = this.initSort(sort.dataField, sortOrder);\n      }\n      this.state = { sortOrder, sortColumn };\n    }\n\n    componentDidMount() {\n      const { sortOrder, sortColumn } = this.state;\n      if (isRemoteSort() && sortOrder && sortColumn) {\n        handleSortChange(sortColumn.dataField, sortOrder);\n      }\n    }\n\n    UNSAFE_componentWillReceiveProps(nextProps) {\n      const { sort, columns } = nextProps;\n      if (sort && sort.dataField && sort.order) {\n        this.setState({\n          sortOrder: sort.order,\n          sortColumn: columns.find(col => col.dataField === sort.dataField)\n        });\n      }\n    }\n\n    initSort(sortField, sortOrder) {\n      let sortColumn;\n      const { columns } = this.props;\n      const sortColumns = columns.filter(col => col.dataField === sortField);\n      if (sortColumns.length > 0) {\n        sortColumn = sortColumns[0];\n\n        if (sortColumn.onSort) {\n          sortColumn.onSort(sortField, sortOrder);\n        }\n      }\n      return sortColumn;\n    }\n\n    handleSort = (column) => {\n      const sortOrder = dataOperator.nextOrder(column, this.state, this.props.defaultSortDirection);\n\n      if (column.onSort) {\n        column.onSort(column.dataField, sortOrder);\n      }\n\n      if (isRemoteSort()) {\n        handleSortChange(column.dataField, sortOrder);\n      }\n      this.setState(() => ({\n        sortOrder,\n        sortColumn: column\n      }));\n    }\n\n    render() {\n      let { data } = this.props;\n      const { sort } = this.props;\n      const { sortOrder, sortColumn } = this.state;\n      if (!isRemoteSort() && sortColumn) {\n        const sortFunc = sortColumn.sortFunc ? sortColumn.sortFunc : (sort && sort.sortFunc);\n        data = dataOperator.sort(data, sortOrder, { ...sortColumn, sortFunc });\n      }\n\n      return (\n        <SortContext.Provider\n          value={ {\n            data,\n            sortOrder,\n            onSort: this.handleSort,\n            sortField: sortColumn ? sortColumn.dataField : null\n          } }\n        >\n          { this.props.children }\n        </SortContext.Provider>\n      );\n    }\n  }\n  return {\n    Provider: SortProvider,\n    Consumer: SortContext.Consumer\n  };\n};\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/contexts/sort-context.js","import EventEmitter from 'events';\nimport _ from '../utils';\n\nexport default ExtendBase =>\n  class RemoteResolver extends ExtendBase {\n    constructor(props) {\n      super(props);\n      this.remoteEmitter = new EventEmitter();\n      this.remoteEmitter.on('paginationChange', this.handleRemotePageChange);\n      this.remoteEmitter.on('isRemotePagination', this.isRemotePagination);\n    }\n\n    getNewestState = (state = {}) => {\n      let sortOrder;\n      let sortField;\n      let page;\n      let sizePerPage;\n      let searchText;\n      let filters = {};\n\n      if (this.sortContext) {\n        sortOrder = this.sortContext.state.sortOrder;\n        sortField = this.sortContext.state.sortColumn ?\n          this.sortContext.state.sortColumn.dataField :\n          null;\n      }\n\n      if (this.filterContext) {\n        filters = this.filterContext.currFilters;\n      }\n\n      if (this.paginationContext) {\n        page = this.paginationContext.currPage;\n        sizePerPage = this.paginationContext.currSizePerPage;\n      }\n\n      if (this.searchContext) {\n        searchText = this.props.search.searchText;\n      }\n\n      return {\n        sortOrder,\n        sortField,\n        filters,\n        page,\n        sizePerPage,\n        searchText,\n        ...state,\n        data: this.props.data\n      };\n    }\n\n    isRemoteSearch = () => {\n      const { remote } = this.props;\n      return remote === true || (_.isObject(remote) && remote.search) || this.isRemotePagination();\n    }\n\n    isRemotePagination = (e = {}) => {\n      const { remote } = this.props;\n      e.result = (remote === true || (_.isObject(remote) && remote.pagination));\n      return e.result;\n    }\n\n    isRemoteFiltering = () => {\n      const { remote } = this.props;\n      return remote === true || (_.isObject(remote) && remote.filter) || this.isRemotePagination();\n    }\n\n    isRemoteSort = () => {\n      const { remote } = this.props;\n      return remote === true || (_.isObject(remote) && remote.sort) || this.isRemotePagination();\n    }\n\n    isRemoteCellEdit = () => {\n      const { remote } = this.props;\n      return remote === true || (_.isObject(remote) && remote.cellEdit);\n    }\n\n    handleRemotePageChange = (page, sizePerPage) => {\n      this.props.onTableChange('pagination', this.getNewestState({ page, sizePerPage }));\n    }\n\n    handleRemoteFilterChange = (filters) => {\n      const newState = { filters };\n      if (this.isRemotePagination()) {\n        const options = this.props.pagination.options || {};\n        newState.page = _.isDefined(options.pageStartIndex) ? options.pageStartIndex : 1;\n      }\n      this.props.onTableChange('filter', this.getNewestState(newState));\n    }\n\n    handleRemoteSortChange = (sortField, sortOrder) => {\n      this.props.onTableChange('sort', this.getNewestState({ sortField, sortOrder }));\n    }\n\n    handleRemoteCellChange = (rowId, dataField, newValue) => {\n      const cellEdit = { rowId, dataField, newValue };\n      this.props.onTableChange('cellEdit', this.getNewestState({ cellEdit }));\n    }\n\n    handleRemoteSearchChange = (searchText) => {\n      this.props.onTableChange('search', this.getNewestState({ searchText }));\n    }\n  };\n\n\n\n// WEBPACK FOOTER //\n// ./packages/react-bootstrap-table2/src/props-resolver/remote-resolver.js"],"sourceRoot":""}
|
||
//# sourceMappingURL=react-bootstrap-table-next.js.map
|