UNPKG

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>

228 lines (195 loc) 27.9 kB
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; } 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","filterSearchable","filterSearchPlaceholder","filterSearchCaseSensitive","filterSearchFunc","filteredValueProp","filteredValue","filterMultiple","filterPopoverProps","filterVisible","filtersProp","filters","onFilter","onFilterVisibleChange","title","sortableAndFilterable","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","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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"}