From bdb2bfbe94a1ff091ac5ae379ea01f25f359fc83 Mon Sep 17 00:00:00 2001
From: wxw <Administrator@DESKTOP-5BIMHQ3>
Date: 星期一, 23 十二月 2024 15:52:36 +0800
Subject: [PATCH] 修改问题

---
 Wms/WMS.BLL/BllTransServer/RcsServer.cs               |  705 ++++++++++++++++++++++--------------
 HTML/views/QualityControl/QualityInformationFrom.html |    4 
 Wms/WMS.BLL/BllQualityServer/QualityInspectServer.cs  |   72 ---
 Wms/Model/InterFaceModel/RCSModel.cs                  |    7 
 HTML/views/Login.html                                 |   12 
 HTML/views/ASNSetting/ArrivalNoticeDetail.html        |   16 
 HTML/views/SOSetting/ExportNoticeAddFrom.html         |   72 +--
 Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs         |  148 +------
 HTML/views/SOSetting/ExportSelectSkuFrom.html         |   43 +-
 HTML/views/index.html                                 |    4 
 HTML/views/QualityControl/QualityInformation.html     |    2 
 HTML/views/HouseWithinSetting/CRLogTask.html          |    2 
 HTML/views/SOSetting/ExportNotice.html                |   45 --
 13 files changed, 538 insertions(+), 594 deletions(-)

diff --git a/HTML/views/ASNSetting/ArrivalNoticeDetail.html b/HTML/views/ASNSetting/ArrivalNoticeDetail.html
index a945ed2..c45524f 100644
--- a/HTML/views/ASNSetting/ArrivalNoticeDetail.html
+++ b/HTML/views/ASNSetting/ArrivalNoticeDetail.html
@@ -61,24 +61,12 @@
 				<select name="Type" id="Type" lay-filter="Type" lay-search>
 					<!-- JC23 -->
 					<!-- <option value="0">鎴愬搧鍏ュ簱</option> -->
-					<option value="1">鍘熸枡鍏ュ簱</option>
+					<!-- <option value="1">鍘熸枡鍏ュ簱</option> -->
 					<!-- <option value="4">杞﹂棿浣欐枡閫�鍥炲叆搴�</option>
-					<option value="5">鍏跺畠鍏ュ簱</option>
+					
 					<option value="6">浠e偍鍏ュ簱</option> -->
 					<!-- <option value=""></option> -->
-					<!-- JC24 -->
-					<!-- <option value="0" selected>鎴愬搧鍏ュ簱</option>
-					<option value="1">閲囪喘鍏ュ簱</option>
-					<option value="2">涓棿鍝佸叆搴�</option> -->
-					<!-- <option value="3">閫�璐у叆搴�</option> -->
-					<!-- <option value="4">杞﹂棿浣欐枡閫�鍥炲叆搴�</option>
 					<option value="5">鍏跺畠鍏ュ簱</option>
-					<option value="6">浠e偍鍏ュ簱</option>
-					<option value="7">瀵勫瓨鍏ュ簱</option> -->
-					<!-- JC08 -->
-					<!-- <option value="0">鎴愬搧鍏ュ簱</option>
-					<option value="1">鍘熸枡鍏ュ簱</option>
-					<option value="2">閫�璐у叆搴�</option> -->
 				</select>
 			</div>
 
diff --git a/HTML/views/HouseWithinSetting/CRLogTask.html b/HTML/views/HouseWithinSetting/CRLogTask.html
index 27d537a..1b8b459 100644
--- a/HTML/views/HouseWithinSetting/CRLogTask.html
+++ b/HTML/views/HouseWithinSetting/CRLogTask.html
@@ -305,7 +305,7 @@
 						templet: '#IsSuccessButton',
 					}, {
 						field: 'PalletNo',
-						title: '鎵樼洏鍙�',
+						title: '妗跺彿',
 						width: 110,
 						align: 'center',
 					}, {
diff --git a/HTML/views/Login.html b/HTML/views/Login.html
index 2e3b700..a538c9e 100644
--- a/HTML/views/Login.html
+++ b/HTML/views/Login.html
@@ -3,9 +3,9 @@
 
 <head>
 	<meta charset="utf-8">
-	<title>鍗氭煰鑾甭蜂粨鍌ㄧ鐞嗙郴缁�</title>
-	<meta name="keywords" content="鍗氭煰鑾甭蜂粨鍌ㄧ鐞嗙郴缁�">
-	<meta name="description" content="鍗氭煰鑾甭蜂粨鍌ㄧ鐞嗙郴缁�">
+	<title>鍗氭煰鑾甭稟GV杞繍绯荤粺</title>
+	<meta name="keywords" content="鍗氭煰鑾甭稟GV杞繍绯荤粺">
+	<meta name="description" content="鍗氭煰鑾甭稟GV杞繍绯荤粺">
 	<!-- <link rel="shortcut icon" type="image/ico" href="../img/娌冲寳鍗氭煰鑾�-logo01.png" /> -->
 	<!-- <link rel="bookmark" type="image/ico" href="../img/favicon.ico" /> -->
 	<link href="../layuiadmin/layui/css/layui.css" rel="stylesheet" />
@@ -20,17 +20,17 @@
 
 <body>
 	<div class="elight-product-box animated fadeInUp">
-		<h2>鍗氭煰鑾甭蜂粨鍌ㄧ鐞嗙郴缁�</h2>
+		<!-- <h2>鍗氭煰鑾甭疯浆杩愮郴缁�</h2>
 		<ul class="product-desc">
 			<li>鈥滃崥鏌幈路浠撳偍绠$悊绯荤粺鈥濈畝绉扳�淲MS绯荤粺鈥濓紝WMS鏄櫤鑳戒粨搴撶鐞嗙郴缁�(Warehouse Management System) 鐨勭缉鍐欍��</li>
 			<li>WMS绯荤粺鏄竴涓疄鏃剁殑銆佸畬鍠勭殑浼佷笟绾т粨鍌ㄤ俊鎭鐞嗙郴缁熴��</li>
 			<li>瀹冭兘澶熸寜鐓ц繍浣滅殑涓氬姟瑙勫垯鍜岃繍绠楁硶鍒欙紝閫氳繃鍏ュ簱銆佸嚭搴撱�佺Щ搴撳拰鎷i�夌瓑鍔熻兘锛岀患鍚堟壒娆$鐞嗐�佺墿鏂欏搴斻�佸簱瀛樼洏鐐广�佽川閲忕鐞嗗拰鍗虫椂搴撳瓨绠$悊绛夊姛鑳界殑杩愮敤锛屽淇℃伅銆佽祫婧愩�佽涓哄拰瀛樿揣杩涜瀹岀編鐨勭鐞嗭紝浣垮叾鑳芥渶澶х▼搴︾殑婊¤冻鏈夋晥浜у嚭鍜岀簿纭�х殑瑕佹眰銆�
 			</li>
 			<li>瀹冮�氳繃鏉$爜鎵弿銆佹祦姘磋窡韪�佷换鍔¤窡韪瓑鏂瑰紡鏈夋晥鎺у埗骞惰窡韪粨鍌ㄤ笟鍔$殑鍏ㄨ繃绋嬶紝鎻愰珮浠撳偍鐗╂祦閰嶉�佹晥鐜囷紝鍑忓皯浠撳簱浣滀笟瀵逛汉鍛樼粡楠岀殑渚濊禆鎬с��</li>
-		</ul>
+		</ul> -->
 	</div>
 	<div class="elight-login-box animated fadeInRight">
-		<div class="elight-login-header">鍗氭煰鑾甭蜂粨鍌ㄧ鐞嗙郴缁�</div>
+		<div class="elight-login-header">鍗氭煰鑾甭稟GV杞繍绯荤粺</div>
 		<div class="elight-login-body">
 			<form class="layui-form">
 				<div class="layui-form-item">
diff --git a/HTML/views/QualityControl/QualityInformation.html b/HTML/views/QualityControl/QualityInformation.html
index 6536610..ecf76b3 100644
--- a/HTML/views/QualityControl/QualityInformation.html
+++ b/HTML/views/QualityControl/QualityInformation.html
@@ -363,7 +363,7 @@
 									InspectNo: field.InspectNo,        
 									//ASNNo: field.ASNNo,        
 									LotNo: field.LotNo,
-									SkuNo: field.SkuNo,
+									//SkuNo: field.SkuNo,
 									IsQualified: field.IsQualified,
 								};
 								if(doing)
diff --git a/HTML/views/QualityControl/QualityInformationFrom.html b/HTML/views/QualityControl/QualityInformationFrom.html
index 9b55017..b15ceca 100644
--- a/HTML/views/QualityControl/QualityInformationFrom.html
+++ b/HTML/views/QualityControl/QualityInformationFrom.html
@@ -28,12 +28,12 @@
 					<input type="text" name="LotNo" placeholder="璇疯緭鍏ユ壒娆″彿" lay-verify="required" autocomplete="off" class="layui-input">
 				</div>
 			</div>
-			<div class="layui-form-item">
+			<!-- <div class="layui-form-item">
 				<label class="layui-form-label">鐗╂枡鍙�</label>
 				<div class="layui-input-block" style="width: 70%;">
 					<input type="text" name="SkuNo" placeholder="璇疯緭鍏ョ墿鏂欏彿" lay-verify="required" autocomplete="off" class="layui-input">
 				</div>
-			</div>
+			</div> -->
 			<div class="layui-form-item">
 					<label class="layui-form-label">瀹℃牳鐘舵��</label>
 					<div class="layui-input-block" style="width: 70%;">
diff --git a/HTML/views/SOSetting/ExportNotice.html b/HTML/views/SOSetting/ExportNotice.html
index db804ef..aea67b9 100644
--- a/HTML/views/SOSetting/ExportNotice.html
+++ b/HTML/views/SOSetting/ExportNotice.html
@@ -326,51 +326,14 @@
 				<script type="text/html" id="table-content-list">
 						{{# function GetBtn1(d){
 								var html = ''; 
-								if(d.IsWave == '0'){
-									if(d.Status == '0' || d.Status == '1' ){
-										if(d.Type != "8" && d.Type != "2") {
-											html += `<a class="layui-btn layui-btn-normal layui-btn-xs zifenClass" lay-event="auto"> 
-												<i class="layui-icon layui-icon-ok"></i>鑷姩鍒嗛厤
-											</a>`;
-										}
-									}
+								if(d.IsWave == '0'){									
 									if(d.Status == '0' && d.Origin == 'WMS'){
-										html += `<a class="layui-btn layui-btn-normal layui-btn-xs uptClass" lay-event="edit">
-													<i class="layui-icon layui-icon-edit"></i>缂栬緫
-												</a>
-												<a class="layui-btn layui-btn-danger layui-btn-xs delClass" lay-event="delete">
+										html += `<a class="layui-btn layui-btn-danger layui-btn-xs delClass" lay-event="delete">
 													<i class="layui-icon layui-icon-delete"></i>鍒犻櫎
 												</a>`;
 									}
-									if(d.Status == '1' || d.Status == '2'){
-										html += `<a class="layui-btn layui-btn-danger layui-btn-xs qufenClass" lay-event="cancel">
-													<i class="layui-icon layui-icon-delete"></i>鍙栨秷鍒嗛厤
-												</a>`;
-									}
-									if(d.Type == "1" && (d.Status == '2' || d.Status == '3')){
-										html += `<a class="layui-btn layui-btn-normal layui-btn-xs outClass" lay-event="beiLiaoOutKu">
-											<i class="layui-icon layui-icon-ok"></i>澶囨枡
-										</a>`;
-									}
-									if( d.Status == '2' || d.Status == '3'){
-										html += `<a class="layui-btn layui-btn-normal layui-btn-xs outClass" lay-event="outKu">
-													<i class="layui-icon layui-icon-ok"></i>鍑哄簱
-												</a>`;
-									}
 								}
-								if( d.Status == '4'){
-									html += `<a class="layui-btn layui-btn-normal layui-btn-xs guanClass" lay-event="finish"> 
-												<i class="layui-icon layui-icon-ok"></i>鍏冲崟
-											</a>`;
-								}								
-								if( d.Status == '5'){
-									html += `<a class="layui-btn layui-btn-normal layui-btn-xs checkClass" lay-event="check"> 
-										<i class="layui-icon layui-icon-ok"></i>澶嶆牳
-									</a>`;
-								}
-								html += `<a class="layui-btn layui-btn-normal layui-btn-xs shangClass" lay-event="xml"> 
-									<i class="layui-icon layui-icon-ok"></i>XML
-								</a>`;
+								
 								html += `<a class="layui-btn layui-btn-normal layui-btn-xs editDemoClass" lay-event="editDemo">
 									<i class="layui-icon layui-icon-edit"></i>澶囨敞</a>`;
 								return html;
@@ -488,7 +451,7 @@
 				{ field: 'UpdateTime', title: '淇敼鏃堕棿', align: 'center', templet: '#templetUpdateTime' },
 				{ field: 'CheckUserName', title: '澶嶆牳浜�', align: 'center', width: 110 },
 				{ field: 'CheckTime', title: '澶嶆牳鏃堕棿', align: 'center', templet: '#templetCheckTime' },
-				//{ field: 'caozuo', title: '鎿嶄綔', fixed: 'right', align: 'center', width: 200, toolbar: '#table-content-list', "disabled": false }
+				{ field: 'caozuo', title: '鎿嶄綔', fixed: 'right', align: 'center', width: 200, toolbar: '#table-content-list', "disabled": false }
 			]];
 			var TotalColsSysArr = encodeURIComponent(encodeURIComponent(JSON.stringify(TotalColsArr)))//灏嗚〃澶存暟鎹繘琛寀rl缂栫爜
 			//#endregion
diff --git a/HTML/views/SOSetting/ExportNoticeAddFrom.html b/HTML/views/SOSetting/ExportNoticeAddFrom.html
index 1d0302c..c40e51d 100644
--- a/HTML/views/SOSetting/ExportNoticeAddFrom.html
+++ b/HTML/views/SOSetting/ExportNoticeAddFrom.html
@@ -34,36 +34,16 @@
 						<select name="Type" id="Type" lay-filter="Type" lay-verify="required" lay-search>
 							<!-- <option value=""></option> -->
 							<!-- 23 -->
-							<!-- <option value="0">鎴愬搧鍑哄簱</option> -->
-							<option value="1">棰嗘枡鍑哄簱</option>
-							<!-- <option value="2">鎶芥鍑哄簱</option>
-							<option value="4">涓嶅悎鏍煎搧鍑哄簱</option>
-							<option value="6">浠e偍鍑哄簱</option>
-							<option value="7">鍏朵粬鍑哄簱</option> -->
-							<!-- 24 -->
 							<!-- <option value="0">鎴愬搧鍑哄簱</option>
 							<option value="1">棰嗘枡鍑哄簱</option>
 							<option value="2">鎶芥鍑哄簱</option>
-							<option value="3">鐗╂枡鍙栨牱鍑哄簱</option>
 							<option value="4">涓嶅悎鏍煎搧鍑哄簱</option>
-							<option value="5">涓棿鍝佸嚭搴�</option>
-							<option value="6">浠e偍鍑哄簱</option>
-							<option value="7">鍏朵粬鍑哄簱</option>
-							<option value="8">瀵勫瓨鍑哄簱</option> -->
-							<!-- 09 -->
-							<!-- <option value="0">鏍囧噯閿�鍞嚭搴�</option>
-							<option value="1">闈炴爣閿�鍞嚭搴�</option>
-							<option value="2">鏍囧噯璋冩嫧鍑哄簱</option>
-							<option value="3">闈炴爣璋冩嫧鍑哄簱</option> -->
-							<!-- 08 -->
-							<!-- <option value="0">鎴愬搧鍑哄簱</option>
-							<option value="1">鍘熻緟鏂欏嚭搴�</option>
-							<option value="2">涓嶅悎鏍煎搧鍑哄簱</option>
-							<option value="3">鍙栨牱鍑哄簱</option> -->
+							<option value="6">浠e偍鍑哄簱</option> -->
+							<option value="7">鍏朵粬鍑哄簱</option>							
 						</select>
 					</div>
 				</div>
-				<div class="layui-inline">
+				<!-- <div class="layui-inline">
 					<label class="layui-form-label" id="CustomerNamep">瀹㈡埛鍚嶇О</label>
 					<div class="layui-input-inline">
 						<select name="CustomerNo" id="CustomerNo" lay-search>
@@ -78,7 +58,7 @@
 							<option value=""></option>
 						</select>
 					</div>
-				</div>
+				</div> -->
 				<div class="layui-inline">
 					<div style="padding-bottom: 2px;margin-left: 15px;">
 						<button class="layui-btn layui-btn-sm layuiadmin-btn-list" data-type="add">娣诲姞鏄庣粏</button>
@@ -172,27 +152,31 @@
 					limits: pageLimits,
 					cellMinWidth: 60, //鍏ㄥ眬瀹氫箟甯歌鍗曞厓鏍肩殑鏈�灏忓搴︼紝layui 2.2.1 鏂板
 					cols: [
-						[{
-							field: 'SkuNo',
-							title: '鐗╁搧缂栫爜', 
-							align: 'center',
-							fixed: 'left',
-							width:140,
-						}, {
-							field: 'SkuName',
-							title: '鐗╁搧鍚嶇О', 
-							align: 'center',
-							fixed: 'left',
-						}, {
+						[
+						// 	{
+						// 	field: 'SkuNo',
+						// 	title: '鐗╁搧缂栫爜', 
+						// 	align: 'center',
+						// 	fixed: 'left',
+						// 	width:140,
+						// }, {
+						// 	field: 'SkuName',
+						// 	title: '鐗╁搧鍚嶇О', 
+						// 	align: 'center',
+						// 	fixed: 'left',
+						// }, 
+						{
 							field: 'LotNo',
 							title: '鎵规',
 							align: 'center', 
 							minWidth:140,
-						}, {
-							field: 'Standard',
-							title: '鐗╁搧瑙勬牸',
-							align: 'center', 
-						}, {
+						}, 
+						// {
+						// 	field: 'Standard',
+						// 	title: '鐗╁搧瑙勬牸',
+						// 	align: 'center', 
+						// }, 
+						{
 							field: 'Qty',
 							title: '搴撳瓨鏁伴噺',  
 							align: 'center',
@@ -422,11 +406,11 @@
 							return;
 						}
 						var item = {
-							SkuNo: infoOptions.data[i].SkuNo,
+							//SkuNo: infoOptions.data[i].SkuNo,
 							LotNo: infoOptions.data[i].LotNo,
 							Qty: parseInt(infoOptions.data[i].ExQty),
-							IsBale:infoOptions.data[i].IsBale,
-							IsBelt:infoOptions.data[i].IsBelt,
+							//IsBale:infoOptions.data[i].IsBale,
+							//IsBelt:infoOptions.data[i].IsBelt,
 						};
 						DataList.push(item); //灞炴��
 					}
diff --git a/HTML/views/SOSetting/ExportSelectSkuFrom.html b/HTML/views/SOSetting/ExportSelectSkuFrom.html
index 548ed45..17fef36 100644
--- a/HTML/views/SOSetting/ExportSelectSkuFrom.html
+++ b/HTML/views/SOSetting/ExportSelectSkuFrom.html
@@ -99,28 +99,31 @@
 								type: 'radio',
 								width: 50,
 								fixed: 'left'
-							}, {
-								field: 'SkuNo',
-								title: '鐗╁搧缂栫爜',
-								width: 100,
-								align: 'center',
-								fixed: 'left'
-							}, {
-								field: 'SkuName',
-								title: '鐗╁搧鍚嶇О',
-								align: 'center',
-								width: 250,
-							}, {
+							},
+							//  {
+							// 	field: 'SkuNo',
+							// 	title: '鐗╁搧缂栫爜',
+							// 	width: 100,
+							// 	align: 'center',
+							// 	fixed: 'left'
+							// }, {
+							// 	field: 'SkuName',
+							// 	title: '鐗╁搧鍚嶇О',
+							// 	align: 'center',
+							// 	width: 250,
+							// }, 
+							{
 								field: 'LotNo',
 								align: 'center',
-								title: '鎵规',
-								width: 100
-							}, {
-								field: 'Standard',
-								title: '鐗╁搧瑙勬牸',
-								align: 'center',
-								minWidth: 100
-							}, {
+								title: '鎵规'
+							},
+							//  {
+							// 	field: 'Standard',
+							// 	title: '鐗╁搧瑙勬牸',
+							// 	align: 'center',
+							// 	minWidth: 100
+							// }, 
+							{
 								field: 'Qty',
 								title: '搴撳瓨鏁伴噺',
 								width: 100,
diff --git a/HTML/views/index.html b/HTML/views/index.html
index ba720fe..8600cec 100644
--- a/HTML/views/index.html
+++ b/HTML/views/index.html
@@ -2,7 +2,7 @@
 <html>
 	<head>
 		<meta charset="utf-8">
-		<title>浠撳偍绠$悊绯荤粺</title>
+		<title>AGV杞繍绯荤粺</title>
 		<meta name="renderer" content="webkit">
 		<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
 		<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=0">
@@ -66,7 +66,7 @@
 				<div class="layui-side layui-side-menu" id="leftmenu">
 					<div class="layui-side-scroll">
 						<div class="layui-logo" lay-href="home/console.html" style="background-color: #FFFFFF;">
-							<span>鍗氭煰鑾甭蜂粨鍌ㄧ鐞嗙郴缁�</span>
+							<span>鍗氭煰鑾甭稟GV杞繍绯荤粺</span>
 						</div>
 						<ul class="layui-nav layui-nav-tree" lay-shrink="all" id="LAY-system-side-menu" lay-filter="layadmin-system-side-menu">
 							
diff --git a/Wms/Model/InterFaceModel/RCSModel.cs b/Wms/Model/InterFaceModel/RCSModel.cs
index 2df3ff8..9178884 100644
--- a/Wms/Model/InterFaceModel/RCSModel.cs
+++ b/Wms/Model/InterFaceModel/RCSModel.cs
@@ -28,7 +28,7 @@
         public class Pallnetmsg
         {
             /// <summary>
-            /// 璁惧鎵�鍦ㄤ綅缃紙璧峰浣嶇疆/鐩爣浣嶇疆锛�
+            /// 璁惧鎵�鍦ㄤ綅缃紙璧峰浣嶇疆/鐩爣浣嶇疆锛夛紝璁惧缂栫爜
             /// </summary>
             public string Location { get; set; }
             /// <summary>
@@ -70,8 +70,13 @@
             /// 浠诲姟绫诲瀷 
             /// 0锛氱敵璇峰偍浣�
             /// 1锛氬彨妗�
+            /// 2锛氬悓杞﹂棿骞冲眰鎼繍
             /// </summary>
             public string Crtype { get; set; }
+            /// <summary>
+            /// 杞﹂棿缂栫爜
+            /// </summary>
+            public string WareHouseNo { get; set; }
         }
     }
 }
diff --git a/Wms/WMS.BLL/BllQualityServer/QualityInspectServer.cs b/Wms/WMS.BLL/BllQualityServer/QualityInspectServer.cs
index c7bb748..7fcd8a6 100644
--- a/Wms/WMS.BLL/BllQualityServer/QualityInspectServer.cs
+++ b/Wms/WMS.BLL/BllQualityServer/QualityInspectServer.cs
@@ -95,98 +95,38 @@
             {
                 throw new Exception("璐ㄦ鍙蜂笉鍙负绌猴紝璇锋牳鏌ワ紒");
             }
-            //楠岃瘉鐗╂枡鍙锋槸鍚︿负绌�
-            if (string.IsNullOrEmpty(model.SkuNo))
-            {
-                throw new Exception("鐗╂枡鍙蜂笉鍙负绌猴紝璇锋牳鏌ワ紒");
-            }
-            //鑾峰彇鐗╂枡淇℃伅
-            var sku = Db.Queryable<SysMaterials>().First(a => a.IsDel == "0" && a.SkuNo == model.SkuNo);
-            if (sku == null)
-            {
-                throw new Exception("鐗╂枡淇℃伅涓虹┖锛岃鏍告煡锛�");
-            }
             //楠岃瘉鎵规鍙锋槸鍚︿负绌�
             if (string.IsNullOrEmpty(model.LotNo))
             {
                 throw new Exception("鎵规鍙蜂笉鍙负绌猴紝璇锋牳鏌ワ紒");
             }
-            //int isTui = 0;
-            //楠岃瘉鍏ュ簱鍗曞彿鏄惁涓虹┖
-            if (!string.IsNullOrEmpty(model.ASNNo))
-            {
-                //鏌ヨ鏄惁涓洪��璐у叆搴撳崟鎹�
-                var Arrival = Db.Queryable<BllArrivalNotice>().First(a => a.IsDel == "0" && a.ASNNo == model.ASNNo && a.Type == "3");
-                if (Arrival == null)
-                {
-                    throw new Exception("鍙湁鍏ュ簱鍗曟嵁涓洪��璐у叆搴撳崟鍙緭鍏� 鍏ュ簱鍗曞彿锛岃鏍告煡锛�");
-                }
-
-                //鑾峰彇鍏ュ簱鍗曟槑缁�
-                var ArrivalDetail = Db.Queryable<BllArrivalNoticeDetail>().First(a => a.IsDel == "0" && a.ASNNo == model.ASNNo && a.LotNo.Contains(model.LotNo) && a.SkuNo == model.SkuNo);
-                if (ArrivalDetail == null)
-                {
-                    throw new Exception("杈撳叆鐨勬壒娆℃垨鐗╂枡淇℃伅涓庡叆搴撳崟鎹笉绗︼紝璇锋牳鏌ワ紒");
-                }
-                //isTui = 1;
-            }
-
-            //鏌ユ壘璐ㄦ淇℃伅涓槸鍚﹀瓨鍦ㄥ悓鎵规璐ㄦ褰曞叆璁板綍
-            //BllQualityInspect quality = Db.Queryable<BllQualityInspect>().First(m => m.IsDel == "0" && m.SkuNo == model.SkuNo && m.LotNo == model.LotNo);
-
-            //if (quality != null)
-            //{
-                ////鍒ゆ柇鏄惁涓洪��璐у叆搴撳崟
-                //if (isTui == 1)
-                //{
-                //    if (quality.ASNNo == model.ASNNo)
-                //    {
-                //        throw new Exception("褰撳墠閫�璐у叆搴撳崟宸插垱寤鸿川妫�淇℃伅锛岃鍕块噸澶嶅垱寤猴紒");
-                //    }
-                //}
-            //    throw new Exception("褰撳墠鐗╂枡鍜屾壒娆″凡杩涜璐ㄦ锛岃鏍告煡锛�");
-            //}
-
-            ////鏌ユ壘鍚屾壒娆� 鍚屽崟鎹� 鍏ュ簱鍗曚俊鎭��
-            //BllArrivalNoticeDetail arrivalDetail = Db.Queryable<BllArrivalNoticeDetail>().First(m => m.IsDel == "0" && m.ASNNo == model.ASNNo && m.LotNo == model.LotNo);
 
             model.Origin = "WMS"; //鏉ユ簮
             model.CreateTime = Db.GetDate(); //鍒涘缓鏃ユ湡
-            model.SkuNo = sku.SkuNo; //鐗╂枡鍙�
-            model.SkuName = sku.SkuName; //鐗╂枡鍚嶇О
+            model.SkuNo = ""; //鐗╂枡鍙�
+            model.SkuName = ""; //鐗╂枡鍚嶇О
             model.PassQty = 0; //鍚堟牸鏁伴噺
             model.FailQty = 0; //涓嶅悎鏍兼暟閲�
-            model.Standard = sku.Standard; //瑙勬牸
-            //model.SupplierLot = arrivalDetail.SupplierLot; //渚涜揣鎵规
+            model.Standard = ""; //瑙勬牸
 
             //鏌ユ壘搴撳瓨鏄庣粏淇℃伅
-            List<DataStockDetail> detail = Db.Queryable<DataStockDetail>().Where(m => m.IsDel == "0" && m.SkuNo == model.SkuNo && m.LotNo == model.LotNo).ToList();
+            List<DataStockDetail> detail = Db.Queryable<DataStockDetail>().Where(m => m.IsDel == "0" && m.LotNo == model.LotNo).ToList();
             foreach (var item in detail)
             {
-                List<BllBoxInfo> box = Db.Queryable<BllBoxInfo>().Where(a => a.IsDel == "0" && a.SkuNo == model.SkuNo && a.LotNo == model.LotNo).ToList();
                 //鍒ゆ柇鍚堟牸鐘舵�佹槸鍚﹀悎鏍�
                 if (model.IsQualified == "1")
                 {
-                    //鍚堟牸 鐩稿悓鎵规搴撳瓨淇℃伅鍏ㄩ儴鏀逛负鍚堟牸鐘舵�� 涓斿悎鏍兼暟閲忓鍔犱负鍚屾壒娆″悓鍗曞彿璇ョ墿鏂欏叏閮ㄦ暟閲忎箣鍜�
+                    //鍚堟牸
                     model.PassQty += item.Qty;
                     //淇敼搴撳瓨鏄庣粏鍚堟牸鐘舵��
                     item.InspectStatus = "1"; //1鍚堟牸
-                    //foreach (var b1 in box)
-                    //{
-                    //    b1.InspectMark = "1"; //1鍚堟牸
-                    //}
                 }
                 else //涓嶅悎鏍�
                 {
-                    //涓嶅悎鏍� 鐩稿悓鎵规銆佸叆搴撳崟搴撳瓨淇℃伅鍏ㄩ儴鏀逛负涓嶅悎鏍肩墿鏂� 涓斾笉鍚堟牸鏁伴噺澧炲姞涓哄悓鎵规鍚屽崟鍙疯鐗╂枡鍏ㄩ儴鏁伴噺涔嬪拰
+                    //涓嶅悎鏍�
                     model.FailQty += item.Qty;
                     item.InspectStatus = "2"; //2涓嶅悎鏍�
-                    //foreach (var b1 in box)
-                    //{
-                    //    b1.InspectMark = "2"; //2涓嶅悎鏍�
-                    //}
                 }
-                Db.Updateable(box).ExecuteCommand();
                 Db.Updateable(item).ExecuteCommand();
             }
             var isquality = Db.Insertable(model).ExecuteCommand();
diff --git a/Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs b/Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs
index e904d0f..35e9210 100644
--- a/Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs
+++ b/Wms/WMS.BLL/BllSoServer/ExportNoticeServer.cs
@@ -959,10 +959,11 @@
                 Expression<Func<DataStockDetail, bool>> item = Expressionable.Create<DataStockDetail>()
                     //.And(it => it.WareHouseNo == wareHouseNo)
                     .AndIF(!string.IsNullOrWhiteSpace(inspectStatus), it => inspectStatus.Contains(it.InspectStatus))
-                    .And(m => skuStrList.Contains(m.SkuNo))
+                    //.And(m => skuStrList.Contains(m.SkuNo))
                     .AndIF(type == "6", m => m.OwnerNo == ownerNo)//浠e偍鍑哄簱闇�瑕佸叧鑱旇揣涓�
                     .AndIF(!string.IsNullOrWhiteSpace(msg), it => (it.SkuNo.Contains(msg) || it.SkuName.Contains(msg) || it.LotNo.Contains(msg)))
-                    .And(it => (it.Qty - it.LockQty - it.FrozenQty) > 0)
+                    //.And(it => (it.Qty - it.LockQty - it.FrozenQty) > 0)
+                    .And(it=>!string.IsNullOrEmpty(it.LotNo))
                     .And(it => (it.Status == "0" || it.Status == "1"))
                     .ToExpression();//娉ㄦ剰 杩欎竴鍙� 涓嶈兘灏�
                 //搴撳瓨鏄庣粏
@@ -1037,14 +1038,7 @@
                 if (model == null || model.Detail.Count == 0)
                 {
                     throw new Exception("鍙傛暟寮傚父");
-                }
-                var skuNos = model.Detail.Select(a => a.SkuNo).Distinct().ToList();
-                //鏍规嵁鐗╂枡鍙疯幏鍙栫墿鏂欎俊鎭�佸簱瀛樻槑缁嗕腑鑾峰彇鎵规鎻忚堪渚涜揣鎵规绛�
-                var skuList = Db.Queryable<SysMaterials>().Where(a => skuNos.Contains(a.SkuNo) && a.IsDel == "0").ToList();
-                var stockList = Db.Queryable<DataStock>().Where(s => skuNos.Contains(s.SkuNo) && (s.Qty - s.FrozenQty - s.LockQty) > 0).ToList();
-                //var palletList = contextDb.Queryable<DataStockDetail>().Where(s => skuNos.Contains(s.SkuNo) && (s.Qty - s.FrozenQty - s.LockQty) > 0).ToList();
-                //瀹㈡埛淇℃伅
-                var customer = Db.Queryable<SysCustomer>().Where(m => m.IsDel == "0" && m.CustomerNo == model.CustomerNo).ToList();
+                }                
                 var billNo = "";
                 var bl = true;
                 do
@@ -1055,111 +1049,58 @@
                     bl = Db.Queryable<BllExportNotice>().Any(m => m.SONo == no);
                 } while (bl);
 
-
                 Db.BeginTran();//寮�鍚簨鍔�
-
                 try
                 {
                     var list = new List<BllExportNoticeDetail>();
                     //娣诲姞鍑哄簱鍗�
-                    foreach (var d in model.Detail)
+                    foreach (var item in model.Detail)
                     {
-                        if (d.Qty < 1)
+                        if (item.Qty < 1)
                         {
                             throw new Exception("鍑哄簱鏁伴噺蹇呴』澶т簬0");
                         }
-                        var sku = skuList.FirstOrDefault(a => a.SkuNo == d.SkuNo);
-                        if (sku == null)
+                        if (string.IsNullOrWhiteSpace(item.LotNo))
                         {
-                            throw new Exception($"鐗╂枡淇℃伅涓湭鏌ヨ鍒板嚭搴撶墿鏂欎俊鎭�:{d.SkuNo}");
+                            throw new Exception("鎵规涓嶅彲涓虹┖!");
                         }
-
-                        //0:鎴愬搧鍑哄簱銆�1:棰嗘枡鍑哄簱銆�2:鎶芥鍑哄簱銆�4:涓嶅悎鏍煎搧鍑哄簱銆�6:浠e偍鍑哄簱銆�7:鍏朵粬鍑哄簱銆� ///3锛氱墿鏂欏彇鏍峰嚭搴撱��5:涓棿鍝佸嚭搴撱��8:瀵勫瓨鍑哄簱
-                        if (model.Type == "0" || model.Type == "2" || model.Type == "4" || model.Type == "7")
+                        var soNoticeDetail = Db.Queryable<BllExportNoticeDetail>().First(w => w.IsDel == "0" && w.LotNo == item.LotNo);
+                        if (soNoticeDetail != null)
                         {
-                            if (string.IsNullOrWhiteSpace(d.LotNo))
+                            var soNotice = Db.Queryable<BllExportNotice>().First(w => w.IsDel == "0" && w.SONo == soNoticeDetail.SONo && (w.Status == "0" || w.Status == "1" || w.Status == "2" || w.Status == "3"));
+                            if (soNotice != null)
                             {
-                                throw new Exception("鎵规涓嶅彲涓虹┖!");
-                            }
-                        }
-
-                        if (model.Type == "1")
-                        {
-                            if (list.Count(m=>m.SkuNo == d.SkuNo)>=2)
-                            {
-                                throw new Exception("棰嗘枡鍑哄簱鍗曞悓鍗曟嵁鍚岀墿鏂欎笉鍏佽瓒呰繃3涓壒娆℃贩鎵瑰嚭搴�");
-                            }
-                        }
-                        else
-                        {
-                            if (list.Count(m => m.SkuNo == d.SkuNo) >= 1)
-                            {
-                                throw new Exception("鍑哄簱鍗曞悓鍗曟嵁鍚岀墿鏂欎笉鍏佽瓒呰繃2涓壒娆℃贩鎵瑰嚭搴�");
+                                throw new Exception($"璇ユ壒娆℃湁鏈畬鎴愮殑鍑哄簱鍗曪紝鎵规鍙凤細{soNoticeDetail.LotNo}!");
                             }
                         }
                         //搴撳瓨
-                        List<DataStock> stocks;
+                        var stockDetail = Db.Queryable<DataStockDetail>().First(w => w.IsDel == "0" && w.LotNo == item.LotNo);
 
-                        decimal q1 = 0;
-                        Dictionary<int, decimal> dic = new Dictionary<int, decimal>();
-                        if (!string.IsNullOrWhiteSpace(d.LotNo))
-                        {
-                            stocks = stockList.Where(s => s.SkuNo == d.SkuNo && s.LotNo == d.LotNo).ToList();
-                        }
-                        else
-                        {
-                            stocks = stockList.Where(s => s.SkuNo == d.SkuNo && string.IsNullOrWhiteSpace(s.LotNo)).ToList();
-                        }
-                        if (stocks.Count < 1)
-                        {
-                            throw new Exception($"鎬诲簱瀛樹腑鏈煡璇㈠埌鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}");
-                        }
-                        //鍒ゆ柇鏁伴噺
-                        var qty = stocks.First().Qty - stocks.First().LockQty - stocks.First().FrozenQty;
-                        if (d.Qty > qty)
-                        {
-                            throw new Exception($"鎬诲簱瀛樹腑鍑哄簱鐗╂枡淇℃伅:{d.SkuNo}銆亄d.LotNo} 搴撳瓨鏁伴噺涓嶈冻");
-                        }
-
-                        var item = new BllExportNoticeDetail()
+                        var noticeDetail = new BllExportNoticeDetail()
                         {
                             SONo = billNo,
-                            SkuNo = sku.SkuNo,
-                            SkuName = sku.SkuName,
-                            Standard = sku.Standard,
-                            LotNo = d.LotNo,
+                            SkuNo = stockDetail.SkuNo,
+                            SkuName = stockDetail.SkuName,
+                            Standard = stockDetail.Standard,
+                            LotNo = stockDetail.LotNo,
                             LotText = "",
                             Status = "0",
-                            Qty = d.Qty,
+                            Qty = item.Qty,
                             AllotQty = 0,
                             FactQty = 0,
                             CompleteQty = 0,
-                            PackagNo = sku.PackagNo,
-                            Price = sku.Price,
-                            Money = string.IsNullOrWhiteSpace(sku.Price.ToString()) ? null : sku.Price * d.Qty,
-                            IsBale = d.IsBale,
-                            IsBelt = d.IsBelt,
-                            SupplierLot = stocks.First().SupplierLot,
-                            IsWave = "0",
-                            WaveNo = "",
+                            //PackagNo = sku.PackagNo,
+                            //Price = sku.Price,
+                            //Money = string.IsNullOrWhiteSpace(sku.Price.ToString()) ? null : sku.Price * d.Qty,
+                            //IsBale = d.IsBale,
+                            //IsBelt = d.IsBelt,
+                            //SupplierLot = stocks.First().SupplierLot,
+                            //IsWave = "0",
+                            //WaveNo = "",
 
                             CreateUser = userId,
                         };
-                        list.Add(item);
-
-                        
-                        stocks.First().LockQty += d.Qty;//閿佸畾鏁伴噺
-                        var i = Db.Updateable(stocks.First()).UpdateColumns(it => new { it.LockQty })
-                            .ExecuteCommand();
-
-                        //foreach (var s in dic)
-                        //{
-                        //    var st = stockList.First(m => m.Id == s.Key);
-                        //    st.LockQty += s.Value;//閿佸畾鏁伴噺
-                        //    var i = Db.Updateable(st).UpdateColumns(it => new { it.LockQty })
-                        //        .ExecuteCommand();
-                        //}
-
+                        list.Add(noticeDetail);
                     }
                     var notice = new BllExportNotice()
                     {
@@ -1167,8 +1108,8 @@
                         Type = model.Type,
                         Status = "0",
                         Origin = "WMS",
-                        CustomerNo = model.CustomerNo,
-                        CustomerName = customer.FirstOrDefault() == null ? "" : customer.First().CustomerName,
+                        //CustomerNo = model.CustomerNo,
+                        //CustomerName = customer.FirstOrDefault() == null ? "" : customer.First().CustomerName,
                         LogisticsId = model.LogisticsId,
                         IsWave = "0",
                         WaveNo = "",
@@ -1674,37 +1615,16 @@
                     throw new Exception("鍙傛暟寮傚父,璇锋鏌ョ姸鎬佹槸鍚︽湭绛夊緟鎵ц鎴栨潵婧愭槸鍚︽槸WMS");
                 }
 
-                //鎬诲簱瀛樹俊鎭�
-                var stockList = Db.Queryable<DataStock>().ToList();
                 //鍑哄簱鍗曟槑缁�
                 var noticeDetail = Db.Queryable<BllExportNoticeDetail>().Where(m => m.IsDel == "0" && m.SONo == notice.SONo).ToList();
                 Db.BeginTran();//寮�鍚簨鍔�
                 try
                 {
-                    foreach (var d in noticeDetail)
+                    foreach (var item in noticeDetail)
                     {
-                        //鎬诲簱瀛�
-                        var sq = stockList.Where(s => s.SkuNo == d.SkuNo);
-                        if (!string.IsNullOrWhiteSpace(d.LotNo))
-                        {
-                            sq = sq.Where(s => s.LotNo == d.LotNo);
-                        }
-                        else
-                        {
-                            sq = sq.Where(s => string.IsNullOrWhiteSpace(s.LotNo));
-                        }
-                        var fd = sq.FirstOrDefault();
-                        if (fd == null)
-                        {
-                            throw new Exception($"鏈壘鍒扮墿鏂檣d.SkuNo}銆佹壒娆d.LotNo} 鐨勫簱瀛樹俊鎭�");
-                        }
-                        fd.LockQty -= d.Qty;
-                        d.IsDel = "1";
-                        d.UpdateUser = userId;
-                        d.UpdateTime = DateTime.Now;
-                        Db.Updateable(d).ExecuteCommand();
-                        Db.Updateable(fd).UpdateColumns(it => new { it.LockQty }).ExecuteCommand();
+                        item.IsDel = "1";
                     }
+                    Db.Updateable(noticeDetail).ExecuteCommand();
                     //鍒犻櫎鍑哄簱鍗�
                     notice.IsDel = "1";
                     notice.UpdateUser = userId;
diff --git a/Wms/WMS.BLL/BllTransServer/RcsServer.cs b/Wms/WMS.BLL/BllTransServer/RcsServer.cs
index afa76e9..5048367 100644
--- a/Wms/WMS.BLL/BllTransServer/RcsServer.cs
+++ b/Wms/WMS.BLL/BllTransServer/RcsServer.cs
@@ -42,216 +42,264 @@
                 string taskMsg = "";
                 if (string.IsNullOrEmpty(model.Location))
                 {
-                    throw new Exception("璁惧鎵�鍦ㄤ綅缃笉鍙负绌�");
+                    throw new Exception("璁惧缂栫爜涓嶅彲涓虹┖");
                 }
-                //鍙《璁惧鎵�鍦ㄥ偍浣嶄俊鎭紙鐩爣鍌ㄤ綅锛�
-                var endLoction = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == model.Location);
-                if (endLoction == null)
+                //閫氳繃璁惧鍙锋煡鎵惧埌鎵�灞炶澶囷紙鍖哄煙锛�
+                var deviceInfo = Db.Queryable<SysStorageArea>().First(w => w.IsDel == "0" && w.DeviceCode == model.Location);
+                if (deviceInfo == null)
                 {
-                    throw new Exception("璁惧鍌ㄤ綅淇℃伅涓嶅瓨鍦�");
+                    throw new Exception("璁惧淇℃伅涓嶅瓨鍦�");
                 }
-                var houseNo = endLoction.WareHouseNo;//鍙《浣嶇疆锛屽悗缁牴鎹綅缃叧鑱旀垨瀹氫箟锛屾潵鍒ゆ柇鍙《浣嶇疆鎵�灞炶溅闂�
+                var houseNo = deviceInfo.WareHouseNo;//鍙《璁惧鎵�灞炶溅闂寸紪鍙�
+
+                //鍙《璁惧鎵�鍦ㄥ偍浣嶄俊鎭紙鐩爣鍌ㄤ綅锛�
+                var endLoction = new SysStorageLocat();
+               
                 var urlMes = "";//鍥炰紶MES鐨勬帴鍙e湴鍧�
                 var noticeNo = "0";//鍑哄叆搴撳崟鎹槑缁咺D
-                var stockDetail = Db.Queryable<DataStockDetail>().Where(w => w.Status == "0");//鎵�鏈夊緟鍒嗛厤鐨勬《
+
+                //鎵�鏈夊緟鍒嗛厤鐨勬《
+                var stockDetail = Db.Queryable<DataStockDetail>().Where(w => w.Status == "0");
+                //鍒嗛厤妗朵俊鎭�
+                var pallet = new DataStockDetail();
 
                 //寮�濮嬩簨鍔�
                 Db.BeginTran();
-                DataStockDetail pallet = new DataStockDetail();
+                
                 switch (model.Type)
                 {
-                    case "0"://鍙噣妗�
-                        //鏌ユ壘鍒拌杞﹂棿鍑�妗跺尯
-                        List<string> areaNoList = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "0" && w.WareHouseNo == houseNo).Select(s=>s.AreaNo).ToList();
-                        //鏌ユ壘鍑�妗�
-                        pallet = stockDetail.Where(w => w.WareHouseNo == houseNo && w.PalletStatus == "0" && w.Status == "0"
-                        && areaNoList.Contains(w.AreaNo)).OrderByDescending(o => o.CreateTime).First();
-                        if (pallet == null)
+                    case "0"://鎺ユ枡璁惧鍙噣妗�
                         {
-                            throw new Exception("鏆傛棤鍑�妗跺彲鍒嗛厤");
+                            //鍙《鐩爣鍌ㄤ綅鍦板潃淇℃伅
+                            endLoction = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo);
+                            if (endLoction == null)
+                            {
+                                throw new Exception("鍙《璁惧鐩爣鍌ㄤ綅淇℃伅涓嶅瓨鍦�");
+                            }
+                            //鏌ユ壘鍒拌杞﹂棿鍑�妗跺尯
+                            List<string> areaNoList = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "0" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
+                            //鏌ユ壘鍑�妗�
+                            pallet = stockDetail.Where(w => w.WareHouseNo == houseNo && w.PalletStatus == "0" && w.Status == "0"
+                            && areaNoList.Contains(w.AreaNo)).OrderByDescending(o => o.CreateTime).First();
+                            if (pallet == null)
+                            {
+                                throw new Exception("鏆傛棤鍑�妗跺彲鍒嗛厤");
+                            }
+                            pallet.Status = "2";//鍒嗛厤鐘舵�� 0:寰呭垎閰嶏紝1锛氶儴鍒嗗垎閰� 锛� 2:宸插垎閰�
+                                                //鏇存柊妗跺簱瀛樻槑缁�
+                            Db.Updateable(pallet).ExecuteCommand();
+
+                            taskMsg = "璁惧鍙噣妗朵换鍔�";
+                        }
+                        break;
+                    case "1"://娣锋枡璁惧鍙枡妗讹紙娣锋枡锛�
+                        {
+                            //鍙《鐩爣鍌ㄤ綅鍦板潃淇℃伅
+                            endLoction = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo);
+                            if (endLoction == null)
+                            {
+                                throw new Exception("鍙《璁惧鐩爣鍌ㄤ綅淇℃伅涓嶅瓨鍦�");
+                            }
+                            //鍒ゆ柇鏄惁鏈夋壒娆″彿
+                            if (string.IsNullOrWhiteSpace(model.LotNo))
+                            {
+                                throw new Exception("鎵规鍙蜂负绌猴紒");
+                            }
+                            //鏌ユ壘鍒拌杞﹂棿棰勬贩鍖�
+                            List<string> areaNoList2 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "1" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
+                            //鏌ユ壘搴撳瓨涓槸鍚︽湁鍙敤鐨勬鎵规鐨勬贩鏂欐《
+                            pallet = stockDetail.Where(w => w.WareHouseNo == houseNo && w.PalletStatus == "1" && w.Status == "0" && w.LotNo == model.LotNo
+                            && areaNoList2.Contains(w.AreaNo)).OrderByDescending(o => o.CompleteTime).First();
+                            if (pallet == null)
+                            {
+                                throw new Exception("鏆傛棤娣锋枡妗跺彲鍒嗛厤");
+                            }
+                            pallet.Status = "2";//鍒嗛厤鐘舵�� 0:寰呭垎閰嶏紝1锛氶儴鍒嗗垎閰� 锛� 2:宸插垎閰�
+                                                //鏇存柊妗跺簱瀛樻槑缁�
+                            Db.Updateable(pallet).ExecuteCommand();
+
+                            taskMsg = "璁惧鍙枡妗舵贩鏂欎换鍔�";
+                        }
+                        break;
+                    case "2"://涓嬫枡璁惧鍙枡妗讹紙涓嬫枡锛�
+                        {
+                            if (houseNo == "M04")//闄や簡鍠峰共杞﹂棿涓嬫枡鍙i兘鏄�2涓偍浣嶏紙鎶曟枡鍌ㄤ綅銆佹姇瀹屾枡鍌ㄤ綅锛�
+                            {
+                                //鍙《鐩爣鍌ㄤ綅鍦板潃淇℃伅
+                                endLoction = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo);
+                            }
+                            else
+                            {
+                                //鍙《鐩爣鍌ㄤ綅鍦板潃淇℃伅
+                                endLoction = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo && w.Column == 1);// Column=1 鎶曟枡鍌ㄤ綅锛孋olumn=2 鎶曞畬鏂欏偍浣�                        
+                            }
+                            if (endLoction == null)
+                            {
+                                throw new Exception("鍙《璁惧鐩爣鍌ㄤ綅淇℃伅涓嶅瓨鍦�");
+                            }
+                            //鍒ゆ柇鏄惁鏈夋壒娆″彿
+                            if (string.IsNullOrWhiteSpace(model.LotNo))
+                            {
+                                throw new Exception("鎵规鍙蜂负绌猴紒");
+                            }
+                            //鏌ユ壘鏄惁鏈夋鎵规鍑哄簱鍗曟槑缁�
+                            var soNoticeDetail = Db.Queryable<BllExportNoticeDetail>().Where(w => w.IsDel == "0" && w.LotNo == model.LotNo).OrderBy(o => o.CreateTime).First();
+                            if (soNoticeDetail == null)
+                            {
+                                throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍑哄簱鍗曟槑缁�");
+                            }
+                            noticeNo = soNoticeDetail.Id.ToString();
+                            //鍑哄簱鎬诲崟
+                            var soNotice = Db.Queryable<BllExportNotice>().Where(w => w.IsDel == "0" && w.SONo == soNoticeDetail.SONo).First();
+                            if (soNotice == null)
+                            {
+                                throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍑哄簱鍗�");
+                            }
+                            soNotice.Status = "3";//姝e湪鎵ц
+                            soNotice.UpdateTime = DateTime.Now;
+                            //鏇存柊鍑哄簱鍗�
+                            Db.Updateable(soNotice).ExecuteCommand();
+
+                            //鏌ユ壘鍒拌杞﹂棿鍗婃垚鍝佸尯
+                            List<string> areaNoList3 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "2" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
+                            //鏌ユ壘搴撳瓨涓槸鍚︽湁姝ゆ壒娆$殑鍚堟牸涓嬫枡妗�
+                            pallet = stockDetail.Where(w => w.WareHouseNo == houseNo && w.PalletStatus == "2" && w.Status == "0" && w.LotNo == model.LotNo && w.InspectStatus == "1"
+                            && areaNoList3.Contains(w.AreaNo)).OrderByDescending(o => o.CompleteTime).First();
+                            if (pallet == null)
+                            {
+                                throw new Exception("鏆傛棤涓嬫枡妗跺彲鍒嗛厤");
+                            }
+                            pallet.Status = "2";//鍒嗛厤鐘舵�� 0:寰呭垎閰嶏紝1锛氶儴鍒嗗垎閰� 锛� 2:宸插垎閰�
+                                                //鏇存柊妗跺簱瀛樻槑缁�
+                            Db.Updateable(pallet).ExecuteCommand();
+
+                            taskMsg = "璁惧鍙枡妗朵笅鏂欎换鍔�";
+                        }
+                        break;
+                    case "3"://娓呮礂璁惧鍙剰妗�
+                        {
+                            //鍙《鐩爣鍌ㄤ綅鍦板潃淇℃伅
+                            endLoction = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo && w.Column == 1);// Column=1 娓呮礂鍌ㄤ綅锛孋olumn=2 娓呮礂瀹屾枡鍌ㄤ綅 
+                            if (endLoction == null)
+                            {
+                                throw new Exception("鍙《璁惧鐩爣鍌ㄤ綅淇℃伅涓嶅瓨鍦�");
+                            }
+                            //鏌ユ壘鍒拌杞﹂棿鑴忔《鍖�
+                            List<string> areaNoList4 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "3" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
+                            List<DataStockDetail> palletList = stockDetail.Where(w => w.WareHouseNo == houseNo && w.PalletStatus == "3" && w.Status == "0"
+                            && areaNoList4.Contains(w.AreaNo)).OrderByDescending(o => o.CompleteTime).ToList();
+                            if (palletList.Count <= 0)
+                            {
+                                throw new Exception("鏆傛棤鑴忔《鍙垎閰�");
+                            }
+                            taskMsg = "璁惧鍙剰妗朵换鍔�";
+                            //閬嶅巻搴撳瓨鑴忔《锛岃繑鍥濵ES楠岃瘉
+                            foreach (var item in palletList)
+                            {
+                                #region 鍘绘帀MES
+                                //string jsonReq = JsonConvert.SerializeObject(item.PalletNo);
+                                //var response = HttpHelper.DoPost(urlMes, jsonReq, "鍥炰紶MES鑴忔《缂栧彿", "RCS").ToString();
+                                //var obj = JsonConvert.DeserializeObject<ReMes>(response);//瑙f瀽杩斿洖鏁版嵁
+                                //if (obj.Success == "0")
+                                //{
+                                //    if (obj.Result != "1")//涓嶅彲娓呮礂锛屽皢鑴忔《鍐荤粨
+                                //    {
+                                //        item.Status = "5";//寮傚父鍐荤粨
+                                //        //淇敼璇ユ《搴撳瓨鐘舵��
+                                //        Db.Updateable(item).ExecuteCommand();
+
+                                //        continue;
+                                //    }
+                                //    //涓嬪彂灏忚溅浠诲姟
+                                //    var task2 = new TaskDetial
+                                //    {
+                                //        Startport = item.LocatNo,
+                                //        Endport = model.Location,
+                                //        Pallno = item.PalletNo,
+                                //        Type = model.Type,
+                                //        Crtype = "1",
+                                //        Noticedetailno = int.Parse(noticeno),
+                                //    };
+                                //    CreateLotTask(task2);
+                                //    return;
+                                //}
+                                //else
+                                //{
+                                //    throw new Exception("鍥炰紶MES鍑�妗剁紪鍙峰け璐ワ紒");
+                                //}
+                                #endregion
+
+                                item.Status = "2";//鍒嗛厤鐘舵�� 0:寰呭垎閰嶏紝1锛氶儴鍒嗗垎閰� 锛� 2:宸插垎閰�
+                                                  //鏇存柊妗跺簱瀛樻槑缁�
+                                Db.Updateable(item).ExecuteCommand();
+                                //璧峰鍌ㄤ綅鍦板潃淇℃伅
+                                var startLoction2 = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == item.LocatNo);
+                                if (startLoction2 == null)
+                                {
+                                    throw new Exception($"璧峰鐩爣鍌ㄤ綅淇℃伅涓嶅瓨鍦紝妗跺彿锛歿item.LocatNo}");
+                                }
+
+                                taskNo = new Common().GetMaxNo("TK");//浠诲姟鍙�
+                                var logTaskEntry2 = new LogTask
+                                {
+                                    TaskNo = taskNo,
+                                    Sender = "WMS",
+                                    Receiver = "RCS",
+                                    //IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
+                                    SendDate = DateTime.Now,  //鍙戦�佹椂闂�
+                                                              //BackDate = DateTime.Now,  //杩斿洖鏃堕棿
+                                    StartLocat = item.LocatNo,//璧峰浣嶇疆
+                                    EndLocat = model.Location,//鐩爣浣嶇疆
+                                    PalletNo = item.PalletNo,//鎵樼洏鐮�
+                                    IsSend = 1,//鏄惁鍙啀娆′笅鍙�
+                                    IsCancel = 1,//鏄惁鍙彇娑�
+                                    IsFinish = 1,//鏄惁鍙畬鎴�
+                                    Type = "1",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
+                                    OrderType = "3",//鍗曟嵁绫诲瀷 0 鍏ュ簱 1 鍑哄簱 3 绉诲簱
+                                    Status = "0",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
+                                    NoticeDetailNo = int.Parse(noticeNo),
+                                    Msg = taskMsg, //鍏抽敭淇℃伅
+                                };
+                                //缁勭粐涓嬪彂灏忚溅浠诲姟淇℃伅
+                                var task2 = new TaskDetial
+                                {
+                                    Taskno = taskNo,//浠诲姟鍙�
+                                    Startport = item.LocatNo,
+                                    Endport = model.Location,
+                                    Pallno = item.PalletNo,
+                                    Crtype = "1",//鍙《
+                                    WareHouseNo = houseNo
+                                };
+                                //缁欎笅杞︿笅鍙戜换鍔�
+                                logTaskEntry2.SendDate = DateTime.Now;//鍙戦�佹椂闂�
+                                var agvResult2 = CreateTaskForAgv(task2, url);
+                                if (agvResult2)//鎴愬姛
+                                {
+                                    //璇锋眰鎴愬姛淇敼浠诲姟琛ㄧ浉搴斿瓧娈电姸鎬�
+                                    logTaskEntry2.IsSuccess = 1;
+                                    logTaskEntry2.IsSend = 0;
+                                    //logTaskEntry2.IsCancel = 0;
+                                    logTaskEntry2.BackDate = DateTime.Now;
+                                    logTaskEntry2.Status = "1";
+                                    Db.Insertable(logTaskEntry2).ExecuteCommand();
+
+                                    startLoction2.Status = "3";//鍑哄簱涓�
+                                    Db.Updateable(startLoction2).ExecuteCommand();
+
+                                    endLoction.Status = "2";//鍏ュ簱涓�
+                                    Db.Updateable(endLoction).ExecuteCommand();
+                                }
+                                else//澶辫触
+                                {
+                                    logTaskEntry2.IsSuccess = 0;
+                                    Db.Insertable(logTaskEntry2).ExecuteCommand();
+
+                                }
+                                //鎻愪氦浜嬪姟
+                                Db.CommitTran();
+                                return;
+                            }
                         }                        
-                        pallet.Status = "2";//鍒嗛厤鐘舵�� 0:寰呭垎閰嶏紝1锛氶儴鍒嗗垎閰� 锛� 2:宸插垎閰�
-                        //鏇存柊妗跺簱瀛樻槑缁�
-                        Db.Updateable(pallet).ExecuteCommand();
-
-                        taskMsg = "璁惧鍙噣妗朵换鍔�";
-                        break;
-                    case "1"://鍙枡妗讹紙娣锋枡锛�
-                        //鍒ゆ柇鏄惁鏈夋壒娆″彿
-                        if (string.IsNullOrWhiteSpace(model.LotNo))
-                        {
-                            throw new Exception("鎵规鍙蜂负绌猴紒");
-                        }
-                        //鏌ユ壘鍒拌杞﹂棿棰勬贩鍖�
-                        List<string> areaNoList2 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "1" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
-                        //鏌ユ壘搴撳瓨涓槸鍚︽湁鍙敤鐨勬鎵规鐨勬贩鏂欐《
-                        pallet = stockDetail.Where(w => w.WareHouseNo == houseNo && w.PalletStatus == "1" && w.Status == "0" && w.LotNo == model.LotNo
-                        && areaNoList2.Contains(w.AreaNo)).OrderByDescending(o => o.CompleteTime).First();
-                        if (pallet == null)
-                        {
-                            throw new Exception("鏆傛棤娣锋枡妗跺彲鍒嗛厤");
-                        }
-                        pallet.Status = "2";//鍒嗛厤鐘舵�� 0:寰呭垎閰嶏紝1锛氶儴鍒嗗垎閰� 锛� 2:宸插垎閰�
-                        //鏇存柊妗跺簱瀛樻槑缁�
-                        Db.Updateable(pallet).ExecuteCommand();
-
-                        taskMsg = "璁惧鍙枡妗舵贩鏂欎换鍔�";
-                        break;
-                    case "2"://鍙枡妗讹紙涓嬫枡锛�
-                        //鍒ゆ柇鏄惁鏈夋壒娆″彿
-                        if (string.IsNullOrWhiteSpace(model.LotNo))
-                        {
-                            throw new Exception("鎵规鍙蜂负绌猴紒");
-                        }
-                        //鏌ユ壘鏄惁鏈夋鎵规鍑哄簱鍗曟槑缁�
-                        var soNoticeDetail = Db.Queryable<BllExportNoticeDetail>().Where(w => w.IsDel == "0" && w.LotNo == model.LotNo).OrderBy(o => o.CreateTime).First();
-                        if (soNoticeDetail == null)
-                        {
-                            throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍑哄簱鍗曟槑缁�");
-                        }
-                        noticeNo = soNoticeDetail.Id.ToString();
-                        //鍑哄簱鎬诲崟
-                        var soNotice = Db.Queryable<BllExportNotice>().Where(w => w.IsDel == "0" && w.SONo == soNoticeDetail.SONo).First();
-                        if (soNotice == null)
-                        {
-                            throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍑哄簱鍗�");
-                        }
-                        soNotice.Status = "3";//姝e湪鎵ц
-                        soNotice.UpdateTime = DateTime.Now;
-                        //鏇存柊鍑哄簱鍗�
-                        Db.Updateable(soNotice).ExecuteCommand();
-
-                        //鏌ユ壘鍒拌杞﹂棿鍗婃垚鍝佸尯
-                        List<string> areaNoList3 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "2" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
-                        //鏌ユ壘搴撳瓨涓槸鍚︽湁姝ゆ壒娆$殑鍚堟牸涓嬫枡妗�
-                        pallet = stockDetail.Where(w => w.WareHouseNo == houseNo && w.PalletStatus == "2" && w.Status == "0" && w.LotNo == model.LotNo && w.InspectStatus=="1"
-                        && areaNoList3.Contains(w.AreaNo)).OrderByDescending(o => o.CompleteTime).First();
-                        if (pallet == null)
-                        {
-                            throw new Exception("鏆傛棤涓嬫枡妗跺彲鍒嗛厤");
-                        }
-                        pallet.Status = "2";//鍒嗛厤鐘舵�� 0:寰呭垎閰嶏紝1锛氶儴鍒嗗垎閰� 锛� 2:宸插垎閰�
-                        //鏇存柊妗跺簱瀛樻槑缁�
-                        Db.Updateable(pallet).ExecuteCommand();
-
-                        taskMsg = "璁惧鍙枡妗朵笅鏂欎换鍔�";
-                        break;
-                    case "3"://鍙剰妗�
-                        //鏌ユ壘鍒拌杞﹂棿鑴忔《鍖�
-                        List<string> areaNoList4 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "3" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
-                        List<DataStockDetail> palletList = stockDetail.Where(w => w.WareHouseNo == houseNo && w.PalletStatus == "3" && w.Status == "0"
-                        && areaNoList4.Contains(w.AreaNo)).OrderByDescending(o => o.CompleteTime).ToList();
-                        if (palletList.Count <= 0)
-                        {
-                            throw new Exception("鏆傛棤鑴忔《鍙垎閰�");
-                        }
-                        //閬嶅巻搴撳瓨鑴忔《锛岃繑鍥濵ES楠岃瘉
-                        foreach (var item in palletList)
-                        {
-                            #region 鍘绘帀MES
-                            //string jsonReq = JsonConvert.SerializeObject(item.PalletNo);
-                            //var response = HttpHelper.DoPost(urlMes, jsonReq, "鍥炰紶MES鑴忔《缂栧彿", "RCS").ToString();
-                            //var obj = JsonConvert.DeserializeObject<ReMes>(response);//瑙f瀽杩斿洖鏁版嵁
-                            //if (obj.Success == "0")
-                            //{
-                            //    if (obj.Result != "1")//涓嶅彲娓呮礂锛屽皢鑴忔《鍐荤粨
-                            //    {
-                            //        item.Status = "5";//寮傚父鍐荤粨
-                            //        //淇敼璇ユ《搴撳瓨鐘舵��
-                            //        Db.Updateable(item).ExecuteCommand();
-
-                            //        continue;
-                            //    }
-                            //    //涓嬪彂灏忚溅浠诲姟
-                            //    var task2 = new TaskDetial
-                            //    {
-                            //        Startport = item.LocatNo,
-                            //        Endport = model.Location,
-                            //        Pallno = item.PalletNo,
-                            //        Type = model.Type,
-                            //        Crtype = "1",
-                            //        Noticedetailno = int.Parse(noticeno),
-                            //    };
-                            //    CreateLotTask(task2);
-                            //    return;
-                            //}
-                            //else
-                            //{
-                            //    throw new Exception("鍥炰紶MES鍑�妗剁紪鍙峰け璐ワ紒");
-                            //}
-                            #endregion
-
-                            item.Status = "2";//鍒嗛厤鐘舵�� 0:寰呭垎閰嶏紝1锛氶儴鍒嗗垎閰� 锛� 2:宸插垎閰�
-                            //鏇存柊妗跺簱瀛樻槑缁�
-                            Db.Updateable(item).ExecuteCommand();
-                            //璧峰鍌ㄤ綅鍦板潃淇℃伅
-                            var startLoction2 = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == item.LocatNo);
-                            if (startLoction2 == null)
-                            {
-                                throw new Exception($"璧峰鐩爣鍌ㄤ綅淇℃伅涓嶅瓨鍦紝妗跺彿锛歿item.LocatNo}");
-                            }
-
-                            taskNo = new Common().GetMaxNo("TK");//浠诲姟鍙�
-                            var logTaskEntry2 = new LogTask
-                            {
-                                TaskNo = taskNo,
-                                Sender = "WMS",
-                                Receiver = "RCS",
-                                //IsSuccess = 1, //鏄惁涓嬪彂鎴愬姛 0澶辫触 1鎴愬姛
-                                SendDate = DateTime.Now,  //鍙戦�佹椂闂�
-                                                          //BackDate = DateTime.Now,  //杩斿洖鏃堕棿
-                                StartLocat = item.LocatNo,//璧峰浣嶇疆
-                                EndLocat = model.Location,//鐩爣浣嶇疆
-                                PalletNo = item.PalletNo,//鎵樼洏鐮�
-                                IsSend = 1,//鏄惁鍙啀娆′笅鍙�
-                                IsCancel = 1,//鏄惁鍙彇娑�
-                                IsFinish = 1,//鏄惁鍙畬鎴�
-                                Type = "1",//浠诲姟绫诲瀷 0 鍏ュ簱浠诲姟 1 鍑哄簱浠诲姟  2 绉诲簱浠诲姟
-                                OrderType = "3",//鍗曟嵁绫诲瀷 0 鍏ュ簱 1 鍑哄簱 3 绉诲簱
-                                Status = "0",//浠诲姟鐘舵��0锛氱瓑寰呮墽琛�1姝e湪鎵ц2鎵ц瀹屾垚
-                                NoticeDetailNo = int.Parse(noticeNo),
-                                Msg = taskMsg, //鍏抽敭淇℃伅
-                            };
-                            //缁勭粐涓嬪彂灏忚溅浠诲姟淇℃伅
-                            var task2 = new TaskDetial
-                            {
-                                Taskno = taskNo,//浠诲姟鍙�
-                                Startport = item.LocatNo,
-                                Endport = model.Location,
-                                Pallno = item.PalletNo,
-                                Crtype = "1",//鍙《
-                            };
-                            //缁欎笅杞︿笅鍙戜换鍔�
-                            logTaskEntry2.SendDate = DateTime.Now;//鍙戦�佹椂闂�
-                            var agvResult2 = CreateTaskForAgv(task2, url);
-                            if (agvResult2)//鎴愬姛
-                            {
-                                //璇锋眰鎴愬姛淇敼浠诲姟琛ㄧ浉搴斿瓧娈电姸鎬�
-                                logTaskEntry2.IsSuccess = 1;
-                                logTaskEntry2.IsSend = 0;
-                                //logTaskEntry2.IsCancel = 0;
-                                logTaskEntry2.BackDate = DateTime.Now;
-                                logTaskEntry2.Status = "1";
-                                Db.Insertable(logTaskEntry2).ExecuteCommand();
-
-                                startLoction2.Status = "3";//鍑哄簱涓�
-                                Db.Updateable(startLoction2).ExecuteCommand();
-
-                                endLoction.Status = "2";//鍏ュ簱涓�
-                                Db.Updateable(endLoction).ExecuteCommand();
-                            }
-                            else//澶辫触
-                            {
-                                logTaskEntry2.IsSuccess = 0;
-                                Db.Insertable(logTaskEntry2).ExecuteCommand();
-
-                            }
-                            //鎻愪氦浜嬪姟
-                            Db.CommitTran();
-                            return;
-                        }
-
-                        taskMsg = "璁惧鍙剰妗朵换鍔�";
                         break;
                     default:
                         throw new Exception("浠诲姟绫诲瀷鏃犳晥");
@@ -289,11 +337,12 @@
                 //缁勭粐涓嬪彂灏忚溅浠诲姟淇℃伅
                 var task = new TaskDetial
                 {
-                    Taskno= taskNo,//浠诲姟鍙�
+                    Taskno = taskNo,//浠诲姟鍙�
                     Startport = pallet.LocatNo,//璧峰浣嶇疆
                     Endport = model.Location,//鐩爣浣嶇疆
                     Pallno = pallet.PalletNo,//妗跺彿
                     Crtype = "1",//鍙《
+                    WareHouseNo = houseNo//杞﹂棿缂栫爜
                 };
                 //缁欎笅杞︿笅鍙戜换鍔�
                 logTaskEntry.SendDate = DateTime.Now;//鍙戦�佹椂闂�
@@ -349,13 +398,20 @@
                 {
                     throw new Exception($"璇ユ《鏈夋鍦ㄦ墽琛岀殑浠诲姟锛孭alletNo:{model.PalletNo}");
                 }
+                //閫氳繃璁惧鍙锋煡鎵惧埌鎵�灞炶澶囷紙鍖哄煙锛�
+                var deviceInfo = Db.Queryable<SysStorageArea>().First(w => w.IsDel == "0" && w.DeviceCode == model.Location);
+                if (deviceInfo == null)
+                {
+                    throw new Exception("璁惧淇℃伅涓嶅瓨鍦�");
+                }
+                var houseNo = deviceInfo.WareHouseNo;//鐢宠鍌ㄤ綅璁惧鎵�鍦ㄨ溅闂寸紪鍙�
                 //璁惧鎵�鍦ㄥ偍浣嶄俊鎭紙璧峰鍌ㄤ綅锛�
-                var deviceLocatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.LocatNo == model.Location);
+                var deviceLocatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo);
                 if (deviceLocatInfo == null)
                 {
                     throw new Exception($"鏈煡璇㈠埌璇ヨ澶囨墍鍦ㄥ偍浣嶄俊鎭紝Location:{model.Location}");
                 }
-                var houseNo = deviceLocatInfo.WareHouseNo;//鐢宠鍌ㄤ綅璁惧鎵�鍦ㄨ溅闂寸紪鍙�
+                
                 var noticeno = "0";//鍑哄叆搴撳崟鎹槑缁咺D
                 //妗跺簱瀛樹俊鎭�
                 var palletInfo = Db.Queryable<DataStockDetail>().First(w => w.IsDel == "0" && w.PalletNo == model.PalletNo);
@@ -372,82 +428,114 @@
                 switch (model.Type)
                 {
                     case "3"://娓呮礂璁惧鐢宠鍌ㄤ綅锛堝噣妗剁敵璇峰偍浣嶏級
-                        //鏌ユ壘鍒拌杞﹂棿鍑�妗跺尯
-                        //List<string> areaNoList = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "0" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
-                        //loction = storageLocat.Where(w => w.WareHouseNo == houseNo && areaNoList.Contains(w.AreaNo) && w.Status == "0" && w.Flag == "0").OrderByDescending(o => o.CreateTime).First();
-                        loction = GetLocatModel(houseNo, "0");
-                        if (loction == null)
                         {
-                            throw new Exception("璇ヨ溅闂村噣妗跺尯鏆傛棤绌轰綑鍌ㄤ綅");
-                        }
+                            //璁惧鎵�鍦ㄥ偍浣嶄俊鎭紙璧峰鍌ㄤ綅锛�
+                            deviceLocatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo && w.Column == 2);// Column=1 娓呮礂鍌ㄤ綅锛孋olumn=2 娓呮礂瀹屾枡鍌ㄤ綅 
+                            if (deviceLocatInfo == null)
+                            {
+                                throw new Exception($"鏈煡璇㈠埌璇ヨ澶囨墍鍦ㄥ偍浣嶄俊鎭紝Location:{model.Location}");
+                            }
+                            //鏌ユ壘鍒拌杞﹂棿鍑�妗跺尯;
+                            loction = GetLocatModel(houseNo, "0");
+                            if (loction == null)
+                            {
+                                throw new Exception("璇ヨ溅闂村噣妗跺尯鏆傛棤绌轰綑鍌ㄤ綅");
+                            }
 
-                        taskMsg = "娓呮礂璁惧锛堝噣妗讹級鐢宠鍌ㄤ綅浠诲姟";
+                            taskMsg = "娓呮礂璁惧锛堝噣妗讹級鐢宠鍌ㄤ綅浠诲姟";
+                        }
                         break;
                     case "0"://鎺ユ枡璁惧鐢宠鍌ㄤ綅锛堥娣锋枡妗剁敵璇峰偍浣嶏級
-                        //鍒ゆ柇鏄惁鏈夋壒娆″彿
-                        if (string.IsNullOrWhiteSpace(model.LotNo))
                         {
-                            throw new Exception("鎵规鍙蜂负绌猴紒");
-                        }
-                        //鏌ユ壘鍒拌杞﹂棿棰勬贩鍖�
-                        //List<string> areaNoList2 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "1" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
-                        //loction = storageLocat.Where(w => w.WareHouseNo == houseNo && areaNoList2.Contains(w.AreaNo) && w.Status == "0" && w.Flag == "0").OrderByDescending(o => o.CreateTime).First();
-                        loction = GetLocatModel(houseNo, "1");
-                        if (loction == null)
-                        {
-                            throw new Exception("璇ヨ溅闂撮娣峰尯鏆傛棤绌轰綑鍌ㄤ綅");
-                        }
-                        palletInfo.LotNo = model.LotNo;//鎵规鍙�
-                        //鏇存柊妗跺簱瀛樹俊鎭�
-                        Db.Updateable(palletInfo).ExecuteCommand();
+                            //璁惧鎵�鍦ㄥ偍浣嶄俊鎭紙璧峰鍌ㄤ綅锛�
+                            deviceLocatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo);
+                            if (deviceLocatInfo == null)
+                            {
+                                throw new Exception($"鏈煡璇㈠埌璇ヨ澶囨墍鍦ㄥ偍浣嶄俊鎭紝Location:{model.Location}");
+                            }
+                            //鍒ゆ柇鏄惁鏈夋壒娆″彿
+                            if (string.IsNullOrWhiteSpace(model.LotNo))
+                            {
+                                throw new Exception("鎵规鍙蜂负绌猴紒");
+                            }
+                            //鏌ユ壘鍒拌杞﹂棿棰勬贩鍖�
+                            loction = GetLocatModel(houseNo, "1");
+                            if (loction == null)
+                            {
+                                throw new Exception("璇ヨ溅闂撮娣峰尯鏆傛棤绌轰綑鍌ㄤ綅");
+                            }
+                            palletInfo.LotNo = model.LotNo;//鎵规鍙�
+                                                           //鏇存柊妗跺簱瀛樹俊鎭�
+                            Db.Updateable(palletInfo).ExecuteCommand();
 
-                        taskMsg = "鎺ユ枡璁惧锛堥娣锋枡妗讹級鐢宠鍌ㄤ綅浠诲姟";
+                            taskMsg = "鎺ユ枡璁惧锛堥娣锋枡妗讹級鐢宠鍌ㄤ綅浠诲姟";
+                        }
                         break;
                     case "1"://娣锋枡璁惧鐢宠鍌ㄤ綅锛堝崐鎴愬搧妗剁敵璇峰偍浣嶏級
-                        //鍒ゆ柇鏄惁鏈夋壒娆″彿
-                        if (string.IsNullOrWhiteSpace(model.LotNo))
                         {
-                            throw new Exception("鎵规鍙蜂负绌猴紒");
-                        }
-                        //鏍¢獙姝ゆ壒娆℃槸鍚︽湁鍏ュ簱鍗�
-                        var noticeDetail = Db.Queryable<BllArrivalNoticeDetail>().Where(w => w.IsDel == "0" && w.Status == "0" && w.LotNo == model.LotNo).OrderByDescending(o => o.CreateTime).First();
-                        if (noticeDetail == null)
-                        {
-                            throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍏ュ簱鍗曟槑缁�");
-                        }
-                        noticeno = noticeDetail.Id.ToString();
-                        //鍏ュ簱鎬诲崟
-                        var notice = Db.Queryable<BllArrivalNotice>().Where(w => w.IsDel == "0" && w.ASNNo == noticeDetail.ASNNo).First();
-                        if (notice == null)
-                        {
-                            throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍏ュ簱鍗�");
-                        }
-                        notice.Status = "1";//姝e湪鎵ц
-                        //鏇存柊鍏ュ簱鍗曠姸鎬�
-                        Db.Updateable(notice).ExecuteCommand();
+                            //璁惧鎵�鍦ㄥ偍浣嶄俊鎭紙璧峰鍌ㄤ綅锛�
+                            deviceLocatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo);
+                            if (deviceLocatInfo == null)
+                            {
+                                throw new Exception($"鏈煡璇㈠埌璇ヨ澶囨墍鍦ㄥ偍浣嶄俊鎭紝Location:{model.Location}");
+                            }
+                            //鍒ゆ柇鏄惁鏈夋壒娆″彿
+                            if (string.IsNullOrWhiteSpace(model.LotNo))
+                            {
+                                throw new Exception("鎵规鍙蜂负绌猴紒");
+                            }
+                            //鏍¢獙姝ゆ壒娆℃槸鍚︽湁鍏ュ簱鍗�
+                            var noticeDetail = Db.Queryable<BllArrivalNoticeDetail>().Where(w => w.IsDel == "0" && w.Status == "0" && w.LotNo == model.LotNo).OrderByDescending(o => o.CreateTime).First();
+                            if (noticeDetail == null)
+                            {
+                                throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍏ュ簱鍗曟槑缁�");
+                            }
+                            noticeno = noticeDetail.Id.ToString();
+                            //鍏ュ簱鎬诲崟
+                            var notice = Db.Queryable<BllArrivalNotice>().Where(w => w.IsDel == "0" && w.ASNNo == noticeDetail.ASNNo).First();
+                            if (notice == null)
+                            {
+                                throw new Exception("璇ユ壒娆℃病鏈夊搴旂殑鍏ュ簱鍗�");
+                            }
+                            notice.Status = "1";//姝e湪鎵ц
+                                                //鏇存柊鍏ュ簱鍗曠姸鎬�
+                            Db.Updateable(notice).ExecuteCommand();
 
-                        //鏌ユ壘鍒拌杞﹂棿鍗婃垚鍝佸尯
-                        //List<string> areaNoList3 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "2" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
-                        //loction = storageLocat.Where(w => w.WareHouseNo == houseNo && areaNoList3.Contains(w.AreaNo) && w.Status == "0" && w.Flag == "0").OrderByDescending(o => o.CreateTime).First();
-                        loction = GetLocatModel(houseNo, "2");
-                        if (loction == null)
-                        {
-                            throw new Exception("璇ヨ溅闂村崐鎴愬搧鍖烘殏鏃犵┖浣欏偍浣�");
-                        }
+                            //鏌ユ壘鍒拌杞﹂棿鍗婃垚鍝佸尯
+                            loction = GetLocatModel(houseNo, "2");
+                            if (loction == null)
+                            {
+                                throw new Exception("璇ヨ溅闂村崐鎴愬搧鍖烘殏鏃犵┖浣欏偍浣�");
+                            }
 
-                        taskMsg = "鎺ユ枡璁惧锛堟贩鏂欐《锛夌敵璇峰偍浣嶄换鍔�";
+                            taskMsg = "鎺ユ枡璁惧锛堟贩鏂欐《锛夌敵璇峰偍浣嶄换鍔�";
+                        }
                         break;
                     case "2"://涓嬫枡璁惧鐢宠鍌ㄤ綅锛堣剰妗剁敵璇峰偍浣嶏級
-                        //鏌ユ壘鍒拌杞﹂棿鑴忔《鍖�
-                        //List<string> areaNoList4 = Db.Queryable<SysStorageArea>().Where(w => w.IsDel == "0" && w.Status == "0" && w.Type == "3" && w.WareHouseNo == houseNo).Select(s => s.AreaNo).ToList();
-                        //loction = storageLocat.Where(w => w.WareHouseNo == houseNo && areaNoList4.Contains(w.AreaNo) && w.Status == "0" && w.Flag == "0").OrderByDescending(o => o.CreateTime).First();
-                        loction = GetLocatModel(houseNo, "3");
-                        if (loction == null)
                         {
-                            throw new Exception("璇ヨ溅闂磋剰妗跺尯鏆傛棤绌轰綑鍌ㄤ綅");
-                        }
+                            if (houseNo == "M04")//闄や簡鍠峰共杞﹂棿涓嬫枡鍙i兘鏄�2涓偍浣嶏紙鎶曟枡鍌ㄤ綅銆佹姇瀹屾枡鍌ㄤ綅锛�
+                            {
+                                //璁惧鎵�鍦ㄥ偍浣嶄俊鎭紙璧峰鍌ㄤ綅锛�
+                                deviceLocatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo);
+                            }
+                            else
+                            {
+                                //璁惧鎵�鍦ㄥ偍浣嶄俊鎭紙璧峰鍌ㄤ綅锛�
+                                deviceLocatInfo = Db.Queryable<SysStorageLocat>().First(w => w.IsDel == "0" && w.WareHouseNo == houseNo && w.AreaNo == deviceInfo.AreaNo && w.Column == 2);//Column=1 鎶曟枡鍌ㄤ綅锛孋olumn=2 鎶曞畬鏂欏偍浣�           
+                            }                            
+                            if (deviceLocatInfo == null)
+                            {
+                                throw new Exception($"鏈煡璇㈠埌璇ヨ澶囨墍鍦ㄥ偍浣嶄俊鎭紝Location:{model.Location}");
+                            }
+                            //鏌ユ壘鍒拌杞﹂棿鑴忔《鍖�
+                            loction = GetLocatModel(houseNo, "3");
+                            if (loction == null)
+                            {
+                                throw new Exception("璇ヨ溅闂磋剰妗跺尯鏆傛棤绌轰綑鍌ㄤ綅");
+                            }
 
-                        taskMsg = "涓嬫枡璁惧锛堣剰妗讹級鐢宠鍌ㄤ綅浠诲姟";
+                            taskMsg = "涓嬫枡璁惧锛堣剰妗讹級鐢宠鍌ㄤ綅浠诲姟";
+                        }
                         break;
                 }
 
@@ -480,6 +568,7 @@
                     Endport = loction.LocatNo,
                     Pallno = model.PalletNo,
                     Crtype = "0",//鍏ュ簱
+                    WareHouseNo = houseNo
                 };
                 //缁欎笅杞︿笅鍙戜换鍔�
                 logTaskEntry.SendDate = DateTime.Now;//鍙戦�佹椂闂�
@@ -748,28 +837,59 @@
                 //鍏ュ簱浠诲姟锛屽鐞嗗叆搴撳崟
                 if (taskInfo.Type == "0" && taskInfo.NoticeDetailNo != 0)
                 {
-                    var notice = Db.Queryable<BllArrivalNotice>().First(w => w.IsDel == "0" && w.Status == "1");
-                    if (notice != null)
-                    {
-                        notice.Status = "2";//鎵ц瀹屾垚
-                        notice.UpdateTime = DateTime.Now;
-                        notice.CompleteTime = DateTime.Now;
-                        //淇敼鍏ュ簱鍗曠姸鎬�
-                        Db.Updateable(notice).ExecuteCommand();
+                    //鍏ュ簱鍗曟槑缁�
+                    var noticeDetail = Db.Queryable<BllArrivalNoticeDetail>().First(w => w.IsDel == "0" && w.Id == taskInfo.NoticeDetailNo);
+                    if (noticeDetail != null)
+                    {                        
+                        noticeDetail.CompleteQty += 1;//瀹屾垚鏁伴噺
+
+                        if (noticeDetail.CompleteQty >= noticeDetail.Qty)
+                        {
+                            noticeDetail.CompleteTime = DateTime.Now;//瀹屾垚鏃堕棿
+
+                            //鍏ュ簱鍗�
+                            var notice = Db.Queryable<BllArrivalNotice>().First(w => w.IsDel == "0" && w.ASNNo == noticeDetail.ASNNo);
+
+                            var noticeDetailList = Db.Queryable<BllArrivalNoticeDetail>().Where(w => w.IsDel == "0" && w.CompleteQty < w.Qty && w.Id != noticeDetail.Id).ToList();
+                            if (noticeDetailList.Count <= 0)
+                            {
+                                notice.Status = "2";//鎵ц瀹屾垚
+                                notice.UpdateTime = DateTime.Now;
+                                notice.CompleteTime = DateTime.Now;
+                                //淇敼鍏ュ簱鍗曠姸鎬�
+                                Db.Updateable(notice).ExecuteCommand();
+                            }
+                        }
+                        //淇敼鍏ュ簱鍗曟槑缁�
+                        Db.Updateable(noticeDetail).ExecuteCommand();                        
                     }
                 }
                 //鍑哄簱浠诲姟锛屽鐞嗗嚭搴撳崟
                 if (taskInfo.Type == "1" && taskInfo.NoticeDetailNo != 0)//鍏ュ簱
                 {
-                    var notice = Db.Queryable<BllExportNotice>().First(w => w.IsDel == "0" && w.Status == "3");
-                    if (notice != null)
+                    var noticeDetail = Db.Queryable<BllExportNoticeDetail>().First(w => w.IsDel == "0" && w.Id==taskInfo.NoticeDetailNo);
+                    if (noticeDetail != null)
                     {
-                        notice.Status = "4";//鎵ц瀹屾垚
-                        notice.UpdateTime = DateTime.Now;
-                        notice.CompleteTime = DateTime.Now;
-                        //淇敼鍏ュ簱鍗曠姸鎬�
-                        Db.Updateable(notice).ExecuteCommand();
+                        noticeDetail.CompleteQty += 1;//瀹屾垚鏁伴噺
+
+                        if (noticeDetail.CompleteQty >= noticeDetail.Qty)
+                        {
+                            var notice = Db.Queryable<BllExportNotice>().First(w => w.IsDel == "0" && w.SONo == noticeDetail.SONo);
+
+                            var noticeDetailList = Db.Queryable<BllExportNoticeDetail>().Where(w => w.IsDel == "0" && w.CompleteQty < w.Qty && w.Id != noticeDetail.Id).ToList();
+                            if (noticeDetailList.Count <= 0)
+                            {
+                                notice.Status = "4";//鎵ц瀹屾垚
+                                notice.UpdateTime = DateTime.Now;
+                                notice.CompleteTime = DateTime.Now;
+                                //淇敼鍏ュ簱鍗曠姸鎬�
+                                Db.Updateable(notice).ExecuteCommand();
+                            }
+                        }
+                        //淇敼鍏ュ簱鍗曟槑缁�
+                        Db.Updateable(noticeDetail).ExecuteCommand();
                     }
+                    
                 }
 
                 #region 鍘绘帀MES
@@ -982,7 +1102,11 @@
             {
                 path1.type = "05";
             }
-            else//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
+            else if (taskDetial.Crtype == "0")//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
+            {
+                path1.type = "00";
+            }
+            else//鍚岃溅闂村钩灞傛惉杩�
             {
                 path1.type = "05";
             }
@@ -993,9 +1117,13 @@
             path2.positionCode = taskDetial.Endport;
             if (taskDetial.Crtype == "1")//鍙《锛堟《鍑哄簱锛�
             {
+                path2.type = "00";
+            }
+            else if (taskDetial.Crtype == "1")//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
+            {
                 path2.type = "05";
             }
-            else//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
+            else //鍚岃溅闂村钩灞傛惉杩�
             {
                 path2.type = "05";
             }
@@ -1005,21 +1133,34 @@
             AgvSchedulingTask agvTask = new AgvSchedulingTask();
             agvTask.reqCode = taskDetial.Taskno;//璇锋眰缂栧彿
             agvTask.taskCode = taskDetial.Taskno;//浠诲姟鍙�
-            agvTask.ctnrCode = taskDetial.Pallno;//妗跺彿
-            agvTask.ctnrTyp = "1";// 1:妗� 3锛氭墭鐩�
+            agvTask.ctnrCode = taskDetial.Pallno;//妗跺彿            
             agvTask.reqTime = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss");//璇锋眰鏃堕棿                
             agvTask.wbCode = "";
             agvTask.positionCodePath = pahtList;//灏忚溅璺緞
             agvTask.podCode = "";
             agvTask.userCallCode = "";//taskDetial.Endport;//鐩爣浣嶇疆
+            //鍒ゆ柇瀹瑰櫒绫诲瀷
+            if (taskDetial.WareHouseNo == "M04")//鍠峰共杞﹂棿
+            {
+                agvTask.ctnrTyp = "2";// 1锛氭《 2锛氭《锛堝皬锛� 3锛氭墭鐩�
+            }
+            else
+            {
+                agvTask.ctnrTyp = "1";// 1锛氭《 2锛氭《锛堝皬锛� 3锛氭墭鐩�
+            }
+            //鍒ゆ柇浠诲姟绫诲瀷
             if (taskDetial.Crtype == "1")//鍙《锛堟《鍑哄簱锛�
             {
                 agvTask.taskTyp = "Z3";//浠诲姟绫诲瀷 绾胯竟鍒版墭鐩樻敹闆嗗櫒 Z1锛� 鎵樼洏鍨涚敵璇峰叆搴� Z2
             }
-            else//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
+            else if (taskDetial.Crtype == "0")//鐢宠鍌ㄤ綅锛堟《鍏ュ簱锛�
             {
                 agvTask.taskTyp = "Z4";//浠诲姟绫诲瀷 绾胯竟鍒版墭鐩樻敹闆嗗櫒 Z1锛� 鎵樼洏鍨涚敵璇峰叆搴� Z2
             }
+            else//鍚岃溅闂村钩灞傛惉杩�
+            {
+                agvTask.taskTyp = "Z5";
+            }
 
             // 姝e紡杩愯绋嬪簭鏀惧紑
             var jsonData = JsonConvert.SerializeObject(agvTask);

--
Gitblit v1.8.0