From d044dc871c16f05c9a1fb1489621020c91ec9d59 Mon Sep 17 00:00:00 2001
From: Mr.Shi <1878285526@qq.com>
Date: 星期三, 16 八月 2023 18:30:56 +0800
Subject: [PATCH] Merge branch 'master' of ssh://139.186.142.91:29418/productDev/dmMes

---
 web_standard/src/components/business/OperaSalaryParamWindow.vue |  254 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 254 insertions(+), 0 deletions(-)

diff --git a/web_standard/src/components/business/OperaSalaryParamWindow.vue b/web_standard/src/components/business/OperaSalaryParamWindow.vue
new file mode 100644
index 0000000..9d2c21a
--- /dev/null
+++ b/web_standard/src/components/business/OperaSalaryParamWindow.vue
@@ -0,0 +1,254 @@
+<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="type">
+        <el-select v-model="form.type" placeholder="璇烽�夋嫨璁′环鏂瑰紡" clearable>
+          <el-option
+            v-for="item in type"
+            :key="item.value"
+            :label="item.label"
+            :value="item.value"
+          >
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="宸ュ巶" prop="departId">
+        <el-select v-model="form.departId" placeholder="璇烽�夋嫨宸ュ巶" :disabled="isEdit" clearable @change="selectFactoey">
+          <el-option
+            v-for="item in factories"
+            :key="item.id"
+            :label="item.name"
+            :value="item.id"
+          >
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="鐗╂枡" prop="materialId">
+        <el-select v-model="form.materialId" placeholder="璇烽�夋嫨鐗╂枡" :disabled="isEdit" clearable @change="selectMaterial">
+          <el-option
+            v-for="item in materials"
+            :key="item.realMaterialId"
+            :label="item.mmodel.name"
+            :value="item.realMaterialId"
+          >
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="宸ュ簭" prop="procedureId">
+        <el-select v-model="form.procedureId" placeholder="璇烽�夋嫨宸ュ簭" :disabled="isEdit" clearable>
+          <el-option
+            v-for="item in productes"
+            :key="item.id"
+            :label="item.name"
+            :value="item.id"
+          >
+          </el-option>
+        </el-select>
+      </el-form-item>
+      <el-form-item label="宸ヨ祫鍗曚环锛堝厓)" prop="salary">
+        <el-input v-model="form.salary" placeholder="璇疯緭鍏ュ伐璧勫崟浠凤紙鍏�)" @input="inputZAction(form, 'salary')" v-trim/>
+      </el-form-item>
+      <el-form-item label="鏍囧噯鏁堢巼" prop="num">
+        <div style="display: flex;">
+          <el-input v-model="form.num" v-trim/>/
+          <el-input v-model="form.hours" v-trim/><div class="unit">灏忔椂</div>
+          <el-input v-model="form.minute" v-trim/><div class="unit">鍒嗛挓</div>
+          <el-input v-model="form.second" v-trim/><div>绉�</div>
+        </div>
+      </el-form-item>
+      <el-form-item label="涓嶈壇鍝佹槸鍚﹁鍏�" prop="unqualified">
+        <el-switch v-model="form.unqualified" :inactive-value="0" :active-value="1"></el-switch>
+        <!-- <el-input v-model="form.unqualified" placeholder="璇疯緭鍏ヤ笉鑹搧鏄惁璁″叆 0鍚� 1鏄�" v-trim/> -->
+      </el-form-item>
+      
+    </el-form>
+  </GlobalWindow>
+</template>
+
+<script>
+import BaseOpera from '@/components/base/BaseOpera'
+import GlobalWindow from '@/components/common/GlobalWindow'
+import { getDepartmentListByConditon } from '@/api/ext/departmentExt'
+import { getBomMaterialList } from '@/api/ext/bomExt'
+import { routeExt as proceList } from '@/api/ext/routeProcedureExt'
+import { numRule } from '@/utils/form'
+export default {
+  name: 'OperaSalaryParamWindow',
+  extends: BaseOpera,
+  components: { GlobalWindow },
+  data () {
+    return {
+      // 琛ㄥ崟鏁版嵁
+      form: {
+        id: null,
+        materialId: '',
+        createUser: '',
+        createTime: '',
+        updateUser: '',
+        updateTime: '',
+        remark: '',
+        rootDepartId: '',
+        departId: '',
+        procedureId: '',
+        bomId: '',
+        salary: '',
+        num: '',
+        times: '',
+        hours: '',
+        minute: '',
+        second: '',
+        unqualified: 0,
+        type: ''
+      },
+      isEdit: false,
+      type: [
+        { label: '璁′欢', value: 0 },
+        { label: '璁℃椂', value: 1 },
+      ],
+      factories: [],
+      materials: [],
+      productes: [],
+      // 楠岃瘉瑙勫垯
+      rules: {
+        departId: [
+          { required: true, validator: numRule, message: '璇烽�夋嫨宸ュ巶', tigger: 'change' }
+        ],
+        materialId: [
+          { required: true, validator: numRule, message: '璇烽�夋嫨鐗╂枡', tigger: 'change' }
+        ],
+        procedureId: [
+          { required: true, validator: numRule, message: '璇烽�夋嫨宸ュ簭', tigger: 'change' }
+        ],
+        salary: [
+          { required: true, validator: numRule, message: '璇疯緭鍏ュ伐璧勫崟浠�', tigger: 'blur' }
+        ],
+      }
+    }
+  },
+  created () {
+    this.config({
+      api: '/business/salaryParam',
+      'field.id': 'id'
+    })
+    this.initData()
+  },
+  methods: {
+    open (title, target) {
+      this.title = title
+      this.visible = true
+      this.isEdit = false
+      // 鏂板缓
+      if (target == null) {
+        this.$nextTick(() => {
+          this.$refs.form.resetFields()
+          this.form[this.configData['field.id']] = null
+          this.form.times = ''
+          this.form.second = ''
+          this.form.minute = ''
+          this.form.hours = ''
+          this.form.departId = this.factories[0]?this.factories[0].id:''
+          this.selectFactoey(this.form.departId)
+        })
+        return
+      }
+      // 缂栬緫
+      this.$nextTick(() => {
+        this.isEdit = true
+        for (const key in this.form) {
+          this.form[key] = target[key]
+        }
+        let { times } = target
+        this.form.second = +times%60
+        let lesMin = Math.floor(+times/60)
+        this.form.minute = lesMin%60
+        this.form.hours = Math.floor(lesMin/60)
+        this.selectFactoey(this.form.departId, true)
+        
+      })
+    },
+    initData() {
+      getDepartmentListByConditon({ type: 1 })
+        .then(res => {
+          this.factories = res
+        })
+        .catch(err => {
+          console.log(err)
+        })
+    },
+    selectFactoey (v, isEdit=false) {
+      
+      // console.log(v)
+      if (!isEdit) {
+        this.materials = []
+        this.form.materialId = ''
+        this.form.procedureId = ''
+        this.productes = []
+      }
+      getBomMaterialList({ departId: v })
+        .then(res => {
+          // console.log(res)
+          this.materials = res
+          // if (!isEdit) {
+          //   this.form.materialId = res[0]?res[0].materialId:''
+          // }
+          // this.selectMaterial(this.form.materialId)
+        })
+        .catch(err => {
+          console.log(err)
+        })
+    },
+    selectMaterial (id, isEdit) {
+     
+      let routeId;
+      for (const item of this.materials) {
+        if (item.realMaterialId === id) {
+          routeId = item.routeId
+        }
+      }
+      proceList(routeId)
+        .then(res => {
+          // console.log(res)
+          this.productes = res.proceList
+          if (!isEdit) {
+            // debugger
+            this.form.procedureId = this.productes[0]?this.productes[0].id:''
+          }
+        }).catch(err => {
+          console.log(err)
+        })
+    },
+    // 2浣嶆湁鏁堥攢鍞紙姝o級
+    inputZAction(item, key) {
+      item[key] = item[key].replace(/[^\d.]/g, '')
+                      .replace(/\.{2,}/g, '.')
+                      .replace('.', '$#$')
+                      .replace(/\./g, '')
+                      .replace('$#$', '.')
+                      .replace(/^(\-)*(\d+)\.(\d\d).*$/, '$1$2.$3')
+                      .replace(/^\./g, '')
+    },
+    confirm () {
+      // console.log((+this.form.hours) * 3600);
+      // console.log((+this.form.minute) * 60);
+      // console.log(this.form.second);
+      this.form.times = (+this.form.hours) * 3600 + (+this.form.minute)* 60 + (+this.form.second)
+      if (this.form.id == null || this.form.id === '') {
+        this.__confirmCreate()
+        return
+      }
+      this.__confirmEdit()
+    },
+  },
+}
+</script>
+
+<style>
+.unit {
+  white-space: nowrap;
+}
+</style>

--
Gitblit v1.9.3