|
|
|
@ -3,8 +3,10 @@ |
|
|
|
<div style="width: 100%; height: 100%;"> |
|
|
|
<div class="project-detail"> |
|
|
|
<div class="project-detail-tip">议题详情</div> |
|
|
|
<el-form label-position="right" label-width="120px"> |
|
|
|
<el-form-item label="议题内容:" prop="eventContent"> |
|
|
|
<el-form label-position="right" |
|
|
|
label-width="120px"> |
|
|
|
<el-form-item label="议题内容:" |
|
|
|
prop="eventContent"> |
|
|
|
<div>{{dataForm.itemContent}}</div> |
|
|
|
<el-image v-for="url in dataForm.images" |
|
|
|
style="width: 100px; height: 100px; margin-right: 10px" |
|
|
|
@ -14,19 +16,25 @@ |
|
|
|
@click="clickImg(url)"> |
|
|
|
</el-image> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item v-if="dataForm.groupName && dataForm.groupName.length > 0" label="项目来源:" prop="ownGrid"> |
|
|
|
<el-form-item v-if="dataForm.groupName && dataForm.groupName.length > 0" |
|
|
|
label="项目来源:" |
|
|
|
prop="ownGrid"> |
|
|
|
<div>{{dataForm.groupName}}</div> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="上报时间:" prop="distributeTime"> |
|
|
|
<el-form-item label="上报时间:" |
|
|
|
prop="distributeTime"> |
|
|
|
<div>{{dataForm.distributeTime}}</div> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="上报人:" prop="nickName"> |
|
|
|
<el-form-item label="上报人:" |
|
|
|
prop="nickName"> |
|
|
|
<div>{{dataForm.nickName}}</div> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="电话:" prop="mobile"> |
|
|
|
<el-form-item label="电话:" |
|
|
|
prop="mobile"> |
|
|
|
<div>{{dataForm.mobile}}</div> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="所属类别:" prop="categoryName"> |
|
|
|
<el-form-item label="所属类别:" |
|
|
|
prop="categoryName"> |
|
|
|
<div>{{dataForm.categoryName}}</div> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="项目态度:"> |
|
|
|
@ -36,7 +44,8 @@ |
|
|
|
<span>反对 {{dataForm.opposeNum}}</span> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="项目评论:"> |
|
|
|
<el-button type="text" @click="innerVisible = true">查看评论</el-button> |
|
|
|
<el-button type="text" |
|
|
|
@click="innerVisible = true">查看评论</el-button> |
|
|
|
</el-form-item> |
|
|
|
</el-form> |
|
|
|
<div class="container"> |
|
|
|
@ -47,13 +56,12 @@ |
|
|
|
<div class="project-progress"> |
|
|
|
<div class="project-progress-tip">处理进展</div> |
|
|
|
<el-timeline> |
|
|
|
<el-timeline-item |
|
|
|
v-for="(item, index) in timeLineList" |
|
|
|
<el-timeline-item v-for="(item, index) in timeLineList" |
|
|
|
:key="item.id" |
|
|
|
:color="item.type === 'init' ? 'red' : item.type === 'project' ? '#009688' : '#ffa546'"> |
|
|
|
<div :id="`content${index}`" style="line-height:25px; "> |
|
|
|
<div |
|
|
|
:style="{ marginBottom: '10px', width: '35px', height: '20px', fontSize: '12px', borderRadius: '4px', background: item.type === 'project' ? '#009688': item.type === 'issue' || item.type === 'issue-project' ? '#ffa546' : '', color: '#fff', textAlign: 'center', lineHeight: '20px'}" |
|
|
|
<div :id="`content${index}`" |
|
|
|
style="line-height:25px; "> |
|
|
|
<div :style="{ marginBottom: '10px', width: '35px', height: '20px', fontSize: '12px', borderRadius: '4px', background: item.type === 'project' ? '#009688': item.type === 'issue' || item.type === 'issue-project' ? '#ffa546' : '', color: '#fff', textAlign: 'center', lineHeight: '20px'}" |
|
|
|
v-if="item.type !== 'init'"> |
|
|
|
{{item.type === 'project' ? '项目': item.type === 'issue' || item.type === 'issue-project' ? '议题' : ''}} |
|
|
|
</div> |
|
|
|
@ -66,10 +74,12 @@ |
|
|
|
<div v-if="item.state !== 3"> |
|
|
|
<div><span style="font-weight: bold; color: rgb(96, 98, 102);">处理部门:</span>{{item.handlerDept}}</div> |
|
|
|
</div> |
|
|
|
<div v-if="item.itemDeptDTOS && item.itemDeptDTOS.length > 0" style="width: 100%; display: flex;"> |
|
|
|
<div v-if="item.itemDeptDTOS && item.itemDeptDTOS.length > 0" |
|
|
|
style="width: 100%; display: flex;"> |
|
|
|
<div><span style="font-weight: bold; color: rgb(96, 98, 102);">被吹哨部门:</span> </div> |
|
|
|
<div> |
|
|
|
<span v-for="(csDept, index1) in item.itemDeptDTOS" :key="index1"> |
|
|
|
<span v-for="(csDept, index1) in item.itemDeptDTOS" |
|
|
|
:key="index1"> |
|
|
|
{{ csDept.deptName }}<br /> |
|
|
|
</span> |
|
|
|
</div> |
|
|
|
@ -92,35 +102,53 @@ |
|
|
|
</div> |
|
|
|
<div class="handle-operation"> |
|
|
|
<div class="handle-operation-tip">处理操作</div> |
|
|
|
<el-form ref="dataForm" label-width="120px" label-position="right" style="width: 720px;" :model="dataForm" :rules="dataRule"> |
|
|
|
<el-form-item label="处理:" prop="handleCategory"> |
|
|
|
<el-select v-model="postDataForm.handleCategory" placeholder="请选择"> |
|
|
|
<el-option |
|
|
|
v-for="handleResultDTO in dataForm.handleResultDTOS" |
|
|
|
<el-form ref="dataForm" |
|
|
|
label-width="120px" |
|
|
|
label-position="right" |
|
|
|
style="width: 720px;" |
|
|
|
:model="dataForm" |
|
|
|
:rules="dataRule"> |
|
|
|
<el-form-item label="处理:" |
|
|
|
prop="handleCategory"> |
|
|
|
<el-select v-model="postDataForm.handleCategory" |
|
|
|
placeholder="请选择"> |
|
|
|
<el-option v-for="handleResultDTO in dataForm.handleResultDTOS" |
|
|
|
:key="handleResultDTO.processResult" |
|
|
|
:label="handleResultDTO.processName" |
|
|
|
:value="handleResultDTO.processResult"> |
|
|
|
</el-option> |
|
|
|
</el-select> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="吹哨部门:" prop="deptResultDTOS" v-if="deptResultDTOSVisible"> |
|
|
|
<el-select v-model="deptResult" multiple placeholder="请选择"> |
|
|
|
<el-option |
|
|
|
v-for="item in dataForm.deptResultDTOS" |
|
|
|
<el-form-item label="吹哨部门:" |
|
|
|
prop="deptResultDTOS" |
|
|
|
v-if="deptResultDTOSVisible"> |
|
|
|
<el-select v-model="deptResult" |
|
|
|
multiple |
|
|
|
placeholder="请选择"> |
|
|
|
<el-option v-for="item in dataForm.deptResultDTOS" |
|
|
|
:key="item.deptId" |
|
|
|
:label="item.deptName" |
|
|
|
:value="item.deptId"> |
|
|
|
</el-option> |
|
|
|
</el-select> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="回复居民意见:" prop="outHandleAdvice"> |
|
|
|
<el-input v-model="postDataForm.outHandleAdvice" type="textarea" placeholder="请您选择居民诉求的处理情况及答复意见,向居民公开展示"></el-input> |
|
|
|
<el-form-item label="回复居民意见:" |
|
|
|
prop="outHandleAdvice"> |
|
|
|
<el-input v-model="postDataForm.outHandleAdvice" |
|
|
|
type="textarea" |
|
|
|
placeholder="请您选择居民诉求的处理情况及答复意见,向居民公开展示"></el-input> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="项目处理意见:" prop="handleAdvice"> |
|
|
|
<el-input v-model="postDataForm.handleAdvice" type="textarea" placeholder="请您填写项目的实际办理情况(自己处理、吹哨报道、内部协调),便于相关部门了解项目的实际情况"></el-input> |
|
|
|
<el-form-item label="项目处理意见:" |
|
|
|
prop="handleAdvice"> |
|
|
|
<el-input v-model="postDataForm.handleAdvice" |
|
|
|
type="textarea" |
|
|
|
placeholder="请您填写项目的实际办理情况(自己处理、吹哨报道、内部协调),便于相关部门了解项目的实际情况"></el-input> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item label="满意度评价:" prop="evaluateDeptDTOS" v-if="evaluateDeptDTOSVisible"> |
|
|
|
<div v-for="(evaluateDeptDTO, index) in dataForm.evaluateDeptDTOS" :key="index"> |
|
|
|
<el-form-item label="满意度评价:" |
|
|
|
prop="evaluateDeptDTOS" |
|
|
|
v-if="evaluateDeptDTOSVisible"> |
|
|
|
<div v-for="(evaluateDeptDTO, index) in dataForm.evaluateDeptDTOS" |
|
|
|
:key="index"> |
|
|
|
<label>{{evaluateDeptDTO.deptName}}</label> |
|
|
|
<el-radio-group v-model="evaluateDeptDTO.evaluationLevel"> |
|
|
|
<el-radio :label="2">非常满意</el-radio> |
|
|
|
@ -130,29 +158,62 @@ |
|
|
|
</div> |
|
|
|
</el-form-item> |
|
|
|
<el-form-item style="float: right;"> |
|
|
|
<el-button size="small" type="primary" :disabled="isAble" style="width: 95px" @click="dataFormSubmitHandle()">{{ $t('confirm') }}</el-button> |
|
|
|
<el-button size="small" style="width: 95px" @click="backToItemDeal">返回</el-button> |
|
|
|
<el-button size="small" |
|
|
|
type="primary" |
|
|
|
:disabled="isAble" |
|
|
|
style="width: 95px" |
|
|
|
@click="dataFormSubmitHandle()">{{ $t('confirm') }}</el-button> |
|
|
|
<el-button size="small" |
|
|
|
style="width: 95px" |
|
|
|
@click="backToItemDeal">返回</el-button> |
|
|
|
</el-form-item> |
|
|
|
</el-form> |
|
|
|
|
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<el-dialog width="90%" title="评论" :visible.sync="innerVisible" append-to-body> |
|
|
|
<el-table :data="commentsDTOs" border style="width: 100%;"> |
|
|
|
<el-table-column prop="user.userName" label="发言人" header-align="center" align="center"></el-table-column> |
|
|
|
<el-table-column prop="commentTime" label="发言时间" header-align="center" align="center"></el-table-column> |
|
|
|
<el-table-column prop="content" label="发言内容" header-align="center" align="center"></el-table-column> |
|
|
|
<el-table-column prop="replyComment.userName" label="被回复人" header-align="center" align="center"></el-table-column> |
|
|
|
<el-table-column prop="replyComment.content" label="被回复内容" header-align="center" align="center"></el-table-column> |
|
|
|
<el-table-column :label="$t('handle')" header-align="center" align="center" width="150"> |
|
|
|
<el-dialog width="90%" |
|
|
|
title="评论" |
|
|
|
:visible.sync="innerVisible" |
|
|
|
append-to-body> |
|
|
|
<el-table :data="commentsDTOs" |
|
|
|
border |
|
|
|
style="width: 100%;"> |
|
|
|
<el-table-column prop="user.userName" |
|
|
|
label="发言人" |
|
|
|
header-align="center" |
|
|
|
align="center"></el-table-column> |
|
|
|
<el-table-column prop="commentTime" |
|
|
|
label="发言时间" |
|
|
|
header-align="center" |
|
|
|
align="center"></el-table-column> |
|
|
|
<el-table-column prop="content" |
|
|
|
label="发言内容" |
|
|
|
header-align="center" |
|
|
|
align="center"></el-table-column> |
|
|
|
<el-table-column prop="replyComment.userName" |
|
|
|
label="被回复人" |
|
|
|
header-align="center" |
|
|
|
align="center"></el-table-column> |
|
|
|
<el-table-column prop="replyComment.content" |
|
|
|
label="被回复内容" |
|
|
|
header-align="center" |
|
|
|
align="center"></el-table-column> |
|
|
|
<el-table-column :label="$t('handle')" |
|
|
|
header-align="center" |
|
|
|
align="center" |
|
|
|
width="150"> |
|
|
|
<template slot-scope="scope"> |
|
|
|
<el-button v-if="scope.row.shieldFlag === '0'" type="button" size="small" @click="deleteComment(scope.row.commentId)">屏蔽</el-button> |
|
|
|
<el-button v-if="scope.row.shieldFlag === '1'" type="text" size="small">已屏蔽</el-button> |
|
|
|
<el-button v-if="scope.row.shieldFlag === '0'" |
|
|
|
type="button" |
|
|
|
size="small" |
|
|
|
@click="deleteComment(scope.row.commentId)">屏蔽</el-button> |
|
|
|
<el-button v-if="scope.row.shieldFlag === '1'" |
|
|
|
type="text" |
|
|
|
size="small">已屏蔽</el-button> |
|
|
|
</template> |
|
|
|
</el-table-column> |
|
|
|
</el-table> |
|
|
|
<el-pagination |
|
|
|
:current-page="pageIndex" |
|
|
|
<el-pagination :current-page="pageIndex" |
|
|
|
:page-sizes="[10, 20, 50, 100]" |
|
|
|
:page-size="limitVal" |
|
|
|
:total="total" |
|
|
|
|