Form_Task.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402
  1. using CCWin;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.ComponentModel;
  5. using System.Data;
  6. using System.Drawing;
  7. using System.Linq;
  8. using System.Text;
  9. using System.Threading.Tasks;
  10. using System.Windows.Forms;
  11. using WCS_Client.UC;
  12. using WCS_Client.Utility;
  13. namespace WCS_Client.From
  14. {
  15. public partial class Form_Task : CCSkinMain
  16. {
  17. DataTable _dt;
  18. DataRow _currentDr;
  19. public Form_Task()
  20. {
  21. InitializeComponent();
  22. Bind();
  23. SelectedRow(true);
  24. if (_currentDr != null)
  25. {
  26. BindingDataDtl(_currentDr["TASK_ID"].ToString());
  27. }
  28. }
  29. private static Form_Task childFromInstanc;
  30. public static Form_Task ChildFromInstanc
  31. {
  32. get
  33. {
  34. if (childFromInstanc == null || childFromInstanc.IsDisposed)
  35. {
  36. childFromInstanc = new Form_Task();
  37. }
  38. return childFromInstanc;
  39. }
  40. }
  41. //绑定数据
  42. private void Bind()
  43. {
  44. string sqlstr = string.Format(@"select t.*,m.MEP_MAPPINGCHNAME task_comtypech,me.MEP_MAPPINGCHNAME task_wkstatusch from dbo.WCS_TASK t
  45. left join WCS_MAPPINGENTRY m on t.task_comtype = m.MEP_MAPPINGNO and m.MEP_MAPPINGTYPE = 'COMTYPE'
  46. left join WCS_MAPPINGENTRY me on t.task_wkstatus = me.MEP_MAPPINGNO and me.MEP_MAPPINGTYPE = 'WkStatus' ");
  47. PageData pd = QueryPageDataMethods(1, 10000,sqlstr);
  48. if (pd != null)
  49. {
  50. _dt = pd.Dt;
  51. dgvTask.DataSource = _dt;
  52. }
  53. else
  54. {
  55. if (_dt != null) _dt.Clear();
  56. }
  57. }
  58. //获取数据集
  59. private PageData QueryPageDataMethods(int PageIndex, int PageSize,string sqlstr)
  60. {
  61. string _Orderby = " task_no asc";
  62. PageData pd = BaseWorkflow.QueryPageData(sqlstr, _Orderby, new List<string>(), PageIndex, PageSize);
  63. return pd;
  64. }
  65. private void BtnRefresh_Click(object sender, EventArgs e)
  66. {
  67. Bind();
  68. }
  69. private void dgvTask_CellMouseClick(object sender, DataGridViewCellMouseEventArgs e)
  70. {
  71. SelectedRow(true);
  72. BindingDataDtl(_currentDr["TASK_ID"].ToString());
  73. }
  74. protected virtual bool SelectedRow(bool isFrist)
  75. {
  76. _currentDr = GetDgvRow("TASK_ID");
  77. if (_currentDr == null)
  78. {
  79. if (isFrist == false)
  80. {
  81. MessageUtil.ShowWarning("请选中行!!!");
  82. }
  83. return false;
  84. }
  85. return true;
  86. }
  87. public DataRow GetDgvRow(string cellName)
  88. {
  89. try
  90. {
  91. if (dgvTask.CurrentCell == null) return null;
  92. if (dgvTask.CurrentCell.RowIndex >= 0)
  93. {
  94. string no = Convert.ToString(dgvTask.Rows[dgvTask.CurrentCell.RowIndex].Cells[cellName].Value);
  95. return _dt.Select(cellName + "='" + no + "'")[0];
  96. }
  97. return null;
  98. }
  99. catch (Exception ex)
  100. {
  101. return null;
  102. }
  103. }
  104. DataTable _dtdtl = null;
  105. private void BindingDataDtl(string task_Id)
  106. {
  107. string _SQLText = @"SELECT id,parentid,taskno,posidcur,posidnext,description,notes,to_char(executedate,'yyyy-MM-dd hh24:mi:ss') executedate FROM wcs_task_dtl where parentid='" + task_Id+"'";
  108. string _Orderby = " executedate asc";
  109. PageData pd = BaseWorkflow.QueryPageData(_SQLText, _Orderby, new List<string>(), 1, 10000);
  110. if (pd == null)
  111. {
  112. if (_dtdtl != null) _dtdtl.Clear();
  113. }
  114. else
  115. {
  116. _dtdtl = pd.Dt;
  117. dgvTaskdtl.DataSource = pd.Dt;
  118. }
  119. }
  120. private void sknBinResetSrm_Click(object sender, EventArgs e)
  121. {
  122. if (_currentDr == null)
  123. {
  124. MessageBox.Show("请选择手动处理的任务。");
  125. }
  126. else
  127. {
  128. int taskid = Convert.ToInt32(_currentDr["TASK_NO"].ToString());
  129. string taskno = _currentDr["TASK_NO"].ToString();
  130. DialogResult dr = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要执行[重下堆垛机]吗(谨慎操作)?", taskno));
  131. if (dr != DialogResult.Yes) return;
  132. string result= BaseWorkflow.UpdateTask(taskid, TaskStatusType.重下堆垛机);
  133. MessageBox.Show(result);
  134. Bind();
  135. }
  136. }
  137. private void sknBtnOnMaterResetAGV_Click(object sender, EventArgs e)
  138. {
  139. if (_currentDr == null)
  140. {
  141. MessageBox.Show("请选择手动处理的任务。");
  142. }
  143. else
  144. {
  145. int taskid = Convert.ToInt32(_currentDr["TASK_NO"].ToString());
  146. string taskno = _currentDr["TASK_NO"].ToString();
  147. DialogResult dr = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要执行[重下RGV上料]吗(谨慎操作)?", taskno));
  148. if (dr != DialogResult.Yes) return;
  149. string result = BaseWorkflow.UpdateTask(taskid, TaskStatusType.重下RGV上料);
  150. MessageBox.Show(result);
  151. Bind();
  152. }
  153. }
  154. private void sknBinUpMaterResetAGV_Click(object sender, EventArgs e)
  155. {
  156. if (_currentDr == null)
  157. {
  158. MessageBox.Show("请选择手动处理的任务。");
  159. }
  160. else
  161. {
  162. int taskid = Convert.ToInt32(_currentDr["TASK_NO"].ToString());
  163. string taskno = _currentDr["TASK_NO"].ToString();
  164. DialogResult dr = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要执行[重下RGV下料]吗(谨慎操作)?", taskno));
  165. if (dr != DialogResult.Yes) return;
  166. string result = BaseWorkflow.UpdateTask(taskid, TaskStatusType.重下RGV下料);
  167. MessageBox.Show(result);
  168. Bind();
  169. }
  170. }
  171. private void sknBinTaskFinish_Click(object sender, EventArgs e)
  172. {
  173. if (_currentDr == null)
  174. {
  175. MessageBox.Show("请选择手动完成的任务。");
  176. }
  177. else
  178. {
  179. int taskno = Convert.ToInt32(_currentDr["TASK_NO"]);
  180. int tasktype = Convert.ToInt32(_currentDr["TASK_COMTYPE"]);
  181. DialogResult dr = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要执行[手动完成]吗(谨慎操作)?", taskno));
  182. if (dr != DialogResult.Yes) return;
  183. int temptype = 0;
  184. if (tasktype == 1)
  185. {
  186. temptype = 1;//入库完成
  187. }
  188. else if (tasktype == 2)
  189. {
  190. string errormsg = TryCachHelper.TryExecute((db)=>{
  191. var task = db.Queryable<Models.WCS_TASK>().First(v => v.TASK_NO == taskno);
  192. if (task != null && task.TASK_WKSTATUS == 5)//堆垛机出库完成
  193. {
  194. temptype = 2;
  195. string completeMsg = string.Empty;
  196. bool abc = BaseWorkflow.BZ_TASKCOMPLETE(taskno, temptype, out completeMsg);
  197. if (abc == false)
  198. {
  199. throw new Exception(completeMsg);
  200. }
  201. }
  202. temptype = 4;//出库完成
  203. });
  204. if (!string.IsNullOrWhiteSpace(errormsg))
  205. {
  206. MessageBox.Show(errormsg);
  207. return;
  208. }
  209. }
  210. else if (tasktype == 4)
  211. {
  212. temptype = 4;//出库完成
  213. }
  214. else if (tasktype == 2 || tasktype == 4)
  215. {
  216. temptype = 4;//出库完成
  217. }
  218. else if (tasktype == 3)
  219. {
  220. temptype = 3;//移库完成
  221. }
  222. else if (tasktype == 5)
  223. {
  224. temptype = 5;//堆垛机码盘完成
  225. }
  226. string msg = string.Empty;
  227. bool result = BaseWorkflow.BZ_TASKCOMPLETE(taskno, temptype, out msg);
  228. MessageBox.Show(msg);
  229. Bind();
  230. }
  231. }
  232. private void sknBtnResertTask_Click(object sender, EventArgs e)
  233. {
  234. if (_currentDr == null)
  235. {
  236. MessageBox.Show("请选择手动处理的任务。");
  237. }
  238. else
  239. {
  240. string taskid = _currentDr["TASK_ID"].ToString();
  241. string taskno = _currentDr["TASK_NO"].ToString();
  242. DialogResult dr = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要执行[重下任务]吗(谨慎操作)?", taskno));
  243. if (dr != DialogResult.Yes) return;
  244. string result = BaseWorkflow.UpdateTask(Convert.ToInt32(taskno), TaskStatusType.重下任务);
  245. MessageBox.Show(result);
  246. Bind();
  247. }
  248. }
  249. private void sknBtnCancel_Click(object sender, EventArgs e)
  250. {
  251. if (_currentDr == null)
  252. {
  253. MessageBox.Show("请选择手动处理的任务。");
  254. }
  255. else
  256. {
  257. string taskno = _currentDr["TASK_NO"].ToString();
  258. DialogResult dr = MessageUtil.ShowYesNoAndWarning(string.Format("任务[{0}]确定要执行[取消任务]吗(谨慎操作)?", taskno));
  259. if (dr != DialogResult.Yes) return;
  260. string msg = string.Empty;
  261. BaseWorkflow.TaskCancel(Convert.ToInt32(taskno), out msg);
  262. MessageBox.Show(msg);
  263. Bind();
  264. }
  265. }
  266. private void btnQuery_Click(object sender, EventArgs e)
  267. {
  268. string sqlstr = string.Format(@"SELECT task_id,task_no,task_systype,TASK_COMTYPE,task_posidfrom,task_posidcur,task_posidnext,task_posidto,task_posidmove,task_priority,
  269. task_whid, task_adduserno, task_adddatetime, task_edituserno, task_editdatetime, task_notes, task_srmno, task_boxbarcode,
  270. m.MEP_MAPPINGCHNAME task_comtypech, me.MEP_MAPPINGCHNAME task_wkstatusch,i.F_MATNO,i.F_MATNAME,i.qty
  271. FROM wcs_task t
  272. left join WCS_MAPPINGENTRY m on t.task_comtype = m.MEP_MAPPINGNO and m.MEP_MAPPINGTYPE = 'COMTYPE'
  273. left join WCS_MAPPINGENTRY me on t.task_wkstatus = me.MEP_MAPPINGNO and me.MEP_MAPPINGTYPE = 'WkStatus'
  274. left join
  275. (
  276. select i.F_MATNO,i.F_MATNAME,i.F_CONTRGRPNO,sum(i.f_qty) qty from wcs_task t
  277. left join BILL_INVCONTR i on t.TASK_ITEM5=i.F_CONTRGRPNO
  278. where i.F_WAREHOUSENO='WTP' or i.F_WAREHOUSENO='WZZ'
  279. group by i.F_MATNO,F_MATNAME,i.F_CONTRGRPNO
  280. ) i on t.TASK_ITEM5=i.F_CONTRGRPNO
  281. where task_srmno like '%{0}%' and task_posidto like '%{1}%' and task_boxbarcode like '%{2}%' and task_no like '%{3}%' and (nvl(i.F_MATNO,0) like '%{4}%' or nvl(i.F_MATNAME,0) like '%{5}%')",
  282. txtSrmNo.Text.Trim(), txtEnd.Text.Trim(), txtBarCode.Text.Trim(), txtTaskNo.Text.Trim(), txtMatNo.Text.Trim(), txtMatNo.Text.Trim());
  283. var pd = QueryPageDataMethods(1,1000,sqlstr);
  284. if (pd != null)
  285. {
  286. _dt = pd.Dt;
  287. dgvTask.DataSource = _dt;
  288. }
  289. else
  290. {
  291. if (_dt != null) _dt.Clear();
  292. }
  293. }
  294. private void skBtnCancelNoTask_Click(object sender, EventArgs e)
  295. {
  296. //string task_id = _currentDr["TASK_NO"].ToString();
  297. //string msg = string.Empty;
  298. //TaskWorkflow.Text_out(out msg);
  299. // LogHelper.Sys_Log.WriteLog("开始调用函数分配货位");
  300. //string posIdTo = TaskWorkflow.WareCell_Assign2(task_id, out msg);
  301. //var srmlist = TaskWorkflow.QuerySrmList(Convert.ToInt32(task_id),out msg);
  302. //LogHelper.Sys_Log.WriteLog(string.Format("分配货位调用函数结束,任务[{0}]", task_id));
  303. //MessageBox.Show(msg);
  304. //int success = 0;
  305. //int failure = 0;
  306. //string error = string.Empty;
  307. //TryCachHelper.TryExecute((db) =>
  308. //{
  309. // var tasks = db.Queryable<WCS_TASK>().Where(v => v.TASK_COMTYPE == 2 && v.TASK_WKSTATUS <= 0 && v.TASK_WHID.Trim().ToUpper() == ClassHelper.WearHosNoLX).ToList();
  310. // foreach (var task in tasks)
  311. // {
  312. // string msg = string.Empty;
  313. // bool result = TaskWorkflow.TaskCancel(task.TASK_NO, out msg);
  314. // if (result)
  315. // {
  316. // success++;
  317. // }
  318. // else
  319. // {
  320. // failure--;
  321. // error = error + msg + "/n";
  322. // }
  323. // }
  324. //});
  325. //MessageBox.Show(string.Format("取消任务成功[{0}]条,失败[{1}]条.失败原因:[{2}]", success, failure, error));
  326. //string result = TryCachHelper.TryTranExecute((db) =>
  327. //{
  328. // var task = db.Queryable<WCS_TASK>().First(v => v.TASK_NO == 25080);
  329. // db.Updateable<WCS_TASK>()
  330. // .UpdateColumns(it => new WCS_TASK()
  331. // {
  332. // TASK_WKSTATUS = (int)WkStatus.堆垛机执行,
  333. // TASK_POSIDNEXT = "1020",
  334. // TASK_EDITUSERNO = "WCS",
  335. // TASK_EDITDATETIME = DateTime.Now
  336. // })
  337. // .Where(it => it.TASK_NO == task.TASK_NO).ExecuteCommand();
  338. // //string msg = string.Format("任务已下发给输送机[{0}]执行,起点地址[{1}]目标地址[{2}]", converywrite.ConveyorNo, converywrite.Goodsstart, converywrite.Goodsend);
  339. // //CommonData.AddWCS_TASK_DTL(db, task.TASK_ID, task.TASK_NO, task.TASK_POSIDCUR, converywrite.Goodsend.ToString(), msg);
  340. // string msg = string.Format("任务已下发给输送机[0]执行,起点地址[1]目标地址[2]");
  341. // var task_dtl = new WCS_TASK_DTL();
  342. // task_dtl.ID = Guid.NewGuid().ToString();
  343. // task_dtl.PARENTID = "25080";
  344. // task_dtl.TASKNO = "25080";
  345. // task_dtl.POSIDCUR = "1020";
  346. // task_dtl.POSIDNEXT = "1020";
  347. // task_dtl.DESCRIPTION = msg;
  348. // task_dtl.EXECUTEDATE = DateTime.Now;
  349. // db.Insertable(task_dtl).ExecuteCommand();
  350. //});
  351. }
  352. private void btnClear_Click(object sender, EventArgs e)
  353. {
  354. txtBarCode.Text = string.Empty;
  355. txtEnd.Text = string.Empty;
  356. txtSrmNo.Text = string.Empty;
  357. txtTaskNo.Text = string.Empty;
  358. txtMatNo.Text = string.Empty;
  359. }
  360. private void sknBtnPRIORITY_Click(object sender, EventArgs e)
  361. {
  362. if (_currentDr == null)
  363. {
  364. MessageBox.Show("请选择要调整优先级的任务。");
  365. }
  366. else
  367. {
  368. string taskno = _currentDr["TASK_NO"].ToString();
  369. int priority = Convert.ToInt32(_currentDr["TASK_PRIORITY"].ToString());
  370. var form_Priority = new Form_PRIORITY(taskno, priority);
  371. form_Priority.ShowDialog();
  372. Bind();
  373. }
  374. }
  375. }
  376. }