using Gs.DevApp.Entity; using Gs.DevApp.ToolBox; using Newtonsoft.Json; using Newtonsoft.Json.Linq; using System; using System.Collections.Generic; using System.Data; using System.Threading.Tasks; using System.Windows.Forms; namespace Gs.DevApp.DevFrm.QC { public partial class Frm_WorkTechniqueShow : DevExpress.XtraEditors.XtraForm { private List _filterList = new List(); private readonly string _webServiceName = "WorkTechnique/"; private string sourceGuid = "";//源guid /// /// /// /// /// public Frm_WorkTechniqueShow(string _sourceGuid) { InitializeComponent(); sourceGuid = _sourceGuid; this.gvMain.CustomDrawColumnHeader += (s, e) => { Gs.DevApp.ToolBox.UtilityHelper.CustomDrawColumnHeader(s, e); }; this.gvMain.MouseUp += (s, e) => { Gs.DevApp.ToolBox.UtilityHelper.CustomMouseUp(s, e, gcMain, gvMain); }; this.colChkInt.OptionsColumn.AllowSort = DevExpress.Utils.DefaultBoolean.False; this.colChkInt.OptionsFilter.AllowAutoFilter = false; this.colChkInt.OptionsFilter.AllowFilter = false; this.colChkInt.OptionsFilter.AllowInHeaderSearch = DevExpress.Utils.DefaultBoolean.False; this.pageBar1.setBar(false); getPageList(1); getModel(_sourceGuid); pageBar1.PagerEvent += PageBar1_PagerEvent; Gs.DevApp.ToolBox.UtilityHelper.SetGridViewParameter(gvMain); Gs.DevApp.ToolBox.UtilityHelper.SetGridViewParameter(gvMainCopy); UtilityHelper.SetDefaultTable(gcMainCopy, gvMainCopy); btnIn.Click += (s, e) => { gvMain.PostEditor(); gvMain.UpdateCurrentRow(); var list = new List(); DataTable _oldTable = (DataTable)gcMainCopy.DataSource; DataTable dt = this.gcMain.DataSource as DataTable; { foreach (DataRow dr in dt.Rows) { string checkBox = dr["chkInt"].ToString(); if (Gs.DevApp.ToolBox.UtilityHelper.ToCheck(checkBox)) { _oldTable.ImportRow(dr); } } } if (_oldTable.Rows.Count <= 0) { MsgHelper.ShowInformation("请选择你需要复制的物料!"); return; } gcMainCopy.BindingContext = new BindingContext(); gcMainCopy.DataSource = _oldTable; gcMainCopy.ForceInitialize(); gvMainCopy.BestFitColumns(); }; this.wizardControl1.FinishClick += (s, e) => { int _rows = gvMainCopy.RowCount; if (_rows <= 0) { MsgHelper.ShowInformation("请选择你需要复制的物料!"); e.Cancel = true; return; } if (!MsgHelper.AskQuestion("你选择了" + _rows.ToString() + "条数据,确定保存吗?")) { e.Cancel = true; return; } System.Text.StringBuilder _sbGuids = new System.Text.StringBuilder(); for (var i = 0; i < gvMainCopy.DataRowCount; i++) { var row = gvMainCopy.GetDataRow(i); if (_sbGuids.Length > 0) _sbGuids.Append(","); Guid? _guid = UtilityHelper.ToGuid(row["guid"].ToString()); _sbGuids.Append(_guid.ToString()); } var _obj = new { sourceGuid = UtilityHelper.ToGuid(sourceGuid), itemGuids = _sbGuids.ToString(), }; try { var strJson = UtilityHelper.HttpPost("", _webServiceName + "ItemsComyMx", JsonConvert.SerializeObject(_obj)); var _rtn = UtilityHelper.ReturnToDynamic(strJson); MsgHelper.Warning("提示:" + _rtn.rtnMsg); if (_rtn.rtnCode > 0) { UtilityHelper.SetDefaultTable(gcMainCopy, gvMainCopy); } } catch (Exception ex) { MsgHelper.Warning("提示:" + ex.Message); } }; this.wizardControl1.NextClick += (s, e) => { string pageText = e.Page.Text; if (pageText == "选择物料") { int _rows = gvMainCopy.RowCount; if (_rows <= 0) { MsgHelper.ShowInformation("请选择你需要复制的物料!"); e.Handled = true; return; } } }; } #region 源物料数据绑定 private void GridView1_ColumnFilterChanged(object sender, EventArgs e) { _filterList = Gs.DevApp.ToolBox.UtilityHelper.GetDilter(gvMain.Columns, gvMain); Task.Delay(100); getPageList(1); } /// /// 分页事件 /// /// /// private void PageBar1_PagerEvent(int curPage, int pageSize) { getPageList(curPage); } /// /// /// 第几页 /// 每页几条 private void getPageList(int curPage) { gcMain.DataSource = null; var _sbSqlWhere = UtilityHelper.GetSearchWhere(_filterList); var pgq = new PageQueryModel(curPage, this.pageBar1.RowsCount, "item_no", "asc", "", _sbSqlWhere.ToString(), "workTechnique"); var json = JsonConvert.SerializeObject(pgq); try { var strReturn = UtilityHelper.HttpPost("", "MesItemsManager/GetListSelect", json); var dd = UtilityHelper.ReturnToTablePage(strReturn); if (dd.rtnCode > 0) { DataTable dt = dd.rtnData.list; gcMain.BindingContext = new BindingContext(); gvMain.ColumnFilterChanged -= GridView1_ColumnFilterChanged; if (dt.Rows.Count > 0) { gcMain.DataSource = dt; gcMain.ForceInitialize(); gvMain.BestFitColumns(); Gs.DevApp.ToolBox.UtilityHelper.SetGridLayout(gvMain); } else UtilityHelper.SetDefaultTable(gcMain, gvMain); gvMain.ColumnFilterChanged += GridView1_ColumnFilterChanged; pageBar1.TotalPages = dd.rtnData.pages;//总页 pageBar1.CurrentPage = curPage;//当前页 pageBar1.RecordCount = dd.rtnData.total;//总记录数 } else { ToolBox.MsgHelper.ShowError("提示:" + dd.rtnMsg); } } catch (Exception ex) { MsgHelper.Warning("提示:" + ex.Message); } } #endregion private void getModel(string strGuid) { var _obj = new { guid = strGuid //主建 }; try { var strJson = UtilityHelper.HttpPost("", _webServiceName + "GetModel", JsonConvert.SerializeObject(_obj)); var _rtn = UtilityHelper.ReturnToDynamic(strJson); if (_rtn.rtnCode > 0) { dynamic dy = _rtn.rtnData; List gvList = new List(); gvList.Add(gvMx1); UtilityHelper.SetValueByObj(this.layoutMx1.Controls, dy, false, gvList); JObject _job = JObject.Parse(strJson); JArray array = new JArray(); foreach (var a in _job["rtnData"]["list"]) { array.Add(a); } DataTable dt = JsonConvert.DeserializeObject(array.ToString()); if (dt.Rows.Count > 0) { gcMx1.BindingContext = new BindingContext(); gcMx1.DataSource = dt; gcMx1.ForceInitialize(); gvMx1.BestFitColumns(); } else { Gs.DevApp.ToolBox.UtilityHelper.SetDefaultTable(gcMx1, gvMx1); } } else { MsgHelper.Warning("提示:" + _rtn.rtnMsg); } } catch (Exception ex) { MsgHelper.Warning("提示:" + ex.Message); } } /// /// 删除复制项 /// /// /// private void rptBtnDel_ButtonClick(object sender, DevExpress.XtraEditors.Controls.ButtonPressedEventArgs e) { gvMainCopy.CloseEditor(); gvMainCopy.UpdateCurrentRow(); var rowhandle = gvMainCopy.FocusedRowHandle; if (rowhandle < 0) return; if (e.Button.Index == 0) { var dr = gvMainCopy.GetDataRow(rowhandle); if (!MsgHelper.AskQuestion("你选择了1条数据,确定删除吗?")) return; gvMainCopy.DeleteRow(rowhandle); return; } } } }