@e-group/material-module
Version:
EGroup Team react component modules.
61 lines (44 loc) • 2.72 kB
JavaScript
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.getNextEachRowState = void 0;
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _core = require("@material-ui/core");
var _react = _interopRequireWildcard(require("react"));
var _DataTableContext = _interopRequireWildcard(require("../DataTable/DataTableContext"));
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
const getNextEachRowState = (prev, state) => {
const next = _objectSpread({}, prev);
const keys = Object.keys(next);
for (let i = 0; i < keys.length; i++) {
const key = keys[i];
next[key] = _objectSpread(_objectSpread({}, next[key]), state);
}
return next;
};
exports.getNextEachRowState = getNextEachRowState;
const DataTableCheckedAllCheckbox = () => {
const _useContext = (0, _react.useContext)(_DataTableContext.default),
setTableEvent = _useContext.setTableEvent,
eachRowState = _useContext.eachRowState,
setEachRowState = _useContext.setEachRowState;
const isAllChecked = Object.keys(eachRowState).length > 0 && Object.values(eachRowState).filter(el => !(el !== null && el !== void 0 && el.checked)).length === 0;
return /*#__PURE__*/_react.default.createElement(_core.Checkbox, {
size: "small",
checked: isAllChecked,
onChange: (_, checked) => {
if (setTableEvent && setEachRowState) {
setTableEvent(_DataTableContext.TableEvent.CHNAGE_ALL_CHECKED_ROWS);
setEachRowState(val => getNextEachRowState(val, {
checked
}));
}
}
});
};
var _default = DataTableCheckedAllCheckbox;
exports.default = _default;
;