adui
Version:
<div> <img src="https://wxa.wxs.qq.com/mpweb/delivery/legacy/wxadtouch/upload/t1/od834zef_52939fc6.png" style="margin:40px 0 0 -8px; background-color: #fcfcfc; box-shadow: none;" /> </div>
252 lines (205 loc) • 30.1 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 _propTypes = _interopRequireDefault(require("prop-types"));
var _classnames = _interopRequireDefault(require("classnames"));
var _icon = _interopRequireDefault(require("../icon"));
var _popover = _interopRequireDefault(require("../popover"));
var _checkbox = _interopRequireDefault(require("../checkbox"));
var _radio = _interopRequireDefault(require("../radio"));
require("./style");
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 _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
var prefix = "adui-table";
var getFilteredValue = function getFilteredValue(val) {
if (val === null || val === undefined || val.length === 0) {
return ["all"];
}
return val;
};
var TableFilter = function TableFilter(_ref) {
var filterSearchable = _ref.filterSearchable,
filterSearchPlaceholder = _ref.filterSearchPlaceholder,
filterSearchCaseSensitive = _ref.filterSearchCaseSensitive,
filterSearchFunc = _ref.filterSearchFunc,
filteredValueProp = _ref.filteredValue,
filterMultiple = _ref.filterMultiple,
filterPopoverProps = _ref.filterPopoverProps,
filterVisible = _ref.filterVisible,
filtersProp = _ref.filters,
onFilter = _ref.onFilter,
onFilterVisibleChange = _ref.onFilterVisibleChange,
title = _ref.title,
sortableAndFilterable = _ref.sortableAndFilterable;
if (!filtersProp) {
return null;
}
var _useState = (0, _react.useState)(getFilteredValue(filteredValueProp)),
_useState2 = _slicedToArray(_useState, 2),
filteredValue = _useState2[0],
setFilteredValue = _useState2[1];
var _useState3 = (0, _react.useState)(filterVisible || false),
_useState4 = _slicedToArray(_useState3, 2),
visible = _useState4[0],
setVisible = _useState4[1];
var _useState5 = (0, _react.useState)(""),
_useState6 = _slicedToArray(_useState5, 2),
searchValue = _useState6[0],
setSearchValue = _useState6[1];
if (filteredValueProp !== null && filteredValueProp !== undefined && JSON.stringify(filteredValue) !== JSON.stringify(getFilteredValue(filteredValueProp))) {
setFilteredValue(getFilteredValue(filteredValueProp));
}
if (typeof filterVisible === "boolean" && visible !== filterVisible) {
setVisible(filterVisible);
}
var handleChange = function handleChange(filteredValueParam) {
var newValue = filterMultiple && filteredValueParam ? filteredValueParam : [filteredValueParam];
if (newValue.includes("all")) {
newValue.splice(newValue.indexOf("all"), 1);
}
if (filteredValueProp === null) {
setFilteredValue(getFilteredValue(newValue));
}
if (onFilter) {
if (filteredValueParam === "all") {
onFilter([]);
} else {
onFilter(newValue);
}
}
if (!filterMultiple) {
setTimeout(function () {
if (onFilterVisibleChange) {
onFilterVisibleChange(false);
}
setVisible(false);
}, 100);
}
};
var popup;
if (filterSearchable) {
popup = _react["default"].createElement("div", null, _react["default"].createElement("div", {
className: "".concat(prefix, "-filter-search")
}, _react["default"].createElement("input", {
value: searchValue,
placeholder: filterSearchPlaceholder,
onChange: function onChange(e) {
var value = e.target.value;
setSearchValue(value);
}
}), _react["default"].createElement(_icon["default"], {
icon: "search",
className: "".concat(prefix, "-filter-icon")
})));
}
var filters = searchValue ? filtersProp.filter(function (o) {
var text = o.text;
if (filterSearchFunc) {
return filterSearchFunc(searchValue, o);
}
if (!filterSearchCaseSensitive) {
return String(text).toLocaleLowerCase().includes(searchValue.toLocaleLowerCase());
}
return String(text).includes(searchValue);
}) : filtersProp;
if (filterMultiple) {
popup = _react["default"].createElement(_react["default"].Fragment, null, popup, !filters.length ? _react["default"].createElement("div", {
className: "".concat(prefix, "-filter-no")
}, "\u65E0\u5339\u914D\u7ED3\u679C") : _react["default"].createElement(_checkbox["default"].Group, {
className: "".concat(prefix, "-filterList"),
defaultValue: ["all"],
value: filteredValue,
onChange: handleChange
}, filters.map(function (item) {
return _react["default"].createElement(_checkbox["default"], {
key: item.value,
value: item.value
}, item.text);
})));
} else {
popup = _react["default"].createElement(_react["default"].Fragment, null, popup, !filters.length ? _react["default"].createElement("div", {
className: "".concat(prefix, "-filter-no")
}, "\u65E0\u5339\u914D\u7ED3\u679C") : _react["default"].createElement(_radio["default"].Group, {
className: "".concat(prefix, "-filterList"),
defaultValue: "all",
value: filteredValue ? filteredValue[0] : null,
onChange: handleChange
}, _react["default"].createElement(_radio["default"], {
value: "all"
}, "\u5168\u90E8"), filters.map(function (item) {
return _react["default"].createElement(_radio["default"], {
key: item.value,
value: item.value
}, item.text);
})));
}
return _react["default"].createElement(_popover["default"], _extends({
arrowed: false,
visible: visible,
onVisibleChange: function onVisibleChange(bool) {
if (typeof filterVisible !== "boolean") {
setVisible(bool);
}
if (onFilterVisibleChange) {
onFilterVisibleChange(bool);
}
},
popup: popup,
trigger: "click",
placement: "bottomLeft"
}, filterPopoverProps), _react["default"].createElement("div", {
"data-value": filteredValue,
role: "columnheader",
className: (0, _classnames["default"])("".concat(prefix, "-filter"), _defineProperty({}, "".concat(prefix, "-filtered"), filteredValue && (filteredValue.length > 1 || filteredValue[0] !== "all")))
}, !sortableAndFilterable ? title : null, _react["default"].createElement(_icon["default"], {
icon: "filter-outlined"
}), !sortableAndFilterable && _react["default"].createElement("div", {
className: "".concat(prefix, "-clickholder")
})));
};
TableFilter.propTypes = {
filterMultiple: _propTypes["default"].bool,
filterSearchable: _propTypes["default"].bool,
filterSearchCaseSensitive: _propTypes["default"].bool,
filterSearchPlaceholder: _propTypes["default"].string,
filterSearchFunc: _propTypes["default"].func,
filterPopoverProps: _propTypes["default"].object,
filteredValue: _propTypes["default"].array,
filters: _propTypes["default"].any,
filterVisible: _propTypes["default"].bool,
onFilter: _propTypes["default"].func,
onFilterVisibleChange: _propTypes["default"].func,
title: _propTypes["default"].node,
sortableAndFilterable: _propTypes["default"].bool
};
TableFilter.defaultProps = {
filterMultiple: false,
filterSearchable: false,
filterSearchCaseSensitive: false,
filterSearchPlaceholder: "在筛选项中搜索",
filterSearchFunc: undefined,
filterPopoverProps: {},
filteredValue: null,
filterVisible: null,
filters: null,
onFilter: null,
onFilterVisibleChange: null,
title: null,
sortableAndFilterable: false
};
var _default = TableFilter;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["prefix","getFilteredValue","val","undefined","length","TableFilter","filterSearchable","filterSearchPlaceholder","filterSearchCaseSensitive","filterSearchFunc","filteredValueProp","filteredValue","filterMultiple","filterPopoverProps","filterVisible","filtersProp","filters","onFilter","onFilterVisibleChange","title","sortableAndFilterable","useState","setFilteredValue","visible","setVisible","searchValue","setSearchValue","JSON","stringify","handleChange","filteredValueParam","newValue","includes","splice","indexOf","setTimeout","popup","e","value","target","filter","o","text","String","toLocaleLowerCase","map","item","bool","classNames","propTypes","PropTypes","string","func","object","array","any","node","defaultProps"],"sources":["../../components/table/TableFilter.tsx"],"sourcesContent":["import React, { useState } from \"react\"\nimport PropTypes from \"prop-types\"\nimport classNames from \"classnames\"\nimport Icon from \"../icon\"\nimport Popover, { IPopoverProps } from \"../popover\"\nimport Checkbox from \"../checkbox\"\nimport Radio from \"../radio\"\nimport \"./style\"\n\nconst prefix = \"adui-table\"\nconst getFilteredValue = (val?: (string | number)[] | null) => {\n  if (val === null || val === undefined || val.length === 0) {\n    return [\"all\"]\n  }\n  return val\n}\n\nexport interface ITableFilterProps {\n  filteredValue?: (string | number)[] | null\n  filterMultiple?: boolean\n  filterSearchable?: boolean\n  filterSearchCaseSensitive?: boolean\n  filterSearchPlaceholder?: string\n  filterSearchFunc?: (\n    input: string,\n    item: { text: string; value: string | number }\n  ) => boolean\n  filterPopoverProps?: IPopoverProps\n  filters?: Array<{ text: string; value: string | number }> | null\n  filterVisible?: boolean | null\n  onFilter?: ((value: (string | number)[]) => void) | null\n  onFilterVisibleChange?: ((visible: boolean) => void) | null\n  title?: React.ReactNode\n  sortableAndFilterable?: boolean\n}\n\n/**\n * 表格筛选\n */\nconst TableFilter: React.FC<ITableFilterProps> = ({\n  filterSearchable,\n  filterSearchPlaceholder,\n  filterSearchCaseSensitive,\n  filterSearchFunc,\n  filteredValue: filteredValueProp,\n  filterMultiple,\n  filterPopoverProps,\n  filterVisible,\n  filters: filtersProp,\n  onFilter,\n  onFilterVisibleChange,\n  title,\n  sortableAndFilterable,\n}: ITableFilterProps) => {\n  if (!filtersProp) {\n    return null\n  }\n  const [filteredValue, setFilteredValue] = useState(\n    getFilteredValue(filteredValueProp)\n  )\n  const [visible, setVisible] = useState(filterVisible || false)\n  const [searchValue, setSearchValue] = useState(\"\")\n\n  // 相当于生命周期 getDerivedStateFromProps\n  if (\n    filteredValueProp !== null &&\n    filteredValueProp !== undefined &&\n    JSON.stringify(filteredValue) !==\n      JSON.stringify(getFilteredValue(filteredValueProp))\n  ) {\n    setFilteredValue(getFilteredValue(filteredValueProp))\n  }\n\n  if (typeof filterVisible === \"boolean\" && visible !== filterVisible) {\n    setVisible(filterVisible)\n  }\n\n  const handleChange = (\n    filteredValueParam: (string | number) | (string | number)[]\n  ) => {\n    const newValue: any =\n      filterMultiple && filteredValueParam\n        ? filteredValueParam\n        : [filteredValueParam]\n    if (newValue.includes(\"all\")) {\n      newValue.splice(newValue.indexOf(\"all\"), 1)\n    }\n    if (filteredValueProp === null) {\n      setFilteredValue(getFilteredValue(newValue))\n    }\n    if (onFilter) {\n      if (filteredValueParam === \"all\") {\n        onFilter([])\n      } else {\n        onFilter(newValue)\n      }\n    }\n    if (!filterMultiple) {\n      // 延迟是为了让状态的变化在视觉上先被接受\n      setTimeout(() => {\n        if (onFilterVisibleChange) {\n          onFilterVisibleChange(false)\n        }\n        setVisible(false)\n      }, 100)\n    }\n  }\n\n  let popup\n\n  if (filterSearchable) {\n    popup = (\n      <div>\n        <div className={`${prefix}-filter-search`}>\n          <input\n            value={searchValue}\n            placeholder={filterSearchPlaceholder}\n            onChange={(e) => {\n              const { value } = e.target\n              setSearchValue(value)\n            }}\n          />\n          <Icon icon=\"search\" className={`${prefix}-filter-icon`} />\n        </div>\n      </div>\n    )\n  }\n\n  const filters = searchValue\n    ? filtersProp.filter((o) => {\n        const { text } = o\n        if (filterSearchFunc) {\n          return filterSearchFunc(searchValue, o)\n        }\n        if (!filterSearchCaseSensitive) {\n          return String(text)\n            .toLocaleLowerCase()\n            .includes(searchValue.toLocaleLowerCase())\n        }\n        return String(text).includes(searchValue)\n      })\n    : filtersProp\n\n  if (filterMultiple) {\n    popup = (\n      <>\n        {popup}\n        {!filters.length ? (\n          <div className={`${prefix}-filter-no`}>无匹配结果</div>\n        ) : (\n          <Checkbox.Group\n            className={`${prefix}-filterList`}\n            defaultValue={[\"all\"]}\n            value={filteredValue}\n            onChange={handleChange}\n          >\n            {filters.map((item) => (\n              <Checkbox key={item.value} value={item.value}>\n                {item.text}\n              </Checkbox>\n            ))}\n          </Checkbox.Group>\n        )}\n      </>\n    )\n  } else {\n    popup = (\n      <>\n        {popup}\n        {!filters.length ? (\n          <div className={`${prefix}-filter-no`}>无匹配结果</div>\n        ) : (\n          <Radio.Group\n            className={`${prefix}-filterList`}\n            defaultValue=\"all\"\n            value={filteredValue ? filteredValue[0] : null}\n            onChange={handleChange}\n          >\n            <Radio value=\"all\">全部</Radio>\n            {filters.map((item) => (\n              <Radio key={item.value} value={item.value}>\n                {item.text}\n              </Radio>\n            ))}\n          </Radio.Group>\n        )}\n      </>\n    )\n  }\n\n  return (\n    <Popover\n      arrowed={false}\n      visible={visible}\n      onVisibleChange={(bool) => {\n        if (typeof filterVisible !== \"boolean\") {\n          setVisible(bool)\n        }\n        if (onFilterVisibleChange) {\n          onFilterVisibleChange(bool)\n        }\n      }}\n      popup={popup}\n      trigger=\"click\"\n      placement=\"bottomLeft\"\n      {...filterPopoverProps}\n    >\n      <div\n        data-value={filteredValue}\n        role=\"columnheader\"\n        className={classNames(`${prefix}-filter`, {\n          [`${prefix}-filtered`]:\n            filteredValue &&\n            (filteredValue.length > 1 || filteredValue[0] !== \"all\"),\n        })}\n      >\n        {!sortableAndFilterable ? title : null}\n        <Icon icon=\"filter-outlined\" />\n        {!sortableAndFilterable && <div className={`${prefix}-clickholder`} />}\n      </div>\n    </Popover>\n  )\n}\n\nTableFilter.propTypes = {\n  /**\n   * 是否多选\n   */\n  filterMultiple: PropTypes.bool,\n  /**\n   * 筛选是否支持搜索\n   */\n  filterSearchable: PropTypes.bool,\n  /**\n   * 筛选搜索开启大小写敏感搜索，默认为 false\n   */\n  filterSearchCaseSensitive: PropTypes.bool,\n  /**\n   * 筛选搜索 placeholder\n   */\n  filterSearchPlaceholder: PropTypes.string,\n  /**\n   * 筛选搜索的自定义 function\n   */\n  filterSearchFunc: PropTypes.func,\n  /**\n   * 筛选 Popover props，会将此对象透传给 <Popover />\n   */\n  filterPopoverProps: PropTypes.object,\n  /**\n   * 可以从外部传入筛选的值，null, [], 都会识别为未筛选状态\n   */\n  filteredValue: PropTypes.array,\n  /**\n   * 筛选项，格式：[{ text: \"朋友圈广告\", value: '2' }]\n   */\n  filters: PropTypes.any,\n  /**\n   * 从外部控制 filter Popover 的显示\n   */\n  filterVisible: PropTypes.bool,\n  /**\n   * 筛选时的 handler\n   */\n  onFilter: PropTypes.func,\n  /**\n   * 筛选 popup visible 变化时的 handler，参数 (bool, col)\n   */\n  onFilterVisibleChange: PropTypes.func,\n  /**\n   * title\n   */\n  title: PropTypes.node,\n  /**\n   * sortableAndFilterable?: boolean\n   */\n  sortableAndFilterable: PropTypes.bool,\n}\n\nTableFilter.defaultProps = {\n  filterMultiple: false,\n  filterSearchable: false,\n  filterSearchCaseSensitive: false,\n  filterSearchPlaceholder: \"在筛选项中搜索\",\n  filterSearchFunc: undefined,\n  filterPopoverProps: {},\n  filteredValue: null,\n  filterVisible: null,\n  filters: null,\n  onFilter: null,\n  onFilterVisibleChange: null,\n  title: null,\n  sortableAndFilterable: false,\n}\n\nexport default TableFilter\n"],"mappings":"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"}