| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365 | 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("WCSTASK", "WCS任务号", 80),                SuperGridUtil.Get_GridColumn("WMSTASK", "WMS任务号", 80),                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", "站台地址", 60),                SuperGridUtil.Get_GridColumn("Position", "起始地址", 100),                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("WCSTASK", "WCS任务号:", 20, SubmitMethods, null));            LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.ID like '%{0}%'" };             LCIList.Add(LCItemUtil.Add_TextboxX("WESTASK", "WMS任务号:", 20, SubmitMethods, null));            LCIList[LCIList.Count - 1].Tag = new LCWhereInfo() { QWhereText = "t.WMSTASK 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));                LCIList.Add(LCItemUtil.Add_ButtonX("btn_SendAgv", "AGV任务重下", 100, 30, SubmitMethods));                LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask_Q", "允许取货", 100, 30, SubmitMethods));                LCIList.Add(LCItemUtil.Add_ButtonX("btn_CancelAgvTask_F", "允许放货", 100, 30, SubmitMethods));                LCIList.Add(LCItemUtil.Add_ButtonX("btn_AllowLeave", "允许离开", 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.*,t.ID WCSTASK,t.WMSTASK,b.MEP_MAPPINGCHNAME AgvTaskTypeCh,                                c.MEP_MAPPINGCHNAME StatusCh,d.MEP_MAPPINGCHNAME AgvStatusCh  FROM dbo.WCS_AGVTask a                                left join ( select ID,WMSTASK,AgvTask from ( select ROW_NUMBER() over (PARTITION BY AgvTask order by AgvTask desc) rowid,* from WCS_TASK where AgvTask>0 ) T where rowid=1  )t on a.ID=t.AgvTask                                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 a.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) =>                    {                        var wcstask = db.Queryable<WCS_TASK>().First(v => v.AgvTask == id);                        if (wcstask == null)                        {                            throw new Exception(string.Format("AGV任务ID[{0}]未查询到对应的WCS任务", id));                        }                        var agvtask = db.Queryable<WCS_AGVTask>().First(v => v.ID == id);                        if (agvtask.TaskType == AGVTaskType.叫料)                        {                            agvtask.Status = AGVTaskStatus.确认;                            agvtask.AGVStatus = AGVTaskStatus.新建;                            db.Updateable(agvtask).UpdateColumns(it => new { it.Status, it.AGVStatus }).ExecuteCommand();                        }                        else                            throw new Exception(string.Format("AGV任务ID[{0}]不是叫料任务,不能重新下发", id));                    });                    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);                        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_CancelAgvTask_Q")            {                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.AGVStatus == Frm.AGVTaskStatus.请求_允许)                                                                    {                            agvtask.Status = Frm.AGVTaskStatus.请求_允许;                            db.Updateable(agvtask).UpdateColumns(it => new { it.Status }).ExecuteCommand();                        }                        else                                                                                              {                            throw new Exception("AGV任务状态非请求_允许状态,不支持允许取货动作。");                        }                    });                    if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务允许取货成功", id);                    MessageUtil.ShowTips(msg);                    uC_QueryPage1.RefreshData(1, 0);                }            }            //允许放货            else if (LCName == "btn_CancelAgvTask_F")            {                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.AGVStatus == Frm.AGVTaskStatus.请求_允许)                        {                            agvtask.Status = Frm.AGVTaskStatus.请求_允许;                            db.Updateable(agvtask).UpdateColumns(it => new { it.Status }).ExecuteCommand();                        }                        else                        {                            throw new Exception("AGV任务状态非请求_允许状态,不支持放货动作。");                        }                    });                    if (string.IsNullOrWhiteSpace(msg)) msg = string.Format("ID[{0}]任务允许放货成功", id);                    MessageUtil.ShowTips(msg);                    uC_QueryPage1.RefreshData(1, 0);                }            }            //允许离开            else if (LCName == "btn_AllowLeave")            {                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.AGVStatus == Frm.AGVTaskStatus.取放完成)                        {                            agvtask.Status = Frm.AGVTaskStatus.取放完成;                            db.Updateable(agvtask).UpdateColumns(it => new { it.Status }).ExecuteCommand();                        }                        else                        {                            throw new Exception("AGV任务状态异常,不支持离开。");                        }                    });                    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)        {        }    }}
 |