|  | @@ -1,60 +1,57 @@
 | 
	
		
			
				|  |  |  <template>
 | 
	
		
			
				|  |  |    <div class="app-container">
 | 
	
		
			
				|  |  | -    <!-- 查询条件 -->
 | 
	
		
			
				|  |  | -    <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
 | 
	
		
			
				|  |  | -      <el-form-item label="投诉单号" prop="complaintNo">
 | 
	
		
			
				|  |  | +    <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
 | 
	
		
			
				|  |  | +      <el-form-item label="投诉用户" prop="fsUserId">
 | 
	
		
			
				|  |  |          <el-input
 | 
	
		
			
				|  |  | -          v-model="queryParams.complaintNo"
 | 
	
		
			
				|  |  | -          placeholder="请输入投诉单号"
 | 
	
		
			
				|  |  | +          v-model="queryParams.nickName"
 | 
	
		
			
				|  |  | +          placeholder="请输入投诉用户"
 | 
	
		
			
				|  |  |            clearable
 | 
	
		
			
				|  |  | +          size="small"
 | 
	
		
			
				|  |  |            @keyup.enter.native="handleQuery"
 | 
	
		
			
				|  |  |          />
 | 
	
		
			
				|  |  |        </el-form-item>
 | 
	
		
			
				|  |  | -      <el-form-item label="投诉分类" prop="categoryId">
 | 
	
		
			
				|  |  | -        <el-select v-model="queryParams.categoryId" placeholder="请选择投诉分类" clearable>
 | 
	
		
			
				|  |  | -          <el-option
 | 
	
		
			
				|  |  | -            v-for="category in categoryList"
 | 
	
		
			
				|  |  | -            :key="category.id"
 | 
	
		
			
				|  |  | -            :label="category.categoryName"
 | 
	
		
			
				|  |  | -            :value="category.id"
 | 
	
		
			
				|  |  | -          />
 | 
	
		
			
				|  |  | -        </el-select>
 | 
	
		
			
				|  |  | +      <el-form-item label="投诉标题" prop="title">
 | 
	
		
			
				|  |  | +        <el-input
 | 
	
		
			
				|  |  | +          v-model="queryParams.title"
 | 
	
		
			
				|  |  | +          placeholder="请输入投诉标题"
 | 
	
		
			
				|  |  | +          clearable
 | 
	
		
			
				|  |  | +          size="small"
 | 
	
		
			
				|  |  | +          @keyup.enter.native="handleQuery"
 | 
	
		
			
				|  |  | +        />
 | 
	
		
			
				|  |  |        </el-form-item>
 | 
	
		
			
				|  |  | -      <el-form-item label="投诉状态" prop="status">
 | 
	
		
			
				|  |  | -        <el-select v-model="queryParams.status" placeholder="请选择投诉状态" clearable>
 | 
	
		
			
				|  |  | -          <el-option label="待处理" value="0" />
 | 
	
		
			
				|  |  | -          <el-option label="已处理" value="1" />
 | 
	
		
			
				|  |  | +      <el-form-item label="投诉类型" prop="type">
 | 
	
		
			
				|  |  | +        <el-select v-model="queryParams.type" placeholder="请选择投诉类型" clearable size="small">
 | 
	
		
			
				|  |  | +          <el-option v-for="item in typeList" :label="item.value" :value="item.type" />
 | 
	
		
			
				|  |  |          </el-select>
 | 
	
		
			
				|  |  |        </el-form-item>
 | 
	
		
			
				|  |  | -      <el-form-item label="投诉时间">
 | 
	
		
			
				|  |  | -        <el-date-picker
 | 
	
		
			
				|  |  | -          v-model="dateRange"
 | 
	
		
			
				|  |  | -          style="width: 240px"
 | 
	
		
			
				|  |  | -          value-format="yyyy-MM-dd"
 | 
	
		
			
				|  |  | -          type="daterange"
 | 
	
		
			
				|  |  | -          range-separator="-"
 | 
	
		
			
				|  |  | -          start-placeholder="开始日期"
 | 
	
		
			
				|  |  | -          end-placeholder="结束日期"
 | 
	
		
			
				|  |  | -        ></el-date-picker>
 | 
	
		
			
				|  |  | -      </el-form-item>
 | 
	
		
			
				|  |  |        <el-form-item>
 | 
	
		
			
				|  |  |          <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
 | 
	
		
			
				|  |  |          <el-button icon="el-icon-refresh" size="mini" @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="el-icon-plus"
 | 
	
		
			
				|  |  | -          size="mini"
 | 
	
		
			
				|  |  | -          @click="handleAdd"
 | 
	
		
			
				|  |  | -          v-hasPermi="['complaint:add']"
 | 
	
		
			
				|  |  | -        >新增投诉</el-button>
 | 
	
		
			
				|  |  | -      </el-col>
 | 
	
		
			
				|  |  | +<!--      <el-col :span="1.5">-->
 | 
	
		
			
				|  |  | +<!--        <el-button-->
 | 
	
		
			
				|  |  | +<!--          type="primary"-->
 | 
	
		
			
				|  |  | +<!--          plain-->
 | 
	
		
			
				|  |  | +<!--          icon="el-icon-plus"-->
 | 
	
		
			
				|  |  | +<!--          size="mini"-->
 | 
	
		
			
				|  |  | +<!--          @click="handleAdd"-->
 | 
	
		
			
				|  |  | +<!--          v-hasPermi="['user:complaint:add']"-->
 | 
	
		
			
				|  |  | +<!--        >新增</el-button>-->
 | 
	
		
			
				|  |  | +<!--      </el-col>-->
 | 
	
		
			
				|  |  | +<!--      <el-col :span="1.5">-->
 | 
	
		
			
				|  |  | +<!--        <el-button-->
 | 
	
		
			
				|  |  | +<!--          type="success"-->
 | 
	
		
			
				|  |  | +<!--          plain-->
 | 
	
		
			
				|  |  | +<!--          icon="el-icon-edit"-->
 | 
	
		
			
				|  |  | +<!--          size="mini"-->
 | 
	
		
			
				|  |  | +<!--          :disabled="single"-->
 | 
	
		
			
				|  |  | +<!--          @click="handleUpdate"-->
 | 
	
		
			
				|  |  | +<!--          v-hasPermi="['user:complaint:edit']"-->
 | 
	
		
			
				|  |  | +<!--        >修改</el-button>-->
 | 
	
		
			
				|  |  | +<!--      </el-col>-->
 | 
	
		
			
				|  |  |        <el-col :span="1.5">
 | 
	
		
			
				|  |  |          <el-button
 | 
	
		
			
				|  |  |            type="danger"
 | 
	
	
		
			
				|  | @@ -63,67 +60,70 @@
 | 
	
		
			
				|  |  |            size="mini"
 | 
	
		
			
				|  |  |            :disabled="multiple"
 | 
	
		
			
				|  |  |            @click="handleDelete"
 | 
	
		
			
				|  |  | -          v-hasPermi="['complaint:delete']"
 | 
	
		
			
				|  |  | -        >批量删除</el-button>
 | 
	
		
			
				|  |  | +          v-hasPermi="['user:complaint:remove']"
 | 
	
		
			
				|  |  | +        >删除</el-button>
 | 
	
		
			
				|  |  |        </el-col>
 | 
	
		
			
				|  |  | +<!--      <el-col :span="1.5">-->
 | 
	
		
			
				|  |  | +<!--        <el-button-->
 | 
	
		
			
				|  |  | +<!--          type="warning"-->
 | 
	
		
			
				|  |  | +<!--          plain-->
 | 
	
		
			
				|  |  | +<!--          icon="el-icon-download"-->
 | 
	
		
			
				|  |  | +<!--          size="mini"-->
 | 
	
		
			
				|  |  | +<!--          :loading="exportLoading"-->
 | 
	
		
			
				|  |  | +<!--          @click="handleExport"-->
 | 
	
		
			
				|  |  | +<!--          v-hasPermi="['user:complaint:export']"-->
 | 
	
		
			
				|  |  | +<!--        >导出</el-button>-->
 | 
	
		
			
				|  |  | +<!--      </el-col>-->
 | 
	
		
			
				|  |  |        <right-toolbar :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
 | 
	
		
			
				|  |  |      </el-row>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    <!-- 投诉列表 -->
 | 
	
		
			
				|  |  | -    <el-table v-loading="loading" :data="complaintList" @selection-change="handleSelectionChange">
 | 
	
		
			
				|  |  | +    <el-table border v-loading="loading" :data="complaintList" @selection-change="handleSelectionChange">
 | 
	
		
			
				|  |  |        <el-table-column type="selection" width="55" align="center" />
 | 
	
		
			
				|  |  | -      <el-table-column label="投诉单号" align="center" prop="complaintNo" />
 | 
	
		
			
				|  |  | -      <el-table-column label="投诉人" align="center" prop="complainantName" />
 | 
	
		
			
				|  |  | -      <el-table-column label="投诉分类" align="center" prop="categoryName" />
 | 
	
		
			
				|  |  | -      <el-table-column label="投诉内容" align="center" prop="content" show-overflow-tooltip />
 | 
	
		
			
				|  |  | -      <el-table-column label="投诉状态" align="center" prop="status">
 | 
	
		
			
				|  |  | +      <el-table-column label="id" align="center" prop="id" />
 | 
	
		
			
				|  |  | +      <el-table-column label="投诉用户" align="center" prop="nickName" />
 | 
	
		
			
				|  |  | +      <el-table-column label="投诉标题" align="center" prop="title" />
 | 
	
		
			
				|  |  | +      <el-table-column label="投诉内容" align="center" prop="content" />
 | 
	
		
			
				|  |  | +      <el-table-column label="商品图片" align="center" width="120">
 | 
	
		
			
				|  |  |          <template slot-scope="scope">
 | 
	
		
			
				|  |  | -          <el-tag v-if="scope.row.status === '0'" type="warning">待处理</el-tag>
 | 
	
		
			
				|  |  | -          <el-tag v-else-if="scope.row.status === '1'" type="success">已处理</el-tag>
 | 
	
		
			
				|  |  | -          <el-tag v-else type="info">未知</el-tag>
 | 
	
		
			
				|  |  | +          <el-popover
 | 
	
		
			
				|  |  | +            placement="right"
 | 
	
		
			
				|  |  | +            title=""
 | 
	
		
			
				|  |  | +            trigger="hover">
 | 
	
		
			
				|  |  | +            <img slot="reference"  :src="scope.row.images" width="100">
 | 
	
		
			
				|  |  | +            <img :src="scope.row.images" style="max-width: 150px;">
 | 
	
		
			
				|  |  | +          </el-popover>
 | 
	
		
			
				|  |  |          </template>
 | 
	
		
			
				|  |  |        </el-table-column>
 | 
	
		
			
				|  |  | -      <el-table-column label="投诉时间" align="center" prop="createTime" width="180">
 | 
	
		
			
				|  |  | +      <el-table-column label="投诉类型" align="center">
 | 
	
		
			
				|  |  |          <template slot-scope="scope">
 | 
	
		
			
				|  |  | -          <span>{{ parseTime(scope.row.createTime, '{y}-{m}-{d} {h}:{i}:{s}') }}</span>
 | 
	
		
			
				|  |  | +          <span v-for="item in typeList" :key="item.type">
 | 
	
		
			
				|  |  | +            <template v-if="item.type === scope.row.type">
 | 
	
		
			
				|  |  | +                {{ item.value }}
 | 
	
		
			
				|  |  | +            </template>
 | 
	
		
			
				|  |  | +          </span>
 | 
	
		
			
				|  |  |          </template>
 | 
	
		
			
				|  |  |        </el-table-column>
 | 
	
		
			
				|  |  | +      <el-table-column label="备注" align="center" prop="remark" />
 | 
	
		
			
				|  |  |        <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
 | 
	
		
			
				|  |  |          <template slot-scope="scope">
 | 
	
		
			
				|  |  | -          <el-button
 | 
	
		
			
				|  |  | -            size="mini"
 | 
	
		
			
				|  |  | -            type="text"
 | 
	
		
			
				|  |  | -            icon="el-icon-view"
 | 
	
		
			
				|  |  | -            @click="handleDetail(scope.row)"
 | 
	
		
			
				|  |  | -            v-hasPermi="['complaint:query']"
 | 
	
		
			
				|  |  | -          >详情</el-button>
 | 
	
		
			
				|  |  |            <el-button
 | 
	
		
			
				|  |  |              size="mini"
 | 
	
		
			
				|  |  |              type="text"
 | 
	
		
			
				|  |  |              icon="el-icon-edit"
 | 
	
		
			
				|  |  |              @click="handleUpdate(scope.row)"
 | 
	
		
			
				|  |  | -            v-hasPermi="['complaint:edit']"
 | 
	
		
			
				|  |  | -          >编辑</el-button>
 | 
	
		
			
				|  |  | -          <el-button
 | 
	
		
			
				|  |  | -            v-if="scope.row.status === '0'"
 | 
	
		
			
				|  |  | -            size="mini"
 | 
	
		
			
				|  |  | -            type="text"
 | 
	
		
			
				|  |  | -            icon="el-icon-check"
 | 
	
		
			
				|  |  | -            @click="handleProcess(scope.row)"
 | 
	
		
			
				|  |  | -            v-hasPermi="['complaint:edit']"
 | 
	
		
			
				|  |  | -          >处理</el-button>
 | 
	
		
			
				|  |  | +            v-hasPermi="['user:complaint:edit']"
 | 
	
		
			
				|  |  | +          >修改</el-button>
 | 
	
		
			
				|  |  |            <el-button
 | 
	
		
			
				|  |  |              size="mini"
 | 
	
		
			
				|  |  |              type="text"
 | 
	
		
			
				|  |  |              icon="el-icon-delete"
 | 
	
		
			
				|  |  |              @click="handleDelete(scope.row)"
 | 
	
		
			
				|  |  | -            v-hasPermi="['complaint:delete']"
 | 
	
		
			
				|  |  | +            v-hasPermi="['user:complaint:remove']"
 | 
	
		
			
				|  |  |            >删除</el-button>
 | 
	
		
			
				|  |  |          </template>
 | 
	
		
			
				|  |  |        </el-table-column>
 | 
	
		
			
				|  |  |      </el-table>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    <!-- 分页 -->
 | 
	
		
			
				|  |  |      <pagination
 | 
	
		
			
				|  |  |        v-show="total>0"
 | 
	
		
			
				|  |  |        :total="total"
 | 
	
	
		
			
				|  | @@ -132,48 +132,35 @@
 | 
	
		
			
				|  |  |        @pagination="getList"
 | 
	
		
			
				|  |  |      />
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -    <!-- 添加或修改投诉对话框 -->
 | 
	
		
			
				|  |  | -    <el-dialog :title="title" :visible.sync="open" width="600px" append-to-body>
 | 
	
		
			
				|  |  | +    <!-- 添加或修改用户投诉对话框 -->
 | 
	
		
			
				|  |  | +    <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
 | 
	
		
			
				|  |  |        <el-form ref="form" :model="form" :rules="rules" label-width="80px">
 | 
	
		
			
				|  |  | -        <el-form-item label="投诉人" prop="complainantName">
 | 
	
		
			
				|  |  | -          <el-input v-model="form.complainantName" placeholder="请输入投诉人姓名" />
 | 
	
		
			
				|  |  | +        <el-form-item label="投诉用户" prop="nickName">
 | 
	
		
			
				|  |  | +          <el-input v-model="form.nickName" placeholder="请输入投诉用户" />
 | 
	
		
			
				|  |  |          </el-form-item>
 | 
	
		
			
				|  |  | -        <el-form-item label="联系电话" prop="phone">
 | 
	
		
			
				|  |  | -          <el-input v-model="form.phone" placeholder="请输入联系电话" />
 | 
	
		
			
				|  |  | +        <el-form-item label="投诉标题" prop="title">
 | 
	
		
			
				|  |  | +          <el-input v-model="form.title" placeholder="请输入投诉标题" />
 | 
	
		
			
				|  |  |          </el-form-item>
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        <el-form-item label="投诉分类" prop="type">
 | 
	
		
			
				|  |  | -          <el-select v-model="form.type" placeholder="请选择投诉分类" style="width: 100%">
 | 
	
		
			
				|  |  | -            <el-option
 | 
	
		
			
				|  |  | -              v-for="category in categoryList"
 | 
	
		
			
				|  |  | -              :key="category.id"
 | 
	
		
			
				|  |  | -              :label="category.categoryName"
 | 
	
		
			
				|  |  | -              :value="category.id"
 | 
	
		
			
				|  |  | -            />
 | 
	
		
			
				|  |  | -          </el-select>
 | 
	
		
			
				|  |  | -        </el-form-item>
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -        <el-form-item label="投诉内容" prop="content">
 | 
	
		
			
				|  |  | -          <el-input v-model="form.content" type="textarea" placeholder="请输入投诉内容" :rows="4" />
 | 
	
		
			
				|  |  | +        <el-form-item label="投诉内容">
 | 
	
		
			
				|  |  | +          <el-input type="textarea" :rows="3" v-model="form.content" :min-height="192" disabled/>
 | 
	
		
			
				|  |  |          </el-form-item>
 | 
	
		
			
				|  |  | -        <!-- 图片上传 -->
 | 
	
		
			
				|  |  | -        <el-form-item label="投诉凭证" prop="url">
 | 
	
		
			
				|  |  | -          <image-upload
 | 
	
		
			
				|  |  | -            v-model="form.url"
 | 
	
		
			
				|  |  | -            :limit="0"
 | 
	
		
			
				|  |  | -            :file-size="5"
 | 
	
		
			
				|  |  | -            @change="handleImageChange"
 | 
	
		
			
				|  |  | -          />
 | 
	
		
			
				|  |  | -          <el-button type="primary" @click="submitForm">提交</el-button>
 | 
	
		
			
				|  |  | +        <el-form-item label="投诉图片" prop="images">
 | 
	
		
			
				|  |  | +          <div class="demo-image__preview">
 | 
	
		
			
				|  |  | +            <el-image
 | 
	
		
			
				|  |  | +              style="width: 100px; height: 100px"
 | 
	
		
			
				|  |  | +              :src="form.images"
 | 
	
		
			
				|  |  | +              @click="imageClick(form.images)"
 | 
	
		
			
				|  |  | +              :preview-src-list="srcList">
 | 
	
		
			
				|  |  | +            </el-image>
 | 
	
		
			
				|  |  | +          </div>
 | 
	
		
			
				|  |  |          </el-form-item>
 | 
	
		
			
				|  |  | -        <el-form-item label="投诉状态" prop="status" v-if="form.id">
 | 
	
		
			
				|  |  | -          <el-select v-model="form.status" placeholder="请选择投诉状态">
 | 
	
		
			
				|  |  | -            <el-option label="待处理" value="0" />
 | 
	
		
			
				|  |  | -            <el-option label="已处理" value="1" />
 | 
	
		
			
				|  |  | +        <el-form-item label="投诉类型" prop="type">
 | 
	
		
			
				|  |  | +          <el-select v-model="form.type" placeholder="请选择投诉类型" clearable size="small">
 | 
	
		
			
				|  |  | +            <el-option v-for="item in typeList" :label="item.value" :value="item.type" />
 | 
	
		
			
				|  |  |            </el-select>
 | 
	
		
			
				|  |  |          </el-form-item>
 | 
	
		
			
				|  |  | -        <el-form-item label="处理备注" prop="remark" v-if="form.id">
 | 
	
		
			
				|  |  | -          <el-input v-model="form.remark" type="textarea" placeholder="请输入处理备注" :rows="3" />
 | 
	
		
			
				|  |  | +        <el-form-item label="备注" prop="remark">
 | 
	
		
			
				|  |  | +          <el-input v-model="form.remark" placeholder="请输入备注" />
 | 
	
		
			
				|  |  |          </el-form-item>
 | 
	
		
			
				|  |  |        </el-form>
 | 
	
		
			
				|  |  |        <div slot="footer" class="dialog-footer">
 | 
	
	
		
			
				|  | @@ -181,54 +168,33 @@
 | 
	
		
			
				|  |  |          <el-button @click="cancel">取 消</el-button>
 | 
	
		
			
				|  |  |        </div>
 | 
	
		
			
				|  |  |      </el-dialog>
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -    <!-- 投诉详情对话框 -->
 | 
	
		
			
				|  |  | -    <el-dialog title="投诉详情" :visible.sync="detailOpen" width="600px" append-to-body>
 | 
	
		
			
				|  |  | -      <el-descriptions :column="2" border>
 | 
	
		
			
				|  |  | -        <el-descriptions-item label="投诉单号">{{ detailData.complaintNo }}</el-descriptions-item>
 | 
	
		
			
				|  |  | -        <el-descriptions-item label="投诉状态">
 | 
	
		
			
				|  |  | -          <el-tag v-if="detailData.status === '0'" type="warning">待处理</el-tag>
 | 
	
		
			
				|  |  | -          <el-tag v-else-if="detailData.status === '1'" type="success">已处理</el-tag>
 | 
	
		
			
				|  |  | -        </el-descriptions-item>
 | 
	
		
			
				|  |  | -        <el-descriptions-item label="投诉人">{{ detailData.complainantName }}</el-descriptions-item>
 | 
	
		
			
				|  |  | -        <el-descriptions-item label="联系电话">{{ detailData.phone }}</el-descriptions-item>
 | 
	
		
			
				|  |  | -        <el-descriptions-item label="投诉分类">{{ detailData.categoryName }}</el-descriptions-item>
 | 
	
		
			
				|  |  | -        <el-descriptions-item label="投诉时间" :span="2">
 | 
	
		
			
				|  |  | -          {{ parseTime(detailData.createTime, '{y}-{m}-{d} {h}:{i}:{s}') }}
 | 
	
		
			
				|  |  | -        </el-descriptions-item>
 | 
	
		
			
				|  |  | -        <el-descriptions-item label="投诉内容" :span="2">{{ detailData.content }}</el-descriptions-item>
 | 
	
		
			
				|  |  | -        <el-descriptions-item label="处理备注" :span="2" v-if="detailData.remark">
 | 
	
		
			
				|  |  | -          {{ detailData.remark }}
 | 
	
		
			
				|  |  | -        </el-descriptions-item>
 | 
	
		
			
				|  |  | -      </el-descriptions>
 | 
	
		
			
				|  |  | -      <div slot="footer" class="dialog--footer">
 | 
	
		
			
				|  |  | -        <el-button @click="detailOpen = false">关 闭</el-button>
 | 
	
		
			
				|  |  | -      </div>
 | 
	
		
			
				|  |  | -    </el-dialog>
 | 
	
		
			
				|  |  |    </div>
 | 
	
		
			
				|  |  |  </template>
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  <script>
 | 
	
		
			
				|  |  | -import {
 | 
	
		
			
				|  |  | -  getComplaintPage,
 | 
	
		
			
				|  |  | -  getComplaintById,
 | 
	
		
			
				|  |  | -  submitComplaint,
 | 
	
		
			
				|  |  | -  updateComplaint,
 | 
	
		
			
				|  |  | -  deleteComplaint,
 | 
	
		
			
				|  |  | -  handleComplaint,
 | 
	
		
			
				|  |  | -  getAllCategory
 | 
	
		
			
				|  |  | -} from "@/api/complaint/complaint";
 | 
	
		
			
				|  |  | -import {parseTime} from "../../../utils/common";
 | 
	
		
			
				|  |  | -import ImageUpload from "@/components/ImageUpload/index.vue";
 | 
	
		
			
				|  |  | +import { listComplaint, getComplaint, delComplaint, addComplaint, updateComplaint, exportComplaint } from "@/api/user/complaint";
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |  export default {
 | 
	
		
			
				|  |  |    name: "Complaint",
 | 
	
		
			
				|  |  | -  components: {ImageUpload},
 | 
	
		
			
				|  |  |    data() {
 | 
	
		
			
				|  |  |      return {
 | 
	
		
			
				|  |  | -      categoryList: [],
 | 
	
		
			
				|  |  | +      srcList:[],
 | 
	
		
			
				|  |  | +      typeList:[
 | 
	
		
			
				|  |  | +        {
 | 
	
		
			
				|  |  | +          type:1,
 | 
	
		
			
				|  |  | +          value:'店铺'
 | 
	
		
			
				|  |  | +        },{
 | 
	
		
			
				|  |  | +          type:2,
 | 
	
		
			
				|  |  | +          value:'商品'
 | 
	
		
			
				|  |  | +        },{
 | 
	
		
			
				|  |  | +          type:0,
 | 
	
		
			
				|  |  | +          value:'其它'
 | 
	
		
			
				|  |  | +        },
 | 
	
		
			
				|  |  | +      ],
 | 
	
		
			
				|  |  |        // 遮罩层
 | 
	
		
			
				|  |  |        loading: true,
 | 
	
		
			
				|  |  | +      // 导出遮罩层
 | 
	
		
			
				|  |  | +      exportLoading: false,
 | 
	
		
			
				|  |  |        // 选中数组
 | 
	
		
			
				|  |  |        ids: [],
 | 
	
		
			
				|  |  |        // 非单个禁用
 | 
	
	
		
			
				|  | @@ -239,76 +205,39 @@ export default {
 | 
	
		
			
				|  |  |        showSearch: true,
 | 
	
		
			
				|  |  |        // 总条数
 | 
	
		
			
				|  |  |        total: 0,
 | 
	
		
			
				|  |  | -      // 投诉表格数据
 | 
	
		
			
				|  |  | +      // 用户投诉表格数据
 | 
	
		
			
				|  |  |        complaintList: [],
 | 
	
		
			
				|  |  |        // 弹出层标题
 | 
	
		
			
				|  |  |        title: "",
 | 
	
		
			
				|  |  |        // 是否显示弹出层
 | 
	
		
			
				|  |  |        open: false,
 | 
	
		
			
				|  |  | -      // 是否显示详情弹出层
 | 
	
		
			
				|  |  | -      detailOpen: false,
 | 
	
		
			
				|  |  | -      // 详情数据
 | 
	
		
			
				|  |  | -      detailData: {},
 | 
	
		
			
				|  |  | -      // 日期范围
 | 
	
		
			
				|  |  | -      dateRange: [],
 | 
	
		
			
				|  |  |        // 查询参数
 | 
	
		
			
				|  |  |        queryParams: {
 | 
	
		
			
				|  |  |          pageNum: 1,
 | 
	
		
			
				|  |  |          pageSize: 10,
 | 
	
		
			
				|  |  | -        complaintNo: null,
 | 
	
		
			
				|  |  | -        status: null,
 | 
	
		
			
				|  |  | -        startTime: null,
 | 
	
		
			
				|  |  | -        endTime: null
 | 
	
		
			
				|  |  | +        fsUserId: null,
 | 
	
		
			
				|  |  | +        title: null,
 | 
	
		
			
				|  |  | +        content: null,
 | 
	
		
			
				|  |  | +        images: null,
 | 
	
		
			
				|  |  | +        type:null,
 | 
	
		
			
				|  |  | +        linkId: null,
 | 
	
		
			
				|  |  | +        nickName: null,
 | 
	
		
			
				|  |  |        },
 | 
	
		
			
				|  |  |        // 表单参数
 | 
	
		
			
				|  |  |        form: {},
 | 
	
		
			
				|  |  |        // 表单校验
 | 
	
		
			
				|  |  |        rules: {
 | 
	
		
			
				|  |  | -        complainantName: [
 | 
	
		
			
				|  |  | -          { required: true, message: "投诉人姓名不能为空", trigger: "blur" }
 | 
	
		
			
				|  |  | -        ],
 | 
	
		
			
				|  |  | -        phone: [
 | 
	
		
			
				|  |  | -          { required: true, message: "联系电话不能为空", trigger: "blur" },
 | 
	
		
			
				|  |  | -          { pattern: /^1[3|4|5|6|7|8|9][0-9]\d{8}$/, message: "请输入正确的手机号码", trigger: "blur" }
 | 
	
		
			
				|  |  | -        ],
 | 
	
		
			
				|  |  | -        type: [
 | 
	
		
			
				|  |  | -          { required: true, message: "投诉分类不能为空", trigger: "change" }
 | 
	
		
			
				|  |  | -        ],
 | 
	
		
			
				|  |  | -        content: [
 | 
	
		
			
				|  |  | -          { required: true, message: "投诉内容不能为空", trigger: "blur" }
 | 
	
		
			
				|  |  | -        ]
 | 
	
		
			
				|  |  |        }
 | 
	
		
			
				|  |  |      };
 | 
	
		
			
				|  |  |    },
 | 
	
		
			
				|  |  |    created() {
 | 
	
		
			
				|  |  | -    this.getCategoryList();
 | 
	
		
			
				|  |  |      this.getList();
 | 
	
		
			
				|  |  |    },
 | 
	
		
			
				|  |  |    methods: {
 | 
	
		
			
				|  |  | -    handleImageChange(newImages) {
 | 
	
		
			
				|  |  | -      this.form.url = newImages;
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    /** 获取投诉分类列表 */
 | 
	
		
			
				|  |  | -    getCategoryList() {
 | 
	
		
			
				|  |  | -      getAllCategory().then(response => {
 | 
	
		
			
				|  |  | -        this.categoryList = response.data || [];
 | 
	
		
			
				|  |  | -      }).catch(() => {
 | 
	
		
			
				|  |  | -        this.$message.error('获取投诉分类失败');
 | 
	
		
			
				|  |  | -        this.categoryList = [];
 | 
	
		
			
				|  |  | -      });
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    parseTime,
 | 
	
		
			
				|  |  | -    /** 查询投诉列表 */
 | 
	
		
			
				|  |  | +    /** 查询用户投诉列表 */
 | 
	
		
			
				|  |  |      getList() {
 | 
	
		
			
				|  |  |        this.loading = true;
 | 
	
		
			
				|  |  | -      if (this.dateRange != null && this.dateRange.length === 2) {
 | 
	
		
			
				|  |  | -        this.queryParams.startTime = this.dateRange[0];
 | 
	
		
			
				|  |  | -        this.queryParams.endTime = this.dateRange[1];
 | 
	
		
			
				|  |  | -      } else {
 | 
	
		
			
				|  |  | -        this.queryParams.startTime = null;
 | 
	
		
			
				|  |  | -        this.queryParams.endTime = null;
 | 
	
		
			
				|  |  | -      }
 | 
	
		
			
				|  |  | -      getComplaintPage(this.queryParams).then(response => {
 | 
	
		
			
				|  |  | +      listComplaint(this.queryParams).then(response => {
 | 
	
		
			
				|  |  |          this.complaintList = response.rows;
 | 
	
		
			
				|  |  |          this.total = response.total;
 | 
	
		
			
				|  |  |          this.loading = false;
 | 
	
	
		
			
				|  | @@ -323,11 +252,18 @@ export default {
 | 
	
		
			
				|  |  |      reset() {
 | 
	
		
			
				|  |  |        this.form = {
 | 
	
		
			
				|  |  |          id: null,
 | 
	
		
			
				|  |  | -        complainantName: null,
 | 
	
		
			
				|  |  | -        phone: null,
 | 
	
		
			
				|  |  | +        fsUserId: null,
 | 
	
		
			
				|  |  | +        title: null,
 | 
	
		
			
				|  |  |          content: null,
 | 
	
		
			
				|  |  | -        status: "0",
 | 
	
		
			
				|  |  | -        remark: null
 | 
	
		
			
				|  |  | +        images: null,
 | 
	
		
			
				|  |  | +        type: null,
 | 
	
		
			
				|  |  | +        linkId: null,
 | 
	
		
			
				|  |  | +        createTime: null,
 | 
	
		
			
				|  |  | +        createBy: null,
 | 
	
		
			
				|  |  | +        updateTime: null,
 | 
	
		
			
				|  |  | +        updateBy: null,
 | 
	
		
			
				|  |  | +        remark: null,
 | 
	
		
			
				|  |  | +        nickName: null,
 | 
	
		
			
				|  |  |        };
 | 
	
		
			
				|  |  |        this.resetForm("form");
 | 
	
		
			
				|  |  |      },
 | 
	
	
		
			
				|  | @@ -338,8 +274,8 @@ export default {
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  |      /** 重置按钮操作 */
 | 
	
		
			
				|  |  |      resetQuery() {
 | 
	
		
			
				|  |  | -      this.dateRange = [];
 | 
	
		
			
				|  |  |        this.resetForm("queryForm");
 | 
	
		
			
				|  |  | +      this.queryParams.nickName = null;
 | 
	
		
			
				|  |  |        this.handleQuery();
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  |      // 多选框选中数据
 | 
	
	
		
			
				|  | @@ -352,86 +288,71 @@ export default {
 | 
	
		
			
				|  |  |      handleAdd() {
 | 
	
		
			
				|  |  |        this.reset();
 | 
	
		
			
				|  |  |        this.open = true;
 | 
	
		
			
				|  |  | -      this.title = "添加投诉";
 | 
	
		
			
				|  |  | +      this.title = "添加用户投诉";
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  |      /** 修改按钮操作 */
 | 
	
		
			
				|  |  |      handleUpdate(row) {
 | 
	
		
			
				|  |  |        this.reset();
 | 
	
		
			
				|  |  |        const id = row.id || this.ids
 | 
	
		
			
				|  |  | -      getComplaintById(id).then(response => {
 | 
	
		
			
				|  |  | +      getComplaint(id).then(response => {
 | 
	
		
			
				|  |  |          this.form = response.data;
 | 
	
		
			
				|  |  |          this.open = true;
 | 
	
		
			
				|  |  | -        this.title = "修改投诉";
 | 
	
		
			
				|  |  | -      });
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    /** 查看详情 */
 | 
	
		
			
				|  |  | -    handleDetail(row) {
 | 
	
		
			
				|  |  | -      getComplaintById(row.id).then(response => {
 | 
	
		
			
				|  |  | -        this.detailData = response.data;
 | 
	
		
			
				|  |  | -        this.detailOpen = true;
 | 
	
		
			
				|  |  | +        this.title = "修改用户投诉";
 | 
	
		
			
				|  |  |        });
 | 
	
		
			
				|  |  |      },
 | 
	
		
			
				|  |  | -    /** 处理投诉 */
 | 
	
		
			
				|  |  | -    handleProcess(row) {
 | 
	
		
			
				|  |  | -      this.$confirm('是否确认将投诉单号为"' + row.complaintNo + '"的投诉标记为已处理?').then(() => {
 | 
	
		
			
				|  |  | -        handleComplaint(row.id).then(() => {
 | 
	
		
			
				|  |  | -          this.$message.success('处理成功');
 | 
	
		
			
				|  |  | -          this.getList();
 | 
	
		
			
				|  |  | -        }).catch(() => {
 | 
	
		
			
				|  |  | -          this.$message.error('处理失败');
 | 
	
		
			
				|  |  | -        });
 | 
	
		
			
				|  |  | -      });
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    /** 删除投诉 */
 | 
	
		
			
				|  |  | -    handleDelete(row) {
 | 
	
		
			
				|  |  | -      const ids = row ? [row.id] : this.ids;
 | 
	
		
			
				|  |  | -      this.$confirm('确认删除选中的投诉吗?').then(() => {
 | 
	
		
			
				|  |  | -        deleteComplaint(ids).then(() => {
 | 
	
		
			
				|  |  | -          this.$message.success('删除成功');
 | 
	
		
			
				|  |  | -          this.getList();
 | 
	
		
			
				|  |  | -        }).catch(() => {
 | 
	
		
			
				|  |  | -          this.$message.error('删除失败');
 | 
	
		
			
				|  |  | -        });
 | 
	
		
			
				|  |  | -      });
 | 
	
		
			
				|  |  | -    },
 | 
	
		
			
				|  |  | -    /** 提交表单 */
 | 
	
		
			
				|  |  | +    /** 提交按钮 */
 | 
	
		
			
				|  |  |      submitForm() {
 | 
	
		
			
				|  |  | -      this.$refs['form'].validate((valid) => {
 | 
	
		
			
				|  |  | +      this.$refs["form"].validate(valid => {
 | 
	
		
			
				|  |  |          if (valid) {
 | 
	
		
			
				|  |  | -          if (this.form.id) {
 | 
	
		
			
				|  |  | -            updateComplaint(this.form.id, this.form).then(() => {
 | 
	
		
			
				|  |  | -              this.$message.success('修改成功');
 | 
	
		
			
				|  |  | +          if (this.form.id != null) {
 | 
	
		
			
				|  |  | +            updateComplaint(this.form).then(response => {
 | 
	
		
			
				|  |  | +              this.msgSuccess("修改成功");
 | 
	
		
			
				|  |  | +              this.open = false;
 | 
	
		
			
				|  |  |                this.getList();
 | 
	
		
			
				|  |  | -              this.cancel();
 | 
	
		
			
				|  |  | -            }).catch(() => {
 | 
	
		
			
				|  |  | -              this.$message.error('修改失败');
 | 
	
		
			
				|  |  |              });
 | 
	
		
			
				|  |  |            } else {
 | 
	
		
			
				|  |  | -            submitComplaint(this.form).then(() => {
 | 
	
		
			
				|  |  | -              this.$message.success('添加成功');
 | 
	
		
			
				|  |  | +            addComplaint(this.form).then(response => {
 | 
	
		
			
				|  |  | +              this.msgSuccess("新增成功");
 | 
	
		
			
				|  |  | +              this.open = false;
 | 
	
		
			
				|  |  |                this.getList();
 | 
	
		
			
				|  |  | -              this.cancel();
 | 
	
		
			
				|  |  | -            }).catch(() => {
 | 
	
		
			
				|  |  | -              this.$message.error('添加失败');
 | 
	
		
			
				|  |  |              });
 | 
	
		
			
				|  |  |            }
 | 
	
		
			
				|  |  | -        } else {
 | 
	
		
			
				|  |  | -          return false;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |        });
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    /** 删除按钮操作 */
 | 
	
		
			
				|  |  | +    handleDelete(row) {
 | 
	
		
			
				|  |  | +      const ids = row.id || this.ids;
 | 
	
		
			
				|  |  | +      this.$confirm('是否确认删除用户投诉编号为"' + ids + '"的数据项?', "警告", {
 | 
	
		
			
				|  |  | +        confirmButtonText: "确定",
 | 
	
		
			
				|  |  | +        cancelButtonText: "取消",
 | 
	
		
			
				|  |  | +        type: "warning"
 | 
	
		
			
				|  |  | +      }).then(function() {
 | 
	
		
			
				|  |  | +        return delComplaint(ids);
 | 
	
		
			
				|  |  | +      }).then(() => {
 | 
	
		
			
				|  |  | +        this.getList();
 | 
	
		
			
				|  |  | +        this.msgSuccess("删除成功");
 | 
	
		
			
				|  |  | +      }).catch(() => {});
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    /** 导出按钮操作 */
 | 
	
		
			
				|  |  | +    handleExport() {
 | 
	
		
			
				|  |  | +      const queryParams = this.queryParams;
 | 
	
		
			
				|  |  | +      this.$confirm('是否确认导出所有用户投诉数据项?', "警告", {
 | 
	
		
			
				|  |  | +        confirmButtonText: "确定",
 | 
	
		
			
				|  |  | +        cancelButtonText: "取消",
 | 
	
		
			
				|  |  | +        type: "warning"
 | 
	
		
			
				|  |  | +      }).then(() => {
 | 
	
		
			
				|  |  | +        this.exportLoading = true;
 | 
	
		
			
				|  |  | +        return exportComplaint(queryParams);
 | 
	
		
			
				|  |  | +      }).then(response => {
 | 
	
		
			
				|  |  | +        this.download(response.msg);
 | 
	
		
			
				|  |  | +        this.exportLoading = false;
 | 
	
		
			
				|  |  | +      }).catch(() => {});
 | 
	
		
			
				|  |  | +    },
 | 
	
		
			
				|  |  | +    imageClick(url){
 | 
	
		
			
				|  |  | +      this.srcList=[];
 | 
	
		
			
				|  |  | +      this.srcList.push(url)
 | 
	
		
			
				|  |  |      }
 | 
	
		
			
				|  |  |    }
 | 
	
		
			
				|  |  |  };
 | 
	
		
			
				|  |  |  </script>
 | 
	
		
			
				|  |  | -
 | 
	
		
			
				|  |  | -<style scoped>
 | 
	
		
			
				|  |  | -.app-container {
 | 
	
		
			
				|  |  | -  padding: 20px;
 | 
	
		
			
				|  |  | -}
 | 
	
		
			
				|  |  | -.mb8 {
 | 
	
		
			
				|  |  | -  margin-bottom: 8px;
 | 
	
		
			
				|  |  | -}
 | 
	
		
			
				|  |  | -.fixed-width {
 | 
	
		
			
				|  |  | -  width: 120px;
 | 
	
		
			
				|  |  | -}
 | 
	
		
			
				|  |  | -</style>
 |