Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
zuiqiangwanggong
vue-vben-admin
提交
67d514ad
V
vue-vben-admin
项目概览
zuiqiangwanggong
/
vue-vben-admin
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
V
vue-vben-admin
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
67d514ad
编写于
1月 18, 2022
作者:
T
ToQuery
提交者:
GitHub
1月 18, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
新增 api tree 组件 (#1582)
* tsconfig 增加 types , 解决webstorm提示错误 * api-tree
上级
929141be
变更
4
显示空白变更内容
内联
并排
Showing
4 changed file
with
90 addition
and
0 deletion
+90
-0
src/components/Form/index.ts
src/components/Form/index.ts
+1
-0
src/components/Form/src/componentMap.ts
src/components/Form/src/componentMap.ts
+2
-0
src/components/Form/src/components/ApiTree.vue
src/components/Form/src/components/ApiTree.vue
+86
-0
src/components/Form/src/types/index.ts
src/components/Form/src/types/index.ts
+1
-0
未找到文件。
src/components/Form/index.ts
浏览文件 @
67d514ad
...
...
@@ -9,6 +9,7 @@ export { useForm } from './src/hooks/useForm';
export
{
default
as
ApiSelect
}
from
'
./src/components/ApiSelect.vue
'
;
export
{
default
as
RadioButtonGroup
}
from
'
./src/components/RadioButtonGroup.vue
'
;
export
{
default
as
ApiTreeSelect
}
from
'
./src/components/ApiTreeSelect.vue
'
;
export
{
default
as
ApiTree
}
from
'
./src/components/ApiTree.vue
'
;
export
{
default
as
ApiRadioGroup
}
from
'
./src/components/ApiRadioGroup.vue
'
;
export
{
default
as
ApiCascader
}
from
'
./src/components/ApiCascader.vue
'
;
...
...
src/components/Form/src/componentMap.ts
浏览文件 @
67d514ad
...
...
@@ -24,6 +24,7 @@ import {
import
ApiRadioGroup
from
'
./components/ApiRadioGroup.vue
'
;
import
RadioButtonGroup
from
'
./components/RadioButtonGroup.vue
'
;
import
ApiSelect
from
'
./components/ApiSelect.vue
'
;
import
ApiTree
from
'
./components/ApiTree.vue
'
;
import
ApiTreeSelect
from
'
./components/ApiTreeSelect.vue
'
;
import
ApiCascader
from
'
./components/ApiCascader.vue
'
;
import
{
BasicUpload
}
from
'
/@/components/Upload
'
;
...
...
@@ -43,6 +44,7 @@ componentMap.set('AutoComplete', AutoComplete);
componentMap
.
set
(
'
Select
'
,
Select
);
componentMap
.
set
(
'
ApiSelect
'
,
ApiSelect
);
componentMap
.
set
(
'
ApiTree
'
,
ApiTree
);
componentMap
.
set
(
'
TreeSelect
'
,
TreeSelect
);
componentMap
.
set
(
'
ApiTreeSelect
'
,
ApiTreeSelect
);
componentMap
.
set
(
'
ApiRadioGroup
'
,
ApiRadioGroup
);
...
...
src/components/Form/src/components/ApiTree.vue
0 → 100644
浏览文件 @
67d514ad
<
template
>
<a-tree
v-bind=
"getAttrs"
@
change=
"handleChange"
>
<template
#[item]=
"data"
v-for=
"item in Object.keys($slots)"
>
<slot
:name=
"item"
v-bind=
"data ||
{}">
</slot>
</
template
>
<
template
#suffixIcon
v-if=
"loading"
>
<LoadingOutlined
spin
/>
</
template
>
</a-tree>
</template>
<
script
lang=
"ts"
>
import
{
computed
,
defineComponent
,
watch
,
ref
,
onMounted
,
unref
}
from
'
vue
'
;
import
{
Tree
}
from
'
ant-design-vue
'
;
import
{
isArray
,
isFunction
}
from
'
/@/utils/is
'
;
import
{
get
}
from
'
lodash-es
'
;
import
{
propTypes
}
from
'
/@/utils/propTypes
'
;
import
{
LoadingOutlined
}
from
'
@ant-design/icons-vue
'
;
export
default
defineComponent
({
name
:
'
ApiTree
'
,
components
:
{
ATree
:
Tree
,
LoadingOutlined
},
props
:
{
api
:
{
type
:
Function
as
PropType
<
(
arg
?:
Recordable
)
=>
Promise
<
Recordable
>>
},
params
:
{
type
:
Object
},
immediate
:
{
type
:
Boolean
,
default
:
true
},
resultField
:
propTypes
.
string
.
def
(
''
),
},
emits
:
[
'
options-change
'
,
'
change
'
],
setup
(
props
,
{
attrs
,
emit
})
{
const
treeData
=
ref
<
Recordable
[]
>
([]);
const
isFirstLoaded
=
ref
<
Boolean
>
(
false
);
const
loading
=
ref
(
false
);
const
getAttrs
=
computed
(()
=>
{
return
{
...(
props
.
api
?
{
treeData
:
unref
(
treeData
)
}
:
{}),
...
attrs
,
};
});
function
handleChange
(...
args
)
{
emit
(
'
change
'
,
...
args
);
}
watch
(
()
=>
props
.
params
,
()
=>
{
!
unref
(
isFirstLoaded
)
&&
fetch
();
},
{
deep
:
true
},
);
watch
(
()
=>
props
.
immediate
,
(
v
)
=>
{
v
&&
!
isFirstLoaded
.
value
&&
fetch
();
},
);
onMounted
(()
=>
{
props
.
immediate
&&
fetch
();
});
async
function
fetch
()
{
const
{
api
}
=
props
;
if
(
!
api
||
!
isFunction
(
api
))
return
;
loading
.
value
=
true
;
treeData
.
value
=
[];
let
result
;
try
{
result
=
await
api
(
props
.
params
);
}
catch
(
e
)
{
console
.
error
(
e
);
}
loading
.
value
=
false
;
if
(
!
result
)
return
;
if
(
!
isArray
(
result
))
{
result
=
get
(
result
,
props
.
resultField
);
}
treeData
.
value
=
(
result
as
Recordable
[])
||
[];
isFirstLoaded
.
value
=
true
;
emit
(
'
options-change
'
,
treeData
.
value
);
}
return
{
getAttrs
,
loading
,
handleChange
};
},
});
</
script
>
src/components/Form/src/types/index.ts
浏览文件 @
67d514ad
...
...
@@ -91,6 +91,7 @@ export type ComponentType =
|
'
Select
'
|
'
ApiSelect
'
|
'
TreeSelect
'
|
'
ApiTree
'
|
'
ApiTreeSelect
'
|
'
ApiRadioGroup
'
|
'
RadioButtonGroup
'
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录