Mr.Shi
2023-09-19 02eb974bcf9f85a4a6594540fab97007abef4291
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
<template>
  <GlobalWindow :title="title" :visible.sync="visible" :confirm-working="isWorking" @confirm="confirm">
    <el-form :model="form" ref="form" :rules="rules">
      <el-form-item label="商品类别" prop="categoryId">
        <el-select v-model="form.categoryId" placeholder="请选择">
          <el-option
            v-for="item in categoryList"
            :key="item.id"
            :label="item.name"
            :value="`${item.platCateId},${item.id}`">
          </el-option>
        </el-select>
      </el-form-item>
      <el-form-item label="商品范围" prop="type">
        <el-radio-group v-model="form.type">
          <el-radio :label="0">全部</el-radio>
          <el-radio :label="1">部分</el-radio>
        </el-radio-group>
      </el-form-item>
      <el-form-item label="加价系数" prop="rate">
        <el-input v-model="form.rate" placeholder="平台采购价*加价系数,作为参考出手价,建议输入大于1的数字" v-trim />
      </el-form-item>
    </el-form>
    <!-- 选择平台商品 -->
    <selectProductItem ref="selectProductItem" @result="result" />
  </GlobalWindow>
</template>
    
<script>
  import BaseOpera from '@/components/base/BaseOpera'
  import GlobalWindow from '@/components/common/GlobalWindow'
  import selectProductItem from '@/components/business/selectProductItem'
  import { list } from '@/api/business/category.js'
  import { createPlat } from '@/api/business/goods'
 
  export default {
    name: 'OperaBrandWindow',
    extends: BaseOpera,
    components: { GlobalWindow, selectProductItem },
    data() {
      return {
        categoryList: [],
        // 表单数据
        form: {
          categoryId: '',
          type: 0,
          rate: ''
        },
        // 验证规则
        rules: {
          categoryId: [
            { required: true, message: '商品类别不能为空', trigger: 'blur' }
          ],
          type: [
            { required: true, message: '商品范围不能为空', trigger: 'blur' }
          ],
          rate: [
            { required: true, message: '加价系数不能为空', trigger: 'blur' }
          ]
        }
      }
    },
    created() {
      this.config({
        api: '/business/anchor',
        'field.id': 'id'
      })
    },
    methods: {
      result() {
        // this.$emit('success')
        this.$emit('result')
        this.visible = false
      },
      confirm() {
        this.$refs.form.validate((valid) => {
          if (!valid) return
          // 新建
          if (this.form.type == 0) {
            this.isWorking = true
            createPlat({
              categoryId: this.form.categoryId.split(',')[1],
              rate: this.form.rate,
              type: this.form.type
            }).then(res => {
              this.visible = false
              this.$tip.apiSuccess('操作成功')
              // this.$emit('success')
              this.$emit('result')
            })
            .catch(e => {
              this.$tip.apiFailed(e)
            })
            .finally(() => {
              this.isWorking = false
            })
          } else {
            this.$refs.selectProductItem.open('选择平台商品', this.form)
          }
        })
      },
      /**
       * 打开窗口
       * @title 窗口标题
       * @target 编辑的对象
       */
      open (title, target) {
        this.title = title
        this.visible = true
        this.form.categoryId = ''
        this.form.type = 0
        this.form.rate = ''
        // 获取分类列表
        list({ type: 1 })
          .then(res => {
            this.categoryList = res
          })
      }
    }
  }
</script>