forked from opentiny/tiny-vue
641 lines
21 KiB
JavaScript
641 lines
21 KiB
JavaScript
export default {
|
||
mode: ['pc'],
|
||
apis: [
|
||
{
|
||
name: 'tree-menu',
|
||
type: 'component',
|
||
props: [
|
||
{
|
||
name: 'accordion',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否设置为手风琴效果(只能展开一个同级别的节点)',
|
||
'en-US': 'Set to accordion effect (can only expand one node at the same level)'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'accordion'
|
||
},
|
||
{
|
||
name: 'allow-drag',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(vm:ITreeNodeVm) => boolean',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '拖拽开始前的回调事件,定义节点是否允许拖拽的规则,返回 true 则允许拖拽,配合 draggable 属性使用',
|
||
'en-US':
|
||
'The callback event before the start of dragging, defining the rules for whether nodes are allowed to drag, and returning true to allow dragging, used in conjunction with the draggable attribute'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'event-allow-draggable'
|
||
},
|
||
{
|
||
name: 'allow-drop',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(draggingNode: ITreeNodeVm, targetNode: ITreeNodeVm,type: "prev"|"next"|"inner") => boolean',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN':
|
||
'拖拽结束前的回调事件,定义节点是否允许放置到模板节点的规则,返回 true 则允许放置,配合 draggable 属性使用',
|
||
'en-US':
|
||
'Callback event before the end of drag and drop, defining rules for whether nodes are allowed to be placed on template nodes. If true is returned, placement is allowed, and the draggable attribute needs to be configured for use'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'event-allow-draggable'
|
||
},
|
||
{
|
||
name: 'check-strictly',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否遵循父级和子级严格不相关联的做法,配合 show-checkbox 属性使用',
|
||
'en-US':
|
||
'Do you follow the practice of strictly unrelated parents and children, and use it in conjunction with the show checkbox attribute'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-checkbox'
|
||
},
|
||
{
|
||
name: 'collapsible',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否允许展开后的菜单收起,未和 show-number 配套使用时,仍可以点击图标收起',
|
||
'en-US':
|
||
'Set whether to allow expanded menus to be collapsed. When not used in conjunction with show number, the icon can still be clicked to collapse'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-number'
|
||
},
|
||
{
|
||
name: 'customIcon',
|
||
type: 'VueComponent',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '设置带图标树形菜单',
|
||
'en-US': 'Set the Tree Menu with Icons'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-expand'
|
||
},
|
||
{
|
||
name: 'data',
|
||
typeAnchorName: 'ITreeNodeData',
|
||
type: 'ITreeNodeData[]',
|
||
defaultValue: '[]',
|
||
desc: {
|
||
'zh-CN': '静态数据源',
|
||
'en-US': 'Static Data Source'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'data-resource'
|
||
},
|
||
{
|
||
name: 'default-checked-keys',
|
||
type: 'Array<number|string>',
|
||
defaultValue: '[]',
|
||
desc: {
|
||
'zh-CN': '默认勾选节点的 key 的数组',
|
||
'en-US': 'Array of keys for default selected nodes'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'default-expand-all'
|
||
},
|
||
{
|
||
name: 'default-expand-all',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否默认展开所有子节点',
|
||
'en-US': 'Expand all child nodes by default'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'default-expand-all'
|
||
},
|
||
{
|
||
name: 'default-expanded-keys',
|
||
type: 'Array<number|string>',
|
||
defaultValue: '[]',
|
||
desc: {
|
||
'zh-CN': '默认展开节点的 key 的数组',
|
||
'en-US': 'Array of keys for default expanded nodes'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'default-expanded-keys'
|
||
},
|
||
{
|
||
name: 'default-expanded-keys-highlight',
|
||
type: 'number|string',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '设置默认展开节点中的某个节点高亮,配合 default-expanded-keys 属性使用',
|
||
'en-US':
|
||
'Set a node highlight in the default expanded node to be used in conjunction with the default expanded keys attribute'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'default-expanded-keys-highlight'
|
||
},
|
||
{
|
||
name: 'draggable',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否可拖动菜单节点',
|
||
'en-US': 'Can menu nodes be dragged'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'draggable'
|
||
},
|
||
{
|
||
name: 'ellipsis',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否文字超长省略显示。优先级高于 wrap',
|
||
'en-US': 'Whether the text is too long and omitted for display. Priority higher than wrap'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'text-ellipsis'
|
||
},
|
||
{
|
||
name: 'empty-text',
|
||
type: 'string',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '内容为空时展示的文本',
|
||
'en-US': 'Text displayed when the content is empty'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'empty-text'
|
||
},
|
||
{
|
||
name: 'expand-on-click-node',
|
||
type: 'boolean',
|
||
defaultValue: 'true',
|
||
desc: {
|
||
'zh-CN': '是否能点击节点即展开/收起。配置为 fasle 则只能点击下拉图标展开/收起',
|
||
'en-US':
|
||
'Whether to click on the node to expand/collapse. If configured as fasle, you can only click on the dropdown icon to expand/collapse'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'expand-on-click-node'
|
||
},
|
||
{
|
||
name: 'filter-node-method',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(query:string, data:ITreeNodeData, node:ITreeNodeVm) => boolean',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '自定义树节点过滤的方法,返回 true 表示这个节点可以显示,返回 false 则表示这个节点会被隐藏',
|
||
'en-US':
|
||
'Custom tree node filtering method, returning true indicates that this node can be displayed, while returning false indicates that this node will be hidden'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'filter-node-method'
|
||
},
|
||
{
|
||
name: 'get-menu-data-sync',
|
||
typeAnchorName: 'ITreeNodeData',
|
||
type: '() => ITreeNodeData[]',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '自定义获取服务端数据源的方法,返回一个 Promise 对象',
|
||
'en-US': 'Customize the method for obtaining server-side data sources and return a Promise object'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'data-resource'
|
||
},
|
||
{
|
||
name: 'indent',
|
||
type: 'number',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '子级相对于父级节点的水平缩进距离,单位 px',
|
||
'en-US': 'The horizontal indentation distance of a child relative to its parent node, in px'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'indent'
|
||
},
|
||
{
|
||
name: 'lazy',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否懒加载子节点,配合 load 属性使用',
|
||
'en-US': 'Whether to lazily load child nodes and use them in conjunction with the load attribute'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'lazy-load'
|
||
},
|
||
{
|
||
name: 'load',
|
||
typeAnchorName: 'IResolveType',
|
||
type: '(node:ITreeNodeVm, resolve:IResolveType) => IResolveType',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '加载子树数据的方法,仅当 lazy 属性为 true 时生效',
|
||
'en-US': 'Method for loading subtree data. This parameter is valid only when lazy is set to true'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'lazy-load'
|
||
},
|
||
{
|
||
name: 'menu-collapsible',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否显示侧边折叠与展开按钮',
|
||
'en-US': 'Is the side fold and unfold buttons displayed'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'menu-collapsible'
|
||
},
|
||
{
|
||
name: 'node-height',
|
||
type: 'number',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '节点高度',
|
||
'en-US': 'Node height'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-number'
|
||
},
|
||
{
|
||
name: 'node-key',
|
||
type: 'string',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '设置每个树节点唯一标识(key)的属性,在整棵树中都是唯一的',
|
||
'en-US':
|
||
"Set the attribute of each tree node's unique identifier (key) to be unique throughout the entire tree"
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'default-expand-all'
|
||
},
|
||
{
|
||
name: 'only-check-children',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '父级是否不可选,只能展开不能跳转',
|
||
'en-US': 'Parent level is not optional, can only be expanded and cannot jump'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'only-check-children'
|
||
},
|
||
{
|
||
name: 'prefix-icon',
|
||
type: 'Component',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '自定义前置图标',
|
||
'en-US': 'Customize the front icon'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'custom-icon'
|
||
},
|
||
{
|
||
name: 'props',
|
||
typeAnchorName: 'IProps',
|
||
type: 'IProps',
|
||
defaultValue:
|
||
"<pre>\n{\n children: 'children'\n label: 'label'\n disabled: 'disabled'\n isLeaf: 'isLeaf'\n} \n</pre>",
|
||
desc: {
|
||
'zh-CN': '映射字段',
|
||
'en-US': 'Map Fields'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'props'
|
||
},
|
||
{
|
||
name: 'search-icon',
|
||
type: 'Component',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '自定义搜索图标',
|
||
'en-US': 'Customize the search icon'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'custom-icon'
|
||
},
|
||
{
|
||
name: 'show-checkbox',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '节点是否可被选择',
|
||
'en-US': 'Whether the node can be selected'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-checkbox'
|
||
},
|
||
{
|
||
name: 'show-expand',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN':
|
||
'是否启用一键展开/收起功能。点击左下角图标可展开/收起菜单注意:配合 customIcon 属性使用,纯文本菜单不支持此功能',
|
||
'en-US':
|
||
'Whether to enable the one click expand/collapse function. Click on the icon in the bottom left corner to expand/collapse the menu. Note: When used in conjunction with the customIcon attribute, plain text menus do not support this feature'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-expand'
|
||
},
|
||
{
|
||
name: 'show-filter',
|
||
type: 'boolean',
|
||
defaultValue: 'true',
|
||
desc: {
|
||
'zh-CN': '是否显示搜索框,可搜索过滤节点',
|
||
'en-US': 'Display a search box to search for filter nodes'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-filter'
|
||
},
|
||
{
|
||
name: 'show-number',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '右侧下拉图标区域是否显示为 number 属性定义的数字内容,建议不超过 4 个字符',
|
||
'en-US':
|
||
'The drop-down icon area on the right displays the numerical content defined by the number attribute, which should not exceed 4 characters'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-number'
|
||
},
|
||
{
|
||
name: 'show-title',
|
||
type: 'boolean',
|
||
defaultValue: 'true',
|
||
desc: {
|
||
'zh-CN': '是否显示节点的 title 提示,鼠标悬浮节点之上触发',
|
||
'en-US': 'Whether to display the title prompt of the node, triggered by hovering the mouse over the node'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'show-filter'
|
||
},
|
||
{
|
||
name: 'suffix-icon',
|
||
type: 'Component',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '自定义后置图标',
|
||
'en-US': 'Customize the post icon'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'custom-icon'
|
||
},
|
||
{
|
||
name: 'wrap',
|
||
type: 'boolean',
|
||
defaultValue: 'false',
|
||
desc: {
|
||
'zh-CN': '是否换行显示',
|
||
'en-US': 'Indicates whether to display information in a new line.'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'text-wrap'
|
||
}
|
||
],
|
||
events: [
|
||
{
|
||
name: 'check-change',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(node:ITreeNodeVm, checked:boolean, indeterminate:boolean) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '监听可勾选节点的勾选状态发生变化时的事件',
|
||
'en-US': 'Listen for events when the check status of checkable nodes changes'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'events'
|
||
},
|
||
{
|
||
name: 'current-change',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(nodeData:ITreeNodeData, node:ITreeNodeVm) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '监听当前选中节点发生变化时的事件',
|
||
'en-US': 'Listen for events when the currently selected node changes'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'events'
|
||
},
|
||
{
|
||
name: 'node-click',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(nodeData:ITreeNodeData, node:ITreeNodeVm) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '监听节点被点击时的事件',
|
||
'en-US': 'Listen for events when a node is clicked'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'events'
|
||
},
|
||
{
|
||
name: 'node-collapse',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(nodeData:ITreeNodeData, node:ITreeNodeVm) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '监听节点被点击收起时的事件;',
|
||
'en-US': 'Event when a listening node is clicked to collapse'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'events'
|
||
},
|
||
{
|
||
name: 'node-drag-end',
|
||
typeAnchorName: 'IDropType',
|
||
type: '(draggingNode:ITreeNodeVm, targetNode:ITreeNodeVm, dropType:IDropType, event:DragEvent) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '监听节点拖拽结束(可能未成功)的事件',
|
||
'en-US': 'Listening for events where node drag and drop ends (possibly unsuccessful)'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'event-allow-draggable'
|
||
},
|
||
{
|
||
name: 'node-drag-start',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(node:ITreeNodeVm, event:DragEvent) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '监听节点开始拖拽的事件',
|
||
'en-US': 'Listening for events where nodes start dragging and dropping'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'event-allow-draggable'
|
||
},
|
||
{
|
||
name: 'node-expand',
|
||
typeAnchorName: 'ITreeNodeVm',
|
||
type: '(nodeData:ITreeNodeData, node:ITreeNodeVm) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '监听节点被点击展开时的事件;',
|
||
'en-US': 'Event when a listening node is clicked to expand'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'events'
|
||
}
|
||
],
|
||
methods: [
|
||
{
|
||
name: 'getCurrentKey',
|
||
type: '() => string | number | null',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '获取当前选中节点的 key ,注意:配合 node-key 属性设置每个节点 key 值的字段,仅适用单选',
|
||
'en-US':
|
||
'Obtain the key of the currently selected node. Note: Set the field for the key value of each node in conjunction with the node key attribute, only applicable for single selection'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'current-node'
|
||
},
|
||
{
|
||
name: 'getCurrentNode',
|
||
typeAnchorName: 'ITreeNodeData',
|
||
type: '() => ITreeNodeData|null',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '获得当前选中节点的数据,注意:配合 node-key 属性设置每个节点 key 值的字段,仅适用单选',
|
||
'en-US':
|
||
'Obtain the data of the currently selected node. Note: Set the field for the key value of each node in conjunction with the node key attribute, only applicable for single selection'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'current-node'
|
||
},
|
||
{
|
||
name: 'setCurrentKey',
|
||
type: '(key:string|number) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '通过 key 设置某个节点为当前选中的节点,注意:配合 node-key 属性设置每个节点 key 值的字段',
|
||
'en-US':
|
||
'Set a node as the currently selected node through key. Note: Set the key value field for each node in conjunction with the node key attribute'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'current-node'
|
||
},
|
||
{
|
||
name: 'setCurrentNode',
|
||
typeAnchorName: 'ITreeNodeData',
|
||
type: '(nodeData:ITreeNodeData) => void',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '通过 nodeData 设置某个节点为当前选中的节点,注意:配合 node-key 属性设置每个节点 key 值的字段',
|
||
'en-US':
|
||
'Set a node as the currently selected node through nodeData. Note: Set the key value field for each node in conjunction with the node key attribute'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'current-node'
|
||
}
|
||
],
|
||
slots: [
|
||
{
|
||
name: 'default',
|
||
defaultValue: '',
|
||
desc: {
|
||
'zh-CN': '自定义树节点的内容,参数为 { node, data }',
|
||
'en-US': 'Content of a customized tree node. The parameter is {node, data}'
|
||
},
|
||
mode: ['pc'],
|
||
pcDemo: 'tree-menu-slot'
|
||
}
|
||
]
|
||
}
|
||
],
|
||
types: [
|
||
{
|
||
name: 'ITreeNodeVm',
|
||
type: 'interface',
|
||
code: `
|
||
interface ITreeNodeVm {
|
||
// 是否已勾选
|
||
"checked": boolean
|
||
// 子节点
|
||
"childNodes": ITreeNodeVm[]
|
||
// 节点数据
|
||
"data": ITreeNodeData
|
||
// 是否展开
|
||
"expanded": boolean
|
||
// 唯一标识
|
||
"id": string | number
|
||
// 是否半选
|
||
"indeterminate": boolean
|
||
// 是否当前节点
|
||
"isCurrent": boolean
|
||
// 是否叶子节点
|
||
"isLeaf": boolean
|
||
// 层级
|
||
"level": number
|
||
// 是否已加载
|
||
"loaded": boolean
|
||
// 是否加载中
|
||
"loading": boolean
|
||
// 是否可见
|
||
"visible": boolean
|
||
// 是否禁用
|
||
"disabled": boolean
|
||
// 节点显示文本
|
||
"label": string
|
||
}
|
||
`
|
||
},
|
||
{
|
||
name: 'ITreeNodeData',
|
||
type: 'interface',
|
||
code: `
|
||
interface ITreeNodeData {
|
||
// node-key='id' 设置节点的唯一标识
|
||
"id": number | string
|
||
// 节点显示文本
|
||
"label": string
|
||
// 子节点
|
||
"children"?: ITreeNodeData[]
|
||
// 链接
|
||
"url"?: string,
|
||
// show-number 时展示的字段
|
||
"number"?: number | string
|
||
// 自定义每个节点的图标
|
||
"customIcon": Component
|
||
}
|
||
`
|
||
},
|
||
{
|
||
name: 'IProps',
|
||
type: 'interface',
|
||
code: `
|
||
interface IProps {
|
||
"label"?: string
|
||
"children"?: string
|
||
"disabled": string
|
||
"isLeaf": string
|
||
}
|
||
`
|
||
},
|
||
{
|
||
name: 'IResolveType',
|
||
type: 'type',
|
||
code: `
|
||
// Promise 的 resolve 回调函数
|
||
type IResolveType = (data:ITreeNodeData) => void
|
||
`
|
||
},
|
||
{
|
||
name: 'IDropType',
|
||
type: 'type',
|
||
code: `
|
||
// 拖拽节点相对目标节点的位置
|
||
type IDropType = before | after | inner | none
|
||
`
|
||
}
|
||
]
|
||
}
|