From 0078a39617b9991c5224fdac02df1fcac97145fa Mon Sep 17 00:00:00 2001
From: daisy <904492381@qq.com>
Date: Thu, 6 Jun 2024 17:10:09 +0800
Subject: [PATCH] feat: column minWidth (#1125)
* feat: column minWidth
* chore: simplify code
---
README.md | 1 +
src/ColGroup.tsx | 19 ++++++++++++++++---
src/interface.ts | 7 ++++++-
tests/Colgroup.spec.jsx | 25 +++++++++++++++++++++++++
4 files changed, 48 insertions(+), 4 deletions(-)
diff --git a/README.md b/README.md
index ad889ead2..5adb71f89 100644
--- a/README.md
+++ b/README.md
@@ -129,6 +129,7 @@ React.render(
, mountNode);
| title | React Node | | title of this column |
| dataIndex | String | | display field of the data record |
| width | String \| Number | | width of the specific proportion calculation according to the width of the columns |
+| minWidth | Number | | the minimum width of the column, only worked when tableLayout is auto |
| fixed | String \| Boolean | | this column will be fixed when table scroll horizontally: true or 'left' or 'right' |
| align | String | | specify how cell content is aligned |
| ellipsis | Boolean | | specify whether cell content be ellipsized |
diff --git a/src/ColGroup.tsx b/src/ColGroup.tsx
index 656e33551..a20e58c28 100644
--- a/src/ColGroup.tsx
+++ b/src/ColGroup.tsx
@@ -1,6 +1,8 @@
import * as React from 'react';
import type { ColumnType } from './interface';
import { INTERNAL_COL_DEFINE } from './utils/legacyUtil';
+import { useContext } from '@rc-component/context';
+import TableContext from './context/TableContext';
export interface ColGroupProps {
colWidths: readonly (number | string)[];
@@ -9,6 +11,8 @@ export interface ColGroupProps {
}
function ColGroup({ colWidths, columns, columCount }: ColGroupProps) {
+ const { tableLayout } = useContext(TableContext, ['tableLayout']);
+
const cols: React.ReactElement[] = [];
const len = columCount || columns.length;
@@ -18,11 +22,20 @@ function ColGroup({ colWidths, columns, columCount }: ColGroupProps<
for (let i = len - 1; i >= 0; i -= 1) {
const width = colWidths[i];
const column = columns && columns[i];
- const additionalProps = column && column[INTERNAL_COL_DEFINE];
+ let additionalProps;
+ let minWidth: number;
+ if (column) {
+ additionalProps = column[INTERNAL_COL_DEFINE];
+
+ // fixed will cause layout problems
+ if (tableLayout === 'auto') {
+ minWidth = column.minWidth;
+ }
+ }
- if (width || additionalProps || mustInsert) {
+ if (width || minWidth || additionalProps || mustInsert) {
const { columnType, ...restAdditionalProps } = additionalProps || {};
- cols.unshift();
+ cols.unshift();
mustInsert = true;
}
}
diff --git a/src/interface.ts b/src/interface.ts
index 06213c043..051ac57ae 100644
--- a/src/interface.ts
+++ b/src/interface.ts
@@ -70,7 +70,11 @@ export type Direction = 'ltr' | 'rtl';
// SpecialString will be removed in antd@6
export type SpecialString = T | (string & {});
-export type DataIndex = DeepNamePath | SpecialString | number | (SpecialString | number)[];
+export type DataIndex =
+ | DeepNamePath
+ | SpecialString
+ | number
+ | (SpecialString | number)[];
export type CellEllipsisType = { showTitle?: boolean } | boolean;
@@ -109,6 +113,7 @@ export interface ColumnType extends ColumnSharedType {
shouldCellUpdate?: (record: RecordType, prevRecord: RecordType) => boolean;
rowSpan?: number;
width?: number | string;
+ minWidth?: number;
onCell?: GetComponentProps;
/** @deprecated Please use `onCell` instead */
onCellClick?: (record: RecordType, e: React.MouseEvent) => void;
diff --git a/tests/Colgroup.spec.jsx b/tests/Colgroup.spec.jsx
index e112721a6..802044da0 100644
--- a/tests/Colgroup.spec.jsx
+++ b/tests/Colgroup.spec.jsx
@@ -26,4 +26,29 @@ describe('Table.ColGroup', () => {
const wrapper = mount();
expect(String(wrapper.find('colgroup col').key())).toEqual('0');
});
+
+ it('minWidth should be worked', () => {
+ const columns = [
+ {
+ key: 0,
+ minWidth: 100,
+ },
+ ];
+
+ const wrapper = mount();
+ expect(wrapper.find('colgroup col').at(0).props().style.minWidth).toEqual(100);
+ });
+
+ it('should not have minWidth when tableLayout is fixed', () => {
+ const columns = [
+ {
+ key: 0,
+ width: 100,
+ minWidth: 100,
+ },
+ ];
+
+ const wrapper = mount();
+ expect(wrapper.find('colgroup col').at(0).props().style.minWidth).toBeFalsy();
+ });
});