123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233 |
- 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<GridColumn> GCList = new List<GridColumn>()
- {
- 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<LayoutControlItem> LCIList = new List<LayoutControlItem>();
- 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<WCS_MAPPINGENTRY>().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<WCS_MAPPINGENTRY>().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));
- }
- 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 < 100 ";
- 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<WCS_TASK>().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<Middle_AGVTask>().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<WCS_AGVTask>().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<WCS_AGVTask>().First(v => v.ID == id);
- 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);
- }
- }
- }
- 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)
- {
- }
- }
- }
|