Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
P
pica.cloud.web-education-admin
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
成员
成员
收起侧边栏
Close sidebar
动态
分支图
统计图
提交
打开侧边栏
com.pica.cloud.education.frontend
pica.cloud.web-education-admin
提交
7d7e20a6
提交
7d7e20a6
编写于
3月 30, 2021
作者:
yi.li
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'origin/dev-kol-20210324' into dev-kol-20210324
# Conflicts: # src/components/yqrange/kol-manage.vue
上级
d5f34cee
8eb8bfce
变更
3
隐藏空白字符变更
内嵌
并排
正在显示
3 个修改的文件
包含
153 行增加
和
35 行删除
+153
-35
kolTable.vue
src/components/yqrange/kol-component/kolTable.vue
+145
-0
kol-manage.vue
src/components/yqrange/kol-manage.vue
+6
-35
main.js
src/main.js
+2
-0
未找到文件。
src/components/yqrange/kol-component/kolTable.vue
0 → 100644
浏览文件 @
7d7e20a6
<
template
>
<div
class=
"kmc"
>
<el-row
class=
"table-content"
>
<!-- 表格 -->
<div
class=
"table-title"
>
<span
class=
"table-t"
v-for=
"(item,index) of titleList"
:key=
"index"
>
{{
item
.
title
}}
</span>
</div>
<draggable
:list=
"groupData"
:move=
"getdata"
@
update=
"datadragEnd"
:options=
"
{handle:'.dargDiv'}">
<transition-group
name=
"list-complete"
>
<div
v-for=
"(element, index) in groupData"
:key=
"index"
class=
"list-complete-item dargDiv"
v-bind:class=
"
{ border_top: index == 0}">
<div
class=
"styleclass"
style=
"width: 100px"
>
{{
index
+
1
}}
</div>
<div
class=
"styleclass"
>
{{
element
.
name
}}
</div>
<div
class=
"styleclass"
>
{{
element
.
district
}}
</div>
<div
class=
"styleclass"
>
{{
element
.
hospital
}}
</div>
<div
class=
"styleclass"
>
{{
element
.
department
}}
</div>
<div
class=
"styleclass"
>
{{
element
.
title
}}
</div>
<div
class=
"styleclass"
>
{{
element
.
team
}}
</div>
<div
class=
"styleclass"
>
{{
element
.
status
}}
</div>
<div
class=
"styleclass"
>
<el-button
type=
"danger"
size=
"small"
@
click=
"deletefn(index)"
>
删除
</el-button>
</div>
</div>
</transition-group>
</draggable>
</el-row>
</div>
</
template
>
<
script
>
export
default
{
props
:
{
tableData
:
{
type
:
Array
,
default
:
[]
}
},
data
()
{
return
{
groupData
:
[],
titleList
:
[
{
title
:
'顺序'
},
{
title
:
'姓名'
},
{
title
:
'地区'
},
{
title
:
'所在医院'
},
{
title
:
'科室'
},
{
title
:
'职称'
},
{
title
:
'所属团队'
},
{
title
:
'发布状态'
},
{
title
:
'操作'
}
]
}
},
watch
:
{
tableData
:
{
deep
:
true
,
immediate
:
true
,
handler
(
newv
){
this
.
groupData
=
newv
}
}
},
methods
:
{
getdata
:
function
(
evt
){
},
datadragEnd
:
function
(
evt
){
console
.
log
(
'拖动前的索引:'
+
evt
.
oldIndex
);
console
.
log
(
'拖动后的索引:'
+
evt
.
newIndex
);
},
deletefn
(
index
)
{
this
.
groupData
.
splice
(
index
,
1
)
},
getNewData
()
{
this
.
groupData
.
forEach
((
element
,
index
)
=>
{
element
.
seq
=
index
+
1
});
return
this
.
groupData
}
},
}
</
script
>
<
style
lang=
"scss"
scoped
>
.table-content
{
margin-top
:
15px
;
}
.save-btn
{
margin-top
:
20px
;
display
:
flex
;
justify-content
:
center
;
}
.table-title
{
display
:
flex
;
height
:
60px
;
line-height
:
60px
;
background
:
#fafafa
;
border-bottom
:
1px
solid
#efefef
;
.table-t
{
flex
:
1
;
width
:
11%
;
display
:
inline-block
;
text-align
:
center
;
}
}
.dargDiv
{
display
:
flex
;
padding
:
20px
0
;
border-bottom
:
1px
solid
#efefef
;
overflow
:
hidden
;
}
.dargDiv
.styleclass
{
flex
:
1
;
width
:
11%
;
text-align
:
center
;
height
:
100px
;
// line-height: 100px;
// overflow: hidden;
// text-overflow:ellipsis;
// white-space: nowrap;
align-items
:
center
;
justify-content
:
center
;
display
:
flex
;
}
</
style
>
src/components/yqrange/kol-manage.vue
浏览文件 @
7d7e20a6
...
@@ -22,28 +22,7 @@
...
@@ -22,28 +22,7 @@
</el-row>
</el-row>
</el-form>
</el-form>
<el-row
class=
"table-content"
>
<el-row
class=
"table-content"
>
<el-table
<kol-table
:tableData=
"tableData"
ref=
"kolTable"
></kol-table>
:data=
"tableData"
border
id=
"kolTable"
style=
"width: 100%"
>
<el-table-column
show-overflow-tooltip
v-for=
"(item, key) in col"
:key=
"`col_$
{key}`"
:prop="col[key].prop"
:label="item.label"
align="center"
>
<template
slot-scope=
"scope"
>
<p>
{{
scope
.
row
[
item
.
prop
]
}}
</p>
<div
v-if=
"item.prop === 'operate'"
>
<el-button
size=
"small"
@
click=
"deleteItem(scope.$index)"
>
移除
</el-button>
</div>
</
template
>
</el-table-column>
</el-table>
<el-row
class=
"save-btn"
>
<el-row
class=
"save-btn"
>
<el-button
type=
"primary"
@
click=
"handleSave"
>
保存
</el-button>
<el-button
type=
"primary"
@
click=
"handleSave"
>
保存
</el-button>
</el-row>
</el-row>
...
@@ -72,8 +51,7 @@
...
@@ -72,8 +51,7 @@
v-for=
"item in expertList"
v-for=
"item in expertList"
:key=
"item.userId"
:key=
"item.userId"
:label=
"item.option"
:label=
"item.option"
:value=
"item.userId"
:value=
"item.userId"
>
:disabled=
"item.disabled"
>
</el-option>
</el-option>
</el-select>
</el-select>
</el-form-item>
</el-form-item>
...
@@ -87,14 +65,13 @@
...
@@ -87,14 +65,13 @@
</
template
>
</
template
>
<
script
>
<
script
>
import
Sortable
from
'sortablejs'
;
import
kolTable
from
'./kol-component/kolTable'
import
{
kolCol
}
from
'./util/common'
;
import
{
getExpertList
,
getExperNametList
,
saveKolConfig
}
from
'@/utils/yqrange/rangeApi'
import
{
getExpertList
,
getExperNametList
,
saveKolConfig
}
from
'@/utils/yqrange/rangeApi'
import
{
openLoading
,
closeLoading
}
from
"@/utils/utils"
;
import
{
openLoading
,
closeLoading
}
from
"@/utils/utils"
;
export
default
{
export
default
{
components
:
{
components
:
{
Sort
able
kolT
able
},
},
props
:
{
props
:
{
circleId
:
{
circleId
:
{
...
@@ -130,15 +107,11 @@ export default {
...
@@ -130,15 +107,11 @@ export default {
{
required
:
true
,
message
:
'请输入专家姓名或医院名称,多个关键字用空格隔开'
,
trigger
:
'change'
},
{
required
:
true
,
message
:
'请输入专家姓名或医院名称,多个关键字用空格隔开'
,
trigger
:
'change'
},
],
],
},
},
col
:
kolCol
,
tableData
:
[]
tableData
:
[]
}
}
},
},
mounted
()
{
mounted
()
{
this
.
initData
();
this
.
initData
();
this
.
$nextTick
(()
=>
{
this
.
rowDrop
();
});
},
},
methods
:
{
methods
:
{
initData
()
{
initData
()
{
...
@@ -153,10 +126,6 @@ export default {
...
@@ -153,10 +126,6 @@ export default {
console
.
log
(
'网络出现点儿问题,稍后重试'
)
console
.
log
(
'网络出现点儿问题,稍后重试'
)
})
})
},
},
rowDrop
()
{
const
tbody
=
document
.
querySelector
(
'#kolTable tbody'
);
Sortable
.
create
(
tbody
);
},
handleAdd
()
{
handleAdd
()
{
this
.
addFormVisible
=
true
;
this
.
addFormVisible
=
true
;
if
(
this
.
$refs
[
'addForm'
])
{
if
(
this
.
$refs
[
'addForm'
])
{
...
@@ -166,6 +135,8 @@ export default {
...
@@ -166,6 +135,8 @@ export default {
this
.
selectExpertItem
=
{};
this
.
selectExpertItem
=
{};
},
},
handleSave
()
{
handleSave
()
{
// 排序和删除后的table数据
let
newTableData
=
this
.
$refs
.
kolTable
.
getNewData
()
this
.
$refs
.
ruleForm
.
validate
((
valid
)
=>
{
this
.
$refs
.
ruleForm
.
validate
((
valid
)
=>
{
if
(
valid
)
{
if
(
valid
)
{
// console.log('form校验通过')
// console.log('form校验通过')
...
...
src/main.js
浏览文件 @
7d7e20a6
...
@@ -6,6 +6,8 @@ import store from './store/'
...
@@ -6,6 +6,8 @@ import store from './store/'
const
mixins
=
require
(
'@/utils/mixins'
);
const
mixins
=
require
(
'@/utils/mixins'
);
import
FastClick
from
'fastclick'
import
FastClick
from
'fastclick'
import
vueFilters
from
'@/utils/filter'
import
vueFilters
from
'@/utils/filter'
import
draggable
from
'vuedraggable'
Vue
.
component
(
'draggable'
,
draggable
);
// import '@/utils/toBlob';
// import '@/utils/toBlob';
// 引入ElementUI
// 引入ElementUI
...
...
写
预览
Markdown
格式
0%
请重试
or
附加一个文件
附加文件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录