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