UNPKG

@wix/design-system

Version:

@wix/design-system

231 lines (230 loc) 7.78 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); exports.__esModule = true; exports["default"] = void 0; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _react = _interopRequireWildcard(require("react")); var _Checkbox = _interopRequireDefault(require("../../Checkbox")); var _ToggleSwitch = _interopRequireDefault(require("../../ToggleSwitch")); var _Radio = _interopRequireDefault(require("../../Radio")); var _Text = _interopRequireDefault(require("../../Text")); var _Collapse = _interopRequireDefault(require("../../Collapse")); var _Divider = _interopRequireDefault(require("../../Divider")); var _constants = require("../constants"); var _StringUtils = require("../../utils/StringUtils"); var _useHover2 = require("../../common/useHover"); var _ItemSt = require("./Item.st.css.js"); var _jsxFileName = "/home/builduser/work/57e038ea7326c1ec/packages/wix-design-system/dist/cjs/SelectableAccordion/Item/Item.jsx", _this = void 0; 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); } var renderTitle = function renderTitle(title) { if ((0, _StringUtils.isString)(title)) { return /*#__PURE__*/_react["default"].createElement(_Text["default"], { weight: "normal", size: "medium", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 16, columnNumber: 7 } }, title); } return title; }; var renderSubtitle = function renderSubtitle(subtitle) { return (0, _StringUtils.isString)(subtitle) ? /*#__PURE__*/_react["default"].createElement(_Text["default"], { ellipsis: true, size: "small", weight: "thin", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 26, columnNumber: 5 } }, subtitle) : subtitle; }; var renderContent = function renderContent(content) { return (0, _StringUtils.isString)(content) ? /*#__PURE__*/_react["default"].createElement(_Text["default"], { className: _ItemSt.classes.text, size: "small", weight: "thin", __self: _this, __source: { fileName: _jsxFileName, lineNumber: 35, columnNumber: 5 } }, content) : content; }; var renderSelector = function renderSelector(_ref) { var type = _ref.type, open = _ref.open, disabled = _ref.disabled, onChange = _ref.onChange; var selector = null; switch (type) { case _constants.TYPES.CHECKBOX: selector = /*#__PURE__*/_react["default"].createElement(_Checkbox["default"], { checked: open, onChange: onChange, disabled: disabled, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 48, columnNumber: 9 } }); break; case _constants.TYPES.RADIO: selector = /*#__PURE__*/_react["default"].createElement(_Radio["default"], { checked: open, onChange: onChange, disabled: disabled, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 53, columnNumber: 9 } }); break; case _constants.TYPES.TOGGLE: selector = /*#__PURE__*/_react["default"].createElement(_ToggleSwitch["default"], { checked: open, onChange: onChange, size: "small", disabled: disabled, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 58, columnNumber: 9 } }); break; default: break; } return /*#__PURE__*/_react["default"].createElement("span", { className: _ItemSt.classes.selectorToggle, onClick: function onClick(e) { return e.stopPropagation(); }, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 70, columnNumber: 5 } }, selector); }; var SelectableAccordionItem = function SelectableAccordionItem(_ref2) { var _ref2$type = _ref2.type, type = _ref2$type === void 0 ? 'toggle' : _ref2$type, _ref2$onChange = _ref2.onChange, onChange = _ref2$onChange === void 0 ? function () {} : _ref2$onChange, idx = _ref2.idx, open = _ref2.open, disabled = _ref2.disabled, verticalPadding = _ref2.verticalPadding, title = _ref2.title, subtitle = _ref2.subtitle, content = _ref2.content; var _useHover = (0, _useHover2.useHover)(), hovered = _useHover.hovered, hoverProps = _useHover.hoverProps; var handleChange = (0, _react.useCallback)(function (event) { if (disabled) { return; } if (type === 'radio' && open) { return; } onChange(event, idx, !open); }, [disabled, type, open, onChange, idx]); return /*#__PURE__*/_react["default"].createElement("div", (0, _extends2["default"])({}, hoverProps, { "data-hook": _constants.dataHooks.item, "data-state": open ? 'open' : 'collapsed', "data-disabled": disabled, className: (0, _ItemSt.st)(_ItemSt.classes.item, { hovered: !open && hovered, verticalPadding: verticalPadding, disabled: disabled }), __self: _this, __source: { fileName: _jsxFileName, lineNumber: 103, columnNumber: 5 } }), /*#__PURE__*/_react["default"].createElement("div", { onClick: handleChange, className: _ItemSt.classes.selector, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 114, columnNumber: 7 } }, renderSelector({ type: type, open: open, disabled: disabled, onChange: handleChange })), /*#__PURE__*/_react["default"].createElement("div", { "data-hook": _constants.dataHooks.itemHeader, onClick: handleChange, className: _ItemSt.classes.header, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 117, columnNumber: 7 } }, renderTitle(title), renderSubtitle(subtitle)), /*#__PURE__*/_react["default"].createElement("div", { className: _ItemSt.classes.content, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 125, columnNumber: 7 } }, content ? /*#__PURE__*/_react["default"].createElement(_Collapse["default"], { open: open, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 127, columnNumber: 11 } }, /*#__PURE__*/_react["default"].createElement("div", { className: _ItemSt.classes.inner, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 128, columnNumber: 13 } }, renderContent(content))) : null, /*#__PURE__*/_react["default"].createElement("div", { className: _ItemSt.classes.divider, __self: _this, __source: { fileName: _jsxFileName, lineNumber: 131, columnNumber: 9 } }, /*#__PURE__*/_react["default"].createElement(_Divider["default"], { __self: _this, __source: { fileName: _jsxFileName, lineNumber: 132, columnNumber: 11 } })))); }; SelectableAccordionItem.displayName = 'SelectableAccordionItem'; var _default = exports["default"] = SelectableAccordionItem;