<template>
  <div class="mod-config">
    <el-button type="primary" @click="submit()" size="small">提交</el-button>
    <el-form
      ref="dataForm"
      :model="dataForm"
      :rules="rules"
      size="medium"
      label-width="110px"
    >
      <div>
        <el-row :gutter="20">
          <el-col :span="8">
            <el-form-item label="开始加工时间" prop="startTime">
              <el-date-picker
                v-model="dataForm.startTime"
                value-format="yyyy-MM-dd HH:mm:ss"
                :style="{ width: '100%' }"
                type="datetime"
                placeholder="请选择开始加工时间"
                clearable
              ></el-date-picker>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="账号" prop="startUser">
              <el-input
                v-model="dataForm.startUser"
                placeholder="请输入账号"
                readonly
                prefix-icon="el-icon-user-solid"
                :style="{ width: '100%' }"
              ></el-input>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="配炉号" prop="stoveCode">
              <el-select
                v-model="dataForm.stoveCode"
                :style="{ width: '100%' }"
                filterable
                placeholder="请选择配炉号"
              >
                <el-option
                  v-for="item in stoveCodeArr"
                  :key="item.id"
                  :label="item.code"
                  :value="item.code"
                >
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="车间编码" prop="workShopCode">
              <el-input
                v-model="dataForm.workShopCode"
                placeholder="请输入车间编码"
                readonly
                :style="{ width: '100%' }"
              >
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="工艺号" prop="techCode">
              <el-select
                v-model="dataForm.techCode"
                :style="{ width: '100%' }"
                filterable
                placeholder="请选择工艺号"
              >
                <el-option
                  v-for="item in techCodeArr"
                  :key="item.id"
                  :label="item.craftCode"
                  :value="item.craftCode"
                >
                </el-option>
              </el-select>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="炉号备注" prop="stoveRemark">
              <el-input
                v-model="dataForm.stoveRemark"
                placeholder="请输入炉号备注"
                clearable
                :style="{ width: '100%' }"
              >
              </el-input>
            </el-form-item>
          </el-col>
          <el-col :span="8">
            <el-form-item label="备注" prop="remark">
              <el-input
                v-model="dataForm.remark"
                placeholder="请输入备注"
                clearable
                :style="{ width: '100%' }"
              ></el-input>
            </el-form-item>
          </el-col>
        </el-row>
      </div>
      <el-card class="box-card">
        <div slot="header" class="clearfix">
          <span>生产单</span>
          <el-tooltip effect="dark" content="新增" placement="top">
            <el-button
              style="float: right; padding: 0px;color:#409EFF;font-size:20px;border:none"
              icon="el-icon-circle-plus"
              @click="itemsPlus()"
            ></el-button>
          </el-tooltip>
        </div>
        <div v-for="(item, index) in dataForm.items" :key="index">
          <el-row :gutter="20">
            <el-col :span="1">
              <el-tooltip effect="dark" content="删除" placement="top">
                <el-button
                  style="color:red"
                  icon="el-icon-delete"
                  @click="itemsDelete(index)"
                ></el-button>
              </el-tooltip>
            </el-col>
            <el-col :span="7">
              <el-form-item label="标识卡号" prop="itemCode">
                <el-input
                  v-model="item.itemCode"
                  placeholder="请输入标识卡号"
                  clearable
                  :style="{ width: '100%' }"
                >
                </el-input>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="加工数量" prop="quantity">
                <el-input-number
                  v-model="item.quantity"
                  placeholder="加工数量"
                  :step="1"
                ></el-input-number>
              </el-form-item>
            </el-col>
            <el-col :span="8">
              <el-form-item label="加工重量" prop="weight">
                <el-input-number
                  v-model="item.weight"
                  placeholder="加工重量"
                  :step="1"
                ></el-input-number>
              </el-form-item>
            </el-col>
          </el-row>
        </div>
      </el-card>
    </el-form>
  </div>
</template>

<script>
export default {
  components: {},
  props: [],
  data () {
    return {
      stoveCodeArr: [],
      techCodeArr: [],
      dataForm: {
        startTime: null,
        startUser: 'QJJP03',
        stoveCode: undefined,
        workShopCode: 'BM',
        techCode: undefined,
        stoveRemark: undefined,
        remark: undefined,
        items: [
          {
            itemCode: undefined,
            quantity: 0,
            weight: 0
          }
        ]
      },
      rules: {
        startTime: [
          {
            required: true,
            message: '请选择开始加工时间',
            trigger: 'change'
          }
        ],
        startUser: [
          {
            required: true,
            message: '请输入账号',
            trigger: 'blur'
          }
        ],
        stoveCode: [
          {
            required: true,
            message: '请输入配炉号',
            trigger: 'blur'
          }
        ],
        workShopCode: [
          {
            required: true,
            message: '请输入车间编码',
            trigger: 'blur'
          }
        ],
        techCode: [],
        stoveRemark: [],
        remark: [],
        itemCode: []
      }
    }
  },
  created () {
    this.init()
  },
  methods: {
    init () {
      this.$http({
        url: this.$http.adornUrl('/kilnInfo/page'),
        method: 'post',
        data: this.$http.adornData({
          current: 1,
          size: 200
          // paramKey: this.dataForm.paramKey
        })
      }).then(({ data }) => {
        if (data && data.code === 0) {
          this.stoveCodeArr = data.data.records
        } else {
          this.stoveCodeArr = []
        }
      })
      this.$http({
        url: this.$http.adornUrl('/craftInfo/page'),
        method: 'post',
        data: this.$http.adornData({
          current: 1,
          size: 200
          // paramKey: this.dataForm.paramKey
        })
      }).then(({ data }) => {
        if (data && data.code === 0) {
          this.techCodeArr = data.data.records
        } else {
          this.techCodeArr = []
        }
      })
    },
    itemsPlus () {
      const obj = {
        itemCode: undefined,
        quantity: 0,
        weight: 0
      }
      this.dataForm.items.push(obj)
    },
    itemsDelete (index) {
      this.dataForm.items.splice(index, 1)
    },
    submit () {
      this.$refs['dataForm'].validate(valid => {
        if (valid) {
          let scheck = true
          this.dataForm.items.find(item => {
            if (!item.itemCode) {
              scheck = false
            }
          })
          if (scheck) {
            this.$http({
              url: this.$http.adornUrl('/apms/createProcessSheet'),
              method: 'post',
              data: this.$http.adornData(this.dataForm)
            }).then(({ data }) => {
              if (data && data.code === 0) {
                this.$message({
                  message: '操作成功',
                  type: 'success',
                  duration: 3000,
                  onClose: () => {
                    this.$refs['dataForm'].resetFields()
                    this.dataForm.items.splice(0, this.dataForm.items.length)
                    this.itemsPlus()
                  }
                })
              } else {
                this.$message.error(data.msg)
              }
            })
          } else {
            this.$message.info('请填写完整生产单')
          }
        }
      })
    }
  }
}
</script>
<style scoped></style>