|  |  |  | <template> | 
					
						
							|  |  |  |   <div class="div_main"> | 
					
						
							|  |  |  |     <div> | 
					
						
							|  |  |  |       <div class="div_search"> | 
					
						
							|  |  |  |         <el-form :inline="true" | 
					
						
							|  |  |  |                  :model="formData" | 
					
						
							|  |  |  |                  ref="ref_searchform" | 
					
						
							|  |  |  |                  :label-width="'80px'"> | 
					
						
							|  |  |  |           <div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <el-form-item label="服务名称" | 
					
						
							|  |  |  |                           prop="serviceName"> | 
					
						
							|  |  |  |               <el-input v-model="formData.serviceName" | 
					
						
							|  |  |  |                         class="item_width_1" | 
					
						
							|  |  |  |                         size="small" | 
					
						
							|  |  |  |                         clearable | 
					
						
							|  |  |  |                         placeholder="请输入"> | 
					
						
							|  |  |  |               </el-input> | 
					
						
							|  |  |  |             </el-form-item> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <el-form-item label="服务组织" | 
					
						
							|  |  |  |                           prop="serviceOrgType"> | 
					
						
							|  |  |  |               <el-select v-model="formData.serviceOrgType" | 
					
						
							|  |  |  |                          class="input-width-small" | 
					
						
							|  |  |  |                          placeholder="请选择" | 
					
						
							|  |  |  |                          clearable | 
					
						
							|  |  |  |                          @change="handleServiceChange('add', $event)"> | 
					
						
							|  |  |  |                 <el-option v-for="item in serviceOptions" | 
					
						
							|  |  |  |                            :key="item.value" | 
					
						
							|  |  |  |                            :label="item.label" | 
					
						
							|  |  |  |                            :value="item.value"> | 
					
						
							|  |  |  |                 </el-option> | 
					
						
							|  |  |  |               </el-select> | 
					
						
							|  |  |  |               - | 
					
						
							|  |  |  |               <el-select v-model="formData.serviceOrgId" | 
					
						
							|  |  |  |                          class="input-width-middle" | 
					
						
							|  |  |  |                          filterable | 
					
						
							|  |  |  |                          placeholder="请选择" | 
					
						
							|  |  |  |                          clearable> | 
					
						
							|  |  |  |                 <el-option v-for="item in serviceOptiondList" | 
					
						
							|  |  |  |                            :key="item.value" | 
					
						
							|  |  |  |                            :label="item.label" | 
					
						
							|  |  |  |                            :value="item.value"> | 
					
						
							|  |  |  |                 </el-option> | 
					
						
							|  |  |  |               </el-select> | 
					
						
							|  |  |  |             </el-form-item> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <el-form-item label="服务时间" | 
					
						
							|  |  |  |                           prop="serviceTimeStart"> | 
					
						
							|  |  |  |               <el-date-picker v-model="formData.serviceTimeStart" | 
					
						
							|  |  |  |                               :picker-options="startPickerOptions" | 
					
						
							|  |  |  |                               class="item_width_2" | 
					
						
							|  |  |  |                               size="small" | 
					
						
							|  |  |  |                               type="date" | 
					
						
							|  |  |  |                               value-format="yyyy-MM-dd" | 
					
						
							|  |  |  |                               value="yyyy-MM-dd" | 
					
						
							|  |  |  |                               placeholder="开始时间"> | 
					
						
							|  |  |  |               </el-date-picker> | 
					
						
							|  |  |  |               <span class="data-tag">至</span> | 
					
						
							|  |  |  |               <el-date-picker v-model="formData.serviceTimeEnd" | 
					
						
							|  |  |  |                               :picker-options="endPickerOptions" | 
					
						
							|  |  |  |                               class="item_width_2 data-tag" | 
					
						
							|  |  |  |                               size="small" | 
					
						
							|  |  |  |                               type="date" | 
					
						
							|  |  |  |                               value-format="yyyy-MM-dd" | 
					
						
							|  |  |  |                               value="yyyy-MM-dd" | 
					
						
							|  |  |  |                               placeholder="结束时间"> | 
					
						
							|  |  |  |               </el-date-picker> | 
					
						
							|  |  |  |             </el-form-item> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <el-form-item label="服务状态" | 
					
						
							|  |  |  |                           prop="serviceStatus"> | 
					
						
							|  |  |  |               <el-select class="item_width_2" | 
					
						
							|  |  |  |                          v-model="formData.serviceStatus" | 
					
						
							|  |  |  |                          placeholder="全部" | 
					
						
							|  |  |  |                          size="small" | 
					
						
							|  |  |  |                          clearable> | 
					
						
							|  |  |  |                 <el-option v-for="item in statusArray" | 
					
						
							|  |  |  |                            :key="item.value" | 
					
						
							|  |  |  |                            :label="item.label" | 
					
						
							|  |  |  |                            :value="item.value"> | 
					
						
							|  |  |  |                 </el-option> | 
					
						
							|  |  |  |               </el-select> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             </el-form-item> | 
					
						
							|  |  |  |             <el-form-item label="满意度" | 
					
						
							|  |  |  |                           prop="satisfaction"> | 
					
						
							|  |  |  |               <el-select class="item_width_2" | 
					
						
							|  |  |  |                          v-model="formData.satisfaction" | 
					
						
							|  |  |  |                          placeholder="全部" | 
					
						
							|  |  |  |                          size="small" | 
					
						
							|  |  |  |                          clearable> | 
					
						
							|  |  |  |                 <el-option v-for="item in satisfyArray" | 
					
						
							|  |  |  |                            :key="item.value" | 
					
						
							|  |  |  |                            :label="item.label" | 
					
						
							|  |  |  |                            :value="item.value"> | 
					
						
							|  |  |  |                 </el-option> | 
					
						
							|  |  |  |               </el-select> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             </el-form-item> | 
					
						
							|  |  |  |             <el-button style="margin-left:30px" | 
					
						
							|  |  |  |                        size="small" | 
					
						
							|  |  |  |                        class="diy-button--search" | 
					
						
							|  |  |  |                        @click="handleSearch">查询</el-button> | 
					
						
							|  |  |  |             <el-button style="margin-left:10px" | 
					
						
							|  |  |  |                        size="small" | 
					
						
							|  |  |  |                        class="diy-button--reset" | 
					
						
							|  |  |  |                        @click="resetSearch">重置</el-button> | 
					
						
							|  |  |  |           </div> | 
					
						
							|  |  |  |         </el-form> | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       <div class="div_table"> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         <div class="div_btn"> | 
					
						
							|  |  |  |           <el-button class="diy-button--add" | 
					
						
							|  |  |  |                      size="small" | 
					
						
							|  |  |  |                      @click="handleAdd">发起服务</el-button> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           <!-- <el-button @click="handleExport" | 
					
						
							|  |  |  |                      class="diy-button--reset" | 
					
						
							|  |  |  |                      size="small">导出</el-button> --> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         <el-table :data="tableData" | 
					
						
							|  |  |  |                   border | 
					
						
							|  |  |  |                   v-loading="tableLoading" | 
					
						
							|  |  |  |                   :header-cell-style="{background:'#2195FE',color:'#FFFFFF'}" | 
					
						
							|  |  |  |                   class="table" | 
					
						
							|  |  |  |                   style="width: 100%" | 
					
						
							|  |  |  |                   :height="maxTableHeight"> | 
					
						
							|  |  |  |           <el-table-column label="序号" | 
					
						
							|  |  |  |                            fixed="left" | 
					
						
							|  |  |  |                            type="index" | 
					
						
							|  |  |  |                            align="center" | 
					
						
							|  |  |  |                            width="50" /> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           <el-table-column prop="serviceName" | 
					
						
							|  |  |  |                            label="服务名称" | 
					
						
							|  |  |  |                            align="center" | 
					
						
							|  |  |  |                            :show-overflow-tooltip="true"> | 
					
						
							|  |  |  |           </el-table-column> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           <el-table-column prop="serviceOrgName" | 
					
						
							|  |  |  |                            align="center" | 
					
						
							|  |  |  |                            min-width="150" | 
					
						
							|  |  |  |                            label="服务组织名称" | 
					
						
							|  |  |  |                            :show-overflow-tooltip="true"> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           </el-table-column> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           <el-table-column prop="serviceTimeStart" | 
					
						
							|  |  |  |                            align="center" | 
					
						
							|  |  |  |                            width="300" | 
					
						
							|  |  |  |                            :show-overflow-tooltip="true" | 
					
						
							|  |  |  |                            label="服务时间"> | 
					
						
							|  |  |  |             <template slot-scope="scope"> | 
					
						
							|  |  |  |               <span>{{scope.row.serviceTimeStart}}-{{scope.row.serviceTimeEnd}}</span> | 
					
						
							|  |  |  |             </template> | 
					
						
							|  |  |  |           </el-table-column> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           <el-table-column prop="serviceStatus" | 
					
						
							|  |  |  |                            align="center" | 
					
						
							|  |  |  |                            width="100" | 
					
						
							|  |  |  |                            label="服务状态" | 
					
						
							|  |  |  |                            :show-overflow-tooltip="true"> | 
					
						
							|  |  |  |             <template slot-scope="scope"> | 
					
						
							|  |  |  |               <span>{{scope.row.serviceStatus==='in_service'?'进行中':'已完成'}}</span> | 
					
						
							|  |  |  |             </template> | 
					
						
							|  |  |  |           </el-table-column> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           <el-table-column prop="servicePeopleNumber" | 
					
						
							|  |  |  |                            align="center" | 
					
						
							|  |  |  |                            width="110" | 
					
						
							|  |  |  |                            label="服务人数" | 
					
						
							|  |  |  |                            :show-overflow-tooltip="true"> | 
					
						
							|  |  |  |           </el-table-column> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           <el-table-column fixed="right" | 
					
						
							|  |  |  |                            label="操作" | 
					
						
							|  |  |  |                            align="center" | 
					
						
							|  |  |  |                            width="180"> | 
					
						
							|  |  |  |             <template slot-scope="scope"> | 
					
						
							|  |  |  |               <el-button @click="handleDetail(scope.row)" | 
					
						
							|  |  |  |                          type="text" | 
					
						
							|  |  |  |                          size="small" | 
					
						
							|  |  |  |                          class=".div-table-button--detail">详情</el-button> | 
					
						
							|  |  |  |               <el-button v-if="scope.row.serviceStatus==='in_service'" | 
					
						
							|  |  |  |                          @click="handleEdit(scope.row)" | 
					
						
							|  |  |  |                          type="text" | 
					
						
							|  |  |  |                          size="small" | 
					
						
							|  |  |  |                          class="div-table-button--edit">编辑</el-button> | 
					
						
							|  |  |  |               <el-button v-if="scope.row.serviceStatus==='in_service'" | 
					
						
							|  |  |  |                          @click="handleFeedback(scope.row)" | 
					
						
							|  |  |  |                          type="text" | 
					
						
							|  |  |  |                          size="small" | 
					
						
							|  |  |  |                          class="div-table-button--edit">反馈</el-button> | 
					
						
							|  |  |  |               <el-button v-if="scope.row.serviceStatus==='in_service'" | 
					
						
							|  |  |  |                          @click="handleDel(scope.row)" | 
					
						
							|  |  |  |                          type="text" | 
					
						
							|  |  |  |                          size="small" | 
					
						
							|  |  |  |                          class="div-table-button--delete">取消</el-button> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             </template> | 
					
						
							|  |  |  |           </el-table-column> | 
					
						
							|  |  |  |         </el-table> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         <div> | 
					
						
							|  |  |  |           <el-pagination @size-change="handleSizeChange" | 
					
						
							|  |  |  |                          @current-change="handleCurrentChange" | 
					
						
							|  |  |  |                          :current-page.sync="pageNo" | 
					
						
							|  |  |  |                          :page-sizes="[20, 50, 100, 200]" | 
					
						
							|  |  |  |                          :page-size="parseInt(pageSize)" | 
					
						
							|  |  |  |                          layout="sizes, prev, pager, next, total" | 
					
						
							|  |  |  |                          :total="total"> | 
					
						
							|  |  |  |           </el-pagination> | 
					
						
							|  |  |  |         </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |     <el-dialog v-if="showAdd" | 
					
						
							|  |  |  |                :visible.sync="showAdd" | 
					
						
							|  |  |  |                :close-on-click-modal="false" | 
					
						
							|  |  |  |                :close-on-press-escape="false" | 
					
						
							|  |  |  |                :title="addDiaTitle" | 
					
						
							|  |  |  |                width="850px" | 
					
						
							|  |  |  |                top="5vh" | 
					
						
							|  |  |  |                class="dialog-h" | 
					
						
							|  |  |  |                @closed="showAdd = false"> | 
					
						
							|  |  |  |       <add-form ref="ref_add_form" | 
					
						
							|  |  |  |                 :formType="formType" | 
					
						
							|  |  |  |                 :statusArray="statusArray" | 
					
						
							|  |  |  |                 :satisfyArray="satisfyArray" | 
					
						
							|  |  |  |                 :serviceRecordId="serviceRecordId" | 
					
						
							|  |  |  |                 :serviceName="serviceName" | 
					
						
							|  |  |  |                 @handleOk="handleOk" | 
					
						
							|  |  |  |                 @handleClose="handleClose"></add-form> | 
					
						
							|  |  |  |     </el-dialog> | 
					
						
							|  |  |  |     <el-dialog v-if="showDetail" | 
					
						
							|  |  |  |                :visible.sync="showDetail" | 
					
						
							|  |  |  |                :close-on-click-modal="false" | 
					
						
							|  |  |  |                :close-on-press-escape="false" | 
					
						
							|  |  |  |                :title="detailDiaTitle" | 
					
						
							|  |  |  |                width="850px" | 
					
						
							|  |  |  |                top="5vh" | 
					
						
							|  |  |  |                class="dialog-h" | 
					
						
							|  |  |  |                @closed="showDetail = false"> | 
					
						
							|  |  |  |       <detail-form ref="ref_detail_form" | 
					
						
							|  |  |  |                    :serviceRecordId="serviceRecordId" | 
					
						
							|  |  |  |                    :serviceOrgName="serviceOrgName" | 
					
						
							|  |  |  |                    :satisfyArray="satisfyArray" | 
					
						
							|  |  |  |                    @handleOk="handleOk" | 
					
						
							|  |  |  |                    @handleClose="handleClose" | 
					
						
							|  |  |  |                    :formType="formType"> | 
					
						
							|  |  |  |       </detail-form> | 
					
						
							|  |  |  |     </el-dialog> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   </div> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | import { requestPost } from "@/js/dai/request"; | 
					
						
							|  |  |  | import nextTick from "dai-js/tools/nextTick"; | 
					
						
							|  |  |  | import { mapGetters } from "vuex"; | 
					
						
							|  |  |  | // import eventInfo from "./cpts/event-info";
 | 
					
						
							|  |  |  | import axios from "axios"; | 
					
						
							|  |  |  | import addForm from "./addForm"; | 
					
						
							|  |  |  | import detailForm from "./detailForm"; | 
					
						
							|  |  |  | import feedBackForm from "./addForm"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export default { | 
					
						
							|  |  |  |   components: { addForm, detailForm, feedBackForm }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   data () { | 
					
						
							|  |  |  |     let endDisabledDate = (time) => {//这个关键属性我们一定要写在data的里面并且return的外面,这是动态改变区间的关键
 | 
					
						
							|  |  |  |       let nowData = Date.now() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (this.formData.serviceTimeStart) { | 
					
						
							|  |  |  |         let serviceTimeStart = new Date(this.formData.serviceTimeStart) | 
					
						
							|  |  |  |         return time.getTime() > nowData || time.getTime() < serviceTimeStart || time.getTime() === serviceTimeStart | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         return time.getTime() > nowData | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     let startDisabledDate = (time) => {//这个关键属性我们一定要写在data的里面并且return的外面,这是动态改变区间的关键
 | 
					
						
							|  |  |  |       let nowData = Date.now() | 
					
						
							|  |  |  |       return time.getTime() > nowData | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return { | 
					
						
							|  |  |  |       tableLoading: false, | 
					
						
							|  |  |  |       user: {}, | 
					
						
							|  |  |  |       agencyId: '', | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       tableData: [], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       statusArray: [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           value: "in_service", | 
					
						
							|  |  |  |           label: "进行中", | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           value: "completed", | 
					
						
							|  |  |  |           label: "已完成", | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |       ], | 
					
						
							|  |  |  |       satisfyArray: [ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           value: "bad", | 
					
						
							|  |  |  |           label: "不满意", | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           value: "good", | 
					
						
							|  |  |  |           label: "基本满意", | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           value: "perfect", | 
					
						
							|  |  |  |           label: "非常满意", | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       ], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       formData: { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         serviceName: '',//项目名称	
 | 
					
						
							|  |  |  |         serviceOrgType: '',//服务组织类型	
 | 
					
						
							|  |  |  |         serviceOrgId: '',//服务组织Id	
 | 
					
						
							|  |  |  |         serviceTimeStart: '',//服务开始时间yyyy-MM-dd	
 | 
					
						
							|  |  |  |         serviceTimeEnd: '',//服务结束时间yyyy-MM-dd	
 | 
					
						
							|  |  |  |         serviceStatus: '',//服务状态。in_service服务中;completed:已完成	
 | 
					
						
							|  |  |  |         satisfaction: '',//满意度.不满意:bad、基本满意:good、非常满意:perfect	
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       pageNo: 1, | 
					
						
							|  |  |  |       pageSize: window.localStorage.getItem("pageSize") || 20, | 
					
						
							|  |  |  |       total: 1, | 
					
						
							|  |  |  |       endPickerOptions: { | 
					
						
							|  |  |  |         disabledDate: endDisabledDate | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       startPickerOptions: { | 
					
						
							|  |  |  |         disabledDate: startDisabledDate | 
					
						
							|  |  |  |       }, | 
					
						
							|  |  |  |       serviceRecordId: '', | 
					
						
							|  |  |  |       serviceName: '', | 
					
						
							|  |  |  |       serviceOrgName: '', | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       showAdd: false, | 
					
						
							|  |  |  |       showDetail: false, | 
					
						
							|  |  |  |       showFeedback: false, | 
					
						
							|  |  |  |       formType: 'add', | 
					
						
							|  |  |  |       addDiaTitle: '发起服务', | 
					
						
							|  |  |  |       detailDiaTitle: '服务详情', | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       serviceOptions: [], | 
					
						
							|  |  |  |       serviceOptiondList: [], | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }; | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   computed: { | 
					
						
							|  |  |  |     maxTableHeight () { | 
					
						
							|  |  |  |       return this.$store.state.inIframe | 
					
						
							|  |  |  |         ? this.clientHeight - 410 + this.iframeHeigh | 
					
						
							|  |  |  |         : this.clientHeight - 410; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     ...mapGetters(["clientHeight", "iframeHeight"]), | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   watch: { | 
					
						
							|  |  |  |     // "formData.serviceTimeEnd": function (val) {
 | 
					
						
							|  |  |  |     //   if (val && val != '') {
 | 
					
						
							|  |  |  |     //     let arrayTemp = val.split(' ')
 | 
					
						
							|  |  |  |     //     this.formData.serviceTimeEnd = arrayTemp[0] + ' 23:59:59'
 | 
					
						
							|  |  |  |     //   }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // },
 | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   mounted () { | 
					
						
							|  |  |  |     console.log(this.$store.state) | 
					
						
							|  |  |  |     this.user = this.$store.state.user | 
					
						
							|  |  |  |     this.agencyId = this.user.agencyId | 
					
						
							|  |  |  |     this.getDictOptions() | 
					
						
							|  |  |  |     this.getTableData(); | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  |   methods: { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleSearch (val) { | 
					
						
							|  |  |  |       console.log(this.formData); | 
					
						
							|  |  |  |       this.pageNo = 1; | 
					
						
							|  |  |  |       this.getTableData(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     // 获取服务组织
 | 
					
						
							|  |  |  |     async getDictOptions () { | 
					
						
							|  |  |  |       const url = "/sys/dict/data/dictlist" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       let params = { | 
					
						
							|  |  |  |         dictType: 'user_demand_service_type' | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const { data, code, msg } = await requestPost(url, params) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (code === 0) { | 
					
						
							|  |  |  |         this.serviceOptions = data; | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.$message.error(msg) | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleServiceChange (type, val) { | 
					
						
							|  |  |  |       this.formData.serviceOrgId = '' | 
					
						
							|  |  |  |       if (val === "social_org") { | 
					
						
							|  |  |  |         if (type === "add") { | 
					
						
							|  |  |  |           this.getServiceuserList(val, "add_demand"); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |           this.getServiceuserList(val, "query_demand"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.getServiceuserList(val, ""); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async getServiceuserList (serviceType, query) { | 
					
						
							|  |  |  |       if (!serviceType) return false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const params = { | 
					
						
							|  |  |  |         serviceName: "", | 
					
						
							|  |  |  |         serviceType: serviceType, | 
					
						
							|  |  |  |         queryPurpose: query, | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       await this.$http | 
					
						
							|  |  |  |         .post("/heart/userdemand/servicelist", params) | 
					
						
							|  |  |  |         .then(({ data: res }) => { | 
					
						
							|  |  |  |           if (res.code !== 0) { | 
					
						
							|  |  |  |             return this.$message.error(res.msg); | 
					
						
							|  |  |  |           } else { | 
					
						
							|  |  |  |             this.serviceOptiondList = res.data | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         .catch(() => { | 
					
						
							|  |  |  |           return this.$message.error("网络错误"); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async handleAdd () { | 
					
						
							|  |  |  |       this.addDiaTitle = '发起服务' | 
					
						
							|  |  |  |       this.formType = 'add' | 
					
						
							|  |  |  |       this.showAdd = true; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async handleDetail (row) { | 
					
						
							|  |  |  |       this.serviceRecordId = row.serviceRecordId | 
					
						
							|  |  |  |       this.serviceOrgName = row.serviceOrgName | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.formType = 'detail' | 
					
						
							|  |  |  |       this.showDetail = true | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     async handleEdit (row) { | 
					
						
							|  |  |  |       this.serviceRecordId = row.serviceRecordId | 
					
						
							|  |  |  |       this.formType = 'edit' | 
					
						
							|  |  |  |       this.showDetail = true | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     //加载组织数据
 | 
					
						
							|  |  |  |     async handleFeedback (row) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.serviceRecordId = row.serviceRecordId | 
					
						
							|  |  |  |       this.serviceName = row.serviceName | 
					
						
							|  |  |  |       this.addDiaTitle = '服务反馈' | 
					
						
							|  |  |  |       this.formType = 'feedback' | 
					
						
							|  |  |  |       this.showAdd = true; | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleClose () { | 
					
						
							|  |  |  |       this.serviceRecordId = "" | 
					
						
							|  |  |  |       this.formType = '' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.showAdd = false | 
					
						
							|  |  |  |       this.showDetail = false | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     handleOk () { | 
					
						
							|  |  |  |       this.handleClose() | 
					
						
							|  |  |  |       this.pageNo = 1 | 
					
						
							|  |  |  |       this.getTableData() | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async handleDel (row) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.serviceRecordId = row.serviceRecordId | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.$confirm("确认取消服务?", "提示", { | 
					
						
							|  |  |  |         confirmButtonText: "确定", | 
					
						
							|  |  |  |         cancelButtonText: "取消", | 
					
						
							|  |  |  |         type: "warning" | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |         .then(() => { | 
					
						
							|  |  |  |           this.cancelFuwu() | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         .catch(err => { | 
					
						
							|  |  |  |           if (err == "cancel") { | 
					
						
							|  |  |  |             // this.$message({
 | 
					
						
							|  |  |  |             //   type: "info",
 | 
					
						
							|  |  |  |             //   message: "已取消删除"
 | 
					
						
							|  |  |  |             // });
 | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async cancelFuwu () { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const url = '/heart/icServiceRecordV2/cancel'; | 
					
						
							|  |  |  |       let params = { | 
					
						
							|  |  |  |         serviceRecordId: this.serviceRecordId | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const { data, code, msg } = await requestPost(url, params); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (code === 0) { | 
					
						
							|  |  |  |         this.$message.success("取消成功!"); | 
					
						
							|  |  |  |         this.getTableData(); | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.$message.error("操作失败!"); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async getTableData () { | 
					
						
							|  |  |  |       this.tableLoading = true | 
					
						
							|  |  |  |       const url = "/heart/icServiceRecordV2/list"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       const { pageSize, pageNo, formData } = this; | 
					
						
							|  |  |  |       const { data, code, msg } = await requestPost(url, { | 
					
						
							|  |  |  |         pageSize, | 
					
						
							|  |  |  |         pageNo, | 
					
						
							|  |  |  |         ...formData, | 
					
						
							|  |  |  |       }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.tableLoading = false | 
					
						
							|  |  |  |       if (code === 0) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.total = data.total || 0; | 
					
						
							|  |  |  |         this.tableData = data.list | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       } else { | 
					
						
							|  |  |  |         this.$message.error(msg); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     async handleExport () { | 
					
						
							|  |  |  |       const url = "/gov/project/icEvent/export"; | 
					
						
							|  |  |  |       const { pageSize, pageNo, formData } = this; | 
					
						
							|  |  |  |       axios({ | 
					
						
							|  |  |  |         url: window.SITE_CONFIG["apiURL"] + url, | 
					
						
							|  |  |  |         method: "post", | 
					
						
							|  |  |  |         data: { | 
					
						
							|  |  |  |           pageSize, | 
					
						
							|  |  |  |           pageNo, | 
					
						
							|  |  |  |           ...formData, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         responseType: "blob", | 
					
						
							|  |  |  |       }) | 
					
						
							|  |  |  |         .then((res) => { | 
					
						
							|  |  |  |           let fileName = window.decodeURI( | 
					
						
							|  |  |  |             res.headers["content-disposition"].split(";")[1].split("=")[1] | 
					
						
							|  |  |  |           ); | 
					
						
							|  |  |  |           console.log("filename", fileName); | 
					
						
							|  |  |  |           let blob = new Blob([res.data], { type: "application/vnd.ms-excel" }); | 
					
						
							|  |  |  |           var url = window.URL.createObjectURL(blob); | 
					
						
							|  |  |  |           var aLink = document.createElement("a"); | 
					
						
							|  |  |  |           aLink.style.display = "none"; | 
					
						
							|  |  |  |           aLink.href = url; | 
					
						
							|  |  |  |           aLink.setAttribute("download", fileName); | 
					
						
							|  |  |  |           document.body.appendChild(aLink); | 
					
						
							|  |  |  |           aLink.click(); | 
					
						
							|  |  |  |           document.body.removeChild(aLink); //下载完成移除元素
 | 
					
						
							|  |  |  |           window.URL.revokeObjectURL(url); //释放掉blob对象
 | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |         .catch((err) => { | 
					
						
							|  |  |  |           console.log("获取导出情失败", err); | 
					
						
							|  |  |  |           return this.$message.error("网络错误"); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     handleSizeChange (val) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.pageSize = val; | 
					
						
							|  |  |  |       window.localStorage.setItem("pageSize", val); | 
					
						
							|  |  |  |       this.getTableData(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |     handleCurrentChange (val) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.pageNo = val; | 
					
						
							|  |  |  |       this.getTableData(); | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     resetSearch () { | 
					
						
							|  |  |  |       this.formData = { | 
					
						
							|  |  |  |         serviceName: '',//项目名称	
 | 
					
						
							|  |  |  |         serviceOrgType: '',//服务组织类型	
 | 
					
						
							|  |  |  |         serviceOrgId: '',//服务组织Id	
 | 
					
						
							|  |  |  |         serviceTimeStart: '',//服务开始时间yyyy-MM-dd	
 | 
					
						
							|  |  |  |         serviceTimeEnd: '',//服务结束时间yyyy-MM-dd	
 | 
					
						
							|  |  |  |         serviceStatus: '',//服务状态。in_service服务中;completed:已完成	
 | 
					
						
							|  |  |  |         satisfaction: '',//满意度.不满意:bad、基本满意:good、非常满意:perfect	
 | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       this.pageNo = 1 | 
					
						
							|  |  |  |       // this.getTableData()
 | 
					
						
							|  |  |  |     }, | 
					
						
							|  |  |  |   }, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style lang="scss" scoped> | 
					
						
							|  |  |  | @import "@/assets/scss/buttonstyle.scss"; | 
					
						
							|  |  |  | @import "@/assets/scss/modules/management/list-main.scss"; | 
					
						
							|  |  |  | @import "@/assets/scss/modules/shequzhili/event-info.scss"; | 
					
						
							|  |  |  | </style> |