Skip to content
项目
群组
代码片段
帮助
正在加载...
帮助
提交反馈
为 GitLab 提交贡献
登录
切换导航
P
pica.cloud.web-education-admin
项目
项目
详情
动态
版本
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Wiki
Wiki
代码片段
代码片段
成员
成员
收起侧边栏
Close sidebar
动态
分支图
统计图
创建新议题
提交
议题看板
打开侧边栏
jingqi.liu
pica.cloud.web-education-admin
提交
b926909c
提交
b926909c
编写于
9月 27, 2020
作者:
haochangdi
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
新增小圈权限分配页面
上级
b7aa627d
变更
5
隐藏空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
332 行增加
和
11 行删除
+332
-11
router.js
src/router/router.js
+5
-1
cmeApi.js
src/utils/cme/cmeApi.js
+10
-0
filter.js
src/utils/filter.js
+28
-9
slidebar.vue
src/views/layout/slidebar.vue
+15
-1
circle-limit.vue
src/views/system/circle-limit.vue
+274
-0
未找到文件。
src/router/router.js
浏览文件 @
b926909c
...
...
@@ -7,7 +7,8 @@ const blank = r => require.ensure([], () => r(require('../views/blank')), 'blank
const
itemManager
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/education/item-manager.vue'
)),
'item-manager'
)
const
itemComponent
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/education/item-component.vue'
)),
'item-component'
)
const
createComponent
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/education/create-component.vue'
)),
'create-component'
)
const
roleManager
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/system/role.vue'
)),
'role'
)
const
roleManager
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/system/role.vue'
)),
'role'
)
const
circleLimit
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/system/circle-limit.vue'
)),
'circle-limit'
)
const
addManager
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/education/add-manager.vue'
)),
'add-manager'
)
const
editManager
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/education/edit-manager.vue'
)),
'edit-manager'
)
const
itemRole
=
r
=>
require
.
ensure
([],
()
=>
r
(
require
(
'../views/system/item-role.vue'
)),
'item-role'
)
...
...
@@ -121,6 +122,9 @@ export default [{
},{
path
:
'/role'
,
component
:
roleManager
},{
path
:
'/circle-limit'
,
component
:
circleLimit
},{
path
:
'/create-component'
,
component
:
createComponent
...
...
src/utils/cme/cmeApi.js
浏览文件 @
b926909c
...
...
@@ -187,4 +187,14 @@ export const handleExportReq = (data) => {
data
:
data
,
description
:
'导出'
,
})
}
export
const
circleMenu
=
(
data
)
=>
{
return
fetch
({
headers
,
url
:
getBaseUrl
(
`circle/circle/judge/menu`
),
method
:
'get'
,
data
:
data
,
description
:
'判断用户是否有创建圈子菜单权限'
,
})
}
\ No newline at end of file
src/utils/filter.js
浏览文件 @
b926909c
...
...
@@ -523,15 +523,34 @@ const vueFilter = {
return
'-'
}
},
streamTypeFilter
:
(
value
)
=>
{
if
(
value
==
1
)
{
return
'网页直播'
}
else
if
(
value
==
2
)
{
return
'拉流直播'
}
else
{
return
'-'
}
},
streamTypeFilter
:
(
value
)
=>
{
if
(
value
==
1
)
{
return
'网页直播'
}
else
if
(
value
==
2
)
{
return
'拉流直播'
}
else
{
return
'-'
}
},
setDepartment
:
(
value
)
=>
{
if
(
value
==
0
)
{
return
'铁军部'
}
else
if
(
value
==
1
)
{
return
'医疗事业部'
}
else
if
(
value
==
2
)
{
return
'商业化部'
}
else
{
return
'-'
}
},
setFlag
:
(
value
)
=>
{
if
(
value
==
1
)
{
return
'已开通'
}
else
{
return
'未开通'
}
},
}
export
default
vueFilter
src/views/layout/slidebar.vue
浏览文件 @
b926909c
...
...
@@ -52,7 +52,7 @@
import
{
mapGetters
}
from
'vuex'
import
{
setTimeout
}
from
'timers'
import
{
isNotEmptyUtils
}
from
'../../utils/utils'
import
{
getUserTypeReq
}
from
'@/utils/cme/cmeApi'
import
{
getUserTypeReq
,
circleMenu
}
from
'@/utils/cme/cmeApi'
import
{
getCircleRole
}
from
'@/utils/patients/patientsapi'
import
{
queryShopAuth
}
from
'@/utils/shop'
;
...
...
@@ -171,6 +171,7 @@
vm
.
getRoleObj
();
}
vm
.
setShopSide
()
vm
.
setCircleSlide
()
// vm.getGoodsAuth();
},
watch
:
{
...
...
@@ -494,6 +495,19 @@
})
}
},
// judge/menu
setCircleSlide
()
{
circleMenu
({}).
then
((
res
)
=>
{
if
(
res
.
data
===
true
)
{
this
.
items
[
2
].
subs
.
push
({
title
:
'新建小圈权限分配'
,
icon
:
'el-icon-setting'
,
index
:
'circle-limit'
})
}
})
}
}
}
</
script
>
...
...
src/views/system/circle-limit.vue
0 → 100644
浏览文件 @
b926909c
<
template
>
<div
class=
"circle-limit"
>
<bread-crumb
:curmbFirst=
"curmbFirst"
:curmbSecond=
"curmbSecond"
></bread-crumb>
<div
class=
"component-content screenSet"
id=
"screenSet"
>
<div
class=
"header-title"
>
新建小圈权限分配
</div>
<el-row
:gutter=
"30"
class=
"row"
type=
"flex"
style=
"margin-top: 10px;"
align=
'middle'
justify=
'space-around'
>
<el-form
ref=
"formInline"
:model=
"formInline"
label-width=
"75px"
style=
"width:100%;"
>
<el-col
:span=
"6"
style=
"min-width: 200px"
>
<el-form-item
label=
"手机号:"
>
<el-input
v-model=
"formInline.mobile"
size=
"small"
placeholder=
"请输入"
></el-input>
</el-form-item>
</el-col>
<el-col
:span=
"5"
style=
"padding:0;text-align:right;margin-right:40px; float: right"
>
<el-button
type=
"primary"
size=
"small"
@
click=
"searchList"
>
搜索
</el-button>
<el-button
type=
"default"
size=
"small"
@
click=
"resetForm"
style=
"margin-left:0;"
>
取消搜索
</el-button>
</el-col>
</el-form>
</el-row>
<el-table
:data=
"tableData"
style=
"width: 100%"
>
<el-table-column
prop=
"doctorName"
label=
"用户名"
align=
"center"
></el-table-column>
<el-table-column
prop=
"bizDepart"
label=
"对接部门"
align=
"center"
>
<template
slot-scope=
"scope"
>
<span>
{{
scope
.
row
.
bizDepart
|
setDepartment
}}
</span>
</
template
>
</el-table-column>
<el-table-column
prop=
"mobileMask"
label=
"手机号"
align=
"center"
></el-table-column>
<el-table-column
prop=
"hospitalName"
label=
"所属机构"
align=
"center"
></el-table-column>
<el-table-column
prop=
"district"
label=
"所属地区"
align=
"center"
show-overflow-tooltip
></el-table-column>
<el-table-column
prop=
"masterFlag"
label=
"建圈权限状态"
align=
"center"
>
<
template
slot-scope=
"scope"
>
<span>
{{
scope
.
row
.
masterFlag
|
setFlag
}}
</span>
</
template
>
</el-table-column>
<el-table-column
prop=
"modifiedName"
label=
"最后操作"
align=
"center"
></el-table-column>
<el-table-column
fixed=
"right"
label=
"操作"
width=
"200"
align=
"center"
>
<
template
slot-scope=
"scope"
>
<el-button
type=
"primary"
size=
"small"
@
click=
"closeFlag(scope.row)"
v-if=
"scope.row.masterFlag == 1"
>
关闭权限
</el-button>
<el-button
type=
"primary"
size=
"small"
@
click=
"openFlag(scope.row)"
v-else
>
开放权限
</el-button>
</
template
>
</el-table-column>
<div
slot=
"empty"
>
<div
class=
"table-empty"
>
<img
src=
"../../assets/image/no-content1.png"
>
<p>
{{showMsg == 1 ? noDataMsg : noMobileMsg}}
</p>
</div>
</div>
</el-table>
<div
class=
"pagination"
>
<el-pagination
background
@
size-change=
"handleSizeChange"
@
current-change=
"handleCurrentChange"
:current-page=
"formInline.pageNo"
:page-sizes=
"[10, 30, 50, 100, 200]"
:page-size=
"formInline.pageSize"
layout=
"total, sizes, prev, pager, next, jumper"
:total=
"totalRows"
></el-pagination>
</div>
<el-dialog
title=
"开通新建小圈权限"
:visible
.
sync=
"dialogVisible"
width=
"30%"
>
<div>
<el-form
:model=
"orgForm"
:rules=
"rules"
label-width=
"100px"
ref=
"dialogForm"
>
<el-form-item
label=
"对接部门"
prop=
"org"
>
<el-select
v-model=
"orgForm.org"
placeholder=
"请选择"
>
<el-option
v-for=
"item in orgSelect"
:key=
"item.value"
:label=
"item.label"
:value=
"item.value"
>
</el-option>
</el-select>
</el-form-item>
</el-form>
</div>
<span
slot=
"footer"
class=
"dialog-footer"
>
<el-button
@
click=
"dialogVisible = false"
>
取 消
</el-button>
<el-button
type=
"primary"
@
click=
"handleClose"
>
确 定
</el-button>
</span>
</el-dialog>
</div>
</div>
</template>
<
script
>
import
BreadCrumb
from
"../../components/breadcrumb.vue"
;
import
{
create
}
from
"domain"
;
import
{
mapGetters
}
from
'vuex'
import
{
openLoading
,
closeLoading
}
from
"../../utils/utils"
;
import
*
as
commonUtil
from
"../../utils/utils"
;
let
vm
=
null
;
export
default
{
components
:
{
BreadCrumb
},
data
()
{
return
{
curmbFirst
:
"系统管理"
,
curmbSecond
:
"角色管理"
,
tableData
:
[],
totalRows
:
0
,
formInline
:
{
mobile
:
""
,
pageNo
:
1
,
pageSize
:
10
},
orgForm
:
{
org
:
''
,
openDoctorId
:
''
},
orgSelect
:
[
{
value
:
0
,
label
:
'铁军部'
},
{
value
:
1
,
label
:
'医疗事业部'
},
{
value
:
2
,
label
:
'商业化部'
},
],
dialogVisible
:
false
,
noDataMsg
:
'没有查询到相关结果'
,
noMobileMsg
:
'没有查询到该手机号,请重新搜索'
,
showMsg
:
1
,
rules
:
{
org
:
[
{
required
:
true
,
message
:
'请选择该用户对接部门'
,
trigger
:
'change'
}
],
}
};
},
computed
:
{
...
mapGetters
([
"_token"
]),
},
created
()
{
vm
=
this
;
vm
.
idType
=
localStorage
.
getItem
(
'storageIdType'
);
this
.
search
();
},
// 挂载到Dom完成时
mounted
:
function
()
{
commonUtil
.
resizeHeight
();
},
methods
:
{
searchList
()
{
vm
.
formInline
.
pageNo
=
1
;
vm
.
search
();
},
search
()
{
let
req
=
{};
req
=
vm
.
formInline
;
if
(
vm
.
formInline
.
mobile
.
trim
())
{
vm
.
showMsg
=
2
}
else
{
vm
.
showMsg
=
1
}
openLoading
(
vm
);
vm
.
POST
(
"/circle/member/master/grant/list"
,
req
).
then
(
res
=>
{
closeLoading
(
vm
);
if
(
res
.
code
==
"000000"
)
{
vm
.
tableData
=
res
.
data
.
grantListDtos
;
vm
.
totalRows
=
res
.
data
.
total
;
}
});
},
resetForm
()
{
vm
.
formInline
=
{
mobile
:
""
,
pageNo
:
1
,
pageSize
:
10
}
vm
.
search
();
},
openFlag
(
row
)
{
vm
.
orgForm
.
org
=
''
vm
.
orgForm
.
openDoctorId
=
row
.
doctorId
vm
.
dialogVisible
=
true
this
.
$refs
.
dialogForm
.
resetFields
();
},
handleClose
()
{
this
.
$refs
.
dialogForm
.
validate
((
valid
)
=>
{
if
(
!
valid
)
{
console
.
log
(
'error submit!!'
);
}
else
{
vm
.
$confirm
(
'确认开通权限?允许用户创建小圈'
)
.
then
(
_
=>
{
openLoading
(
vm
);
let
req
=
{
bizDepart
:
vm
.
orgForm
.
org
,
doctorId
:
vm
.
orgForm
.
openDoctorId
,
type
:
1
}
vm
.
POST
(
"/circle/member/master/grant"
,
req
).
then
(
res
=>
{
if
(
res
.
code
==
"000000"
)
{
vm
.
searchList
()
vm
.
dialogVisible
=
false
}
});
})
.
catch
(
_
=>
{});
}
});
},
closeFlag
(
row
)
{
vm
.
$confirm
(
'确认关闭权限,禁止用户创建小圈?'
)
.
then
(
_
=>
{
openLoading
(
vm
);
let
req
=
{
bizDepart
:
row
.
bizDepart
,
doctorId
:
row
.
doctorId
,
type
:
2
}
vm
.
POST
(
"/circle/member/master/grant"
,
req
).
then
(
res
=>
{
if
(
res
.
code
==
"000000"
)
{
vm
.
searchList
()
}
});
})
.
catch
(
_
=>
{});
},
handleSizeChange
(
val
)
{
this
.
formInline
.
pageSize
=
val
;
this
.
search
();
console
.
log
(
`每页
${
val
}
条`
);
},
handleCurrentChange
(
val
)
{
this
.
formInline
.
pageNo
=
val
;
this
.
search
();
console
.
log
(
`当前页:
${
val
}
`
);
}
}
};
</
script
>
<
style
lang=
"scss"
scoped
>
.circle-limit
{
.component-content
{
padding
:
10px
;
background
:
#fff
;
.header-title
{
padding
:
10px
12px
;
font-size
:
12px
;
color
:
#449284
;
border-bottom
:
1px
solid
#efefef
;
}
.to-right
{
float
:
right
;
}
.add-button
{
float
:
right
;
}
.table-empty
{
img
{
width
:
100px
;
}
p
{
margin-top
:
-50px
;
}
}
}
}
.el-tooltip__popper
{
max-width
:
50%
}
</
style
>
\ No newline at end of file
写
预览
Markdown
格式
0%
请重试
or
附加一个文件
附加文件
取消
您添加了
0
人
到此讨论。请谨慎行事。
先完成此消息的编辑!
取消
想要评论请
注册
或
登录