Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Q
qr-consistency-vue3
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
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
刘怀志
qr-consistency-vue3
Commits
baaf9348
Commit
baaf9348
authored
Apr 18, 2025
by
ZhangRunSong
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
feat:预置数据管理
parent
8b19d6d0
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
405 additions
and
0 deletions
+405
-0
preset.js
src/api/control/preset.js
+44
-0
index.vue
src/views/controlPlan/baseConfig/presetData/index.vue
+361
-0
No files found.
src/api/control/preset.js
0 → 100644
View file @
baaf9348
import
request
from
'@/utils/request'
// 查询预置数据列表
export
function
listPreset
(
query
)
{
return
request
({
url
:
'/control/preset/list'
,
method
:
'get'
,
params
:
query
})
}
// 查询预置数据详细
export
function
getPreset
(
id
)
{
return
request
({
url
:
'/control/preset/'
+
id
,
method
:
'get'
})
}
// 新增预置数据
export
function
addPreset
(
data
)
{
return
request
({
url
:
'/control/preset'
,
method
:
'post'
,
data
:
data
})
}
// 修改预置数据
export
function
updatePreset
(
data
)
{
return
request
({
url
:
'/control/preset'
,
method
:
'put'
,
data
:
data
})
}
// 删除预置数据
export
function
delPreset
(
id
)
{
return
request
({
url
:
'/control/preset/'
+
id
,
method
:
'delete'
})
}
src/views/controlPlan/baseConfig/presetData/index.vue
0 → 100644
View file @
baaf9348
<
template
>
<div
class=
"app-container"
>
<el-form
:model=
"queryParams"
ref=
"queryRef"
:inline=
"true"
v-show=
"showSearch"
label-width=
"68px"
>
<el-form-item
label=
"预置数据编号"
prop=
"presetDataCode"
label-width=
"100"
>
<el-input
v-model=
"queryParams.presetDataCode"
placeholder=
"请输入预置数据编号"
clearable
@
keyup
.
enter=
"handleQuery"
style=
"width: 150px;"
/>
</el-form-item>
<el-form-item
label=
"所属模板"
prop=
"relatedTemplateId"
label-width=
"70"
>
<el-input
v-model=
"queryParams.relatedTemplateId"
placeholder=
"请输入所属填写模板"
clearable
@
keyup
.
enter=
"handleQuery"
style=
"width: 150px;"
/>
</el-form-item>
<el-form-item
label=
"所属表单"
prop=
"relatedFormId"
label-width=
"70"
>
<el-input
v-model=
"queryParams.relatedFormId"
placeholder=
"请输入所属表单ID"
clearable
@
keyup
.
enter=
"handleQuery"
style=
"width: 150px;"
/>
</el-form-item>
<el-form-item
label=
"备注"
prop=
"remake"
label-width=
"40"
>
<el-input
v-model=
"queryParams.updateBy"
placeholder=
"请输入备注"
clearable
@
keyup
.
enter=
"handleQuery"
style=
"width: 150px;"
/>
</el-form-item>
<el-form-item
label=
"更新人"
prop=
"updateBy"
label-width=
"60"
>
<el-input
v-model=
"queryParams.updateBy"
placeholder=
"请输入更新人"
clearable
@
keyup
.
enter=
"handleQuery"
style=
"width: 150px;"
/>
</el-form-item>
<el-form-item>
<el-button
class=
"btn-A"
icon=
"Search"
@
click=
"handleQuery"
>
搜索
</el-button>
<el-button
class=
"btn-B"
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"
v-hasPermi=
"['control:preset:add']"
>
新增
</el-button>
</el-col>
<!--
<el-col
:span=
"1.5"
>
<el-button
type=
"success"
plain
icon=
"Edit"
:disabled=
"single"
@
click=
"handleUpdate"
v-hasPermi=
"['control:preset:edit']"
>
修改
</el-button>
</el-col>
<el-col
:span=
"1.5"
>
<el-button
type=
"danger"
plain
icon=
"Delete"
:disabled=
"multiple"
@
click=
"handleDelete"
v-hasPermi=
"['control:preset:remove']"
>
删除
</el-button>
</el-col>
<el-col
:span=
"1.5"
>
<el-button
type=
"warning"
plain
icon=
"Download"
@
click=
"handleExport"
v-hasPermi=
"['control:preset:export']"
>
导出
</el-button>
</el-col>
-->
<right-toolbar
v-model:showSearch=
"showSearch"
@
queryTable=
"getList"
></right-toolbar>
</el-row>
<el-table
v-loading=
"loading"
border
:data=
"presetList"
>
<el-table-column
label=
"序号"
width=
"55"
align=
"center"
prop=
"seq"
/>
<el-table-column
label=
"预置数据编号"
align=
"center"
prop=
"presetDataCode"
/>
<el-table-column
label=
"所属填写模板"
align=
"center"
prop=
"relatedTemplateName"
/>
<el-table-column
label=
"所属表单"
align=
"center"
prop=
"relatedFormName"
/>
<el-table-column
label=
"数据内容"
align=
"center"
prop=
""
/>
<el-table-column
label=
"备注"
align=
"center"
prop=
"remark"
/>
<el-table-column
label=
"更新人"
align=
"center"
prop=
"updateByName"
/>
<el-table-column
label=
"更新时间"
align=
"center"
prop=
"updateTime"
width=
"180"
>
<template
#
default=
"scope"
>
<span>
{{
parseTime
(
scope
.
row
.
updateTime
,
'{y
}
-{m
}
-{d
}
'
)
}}
<
/span
>
<
/template
>
<
/el-table-column
>
<
el
-
table
-
column
label
=
"操作"
align
=
"center"
class
-
name
=
"small-padding fixed-width"
>
<
template
#
default
=
"scope"
>
<
el
-
button
link
type
=
"primary"
@
click
=
""
v
-
hasPermi
=
"['control:preset:edit']"
>
下载
<
/el-button
>
<
el
-
button
link
type
=
"primary"
@
click
=
"handleUpdate(scope.row)"
v
-
hasPermi
=
"['control:preset:edit']"
>
上传更新
<
/el-button
>
<
el
-
button
link
type
=
"primary"
@
click
=
""
v
-
hasPermi
=
"['control:preset:edit']"
>
恢复默认
<
/el-button
>
<!--
<
el
-
button
link
type
=
"primary"
icon
=
"Edit"
@
click
=
"handleUpdate(scope.row)"
v
-
hasPermi
=
"['control:preset:edit']"
>
修改
<
/el-button
>
<
el
-
button
link
type
=
"primary"
icon
=
"Delete"
@
click
=
"handleDelete(scope.row)"
v
-
hasPermi
=
"['control:preset:remove']"
>
删除
<
/el-button>--
>
<
/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
-
drawer
:
title
=
"title"
v
-
model
=
"open"
direction
=
"rtl"
size
=
"30%"
:
before
-
close
=
"cancel"
custom
-
class
=
"demo-drawer"
>
<
el
-
form
ref
=
"presetRef"
:
model
=
"form"
:
rules
=
"rules"
label
-
width
=
"80px"
>
<
el
-
form
-
item
label
=
"所属模板"
prop
=
"relatedTemplateName"
>
<
el
-
input
v
-
model
=
"form.relatedTemplateName"
placeholder
=
"请输入所属填写模板"
/>
<
/el-form-item
>
<
el
-
form
-
item
label
=
"所属表单"
prop
=
"relatedFormName"
>
<
el
-
input
v
-
model
=
"form.relatedFormName"
placeholder
=
"请输入所属表单"
/>
<
/el-form-item
>
<
el
-
form
-
item
label
=
"上传文件"
prop
=
"file"
>
<
el
-
upload
ref
=
"upload"
:
auto
-
upload
=
"false"
:
limit
=
"1"
:
on
-
change
=
"handleFileChange"
:
on
-
remove
=
"handleFileRemove"
>
<
el
-
button
icon
=
""
type
=
"primary"
>
选择文件
<
/el-button
>
<
template
#
tip
>
<
div
class
=
"el-upload__tip"
>
支持
.
zip
/
.
xls
/
.
xlsx
格式,大小不超过
10
MB
<
/div
>
<
/template
>
<
/el-upload
>
<
/el-form-item
>
<
el
-
form
-
item
label
=
"备注"
prop
=
"remark"
>
<
el
-
input
v
-
model
=
"form.remark"
placeholder
=
"请输入所属表单"
/>
<
/el-form-item
>
<
/el-form
>
<
template
#
footer
>
<
div
class
=
"drawer-footer"
>
<
el
-
button
type
=
"primary"
@
click
=
"submitForm"
>
确
定
<
/el-button
>
<
el
-
button
@
click
=
"cancel"
>
取
消
<
/el-button
>
<
/div
>
<
/template
>
<
/el-drawer
>
<
/div
>
<
/template
>
<
script
setup
name
=
"Preset"
>
import
{
listPreset
,
getPreset
,
delPreset
,
addPreset
,
updatePreset
}
from
"@/api/control/preset"
;
const
{
proxy
}
=
getCurrentInstance
();
const
presetList
=
ref
([]);
const
open
=
ref
(
false
);
const
loading
=
ref
(
true
);
const
showSearch
=
ref
(
true
);
const
ids
=
ref
([]);
const
total
=
ref
(
0
);
const
title
=
ref
(
""
);
const
file
=
ref
(
null
);
const
upload
=
ref
(
null
);
const
data
=
reactive
({
form
:
{
}
,
queryParams
:
{
pageNum
:
1
,
pageSize
:
10
,
updateBy
:
null
,
remark
:
null
,
presetDataCode
:
null
,
relatedTemplateId
:
null
,
relatedFormId
:
null
}
,
rules
:
{
relatedTemplateId
:
[
{
required
:
true
,
message
:
"所属填写模板不能为空"
,
trigger
:
"blur"
}
],
relatedFormId
:
[
{
required
:
true
,
message
:
"所属表单不能为空"
,
trigger
:
"blur"
}
]
}
}
);
const
{
queryParams
,
form
,
rules
}
=
toRefs
(
data
);
/** 查询预置数据列表 */
function
getList
()
{
loading
.
value
=
true
;
listPreset
(
queryParams
.
value
).
then
(
response
=>
{
presetList
.
value
=
response
.
rows
;
total
.
value
=
response
.
total
;
loading
.
value
=
false
;
}
);
}
// 取消按钮
function
cancel
()
{
open
.
value
=
false
;
reset
();
}
// 表单重置
function
reset
()
{
form
.
value
=
{
id
:
null
,
createBy
:
null
,
createTime
:
null
,
updateBy
:
null
,
updateTime
:
null
,
remark
:
null
,
delFlag
:
null
,
seq
:
null
,
presetDataCode
:
null
,
relatedTemplateId
:
null
,
relatedFormId
:
null
}
;
proxy
.
resetForm
(
"presetRef"
);
}
/** 搜索按钮操作 */
function
handleQuery
()
{
queryParams
.
value
.
pageNum
=
1
;
getList
();
}
/** 重置按钮操作 */
function
resetQuery
()
{
proxy
.
resetForm
(
"queryRef"
);
handleQuery
();
}
/** 新增按钮操作 */
function
handleAdd
()
{
reset
();
open
.
value
=
true
;
// 仍然通过此变量控制抽屉显示
title
.
value
=
"添加预置数据"
;
}
/** 修改按钮操作 */
function
handleUpdate
(
row
)
{
reset
();
const
_id
=
row
.
id
||
ids
.
value
getPreset
(
_id
).
then
(
response
=>
{
form
.
value
=
response
.
data
;
open
.
value
=
true
;
title
.
value
=
"修改预置数据"
;
}
);
}
/** 提交按钮 */
const
submitForm
=
async
()
=>
{
proxy
.
$refs
[
"presetRef"
].
validate
(
async
(
valid
)
=>
{
if
(
valid
)
{
const
formData
=
new
FormData
();
if
(
file
.
value
)
{
formData
.
append
(
'file'
,
file
.
value
);
}
Object
.
keys
(
form
.
value
).
forEach
(
key
=>
{
formData
.
append
(
key
,
form
.
value
[
key
]);
}
);
try
{
if
(
form
.
value
.
id
)
{
await
updatePreset
(
formData
);
proxy
.
$modal
.
msgSuccess
(
"修改成功"
);
}
else
{
await
addPreset
(
formData
);
proxy
.
$modal
.
msgSuccess
(
"新增成功"
);
}
open
.
value
=
false
;
getList
();
}
catch
(
error
)
{
proxy
.
$modal
.
msgError
(
"操作失败"
);
}
}
}
);
}
;
// 文件状态改变时的回调
const
handleFileChange
=
(
uploadFile
)
=>
{
file
.
value
=
uploadFile
.
raw
;
}
;
// 文件移除时的回调
const
handleFileRemove
=
()
=>
{
file
.
value
=
null
;
}
;
/** 删除按钮操作 */
function
handleDelete
(
row
)
{
const
_ids
=
row
.
id
||
ids
.
value
;
proxy
.
$modal
.
confirm
(
'是否确认删除预置数据编号为"'
+
_ids
+
'"的数据项?'
).
then
(
function
()
{
return
delPreset
(
_ids
);
}
).
then
(()
=>
{
getList
();
proxy
.
$modal
.
msgSuccess
(
"删除成功"
);
}
).
catch
(()
=>
{
}
);
}
/** 导出按钮操作 */
function
handleExport
()
{
proxy
.
download
(
'control/preset/export'
,
{
...
queryParams
.
value
}
,
`preset_${new Date().getTime()
}
.xlsx`
)
}
getList
();
<
/script
>
<
style
scoped
lang
=
"scss"
>
@
import
"@/assets/styles/btn.scss"
;
.
demo
-
drawer
.
el
-
drawer__body
{
height
:
calc
(
100
%
-
60
px
);
overflow
:
auto
;
padding
:
20
px
;
}
/* 底部按钮固定定位 */
.
drawer
-
footer
{
position
:
absolute
;
bottom
:
0
;
width
:
100
%
;
padding
:
16
px
;
background
:
#
fff
;
border
-
top
:
1
px
solid
#
e8e8e8
;
display
:
flex
;
justify
-
content
:
flex
-
end
;
gap
:
10
px
;
}
<
/style>
\ No newline at end of file
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