You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

575 lines
23 KiB

<template>
<div class="container">
2 months ago
<!-- 顶部信息 -->
<div class="containertop">
<div class="topleft">
2 months ago
<img src="../../../assets/images/detailsicon/1.png" alt="">
<span>基本信息</span>
</div>
2 weeks ago
<div class="topright" v-if="action === 'fill' || !action || action === 'okay'">
<el-button type="primary" size="medium" plain v-if="action === 'fill' || !action || action === 'okay'"
1 month ago
style="border: none;background-color: rgba(43,98,241,0.1);color: #2B62F1;" @click="edit">
<img src="../../../assets/images/detailsicon/icon-bj@2x.png" alt="编辑"
style="width: 0.6rem; height: 0.6rem; margin-right: 4px;">
编辑
1 month ago
</el-button>
2 weeks ago
<el-button type="primary" size="medium" plain v-if="checkRole(['admin', 'common'])"
1 month ago
style="border: none;background-color: rgba(43,98,241,0.1);color: #2B62F1;" @click="handleExport">
<img src="../../../assets/images/detailsicon/icon-dc@2x.png" alt="编辑"
style="width: 0.6rem; height: 0.6rem; margin-right: 4px;">
导出
3 weeks ago
</el-button>
2 months ago
</div>
</div>
1 month ago
<!-- 内容展示区 -->
2 months ago
<div class="content">
<div class="picturediv">
4 weeks ago
<!-- 图片展示 -->
3 weeks ago
<img v-if="basicInfo.fj" :src="baseUrl + basicInfo.fj" alt="项目代表性照片">
</div>
2 months ago
<div class="descriptionsdiv">
<el-descriptions class="margin-top" :column="3" border>
1 month ago
<el-descriptions-item v-for="(item, index) in descriptions" :key="index"
3 weeks ago
:span="item.label === '项目法人单位简介' || item.label === '统一信用代码' ? 3 : 1">
2 months ago
<template slot="label">
1 month ago
{{ item.label }}
2 months ago
</template>
{{ item.value }}
2 months ago
</el-descriptions-item>
</el-descriptions>
</div>
</div>
<!-- 添加或编辑项目对话框 -->
1 month ago
<el-dialog :title="title" :visible.sync="dialogVisible" width="70rem" append-to-body>
<el-form :model="form" :rules="rules" ref="form" label-width="180px">
<el-row>
<el-col :span="12">
1 month ago
<el-form-item label="项目名称" prop="name">
<el-input v-model="form.name" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
<el-col :span="12">
1 month ago
<el-form-item label="建设地点" prop="jsdd">
<el-row :gutter="10">
<el-col :span="20">
<el-input v-model="form.jsdd" maxlength="50"></el-input>
</el-col>
<el-col :span="3">
<span @click="showMap" style="color: #2B62F1;cursor: pointer;">落图</span>
</el-col>
</el-row>
1 month ago
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
1 month ago
<el-form-item label="项目法人单位" prop="xmfrdwxz">
<el-input v-model="form.xmfrdwxz" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
<el-col :span="12">
1 month ago
<el-form-item label="重点发展产业" prop="prioritize">
<el-input v-model="form.prioritize" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
1 month ago
<el-form-item label="项目法人单位性质" prop="nature">
1 month ago
<el-select v-model="form.nature" placeholder="请选择" value-key="value"
style="width: 22.5rem;">
<el-option v-for="dict in dict.type.xmfrdwxz" :key="dict.value" :label="dict.label"
:value="parseInt(dict.value)" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
1 month ago
<el-form-item label="建设模式" prop="jsms">
1 month ago
<el-select v-model="form.jsms" placeholder="请选择" value-key="value" style="width: 22.5rem;">
<el-option v-for="dict in dict.type.jsms" :key="dict.value" :label="dict.label"
:value="parseInt(dict.value)" />
</el-select>
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
1 month ago
<el-form-item label="施工单位" prop="sgdw">
<el-input v-model="form.sgdw" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
<el-col :span="12">
1 month ago
<el-form-item label="项目标签" prop="label">
<el-input v-model="form.label" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
1 month ago
<el-form-item label="设计单位" prop="sjdw">
<el-input v-model="form.sjdw" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
<el-col :span="12">
1 month ago
<el-form-item label="项目负责人" prop="projectLeader">
<el-input v-model="form.projectLeader" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
1 month ago
<el-form-item label="总投资额(万元)" prop="ztze">
<el-input v-model.number="form.ztze" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
<el-col :span="12">
1 month ago
<el-form-item label="联系方式" prop="phone">
<el-input v-model="form.phone" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
1 month ago
<el-form-item label="所属功能区" prop="ssgnq">
1 month ago
<el-select v-model="form.ssgnq" placeholder="请选择" value-key="value" style="width: 22.5rem;">
<el-option v-for="dict in dict.type.ssgnq" :key="dict.value" :label="dict.label"
:value="parseInt(dict.value)" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
1 month ago
<el-form-item label="施工许可证发放时间" prop="issuingTime">
<el-input v-model="form.issuingTime" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
3 weeks ago
<el-form-item label="建设起止时间">
<el-date-picker v-model="form.begainTime" type="date" placeholder="开始日期"
style="width: 11rem;"></el-date-picker>
~
<el-date-picker v-model="form.endTime" type="date" placeholder="结束日期"
style="width: 10.5rem;"></el-date-picker>
1 month ago
</el-form-item>
</el-col>
<el-col :span="12">
1 month ago
<el-form-item label="竣工验收时间" prop="acceptanceTime">
<el-input v-model="form.acceptanceTime" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
</el-row>
<el-row>
<el-col :span="12">
1 month ago
<el-form-item label="现状分类" prop="xzfl">
1 month ago
<el-select v-model="form.xzfl" placeholder="请选择" value-key="value" style="width: 22.5rem;">
<el-option v-for="dict in dict.type.xzfl" :key="dict.value" :label="dict.label"
:value="parseInt(dict.value)" />
</el-select>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="建设进度" prop="jsjd">
<el-input v-model="form.jsjd" maxlength="50"></el-input>
1 month ago
</el-form-item>
</el-col>
</el-row>
3 weeks ago
<el-row>
<el-col :span="12">
<el-form-item label="统一社会信用代码" prop="tyshxydm">
<el-input v-model="form.tyshxydm" maxlength="50"></el-input>
</el-form-item>
</el-col>
</el-row>
2 weeks ago
<el-row>
<el-col :span="12">
<el-form-item label="经度" prop="tyshxydm">
<el-input v-model="form.tyshxydm" maxlength="50"></el-input>
</el-form-item>
</el-col>
<el-col :span="12">
<el-form-item label="纬度" prop="tyshxydm">
<el-input v-model="form.tyshxydm" maxlength="50"></el-input>
</el-form-item>
</el-col>
</el-row>
1 month ago
<el-form-item label="项目法人单位简介" prop="unitIntroduction">
<el-input v-model="form.unitIntroduction" type="textarea" rows="4" maxlength="1000"></el-input>
1 month ago
</el-form-item>
1 month ago
<el-form-item label="项目简介" prop="introduction">
<el-input v-model="form.introduction" type="textarea" rows="4" maxlength="1000"></el-input>
1 month ago
</el-form-item>
<el-form-item label="项目代表性照片">
<ImageUpload v-model="form.fj" />
</el-form-item>
</el-form>
<span slot="footer" class="dialog-footer">
<el-button @click="dialogVisible = false"> </el-button>
<el-button type="primary" @click="saveForm"> </el-button>
</span>
</el-dialog>
<!-- 地图弹窗 -->
4 weeks ago
<el-dialog :title="mapDialogTitle" :visible.sync="mapDialogVisible" width="1000px" height="1000px"
style="height: 1000;" append-to-body>
<luotu v-if="mapDialogVisible" />
</el-dialog>
</div>
</template>
1 month ago
<script>
1 month ago
import ImageUpload from '@/components/ImageUpload2/index.vue';
4 weeks ago
import luotu from '@/views/components/ProjectDetails/luotu.vue'
2 weeks ago
import { checkPermi, checkRole } from "@/utils/permission";
export default {
1 month ago
components: {
ImageUpload, luotu
1 month ago
},
dicts: [
1 month ago
'ssgnq', 'xmfrdwxz', 'xzfl', 'jsms'
],
props: {
size: {
type: String,
1 month ago
default: ''
},
4 weeks ago
basicInfo: {
type: Object,
required: true
4 weeks ago
},
3 weeks ago
action: {
4 weeks ago
type: String,
required: true
}
},
data() {
return {
3 weeks ago
baseUrl: process.env.VUE_APP_BASE_API,
descriptions: [],
dialogImageUrl: '',
dialogVisibletwo: false,
dialogVisible: false,
4 weeks ago
mapDialogVisible: false,
mapDialogTitle: '地图',
title: '编辑基本信息',
form: {
name: '',
xmfrdwxz: '',
nature: 0,
sgdw: '',
sjdw: '',
ztze: 0,
4 weeks ago
id: 0,
1 month ago
ssgnq: 0,
begainTime: '',
endtime: '',
xzfl: 0,
jsdd: '',
prioritize: '',
jsms: 0,
label: '',
projectLeader: '',
phone: '',
issuingTime: '',
acceptanceTime: '',
unitIntroduction: '',
introduction: '',
fj: '',
4 weeks ago
jsjd: '',
},
rules: {
3 weeks ago
name: [
{ required: true, message: '项目名称不能为空', trigger: 'blur' },
],
xmfrdwxz: [
{ required: true, message: '项目法人单位不能为空', trigger: 'blur' },
],
nature: [
{ required: true, message: '项目法人单位性质不能为空', trigger: 'change' }
],
ztze: [
{ required: true, message: '总投资额不能为空', trigger: 'blur' },
{ type: 'number', message: '总投资额必须是数字', trigger: 'blur' },
],
ssgnq: [
{ required: true, message: '所属功能区不能为空', trigger: 'change' }
],
begainTime: [
{ required: true, message: '建设起始时间不能为空', trigger: 'change' }
],
endTime: [
{ required: true, message: '建设结束时间不能为空', trigger: 'change' }
],
xzfl: [
{ required: true, message: '现状分类不能为空', trigger: 'change' }
],
jsms: [
{ required: true, message: '建设模式不能为空', trigger: 'change' }
],
projectLeader: [
{ required: true, message: '项目负责人不能为空', trigger: 'blur' },
],
phone: [
{ required: true, message: '联系方式不能为空', trigger: 'blur' },
{ pattern: /^[\d-]+$/, message: '联系方式只能包含数字和连字符', trigger: 'blur' },
],
unitIntroduction: [
{ max: 1000, message: '项目法人单位简介长度不能超过1000个字', trigger: 'blur' }
],
introduction: [
{ max: 1000, message: '项目简介长度不能超过1000个字', trigger: 'blur' }
]
1 month ago
},
// select映射
ssgnqMap: {
1: '高端制造与国际贸易区',
3 weeks ago
2: '独墅湖科教创新区',
3: '阳澄湖半岛旅游度假区',
4: '金鸡湖商务区',
5: '苏相合作区'
1 month ago
},
xmfrdwxzMap: {
1: '国企',
2: '外资企业',
3: '民营企业',
4: '其他'
},
jsmsMap: {
1: '工地实施',
2: '利用存量用地改扩建',
},
xzflMap: {
1: '已建',
3 weeks ago
2: '在建',
1 month ago
3: '拟建',
}
};
},
4 weeks ago
watch: {
basicInfo: {
handler(newVal) {
this.descriptions = this.formatDescriptions(newVal);
this.form = {
...newVal,
3 weeks ago
begainTime: newVal.begainTime ? new Date(newVal.begainTime) : '',
endTime: newVal.endTime ? new Date(newVal.endTime) : '',
4 weeks ago
};
},
immediate: true,
deep: true
}
},
methods: {
2 weeks ago
checkPermi,
checkRole,
/** 导出按钮操作 */
handleExport() {
2 weeks ago
this.download('/gysl/basicInformation/export', {
xmid: this.basicInfo.id
}, `基本信息导出${new Date().getTime()}.xlsx`)
},
// 格式化描述信息
formatDescriptions(data) {
return [
{ label: '项目名称', value: data.name },
{ label: '项目法人单位', value: data.xmfrdwxz },
3 weeks ago
{ label: '项目法人单位性质', value: this.xmfrdwxzMap[data.nature] || '' },
{ label: '施工单位', value: data.sgdw },
{ label: '设计单位', value: data.sjdw },
{ label: '总投资额(万元)', value: data.ztze },
3 weeks ago
{ label: '所属功能区', value: this.ssgnqMap[data.ssgnq] || '' },
{
label: '建设起止时间',
value: `${data.begainTime ? data.begainTime : ''}${data.endTime ? data.endTime : ''}`
},
{ label: '现状分类', value: this.xzflMap[data.xzfl] || '' },
{ label: '建设地点', value: data.jsdd },
{ label: '重点发展产业', value: data.prioritize },
3 weeks ago
{ label: '建设模式', value: this.jsmsMap[data.jsms] || '' },
{ label: '项目标签', value: data.label },
{ label: '项目负责人', value: data.projectLeader },
{ label: '联系方式', value: data.phone },
{ label: '施工许可证发放时间', value: data.issuingTime },
{ label: '竣工验收时间', value: data.acceptanceTime },
{ label: '建设进度', value: data.jsjd },
3 weeks ago
{ label: '统一信用代码', value: data.tyshxydm },
{ label: '项目法人单位简介', value: data.unitIntroduction },
{ label: '项目简介', value: data.introduction }
];
},
// 打开编辑对话框
edit() {
this.dialogVisible = true;
},
// 保存表单
saveForm() {
4 weeks ago
if (this.validateForm()) {
const formData = this.prepareFormData(this.form);
// 触发事件,将数据传递给父组件
this.$emit('update-data', formData);
this.dialogVisible = false;
}
},
// 手动验证表单
validateForm() {
for (const field in this.rules) {
const rules = this.rules[field];
const value = this.form[field];
for (const rule of rules) {
if (rule.required && !value) {
this.$message.error(rule.message);
return false;
}
}
}
return true;
},
// 准备表单数据
3 weeks ago
// 准备表单数据
4 weeks ago
prepareFormData(formData) {
3 weeks ago
// 格式化日期字段
const formatDate = (date) => {
if (!date) return '';
// 如果是 Date 对象,直接格式化;如果是字符串,保持原样
return date instanceof Date ? date.toISOString().split('T')[0] : date;
};
4 weeks ago
return {
3 weeks ago
...formData,
begainTime: formatDate(formData.begainTime), // 单独格式化 begainTime
endTime: formatDate(formData.endTime), // 单独格式化 endTime
createBy: '',
createId: 0,
createTime: '',
updateBy: '',
updateId: 0,
updateTime: '',
1 month ago
};
},
4 weeks ago
3 weeks ago
// formatDateRange(dateRange) {
// if (!dateRange || dateRange.length !== 2) return ['', '']; // 防止空值报错
// // 格式化日期,确保返回 YYYY-MM-DD 格式
// const formatDate = (date) => {
// if (!date) return '';
// // 如果是 Date 对象,直接格式化;如果是字符串,先转成 Date 再格式化
// const d = date instanceof Date ? date : new Date(date);
// return d.toISOString().split('T')[0]; // 取 YYYY-MM-DD 部分
// };
4 weeks ago
3 weeks ago
// return [
// formatDate(dateRange[0]), // 开始日期
// formatDate(dateRange[1]) // 结束日期
// ];
// },
// 处理附件上传成功
handleAttachmentSuccess(response, file) {
this.form.fj = response.url;
},
// 上传前验证
beforeAttachmentUpload(file) {
const isImage = file.type.startsWith('image/');
const isLt2M = file.size / 1024 / 1024 < 2;
if (!isImage) this.$message.error('只能上传图片文件!');
if (!isLt2M) this.$message.error('上传图片大小不能超过 2MB!');
return isImage && isLt2M;
},
// 删除附件
removeAttachment() {
this.form.fj = '';
},
4 weeks ago
// 显示地图弹窗
showMap() {
this.mapDialogVisible = true;
}
}
};
</script>
1 month ago
<style scoped>
.container {
display: flex;
flex-direction: column;
width: 100%;
2 months ago
background-color: #FFFFFF;
box-shadow: 0rem 0.13rem 0.63rem 0rem rgba(177, 177, 177, 0.1);
border-radius: 0.5rem 0.5rem 0.5rem 0.5rem;
}
.content {
padding: 1rem;
display: flex;
}
.containertop {
height: auto;
display: flex;
justify-content: space-between;
3 weeks ago
padding: .5rem;
2 months ago
border-bottom: 1px solid #E5E5E5;
}
.topleft {
4 weeks ago
height: 2rem;
2 months ago
width: 8rem;
display: flex;
gap: 0.4rem;
align-items: center;
}
.topleft img {
width: 0.81rem;
height: 0.81rem;
}
.topleft span {
width: auto;
height: 0.88rem;
font-family: AlibabaPuHuiTi, AlibabaPuHuiTi;
font-weight: 500;
font-size: 0.88rem;
color: #3D424C;
line-height: 0.88rem;
text-align: right;
font-style: normal;
text-transform: none;
}
.picturediv {
width: 18.31rem;
height: 25rem;
position: relative;
overflow: hidden;
}
.picturediv img {
width: 100%;
height: auto;
object-fit: cover;
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
margin: auto;
2 months ago
}
.descriptionsdiv {
width: calc(100% - 18.31rem);
2 months ago
margin-left: 1rem;
1 month ago
height: auto;
2 months ago
}
.two-row-item {
1 month ago
height: auto;
}
.tanchuang {
width: 70rem;
height: auto;
padding: 2rem;
}
4 weeks ago
</style>