Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
A
ai-yunshou-vue
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
AI云守
ai-yunshou-vue
Commits
cb249d29
Commit
cb249d29
authored
Aug 12, 2024
by
胡占生
🇨🇳
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
feat:设备列表功能接口联调,页面构建
parent
ffe8dcea
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
446 additions
and
10 deletions
+446
-10
src/api/algorithmList/algorithmDown.js
src/api/algorithmList/algorithmDown.js
+5
-5
src/api/algorithmList/index.js
src/api/algorithmList/index.js
+5
-5
src/api/yunshou/device.js
src/api/yunshou/device.js
+85
-0
src/views/deviceControl/index.vue
src/views/deviceControl/index.vue
+351
-0
No files found.
src/api/algorithmList/algorithmDown.js
View file @
cb249d29
...
...
@@ -12,7 +12,7 @@ import request from '@/utils/request'
// 查询算法列表
export
function
listAlgLevel
(
query
)
{
return
request
({
url
:
'
/
system
/alarmLevel/list
'
,
url
:
'
/
yunshou
/alarmLevel/list
'
,
method
:
'
get
'
,
params
:
query
})
...
...
@@ -21,7 +21,7 @@ export function listAlgLevel(query) {
// 查询算法列表x详情
export
function
detailAlgLevel
(
id
)
{
return
request
({
url
:
`/
system
/alarmLevel/
${
id
}
`
,
url
:
`/
yunshou
/alarmLevel/
${
id
}
`
,
method
:
'
get
'
,
})
}
...
...
@@ -30,7 +30,7 @@ export function detailAlgLevel(id) {
// 新增算法列表
export
function
addAlgLevel
(
data
)
{
return
request
({
url
:
'
/
system
/alarmLevel
'
,
url
:
'
/
yunshou
/alarmLevel
'
,
method
:
'
post
'
,
data
:
data
})
...
...
@@ -39,7 +39,7 @@ export function addAlgLevel(data) {
// 修改算法列表
export
function
updateAlgLevel
(
data
)
{
return
request
({
url
:
'
/
system
/alarmLevel
'
,
url
:
'
/
yunshou
/alarmLevel
'
,
method
:
'
put
'
,
data
:
data
})
...
...
@@ -49,7 +49,7 @@ export function updateAlgLevel(data) {
// 删除算法列表
export
function
deleteAlgLevel
(
ids
)
{
return
request
({
url
:
`/
system
/alarmLevel/
${
ids
}
`
,
url
:
`/
yunshou
/alarmLevel/
${
ids
}
`
,
method
:
'
delete
'
})
}
src/api/algorithmList/index.js
View file @
cb249d29
...
...
@@ -24,7 +24,7 @@ import request from '@/utils/request'
// 查询算法列表
export
function
listAlg
(
query
)
{
return
request
({
url
:
'
/
system
/aiAlgorithmConfig/list
'
,
url
:
'
/
yunshou
/aiAlgorithmConfig/list
'
,
method
:
'
get
'
,
params
:
query
})
...
...
@@ -33,7 +33,7 @@ export function listAlg(query) {
// 查询算法列表x详情
export
function
detailAlg
(
id
)
{
return
request
({
url
:
`/
system
/aiAlgorithmConfig/
${
id
}
`
,
url
:
`/
yunshou
/aiAlgorithmConfig/
${
id
}
`
,
method
:
'
get
'
,
})
}
...
...
@@ -42,7 +42,7 @@ export function detailAlg(id) {
// 新增算法列表
export
function
addAlg
(
data
)
{
return
request
({
url
:
'
/
system
/aiAlgorithmConfig
'
,
url
:
'
/
yunshou
/aiAlgorithmConfig
'
,
method
:
'
post
'
,
data
:
data
})
...
...
@@ -51,7 +51,7 @@ export function addAlg(data) {
// 修改算法列表
export
function
updateAlg
(
data
)
{
return
request
({
url
:
'
/
system
/aiAlgorithmConfig
'
,
url
:
'
/
yunshou
/aiAlgorithmConfig
'
,
method
:
'
put
'
,
data
:
data
})
...
...
@@ -61,7 +61,7 @@ export function updateAlg(data) {
// 删除算法列表
export
function
deleteAlg
(
ids
)
{
return
request
({
url
:
`/
system
/aiAlgorithmConfig/
${
ids
}
`
,
url
:
`/
yunshou
/aiAlgorithmConfig/
${
ids
}
`
,
method
:
'
delete
'
})
}
src/api/yunshou/device.js
0 → 100644
View file @
cb249d29
/**
* 新增设备
* @param {object} params 设备表
* @param {string} params.createBy
* @param {object} params.createTime
* @param {object} params.params
* @param {string} params.remark
* @param {string} params.searchValue
* @param {string} params.updateBy
* @param {object} params.updateTime
* @param {string} params.id 主键ID
* @param {string} params.deviceNo 设备编号
* @param {string} params.deviceName 设备名称
* @param {string} params.deviceType 设备类型
* @param {string} params.videoUrlType 视频流类型
* @param {string} params.videoUrl 视频流地址
* @param {string} params.isDel 是否删除(0 正常 / 1 删除)
* @param {string} params.isEffective 是否有效(0 有效 / 1 无效)
* @param {string} params.isOpen 开启状态(0 开启 / 1 关闭)
* @returns
*/
import
request
from
'
@/utils/request
'
// 查询设备列表
export
function
listDevice
(
query
)
{
return
request
({
url
:
'
/yunshou/aiDevice/list
'
,
method
:
'
get
'
,
params
:
query
})
}
// 查询设备列表x详情
export
function
detailDevice
(
id
)
{
return
request
({
url
:
`/yunshou/aiDevice/
${
id
}
`
,
method
:
'
get
'
,
})
}
// 修改设备状态
export
function
updateStatusDevice
(
query
)
{
return
request
({
url
:
`/yunshou/aiDevice/updateStatus`
,
method
:
'
get
'
,
params
:
query
})
}
// 新增设备列表
export
function
addDevice
(
data
)
{
return
request
({
url
:
'
/yunshou/aiDevice
'
,
method
:
'
post
'
,
data
:
data
})
}
// 修改设备列表
export
function
updateDevice
(
data
)
{
return
request
({
url
:
'
/yunshou/aiDevice
'
,
method
:
'
put
'
,
data
:
data
})
}
// 删除设备列表
export
function
deleteDevice
(
ids
)
{
return
request
({
url
:
`/yunshou/aiDevice/
${
ids
}
`
,
method
:
'
delete
'
})
}
// 导出设备列表
export
function
exportDevice
(
data
)
{
return
request
({
url
:
`/yunshou/aiDevice/export`
,
method
:
'
post
'
,
data
:
data
})
}
src/views/deviceControl/index.vue
0 → 100644
View file @
cb249d29
<
template
>
<div
class=
"app-container"
>
<TabTitle
:text=
"nowText"
/>
<el-card
class=
"left-list"
>
<el-form
:model=
"queryParams"
ref=
"queryRef"
:inline=
"true"
v-show=
"showSearch"
>
<el-form-item
label=
"设备名称"
prop=
"deviceName"
>
<el-input
v-model=
"queryParams.deviceName"
placeholder=
"请输入设备名称"
clearable
style=
"width: 200px"
@
keyup.enter=
"handleQuery"
/>
</el-form-item>
<el-form-item
label=
"设备是否有效"
prop=
"isEffective"
>
<el-select
v-model=
"queryParams.isEffective"
placeholder=
"请选择是否有效"
clearable
style=
"width: 200px"
>
<el-option
:label=
"'有效'"
:value=
"'0'"
/>
<el-option
:label=
"'无效'"
:value=
"'1'"
/>
</el-select>
</el-form-item>
<el-form-item
label=
"状态"
prop=
"isOpen"
>
<el-select
v-model=
"queryParams.isOpen"
placeholder=
"请选择所属部门"
clearable
style=
"width: 200px"
>
<el-option
:label=
"'运行中'"
:value=
"'0'"
/>
<el-option
:label=
"'已禁用'"
:value=
"'1'"
/>
</el-select>
</el-form-item>
<el-form-item
label=
"创建时间"
>
<el-date-picker
v-model=
"dateRange"
value-format=
"YYYY-MM-DD"
type=
"daterange"
range-separator=
"-"
start-placeholder=
"开始日期"
end-placeholder=
"结束日期"
></el-date-picker>
</el-form-item>
<el-form-item>
<el-button
type=
"primary"
icon=
"Search"
@
click=
"handleQuery"
>
搜索
</el-button>
<el-button
icon=
"Refresh"
@
click=
"resetQuery"
>
重置
</el-button>
</el-form-item>
</el-form>
<el-row
:gutter=
"10"
class=
"mb8"
>
<el-col
:span=
"1.5"
>
<el-button
type=
"primary"
plain
icon=
"Plus"
@
click=
"handleAdd"
>
新增
</el-button>
</el-col>
<!--
<el-col
:span=
"1.5"
>
<el-button
type=
"success"
plain
icon=
"Edit"
:disabled=
"single"
@
click=
"handleUpdate"
v-hasPermi=
"['monitor:job:edit']"
>
修改
</el-button>
</el-col>
<el-col
:span=
"1.5"
>
<el-button
type=
"danger"
plain
icon=
"Delete"
:disabled=
"multiple"
@
click=
"handleDelete"
v-hasPermi=
"['monitor:job:remove']"
>
删除
</el-button>
</el-col>
-->
<!--
<el-col
:span=
"1.5"
>
<el-button
type=
"warning"
plain
icon=
"Download"
@
click=
"handleExport"
v-hasPermi=
"['monitor:job:export']"
>
导入
</el-button>
</el-col>
-->
<right-toolbar
v-model:showSearch=
"showSearch"
@
queryTable=
"getList"
></right-toolbar>
</el-row>
<el-table
v-loading=
"loading"
:data=
"deviceList"
@
selection-change=
"handleSelectionChange"
>
<el-table-column
type=
"selection"
width=
"55"
align=
"center"
/>
<el-table-column
label=
"设备名称"
width=
"100"
align=
"center"
prop=
"deviceName"
/>
<el-table-column
label=
"设备编码"
align=
"center"
prop=
"deviceNo"
:show-overflow-tooltip=
"true"
/>
<el-table-column
label=
"设备视频流地址"
align=
"center"
prop=
"videoUrl"
/>
<el-table-column
label=
"创建人"
align=
"center"
prop=
"createBy"
:show-overflow-tooltip=
"true"
/>
<el-table-column
label=
"创建时间"
align=
"center"
prop=
"createTime"
:show-overflow-tooltip=
"true"
/>
<el-table-column
label=
"设备是否有效"
align=
"center"
prop=
"isEffective"
:show-overflow-tooltip=
"true"
>
<template
#default
="
scope
"
>
<el-tag
:type=
"scope.row.isEffective === '0'?'success' : 'danger'"
effect=
"dark"
>
{{
scope
.
row
.
isEffective
===
'
0
'
?
'
有效
'
:
'
无效
'
}}
</el-tag>
</
template
>
</el-table-column>
<el-table-column
label=
"状态"
align=
"center"
prop=
"isOpen"
:show-overflow-tooltip=
"true"
>
<
template
#default
="
scope
"
>
<el-tag
:type=
"scope.row.isOpen === '0'?'success' : 'danger'"
effect=
"dark"
>
{{
scope
.
row
.
isOpen
===
'
0
'
?
'
运行中
'
:
'
已禁用
'
}}
</el-tag>
</
template
>
</el-table-column>
<el-table-column
label=
"操作"
align=
"center"
width=
"200"
class-name=
"small-padding fixed-width"
>
<
template
#default
="
scope
"
>
<el-tooltip
content=
"禁用"
placement=
"top"
>
<el-button
link
type=
"primary"
icon=
"Edit"
@
click=
"handleUpdate(scope.row)"
v-hasPermi=
"['monitor:job:edit']"
></el-button>
</el-tooltip>
<el-tooltip
content=
"修改"
placement=
"top"
>
<el-button
link
type=
"primary"
icon=
"Edit"
@
click=
"handleUpdate(scope.row)"
v-hasPermi=
"['monitor:job:edit']"
></el-button>
</el-tooltip>
<el-tooltip
content=
"删除"
placement=
"top"
>
<el-button
link
type=
"primary"
icon=
"Delete"
@
click=
"handleDelete(scope.row)"
v-hasPermi=
"['monitor:job:remove']"
></el-button>
</el-tooltip>
</
template
>
</el-table-column>
</el-table>
<pagination
v-show=
"total > 0"
:total=
"total"
v-model:page=
"queryParams.pageNum"
v-model:limit=
"queryParams.pageSize"
@
pagination=
"getList"
/>
</el-card>
<!-- 添加或修改定时任务对话框 -->
<el-dialog
:title=
"title"
v-model=
"open"
width=
"800px"
append-to-body
>
<
template
v-slot:header
>
<div
class=
"cleartitle"
style=
"display: flex;justify-content: flex-start;align-items: center;"
>
<img
src=
"@/assets/images/logo_video.png"
width=
"25px"
alt=
""
>
<span>
{{
title
}}
</span>
</div>
</
template
>
<el-form
ref=
"deviceRef"
:model=
"form"
:rules=
"rules"
label-width=
"120px"
>
<el-row>
<el-col
:span=
"24"
>
<el-form-item
label=
"设备名称"
prop=
"deviceName"
>
<el-input
v-model=
"form.deviceName"
placeholder=
"请输入设备名称"
/>
</el-form-item>
</el-col>
<el-col
:span=
"24"
>
<el-form-item
label=
"设备编码"
prop=
"deviceNo"
>
<el-input
v-model=
"form.deviceNo"
placeholder=
"请输入设备编码"
/>
</el-form-item>
</el-col>
<el-col
:span=
"24"
>
<el-form-item
label=
"视频流类型"
prop=
"videoUrlType"
>
<el-select
v-model=
"form.videoUrlType"
placeholder=
"请选择视频流类型"
clearable
>
<el-option
:label=
"'RTSP类型'"
:value=
"'rtsp'"
/>
</el-select>
</el-form-item>
</el-col>
<el-col
:span=
"24"
>
<el-form-item
label=
"视频流地址"
prop=
"videoUrl"
>
<el-input
v-model=
"form.videoUrl"
placeholder=
"请输入视频流类型"
/>
</el-form-item>
</el-col>
</el-row>
</el-form>
<
template
#footer
>
<div
class=
"dialog-footer"
>
<el-button
type=
"primary"
@
click=
"submitForm"
>
确 定
</el-button>
<el-button
@
click=
"cancel"
>
取 消
</el-button>
</div>
</
template
>
</el-dialog>
</div>
</template>
<
script
setup
name=
"Job"
>
import
{
listDevice
,
deleteDevice
,
addDevice
,
updateDevice
,
detailDevice
}
from
"
@/api/yunshou/device
"
;
const
router
=
useRouter
();
const
{
proxy
}
=
getCurrentInstance
();
const
{
sys_job_group
,
sys_job_status
}
=
proxy
.
useDict
(
"
sys_job_group
"
,
"
sys_job_status
"
);
const
nowText
=
ref
(
"
设备管理
"
);
const
deviceList
=
ref
([]);
const
open
=
ref
(
false
);
const
loading
=
ref
(
true
);
const
showSearch
=
ref
(
true
);
const
ids
=
ref
([]);
const
dateRange
=
ref
([]);
const
single
=
ref
(
true
);
const
multiple
=
ref
(
true
);
const
total
=
ref
(
0
);
const
title
=
ref
(
""
);
const
data
=
reactive
({
form
:
{},
queryParams
:
{
pageNum
:
1
,
pageSize
:
10
,
jobName
:
undefined
,
jobGroup
:
undefined
,
status
:
undefined
},
rules
:
{
deviceName
:
[{
required
:
true
,
message
:
"
设备名称不能为空
"
,
trigger
:
"
blur
"
}],
deviceNo
:
[{
required
:
true
,
message
:
"
设备编码不能为空
"
,
trigger
:
"
blur
"
}],
videoUrl
:
[{
required
:
true
,
message
:
"
视频流地址不能为空
"
,
trigger
:
"
blur
"
}]
}
});
const
{
queryParams
,
form
,
rules
}
=
toRefs
(
data
);
/** 查询定时任务列表 */
function
getList
()
{
loading
.
value
=
true
;
listDevice
(
proxy
.
addDateRange
(
queryParams
.
value
,
dateRange
.
value
)).
then
(
response
=>
{
deviceList
.
value
=
response
.
rows
;
total
.
value
=
response
.
total
;
loading
.
value
=
false
;
});
}
/** 任务组名字典翻译 */
function
jobGroupFormat
(
row
,
column
)
{
return
proxy
.
selectDictLabel
(
sys_job_group
.
value
,
row
.
jobGroup
);
}
/** 取消按钮 */
function
cancel
()
{
open
.
value
=
false
;
reset
();
}
/** 表单重置 */
function
reset
()
{
form
.
value
=
{
videoUrlType
:
'
rtsp
'
,
videoUrl
:
undefined
,
deviceNo
:
undefined
,
deviceName
:
undefined
,
isOpen
:
'
0
'
,
isEffective
:
"
0
"
};
proxy
.
resetForm
(
"
deviceRef
"
);
}
/** 搜索按钮操作 */
function
handleQuery
()
{
queryParams
.
value
.
pageNum
=
1
;
getList
();
}
/** 重置按钮操作 */
function
resetQuery
()
{
proxy
.
resetForm
(
"
queryRef
"
);
handleQuery
();
}
// 多选框选中数据
function
handleSelectionChange
(
selection
)
{
ids
.
value
=
selection
.
map
(
item
=>
item
.
id
);
single
.
value
=
selection
.
length
!=
1
;
multiple
.
value
=
!
selection
.
length
;
}
// 任务状态修改
function
handleStatusChange
(
row
)
{
let
text
=
row
.
status
===
"
0
"
?
"
启用
"
:
"
停用
"
;
proxy
.
$modal
.
confirm
(
'
确认要"
'
+
text
+
'
""
'
+
row
.
jobName
+
'
"任务吗?
'
).
then
(
function
()
{
return
changeJobStatus
(
row
.
id
,
row
.
status
);
}).
then
(()
=>
{
proxy
.
$modal
.
msgSuccess
(
text
+
"
成功
"
);
}).
catch
(
function
()
{
row
.
status
=
row
.
status
===
"
0
"
?
"
1
"
:
"
0
"
;
});
}
/** 新增按钮操作 */
function
handleAdd
()
{
reset
();
open
.
value
=
true
;
title
.
value
=
"
添加设备
"
;
}
/** 修改按钮操作 */
function
handleUpdate
(
row
)
{
reset
();
const
id
=
row
.
id
||
ids
.
value
;
detailDevice
(
id
).
then
(
response
=>
{
form
.
value
=
response
.
data
;
open
.
value
=
true
;
title
.
value
=
"
修改设备
"
;
});
}
/** 提交按钮 */
function
submitForm
()
{
proxy
.
$refs
[
"
deviceRef
"
].
validate
(
valid
=>
{
if
(
valid
)
{
if
(
form
.
value
.
id
!=
undefined
)
{
updateDevice
(
form
.
value
).
then
(
response
=>
{
proxy
.
$modal
.
msgSuccess
(
"
修改成功
"
);
open
.
value
=
false
;
getList
();
});
}
else
{
addDevice
(
form
.
value
).
then
(
response
=>
{
proxy
.
$modal
.
msgSuccess
(
"
新增成功
"
);
open
.
value
=
false
;
getList
();
});
}
}
});
}
/** 删除按钮操作 */
function
handleDelete
(
row
)
{
const
ids
=
row
.
id
||
ids
.
value
;
proxy
.
$modal
.
confirm
(
'
是否确认删除定时任务编号为"
'
+
ids
+
'
"的数据项?
'
).
then
(
function
()
{
return
deleteDevice
(
ids
);
}).
then
(()
=>
{
getList
();
proxy
.
$modal
.
msgSuccess
(
"
删除成功
"
);
}).
catch
(()
=>
{});
}
/** 导出按钮操作 */
function
handleExport
()
{
proxy
.
download
(
"
monitor/job/export
"
,
{
...
queryParams
.
value
,
},
`job_
${
new
Date
().
getTime
()}
.xlsx`
);
}
getList
();
</
script
>
<
style
scoped
lang=
"scss"
>
.left-list
{
min-height
:
700px
;
}
</
style
>
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment