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>
198 lines • 29.9 kB
JavaScript
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _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(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t.return && (u = t.return(), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
import React, { useState } from "react";
import PropTypes from "prop-types";
import classNames from "classnames";
import Icon from "../icon";
import Popover from "../popover";
import Checkbox from "../checkbox";
import Radio from "../radio";
import "./style";
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 = useState(getFilteredValue(filteredValueProp)),
_useState2 = _slicedToArray(_useState, 2),
filteredValue = _useState2[0],
setFilteredValue = _useState2[1];
var _useState3 = useState(filterVisible || false),
_useState4 = _slicedToArray(_useState3, 2),
visible = _useState4[0],
setVisible = _useState4[1];
var _useState5 = 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.createElement("div", null, React.createElement("div", {
className: "".concat(prefix, "-filter-search")
}, React.createElement("input", {
value: searchValue,
placeholder: filterSearchPlaceholder,
onChange: function onChange(e) {
var value = e.target.value;
setSearchValue(value);
}
}), React.createElement(Icon, {
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.createElement(React.Fragment, null, popup, !filters.length ? React.createElement("div", {
className: "".concat(prefix, "-filter-no")
}, "\u65E0\u5339\u914D\u7ED3\u679C") : React.createElement(Checkbox.Group, {
className: "".concat(prefix, "-filterList"),
defaultValue: ["all"],
value: filteredValue,
onChange: handleChange
}, filters.map(function (item) {
return React.createElement(Checkbox, {
key: item.value,
value: item.value
}, item.text);
})));
} else {
popup = React.createElement(React.Fragment, null, popup, !filters.length ? React.createElement("div", {
className: "".concat(prefix, "-filter-no")
}, "\u65E0\u5339\u914D\u7ED3\u679C") : React.createElement(Radio.Group, {
className: "".concat(prefix, "-filterList"),
defaultValue: "all",
value: filteredValue ? filteredValue[0] : null,
onChange: handleChange
}, React.createElement(Radio, {
value: "all"
}, "\u5168\u90E8"), filters.map(function (item) {
return React.createElement(Radio, {
key: item.value,
value: item.value
}, item.text);
})));
}
return React.createElement(Popover, _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.createElement("div", {
"data-value": filteredValue,
role: "columnheader",
className: classNames("".concat(prefix, "-filter"), _defineProperty({}, "".concat(prefix, "-filtered"), filteredValue && (filteredValue.length > 1 || filteredValue[0] !== "all")))
}, !sortableAndFilterable ? title : null, React.createElement(Icon, {
icon: "filter-outlined"
}), !sortableAndFilterable && React.createElement("div", {
className: "".concat(prefix, "-clickholder")
})));
};
TableFilter.propTypes = {
filterMultiple: PropTypes.bool,
filterSearchable: PropTypes.bool,
filterSearchCaseSensitive: PropTypes.bool,
filterSearchPlaceholder: PropTypes.string,
filterSearchFunc: PropTypes.func,
filterPopoverProps: PropTypes.object,
filteredValue: PropTypes.array,
filters: PropTypes.any,
filterVisible: PropTypes.bool,
onFilter: PropTypes.func,
onFilterVisibleChange: PropTypes.func,
title: PropTypes.node,
sortableAndFilterable: PropTypes.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
};
export default TableFilter;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useState","PropTypes","classNames","Icon","Popover","Checkbox","Radio","prefix","getFilteredValue","val","undefined","length","TableFilter","_ref","filterSearchable","filterSearchPlaceholder","filterSearchCaseSensitive","filterSearchFunc","filteredValueProp","filteredValue","filterMultiple","filterPopoverProps","filterVisible","filtersProp","filters","onFilter","onFilterVisibleChange","title","sortableAndFilterable","_useState","_useState2","_slicedToArray","setFilteredValue","_useState3","_useState4","visible","setVisible","_useState5","_useState6","searchValue","setSearchValue","JSON","stringify","handleChange","filteredValueParam","newValue","includes","splice","indexOf","setTimeout","popup","createElement","className","concat","value","placeholder","onChange","e","target","icon","filter","o","text","String","toLocaleLowerCase","Fragment","Group","defaultValue","map","item","key","_extends","arrowed","onVisibleChange","bool","trigger","placement","role","_defineProperty","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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","ignoreList":[]}