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>

115 lines (105 loc) 22.6 kB
import * as React from "react"; import PropTypes from "prop-types"; import omit from "../_util/omit"; function Column(props) { var restProps = omit(props, ["align", "children", "dataIndex", "filterMultiple", "filterSearchable", "filterSearchCaseSensitive", "filterSearchPlaceholder", "filterSearchFunc", "filterPopoverProps", "filteredValue", "filters", "fixed", "getHeadCellClassName", "getHeadCellStyle", "getCellClassName", "getCellProps", "getCellStyle", "grow", "onFilter", "onFilterVisibleChange", "onSort", "popover", "render", "resizable", "sortOrder", "title", "verticalAlign", "width"]); return React.createElement("div", restProps); } Column.propTypes = { align: PropTypes.oneOf([null, "left", "center", "right"]), dataIndex: PropTypes.string, filterMultiple: PropTypes.bool, filterSearchable: PropTypes.bool, filterSearchCaseSensitive: PropTypes.bool, filterSearchPlaceholder: PropTypes.string, filterSearchFunc: PropTypes.func, filterPopoverProps: PropTypes.object, filteredValue: PropTypes.array, filterVisible: PropTypes.bool, filters: PropTypes.array, fixed: PropTypes.oneOf([null, false, true, "left", "right"]), getHeadCellClassName: PropTypes.func, getHeadCellStyle: PropTypes.func, getCellClassName: PropTypes.func, getCellProps: PropTypes.func, getCellStyle: PropTypes.func, grow: PropTypes.bool, onFilter: function onFilter(props) { var onFilter = props.onFilter, onSort = props.onSort; if (onFilter) { if (typeof onFilter !== "function") { return new Error("Invalid prop `onFilter` supplied to `Column`, expected `function`"); } if (!!onFilter && !!onSort) { return new Error("Column: 筛选和排序功能不能同时使用"); } } return null; }, onFilterVisibleChange: PropTypes.func, onSort: function onSort(props) { var onFilter = props.onFilter, onSort = props.onSort; if (onSort) { if (typeof onSort !== "function") { return new Error("Invalid prop `onSort` supplied to `Column`, expected `function`"); } if (!!onFilter && !!onSort) { return new Error("Column: 筛选和排序功能不能同时使用"); } } return null; }, popover: PropTypes.node, render: PropTypes.func, resizable: PropTypes.bool, sortOrder: PropTypes.oneOf([null, "", "asc", "desc"]), title: PropTypes.node.isRequired, verticalAlign: PropTypes.oneOf([null, "top", "center", "bottom"]), width: function width(props) { var fixed = props.fixed, width = props.width; if (width) { if (typeof width !== "string" && typeof width !== "number") { return new Error("Invalid `width` supplied to `Column`, expected `string`|`number`."); } } else if (fixed) { return new Error("Column: fixed 列必须传入 width prop."); } return null; } }; Column.defaultProps = { align: null, dataIndex: null, filterMultiple: false, filterSearchable: false, filterSearchCaseSensitive: false, filterSearchPlaceholder: "在筛选项中搜索", filterSearchFunc: undefined, filterPopoverProps: {}, filteredValue: null, filterVisible: null, filters: null, fixed: null, getHeadCellClassName: function getHeadCellClassName() { return ""; }, getHeadCellStyle: function getHeadCellStyle() {}, getCellClassName: undefined, getCellProps: undefined, getCellStyle: undefined, grow: undefined, onFilter: null, onFilterVisibleChange: function onFilterVisibleChange() {}, onSort: null, popover: null, render: null, resizable: null, sortOrder: null, verticalAlign: null, width: null }; export default Column; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropTypes","omit","Column","props","restProps","propTypes","align","oneOf","dataIndex","string","filterMultiple","bool","filterSearchable","filterSearchCaseSensitive","filterSearchPlaceholder","filterSearchFunc","func","filterPopoverProps","object","filteredValue","array","filterVisible","filters","fixed","getHeadCellClassName","getHeadCellStyle","getCellClassName","getCellProps","getCellStyle","grow","onFilter","onSort","Error","onFilterVisibleChange","popover","node","render","resizable","sortOrder","title","isRequired","verticalAlign","width","defaultProps","undefined"],"sources":["../../components/table/Column.tsx"],"sourcesContent":["import * as React from \"react\"\nimport PropTypes from \"prop-types\"\nimport omit from \"../_util/omit\"\nimport { IPopoverProps } from \"../popover\"\n\ninterface IBaseObject {\n  [key: string]: any\n}\n\nexport interface IColumnProps<T extends IBaseObject = IBaseObject> {\n  /**\n   * 水平靠齐方向\n   */\n  align?: null | \"left\" | \"center\" | \"right\"\n  /**\n   * 子节点\n   */\n  children?: React.ReactNode[]\n  /**\n   * 索引\n   */\n  dataIndex: string\n  /**\n   * 筛选是否支持多选\n   */\n  filterMultiple?: boolean\n  /**\n   * 筛选是否支持搜索\n   */\n  filterSearchable?: boolean\n  /**\n   * 筛选搜索开启大小写敏感搜索，默认为 false\n   */\n  filterSearchCaseSensitive?: boolean\n  /**\n   * 筛选搜索 placeholder\n   */\n  filterSearchPlaceholder?: string\n  /**\n   * 筛选搜索的自定义 function\n   */\n  filterSearchFunc?: (\n    input: string,\n    item: { text: string; value: string | number }\n  ) => boolean\n  /**\n   * 筛选 Popover props，会将此对象透传给 <Popover />\n   */\n  filterPopoverProps?: IPopoverProps\n  /**\n   * 可以从外部传入筛选的值，null, [], 都会识别为未筛选状态\n   */\n  filteredValue?: Array<React.ReactText> | null\n  /**\n   * 从外部控制 filter Popover 的显示\n   */\n  filterVisible?: boolean | null\n  /**\n   * 筛选项，格式：[{ text: \"朋友圈广告\", value: '2' }]\n   */\n  filters?: Array<{ text: string; value: React.ReactText }> | null\n  /**\n   * 固定设置\n   */\n  fixed?: true | false | \"left\" | \"right\"\n  /**\n   * 设置该列 TH 的类名\n   */\n  getHeadCellClassName?: () => string\n  /**\n   * 设置该列 TH 上的 style\n   */\n  getHeadCellStyle?: () => React.CSSProperties | void\n  /**\n   * 设置该列每个单元格的类名：(row, rowIndex) => (string)\n   */\n  getCellClassName?: (row: T, rowIndex: number) => string\n  /**\n   * 设置该列每个单元格上的由组件规定的 prop，\n   * 如 rowSpan colSpan，(row, rowIndex) => ({})\n   */\n  getCellProps?: (row: T, rowIndex: number) => IBaseObject | void\n  /**\n   * 设置该列每个单元格上的 style，(row, rowIndex) => ({})\n   */\n  getCellStyle?: (row: T, rowIndex: number) => React.CSSProperties | void\n  /**\n   * adui@2.15.0 是否在整体宽度有剩余的情况下填充\n   */\n  grow?: boolean\n  /**\n   * 筛选时的 handler，筛选和排序功能不能同时使用\n   */\n  onFilter?: ((value: Array<React.ReactText>) => void) | null\n  /**\n   * 筛选 popup visible 变化时的 handler，参数 (bool, col)\n   */\n  onFilterVisibleChange?: ((visible: boolean) => {}) | null\n  /**\n   * 排序时的 handler，筛选和排序功能不能同时使用\n   */\n  onSort?: ((order: \"asc\" | \"desc\" | \"\") => void) | null\n  /**\n   * 在列头上增加 popover。这样的需求越来越常规，样式上内置到 Table 内做规范，作为 prop 是有必要的。\n   */\n  popover?: React.ReactNode\n  /**\n   * 如果有 render，则 render (row, col, rowIndex, colIndex)，否则取 dataIndex。\n   */\n  render?: (\n    row: T,\n    col: IBaseObject,\n    rowIndex: number,\n    colIndex: number\n  ) => React.ReactNode\n  /**\n   * 是否允许调整宽度，默认 true\n   */\n  resizable?: boolean\n  /**\n   * 可以从外部控制排序方式\n   */\n  sortOrder?: null | \"\" | \"asc\" | \"desc\"\n  /**\n   * 列头显示的内容\n   */\n  title: React.ReactNode\n  /**\n   * 垂直靠齐方向\n   */\n  verticalAlign?: \"top\" | \"center\" | \"bottom\"\n  /**\n   * 列的固定宽度\n   */\n  width?: React.ReactText\n}\n\n/**\n * Column.js 的作用仅是约束 PropTypes。\n * 每一列的 props 在 ColumnManager.js 中得到处理。\n */\nfunction Column<T extends IBaseObject = IBaseObject>(props: IColumnProps<T>) {\n  const restProps = omit(props, [\n    \"align\",\n    \"children\",\n    \"dataIndex\",\n    \"filterMultiple\",\n    \"filterSearchable\",\n    \"filterSearchCaseSensitive\",\n    \"filterSearchPlaceholder\",\n    \"filterSearchFunc\",\n    \"filterPopoverProps\",\n    \"filteredValue\",\n    \"filters\",\n    \"fixed\",\n    \"getHeadCellClassName\",\n    \"getHeadCellStyle\",\n    \"getCellClassName\",\n    \"getCellProps\",\n    \"getCellStyle\",\n    \"grow\",\n    \"onFilter\",\n    \"onFilterVisibleChange\",\n    \"onSort\",\n    \"popover\",\n    \"render\",\n    \"resizable\",\n    \"sortOrder\",\n    \"title\",\n    \"verticalAlign\",\n    \"width\",\n  ])\n  return <div {...restProps} />\n}\n\nColumn.propTypes = {\n  /**\n   * 水平靠齐方向\n   */\n  align: PropTypes.oneOf([null, \"left\", \"center\", \"right\"]),\n  /**\n   * 索引\n   */\n  dataIndex: PropTypes.string,\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   * 从外部控制 filter Popover 的显示\n   */\n  filterVisible: PropTypes.bool,\n  /**\n   * 筛选项，格式：[{ text: \"朋友圈广告\", value: '2' }]\n   */\n  filters: PropTypes.array,\n  /**\n   * 固定设置\n   */\n  fixed: PropTypes.oneOf([null, false, true, \"left\", \"right\"]),\n  /**\n   * 设置该列 TH 的类名：() => (string)\n   */\n  getHeadCellClassName: PropTypes.func,\n  /**\n   * 设置该列 TH 上的 style，() => ({})\n   */\n  getHeadCellStyle: PropTypes.func,\n  /**\n   * 设置该列每个单元格的类名：(row, rowIndex) => (string)\n   */\n  getCellClassName: PropTypes.func,\n  /**\n   * 设置该列每个单元格上的由组件规定的 prop，\n   * 如 rowSpan colSpan，(row, rowIndex) => ({})\n   */\n  getCellProps: PropTypes.func,\n  /**\n   * 设置该列每个单元格上的 style，(row, rowIndex) => ({})\n   */\n  getCellStyle: PropTypes.func,\n  /**\n   * adui@2.15.0 是否在整体宽度有剩余的情况下填充\n   */\n  grow: PropTypes.bool,\n  /**\n   * 筛选时的 handler，筛选和排序功能不能同时使用\n   */\n  onFilter: (props: IColumnProps) => {\n    const { onFilter, onSort } = props\n    if (onFilter) {\n      if (typeof onFilter !== \"function\") {\n        return new Error(\n          \"Invalid prop `onFilter` supplied to `Column`, expected `function`\"\n        )\n      }\n      if (!!onFilter && !!onSort) {\n        return new Error(\"Column: 筛选和排序功能不能同时使用\")\n      }\n    }\n    return null\n  },\n  /**\n   * 筛选 popup visible 变化时的 handler，参数 (bool, col)\n   */\n  onFilterVisibleChange: PropTypes.func,\n  /**\n   * 排序时的 handler，筛选和排序功能不能同时使用\n   */\n  onSort: (props: IColumnProps) => {\n    const { onFilter, onSort } = props\n    if (onSort) {\n      if (typeof onSort !== \"function\") {\n        return new Error(\n          \"Invalid prop `onSort` supplied to `Column`, expected `function`\"\n        )\n      }\n      if (!!onFilter && !!onSort) {\n        return new Error(\"Column: 筛选和排序功能不能同时使用\")\n      }\n    }\n    return null\n  },\n  /**\n   * 在列头上增加 popover。这样的需求越来越常规，样式上内置到 Table 内做规范，作为 prop 是有必要的。\n   */\n  popover: PropTypes.node,\n  /**\n   * 如果有 render，则 render (row, col, rowIndex, colIndex)，否则取 dataIndex。\n   */\n  render: PropTypes.func,\n  /**\n   * 是否允许调整宽度，默认 true\n   */\n  resizable: PropTypes.bool,\n  /**\n   * 可以从外部控制排序方式\n   */\n  sortOrder: PropTypes.oneOf([null, \"\", \"asc\", \"desc\"]),\n  /**\n   * 列头显示的内容\n   */\n  title: PropTypes.node.isRequired,\n  /**\n   * 垂直靠齐方向\n   */\n  verticalAlign: PropTypes.oneOf([null, \"top\", \"center\", \"bottom\"]),\n  /**\n   * 列的固定宽度\n   */\n  width: (props: IColumnProps) => {\n    /**\n     * 1. width 目前只支持 {50}，\"50px\"，\"50%\" 三种格式，请不要使用其他单位；\n     * 2. 固定列必须设置宽度，Table 做这样的约束，是为了避免太多的计算成本。\n     */\n    const { fixed, width } = props\n    if (width) {\n      if (typeof width !== \"string\" && typeof width !== \"number\") {\n        return new Error(\n          \"Invalid `width` supplied to `Column`, expected `string`|`number`.\"\n        )\n      }\n    } else if (fixed) {\n      return new Error(\"Column: fixed 列必须传入 width prop.\")\n    }\n    return null\n  },\n}\n\nColumn.defaultProps = {\n  align: null,\n  dataIndex: null,\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  fixed: null,\n  getHeadCellClassName: () => \"\",\n  getHeadCellStyle: () => {},\n  getCellClassName: undefined,\n  getCellProps: undefined,\n  getCellStyle: undefined,\n  grow: undefined,\n  onFilter: null,\n  onFilterVisibleChange: () => {},\n  onSort: null,\n  popover: null,\n  render: null,\n  resizable: null,\n  sortOrder: null,\n  verticalAlign: null,\n  width: null,\n}\n\nexport default Column\n"],"mappings":"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"}