@netdata/netdata-ui
Version:
netdata UI kit
87 lines • 4.78 kB
JavaScript
var _excluded = ["items", "value", "isMulti", "onChange", "children", "ButtonComponent", "buttonProps"];
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return 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); }
function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
import React, { Children, isValidElement, cloneElement } from "react";
import Flex from "../templates/flex";
import { Button } from "./button";
var noop = function noop() {};
var getButtonGroupProps = function getButtonGroupProps(itemIndex, itemsLength) {
var groupFirst = itemIndex == 0;
var groupLast = itemIndex == itemsLength - 1;
return {
groupFirst: groupFirst,
groupLast: groupLast,
groupMiddle: !groupFirst && !groupLast
};
};
var Content = function Content(_ref) {
var children = _ref.children;
var renderedChildren = Children.toArray(children).length;
return /*#__PURE__*/React.createElement(React.Fragment, null, Children.map(children, function (child, index) {
if (/*#__PURE__*/isValidElement(child)) {
var buttonGroupProps = getButtonGroupProps(index, renderedChildren);
return /*#__PURE__*/cloneElement(child, buttonGroupProps);
}
return child;
}));
};
var RadioButtons = function RadioButtons(_ref2) {
var items = _ref2.items,
value = _ref2.value,
isMulti = _ref2.isMulti,
_ref2$ButtonComponent = _ref2.ButtonComponent,
ButtonComponent = _ref2$ButtonComponent === void 0 ? Button : _ref2$ButtonComponent,
_ref2$buttonProps = _ref2.buttonProps,
buttonProps = _ref2$buttonProps === void 0 ? {} : _ref2$buttonProps,
onChange = _ref2.onChange;
return /*#__PURE__*/React.createElement(React.Fragment, null, items.map(function (item, index) {
var buttonGroupProps = getButtonGroupProps(index, items.length);
var isSelected = value === item.value || Array.isArray(value) && value.includes(item.value);
var onClick = function onClick() {
if (isMulti) {
var newValue = Array.isArray(value) ? value.includes(item.value) ? value.filter(function (v) {
return v !== item.value;
}) : [].concat(_toConsumableArray(value), [item.value]) : [item.value];
onChange(newValue);
} else {
onChange(item.value);
}
};
return /*#__PURE__*/React.createElement(ButtonComponent, _extends({
key: item.value,
label: item.label,
onClick: onClick
}, item.title ? {
title: item.title
} : {}, !isSelected ? {
flavour: "hollow"
} : {}, buttonGroupProps, buttonProps, item.buttonProps || {}));
}));
};
export var ButtonGroup = function ButtonGroup(_ref3) {
var items = _ref3.items,
value = _ref3.value,
isMulti = _ref3.isMulti,
_ref3$onChange = _ref3.onChange,
onChange = _ref3$onChange === void 0 ? noop : _ref3$onChange,
children = _ref3.children,
ButtonComponent = _ref3.ButtonComponent,
buttonProps = _ref3.buttonProps,
props = _objectWithoutPropertiesLoose(_ref3, _excluded);
return /*#__PURE__*/React.createElement(Flex, _extends({
alignItems: "center"
}, props), items != null && items.length ? /*#__PURE__*/React.createElement(RadioButtons, {
items: items,
value: value,
isMulti: isMulti,
onChange: onChange,
ButtonComponent: ButtonComponent,
buttonProps: buttonProps
}) : /*#__PURE__*/React.createElement(Content, null, children));
};