瀏覽代碼

反馈模块

DESKTOP-SVI9JE1\muzen 2 年之前
父節點
當前提交
47a1bc1252

+ 94 - 0
src/views/operation/feedbacklist/detail.vue

@@ -0,0 +1,94 @@
+<template>
+  <div class='app-container'>
+    <el-form :model="form" ref="form" :rules="rules" label-width="100px" :disabled="disabled">
+      <el-form-item label="用户Id:">
+        <span>{{ form.uid }}</span>
+      </el-form-item>
+      <el-form-item label="手机号:">
+        <span>{{ form.phone }}</span>
+      </el-form-item>
+      <el-form-item label="图片:">
+        <el-image v-for="item in form.url" :key="item" :src="item" :preview-src-list="form.url">
+          <span slot="error">暂无图片</span>
+        </el-image>
+      </el-form-item>
+      <el-form-item label="反馈类型:">
+        <span>{{ form.type }}</span>
+      </el-form-item>
+      <el-form-item label="反馈内容:">
+        <span>{{ form.content }}</span>
+      </el-form-item>
+      <el-form-item label="回复:" prop="reply" style="width: 500px;">
+        <el-input v-model="form.reply" type="textarea" :rows="10" placeholder="请输入回复" />
+      </el-form-item>
+    </el-form>
+    <div class="form-btn">
+      <el-button @click="close">取消</el-button>
+      <el-button v-if="!disabled" type="primary" @click="getSubmit">确定</el-button>
+    </div>
+  </div>
+</template>
+
+<script>
+import { detail, submit } from '@/api/operation/feedbacklist'
+export default {
+  data() {
+    return {
+      // 表单
+      form: {
+        id: this.$route.query.id
+      },
+      // 校验
+      rules: {
+        reply: [{
+          required: true, message: '请输入回复', trigger: 'blur'
+        }]
+      },
+      // 只读
+      disabled: this.$route.query.boolean ? Boolean(this.$route.query.boolean) : false
+    }
+  },
+  mounted() {
+    this.getDetail()
+  },
+  methods: {
+    // 详情
+    getDetail() {
+      detail(this.form.id).then(res => {
+        if (res.code === 0) {
+          this.form = res.data
+          this.form.url = res.data.url.split(',')
+        }
+      })
+    },
+
+    // 取消
+    close() {
+      this.$tab.closeOpenPage("/operation/feedback/feedbacklist");
+    },
+
+    // 提交
+    getSubmit() {
+      this.$refs.form.validate((valid) => {
+        if (valid) {
+          submit(this.form.id, this.form.reply).then(res => {
+            if (res.code === 0) {
+              this.$message.success('提交成功!')
+              this.close()
+            }
+          })
+        } else {
+          return false
+        }
+      })
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.el-image {
+  width: 200px;
+  margin-right: 10px;
+}
+</style>

+ 123 - 0
src/views/operation/feedbacklist/index.vue

@@ -0,0 +1,123 @@
+<template>
+  <div class='app-container'>
+    <!-- 搜索 -->
+    <el-form inline size="mini">
+      <el-form-item label="用户Id:">
+        <el-input v-model="form.uid" placeholder="请输入用户Id" />
+      </el-form-item>
+      <el-form-item label="手机号:">
+        <el-input v-model="form.phone" placeholder="请输入用户手机号" />
+      </el-form-item>
+      <el-form-item label="反馈类型:">
+        <el-select v-model="form.type" placeholder="请选择反馈类型">
+          <el-option v-for="item in typeOptions" :key="item.value" :value="item.value" :label="item.label" />
+        </el-select>
+      </el-form-item>
+      <el-form-item label="反馈时间:">
+        <el-date-picker v-model="form.listDate" type="datetimerange" start-placeholder="开始日期" end-placeholder="结束日期"
+          value-format="yyyy-MM-dd HH:mm:ss" />
+      </el-form-item>
+      <el-form-item>
+        <el-button type="primary" icon="el-icon-search" @click="getSearch">搜索</el-button>
+        <el-button icon="el-icon-refresh" @click="getRefresh">重置</el-button>
+        <el-button type="primary" icon="el-icon-download" @click="getDownload">导出</el-button>
+      </el-form-item>
+    </el-form>
+    <!-- 列表 -->
+    <el-table :data="tableData" v-loading="loading">
+      <el-table-column label="序号" type="index" align="center" />
+      <el-table-column label="用户Id" prop="uid" align="center" show-overflow-tooltip />
+      <el-table-column label="手机号" prop="phone" align="center" />
+      <el-table-column label="图片" align="center" width="100px">
+        <template slot-scope="scope">
+          <el-image :src="scope.row.url.split(',')[0]">
+            <span slot="error" />
+          </el-image>
+        </template>
+      </el-table-column>
+      <el-table-column label="反馈类型" prop="type" align="center" />
+      <el-table-column label="反馈内容" prop="content" align="center" show-overflow-tooltip />
+      <el-table-column label="回复" prop="reply" align="center" show-overflow-tooltip />
+      <el-table-column label="反馈时间" prop="updateTime" align="center" />
+      <el-table-column label="操作" align="center">
+        <template slot-scope="scope">
+          <el-button type="text" @click="getDetail(scope.row.id, true)">查看</el-button>
+          <el-button type="text" @click="getDetail(scope.row.id)">回复</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+    <pagination v-show="total > 0" :total="total" :page.sync="form.pageNum" :limit.sync="form.pageSize"
+      @pagination="getList" />
+  </div>
+</template>
+
+<script>
+import { saveAs } from 'file-saver'
+import { list, download } from '@/api/operation/feedbacklist'
+export default {
+  data() {
+    return {
+      // 遮罩层
+      loading: false,
+      // 表单
+      form: {
+        pageNum: 1,
+        pageSize: 10
+      },
+      // 总数据
+      total: 0,
+      // 列表
+      tableData: [],
+      // 反馈类型
+      typeOptions: []
+    }
+  },
+  mounted() {
+    this.getList()
+  },
+  methods: {
+    // 列表
+    getList() {
+      this.loading = true
+      list(this.form).then(res => {
+        if (res.code === 0) {
+          this.tableData = res.data.records
+          this.total = res.data.total
+          this.loading = false
+        }
+      })
+    },
+
+    // 搜索
+    getSearch() {
+      this.form.pageNum = 1
+      this.getList()
+    },
+
+    // 重置
+    getRefresh() {
+      this.form = {
+        pageNum: 1,
+        pageSize: 10
+      }
+      this.getList()
+    },
+
+    // 导出
+    getDownload() {
+      this.download('/admin/opinions/excelDownload', this.form, '反馈列表.xlsx')
+    },
+
+    // 查看 回复
+    getDetail(id, boolean) {
+      this.$router.push({
+        path: `/operation/feedback/feedbacklist/detail`,
+        query: {
+          id: id,
+          boolean: boolean
+        }
+      })
+    }
+  }
+}
+</script>

+ 140 - 0
src/views/operation/feedbacktype/index.vue

@@ -0,0 +1,140 @@
+<template>
+  <div class='app-container'>
+    <!-- 搜索 -->
+    <el-form inline size="mini">
+      <el-form-item>
+        <el-button type="primary" icon="el-icon-plus" @click="getDialog('新增')">新增</el-button>
+      </el-form-item>
+    </el-form>
+    <!-- 列表 -->
+    <el-table :data="tableData" v-loading="loading">
+      <el-table-column label="序号" type="index" align="center"></el-table-column>
+      <el-table-column label="排序" prop="sort" align="center"></el-table-column>
+      <el-table-column label="类型名称" prop="name" align="center"></el-table-column>
+      <el-table-column label="创建时间" prop="createTime" align="center"></el-table-column>
+      <el-table-column label="操作" align="center">
+        <template slot-scope="scope">
+          <el-button type="text" @click="getDialog('编辑', scope.row.id)">编辑</el-button>
+          <el-button type="delete" @click="getDelete(scope.row)">删除</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+    <pagination v-show="total > 0" :total="total" :page.sync="form.pageNum" :limit.sync="form.pageSize"
+      @pagination="getList" />
+    <!-- 弹窗 -->
+    <el-dialog :visible.sync="dialogVisible" :title="title" width="500px" :before-close="close">
+      <el-form :model="dialogForm" ref="dialogForm" :rules="rules" label-width="100px">
+        <el-form-item label="类型名称:" prop="name">
+          <el-input v-model="dialogForm.name" placeholder="请输入类型名称" />
+        </el-form-item>
+        <el-form-item label="排序:" prop="sort">
+          <el-input-number v-model="dialogForm.sort" :min="1" />
+        </el-form-item>
+      </el-form>
+      <div slot="footer">
+        <el-button @click="close">取消</el-button>
+        <el-button type="primary" @click="getSubmit">确定</el-button>
+      </div>
+    </el-dialog>
+  </div>
+</template>
+
+<script>
+import { list, detail, remove, submit } from '@/api/operation/feedbacktype'
+export default {
+  data() {
+    return {
+      // 遮罩层
+      loading: false,
+      // 表单
+      form: {
+        pageNum: 1,
+        pageSize: 10
+      },
+      // 总数据
+      total: 0,
+      // 列表
+      tableData: [],
+      // 弹窗
+      dialogVisible: false,
+      // 弹窗标题
+      title: '新增',
+      // 弹窗表单
+      dialogForm: {},
+      // 校验
+      rules: {
+        name: [{
+          required: true, message: '请输入类型名称', trigger: 'blur'
+        }],
+        sort: [{
+          required: true, message: '请输入排序', trigger: 'blur'
+        }]
+      }
+    }
+  },
+  mounted() {
+    this.getList()
+  },
+  methods: {
+    // 列表
+    getList() {
+      this.loading = true
+      list(this.form).then(res => {
+        if (res.code === 0) {
+          this.tableData = res.data.records
+          this.total = res.data.total
+          this.loading = false
+        }
+      })
+    },
+
+    // 删除
+    getDelete(row) {
+      this.$confirm(`是否删除${row.name}?`, '提示', {
+        type: "warning"
+      }).then(() => {
+        remove(row.id).then(res => {
+          if (res.code === 0) {
+            this.$message.success('删除成功!')
+            this.getList()
+          }
+        })
+      }).catch(() => { })
+    },
+
+    // 弹窗
+    getDialog(title, id) {
+      this.dialogVisible = true
+      this.title = title
+      if (id) {
+        detail(id).then(res => {
+          this.dialogForm = res.data
+        })
+      }
+    },
+
+    // 关闭
+    close() {
+      this.dialogVisible = false
+      this.dialogForm = {}
+    },
+
+    // 确定
+    getSubmit() {
+      this.$refs.dialogForm.validate((valid) => {
+        if (valid) {
+          submit(this.dialogForm).then(res => {
+            if (res.code === 0) {
+              this.$message.success('提交成功!')
+              this.close()
+              this.getList()
+            }
+          })
+        } else {
+          return false
+        }
+      })
+    }
+  }
+}
+</script>