@zohodesk/dot
Version:
In this Library, we Provide Some Basic Components to Build Your Application
124 lines (103 loc) • 6.49 kB
JavaScript
;
function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = StatusListItem;
var _react = _interopRequireWildcard(require("react"));
var _defaultProps = require("./props/defaultProps");
var _propTypes = require("./props/propTypes");
var _Layout = require("@zohodesk/components/es/v1/Layout");
var _icons = require("@zohodesk/icons");
var _CssProvider = _interopRequireDefault(require("@zohodesk/components/es/Provider/CssProvider"));
var _StatusListItemModule = _interopRequireDefault(require("../../../../list/status/StatusListItem/StatusListItem.module.css"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
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 StatusListItem(props) {
var size = props.size,
active = props.active,
highlight = props.highlight,
value = props.value,
autoHover = props.autoHover,
palette = props.palette,
title = props.title,
disableTitle = props.disableTitle,
needTick = props.needTick,
isLink = props.isLink,
href = props.href,
target = props.target,
needBorder = props.needBorder,
isDisabled = props.isDisabled,
bulletColor = props.bulletColor,
a11y = props.a11y,
needMultiLineText = props.needMultiLineText,
index = props.index,
getRef = props.getRef,
id = props.id,
onClick = props.onClick,
onMouseEnter = props.onMouseEnter,
customClass = props.customClass,
children = props.children;
var options = {};
var role = a11y.role,
ariaSelected = a11y.ariaSelected,
_a11y$ariaHidden = a11y.ariaHidden,
ariaHidden = _a11y$ariaHidden === void 0 ? true : _a11y$ariaHidden,
ariaLabel = a11y.ariaLabel,
_a11y$insetFocus = a11y.insetFocus,
insetFocus = _a11y$insetFocus === void 0 ? true : _a11y$insetFocus;
if (isLink) {
options.href = href;
options.target = "_".concat(target);
}
var element = (0, _react.useRef)(null);
function getReference(ele) {
element.current = ele;
getRef && getRef(element.current, index, id);
}
function handleClick(e) {
onClick && onClick(id, value, index, e);
}
function handleMouseEnter(e) {
onMouseEnter && onMouseEnter(id, value, index, e);
}
return /*#__PURE__*/_react["default"].createElement(_Layout.Container, _extends({
role: role,
"aria-selected": ariaSelected,
"aria-label": ariaLabel,
"data-a11y-inset-focus": insetFocus,
isCover: false,
align: "baseline",
alignBox: "row",
className: "".concat(_StatusListItemModule["default"].list, " ").concat(_StatusListItemModule["default"][size], " ").concat(_StatusListItemModule["default"][palette], " ").concat(active ? _StatusListItemModule["default"].active : highlight && !isDisabled ? _StatusListItemModule["default"].hover : '', " ").concat(autoHover && !isDisabled ? _StatusListItemModule["default"].effect : '', " ").concat(needTick ? _StatusListItemModule["default"].withTick : '', " ").concat(isDisabled ? (0, _CssProvider["default"])('isDisable') : '', " ").concat(needBorder ? _StatusListItemModule["default"].withBorder : '', " ").concat(customClass),
dataId: String(value).replace("'", '_'),
onClick: !isDisabled && handleClick,
onMouseEnter: handleMouseEnter,
eleRef: getReference,
tagName: isLink ? 'a' : 'li',
"data-title": isDisabled ? disableTitle : null,
tabindex: isDisabled ? '-1' : '0'
}, options, a11y), /*#__PURE__*/_react["default"].createElement(_Layout.Box, {
className: "".concat(_StatusListItemModule["default"].statusType, " ").concat(_StatusListItemModule["default"][bulletColor])
}), /*#__PURE__*/_react["default"].createElement(_Layout.Box, {
flexible: true,
shrink: true
}, /*#__PURE__*/_react["default"].createElement(_Layout.Container, {
alignBox: "row",
align: needMultiLineText ? 'top' : 'vertical'
}, /*#__PURE__*/_react["default"].createElement(_Layout.Box, {
"data-title": isDisabled ? null : title,
shrink: true,
className: needMultiLineText ? _StatusListItemModule["default"].multiLineValue : _StatusListItemModule["default"].value
}, value), /*#__PURE__*/_react["default"].createElement(_Layout.Box, null, children && children))), needTick && active ? /*#__PURE__*/_react["default"].createElement("div", {
className: _StatusListItemModule["default"].tickIcon,
"aria-hidden": ariaHidden
}, /*#__PURE__*/_react["default"].createElement(_icons.Icon, {
name: "ZD-ticknew",
size: "8"
})) : null);
}
StatusListItem.defaultProps = _defaultProps.defaultProps;
StatusListItem.propTypes = _propTypes.propTypes;