fuliqi
2024-01-24 29c1e7eb5ac16e90d8991a86c1c071bc312ec8d9
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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
<template>
    <div>
       <el-dialog :visible.sync="dialogVisible" :title="title" :close-on-click-modal="false" :modal-append-to-body="false" v-if="dialogVisible">
            <el-form size="mini" :model="form" label-width="120px" ref="form" :rules="formRules">
                 <el-form-item label="订单编号:" prop="orderId">
                     <el-input v-model="form.orderId" placeholder="请输入订单编号" clearable disabled></el-input>
                 </el-form-item>
                <el-form-item label="收货人:" prop="contactName">
                     <el-input v-model="form.contactName" placeholder="请输入收货人" clearable disabled></el-input>
                 </el-form-item>
                 <el-form-item label="收货人电话:" prop="contactPhone">
                     <el-input v-model="form.contactPhone" placeholder="请输入收货人电话" clearable disabled></el-input>
                 </el-form-item>
                <el-form-item label="收货地址:" prop="detail">
                     <el-input v-model="form.detail" placeholder="请输入收货地址" clearable disabled></el-input>
                 </el-form-item>
                 <!-- <el-form-item label="承运商:" prop="modeOfDespatch">
                     <el-input v-model="form.modeOfDespatch" placeholder="请输入承运商" clearable disabled>
                          <template slot="append">
                               <el-button id="setAddModeOfDespatch" @click="addModeOfDespatch">添加承运商</el-button>
                          </template>
                     </el-input>
                 </el-form-item>
                <el-form-item label="快递编号:" prop="waybillId">
                     <el-input v-model="form.waybillId" placeholder="请输入快递编号" clearable></el-input>
                 </el-form-item>
                 <el-form-item label="发货方式:" prop="commonCarrier">
                     <el-select placeholder="请选择发货方式" v-model="form.commonCarrier">
                          <el-option key="1" value="1" label="快递"></el-option>
                          <el-option key="2" value="2" label="物流"></el-option>
                     </el-select>
                 </el-form-item> -->
            </el-form>
            <div slot="footer" class="dialog-footer">
                <el-button size="mini" @click="submit" type="primary"  :loading="loading">确定</el-button>
                <el-button size="mini" @click="dialogVisible = false">取消</el-button>
            </div>
        </el-dialog>
         <mode-of-despatch-selectd :show.sync ='selectedVisible' :title="'物流公司信息'" @hand-selected-row-data="handSelectedRowData"></mode-of-despatch-selectd>
    </div>
</template>
<script>
import orderMgtApi from '@/api/orderMgt'
import modeOfDespatchSelectd from '@/views/orderMgt/components/modeOfDespatchSelectd.vue'
export default {
  props: {
    show: {
      type: Boolean,
      default: false
    },
    title: {
      type: String,
      default: '发货'
    },
    row: {
      type: Object,
      default: function () {
        return {}
      }
    }
  },
  components: { modeOfDespatchSelectd },
  data () {
    return {
      selectedVisible: false, // 控制物流弹窗状态
      dialogVisible: false,
      form: { },
      formRules: {
        waybillId: [{ required: true, message: '请输入快递编号', trigger: 'change' }],
        commonCarrier: [{ required: true, message: '请选择发货方式', trigger: 'change' }],
        modeOfDespatch: [{ required: true, message: '请选择发货方式', trigger: 'change' }]
      },
      loading: false
    }
  },
  watch: {
    row: {
      handler (newValue, oldValue) {
        this.form = this.row
      },
      deep: true
    },
    /**
     * 监控外部显示变量变化
     * 传递到dialog组件
     */
    show: function (newShow, oldShow) {
      this.dialogVisible = newShow
    },
    /**
     * 监控内部显示属性变化
     * 传递到外部调用变量
     */
    dialogVisible: function (newDialogShow, oldDialogShow) {
      if (!newDialogShow) {
        for (const i in this.form) {
          this.form[i] = null
        }
        this.$emit('update:show', newDialogShow)
      }
    }
  },
  methods: {
    /**
       * 获取选中的数据
       */
    handSelectedRowData (row) {
      this.form.companyCode = row.companyCode
      this.form.modeOfDespatch = row.companyName
      this.form.companyId = row.companyId
    },
    /**
       * 添加承运商
       */
    addModeOfDespatch () {
      this.selectedVisible = true
    },
    /**
       * 提交
       */
    submit () {
      this.$refs.form.validate().then(res => {
        this.loading = true
        orderMgtApi.deliverGoods({ orderno: this.form.orderId }).then(res => {
          if (res.data) {
            this.$message({
              message: '操作成功',
              type: 'success'
            })
            this.loading = false
            this.$parent.queryList()
            this.dialogVisible = false
          } else {
            this.loading = false
          }
        }).catch(() => {
          this.loading = false
        })
      })
    }
  }
}
</script>
<style scoped>
#setAddModeOfDespatch{
    background-color: #E6A23C;
    color: #fff;
}
</style>