@zohodesk/dot
Version:
In this Library, we Provide Some Basic Components to Build Your Application
113 lines (92 loc) • 5.82 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"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _defaultProps = require("./props/defaultProps");
var _propTypes = require("./props/propTypes");
var _Layout = require("@zohodesk/components/es/v1/Layout");
var _AlphabeticListModule = _interopRequireDefault(require("../../AlphabeticList/AlphabeticList.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; }
/*** Libraries ***/
/*** CSS ***/
var AlphabeticListItemMemo = /*#__PURE__*/(0, _react.memo)(AlphabeticListItem);
function AlphabeticList(props) {
var onSelect = props.onSelect,
selectedCharacter = props.selectedCharacter,
align = props.align,
type = props.type,
i18nKeys = props.i18nKeys,
dataId = props.dataId,
dataSelectorId = props.dataSelectorId;
var _i18nKeys$allText = i18nKeys.allText,
allText = _i18nKeys$allText === void 0 ? 'All' : _i18nKeys$allText,
_i18nKeys$allTitle = i18nKeys.allTitle,
allTitle = _i18nKeys$allTitle === void 0 ? 'All' : _i18nKeys$allTitle;
var alignType = align === 'vertical' ? _AlphabeticListModule["default"].column : _AlphabeticListModule["default"].row;
var letters = type == 'alphabeticalwithhash' ? _propTypes.AlphabeticCharactersWithHash : type == 'alphabetical' ? _propTypes.AlphabeticCharacters : _propTypes.NumberList;
var handleSelectAll = function handleSelectAll() {
onSelect && selectedCharacter != 'ALL' && onSelect('ALL');
};
var handleSelect = function handleSelect(id) {
onSelect && selectedCharacter !== id && onSelect(id);
};
return /*#__PURE__*/_react["default"].createElement(_Layout.Container, {
tagName: "ul",
isCover: false,
alignBox: align === 'vertical' ? 'column' : 'row',
className: "".concat(_AlphabeticListModule["default"].container, " ").concat(alignType, " ").concat(type != 'alphabetical' ? _AlphabeticListModule["default"].numbers : ''),
dataId: "navigationDiv",
dataSelectorId: dataSelectorId
}, /*#__PURE__*/_react["default"].createElement(_Layout.Box, {
tagName: "li",
className: "".concat(_AlphabeticListModule["default"].list, " ").concat(_AlphabeticListModule["default"].title, " ").concat(selectedCharacter === 'ALL' ? _AlphabeticListModule["default"].selected : ''),
dataId: "All_".concat(dataId)
}, /*#__PURE__*/_react["default"].createElement("span", {
onClick: handleSelectAll,
className: "".concat(_AlphabeticListModule["default"].heading, " ").concat(_AlphabeticListModule["default"].letter),
"data-title": allTitle
}, allText)), letters.map(function (letter) {
return /*#__PURE__*/_react["default"].createElement(AlphabeticListItemMemo, {
id: letter,
isActive: letter === selectedCharacter,
onClick: handleSelect,
text: letter,
key: letter,
dataId: dataId
});
}));
}
AlphabeticList.propTypes = _propTypes.AlphabeticList_propTypes;
AlphabeticList.defaultProps = _defaultProps.AlphabeticList_defaultProps;
var MemoizedAlphabeticList = /*#__PURE__*/(0, _react.memo)(AlphabeticList);
MemoizedAlphabeticList.propTypes = _propTypes.AlphabeticList_propTypes;
MemoizedAlphabeticList.defaultProps = _defaultProps.AlphabeticList_defaultProps;
MemoizedAlphabeticList.displayName = 'AlphabeticList';
var _default = MemoizedAlphabeticList;
exports["default"] = _default;
function AlphabeticListItem(props) {
var isActive = props.isActive,
text = props.text,
dataId = props.dataId,
onClick = props.onClick,
id = props.id;
var handleClick = function handleClick() {
onClick && onClick(id);
};
return /*#__PURE__*/_react["default"].createElement(_Layout.Box, {
flexible: true,
tagName: "li",
className: "".concat(_AlphabeticListModule["default"].list, " ").concat(isActive ? _AlphabeticListModule["default"].selected : ''),
onClick: handleClick,
dataId: "".concat(text, "_").concat(dataId)
}, /*#__PURE__*/_react["default"].createElement("span", {
className: _AlphabeticListModule["default"].letter
}, text));
}
AlphabeticListItem.propTypes = _propTypes.AlphabeticListItem_propTypes;
AlphabeticListItem.defaultProps = _defaultProps.AlphabeticListItem_defaultProps;