From 49d4281ebaba8a0d73b6669dcc13da0109a1b91f Mon Sep 17 00:00:00 2001
From: loulijun2021 <1694218219@qq.com>
Date: 星期一, 13 十一月 2023 15:13:57 +0800
Subject: [PATCH] 1.生产报工  75%

---
 pages/scgl/scbg.vue |  229 +++++++++++++++++++++++++++++++++++++--------------------
 1 files changed, 149 insertions(+), 80 deletions(-)

diff --git a/pages/scgl/scbg.vue b/pages/scgl/scbg.vue
index 52b85e3..01ed874 100644
--- a/pages/scgl/scbg.vue
+++ b/pages/scgl/scbg.vue
@@ -50,7 +50,7 @@
 											<view>{{item.stepname}}</view>
 											<view>{{item.planqty}}</view>
 											<view>{{item.noreportqty}}/{{item.reportqty}}</view>
-											<view>{{item.nextstepname}}</view>
+											<view>{{item.nextstepname?item.nextstepname:'/'}}</view>
 										</view>
 									</view>
 
@@ -104,8 +104,8 @@
 						</view>
 
 
-						<view class="flex_center" style="margin: 0rpx 20rpx 10rpx;line-height: 76rpx;"
-							v-if="reckway==='涓汉'">
+						<view class="flex_center" style="margin: 0rpx 20rpx 10rpx;line-height: 76rpx;">
+							<!-- v-if="reckway==='涓汉'" -->
 							<view style="display: flex;" class="titleFont">
 								<view style="color: red;margin-right: 6rpx;">*</view> 鎶ュ伐浜哄憳锛�
 							</view>
@@ -193,13 +193,13 @@
 				</view>
 
 				<!-- 鎶ュ伐浜哄憳淇℃伅 -->
-				<u-gap height="15" v-if="reckway==='鐝粍'" bgColor="#eff0f1"></u-gap>
+				<!-- 			<u-gap height="15" v-if="reckway==='鐝粍'" bgColor="#eff0f1"></u-gap>
 				<view class="head marginLeft10 marginRight10" v-if="reckway==='鐝粍'">
 					<view class="head_block">
 						<view class="head_left">
 							<view class="head_bar"></view>
 							<view class="head_title">
-								鎶ュ伐浜哄憳淇℃伅
+								涓嶈壇鍘熷洜鏄庣粏
 							</view>
 						</view>
 					</view>
@@ -230,7 +230,7 @@
 							</view>
 
 							<u-icon @click="deleteUser(item)" style="width: 50rpx;text-align: center;" name="trash"
-								min='0' max='100' color="#2979ff" size="40">
+								min='0' max='100' color="#2979ff" size="24">
 							</u-icon>
 
 						</view>
@@ -240,7 +240,7 @@
 
 
 
-				</view>
+				</view> -->
 
 			</view>
 
@@ -250,17 +250,12 @@
 				@click="submit" text="鎶ュ伐">
 			</u-button>
 
-			<!-- 			<u-action-sheet :actions="userGroupSheetList" :safeAreaInsetBottom='true' :closeOnClickOverlay="true"
-				:closeOnClickAction="true" @close="userGroupSheetShow=false" :show="userGroupSheetShow"
-				@select='userGroupSheetSelect'>
-			</u-action-sheet> -->
+
 			<u-picker v-if="topContent.length!==0" :show="userGroupSheetShow" :columns="userGroupColumns"
 				:itemHeight='55' :closeOnClickOverlay='true' @close='userGroupSheetShow=false'
 				@confirm='userGroupPickerConfirm' @cancel='userGroupSheetShow=false'>
 			</u-picker>
-			<!-- 		<u-action-sheet :actions="eqpSheetList" :safeAreaInsetBottom='true' :closeOnClickOverlay="true"
-				:closeOnClickAction="true" @close="eqpSheetShow=false" :show="eqpSheetShow" @select='eqpSheetSelect'>
-			</u-action-sheet> -->
+
 			<u-picker v-if="topContent.length!==0" :show="eqpSheetShow" :columns="eqpColumns" :itemHeight='55'
 				:closeOnClickOverlay='true' @close='eqpSheetShow=false' @confirm='eqpPickerConfirm'
 				@cancel='eqpSheetShow=false'>
@@ -275,7 +270,7 @@
 					<u-checkbox-group @change="checkboxChange" size='20px' v-model="checkBoxValue" iconPlacement="right"
 						placement="column">
 						<view v-for="(item,index) in badSelectArr">
-							<u-checkbox activeColor="rgb(0, 102, 255)" labelSize='40' :key="item.code" :name='item.name'
+							<u-checkbox activeColor="rgb(0, 102, 255)" labelSize='18' :key="item.code" :name='item.name'
 								:label="item.name">
 							</u-checkbox>
 							<u-divider :key="item.code"></u-divider>
@@ -285,9 +280,26 @@
 			</u-action-sheet>
 
 
-			<!-- 		<u-action-sheet :actions="operSheetList" :safeAreaInsetBottom='true' :closeOnClickOverlay="true"
-				:closeOnClickAction="true" @close="operSheetShow=false" :show="operSheetShow" @select='operSheetSelect'>
-			</u-action-sheet> -->
+
+			<u-action-sheet v-if="topContent.length!==0" :actions="userSelectArrAll" :safeAreaInsetBottom='true'
+				:closeOnClickOverlay="true" :closeOnClickAction="true" @close="userSheetShow=false"
+				:show="userSheetShow" @select='userSheetSelect'>
+				<view style="min-height: 100rpx;padding: 20rpx 20rpx 30rpx 20rpx;">
+					<u-checkbox-group @change="userCheckboxChange" size='20px' v-model="userCheckBoxValue"
+						iconPlacement="right" placement="column">
+						<view v-for="(item,index) in userSelectArrAll">
+							<u-checkbox activeColor="rgb(0, 102, 255)" labelSize='18' :key="item.code" :name='item.name'
+								:label="item.name">
+							</u-checkbox>
+							<u-divider :key="item.code"></u-divider>
+						</view>
+					</u-checkbox-group>
+				</view>
+			</u-action-sheet>
+
+
+
+
 			<u-picker v-if="topContent.length!==0" :show="operSheetShow" :columns="operColumns" :itemHeight='55'
 				:closeOnClickOverlay='true' @close='operSheetShow=false' @confirm='operPickerConfirm'
 				@cancel='operSheetShow=false'>
@@ -296,13 +308,36 @@
 
 			<u-modal v-if="topContent.length!==0" :show="modalShow" :showCancelButton='true' cancelText='鍙栨秷'
 				@close="modalShow=false" :closeOnClickOverlay="true" style=" " @cancel="modalCancel"
-				@confirm="modalConfirm" title="鎶ュ伐浜哄憳" :content='modalContent'>
+				@confirm="modalConfirm" title="涓嶈壇鏄庣粏" :content='modalContent'>
 
-				<uni-section style="width: 100%;" title=''>
+				<!-- 		<uni-section style="width: 100%;" title=''>
 					<uni-data-select v-model="userSelectValue" :clear='false' emptyText :localdata="userSelectArr"
 						@change="userChange">
 					</uni-data-select>
-				</uni-section>
+				</uni-section> -->
+
+				<!-- 	<view style="display: flex;flex-direction: column;">
+					<view class="flex_center titleFont" style="margin: 0rpx 20rpx 10rpx;line-height: 56rpx;">
+						<view style="color: #fff;margin-right: 6rpx;">*</view> 鏁伴噺锛�
+						<view class='inputClass'>
+							<u--input placeholder="璇疯緭鍏�" border="surround" @change='ngqtyChange' type='number'
+								v-model="ngqty"></u--input>
+						</view>
+					</view>
+					<view class="flex_center" style="margin: 0rpx 20rpx 10rpx;line-height: 76rpx;">
+						<view style="display: flex;" class="titleFont">
+							<view style="color: #fff;margin-right: 6rpx;">*</view> 鍘熷洜锛�
+						</view>
+						<view @click='badSheetClick' class="custominputClass">
+							<view v-show='badSheetValue.length===0' style="color: rgb(192, 196, 204);">璇烽�夋嫨</view>
+							<view v-show='badSheetValue.length!==0' class="ellipsis" style="width: 390rpx;">
+								{{badSheetValue}}
+							</view>
+							<u-icon :name="!badSheetShow?'arrow-down-fill':'arrow-up-fill'"></u-icon>
+						</view>
+					</view>
+				</view> -->
+
 
 			</u-modal>
 
@@ -329,7 +364,12 @@
 
 <script>
 	import {
-		MesOrderStepStart
+		MesOrderStepStart,
+		PersonPermissions,
+		EqpPermissionsPlus,
+		GroupsPermissions,
+		GroupsPersonPermissions,
+		DefectPermissions
 	} from '../../config/api.js';
 	// import scanCode from '@/components/scan-code/scan-code.vue'
 	export default {
@@ -416,7 +456,10 @@
 				userGroupColumns: [], //
 				eqpColumns: [], //
 				operColumns: [], //
-				isAsyncChange: false
+				isAsyncChange: false,
+
+				userCheckBoxValue: [],
+				userSheetShow: false
 			}
 		},
 		created() {
@@ -427,62 +470,63 @@
 
 
 			this.getMesOrderStepStart('SGPO20231110_1;101')
-			// this.getMesOrderStepReportSelectUserGroup() //鑾峰彇鐢熶骇鐝粍
-			// this.getMesOrderStepStartSelectEqp('MO-2023-02-1502;GX002') //鑾峰彇璁惧鍚嶇О
-			// this.getMesOrderStepSelectCause('MO-2023-02-1502;GX002')
-			// this.getMesOrderSelectUser() //鑾峰彇鎿嶄綔浜哄憳
-			// this.getMesOrderGroupSelectUser('BZ001') //鏍规嵁鐝粍鑾峰彇浜哄憳
+
+
+
+
+			this.getSellectAllApi()
+
+
 		},
 		methods: {
 			init() {
 				uni.stopPullDownRefresh();
 			},
+			async getSellectAllApi() {
+				await this.getGroupsPermissions() //鑾峰彇鐢熶骇鐝粍
+				await this.getEqpPermissionsPlus() //鑾峰彇璁惧鍚嶇О
+				await this.getDefectPermissions() //鑾峰彇缂洪櫡涓嬫媺
+				await this.getPersonPermissions() //鑾峰彇鎿嶄綔浜哄憳
+			},
+
 
 			//鑾峰彇鐢熶骇鐝粍
-			async getMesOrderStepReportSelectUserGroup(wkshopcode) {
-				const data = {
-					stu_torgcode: uni.getStorageSync('stu_torgcode'),
-					stu_torgtypecode: uni.getStorageSync('description'),
-					wkshopcode
-				}
+			async getGroupsPermissions(wkshopcode) {
 
-				const res = await MesOrderStepReportSelectUserGroup(this.global.formatData(data))
+				const res = await GroupsPermissions()
 				if (res.code === '200') {
 					// 鏁扮粍瀵硅薄  鏇挎崲瀵硅薄閿悕
 					this.userGroupSheetList = res.data.map(({
-						group_code,
-						group_name
+						usergroupcode,
+						usergroupname
 					}) => ({
-						code: group_code,
-						name: group_name
+						code: usergroupcode,
+						name: usergroupname
 					}))
 
 					this.userGroupColumns = [this.userGroupSheetList.map(i => i.name)]
 				}
 			},
 			// 鑾峰彇璁惧鍚嶇О
-			async getMesOrderStepStartSelectEqp(orderstepqrcode) {
-				const res = await MesOrderStepStartSelectEqp(this.global.formatData({
-					orderstepqrcode
-				}))
+			async getEqpPermissionsPlus() {
+				const res = await EqpPermissionsPlus()
 				if (res.code === '200') {
 					this.eqpSheetList = res.data
 					this.eqpColumns = [this.eqpSheetList.map(i => i.name)]
 				}
 			},
 			// 鑾峰彇涓嶈壇鍘熷洜
-			async getMesOrderStepSelectCause(orderstepqrcode) {
-				const res = await MesOrderStepSelectCause(this.global.formatData({
-					orderstepqrcode
-				}))
+			async getDefectPermissions(orderstepqrcode) {
+				const res = await DefectPermissions()
 				if (res.code === '200') {
 					this.badSelectArr = res.data
 				}
 			},
-			// 鑾峰彇鎿嶄綔浜哄憳
-			async getMesOrderSelectUser() {
-				const res = await MesOrderSelectUser()
+			// 鑾峰彇鎶ュ伐浜哄憳
+			async getPersonPermissions() {
+				const res = await PersonPermissions()
 				if (res.code === '200') {
+					// this.operSheetList = res.data
 					this.operSheetList = res.data.map(({
 						usercode,
 						username
@@ -495,30 +539,46 @@
 				}
 			},
 			// 鏍规嵁鐢熶骇鐝粍鑾峰彇浜哄憳
-			async getMesOrderGroupSelectUser(usergroupcode) {
-				const data = {
-					usergroupcode,
-					stu_torgcode: uni.getStorageSync('stu_torgcode')
-				}
-				const res = await MesOrderGroupSelectUser(this.global.formatData(data))
-				if (res.code === '200') {
-					this.userArr = res.data
-					this.calculatedValue()
-				}
-			},
-			// 璁$畻鍒嗛厤姣斾緥鐨勫��
-			calculatedValue() {
-				const total = 100;
-				let value = 0
-				this.userArr.forEach(item => {
-					item.ratio = parseFloat((100 / this.userArr.length).toFixed(2))
-					value += item.ratio
+			async getGroupsPersonPermissions(groupcode) {
+
+				const res = await GroupsPersonPermissions({
+					groupcode
 				})
-				if (Math.round(value * 100) / 100 !== total) {
-					this.userArr[this.userArr.length - 1].ratio = parseFloat((this.userArr[this.userArr.length - 1].ratio +
-						(total - value)).toFixed(2))
+				if (res.code === '200') {
+					this.userCheckBoxValue = []
+
+					if (res.data[0].usercode_list && res.data[0].usercode_list.length > 0) {
+						this.userSelectArrAll.forEach(i => {
+
+							if (res.data[0].usercode_list.split(',').includes(i.code)) {
+								this.userCheckBoxValue.push(i.name)
+							}
+
+						})
+
+					}
+
+					this.operSheetValue = this.userCheckBoxValue.join(',')
+
+
 				}
 			},
+
+
+
+			userSheetSelect() {
+
+			},
+			userCheckboxChange(val) {
+				this.userCheckBoxValue = val.join(',')
+				// this.userCheckBoxValue = ['001']
+				// this.$forceUpdate()
+
+				// console.log(this.userCheckBoxValue);
+			},
+
+
+
 
 			//鑾峰彇寮�宸ヤ俊鎭�
 			async getMesOrderStepStart(orderstepqrcode) {
@@ -533,11 +593,11 @@
 				if (res.code === '200' && res.count === 1) {
 					this.formData = res.data
 					this.topContent.unshift(res.data)
-					this.getMesOrderStepReportSelectUserGroup(res.data.wkshopcode)
-					let o = res.data.wo_code + ';' + res.data.stepcode
-					this.getMesOrderStepStartSelectEqp(o)
-					this.getMesOrderStepSelectCause(o)
-					this.getMesOrderSelectUser()
+					// this.getGroupsPermissions(res.data.wkshopcode)
+					// let o = res.data.wo_code + ';' + res.data.stepcode
+					// this.getEqpPermissionsPlus(o)
+					// this.getDefectPermissions(o)
+					// this.getPersonPermissions()
 
 				} else if (res.code === '200' && res.count !== 1) {
 					this.$u.toast('姝ゅ伐搴忓凡鎶ュ伐锛�')
@@ -757,7 +817,16 @@
 				console.log(this.badSheetValue, 5);
 			},
 			operSheetClick() {
-				this.operSheetShow = true
+				if (this.reckway === '涓汉') {
+					this.operSheetShow = true
+				}
+
+				if (this.reckway === '鐝粍') {
+					this.userSheetShow = true
+				}
+
+
+
 			},
 			operSheetSelect(val) {
 				this.operSheetValue = val.name
@@ -780,7 +849,7 @@
 			// 鍒犻櫎浜哄憳鎸夐挳
 			deleteUser(item) {
 				this.userArr = this.userArr.filter(i => i.usercode !== item.usercode)
-				this.calculatedValue()
+
 			},
 			// 妯℃�佹鍙栨秷鎸夐挳
 			modalCancel() {
@@ -799,14 +868,14 @@
 					uni.$u.toast('璇烽�夋嫨鎶ュ伐浜哄憳锛�')
 				}
 				this.modalShow = false
-				this.calculatedValue()
+
 			},
 			userChange(val) {
 				this.userSelectValue = val
 			},
 			userGroupPickerConfirm(val) {
 				console.log(val, 11)
-				this.getMesOrderGroupSelectUser(this.userGroupSheetList.find(i => i.name === val.value[0]).code)
+				this.getGroupsPersonPermissions(this.userGroupSheetList.find(i => i.name === val.value[0]).code)
 				this.userGroupSheetValue = val.value[0]
 				this.userGroupSheetShow = false
 			},

--
Gitblit v1.9.3