|  |  |  | using SunlightCentralizedControlManagement_SCCM_.UserClass; | 
					
						
							|  |  |  | using SunlightCentralizedControlManagement_SCCM_.ViewModel; | 
					
						
							|  |  |  | using System; | 
					
						
							|  |  |  | using System.Collections.Generic; | 
					
						
							|  |  |  | using System.Data.SqlClient; | 
					
						
							|  |  |  | using System.Data; | 
					
						
							|  |  |  | using System.Linq; | 
					
						
							|  |  |  | using System.Security.Cryptography; | 
					
						
							|  |  |  | using System.Text; | 
					
						
							|  |  |  | using System.Threading.Tasks; | 
					
						
							|  |  |  | using System.Windows; | 
					
						
							|  |  |  | using System.Windows.Controls; | 
					
						
							|  |  |  | using System.Windows.Data; | 
					
						
							|  |  |  | using System.Windows.Documents; | 
					
						
							|  |  |  | using System.Windows.Input; | 
					
						
							|  |  |  | using System.Windows.Media; | 
					
						
							|  |  |  | using System.Windows.Media.Imaging; | 
					
						
							|  |  |  | using System.Windows.Shapes; | 
					
						
							|  |  |  | using System.Collections.ObjectModel; | 
					
						
							|  |  |  | using System.Reflection; | 
					
						
							|  |  |  | using System.Xml.Linq; | 
					
						
							|  |  |  | using DyeingComputer.UserClass; | 
					
						
							|  |  |  | using System.Windows.Forms; | 
					
						
							|  |  |  | using SunlightCentralizedControlManagement_SCCM_.WindowsView; | 
					
						
							|  |  |  | using OpenTK.Graphics.OpenGL; | 
					
						
							|  |  |  | using ScottPlot.TickGenerators.TimeUnits; | 
					
						
							|  |  |  | using static SunlightCentralizedControlManagement_SCCM_.UserClass.SqliteHelper; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace SunlightCentralizedControlManagement_SCCM_.EX | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /// <summary>
 | 
					
						
							|  |  |  |     /// ManualDyelot.xaml 的交互逻辑
 | 
					
						
							|  |  |  |     /// </summary>
 | 
					
						
							|  |  |  |     public partial class ManualDyelot : Window | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private SQLiteHelper SQLiteHelpers = null;  //定义数据库
 | 
					
						
							|  |  |  |         private readonly string DBAddress = Environment.CurrentDirectory + "\\DataBase\\SCCM.db";  //数据库路径
 | 
					
						
							|  |  |  |         DataTable dyelotdat = new DataTable(); | 
					
						
							|  |  |  |         public static string Machines; | 
					
						
							|  |  |  |         DataTable mach = new DataTable(); | 
					
						
							|  |  |  |         DataTable RRODUCTdataTable = new DataTable();   //建立RRODUCT缓存
 | 
					
						
							|  |  |  |         int ID_N = 1; | 
					
						
							|  |  |  |         int type_; | 
					
						
							|  |  |  |         DateTime time = DateTime.Now; | 
					
						
							|  |  |  |         public ManualDyelot() | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             InitializeComponent(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             State.IsEnabled = false; | 
					
						
							|  |  |  |             string[] strings = { "0", "1", "2", "3" }; | 
					
						
							|  |  |  |             comboBoxtank.ItemsSource = strings; | 
					
						
							|  |  |  |             comboBoxtank.Text = "0"; | 
					
						
							|  |  |  |             comboBoxTotal.Text = "0"; | 
					
						
							|  |  |  |             int mrc = MainWindowViewModel.Machines.Rows.Count; | 
					
						
							|  |  |  |             string[] stringsM = new string[mrc]; | 
					
						
							|  |  |  |             for (int i = 0; i < mrc; i++) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 stringsM[i] = MainWindowViewModel.Machines.Rows[i]["name"].ToString(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             comboBoxMachine.ItemsSource = stringsM; | 
					
						
							|  |  |  |             dyelot.Text = "00_" + DateTime.Now.ToString("yyMMddHHmmss"); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("ID", typeof(int)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("DYELOT", typeof(string)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("ReDye", typeof(int)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("STEP", typeof(int)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("ProductType", typeof(int)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("Created", typeof(string)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("PRODUCT_CODE", typeof(string)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("PRODUCT_NAME", typeof(string)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("TARGET_WT", typeof(float)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("Amount", typeof(string)); | 
					
						
							|  |  |  |             RRODUCTdataTable.Columns.Add("UNIT", typeof(string)); | 
					
						
							|  |  |  |             DataRow row = RRODUCTdataTable.NewRow();  //ID列
 | 
					
						
							|  |  |  |             row["ID"] = ID_N; | 
					
						
							|  |  |  |             row["DYELOT"] = dyelot.Text; | 
					
						
							|  |  |  |             row["ReDye"] = 0; | 
					
						
							|  |  |  |             row["STEP"] = "1"; | 
					
						
							|  |  |  |             row["ProductType"] = type_; | 
					
						
							|  |  |  |             row["Created"] = time; | 
					
						
							|  |  |  |             row["UNIT"] = "g"; | 
					
						
							|  |  |  |             RRODUCTdataTable.Rows.Add(row); | 
					
						
							|  |  |  |             Grid_data.ItemsSource = RRODUCTdataTable.DefaultView; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public void MAC(object Mac,int t) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             Machines = Mac.ToString(); | 
					
						
							|  |  |  |             type_ = t; | 
					
						
							|  |  |  |           /*  string Connstr_SC; | 
					
						
							|  |  |  |             string sql = "SELECT * FROM [dbo].[Pipes] WHERE Dispenser = '" + Machines + "'"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             try | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 if (MainWindowViewModel.SQMOD == "Windows Authentication") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     Connstr_SC = "server=" + MainWindowViewModel.SQLIP + ";database=" + MainWindowViewModel.SQLNAME + ";Trusted_Connection=SSPI"; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     Connstr_SC = "server=" + MainWindowViewModel.SQLIP + ";database=" + MainWindowViewModel.SQLNAME + ";User ID=" + MainWindowViewModel.SQLUSER + ";Password=" + MainWindowViewModel.SQLPASWORD; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 SqlConnection conn_SC = new SqlConnection(Connstr_SC); | 
					
						
							|  |  |  |                 await conn_SC.OpenAsync();     //连接数据库
 | 
					
						
							|  |  |  |                 new SqlDataAdapter(sql, Connstr_SC).Fill(dyelotdat); | 
					
						
							|  |  |  |                 // SqlDataAdapter _data = new SqlDataAdapter(sql, Connstr_SC);   //查询
 | 
					
						
							|  |  |  |                 conn_SC.Close(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 for (int i = 0; i < dyelotdat.Rows.Count; i++) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     SelectProductCode.Add(dyelotdat.Rows[i].Field<string>("ProductCode")); | 
					
						
							|  |  |  |                     SelectProductName.Add(dyelotdat.Rows[i].Field<string>("ProductName")); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             catch (Exception ex) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 LogGing.ERRDATA(ex); | 
					
						
							|  |  |  |             }*/ | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private async void State_Click(object sender, RoutedEventArgs e)//确认按键
 | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             int t = RRODUCTdataTable.Rows.Count;  //获取数据行包含空白行
 | 
					
						
							|  |  |  |             RRODUCTdataTable.Rows[t - 1].Delete(); | 
					
						
							|  |  |  |             RRODUCTdataTable.AcceptChanges(); | 
					
						
							|  |  |  |             if (string.IsNullOrEmpty(comboBoxMachine.Text)) return;//未输入机台时返回
 | 
					
						
							|  |  |  |             try | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 SQLiteHelpers = new SQLiteHelper(DBAddress); //数据库连接路径
 | 
					
						
							|  |  |  |                 SQLiteHelpers.Open();  //打开数据库
 | 
					
						
							|  |  |  |                 Dictionary<string, object> Dyelot_DAT = new Dictionary<string, object>();//缓存函数
 | 
					
						
							|  |  |  |                 for (int x = 0; x < RRODUCTdataTable.Rows.Count; x++) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("WorkOrder", orders.Text); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("Dyelot", RRODUCTdataTable.Rows[x]["Dyelot"]); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("Redye", RRODUCTdataTable.Rows[x]["Redye"]); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("Step", RRODUCTdataTable.Rows[x]["Step"]); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("TIME", RRODUCTdataTable.Rows[x]["Created"]); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("Tank", comboBoxtank.Text); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("State", "201"); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("Machine", comboBoxMachine.Text); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("ProductCode", RRODUCTdataTable.Rows[x]["PRODUCT_CODE"]); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("ProductName", RRODUCTdataTable.Rows[x]["PRODUCT_NAME"]); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("ProductType", RRODUCTdataTable.Rows[x]["ProductType"]); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("DispenseStartTime", DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss")); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("Grams", RRODUCTdataTable.Rows[x]["TARGET_WT"]); | 
					
						
							|  |  |  |                     Dyelot_DAT.Add("Amount", RRODUCTdataTable.Rows[x]["Amount"]); | 
					
						
							|  |  |  |                     SQLiteHelpers.InsertData("Dyelot", Dyelot_DAT);//行插入                                                                             
 | 
					
						
							|  |  |  |                     Dyelot_DAT.Clear(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 SQLiteHelpers.Close();  //关闭连接
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 LogGing.ExchangeDATA("Dyelot=" + dyelot.Text + ";Machine=" + comboBoxMachine.Text + | 
					
						
							|  |  |  |                     ";Program=------;User=" + MainWindowViewModel.USER_data + ";"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 string Connstr_SC; | 
					
						
							|  |  |  |                 if (MainWindowViewModel.SQMOD == "Windows Authentication") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     Connstr_SC = "server=" + MainWindowViewModel.SQLIP + ";database=" + MainWindowViewModel.SQLNAME + ";Trusted_Connection=SSPI"; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     Connstr_SC = "server=" + MainWindowViewModel.SQLIP + ";database=" + MainWindowViewModel.SQLNAME + ";User ID=" + MainWindowViewModel.SQLUSER + ";Password=" + MainWindowViewModel.SQLPASWORD; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 SqlConnection destinationConnection = new SqlConnection(Connstr_SC); //创建一个数据库连接;
 | 
					
						
							|  |  |  |                 await destinationConnection.OpenAsync();    //打开连接
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 //写总览
 | 
					
						
							|  |  |  |                 string dyelots_sql = string.Format("INSERT INTO [dbo].[DYELOTS]([Dyelot] ,[ReDye] , [OrderNo] , [Machine] ,[DispenseMachine] ,[UserAccount]  ) " + | 
					
						
							|  |  |  |                                                       "VALUES ('" + dyelot.Text + "','0','" + orders.Text + "','" + comboBoxMachine.Text + "','" + comboBoxMachine.Text + "','" + MainWindow.user_ + "')"); | 
					
						
							|  |  |  |                 SqlCommand INSERT_cmd = new SqlCommand(dyelots_sql, destinationConnection); | 
					
						
							|  |  |  |                 int dyelots_sqlIN = INSERT_cmd.ExecuteNonQuery();     //执行语句
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 //写明细
 | 
					
						
							|  |  |  |                 SqlBulkCopy bulkCopy = new SqlBulkCopy(destinationConnection);// 实例化 sqlbulkcopy;
 | 
					
						
							|  |  |  |                 bulkCopy.DestinationTableName = "dbo.DyelotsBulkedRecipe";// 目标表名称/
 | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("DYELOT", "Dyelot"); | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("ReDye", "ReDye"); | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("STEP", "StepNumber"); | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("PRODUCT_CODE", "ProductCode"); | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("PRODUCT_NAME", "ProductName"); | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("ProductType", "ProductType"); | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("Created", "Created"); | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("Amount", "Amount"); | 
					
						
							|  |  |  |                 bulkCopy.ColumnMappings.Add("TARGET_WT", "Grams"); | 
					
						
							|  |  |  |                 bulkCopy.WriteToServer(RRODUCTdataTable); //将传入的数据写到数据库;
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 string mac_sql = string.Format("UPDATE [dbo].[Machines] SET DispenseDyelot='" + dyelot.Text | 
					
						
							|  |  |  |                     + "',DispenseReDye='0',ChemicalCallOff=1,ChemicalState=201,ChemicalTank='" + comboBoxtank.Text | 
					
						
							|  |  |  |                     + "' WHERE NAME='" + comboBoxMachine.Text + "'"); | 
					
						
							|  |  |  |                 SqlCommand UPDATE_mac = new SqlCommand(mac_sql, destinationConnection); | 
					
						
							|  |  |  |                 int mac_ = UPDATE_mac.ExecuteNonQuery();     //执行语句
 | 
					
						
							|  |  |  |                 if (mac_ == 0) System.Windows.Forms.MessageBox.Show(Properties.Resources.Not_M); | 
					
						
							|  |  |  |                 destinationConnection.Close(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 this.Close();//退出页面
 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             catch (Exception ex) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 LogGing.ERRDATA(ex); | 
					
						
							|  |  |  |                 System.Windows.Forms.MessageBox.Show(ex.Message.ToString()); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private void comboBoxMachine_DropDownClosed(object sender, EventArgs e) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             if (!string.IsNullOrEmpty(comboBoxMachine.Text)) | 
					
						
							|  |  |  |             {                | 
					
						
							|  |  |  |                 string Macht= MainWindowViewModel.Selet_Machines(MainWindowViewModel.Machines, "WorkOrder", "NAME = '" + comboBoxMachine.Text + "'").ToString(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if (Macht != "------") | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     orders.Text = Macht; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 else | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     orders.Text = dyelot.Text; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private void Cancel_Click(object sender, RoutedEventArgs e) | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             this.Close(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         public ObservableCollection<string> SelectProductCode | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             get { return _selectProductCode; } | 
					
						
							|  |  |  |             set { _selectProductCode = value; } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         private ObservableCollection<string> _selectProductCode = new ObservableCollection<string>(); | 
					
						
							|  |  |  |         public ObservableCollection<string> SelectProductName | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             get { return _selectProductName; } | 
					
						
							|  |  |  |             set { _selectProductName = value; } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         private ObservableCollection<string> _selectProductName = new ObservableCollection<string>(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         string Code_; | 
					
						
							|  |  |  |         string Name_;       | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private void CP_PRODUCT_CODE_DropDownClosed(object sender, EventArgs e)//代码选择事件
 | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             State.IsEnabled = false; | 
					
						
							|  |  |  |             System.Windows.Controls.ComboBox curComboBox = sender as System.Windows.Controls.ComboBox; | 
					
						
							|  |  |  |             int grid_row = Grid_data.SelectedIndex;  //获取当前行
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             Code_ = curComboBox.Text.TrimEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             DataRow[] r = ManualDyelotModel.STUFFdataTable.Select("ProductCode ='" + Code_ + "'"); //查询判断原料代码是否有效
 | 
					
						
							|  |  |  |             if (!r.Any())  //检查原料信息
 | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             int ID_ = grid_row + 1; | 
					
						
							|  |  |  |             DataRow[] c = RRODUCTdataTable.Select("PRODUCT_CODE ='" + Code_ + "'and ID <> '" + ID_ + "'");//查询判断原料代码是否重复
 | 
					
						
							|  |  |  |             if (c.Any()) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 curComboBox.Text = null; | 
					
						
							|  |  |  |                 System.Windows.MessageBox.Show(Properties.Resources.RTRM); | 
					
						
							|  |  |  |                 return; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             Name_ = r[0].ItemArray[1].ToString(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (grid_row == -1) grid_row = 0; | 
					
						
							|  |  |  |             DataRow row = RRODUCTdataTable.Rows[grid_row];  //ID列
 | 
					
						
							|  |  |  |             row.BeginEdit(); | 
					
						
							|  |  |  |             row["PRODUCT_CODE"] = Code_; | 
					
						
							|  |  |  |             row["PRODUCT_NAME"] = Name_; | 
					
						
							|  |  |  |             row.EndEdit(); | 
					
						
							|  |  |  |             DataGridHelper.SetRealTimeCommit(Grid_data, true);   //实时更新datagrid
 | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private void CP_PRODUCT_NAME_DropDownClosed(object sender, EventArgs e)//选择原料事件
 | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             State.IsEnabled = false; | 
					
						
							|  |  |  |             System.Windows.Controls.ComboBox curComboBox = sender as System.Windows.Controls.ComboBox; | 
					
						
							|  |  |  |             int grid_row = Grid_data.SelectedIndex;  //获取当前行
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (curComboBox.Text != "") | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 Name_ = curComboBox.Text.TrimEnd(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 DataRow[] r = ManualDyelotModel.STUFFdataTable.Select("ProductName ='" + Name_ + "'"); //查询判断原料代码是否有效
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 DataRow[] c = RRODUCTdataTable.Select("PRODUCT_NAME ='" + Name_ + "'");//查询判断原料代码是否重复
 | 
					
						
							|  |  |  |                 if (c.Any()) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     curComboBox.Text = null; | 
					
						
							|  |  |  |                     System.Windows.MessageBox.Show(Properties.Resources.RTRM); | 
					
						
							|  |  |  |                     return; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 Code_ = r[0].ItemArray[0].ToString(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 if (grid_row == -1) grid_row = 0; | 
					
						
							|  |  |  |                 DataRow row = RRODUCTdataTable.Rows[grid_row];  //ID列
 | 
					
						
							|  |  |  |                 row.BeginEdit(); | 
					
						
							|  |  |  |                 row["PRODUCT_CODE"] = Code_; | 
					
						
							|  |  |  |                 row["PRODUCT_NAME"] = Name_; | 
					
						
							|  |  |  |                 row.EndEdit(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         private void CP_CONC_KeyDown(object sender, System.Windows.Input.KeyEventArgs e)//输入目标量事件
 | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |             System.Windows.Controls.TextBox textBox = sender as System.Windows.Controls.TextBox; | 
					
						
							|  |  |  |             int grid_row = Grid_data.SelectedIndex;  //获取当前行
 | 
					
						
							|  |  |  |             if (string.IsNullOrEmpty(textBox.Text)) return; | 
					
						
							|  |  |  |             if (e.Key == Key.Enter) | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 if (grid_row == -1) grid_row = 0; | 
					
						
							|  |  |  |                 DataRow row = RRODUCTdataTable.Rows[grid_row]; | 
					
						
							|  |  |  |                 if (string.IsNullOrEmpty(row["PRODUCT_CODE"].ToString())) | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     textBox.Text = null; | 
					
						
							|  |  |  |                     return; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 row.BeginEdit(); | 
					
						
							|  |  |  |                 row["Amount"] = textBox.Text + "g";  | 
					
						
							|  |  |  |                 row["TARGET_WT"] = textBox.Text; | 
					
						
							|  |  |  |                 row.EndEdit(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 ID_N++; | 
					
						
							|  |  |  |                 DataRow rowadd = RRODUCTdataTable.NewRow();  //ID列
 | 
					
						
							|  |  |  |                 rowadd["ID"] = ID_N; | 
					
						
							|  |  |  |                 rowadd["DYELOT"] = dyelot.Text; | 
					
						
							|  |  |  |                 rowadd["ReDye"] = 0; | 
					
						
							|  |  |  |                 rowadd["STEP"] = "1"; | 
					
						
							|  |  |  |                 row["ProductType"] = type_; | 
					
						
							|  |  |  |                 rowadd["Created"] = time; | 
					
						
							|  |  |  |                 rowadd["UNIT"] = "g"; | 
					
						
							|  |  |  |                 RRODUCTdataTable.Rows.Add(rowadd); | 
					
						
							|  |  |  |                 State.IsEnabled = true; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |