@netdata/netdata-ui
Version:
netdata UI kit
62 lines (61 loc) • 3.17 kB
JavaScript
;
exports.__esModule = true;
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _flex = _interopRequireDefault(require("../../templates/flex"));
var _select = _interopRequireDefault(require("../../select"));
var _typography = require("../../typography");
function _interopRequireDefault(e) { return e && e.__esModule ? e : { "default": e }; }
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, "default": e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
var HeaderGroupBy = function HeaderGroupBy(_ref) {
var grouping = _ref.grouping,
groupByColumns = _ref.groupByColumns,
onGroupBy = _ref.onGroupBy,
tableMeta = _ref.tableMeta,
dataGa = _ref.dataGa,
dataColumns = _ref.dataColumns;
var groupByOptions = (0, _react.useMemo)(function () {
return groupByColumns ? _extends({
"default": {
label: "None",
value: ""
}
}, Object.keys(groupByColumns).reduce(function (acc, colId) {
var _extends2;
var column = dataColumns.find(function (_ref2) {
var id = _ref2.id;
return id === colId;
});
return _extends({}, acc, (_extends2 = {}, _extends2[colId] = {
label: groupByColumns[colId].name || (column == null ? void 0 : column.name) || column.id,
value: colId
}, _extends2));
}, {})) : null;
}, [groupByColumns]);
if (!groupByOptions) return;
return /*#__PURE__*/_react["default"].createElement(_flex["default"], _extends({
alignItems: "center",
"data-testid": "tableGroupBy",
gap: 1
}, tableMeta.groupByContainerStyles), /*#__PURE__*/_react["default"].createElement(_typography.TextSmall, {
"data-testid": "tableGroupByLabel",
color: "textLite",
whiteSpace: "nowrap"
}, "Group by"), /*#__PURE__*/_react["default"].createElement(_select["default"], {
"data-ga": dataGa + "::group-by-filter::table-filter",
"data-testid": "tableGroupByFilter",
menuPortalTarget: document.body,
onChange: function onChange(_ref3) {
var value = _ref3.value;
return onGroupBy(value);
},
options: Object.values(groupByOptions),
styles: {
size: "tiny",
minWidth: 120
},
value: groupByOptions[grouping] || groupByOptions["default"]
}));
};
var _default = exports["default"] = /*#__PURE__*/(0, _react.memo)(HeaderGroupBy);