فهرست منبع

商品管理 商品推荐

DESKTOP-O04BTUJ\muzen 3 سال پیش
والد
کامیت
89e035a26b
2فایلهای تغییر یافته به همراه161 افزوده شده و 39 حذف شده
  1. 64 14
      src/views/goods/list/detail.vue
  2. 97 25
      src/views/goods/list/index.vue

+ 64 - 14
src/views/goods/list/detail.vue

@@ -2,51 +2,101 @@
   <div class="app-container">
     <el-form label-width="100px">
       <el-form-item label="推荐位置:">
-        <el-select placeholder="请选择推荐位置">
-          <el-option />
+        <el-select v-model="form.position" placeholder="请选择推荐位置">
+          <el-option v-for="item in dict.type.goods_location" :key="item.value" :label="item.label"
+            :value="Number(item.value)" />
         </el-select>
       </el-form-item>
       <el-form-item label="商品名称:">
-        <el-input placeholder="请输入商品名称" />
+        <el-input v-model="form.name" placeholder="请输入商品名称" />
       </el-form-item>
       <el-form-item label="商品简介:">
-        <el-input type="textarea" rows="4" placeholder="请输入商品简介" />
+        <el-input v-model="form.description" type="textarea" rows="4" placeholder="请输入商品简介" />
       </el-form-item>
       <el-form-item label="商品价格:">
-        <el-input placeholder="请输入商品价格" />
+        <el-input v-model="form.price" placeholder="请输入商品价格" />
       </el-form-item>
       <el-form-item label="商品图片:">
-        <Upload listType="picture-card" />
+        <Upload listType="picture-card" :url="form.pic" @upload="getUpload" />
       </el-form-item>
-      <el-form-item label="跳转网址:">
-        <el-input placeholder="请输入跳转地址" />
+      <el-form-item label="跳转链接:">
+        <el-input v-model="form.forwardUrl" placeholder="请输入跳转链接" />
       </el-form-item>
       <el-form-item label="有效期:">
-        <el-date-picker type="datetimerange" start-placeholder="开始日期" end-placeholder="结束日期" />
+        <el-date-picker v-model="date" type="datetimerange" start-placeholder="开始日期" end-placeholder="结束日期"
+          value-format="yyyy-MM-dd HH:mm:ss" />
       </el-form-item>
       <el-form-item label="权重:">
-        <el-input-number :min="0" :max="9" />
+        <el-input-number v-model="form.sort" :min="0" :max="9" />
       </el-form-item>
       <el-form-item>
         <el-button @click="cancel">取消</el-button>
-        <el-button type="primary">确定</el-button>
+        <el-button type="primary" @click="getSubmit">提交</el-button>
       </el-form-item>
     </el-form>
   </div>
 </template>
 
 <script>
+import { create, detail, edit } from '@/api/goods/list'
 import Upload from '@/components/Upload/index'
 export default {
   components: { Upload },
+  dicts: ['goods_location'],
   data() {
     return {
-
+      // 表单
+      form: {
+        sort: 0
+      },
+      // 有效期
+      date: []
+    }
+  },
+  watch: {
+    date(val) {
+      this.form.startTime = val[0]
+      this.form.endTime = val[1]
+    }
+  },
+  mounted() {
+    if (this.$route.query.id) {
+      detail({
+        id: this.$route.query.id
+      }).then(res => {
+        if (res.code === 0) {
+          this.form = res.data
+          this.date = [res.data.startTime, res.data.endTime]
+        }
+      })
     }
   },
-  methods:{
-    cancel(){
+  methods: {
+    // 上传图片
+    getUpload(e) {
+      this.form.pic = e.file
+    },
+    // 取消
+    cancel() {
       this.$tab.closeOpenPage("/goods/goodsList");
+    },
+    // 提交
+    getSubmit() {
+      if (this.$route.query.id) {
+        edit(this.form).then(res => {
+          if(res.code === 0){
+            this.$message.success('修改成功!')
+            this.cancel()
+          }
+        })
+      } else {
+        create(this.form).then(res => {
+          if (res.code === 0) {
+            this.$message.success('新增成功!')
+            this.cancel()
+          }
+        })
+      }
     }
   }
 }

+ 97 - 25
src/views/goods/list/index.vue

@@ -3,66 +3,138 @@
     <!-- 搜索 -->
     <el-form inline label-width="100px" size="mini">
       <el-form-item label="推荐位置:">
-        <el-select>
-          <el-option />
+        <el-select v-model="form.position" placeholder="请选择推荐位置" clearable>
+          <el-option v-for="item in dict.type.goods_location" :key="item.value" :label="item.label"
+            :value="item.value" />
         </el-select>
       </el-form-item>
       <el-form-item label="当前状态:">
-        <el-select>
-          <el-option />
+        <el-select v-model="form.status" placeholder="请选择当前状态" clearable>
+          <el-option v-for="item in dict.type.on_off_out" :key="item.value" :label="item.label"
+            :value="item.value" />
         </el-select>
       </el-form-item>
       <el-form-item label="商品名称:">
-        <el-input />
-      </el-form-item>
-      <el-form-item label="商品简介:">
-        <el-input />
+        <el-input v-model="form.name" placeholder="请输入商品名称" clearable />
       </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-plus" plain @click="getDetail">新增</el-button>
+        <el-button type="primary" icon="el-icon-plus" plain @click="getDetail()">新增</el-button>
       </el-form-item>
     </el-form>
     <!-- 列表 -->
-    <el-table>
-      <el-table-column label="推荐位置"></el-table-column>
-      <el-table-column label="商品名称"></el-table-column>
-      <el-table-column label="商品简介"></el-table-column>
-      <el-table-column label="商品价格"></el-table-column>
-      <el-table-column label="商品图片"></el-table-column>
-      <el-table-column label="当前状态"></el-table-column>
-      <el-table-column label="权重"></el-table-column>
-      <el-table-column label="有效期"></el-table-column>
-      <el-table-column label="操作">
-        <el-button>编辑</el-button>
+    <el-table :data="tableData" v-loading="loading">
+      <el-table-column label="推荐位置" prop="position" align="center" :formatter="positionFormatter" />
+      <el-table-column label="商品名称" prop="name" align="center" show-overflow-tooltip />
+      <el-table-column label="商品简介" prop="description" align="center" show-overflow-tooltip />
+      <el-table-column label="商品价格/元" prop="price" align="center" />
+      <el-table-column label="商品图片" align="center" width="100px">
+        <template slot-scope="scope">
+          <el-image :src="scope.row.pic" :previewSrcList="[scope.row.pic]" />
+        </template>
+      </el-table-column>
+      <el-table-column label="当前状态" prop="status" align="center" :formatter="statusFormatter" />
+      <el-table-column label="权重" prop="sort" align="center" />
+      <el-table-column label="有效期" align="center" show-overflow-tooltip>
+        <template slot-scope="scope">
+          <span>{{ scope.row.startTime }} 至 {{ scope.row.endTime }}</span>
+        </template>
+      </el-table-column>
+      <el-table-column label="操作" align="center">
+        <template slot-scope="scope">
+          <el-button type="text" @click="getDetail(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" />
   </div>
 </template>
 
 <script>
+import { list, remove } from '@/api/goods/list'
 export default {
+  dicts: ['goods_location', 'on_off_out'],
   data() {
     return {
-
+      // 遮罩层
+      loading: false,
+      // 表单
+      form: {
+        pageNum: 1,
+        pageSize: 10
+      },
+      // 列表
+      tableData: [],
+      total: 0
     }
   },
+  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()
     },
     // 新增 编辑
-    getDetail() {
+    getDetail(id) {
       this.$router.push({
-        path: `/goods/goodsList/detail`
+        path: `/goods/goodsList/detail`,
+        query: {
+          id: id
+        }
+      })
+    },
+
+    // 删除
+    getDelete(row) {
+      this.$confirm(`是否删除${row.name}商品?`, '提醒', {
+        'confirmButtonText': '确定',
+        'cancelButtonText': '取消',
+        type: 'warning'
+      }).then(() => {
+        remove({
+          id: row.id
+        }).then(res => {
+          if (res.code === 0) {
+            this.$message.success('删除成功!')
+            this.getList()
+          }
+        })
       })
     },
+
+    // 字典翻译
+    positionFormatter(row) {
+      return this.selectDictLabel(this.dict.type.goods_location, row.position)
+    },
+
+    statusFormatter(row) {
+      return this.selectDictLabel(this.dict.type.on_off_out, row.status)
+    }
   }
 }
 </script>