mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
feat(Cascader): add show-header prop (#10202)
This commit is contained in:
parent
f50c462978
commit
d1465c2a11
@ -33,6 +33,7 @@ const cascaderProps = {
|
|||||||
closeable: truthProp,
|
closeable: truthProp,
|
||||||
swipeable: truthProp,
|
swipeable: truthProp,
|
||||||
closeIcon: makeStringProp('cross'),
|
closeIcon: makeStringProp('cross'),
|
||||||
|
showHeader: truthProp,
|
||||||
modelValue: numericProp,
|
modelValue: numericProp,
|
||||||
fieldNames: Object as PropType<CascaderFieldNames>,
|
fieldNames: Object as PropType<CascaderFieldNames>,
|
||||||
placeholder: String,
|
placeholder: String,
|
||||||
@ -185,20 +186,21 @@ export default defineComponent({
|
|||||||
const onClickTab = ({ name, title }: TabsClickTabEventParams) =>
|
const onClickTab = ({ name, title }: TabsClickTabEventParams) =>
|
||||||
emit('click-tab', name, title);
|
emit('click-tab', name, title);
|
||||||
|
|
||||||
const renderHeader = () => (
|
const renderHeader = () =>
|
||||||
<div class={bem('header')}>
|
props.showHeader ? (
|
||||||
<h2 class={bem('title')}>
|
<div class={bem('header')}>
|
||||||
{slots.title ? slots.title() : props.title}
|
<h2 class={bem('title')}>
|
||||||
</h2>
|
{slots.title ? slots.title() : props.title}
|
||||||
{props.closeable ? (
|
</h2>
|
||||||
<Icon
|
{props.closeable ? (
|
||||||
name={props.closeIcon}
|
<Icon
|
||||||
class={[bem('close-icon'), HAPTICS_FEEDBACK]}
|
name={props.closeIcon}
|
||||||
onClick={onClose}
|
class={[bem('close-icon'), HAPTICS_FEEDBACK]}
|
||||||
/>
|
onClick={onClose}
|
||||||
) : null}
|
/>
|
||||||
</div>
|
) : null}
|
||||||
);
|
</div>
|
||||||
|
) : null;
|
||||||
|
|
||||||
const renderOption = (
|
const renderOption = (
|
||||||
option: CascaderOption,
|
option: CascaderOption,
|
||||||
|
@ -253,6 +253,7 @@ export default {
|
|||||||
| active-color | Active color | _string_ | `#ee0a24` |
|
| active-color | Active color | _string_ | `#ee0a24` |
|
||||||
| swipeable `v3.0.11` | Whether to enable gestures to slide left and right | _boolean_ | `false` |
|
| swipeable `v3.0.11` | Whether to enable gestures to slide left and right | _boolean_ | `false` |
|
||||||
| closeable | Whether to show close icon | _boolean_ | `true` |
|
| closeable | Whether to show close icon | _boolean_ | `true` |
|
||||||
|
| show-header `v3.4.2` | Whether to show header | _boolean_ | `true` |
|
||||||
| close-icon `v3.0.10` | Close icon name | _string_ | `cross` |
|
| close-icon `v3.0.10` | Close icon name | _string_ | `cross` |
|
||||||
| field-names `v3.0.4` | Custom the fields of options | _object_ | `{ text: 'text', value: 'value', children: 'children' }` |
|
| field-names `v3.0.4` | Custom the fields of options | _object_ | `{ text: 'text', value: 'value', children: 'children' }` |
|
||||||
|
|
||||||
|
@ -263,6 +263,7 @@ export default {
|
|||||||
| active-color | 选中状态的高亮颜色 | _string_ | `#ee0a24` |
|
| active-color | 选中状态的高亮颜色 | _string_ | `#ee0a24` |
|
||||||
| swipeable `v3.0.11` | 是否开启手势左右滑动切换 | _boolean_ | `false` |
|
| swipeable `v3.0.11` | 是否开启手势左右滑动切换 | _boolean_ | `false` |
|
||||||
| closeable | 是否显示关闭图标 | _boolean_ | `true` |
|
| closeable | 是否显示关闭图标 | _boolean_ | `true` |
|
||||||
|
| show-header `v3.4.2` | 是否展示标题栏 | _boolean_ | `true` |
|
||||||
| close-icon `v3.0.10` | 关闭图标名称或图片链接,等同于 Icon 组件的 [name 属性](#/zh-CN/icon#props) | _string_ | `cross` |
|
| close-icon `v3.0.10` | 关闭图标名称或图片链接,等同于 Icon 组件的 [name 属性](#/zh-CN/icon#props) | _string_ | `cross` |
|
||||||
| field-names `v3.0.4` | 自定义 `options` 结构中的字段 | _object_ | `{ text: 'text', value: 'value', children: 'children' }` |
|
| field-names `v3.0.4` | 自定义 `options` 结构中的字段 | _object_ | `{ text: 'text', value: 'value', children: 'children' }` |
|
||||||
|
|
||||||
|
@ -261,3 +261,15 @@ test('should render options-top、options-bottom slots correctly', async () => {
|
|||||||
|
|
||||||
expect(wrapper.find('.van-tab__panel').html()).toMatchSnapshot();
|
expect(wrapper.find('.van-tab__panel').html()).toMatchSnapshot();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('should not render header when show-header prop is false', async () => {
|
||||||
|
const wrapper = mount(Cascader, {
|
||||||
|
props: {
|
||||||
|
options,
|
||||||
|
showHeader: false,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
const header = wrapper.find('.van-cascader__header');
|
||||||
|
expect(header.exists()).toBeFalsy();
|
||||||
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user