import { uuid } from '../_utils/utils'; import snippets from './snippets'; export default { snippets, componentName: 'Select', title: '选择器', category: '表单', group: '基础组件', props: [ { name: 'defaultValue', title: { label: '默认值', tip: 'defaultValue | 默认选中值' }, propType: { type: 'oneOfType', value: [ 'string', { type: 'arrayOf', value: 'string' }, 'number', { type: 'arrayOf', value: 'number' }, ], }, }, { name: 'value', title: { label: '当前值', tip: 'value | 当前值' }, propType: { type: 'oneOfType', value: [ 'string', { type: 'arrayOf', value: 'string' }, 'number', { type: 'arrayOf', value: 'number' }, ], }, }, { name: 'options', title: { label: '可选项', tip: 'options | 可选项' }, propType: { type: 'arrayOf', value: { type: 'shape', value: [ { name: 'label', propType: 'string', description: '选项名', defaultValue: '选项名', }, { name: 'value', propType: ['string', 'number'], description: '选项值', defaultValue: '选项值', }, { name: 'disabled', propType: 'bool', description: '是否禁用', defaultValue: false, }, ], }, }, setter: [ { componentName: 'ArraySetter', props: { itemSetter: { componentName: 'ObjectSetter', props: { config: { items: [ { name: 'label', title: '选项名', setter: ['StringSetter', 'VariableSetter'], isRequired: true, }, { name: 'value', title: '选项值', setter: ['StringSetter', 'NumberSetter', 'VariableSetter'], isRequired: true, }, { name: 'disabled', title: '是否禁用', setter: ['BoolSetter', 'VariableSetter'], }, ], }, }, initialValue: () => { return { label: '选项名', value: uuid(), disabled: false, }; }, }, }, }, 'FunctionSetter', ], }, { name: 'allowClear', title: { label: '支持清除', tip: 'allowClear | 是否允许清除' }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', }, { name: 'autoFocus', title: { label: '自动聚焦', tip: 'autoFocus | 默认获取焦点' }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', }, { name: 'defaultActiveFirstOption', title: { label: '高亮首个选项', tip: 'defaultActiveFirstOption | 是否默认高亮第一个选项' }, propType: 'bool', defaultValue: true, setter: 'BoolSetter', }, { name: 'disabled', title: { label: '是否禁用', tip: 'disabled | 是否为禁用状态' }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', }, { name: 'labelInValue', title: { label: '值包含label', tip: 'labelInValue | 把每个选项的 label 包装到 value 中', }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', }, { name: 'mode', title: { label: '多选/单选', tip: 'mode | 多选/单选' }, setter: { componentName: 'RadioGroupSetter', props: { options: [ { title: '单选', value: 'single', }, { title: '多选', value: 'multiple', }, { title: '任意内容', value: 'tags', }, ], }, }, propType: { type: 'oneOf', value: ['single', 'multiple', 'tags'] }, }, { name: 'maxCount', title: { label: '最大item数', tip: 'maxCount | 最多显示多少个item' }, condition(target) { return ['multiple', 'tags'].includes(target.getProps().getPropValue('mode')); }, propType: 'number', }, { name: 'maxTagTextLength', title: { label: 'tag文本长度', tip: 'maxTagTextLength | 最大显示的tag文本长度' }, condition(target) { return ['multiple', 'tags'].includes(target.getProps().getPropValue('mode')); }, propType: 'number', }, { name: 'notFoundContent', title: { label: '搜索为空提示文案', tip: 'notFoundContent | 搜索为空提示文案' }, propType: 'string', setter: 'StringSetter', }, { name: 'placeholder', title: { label: '选择框默认文字', tip: 'placeholder | 选择框默认文字' }, propType: 'string', setter: 'StringSetter', }, { name: 'showArrow', title: { label: '是否显示下拉箭头', tip: 'showArrow | 是否显示下拉小箭头' }, propType: 'bool', setter: 'BoolSetter', }, { name: 'showSearch', title: { label: '是否可搜索', tip: 'showSearch | 是否可搜索' }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', }, { name: 'size', title: { label: '尺寸', tip: 'size | 选择框大小' }, setter: { componentName: 'RadioGroupSetter', props: { options: [ { title: '大', value: 'large', }, { title: '中', value: 'middle', }, { title: '小', value: 'small', }, ], }, }, propType: { type: 'oneOf', value: ['large', 'middle', 'small'] }, defaultValue: 'middle', }, { name: 'loading', title: { label: '加载中', tip: 'loading | 加载中状态' }, propType: 'bool', defaultValue: false, setter: 'BoolSetter', }, { name: 'bordered', title: { label: '显示边框', tip: 'bordered | 是否有边框' }, propType: 'bool', defaultValue: true, setter: 'BoolSetter', }, { name: 'filterOption', title: { label: '筛选可选项', tip: 'filterOption | 是否根据输入进行筛选' }, propType: { type: 'oneOfType', value: ['bool', 'func'], }, defaultValue: true, }, { name: 'optionFilterProp', title: { label: '用于筛选的字段', tip: 'optionFilterProp | 用于过滤的字段' }, propType: { type: 'oneOf', value: ['value', 'label'], }, defaultValue: 'value', }, { name: 'tokenSeparators', title: { label: '自动分词的分隔符', tip: 'tokenSeparators | 自动分词的分隔符' }, propType: { type: 'arrayOf', value: 'string' }, }, { name: 'onBlur', title: { label: '失去焦点时回调', tip: 'onBlur | 失去焦点时回调' }, propType: 'func', }, { name: 'onChange', title: { label: '选中回调函数', tip: 'onChange | 选中 option,或 input 的 value 变化时,调用此函数', }, propType: 'func', }, { name: 'onDeselect', title: { label: '取消选中时回调', tip: 'onDeselect | 取消选中时调用,参数为选中项的 value (或 key) 值,仅在 multiple 或 tags 模式下生效', }, propType: 'func', }, { name: 'onFocus', title: { label: '获得焦点时回调', tip: 'onFocus | 获得焦点时回调' }, propType: 'func', }, { name: 'onInputKeyDown', title: { label: '按键按下时回调', tip: 'onInputKeyDown | 按键按下时回调' }, propType: 'func', }, { name: 'onMouseEnter', title: { label: '鼠标移入时回调', tip: 'onMouseEnter | 鼠标移入时回调' }, propType: 'func', }, { name: 'onMouseLeave', title: { label: '鼠标移出时回调', tip: 'onMouseLeave | 鼠标移出时回调' }, propType: 'func', }, { name: 'onPopupScroll', title: { label: '下拉列表滚动时的回调', tip: 'onPopupScroll | 下拉列表滚动时的回调' }, propType: 'func', }, { name: 'onSearch', title: { label: '文本框值变化时回调', tip: 'onSearch | 文本框值变化时回调' }, propType: 'func', }, { name: 'onSelect', title: { label: '被选中时回调', tip: 'onSelect | 被选中时调用,参数为选中项的 value (或 key) 值', }, propType: 'func', }, { name: 'onDropdownVisibleChange', title: { label: '展开下拉菜单的回调', tip: 'onDropdownVisibleChange | 展开下拉菜单的回调' }, propType: 'func', }, ], configure: { supports: { style: true, events: [ { name: 'onBlur', description: '失去焦点时回调', template: "\tonBlur(${extParams}){\n\t\t// 失去焦点时回调\n\t\tconsole.log('onBlur');\n\t}\n", }, { name: 'onChange', description: '选中 option 或 input 的 value 变化时调用此函数', template: "\tonChange(value,option,${extParams}){\n\t\t// 选中 option,或 input 的 value 变化时,调用此函数\n\t\tconsole.log('onChange',value,option);\n\t}\n", }, { name: 'onClear', description: '清除内容时回调', template: "\tonClear(${extParams}){\n\t\t// 清除内容时回调\n\t\tconsole.log('onClear');\n\t}\n", }, { name: 'onDeselect', description: '取消选中时调用', template: "\tonDeselect(value,${extParams}){\n\t\t// 取消选中时调用\n\t\tconsole.log('onDeselect',value);\n\t}\n", }, { name: 'onFocus', description: '获得焦点时回调', template: "\tonFocus(${extParams}){\n\t\t// 获得焦点时回调\n\t\tconsole.log('onFocus');\n\t}\n", }, { name: 'onInputKeyDown', description: '按键按下时回调', template: "\tonInputKeyDown(${extParams}){\n\t\t// 按键按下时回调\n\t\tconsole.log('onInputKeyDown');\n\t}\n", }, { name: 'onMouseEnter', description: '鼠标移入时回调', template: "\tonMouseEnter(${extParams}){\n\t\t// 鼠标移入时回调\n\t\tconsole.log('onMouseEnter');\n\t}\n", }, { name: 'onMouseLeave', description: '鼠标移出时回调', template: "\tonMouseLeave(${extParams}){\n\t\t// 鼠标移出时回调\n\t\tconsole.log('onMouseLeave');\n\t}\n", }, { name: 'onPopupScroll', description: '下拉列表滚动时的回调', template: "\tonPopupScroll(${extParams}){\n\t\t// 下拉列表滚动时的回调\n\t\tconsole.log('onPopupScroll');\n\t}\n", }, { name: 'onSearch', description: '文本框值变化时回调', template: "\tonSearch(value,${extParams}){\n\t\t// 文本框值变化时回调\n\t\tconsole.log('onSearch',value);\n\t}\n", }, { name: 'onSelect', description: '被选中时调用', template: "\tonSelect(value,option,${extParams}){\n\t\t// 被选中时调用\n\t\tconsole.log('onSelect',value,option);\n\t}\n", }, { name: 'onDropdownVisibleChange', description: '展开下拉菜单的回调', template: "\tonDropdownVisibleChange(open,${extParams}){\n\t\t// 展开下拉菜单的回调\n\t\tconsole.log('onDropdownVisibleChange',open);\n\t}\n", }, ], }, }, };