licp
2024-12-19 5b9704b66b96c3e5ede42cb7e3f7bda90caba866
完成客户满意度搬迁
已修改1个文件
已添加4个文件
1109 ■■■■■ 文件已修改
src/assets/api/controller.js 12 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/caorui/TableCard/index.vue 68 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/caorui/ZTTable/index.vue 303 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/do/a8-customer-satisfaction/formDialog.vue 286 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/view/a8-customer-satisfaction.vue 440 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/assets/api/controller.js
@@ -42,6 +42,7 @@
    manageRecordCancel,
    manageRecordAudit,
    personnel,
    clientSatisfaction,
  }
}
@@ -547,3 +548,14 @@
const personnel = {
  selectCNSAPersonTree: '/personBasicInfo/selectCNSAPersonTree', // æŸ¥è¯¢CNAS人员侧边栏
}
// 8.3 å®¢æˆ·æ»¡æ„åº¦è°ƒæŸ¥
const clientSatisfaction = {
  pageClientSatisfaction:'/clientSatisfaction/pageClientSatisfaction', // å®¢æˆ·æ»¡æ„åº¦è°ƒæŸ¥åˆ—表
  addClientSatisfaction:'/clientSatisfaction/addClientSatisfaction', // æ–°å¢žå®¢æˆ·æ»¡æ„åº¦è°ƒæŸ¥
  updateClientSatisfaction:'/clientSatisfaction/updateClientSatisfaction', // ä¿®æ”¹æ–°å¢žå®¢æˆ·æ»¡æ„åº¦è°ƒæŸ¥
  delClientSatisfaction:'/clientSatisfaction/delClientSatisfaction', // åˆ é™¤æ–°å¢žå®¢æˆ·æ»¡æ„åº¦è°ƒæŸ¥
  pageAnalyseFile:'/clientSatisfaction/pageAnalyseFile', // æŸ¥è¯¢å®¢æˆ·åˆ†æžé™„ä»¶
  uploadAnalyseFile:'/clientSatisfaction/uploadAnalyseFile', // æ–°å¢žå®¢æˆ·åˆ†æžé™„ä»¶
  delAnalyseFile:'/clientSatisfaction/delAnalyseFile', // åˆ é™¤å®¢æˆ·åˆ†æžé™„ä»¶
}
src/components/caorui/TableCard/index.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,68 @@
<template>
  <div class="table_card">
    <div v-if="showTitle" class="title">
      <span style="font-weight: bold">{{ title }}</span>
    </div>
    <div v-if="showForm" class="table_card_form">
      <slot name="form"></slot>
    </div>
    <div>
      <slot name="table"></slot>
    </div>
  </div>
</template>
<script>
export default {
  props: {
    title: {
      type: String,
      default: '标题'
    },
    showTitle: {
      type: Boolean,
      default: true
    },
    showForm: {
      type: Boolean,
      default: true
    }
  },
  data() {
    return {};
  }
};
</script>
<style scoped>
.table_card {
  text-align: left;
}
.title {
  position: relative;
  font-size: 18px;
  color: #333;
  font-weight: 400;
  padding-left: 10px;
  margin-left: 15px;
}
.title::before {
  position: absolute;
  left: 0;
  top: 4px;
  content: '';
  width: 4px;
  height: 18px;
  background-color: #3A7BFA;
  border-radius: 2px;
}
.table_card_form {
  display: flex;
  justify-content: space-between;
  height: 34px;
  padding: 0 15px;
  margin-bottom: 10px;
}
</style>
src/components/caorui/ZTTable/index.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,303 @@
<!--
 * @FileDescription: è¡¨æ ¼ç»„ä»¶
 * @Author: æ›¹ç¿
 * @Date: 2024/09/29
 * @LastEditors: licp lichunping@guanfang.com.cn
 * @LastEditTime: 2024-12-03 11:05:06
 -->
<template>
  <div>
    <!-- è¡¨æ ¼ -->
    <el-table
        ref="multipleTable"
        v-loading="tableLoading"
        :border="border"
        :data="tableData"
        :header-cell-style="{ background: '#0e3372', color: '#cccccc' }"
        :height="height"
        :highlight-current-row="highlightCurrentRow"
        :row-class-name="rowClassName"
        :row-style="rowStyle"
        :row-key="rowKey"
        stripe
        style="width: 100%; "
        tooltip-effect="dark"
        @row-click="rowClick"
        @current-change="currentChange"
        @selection-change="handleSelectionChange"
      >
      <template v-if="isSelection">
        <el-table-column type="selection" width="55" />
      </template>
      <template>
        <el-table-column align="center" label="序号" type="index" width="60" />
      </template>
      <template v-for="(item, index) in column">
        <el-table-column :column-key="item.columnKey" :filter-method="item.filterHandler"
                         :filter-multiple="item.filterMultiple" :filtered-value="item.filteredValue"
                         :filters="item.filters" :fixed="item.fixed" :label="item.label"
                         :min-width="item.minWidth" :prop="item.prop"
                         :show-overflow-tooltip="item.showOverflowTooltip"
                         :sortable="item.sortable ? true : false" :type="item.type" :width="item.width"
                         align="center">
          <!-- <div class="123" v-if="item.type == ''"> -->
          <template v-if="item.hasOwnProperty('colunmTemplate')" :slot="item.colunmTemplate"
                    slot-scope="scope">
            <slot v-if="item.theadSlot" :index="index" :name="item.theadSlot" :row="scope.row" />
          </template>
          <template slot-scope="scope">
            <!-- æ’æ§½ -->
            <div v-if="item.dataType == 'slot'">
              <slot v-if="item.slot" :index="scope.$index" :name="item.slot" :row="scope.row" />
            </div>
            <!-- è¿›åº¦æ¡ -->
            <div v-else-if="item.dataType == 'progress'">
              <el-progress :percentage="Number(scope.row[item.prop])" />
            </div>
            <!-- tag -->
            <div v-else-if="item.dataType == 'tag'">
              <el-tag v-if="typeof dataTypeFn(scope.row[item.prop], item.formatData) == 'string'"
                      :title="scope.row[item.prop] | formatters(item.formatData)"
                      :type="formatType(scope.row[item.prop], item.formatType)">{{ scope.row[item.prop] | formatters(item.formatData) }}</el-tag>
              <el-tag v-for="(tag, index) in dataTypeFn(scope.row[item.prop], item.formatData)"
                      v-else-if="typeof dataTypeFn(scope.row[item.prop], item.formatData) == 'object'"
                      :key="index" :title="scope.row[item.prop] | formatters(item.formatData)"
                      :type="formatType(tag, item.formatType)">{{ item.tagGroup ? tag[item.tagGroup.label] ? tag[item.tagGroup.label] : tag : tag }}</el-tag>
              <el-tag v-else :title="scope.row[item.prop] | formatters(item.formatData)"
                      :type="formatType(scope.row[item.prop], item.formatType)">{{ scope.row[item.prop] | formatters(item.formatData) }}</el-tag>
            </div>
            <!-- æŒ‰é’® -->
            <div v-else-if="item.dataType == 'action'">
              <template v-for="(o, key) in item.operation">
                <el-button
                    v-if="o.type!='upload'"
                    v-show="o.showHide ? o.showHide(scope.row) : true"
                    :disabled="o.disabled ? o.disabled(scope.row) : false"
                    :icon="o.icon | iconFn(scope.row)"
                    :plain="o.plain" :size="o.size"
                    :style="{ 'color': o.color }"
                    :type="o.type | typeFn(scope.row)"
                    @click="o.clickFun(scope.row)">
                  {{ o.name }}
                </el-button>
                <el-upload
                  action="#"
                  :on-change="(file, fileList)=>o.clickFun(scope.row,file, fileList)"
                  :multiple="o.multiple?o.multiple:false"
                  :limit="o.limit?o.limit:1"
                  :disabled="o.disabled ? o.disabled(scope.row) : false"
                  :accept="o.accept?o.accept:'.jpg,.jpeg,.png,.gif,.doc,.docx,.xls,.xlsx,.ppt,.pptx,.pdf,.zip,.rar'"
                  v-if="o.type=='upload'" style="display: inline-block;width: 50px;"
                  v-show="o.showHide ? o.showHide(scope.row) : true"
                  :auto-upload="false"
                  :on-exceed="onExceed"
                  :show-file-list="false">
                  <el-button :size="o.size?o.size:'small'" type="text" :disabled="o.disabled ? o.disabled(scope.row) : false">{{o.name}}</el-button>
                </el-upload>
              </template>
            </div>
            <!--  -->
            <!-- é»˜è®¤çº¯å±•示数据 -->
            <div v-else>
              <span v-if="!item.formatData">{{ scope.row[item.prop] }}</span>
              <span v-else>{{ scope.row[item.prop] | formatters(item.formatData) }}</span>
            </div>
          </template>
          <!-- </div>   -->
        </el-table-column>
      </template>
    </el-table>
  </div>
</template>
<script>
// æ³¨ï¼šä»¥ä¸‹æ˜¯æ‰€æœ‰é…ç½®é¡¹ï¼Œå…¶ä¸­æœ€å¸¸ä½¿ç”¨çš„就是label、width、prop、dataType、slot
// label ï¼šåˆ—名,就是表头上的标签叫什么些什么,类型 string
// width:该列宽度, string
// prop:  table绑定数据字段 string,这一列要展示哪个tableData里面的字段就写哪个字段
// dataType:  å†…置多个基本的element组件可供直接使用 string
// slot  å½“`dataType`为`slot`时必带参数,参数值为插槽的 `slot` å€¼ string,具体使用方法请看下面的第4点slot插槽的使用
// fixed:列是否固定在左侧或者右侧,true è¡¨ç¤ºå›ºå®šåœ¨å·¦ä¾§ string, boolean
// sortable å¯¹åº”列是否可以排序 boolean, string
// filters æ•°æ®è¿‡æ»¤çš„选项,数组格式,数组中的元素需要有 text å’Œ value å±žæ€§ã€‚Array
// columnKey ï¼šcolumn çš„ key,如果需要使用 filter-change äº‹ä»¶ï¼Œåˆ™éœ€è¦æ­¤å±žæ€§æ ‡è¯†æ˜¯å“ªä¸ª column çš„筛选条件
// filteredValue  é€‰ä¸­çš„æ•°æ®è¿‡æ»¤é¡¹ï¼Œå¦‚果需要自定义表头过滤的渲染方式,可能会需要此属性。
// filterMultiple  æ•°æ®è¿‡æ»¤çš„选项是否多选
// minWidth å¯¹åº”列的最小宽度,与 width çš„区别是 width æ˜¯å›ºå®šçš„,min-width ä¼šæŠŠå‰©ä½™å®½åº¦æŒ‰æ¯”例分配给设置了 min-width çš„列 string
// formatData  å¯¹æ•°æ®è¿›è¡Œæ•°æ®å¤„理,接受一个回调函数 (params?: {prop}) => {}
// formatType  å½“ `dataType`为 `tag`时,对标签颜色设置 (params?: {prop}) => { return 'danger'| 'success'... }`
// operation å½“ `dataType` ä¸º `option`时,对按钮的 é…ç½®ï¼Œå…·ä½“配置项以下图为准object
// tagGroup å½“ `dataType`为 `tag`时,绑定数据集字段显示名称 object
/**
 * æ’槽的使用方法:
 */
/* <div
     slot="protocolSlot"
     slot-scope="scope"
    >
        <span>{{ scope.row.protocol }}</span>
    </div>
*/
/**
 * ä½¿ç”¨formatData进行数据处理
 */
//  {
//           type: '',
//           label: '启用状态',
//           prop: 'is_active',
//           formatData: (item) => {
//             const str = item == true ? '已启用' : '未启用'
//             return str
//           }
//         },
/**
 * operation配置
 */
//  operation配置主要是来用于表格里面的操作那一列,通常就会有很多按钮,有以下参数:
// name:按钮名称,string
// type:按钮类型,`string` | `danger | success`,以elementUi å‚数为准
// size:按钮大小,以elementUi å‚数为准
// icon:按钮上的icon,以elementUi å‚数为准
// plain:按elementUi æ–‡æ¡£ä¸ºå‡†
// clickFun:按钮的回调函数
export default {
  name: 'ZTTable',
  filters: {
    iconFn(val, row) {
      if (typeof (val) === 'function') {
        return val(row);
      } else return val;
    },
    typeFn(val, row) {
      // console.log(val, row, '11111111');
      if (typeof (val) === 'function') {
        return val(row);
      } else return val;
    },
    describeConts(val, describeCont) {
      if (typeof (describeCont) === 'function') {
        return describeCont(val);
      } else return val;
    },
    formatters(val, format) {
      if (typeof (format) === 'function') {
        return format(val);
      } else return val;
    }
  },
  props: {
    isSelection: {
      type: Boolean,
      default: false
    },
    height: {
      type: String,
      default: null
    },
    tableLoading: {
      type: Boolean,
      default: false
    },
    handleSelectionChange: {
      type: Function,
      default: () => {
        return () => {
        };
      }
    },
    rowClick: {
      type: Function,
      default: () => {
        return () => {
        };
      }
    },
    currentChange: {
      type: Function,
      default: () => {
        return () => {
        };
      }
    },
    border: {
      type: Boolean,
      default: true
    },
    highlightCurrentRow: {
      type: Boolean,
      default: false
    },
    headerCellStyle: {
      type: Object,
      default: () => {
        return {};
      }
    },
    column: {
      type: Array,
      default() {
        return [];
      }
    },
    rowClassName: {
      type: Function,
      default: () => {
      }
    },
    rowStyle: {
      type: Function,
      default: () => {
      }
    },
    tableData: {
      type: Array,
      default() {
        return [];
      }
    },
    rowKey: {
      type: String,
      default: undefined
    }
  },
  methods: {
    formatType(val, format) {
      if (typeof (format) === 'function') {
        return format(val);
      } else return '';
    },
    dataTypeFn(val, format) {
      if (typeof (format) === 'function') {
        return format(val);
      } else return val;
    },
    setCurrent(row) {
      this.$refs.multipleTable.setCurrentRow();
    },
    onExceed(){
      this.$message.warning('超出文件个数');
    }
  }
};
</script>
<style scoped>
.el-table >>> .el-table__empty-text {
  text-align: center
}
</style>
src/components/do/a8-customer-satisfaction/formDialog.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,286 @@
<template>
  <div>
    <el-dialog :close-on-click-modal="false" :close-on-press-escape="false"
               :visible.sync="formDia"
               title="客户满意度调查表"
               width="70%"
               @close="closeFormDia">
      <table border="1" cellspacing="10" class="tables">
        <tr>
          <td class="td-title">
            <p>单位名称:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-input v-model="form.unitName"
                      placeholder="请输入内容"
                      size="small">
            </el-input>
          </td>
          <td class="td-title">
            <p>日期:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-date-picker
              v-model="form.fillDate"
              format="yyyy-MM-dd"
              placeholder="选择日期"
              size="small"
              type="date"
              value-format="yyyy-MM-dd">
            </el-date-picker>
          </td>
        </tr>
        <tr>
          <td class="td-title">
            <p>姓名:</p>
          </td>
          <td class="td-info">
            <el-input v-model="form.userName"
                      placeholder="请输入内容"
                      size="small">
            </el-input>
          </td>
          <td class="td-title">
            <p>部门:</p>
          </td>
          <td class="td-info">
            <el-input v-model="form.department"
                      placeholder="请输入内容"
                      size="small">
            </el-input>
          </td>
          <td class="td-title">
            <p>联系电话:</p>
          </td>
          <td class="td-info">
            <el-input v-model="form.contactNumber"
                      placeholder="请输入内容"
                      size="small">
            </el-input>
          </td>
        </tr>
        <tr>
          <td class="td-title">
            <p>服务态度:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-radio-group v-model="form.serviceAttitude" v-removeAriaHidden>
              <el-radio :label="0">满意</el-radio>
              <el-radio :label="1">一般</el-radio>
              <el-radio :label="2">不满意</el-radio>
            </el-radio-group>
          </td>
          <td class="td-title">
            <p>建议:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-input v-model="form.serviceAttitudeSuggestion"
                      placeholder="请输入内容"
                      size="small">
            </el-input>
          </td>
        </tr>
        <tr>
          <td class="td-title">
            <p>技术能力:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-radio-group v-model="form.technicalCompetence" v-removeAriaHidden>
              <el-radio :label="0">满意</el-radio>
              <el-radio :label="1">一般</el-radio>
              <el-radio :label="2">不满意</el-radio>
            </el-radio-group>
          </td>
          <td class="td-title">
            <p>建议:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-input v-model="form.technicalCompetenceSuggestion"
                      placeholder="请输入内容"
                      size="small">
            </el-input>
          </td>
        </tr>
        <tr>
          <td class="td-title">
            <p>检测工作:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-radio-group v-model="form.inspectionWork" v-removeAriaHidden>
              <el-radio :label="0">满意</el-radio>
              <el-radio :label="1">一般</el-radio>
              <el-radio :label="2">不满意</el-radio>
            </el-radio-group>
          </td>
          <td class="td-title">
            <p>建议:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-input v-model="form.inspectionWorkSuggestion"
                      placeholder="请输入内容"
                      size="small">
            </el-input>
          </td>
        </tr>
        <tr>
          <td class="td-title">
            <p>收费合理性:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-radio-group v-model="form.reasonableFees" v-removeAriaHidden>
              <el-radio :label="0">满意</el-radio>
              <el-radio :label="1">一般</el-radio>
              <el-radio :label="2">不满意</el-radio>
            </el-radio-group>
          </td>
          <td class="td-title">
            <p>建议:</p>
          </td>
          <td class="td-info" colspan="2">
            <el-input v-model="form.reasonableFeesSuggestion"
                      placeholder="请输入内容"
                      size="small">
            </el-input>
          </td>
        </tr>
        <tr>
          <td class="td-title">
            <p>您对我们的希望:</p>
          </td>
          <td class="td-info" colspan="5">
            <el-input v-model="form.remark"
                      :rows="4"
                      placeholder="请输入内容"
                      size="small"
                      type="textarea">
            </el-input>
          </td>
        </tr>
      </table>
      <span slot="footer" class="dialog-footer">
        <el-button @click="closeFormDia">取 æ¶ˆ</el-button>
        <el-button :loading="editLoad" type="primary" @click="handleEdit">提 äº¤</el-button>
      </span>
    </el-dialog>
  </div>
</template>
<script>
export default {
  name: 'formDialog',
  // import å¼•入的组件需要注入到对象中才能使用
  components: {},
  data() {
    // è¿™é‡Œå­˜æ”¾æ•°æ®
    return {
      formDia: false,
      form: {
        unitName: '',
        fillDate: '',
        userName: '',
        department: '',
        contactNumber: '',
        serviceAttitude: '',
        technicalCompetence: '',
        technicalCompetenceSuggestion: '',
        inspectionWork: '',
        inspectionWorkSuggestion: '',
        reasonableFees: '',
        reasonableFeesSuggestion: '',
        remark: '',
        clientSatisfactionId: '',
      },
      operationType: '',
      editLoad: false,
    };
  },
  // æ–¹æ³•集合
  methods: {
    openDia (type, row) {
      this.formDia = true;
      this.operationType = type
      if (this.operationType === 'edit') {
        this.form = {...row}
      }
    },
    handleEdit () {
      if (!this.form.unitName    ) {
        this.$message.warning('请填写单位名称')
        return
      }
      if (!this.form.department    ) {
        this.$message.warning('请填写部门')
        return
      }
      this.editLoad = true
      if (this.operationType === 'add') {
        this.$axios.post(this.$api.clientSatisfaction.addClientSatisfaction, this.form, {
          headers: {
            "Content-Type": "application/json"
          },
          noQs: true
        }).then(res => {
          this.editLoad = false
          if (res.code === 201) return
          this.$message.success('提交成功')
          this.closeFormDia()
        }).catch(err => {
          console.log('err---', err);
          this.editLoad = false
        })
      } else {
        this.$axios.post(this.$api.clientSatisfaction.updateClientSatisfaction, this.form, {
          headers: {
            "Content-Type": "application/json"
          },
          noQs: true
        }).then(res => {
          this.editLoad = false
          if (res.code === 201) return
          this.$message.success('提交成功')
          this.closeFormDia()
        }).catch(err => {
          console.log('err---', err);
          this.editLoad = false
        })
      }
    },
    closeFormDia () {
      this.formDia = false;
      this.$emit('closeFormDia')
    },
  }
};
</script>
<style scoped>
>>>.el-dialog {
  margin: 10vh auto 50px !important;
}
.tables {
  table-layout: fixed;
  width: 100%;
  margin-top: 10px;
}
.td-title {
  height: 40px;
  width: 170px;
  text-align: center;
  font-size: 14px;
  word-wrap: break-word;
  white-space: normal;
  padding: 6px;
}
.td-info {
  padding: 6px;
}
.td-info1 {
  display: inline-block;
  width: 100%;
  text-align: left;
  font-size: 14px;
  word-wrap: break-word;
  white-space: normal;
}
</style>
src/components/view/a8-customer-satisfaction.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,440 @@
<template>
  <div>
    <div>
      <div class="view-title">
        <span>客户满意度</span>
        <span>
          <el-button v-if="tabIndex === '0'" size="medium" type="primary" @click="openFormDia('add')">新 å¢ž</el-button>
          <el-upload v-if="tabIndex === '1'" ref='upload'
                     :action="action"
                     :before-upload="beforeUpload" :headers="headers" :on-error="onError"
                     :on-success="handleSuccessUp" :show-file-list="false" accept='.jpg,.jpeg,.png,.gif,.doc,.docx,.xls,.xlsx,.ppt,.pptx,.pdf,.zip,.rar'>
              <el-button :loading="upLoading" size="small" type="primary">导入</el-button>
            </el-upload>
        </span>
      </div>
      <div class="search-background">
        <span v-if="tabIndex === '0'" class="search-group">
          <span style="width: 150px">单位名称:</span>
          <el-input v-model="searchForm.unitName" clearable size="small"></el-input>
        </span>
        <span v-if="tabIndex === '1'" class="search-group">
          <span style="width: 150px">文件名称:</span>
          <el-input v-model="searchForm1.fileName" clearable size="small"></el-input>
        </span>
        <span class="search-group">
          <el-button size="medium"  @click="resetSearchForm">重 ç½®</el-button>
          <el-button size="medium" type="primary" @click="searchList">查 è¯¢</el-button>
        </span>
      </div>
      <div class="table">
        <div class="table-tab">
          <el-radio-group v-model="tabIndex" @change="searchList">
            <el-radio-button label="0">客户满意度</el-radio-button>
            <el-radio-button label="1">综合分析</el-radio-button>
          </el-radio-group>
        </div>
        <div v-if="tabIndex === '0'">
          <TableCard :showForm="false" :showTitle="false">
            <template v-slot:table>
              <ZTTable
                :column="tableColumn"
                :height="'calc(100vh - 27em)'"
                :table-data="tableData"
                :table-loading="tableLoading"
                style="padding: 0 15px;margin-bottom: 16px">
              </ZTTable>
            </template>
          </TableCard>
          <el-pagination :current-page="1" :page-size="page.size" :page-sizes="[10, 20, 30, 50, 100]"
                         :total="total" layout="->,total, sizes, prev, pager, next, jumper"
                         @size-change="handleSizeChange"
                         @current-change="handleCurrentChange">
          </el-pagination>
        </div>
        <div v-if="tabIndex === '1'">
          <TableCard :showForm="false" :showTitle="false">
            <template v-slot:table>
              <ZTTable
                :column="tableColumn1"
                :height="'calc(100vh - 27em)'"
                :table-data="tableData1"
                :table-loading="tableLoading1"
                style="padding: 0 15px;margin-bottom: 16px">
              </ZTTable>
            </template>
          </TableCard>
          <el-pagination :current-page="1" :page-size="page.size" :page-sizes="[10, 20, 30, 50, 100]"
                         :total="total1" layout="->,total, sizes, prev, pager, next, jumper"
                         @size-change="handleSizeChange1"
                         @current-change="handleCurrentChange1">
          </el-pagination>
        </div>
      </div>
    </div>
    <el-dialog
      :visible.sync="lookDialogVisible"
      fullscreen
      title="查看附件" top="5vh" width="800px">
      <filePreview v-if="lookDialogVisible" :currentFile="{}"
                   :fileUrl="javaApi+'/word/'+currentInfo.fileUrl" style="height: 90vh;overflow-y: auto;"/>
    </el-dialog>
    <FormDialog v-if="formDialog" ref="formDialog" @closeFormDia="closeFormDia"></FormDialog>
  </div>
</template>
<script>
import TableCard from '../caorui/TableCard/index.vue';
import ZTTable from '../caorui/ZTTable/index.vue';
import FormDialog from '../do/a8-customer-satisfaction/formDialog.vue';
import filePreview from '../tool/file-preview.vue';
export default {
  name: 'a8-customer-satisfaction',
  // import å¼•入的组件需要注入到对象中才能使用
  components: { filePreview, FormDialog, ZTTable, TableCard },
  data() {
    // è¿™é‡Œå­˜æ”¾æ•°æ®
    return {
      searchForm: {
        unitName: '',
      },
      searchForm1: {
        fileName: '',
      },
      tabIndex: '0',
      tableColumn: [
        {
          label: '单位名称',
          prop: 'unitName',
          minWidth: '100'
        },
        {
          label: '日期',
          prop: 'fillDate',
          minWidth: '100'
        },
        {
          label: '姓名',
          prop: 'userName',
          minWidth: '100'
        },
        {
          label: '部门',
          prop: 'department',
          minWidth: '100'
        },
        {
          label: '联系电话',
          prop: 'contactNumber',
          minWidth: '100'
        },
        {
          label: '创建日期',
          prop: 'createTime',
          minWidth: '100',
        },
        {
          dataType: 'action',
          minWidth: '80',
          label: '操作',
          operation: [
            {
              name: '编辑',
              type: 'text',
              clickFun: (row) => {
                this.openFormDia('edit', row);
              },
            },
            {
              name: '删除',
              type: 'text',
              color: '#f56c6c',
              clickFun: (row) => {
                this.delPlan(row)
              }
            }
          ]
        }
      ],
      tableData: [],
      tableLoading: false,
      page: {
        size: 20,
        current: 1,
      },
      total: 0,
      tableColumn1: [
        {
          label: '附件名称',
          prop: 'fileName',
          minWidth: '100'
        },
        {
          label: '创建人',
          prop: 'userName',
          minWidth: '100'
        },
        {
          label: '创建时间',
          prop: 'createTime',
          minWidth: '100'
        },
        {
          dataType: 'action',
          minWidth: '50',
          label: '操作',
          operation: [
            {
              name: '预览',
              type: 'text',
              clickFun: (row) => {
                this.handleLook(row)
              }
            },
            {
              name: '下载',
              type: 'text',
              clickFun: (row) => {
                this.upload(row);
              },
            },
            {
              name: '删除',
              type: 'text',
              color: '#f56c6c',
              clickFun: (row) => {
                this.delFile(row)
              }
            }
          ]
        }
      ],
      tableData1: [],
      tableLoading1: false,
      page1: {
        size: 20,
        current: 1,
      },
      total1: 0,
      formDialog: false,
      upLoading: false,
      currentInfo:{},
      lookDialogVisible: false,
    };
  },
  mounted() {
    this.searchList()
  },
  // æ–¹æ³•集合
  methods: {
    // æŸ¥è¯¢åˆ—表
    searchList () {
      const entity = this.tabIndex === '0' ? this.searchForm : this.searchForm1
      const page = this.tabIndex === '0' ? this.page : this.page1
      if (this.tabIndex === '0') {
        this.tableLoading = true
        this.$axios.post(this.$api.clientSatisfaction.pageClientSatisfaction, {entity, page}, {
          headers: {
            "Content-Type": "application/json"
          },
          noQs: true
        }).then(res => {
          this.tableLoading = false
          if (res.code === 201) return
          this.tableData = res.data.records
          this.total = res.data.total
        }).catch(err => {
          console.log('err---', err);
          this.tableLoading = false
        })
      } else {
        this.tableLoading1 = true
        this.$axios.post(this.$api.clientSatisfaction.pageAnalyseFile, {entity, page}, {
          headers: {
            "Content-Type": "application/json"
          },
          noQs: true
        }).then(res => {
          this.tableLoading1 = false
          if (res.code === 201) return
          this.tableData1 = res.data.records
          this.total1 = res.data.total
        }).catch(err => {
          console.log('err---', err);
          this.tableLoading1 = false
        })
      }
    },
    openFormDia (type, row) {
      this.formDialog = true
      this.$nextTick(() => {
        this.$refs.formDialog.openDia(type, row);
      })
    },
    closeFormDia () {
      this.formDialog = false
      this.searchList()
    },
    // é‡ç½®æŸ¥è¯¢æ¡ä»¶
    resetSearchForm () {
      this.searchForm.unitName = '';
      this.searchForm1.fileName = '';
      this.searchList()
    },
    // å¯¼å…¥æµç¨‹
    beforeUpload(file) {
      if (file.size > 1024 * 1024 * 10) {
        this.$message.error('上传文件不超过10M');
        this.$refs.upload.clearFiles()
        return false;
      } else {
        this.upLoading = true;
        return true;
      }
    },
    onError(err, file, fileList) {
      this.$message.error('上传失败')
      this.$refs.upload.clearFiles()
    },
    handleSuccessUp(response) {
      this.upLoading = false;
      if (response.code == 200) {
        this.$message.success('上传成功');
        this.searchList()
      }
    },
    // åˆ é™¤å®¢æˆ·æ»¡æ„åº¦
    delPlan (row) {
      this.$confirm('此操作将永久删除该数据, æ˜¯å¦ç»§ç»­?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        this.tableLoading = true
        this.$axios.get(this.$api.clientSatisfaction.delClientSatisfaction + '?clientSatisfactionId=' + row.clientSatisfactionId).then(res => {
          this.tableLoading = false
          if (res.code === 201) return
          this.$message.success('删除成功')
          this.searchList()
        }).catch(err => {
          this.tableLoading = false
          console.log('err---', err);
        })
      }).catch(() => {
        this.$message({
          type: 'info',
          message: '已取消删除'
        });
      });
    },
    // æŸ¥çœ‹æ–‡ä»¶
    handleLook(row){
      this.currentInfo = row
      this.lookDialogVisible = true
    },
    // ä¸‹è½½å®¢æˆ·ç¦å»º
    upload (row) {
      let url = '';
      if(row.type==1){
        url = this.javaApi+'/img/'+row.fileUrl
        file.downloadIamge(url,row.fileName)
      }else{
        url = this.javaApi+'/word/'+row.fileUrl
        const link = document.createElement('a');
        link.href = url;
        link.download = row.fileName;
        link.click();
      }
    },
    // åˆ é™¤å®¢æˆ·åˆ†æžé™„ä»¶
    delFile (row) {
      this.$confirm('此操作将永久删除该数据, æ˜¯å¦ç»§ç»­?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        this.tableLoading = true
        this.$axios.get(this.$api.clientSatisfaction.delAnalyseFile + '?analyseFileId=' + row.analyseFileId).then(res => {
          this.tableLoading = false
          if (res.code === 201) return
          this.$message.success('删除成功')
          this.searchList()
        }).catch(err => {
          this.tableLoading = false
          console.log('err---', err);
        })
      }).catch(() => {
        this.$message({
          type: 'info',
          message: '已取消删除'
        });
      });
    },
    // åˆ†é¡µ
    handleSizeChange(val) {
      this.page.size = val;
      this.searchList();
    },
    handleCurrentChange(val) {
      this.page.current = val;
      this.searchList();
    },
    //
    // åˆ†é¡µ
    handleSizeChange1(val) {
      this.page1.size = val;
      this.searchList();
    },
    handleCurrentChange1(val) {
      this.page1.current = val;
      this.searchList();
    },
    //
  },
  // ç”¨äºŽä¸Šä¼ æ–‡ä»¶çš„信息
  computed: {
    headers() {
      return {
        'token': sessionStorage.getItem('token')
      }
    },
    action() {
      return this.javaApi + this.$api.clientSatisfaction.uploadAnalyseFile
    }
  },
};
</script>
<style scoped>
.view-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 60px;
  padding-left: 20px;
}
.search-background {
  width: 100%;
  height: 80px;
  line-height: 80px;
  background-color: #ffffff;
  display: flex;
}
.search-group {
  display: flex;
  align-items: center;
  margin: 0 20px;
}
.table {
  margin-top: 20px;
  background-color: #ffffff;
  padding-top: 20px;
}
.table-tab {
  margin: 0 20px 20px 20px;
}
</style>