Skip to content
项目
群组
代码片段
帮助
当前项目
正在载入...
登录 / 注册
切换导航面板
E
exhibition_backstage
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
图表
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
图像
聊天
创建新问题
作业
提交
问题看板
Open sidebar
龙菲
exhibition_backstage
Commits
093303b8
提交
093303b8
authored
9月 29, 2022
作者:
龙菲
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
增加展览和文物新增和编辑时的交互反馈;修复文物列表点击大图失效问题;新增用户的部门为必填项
上级
6b895b56
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
6 个修改的文件
包含
172 行增加
和
69 行删除
+172
-69
ManualUploader.vue
src/components/Uploader/ManualUploader.vue
+105
-7
InfoEditDialog.vue
src/views/culturalRelic/components/InfoEditDialog.vue
+0
-0
index.vue
src/views/culturalRelic/index.vue
+15
-4
InfoEditDialog.vue
src/views/display/components/InfoEditDialog.vue
+0
-0
index.vue
src/views/display/index.vue
+1
-1
InfoEditDialog.vue
src/views/user/components/InfoEditDialog.vue
+51
-57
没有找到文件。
src/components/Uploader/ManualUploader.vue
浏览文件 @
093303b8
<
template
>
<
template
>
<div
class=
"images-list"
>
<div
class=
"images-list"
>
<el-upload
<el-upload
action=
"#"
action=
"#"
:on-remove=
"handleRemove"
:on-remove=
"handleRemove"
...
@@ -13,6 +13,7 @@
...
@@ -13,6 +13,7 @@
:accept=
"fileAccept"
:accept=
"fileAccept"
:auto-upload=
"false"
:auto-upload=
"false"
ref=
"ManualUploader"
ref=
"ManualUploader"
:class=
"
{ disabled: uploadDisabled }"
>
>
<i
<i
v-if=
"listType === 'picture-card'"
v-if=
"listType === 'picture-card'"
...
@@ -22,6 +23,7 @@
...
@@ -22,6 +23,7 @@
<el-button
v-else
size=
"small"
type=
"primary"
>
点击上传
</el-button>
<el-button
v-else
size=
"small"
type=
"primary"
>
点击上传
</el-button>
<div
v-if=
"showTip"
slot=
"tip"
class=
"el-upload__tip"
>
<div
v-if=
"showTip"
slot=
"tip"
class=
"el-upload__tip"
>
<div
v-if=
"advice"
style=
"color: #f56c6c"
>
建议:
{{
advice
}}
</div>
提示:只能上传
{{
fileTypeName
||
"jpg/png"
}}
文件,且不超过
提示:只能上传
{{
fileTypeName
||
"jpg/png"
}}
文件,且不超过
{{
fileSize
}}
MB,最多上传
{{
fileLimit
}}
个文件
{{
fileSize
}}
MB,最多上传
{{
fileLimit
}}
个文件
</div>
</div>
...
@@ -65,6 +67,10 @@ export default {
...
@@ -65,6 +67,10 @@ export default {
type
:
Number
,
type
:
Number
,
default
:
99
,
default
:
99
,
},
},
//建议
advice
:
{
type
:
String
,
},
},
},
data
()
{
data
()
{
return
{
return
{
...
@@ -74,7 +80,20 @@ export default {
...
@@ -74,7 +80,20 @@ export default {
watch
:
{
watch
:
{
files
:
{
files
:
{
handler
:
function
(
val
)
{
handler
:
function
(
val
)
{
this
.
fileList
=
JSON
.
parse
(
JSON
.
stringify
(
val
));
// this.fileList = JSON.parse(JSON.stringify(val));
// 将回填的字段从url-->pressUrl
if
(
val
.
length
>
0
)
{
this
.
fileList
=
val
.
map
((
item
)
=>
{
return
{
highImg
:
item
.
url
,
lowImg
:
item
.
pressUrl
,
url
:
item
.
pressUrl
,
// pressUrl:item.pressUrl,
name
:
item
.
name
,
fileId
:
item
.
fileId
,
};
});
}
},
},
immediate
:
true
,
immediate
:
true
,
deep
:
true
,
deep
:
true
,
...
@@ -88,6 +107,9 @@ export default {
...
@@ -88,6 +107,9 @@ export default {
immediate
:
true
,
immediate
:
true
,
deep
:
true
,
deep
:
true
,
},
},
advice
(
value
)
{
console
.
log
(
value
);
},
},
},
computed
:
{
computed
:
{
// 是否显示提示
// 是否显示提示
...
@@ -108,10 +130,36 @@ export default {
...
@@ -108,10 +130,36 @@ export default {
});
});
return
fileAccept
;
return
fileAccept
;
},
},
uploadDisabled
()
{
return
this
.
fileList
.
length
==
this
.
fileLimit
;
},
},
},
methods
:
{
methods
:
{
getFiles
()
{
getFiles
()
{
return
this
.
fileList
;
if
(
this
.
fileType
==
"jpg"
||
this
.
fileType
==
"png"
||
this
.
fileType
==
"jpeg"
)
{
let
newFileList
=
this
.
fileList
.
map
((
item
)
=>
{
// return {
// // highImg: item.url,
// // lowImg: item.pressUrl,
// url: item.highImg,
// pressUrl: item.lowImg,
// name: item.name,
// fileId: item.fileId,
// };
item
.
url
=
item
.
highImg
;
item
.
pressUrl
=
item
.
lowImg
;
item
.
name
=
item
.
name
;
item
.
fileId
=
item
.
fileId
;
return
item
;
});
return
newFileList
;
}
else
{
return
this
.
fileList
;
}
},
},
// 上传前校检格式和大小
// 上传前校检格式和大小
handleBeforeUpload
(
file
)
{
handleBeforeUpload
(
file
)
{
...
@@ -161,22 +209,72 @@ export default {
...
@@ -161,22 +209,72 @@ export default {
handleRemove
(
file
,
fileList
)
{
handleRemove
(
file
,
fileList
)
{
// debugger
// debugger
// console.log("handleRemove", file, fileList);
// console.log("handleRemove", file, fileList);
this
.
fileList
.
map
(
async
(
item
,
index
)
=>
{
let
that
=
this
;
that
.
fileList
.
map
(
async
(
item
,
index
)
=>
{
if
(
item
.
uid
===
file
.
uid
)
{
if
(
item
.
uid
===
file
.
uid
)
{
th
is
.
fileList
.
splice
(
index
,
1
);
th
at
.
fileList
.
splice
(
index
,
1
);
}
}
});
});
this
.
$emit
(
"input"
,
this
.
fileList
);
if
(
that
.
fileType
==
"jpg"
||
that
.
fileType
==
"png"
||
that
.
fileType
==
"jpeg"
)
{
let
newFileList
=
that
.
fileList
.
map
((
item
)
=>
{
item
.
url
=
item
.
highImg
;
item
.
pressUrl
=
item
.
lowImg
;
item
.
name
=
item
.
name
;
item
.
fileId
=
item
.
fileId
;
return
item
;
// return {
// // highImg: item.url,
// // lowImg: item.pressUrl,
// url: item.highImg,
// pressUrl: item.lowImg,
// name: item.name,
// fileId: item.fileId,
// };
});
that
.
$emit
(
"input"
,
newFileList
);
}
else
{
that
.
$emit
(
"input"
,
that
.
fileList
);
}
},
},
handleChange
(
file
,
fileList
)
{
handleChange
(
file
,
fileList
)
{
let
that
=
this
;
let
that
=
this
;
// console.log("handleChange", file, fileList);
// console.log("handleChange", file, fileList);
if
(
fileList
.
length
==
this
.
fileLimit
)
{
this
.
maxNum
=
this
.
fileLimit
;
}
if
(
file
.
status
===
"ready"
)
{
if
(
file
.
status
===
"ready"
)
{
this
.
handleBeforeUpload
(
file
)
this
.
handleBeforeUpload
(
file
)
.
then
((
res
)
=>
{
.
then
((
res
)
=>
{
that
.
fileList
.
push
(
res
);
that
.
fileList
.
push
(
res
);
that
.
$emit
(
"input"
,
that
.
fileList
);
if
(
that
.
fileType
==
"jpg"
||
that
.
fileType
==
"png"
||
that
.
fileType
==
"jpeg"
)
{
let
newFileList
=
that
.
fileList
.
map
((
item
)
=>
{
item
.
url
=
item
.
highImg
;
item
.
pressUrl
=
item
.
lowImg
;
item
.
name
=
item
.
name
;
item
.
fileId
=
item
.
fileId
;
return
item
;
// return {
// // highImg: item.url,
// // lowImg: item.pressUrl,
// url: item.highImg,
// pressUrl: item.lowImg,
// name: item.name,
// fileId: item.fileId,
// };
});
that
.
$emit
(
"input"
,
newFileList
);
}
else
{
that
.
$emit
(
"input"
,
that
.
fileList
);
}
})
})
.
catch
((
err
)
=>
{
.
catch
((
err
)
=>
{
console
.
log
(
"err"
,
err
);
console
.
log
(
"err"
,
err
);
...
...
src/views/culturalRelic/components/InfoEditDialog.vue
浏览文件 @
093303b8
差异被折叠。
点击展开。
src/views/culturalRelic/index.vue
浏览文件 @
093303b8
...
@@ -54,7 +54,6 @@
...
@@ -54,7 +54,6 @@
:data=
"list.records"
:data=
"list.records"
:tableTitle=
"tableTitle"
:tableTitle=
"tableTitle"
:operates=
"tableOperates"
:operates=
"tableOperates"
:height=
"tableHeight"
>
>
<template
v-slot:status=
"data"
>
<template
v-slot:status=
"data"
>
<el-popconfirm
<el-popconfirm
...
@@ -69,9 +68,13 @@
...
@@ -69,9 +68,13 @@
</
template
>
</
template
>
<
template
v-slot:faceImageUrl=
"data"
>
<
template
v-slot:faceImageUrl=
"data"
>
<img
<img
:src=
"data.scope.faceImagePressUrl || data.scope.faceImageUrl"
:src=
"
$getFullUrl(data.scope.faceImagePressUrl || data.scope.faceImageUrl)
"
alt=
"查看大图"
alt=
"查看大图"
v-if=
"data.scope.faceImagePressUrl || data.scope.faceImageUrl"
v-if=
"
$getFullUrl(data.scope.faceImagePressUrl || data.scope.faceImageUrl)
"
style=
"cursor: pointer"
style=
"cursor: pointer"
width=
"100px"
width=
"100px"
@
click=
"handelPreviewImages(data.scope.faceImageUrl)"
@
click=
"handelPreviewImages(data.scope.faceImageUrl)"
...
@@ -125,6 +128,12 @@
...
@@ -125,6 +128,12 @@
:visible=
"importRecordVisible"
:visible=
"importRecordVisible"
@
handleClose=
"handleImportRecordClose"
@
handleClose=
"handleImportRecordClose"
/>
/>
<el-image-viewer
v-if=
"imgViewerVisible"
:on-close=
"closeImgViewer"
:url-list=
"imgList"
/>
</div>
</div>
</template>
</template>
...
@@ -153,10 +162,11 @@ export default {
...
@@ -153,10 +162,11 @@ export default {
SearchBar
,
SearchBar
,
ImportRecordDialog
,
ImportRecordDialog
,
UploadListDialog
,
UploadListDialog
,
"el-image-viewer"
:
()
=>
import
(
"element-ui/packages/image/src/image-viewer"
),
},
},
data
()
{
data
()
{
return
{
return
{
tableHeight
:
400
,
list
:
{
list
:
{
records
:
[],
records
:
[],
size
:
10
,
size
:
10
,
...
@@ -465,6 +475,7 @@ export default {
...
@@ -465,6 +475,7 @@ export default {
},
},
// 预览图片
// 预览图片
handelPreviewImages
(
images
)
{
handelPreviewImages
(
images
)
{
// debugger
this
.
imgViewerVisible
=
true
;
this
.
imgViewerVisible
=
true
;
this
.
imgList
=
[
images
];
this
.
imgList
=
[
images
];
},
},
...
...
src/views/display/components/InfoEditDialog.vue
浏览文件 @
093303b8
差异被折叠。
点击展开。
src/views/display/index.vue
浏览文件 @
093303b8
...
@@ -324,7 +324,7 @@ export default {
...
@@ -324,7 +324,7 @@ export default {
// 预览图片
// 预览图片
handelPreviewImages
(
images
)
{
handelPreviewImages
(
images
)
{
this
.
imgViewerVisible
=
true
;
this
.
imgViewerVisible
=
true
;
this
.
imgList
=
[
images
];
this
.
imgList
=
[
images
];
},
},
handleClosePreviewDialog
()
{
handleClosePreviewDialog
()
{
...
...
src/views/user/components/InfoEditDialog.vue
浏览文件 @
093303b8
...
@@ -12,8 +12,12 @@
...
@@ -12,8 +12,12 @@
<div
class=
"label"
>
{{
title
}}
</div>
<div
class=
"label"
>
{{
title
}}
</div>
</div>
</div>
<div
class=
"dialog-content"
>
<div
class=
"dialog-content"
>
<el-form
:model=
"dialogForm"
class=
"basic-info"
>
<el-form
:model=
"dialogForm"
class=
"basic-info"
:rules=
"rules"
ref=
"form"
>
<el-form-item
label=
"账号"
:label-width=
"formLabelWidth"
>
<el-form-item
label=
"账号"
:label-width=
"formLabelWidth"
prop=
"username"
>
<el-input
<el-input
v-model=
"dialogForm.username"
v-model=
"dialogForm.username"
autocomplete=
"off"
autocomplete=
"off"
...
@@ -21,10 +25,15 @@
...
@@ -21,10 +25,15 @@
clearable
clearable
></el-input>
></el-input>
</el-form-item>
</el-form-item>
<el-form-item
label=
"密码"
:label-width=
"formLabelWidth"
>
<el-form-item
label=
"密码"
:label-width=
"formLabelWidth"
prop=
"password"
>
<el-input
<el-input
v-model=
"dialogForm.password"
v-model=
"dialogForm.password"
autocomplete=
"off"
autocomplete=
"off"
show-password
type=
"password"
type=
"password"
placeholder=
"请输入密码"
placeholder=
"请输入密码"
clearable
clearable
...
@@ -54,13 +63,18 @@
...
@@ -54,13 +63,18 @@
clearable
clearable
></el-input>
></el-input>
</el-form-item>
</el-form-item>
<el-form-item
label=
"所属部门"
:label-width=
"formLabelWidth"
>
<el-form-item
label=
"所属部门"
:label-width=
"formLabelWidth"
prop=
"deptId"
>
<el-cascader
<el-cascader
style=
"width: 100%"
style=
"width: 100%"
v-model=
"dialogForm.deptId"
v-model=
"dialogForm.deptId"
:options=
"orgTreeData"
:options=
"orgTreeData"
:props=
"optionProps"
:props=
"optionProps"
placeholder=
"请选择所属部门"
placeholder=
"请选择所属部门"
clearable
>
>
</el-cascader>
</el-cascader>
</el-form-item>
</el-form-item>
...
@@ -135,9 +149,6 @@ export default {
...
@@ -135,9 +149,6 @@ export default {
deep
:
true
,
deep
:
true
,
immediate
:
true
,
immediate
:
true
,
},
},
// orgTreeData(value){
// console.log(1111,value);
// }
},
},
data
()
{
data
()
{
var
validatePass
=
(
rule
,
value
,
callback
)
=>
{
var
validatePass
=
(
rule
,
value
,
callback
)
=>
{
...
@@ -165,19 +176,7 @@ export default {
...
@@ -165,19 +176,7 @@ export default {
if
(
!
pattern
.
test
(
value
))
{
if
(
!
pattern
.
test
(
value
))
{
callback
(
new
Error
(
"账号长度4-20个字符,只能包括字母、数字、下划线"
));
callback
(
new
Error
(
"账号长度4-20个字符,只能包括字母、数字、下划线"
));
}
else
{
}
else
{
const
formData
=
new
FormData
();
callback
();
formData
.
append
(
"userName"
,
value
);
checkUserName
(
formData
)
.
then
((
res
)
=>
{
if
(
res
.
code
==
"0"
)
{
callback
();
}
else
{
callback
(
res
.
msg
);
}
})
.
catch
((
err
)
=>
{
console
.
error
(
err
);
});
}
}
}
}
};
};
...
@@ -190,20 +189,7 @@ export default {
...
@@ -190,20 +189,7 @@ export default {
if
(
!
pattern
.
test
(
value
))
{
if
(
!
pattern
.
test
(
value
))
{
callback
(
new
Error
(
"请输入合法手机号/电话号"
));
callback
(
new
Error
(
"请输入合法手机号/电话号"
));
}
else
{
}
else
{
const
formData
=
new
FormData
();
callback
();
formData
.
append
(
"phone"
,
value
);
checkPhone
(
formData
)
.
then
((
res
)
=>
{
console
.
log
(
res
);
if
(
res
.
code
==
"0"
)
{
callback
();
}
else
{
callback
(
res
.
msg
);
}
})
.
catch
((
err
)
=>
{
console
.
error
(
err
);
});
}
}
}
}
};
};
...
@@ -223,7 +209,7 @@ export default {
...
@@ -223,7 +209,7 @@ export default {
username
:
[
username
:
[
{
validator
:
validateUserName
,
trigger
:
"blur"
,
required
:
true
},
{
validator
:
validateUserName
,
trigger
:
"blur"
,
required
:
true
},
],
],
phone
:
[{
validator
:
validatePhone
,
trigger
:
"blur"
,
required
:
true
}],
//
phone: [{ validator: validatePhone, trigger: "blur", required: true }],
nickName
:
[
nickName
:
[
{
required
:
true
,
message
:
"请输入昵称"
,
trigger
:
"blur"
},
{
required
:
true
,
message
:
"请输入昵称"
,
trigger
:
"blur"
},
{
{
...
@@ -236,6 +222,7 @@ export default {
...
@@ -236,6 +222,7 @@ export default {
password
:
[
password
:
[
{
validator
:
validatePass
,
trigger
:
"blur"
,
required
:
true
},
{
validator
:
validatePass
,
trigger
:
"blur"
,
required
:
true
},
],
],
deptId
:
[{
required
:
true
,
message
:
"请输入部门"
,
trigger
:
"change"
}],
},
},
};
};
},
},
...
@@ -243,41 +230,48 @@ export default {
...
@@ -243,41 +230,48 @@ export default {
// 取消编辑
// 取消编辑
cancelForm
()
{
cancelForm
()
{
this
.
$emit
(
"handleClose"
);
this
.
$emit
(
"handleClose"
);
this
.
faceImage
=
[];
this
.
$refs
.
form
.
resetFields
();
//对表单进行重置且移除校验结果
},
},
async
handleSubmit
()
{
handleSubmit
()
{
let
params
=
JSON
.
parse
(
JSON
.
stringify
(
this
.
dialogForm
));
this
.
$refs
.
form
.
validate
(
async
(
valid
)
=>
{
// 修改状态
if
(
valid
)
{
params
.
status
=
this
.
status
?
1
:
0
;
let
params
=
JSON
.
parse
(
JSON
.
stringify
(
this
.
dialogForm
));
// return;
// 修改状态
// 处理馆藏单位
params
.
status
=
this
.
status
?
1
:
0
;
if
(
params
.
deptId
instanceof
Array
)
{
// 处理馆藏单位
params
.
deptId
=
params
.
deptId
[
params
.
deptId
.
length
-
1
];
if
(
params
.
deptId
instanceof
Array
)
{
}
params
.
deptId
=
params
.
deptId
[
params
.
deptId
.
length
-
1
];
if
(
params
.
id
)
{
}
let
res
=
await
upadateUser
(
params
);
// debugger
if
(
res
.
code
==
0
)
{
// return;
this
.
$message
.
success
(
"修改成功!"
);
if
(
params
.
id
)
{
this
.
reload
();
let
res
=
await
upadateUser
(
params
);
if
(
res
.
code
==
0
)
{
this
.
$message
.
success
(
"修改成功!"
);
this
.
reload
();
}
}
else
{
let
res
=
await
addUser
(
params
);
if
(
res
.
code
==
0
)
{
this
.
$message
.
success
(
"添加成功!"
);
this
.
reload
();
}
}
}
}
}
else
{
});
let
res
=
await
addUser
(
params
);
if
(
res
.
code
==
0
)
{
this
.
$message
.
success
(
"添加成功!"
);
this
.
reload
();
}
}
},
},
reload
()
{
reload
()
{
this
.
$emit
(
"refresh"
);
this
.
$emit
(
"refresh"
);
this
.
$emit
(
"handleClose"
);
this
.
$emit
(
"handleClose"
);
this
.
$refs
.
form
.
resetFields
();
//对表单进行重置且移除校验结果
},
},
handleClose
(
done
)
{
handleClose
(
done
)
{
this
.
$confirm
(
"确认关闭?"
)
this
.
$confirm
(
"确认关闭?"
)
.
then
((
_
)
=>
{
.
then
((
_
)
=>
{
done
();
done
();
this
.
$emit
(
"handleClose"
);
this
.
$emit
(
"handleClose"
);
this
.
$refs
.
form
.
resetFields
();
//对表单进行重置且移除校验结果
})
})
.
catch
((
_
)
=>
{});
.
catch
((
_
)
=>
{});
},
},
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论