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>

106 lines 22.5 kB
function _readOnlyError(r) { throw new TypeError('"' + r + '" is read-only'); } 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","createElement","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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","ignoreList":[]}