UNPKG

mobile-more

Version:

基于 antd-mobile v5 扩展移动端 UI 组件

53 lines (52 loc) 2.38 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2")); var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties")); var _antdMobile = require("antd-mobile"); var React = _interopRequireWildcard(require("react")); var _BizCheckListPopup = _interopRequireDefault(require("../../BizCheckListPopup")); var _excluded = ["placeholder", "separator", "options", "value", "fieldNames", "renderCurrentValue"]; var SuperCheckList = function SuperCheckList(_ref) { var placeholder = _ref.placeholder, _ref$separator = _ref.separator, separator = _ref$separator === void 0 ? ', ' : _ref$separator, _ref$options = _ref.options, options = _ref$options === void 0 ? [] : _ref$options, value = _ref.value, fieldNames = _ref.fieldNames, renderCurrentValue = _ref.renderCurrentValue, restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded); var _React$useMemo = React.useMemo(function () { return (0, _objectSpread2.default)({ label: 'label', value: 'value' }, fieldNames); }, [fieldNames]), labelKey = _React$useMemo.label, valueKey = _React$useMemo.value; var items = React.useMemo(function () { return options.filter(function (item) { return value === null || value === void 0 ? void 0 : value.includes(item[valueKey]); }); }, [options, value, valueKey]); var valueStr = typeof renderCurrentValue === 'function' ? renderCurrentValue(value, items) : items.filter(function (item) { return !!item; }).map(function (item) { return item[labelKey]; }).join(separator); return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement(_antdMobile.Input, { readOnly: true, value: valueStr, placeholder: placeholder }), /*#__PURE__*/React.createElement(_BizCheckListPopup.default, (0, _objectSpread2.default)({ value: value, options: options, fieldNames: fieldNames }, restProps))); }; var _default = exports.default = SuperCheckList;