using DevComponents.DotNetBar.Layout; using DevComponents.DotNetBar.SuperGrid; using System; using System.Collections.Generic; using System.Data; using System.Windows.Forms; using WCS.Data.Models; using WCS_Client.UC; using WCS_Client.Utility; namespace WCS_Client.Frm { public partial class MBtn_AgvTask : Form { private int wcs_task_no = 0; public MBtn_AgvTask() { InitializeComponent(); InitFrm(); } private void InitFrm() { List GCList = new List() { SuperGridUtil.Get_GridColumn("ID", "任务ID", 80), SuperGridUtil.Get_GridColumn("AGVID", "AGV任务号", 180), SuperGridUtil.Get_GridColumn("AgvTaskTypeCh", "任务类型", 80), SuperGridUtil.Get_GridColumn("StatusCh", "任务状态", 80), SuperGridUtil.Get_GridColumn("AgvStatusCh", "AGV任务状态", 100), SuperGridUtil.Get_GridColumn("Workshop", "车间", 80), SuperGridUtil.Get_GridColumn("Station", "站台地址", 100), SuperGridUtil.Get_GridColumn("Position", "起始地址", 80), SuperGridUtil.Get_GridColumn("CreateTime", "创建时间", 180), SuperGridUtil.Get_GridColumn("UpdateTime", "修改时间", 180), SuperGridUtil.Get_GridColumn("AGVUpdateTime", "AGV修改时间", 180), }; List LCIList = new List(); LCIList.Add(LCItemUtil.Add_TextboxX("ID", "ID:", 20, SubmitMethods, null)); LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.ID like '%{0}%'" }; LCIList.Add(LCItemUtil.Add_TextboxX("AGVID", "AGV任务号:", 20, SubmitMethods, null)); LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.AGVID like '%{0}%'" }; ; LCIList.Add(LCItemUtil.Add_TextboxX("Position", "起始地址:", 20, SubmitMethods, null)); LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Position like '%{0}%'" }; LCIList.Add(LCItemUtil.Add_TextboxX("Station", "站台地址:", 20, SubmitMethods, null)); LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Station like '%{0}%'" }; LCIList.Add(LCItemUtil.Add_TextboxX("Workshop", "车间:", 20, SubmitMethods, null)); LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.Workshop like '%{0}%'" }; LCIList.Add(LCItemUtil.Add_ComboBoxEx("TaskType", "任务类型:", 20, null, SubmitMethods)); TryCachHelper.TryExecute((db) => { var dtsex = db.Queryable().Where(v => v.MEP_MAPPINGTYPE == "TaskType").ToList(); DataTable dt = new DataTable(); DataRow dr; dt.Columns.Add("MEP_MAPPINGNO"); dt.Columns.Add("MEP_MAPPINGCHNAME"); for (int i = 0; i < dtsex.Count; i++) { dr = dt.NewRow(); dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO; dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME; dt.Rows.Add(dr); } LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME"); LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.TaskType like '%{0}%'" }; }); LCIList.Add(LCItemUtil.Add_ComboBoxEx("AGVStatus", "任务状态:", 20, null, SubmitMethods)); TryCachHelper.TryExecute((db) => { var dtsex = db.Queryable().Where(v => v.MEP_MAPPINGTYPE == "AGVStatus").ToList(); DataTable dt = new DataTable(); DataRow dr; dt.Columns.Add("MEP_MAPPINGNO"); dt.Columns.Add("MEP_MAPPINGCHNAME"); for (int i = 0; i < dtsex.Count; i++) { dr = dt.NewRow(); dr["MEP_MAPPINGNO"] = dtsex[i].MEP_MAPPINGNO; dr["MEP_MAPPINGCHNAME"] = dtsex[i].MEP_MAPPINGCHNAME; dt.Rows.Add(dr); } LCItemUtil.Refresh_LCItem(LCIList[LCIList.Count - 1], dt, "MEP_MAPPINGNO", "MEP_MAPPINGCHNAME"); LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "a.STATUS like '%{0}%'" }; }); LCIList.Add(LCItemUtil.Add_ButtonX("btn_QDB", "查询", 80, 30, SubmitMethods)); LCIList.Add(LCItemUtil.Add_ButtonX("btn_QClear", "重置", 80, 30, SubmitMethods)); if (CurrentHelper.User.Use_RoleId == 1) { LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask", "AGV任务取消", 100, 30, SubmitMethods)); LCIList.Add(LCItemUtil.Add_ButtonX("btn_FinishAgvTask", "AGV任务完成", 100, 30, SubmitMethods)); //LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask_F", "允许放货", 100, 30, SubmitMethods)); //LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask_F", "允许放货", 100, 30, SubmitMethods)); //LCIList.Add(LCItemUtil.Add_ButtonX("btn_CMBYWorkShop", "车间叫料", 100, 30, SubmitMethods)); } uC_QueryPage1.Init_QueryPage(60, true, true, "", GCList, LCIList, QueryPageDataMethods, RefreshRoleMethods, DoubleClikMethod, null, null); uC_QueryPage1.ClearLCItemValue(); CommonShow.ShowProcessing("正在处理中,请稍候...", this, (obj) => { uC_QueryPage1.RefreshData(1, 0); }, null); } private PageData QueryPageDataMethods(int PageIndex, int PageSize) { string _SQLText = @"SELECT a.*,b.MEP_MAPPINGCHNAME AgvTaskTypeCh,c.MEP_MAPPINGCHNAME StatusCh,d.MEP_MAPPINGCHNAME AgvStatusCh FROM dbo.WCS_AGVTask a left join dbo.WCS_MAPPINGENTRY b on a.TaskType=b.MEP_MAPPINGNO and b.MEP_MAPPINGTYPE='TaskType' left join dbo.WCS_MAPPINGENTRY c on a.Status=c.MEP_MAPPINGNO and c.MEP_MAPPINGTYPE='AGVStatus' left join dbo.WCS_MAPPINGENTRY d on a.AGVStatus=d.MEP_MAPPINGNO and d.MEP_MAPPINGTYPE='AGVStatus' Where 1=1 and Status < (case when b.MEP_MAPPINGCHNAME='入库' then 100 else 99 end) "; string _Orderby = "a.CreateTime desc"; PageData pd = BaseWorkflow.QueryPageData(_SQLText, _Orderby, uC_QueryPage1.GetQueryWhere(), PageIndex, PageSize); return pd; } private void SubmitMethods(string LCName) { //查询 if (LCName == "btn_QDB") { uC_QueryPage1.RefreshData(); } //清除 else if (LCName == "btn_QClear") { uC_QueryPage1.ShowOpaqueLayer(); uC_QueryPage1.ClearLCItemValue(); uC_QueryPage1.RefreshData(1, 0); uC_QueryPage1.HideOpaqueLayer(); } else if (LCName == "btn_SendAgv") { DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows(); if (dt == null || dt.Rows.Count == 0) { MessageUtil.ShowTips("请选择任务。"); return; } int id = Convert.ToInt32(dt.Rows[0]["Task_Id"].ToString()); var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要重下吗(请谨慎操作)?", id)); if (result == DialogResult.Yes) { string msg = TryCachHelper.TryExecute((db) => { string out_id = id.ToString(); //var wcstask = db.Queryable().First(v => v.TASK_ITEM8 == out_id); //if (wcstask == null) //{ // throw new Exception(string.Format("AGV任务ID[{0}]未查询到对应的WMS任务", out_id)); //} var agvtask = db.Queryable().First(v => v.Task_Id == id); agvtask.Task_WcsStatus = 1; agvtask.Task_AgvStatus = 0; db.Updateable(agvtask).UpdateColumns(it => new { it.Task_WcsStatus, it.Task_AgvStatus }).ExecuteCommand(); }); if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务重下成功", id); MessageUtil.ShowTips(msg); uC_QueryPage1.RefreshData(1, 0); } } //取消任务 else if (LCName == "btn_CancelAgvTask") { DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows(); if (dt == null || dt.Rows.Count == 0) { MessageUtil.ShowTips("请选择任务。"); return; } int id = Convert.ToInt32(dt.Rows[0]["ID"].ToString()); var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务确定要取消吗(请谨慎操作)?", id)); if (result == DialogResult.Yes) { string msg = TryCachHelper.TryExecute((db) => { var agvtask = db.Queryable().First(v => v.ID == id); if (agvtask.Status == Frm.AGVTaskStatus.新建) { agvtask.Status = Frm.AGVTaskStatus.取消; db.Updateable(agvtask).UpdateColumns(it => new { it.Status }).ExecuteCommand(); } else { throw new Exception("该类型任务(或非初始状态)暂时不支持取消动作。"); } }); if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务取消成功", id); MessageUtil.ShowTips(msg); uC_QueryPage1.RefreshData(1, 0); } } //完成任务 else if (LCName == "btn_FinishAgvTask") { DataTable dt = this.uC_QueryPage1.SCGrid_GetChkRows(); if (dt == null || dt.Rows.Count == 0) { MessageUtil.ShowTips("请选择任务。"); return; } int id = Convert.ToInt32(dt.Rows[0]["ID"].ToString()); var result = MessageUtil.ShowYesNoAndWarning(string.Format("id[{0}]的任务要手动完成吗(请谨慎操作)?", id)); if (result == DialogResult.Yes) { string msg = TryCachHelper.TryExecute((db) => { var agvtask = db.Queryable().First(v => v.ID == id); if (agvtask.TaskType == AGVTaskType.入库) { agvtask.Status = AGVTaskStatus.完成扫码; agvtask.AGVStatus = AGVTaskStatus.完成扫码; } else { agvtask.Status = AGVTaskStatus.完成; agvtask.AGVStatus = AGVTaskStatus.完成; } agvtask.UpdateTime = DateTime.Now; db.Updateable(agvtask).UpdateColumns(it => new { it.Status, it.AGVStatus, it.UpdateTime }).ExecuteCommand(); }); if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]手动完成成功", id); MessageUtil.ShowTips(msg); uC_QueryPage1.RefreshData(1, 0); } } else if (LCName == "btn_CMBYWorkShop") { var frmCMByWorkShop = new FrmCMByWorkShop(); frmCMByWorkShop.ShowDialog(); uC_QueryPage1.RefreshData(1, 0); } } private void DoubleClikMethod(DataRow dr) { //wcs_task_no = Convert.ToInt32(dr["TASK_NO"].ToString()); //FrmWCS_TaskDIS_DTL Frm = new FrmWCS_TaskDIS_DTL(wcs_task_no); //Frm.Show(); } private void RefreshRoleMethods(bool ChkValue) { } } }