coze-studio/frontend/packages/arch/bot-utils/__tests__/responsive-table-column.tes...

67 lines
2.4 KiB
TypeScript

/*
* Copyright 2025 coze-dev Authors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/*
表格单元格宽度适配
当 width 小于 WidthThresholds.Small 时应该返回 ColumnSize.Default。
当 width 大于等于 WidthThresholds.Small 但小于 WidthThresholds.Medium 时应该返回 ColumnSize.Small。
当 width 大于等于 WidthThresholds.Medium 但小于 WidthThresholds.Large 时应该返回 ColumnSize.Medium。
当 width 大于等于 WidthThresholds.Large 时应该返回 ColumnSize.Large。
当 minWidth 为 'auto' 时应该返回 'auto'。
当 minWidth 是一个指定数字时,应该返回 minWidth 和 columnWidth 中较大的一个。*/
import { describe, it, expect } from 'vitest';
import {
responsiveTableColumn,
ColumnSize,
WidthThresholds,
} from '../src/responsive-table-column';
describe('responsiveTableColumn', () => {
it('returns auto for minWidth auto', () => {
expect(responsiveTableColumn(1000, 'auto')).toBe('auto');
});
it('returns minWidth when minWidth is a number and greater than columnWidth', () => {
expect(responsiveTableColumn(1000, 80)).toBe(80);
});
it('returns ColumnSize.Small for width less than WidthThresholds.Small', () => {
expect(responsiveTableColumn(WidthThresholds.Small - 1, 50)).toBe(
ColumnSize.Default,
);
});
it('returns ColumnSize.Medium for width between WidthThresholds.Small and WidthThresholds.Medium', () => {
expect(responsiveTableColumn(WidthThresholds.Medium - 1, 50)).toBe(
ColumnSize.Small,
);
});
it('returns ColumnSize.Large for width between WidthThresholds.Medium and WidthThresholds.Large', () => {
expect(responsiveTableColumn(WidthThresholds.Large - 1, 50)).toBe(
ColumnSize.Medium,
);
});
it('returns ColumnSize.Large for width greater than or equal to WidthThresholds.Large', () => {
expect(responsiveTableColumn(WidthThresholds.Large, 50)).toBe(
ColumnSize.Large,
);
});
});