@activecollab/components
Version:
ActiveCollab Components
401 lines (400 loc) • 20.6 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.SortDirection = exports.DataTable = void 0;
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _Styles = require("./Styles");
var _Table = require("./Table");
var _CollapseAll = _interopRequireDefault(require("../Icons/collection/CollapseAll"));
var _CollapseExpandSingle = _interopRequireDefault(require("../Icons/collection/CollapseExpandSingle"));
var _ExpandAll = _interopRequireDefault(require("../Icons/collection/ExpandAll"));
var _SortIcon = _interopRequireDefault(require("../Icons/collection/SortIcon"));
var _Loaders = require("../Loaders");
var _excluded = ["header", "rows", "className", "sortBy", "sortDirection", "onSortCallback", "theadClass", "noResultsCallback", "groupBy", "groupHead", "isCollapsible", "emptyValue", "loading", "loadingRows"];
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
function _extends() { _extends = Object.assign ? Object.assign.bind() : 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 _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
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 ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : String(i); }
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
var SortDirection = exports.SortDirection = /*#__PURE__*/function (SortDirection) {
SortDirection["None"] = "none";
SortDirection["Asc"] = "asc";
SortDirection["Desc"] = "desc";
return SortDirection;
}({});
var groupByKey = function groupByKey(items, key) {
if (items[0] instanceof Array) {
items = items[0];
}
return items.reduce(function (result, item) {
return _objectSpread(_objectSpread({}, result), {}, {
[item[key] !== null ? " " + item[key] : item[key]]: [...(result[item[key] !== null ? " " + item[key] : item[key]] || []), item]
});
}, {});
};
var initialCollapsed = function initialCollapsed(rows, groupBy) {
if (groupBy) {
var groupedData = groupByKey(rows, groupBy);
var keys = Object.keys(groupedData);
var collapsedKeys = {};
keys.forEach(function (key) {
collapsedKeys[key] = true;
});
return collapsedKeys;
}
return {};
};
var DataTable = exports.DataTable = function DataTable(_ref) {
var header = _ref.header,
_ref$rows = _ref.rows,
rows = _ref$rows === void 0 ? [] : _ref$rows,
className = _ref.className,
sortBy = _ref.sortBy,
_ref$sortDirection = _ref.sortDirection,
sortDirection = _ref$sortDirection === void 0 ? SortDirection.None : _ref$sortDirection,
onSortCallback = _ref.onSortCallback,
theadClass = _ref.theadClass,
noResultsCallback = _ref.noResultsCallback,
groupBy = _ref.groupBy,
_ref$groupHead = _ref.groupHead,
groupHead = _ref$groupHead === void 0 ? function () {
return null;
} : _ref$groupHead,
isCollapsible = _ref.isCollapsible,
emptyValue = _ref.emptyValue,
loading = _ref.loading,
_ref$loadingRows = _ref.loadingRows,
loadingRows = _ref$loadingRows === void 0 ? 7 : _ref$loadingRows,
args = _objectWithoutProperties(_ref, _excluded);
var _useState = (0, _react.useState)(sortDirection),
_useState2 = _slicedToArray(_useState, 2),
columnDirection = _useState2[0],
setColumnDirection = _useState2[1];
var _useState3 = (0, _react.useState)(sortBy),
_useState4 = _slicedToArray(_useState3, 2),
active = _useState4[0],
setActive = _useState4[1];
var _useState5 = (0, _react.useState)(),
_useState6 = _slicedToArray(_useState5, 2),
hovered = _useState6[0],
setHovered = _useState6[1];
var _useState7 = (0, _react.useState)(function () {
return initialCollapsed(rows, groupBy);
}),
_useState8 = _slicedToArray(_useState7, 2),
collapsed = _useState8[0],
setCollapsed = _useState8[1];
var sort = function sort(sortByKey, direction, rowsData) {
if (direction === SortDirection.None) {
return rowsData;
}
if (rowsData instanceof Array) return rowsData.sort(function (a, b) {
if (direction === SortDirection.Asc) {
if (a[sortByKey] === null) {
return 1;
}
if (b[sortByKey] === null) {
return -1;
}
}
if (a[sortByKey] === null) {
return -1;
}
if (b[sortByKey] === null) {
return 1;
}
if (typeof a[sortByKey] === "number") {
if (direction === SortDirection.Asc) {
return a[sortByKey] - b[sortByKey];
}
return b[sortByKey] - a[sortByKey];
}
var first = a[sortByKey].toString();
var second = b[sortByKey].toString();
if (direction === SortDirection.Asc) {
return first.localeCompare(second);
}
return second.localeCompare(first);
});
return {};
};
var initialData = (0, _react.useCallback)(function () {
if (sortBy && !groupBy) {
return sort(sortBy, sortDirection, rows);
}
if (sortBy && groupBy) {
sort(sortBy, sortDirection, rows);
return groupByKey(rows, groupBy);
}
if (!sortBy && groupBy) {
return groupByKey(rows, groupBy);
}
return rows;
}, [groupBy, rows, sortBy, sortDirection]);
var _useState9 = (0, _react.useState)(initialData),
_useState10 = _slicedToArray(_useState9, 2),
data = _useState10[0],
setData = _useState10[1];
var getNextSortDirection = function getNextSortDirection(previousDirection, sameColumn) {
if (!sameColumn) {
return SortDirection.Asc;
}
if (previousDirection === SortDirection.Asc) {
return SortDirection.Desc;
}
return SortDirection.Asc;
};
var sortColumn = (0, _react.useCallback)(function (event) {
var index = event.currentTarget.dataset.index;
if (index && header[index] && header[index].sortable) {
var direction = getNextSortDirection(columnDirection, header[index].key === active);
setActive(header[index].key);
setColumnDirection(direction);
if (groupBy) {
var grouped = _objectSpread({}, data);
if (groupBy !== header[index].key) {
Object.keys(grouped).map(function (key) {
grouped[key] = sort(header[index].key, direction, grouped[key]);
});
} else {
if (rows instanceof Object) {
grouped = sort(header[index].key, direction, rows);
grouped = groupByKey([grouped], groupBy);
}
}
setData(grouped);
} else {
setData(sort(header[index].key, direction, data));
}
if (onSortCallback) {
onSortCallback(header[index].key, direction);
}
}
return null;
}, [setData, data, columnDirection, setColumnDirection, header, active, setActive, onSortCallback, groupBy, rows]);
var cellMouseOver = (0, _react.useCallback)(function (e) {
if (e.target instanceof HTMLElement) {
if (e.target.dataset.key) {
setHovered(e.target.dataset.key);
}
}
}, []);
var cellMouseOut = (0, _react.useCallback)(function () {
setHovered(null);
}, []);
(0, _react.useEffect)(function () {
setData(initialData());
setCollapsed(initialCollapsed(rows, groupBy));
}, [rows, groupBy, initialData]);
var renderNoResults = (0, _react.useCallback)(function () {
return /*#__PURE__*/_react.default.createElement("tr", null, /*#__PURE__*/_react.default.createElement("td", {
colSpan: header.length,
className: (0, _classnames.default)({
"text-center": !noResultsCallback
})
}, noResultsCallback ? noResultsCallback() : "There is no data."));
}, [header, noResultsCallback]);
var tableRef = (0, _react.useRef)(null);
var overlayStyles = function overlayStyles() {
if (tableRef.current) {
return tableRef.current.clientHeight + 5;
}
};
var renderCell = (0, _react.useCallback)(function (h, row, colIndex) {
if (h.renderCallback) {
return h.renderCallback(row, h.key, colIndex);
}
if (row[h.key] === null && emptyValue) {
return /*#__PURE__*/_react.default.createElement("i", {
className: "opacity-75"
}, emptyValue[h.key]);
}
return row[h.key];
}, [emptyValue]);
var renderRow = (0, _react.useCallback)(function (row, rowIndex) {
return /*#__PURE__*/_react.default.createElement("tr", {
key: rowIndex,
"data-index": rowIndex,
"data-direction": "asc",
className: "c-table__row",
onMouseOver: cellMouseOver,
onMouseLeave: cellMouseOut
}, header.map(function (h, colIndex) {
return /*#__PURE__*/_react.default.createElement("td", {
key: colIndex,
className: (0, _classnames.default)("c-table__cell c-data-table__item", {
hovered: hovered === h.key
}),
"data-key": h.key,
style: header[colIndex].style ? header[colIndex].style : {}
}, renderCell(h, row, colIndex));
}));
}, [cellMouseOut, cellMouseOver, header, hovered, renderCell]);
var toggleCollapse = (0, _react.useCallback)(function (event) {
var collapseKey = event.currentTarget.dataset.groupkey;
setCollapsed(function (prevState) {
var newState = _objectSpread({}, prevState);
newState[collapseKey] = !prevState[collapseKey];
return newState;
});
}, []);
var renderPlaceholders = (0, _react.useMemo)(function () {
var placeholders = Array(loadingRows).fill({}).map(function (_, index) {
return /*#__PURE__*/_react.default.createElement("tr", {
key: index,
className: "c-table__row",
onMouseOver: cellMouseOver,
onMouseLeave: cellMouseOut
}, header.map(function (col, colIndex) {
return /*#__PURE__*/_react.default.createElement("td", {
key: colIndex,
className: (0, _classnames.default)("c-table__cell c-data-table__item", {
hovered: hovered === col.key
}),
"data-key": col.key
}, /*#__PURE__*/_react.default.createElement(_Loaders.SkeletonLoader, null));
}));
});
return /*#__PURE__*/_react.default.createElement(_Table.Tbody, null, placeholders);
}, [cellMouseOut, cellMouseOver, header, hovered, loadingRows]);
var renderRows = (0, _react.useMemo)(function () {
if (data && data instanceof Array && data.length > 0 || typeof data === "object" && Object.keys(data).length > 0) {
if (groupBy) {
var keys = Object.keys(data);
return keys.map(function (key, i) {
return /*#__PURE__*/_react.default.createElement(_react.Fragment, {
key: key
}, isCollapsible && /*#__PURE__*/_react.default.createElement(_Table.Tbody, {
className: "c-table__collapse_body"
}, /*#__PURE__*/_react.default.createElement("tr", null, /*#__PURE__*/_react.default.createElement("td", {
"data-groupkey": key,
onClick: toggleCollapse,
className: "c-table__body__icon c-table--toggle-collapsed"
}, /*#__PURE__*/_react.default.createElement(_CollapseExpandSingle.default, {
className: (0, _classnames.default)({
"c-table__collapse_icon--expanded": !collapsed[key],
"c-table__collapse_icon--collapsed": collapsed[key]
})
})))), /*#__PURE__*/_react.default.createElement(_Table.Tbody, {
className: (0, _classnames.default)("c-table__grouped__head", "head_".concat(i), {
"c-table__grouped__head--expanded": isCollapsible && !collapsed[key],
"c-table__grouped__head--collapsed": isCollapsible && collapsed[key],
last: i === keys.length - 1,
first: i === 0
})
}, groupHead(data[key], keys[i] !== "null" ? keys[i].trim() : null)), /*#__PURE__*/_react.default.createElement(_Table.Tbody, {
className: (0, _classnames.default)("c-table__group c-table_group_".concat(i), {
hidden: collapsed[key]
})
}, data[key].map(function (row, index) {
return renderRow(row, index);
})));
});
}
return /*#__PURE__*/_react.default.createElement(_Table.Tbody, null, data instanceof Array && data.map(function (row, rowIndex) {
return renderRow(row, rowIndex);
}));
}
return renderNoResults();
}, [data, groupBy, renderRow, groupHead, collapsed, isCollapsible, renderNoResults, toggleCollapse]);
var allGroupsCollapsed = (0, _react.useMemo)(function () {
return Object.keys(collapsed).every(function (key) {
return collapsed[key];
});
}, [collapsed]);
var hasCollapsed = (0, _react.useMemo)(function () {
return Object.keys(collapsed).some(function (key) {
return collapsed[key];
});
}, [collapsed]);
var toggleAllCollapsed = (0, _react.useCallback)(function () {
if (hasCollapsed) {
setCollapsed(function (prevState) {
var newState = _objectSpread({}, prevState);
Object.keys(newState).forEach(function (key) {
newState[key] = false;
});
return newState;
});
} else {
setCollapsed(function (prevState) {
var newState = _objectSpread({}, prevState);
Object.keys(newState).forEach(function (key) {
newState[key] = true;
});
return newState;
});
}
}, [hasCollapsed]);
return /*#__PURE__*/_react.default.createElement(_Styles.StyledDataTable, _extends({
as: _Table.Table,
innerRef: tableRef,
className: (0, _classnames.default)("c-data-table", className, {
"c-table__grouped": groupBy,
"c-table__collapsible": isCollapsible,
"padding-b-0": groupBy && collapsed[Object.keys(data).slice(-1)[0]]
})
}, args), /*#__PURE__*/_react.default.createElement(_Table.Thead, {
className: theadClass
}, header.length > 0 && /*#__PURE__*/_react.default.createElement("tr", {
className: "c-table__row"
}, header.map(function (h, index) {
return /*#__PURE__*/_react.default.createElement("th", {
key: h.key,
className: (0, _classnames.default)("c-table__cell", {
"c-table__cell--hovered": hovered === h.key,
"c-table__head--hidden": groupBy && allGroupsCollapsed && h.hideCollapsed
}),
onMouseOver: cellMouseOver,
onMouseLeave: cellMouseOut,
"data-key": h.key,
style: h.style
}, isCollapsible && groupBy && index === 0 && /*#__PURE__*/_react.default.createElement("span", {
className: "c-table__head__icon-wrapper",
onClick: toggleAllCollapsed,
"data-test": "toggle-collapse"
}, hasCollapsed ? /*#__PURE__*/_react.default.createElement(_ExpandAll.default, {
className: "c-table__head__icon-wrapper__icon"
}) : /*#__PURE__*/_react.default.createElement(_CollapseAll.default, {
className: "c-table__head__icon-wrapper__icon"
})), hovered === h.key && /*#__PURE__*/_react.default.createElement("div", {
className: "c-table__overlay",
style: {
height: overlayStyles() + "px"
}
}), /*#__PURE__*/_react.default.createElement("div", {
onClick: sortColumn,
"data-index": index,
className: (0, _classnames.default)("c-table__icon-wrapper", {
"cursor-pointer": h.sortable === true
})
}, /*#__PURE__*/_react.default.createElement("span", {
className: "c-table__label"
}, h.label), h.sortable && /*#__PURE__*/_react.default.createElement(_SortIcon.default, {
width: "10px",
height: "10px",
className: (0, _classnames.default)("c-table__icon", {
"c-table__icon--inactive": h.key !== active,
"c-table__icon--active": h.key === active,
"c-table__icon--asc": columnDirection === SortDirection.Asc && h.key === active,
"c-table__icon--desc": columnDirection === SortDirection.Desc && h.key === active
})
})));
}))), loading ? renderPlaceholders : renderRows);
};
DataTable.displayName = "DataTable";
//# sourceMappingURL=DataTable.js.map