import { uuid } from '../_utils/utils'; import snippets from './snippets'; export default { snippets, componentName: 'Tabs', title: '标签页', category: '数据展示', group: '基础组件', props: [ { name: 'items', title: '标签项', setter: { componentName: 'ArraySetter', props: { itemSetter: { componentName: 'ObjectSetter', props: { config: { items: [ { name: 'key', title: 'key', setter: 'StringSetter', initialValue: (val) => val || uuid(), supportVariable: true, }, { name: 'label', title: '标题', setter: 'StringSetter', initialValue: '标签项', supportVariable: true, }, // { // name: 'closeable', // title: '是否可删除', // condition(target) { // return target.getProps().getPropValue('type') === 'editable-card'; // }, // setter: 'BoolSetter', // initialValue: true, // }, { name: 'disabled', title: '禁用', setter: 'BoolSetter', initialValue: false, supportVariable: true, }, { name: 'forceRender', title: '隐藏时保留', propType: 'bool', setter: 'BoolSetter', initialValue: false, supportVariable: true, }, { name: 'children', title: '内容', setter: { componentName: 'SlotSetter', initialValue: { type: 'JSSlot', value: [], }, }, }, ], }, }, initialValue: () => { return { key: uuid(), label: '标签项', disabled: false, forceRender: false, children: { type: 'JSSlot', value: [], }, }; }, }, }, }, }, { name: 'animated', title: { label: '切换动画', tip: 'animated | 是否使用动画切换Tabs', }, propType: 'bool', setter: 'BoolSetter', supportVariable: true, }, { name: 'defaultActiveKey', title: { label: '初始选中', tip: 'defaultActiveKey | 初始化选中面板的key,如果没有设置activeKey', }, propType: 'string', setter: 'StringSetter', supportVariable: true, }, { name: 'hideAdd', title: { label: '隐藏加号', tip: 'hideAdd | 是否隐藏加号图标,在`type="editable-card"`时有效', }, condition(target) { return target.getProps().getPropValue('type') === 'editable-card'; }, propType: 'bool', setter: 'BoolSetter', defaultValue: false, supportVariable: true, }, { name: 'size', title: { label: '尺寸', tip: 'size | 大小,提供 `large` `default` 和 `small` 三种大小', }, propType: { type: 'oneOf', value: ['large', 'default', 'small'], }, defaultValue: 'default', }, { name: 'centered', title: { label: '标签居中', tip: 'centered | 标签居中展示' }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', supportVariable: true, }, { name: 'tabBarExtraContent', title: { label: '额外元素', tip: 'tabBarExtraContent | tab bar上额外的元素' }, propType: 'node', }, { name: 'tabBarGutter', title: { label: '标签间隙', tip: 'tabBarGutter | tabs之间的间隙' }, propType: 'number', setter: 'NumberSetter', supportVariable: true, }, { name: 'tabPosition', title: { label: '页签位置', tip: 'tabPosition | 页签位置', }, propType: { type: 'oneOf', value: ['top', 'right', 'bottom', 'left'], }, defaultValue: 'top', }, { name: 'type', title: { label: '页签样式', tip: 'type | 页签的基本样式,可选`line`、`card`、`editable-card`类型', }, propType: { type: 'oneOf', value: ['line', 'card', 'editable-card'], }, defaultValue: 'line', }, { name: 'onChange', title: { label: '切换面板的回调', tip: 'onChange | 切换面板的回调' }, propType: 'func', }, { name: 'onEdit', title: { label: '新增删除回调', tip: 'onEdit | 新增和删除页签的回调,在`type="editable-card"`时有效', }, condition(target) { return target.getProps().getPropValue('type') === 'editable-card'; }, propType: 'func', }, { name: 'onTabClick', title: { label: 'tab点击回调', tip: 'onTabClick | tab被点击的回调' }, propType: 'func', }, { name: 'onTabScroll', title: { label: 'tab滚动触发', tip: 'onTabScroll | tab滚动时触发' }, propType: 'func', }, { name: 'keyboard', title: { label: '键盘切换', tip: 'keyboard | 开启键盘切换功能' }, propType: 'bool', defaultValue: true, }, ], configure: { component: { isContainer: true, }, supports: { style: true, events: [ { name: 'onChange', description: '切换面板的回调', template: "\tonChange(activeKey,${extParams}){\n\t\t// 切换面板的回调\n\t\tconsole.log('onChange',activeKey);\n\t}\n", }, { name: 'onEdit', description: '新增和删除页签的回调,在 type="editable-card"时有效', template: "\tonEdit(targetKey,action,${extParams}){\n\t\t// 新增和删除页签的回调\n\t\tconsole.log('onEdit',targetKey,action);\n\t}\n", }, { name: 'onTabClick', description: 'tab 被点击的回调', template: "\tonTabClick(key,event,${extParams}){\n\t\t// tab 被点击的回调\n\t\tconsole.log('onTabClick',key,event);\n\t}\n", }, { name: 'onTabScroll', description: 'tab滚动时触发', template: "\tonTabScroll({direction},${extParams}){\n\t\t// tab 滚动时触\n\t\tconsole.log('onTabScroll',direction);\n\t}\n", }, ], }, advanced: {}, }, };