frmBeltScaleActualinfo.cs 31 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759
  1. using com.hnshituo.core.webapp.vo;
  2. using Common;
  3. using Common.vo.pb;
  4. using Infragistics.Win;
  5. using Infragistics.Win.UltraWinEditors;
  6. using Infragistics.Win.UltraWinGrid;
  7. using JC_MeasuringSystem;
  8. using MeterModuleLibrary;
  9. using MeterPlugInLibrary;
  10. using Microsoft.VisualBasic;
  11. using System;
  12. using System.Collections.Generic;
  13. using System.Data;
  14. using System.Drawing;
  15. using System.Linq;
  16. using System.Net;
  17. using System.Threading;
  18. using System.Windows.Forms;
  19. namespace BeltScaleSystem
  20. {
  21. public partial class frmBeltScaleActualinfo : Form
  22. {
  23. public frmBeltScaleActualinfo()
  24. {
  25. InitializeComponent();
  26. }
  27. //菜单栏事件
  28. private void ultraToolbarsManager1_ToolClick(object sender, Infragistics.Win.UltraWinToolbars.ToolClickEventArgs e)
  29. {
  30. switch (e.Tool.Key)
  31. {
  32. case "查询":
  33. QueryScaleActualinfo();
  34. break;
  35. case "新增":
  36. AddScalePrediction();
  37. break;
  38. case "修改":
  39. UpdateScalePrediction();
  40. break;
  41. case "导出":
  42. ExporterScaleActual();
  43. break;
  44. case "删除":
  45. DeleteAndRecoverScaleActual(1);
  46. break;
  47. case "还原":
  48. DeleteAndRecoverScaleActual(2);
  49. break;
  50. case "审核":
  51. ApproveScaleActual(1);
  52. break;
  53. case "取消审核":
  54. ApproveScaleActual(2);
  55. break;
  56. }
  57. }
  58. #region 自定义变量
  59. private CoreAppUser appUser = null;//登陆信息
  60. private string userId = "", userName = ""; //用户ID用户名
  61. private MeterWorkBeltActual BeltActualInfo = new MeterWorkBeltActual();//实绩实体
  62. private MeterWorkBeltActualService BeltActualService = new MeterWorkBeltActualService();
  63. private CoreAppUser userinfo = null;
  64. private DataTable dtMaterial;//物料数据源
  65. private DataTable dtMaterial2;//物料数据源
  66. private DataTable dtcustomerSupplier;//发货单位数据源
  67. private DataTable dtcustomerSupplier2;//发货单位数据源
  68. private DataTable dtPoint;//计量点数据源
  69. MeterBaseMatterInfoService meterBaseMatterInfo = new MeterBaseMatterInfoService();//物料服务
  70. MeterBaseScalePointService monitorService = new MeterBaseScalePointService();
  71. MeterBaseCustomerSupplierService customerSupplierService = new MeterBaseCustomerSupplierService();
  72. #endregion
  73. #region 菜单栏方法
  74. //实绩查询
  75. private void QueryScaleActualinfo() {
  76. try
  77. {
  78. if (DateTime.Compare(dtStartTime.Value, dtEndTime.Value) > 0)
  79. {
  80. MessageBox.Show("开始时间不能大于结束时间");
  81. return;
  82. }
  83. MeterWorkBeltActual actual = new MeterWorkBeltActual();
  84. DataTable dtScaleTable = dataTable2.Clone();
  85. CommonPage<MeterWorkBeltActual> cp = new CommonPage<MeterWorkBeltActual>();
  86. if (checkDate.Checked)
  87. {
  88. cp.startTime = dtStartTime.Text.ToString();
  89. cp.endTime = dtEndTime.Text.ToString();
  90. if (cbDateFlag.SelectedIndex == 0) {
  91. actual.startTime = dtStartTime.Value;//不为空即可
  92. }
  93. if (cbDateFlag.SelectedIndex == 1)
  94. {
  95. actual.endTime = dtStartTime.Value;//不为空即可
  96. }
  97. if (cbDateFlag.SelectedIndex == 2)
  98. {
  99. actual.checkTime = dtStartTime.Value;//审核时间 就是发布时间 不为空即可
  100. }
  101. }
  102. if (cmMatName.Text.ToString() != "全部")
  103. {
  104. actual.newMatName = cmMatName.Text.ToString();
  105. }
  106. if (cbfahuo.Text.ToString() != "全部")
  107. {
  108. actual.newSupplier = cbfahuo.Text.ToString();
  109. }
  110. if (cbshouh.Text.ToString() != "全部")
  111. {
  112. actual.receivingUintName = cbshouh.Text.ToString();
  113. }
  114. if (ckShipNo.Checked) {
  115. if (ShipnoTxt_1.Text.ToString() != null && ShipnoTxt_1.Text.ToString().Trim() != "")//船号
  116. {
  117. actual.shipNo = ShipnoTxt_1.Text.ToString();
  118. }
  119. }
  120. if (cmbState.Text.ToString() != "全部" && cmbState.Text.ToString() != "" )
  121. {
  122. actual.valueFlag = cmbState.Value.ToString();
  123. }
  124. if (!Rbtn_AB.Checked)
  125. {
  126. if (Rbtn_A.Checked) {
  127. actual.scaleName = Rbtn_A.Text.ToString().Substring(0,1);
  128. }
  129. if (Rbtn_B.Checked)
  130. {
  131. actual.scaleName = Rbtn_B.Text.ToString().Substring(0, 1);
  132. }
  133. }
  134. if (moteTxt_1.Text.ToString().ToString().Trim() != "")
  135. {
  136. actual.memo = moteTxt_1.Text.ToString().Trim();
  137. }
  138. cp.param = actual;
  139. RESTfulResult<List<MeterWorkBeltActual>> rms = BeltActualService.doQueryAndMultiple(cp);
  140. if (rms.Succeed)
  141. {
  142. if (rms.Data != null && rms.Data.Count > 0)
  143. {
  144. dtScaleTable = rms.Data.ListToDataTable<MeterWorkBeltActual>();
  145. ClsControlPack.CopyDataToDatatable(ref dtScaleTable, ref dataTable2, true);
  146. ClsControlPack.RefreshAndAutoSize(beltActualGrid);
  147. foreach (UltraGridRow ugr in beltActualGrid.Rows)
  148. {
  149. if (ugr.Cells["valueFlag"].Value.ToString() == "0")
  150. {
  151. ugr.Appearance.BackColor = Color.Red;
  152. }
  153. else if (ugr.Cells["checkFlag"].Value.ToString() == "1")
  154. {
  155. ugr.Appearance.BackColor = Color.YellowGreen;
  156. }
  157. else
  158. {
  159. ugr.Appearance.BackColor = Color.White;
  160. }
  161. }
  162. }
  163. else
  164. {
  165. dtScaleTable.Clear();
  166. ClsControlPack.CopyDataToDatatable(ref dtScaleTable, ref dataTable2, true);
  167. ClsControlPack.RefreshAndAutoSize(beltActualGrid);
  168. }
  169. }
  170. }
  171. catch (Exception ex)
  172. {
  173. MessageBox.Show("实绩查询失败,请联系技术中心!" + ex.Message);
  174. return;
  175. }
  176. }
  177. //实绩新增
  178. private void AddScalePrediction() {
  179. RESTfulResult<string> rm = BeltActualService.doAddWf(findFromInfo(1));
  180. if (rm.Succeed)
  181. {
  182. MessageBox.Show("新增实绩成功");
  183. QueryScaleActualinfo();
  184. return;
  185. }
  186. else
  187. {
  188. MessageBox.Show("新增实绩失败,请联系技术中心!" + rm.Message);
  189. return;
  190. }
  191. }
  192. //实绩修改
  193. private void UpdateScalePrediction()
  194. {
  195. try
  196. {
  197. if (!checkIsNull("from"))
  198. {
  199. MessageBox.Show("请选择需要修改的实绩!");
  200. return;
  201. }
  202. RESTfulResult<string> rm = BeltActualService.doUpdateWf(findFromInfo(2));
  203. if (rm.Succeed)
  204. {
  205. MessageBox.Show("实绩修改成功");
  206. QueryScaleActualinfo();
  207. return;
  208. }
  209. else
  210. {
  211. MessageBox.Show("实绩修改失败,请联系技术中心!" + rm.Message);
  212. return;
  213. }
  214. }
  215. catch (Exception ex)
  216. {
  217. MessageBox.Show("实绩修改异常!" + ex.Message);
  218. return;
  219. }
  220. }
  221. //实绩删除
  222. private void DeleteAndRecoverScaleActual(int no)
  223. {
  224. try
  225. {
  226. List<MeterWorkBeltActual> list = new List<MeterWorkBeltActual>();//实绩实体
  227. string flag = "";
  228. //获取已选择的列
  229. List<UltraGridRow> uGrid = GridHelper.UltraGridGetChooseRows(beltActualGrid, "UNCK");
  230. if (!checkIsNull("check",uGrid.Count)) {
  231. MessageBox.Show("请勾选需要操作的实绩!");
  232. return;
  233. }
  234. if (no == 1)
  235. {
  236. foreach (UltraGridRow ugr in uGrid)
  237. {
  238. flag = ugr.Cells["valueFlag"].Value.ToString();
  239. if (flag == "0")
  240. {
  241. MessageBox.Show("该实绩已是无效,不允许删除!");
  242. return;
  243. }
  244. list.Add(new MeterWorkBeltActual { valueFlag = "0", actualNo = ugr.Cells["actualNo"].Value.ToString() });
  245. }
  246. RESTfulResult<int> rm = BeltActualService.doUpdateFlags(list);
  247. if (rm.Succeed)
  248. {
  249. MessageBox.Show("实绩删除成功");
  250. QueryScaleActualinfo();
  251. return;
  252. }
  253. else
  254. {
  255. MessageBox.Show("实绩删除失败,请联系技术中心!" + rm.Message);
  256. return;
  257. }
  258. }
  259. else if(no==2){
  260. foreach (UltraGridRow ugr in uGrid)
  261. {
  262. flag = ugr.Cells["valueFlag"].Value.ToString();
  263. if (flag != "0")
  264. {
  265. MessageBox.Show("不是无效的实绩不允许还原!");
  266. return;
  267. }
  268. list.Add(new MeterWorkBeltActual { valueFlag = "1", actualNo = ugr.Cells["actualNo"].Value.ToString() });
  269. }
  270. RESTfulResult<int> rm = BeltActualService.doUpdateFlags(list);
  271. if (rm.Succeed)
  272. {
  273. MessageBox.Show("实绩还原成功");
  274. QueryScaleActualinfo();
  275. return;
  276. }
  277. else
  278. {
  279. MessageBox.Show("实绩还原失败,请联系技术中心!" + rm.Message);
  280. return;
  281. }
  282. }
  283. }
  284. catch (Exception ex)
  285. {
  286. MessageBox.Show("实绩删除还原异常!" + ex.Message);
  287. return;
  288. }
  289. }
  290. //审核
  291. private void ApproveScaleActual(int no) {
  292. try
  293. {
  294. List<MeterWorkBeltActual> list = new List<MeterWorkBeltActual>();//实绩实体
  295. string flag = "";
  296. //获取已选择的列
  297. List<UltraGridRow> uGrid = GridHelper.UltraGridGetChooseRows(beltActualGrid, "UNCK");
  298. if (!checkIsNull("check", uGrid.Count))
  299. {
  300. MessageBox.Show("请勾选需要操作的实绩!");
  301. return;
  302. }
  303. if (no == 1) {
  304. foreach (UltraGridRow ugr in uGrid)
  305. {
  306. flag = ugr.Cells["checkFlag"].Value.ToString();
  307. if (flag != "0")
  308. {
  309. MessageBox.Show("不是未审核的实绩不允许审核!");
  310. return;
  311. }
  312. list.Add(new MeterWorkBeltActual { checkFlag = "1", actualNo = ugr.Cells["actualNo"].Value.ToString() });
  313. }
  314. RESTfulResult<int> rm = BeltActualService.doUpdateCheckFlags(list);
  315. if (rm.Succeed)
  316. {
  317. MessageBox.Show("审核成功!");
  318. QueryScaleActualinfo();
  319. return;
  320. }
  321. else
  322. {
  323. MessageBox.Show("审核失败,请联系技术中心!" + rm.Message);
  324. return;
  325. }
  326. } else if (no==2) {
  327. foreach (UltraGridRow ugr in uGrid)
  328. {
  329. flag = ugr.Cells["checkFlag"].Value.ToString();
  330. if (flag != "1")
  331. {
  332. MessageBox.Show("不是审核的实绩不允许取消审核!");
  333. return;
  334. }
  335. list.Add(new MeterWorkBeltActual { checkFlag = "0", actualNo = ugr.Cells["actualNo"].Value.ToString() });
  336. }
  337. RESTfulResult<int> rm = BeltActualService.doUpdateCheckFlags(list);
  338. if (rm.Succeed)
  339. {
  340. MessageBox.Show("取消审核成功!");
  341. QueryScaleActualinfo();
  342. return;
  343. }
  344. else
  345. {
  346. MessageBox.Show("取消审核失败,请联系技术中心!" + rm.Message);
  347. return;
  348. }
  349. }
  350. }
  351. catch (Exception ex)
  352. {
  353. MessageBox.Show("审核异常!" + ex.Message);
  354. return;
  355. }
  356. }
  357. //导出
  358. private void ExporterScaleActual()
  359. {
  360. string str = Interaction.InputBox("请输入要导出的文件名", "提示", "", 100, 100);
  361. string pqath = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
  362. this.ultraGridExcelExporter1.Export(this.beltActualGrid, pqath + "\\" + str + ".xls");
  363. MessageBox.Show("导出成功,请查看桌面!是否有[" + str + ".xls]表格");
  364. }
  365. #endregion
  366. #region 公共方法区
  367. //初始化加载
  368. private void frmBeltScaleActualinfo_Load(object sender, EventArgs e)
  369. {
  370. ScaleName.SelectedIndex = -1;
  371. userinfo = ((ST_MainForm)(this.MdiParent)).AppUser;
  372. //设置grid除了选择列 其余不可编辑
  373. GridHelper.SetExcludeColumnsActive(beltActualGrid.DisplayLayout.Bands[0], "UNCK");
  374. userId = ((ST_MainForm)(this.MdiParent)).UserID;
  375. userName = ((ST_MainForm)(this.MdiParent)).UserName;
  376. appUser = ((ST_MainForm)(this.MdiParent)).AppUser;
  377. dtStartTime.Value = Convert.ToDateTime((DateTime.Now.AddDays(-3).ToString("yyyy-MM-dd") + " 00:00:00"));
  378. dtEndTime.Value = Convert.ToDateTime((DateTime.Now.ToString("yyyy-MM-dd") + " 23:59:59"));
  379. DataTable dt = new DataTable();
  380. dt.Columns.Add("TEXT");
  381. dt.Columns.Add("VALUE");
  382. dt.Rows.Add("-1", "全部");
  383. dt.Rows.Add("0", "无效");
  384. dt.Rows.Add("1", "有效");
  385. valueToCombo(dt, cmbState);
  386. this.cmbState.SelectedIndex = -1;
  387. DataTable dt2 = new DataTable();
  388. dt2.Columns.Add("TEXT");
  389. dt2.Columns.Add("VALUE");
  390. dt2.Rows.Add("0", "开始时间");
  391. dt2.Rows.Add("1", "结束时间");
  392. dt2.Rows.Add("2", "发布时间");
  393. valueToCombo(dt2, cbDateFlag);
  394. this.cbDateFlag.SelectedIndex = 0;
  395. ValueList vlistFlag3 = new ValueList();
  396. vlistFlag3.ValueListItems.Add("0", "无效");
  397. vlistFlag3.ValueListItems.Add("1", "有效");
  398. this.beltActualGrid.DisplayLayout.Bands[0].Columns["valueFlag"].ValueList = vlistFlag3;
  399. ValueList vlistFlag4 = new ValueList();
  400. vlistFlag4.ValueListItems.Add("0", "未审核");
  401. vlistFlag4.ValueListItems.Add("1", "已审核");
  402. this.beltActualGrid.DisplayLayout.Bands[0].Columns["checkFlag"].ValueList = vlistFlag4;
  403. InitFromLoad();//加载物料
  404. InitPntInfo();//加载计量点
  405. QueryScaleActualinfo();
  406. }
  407. //下拉框控件自定义option
  408. public static void valueToCombo(DataTable source, UltraComboEditor cbb)
  409. {
  410. cbb.DataSource = source;
  411. cbb.DisplayMember = "VALUE";
  412. cbb.ValueMember = "TEXT";
  413. }
  414. //下拉框控件自定义option
  415. public static void valueToCombo1(DataTable source, ComboBox cbb)
  416. {
  417. cbb.DataSource = source;
  418. cbb.DisplayMember = "VALUE";
  419. cbb.ValueMember = "TEXT";
  420. }
  421. //控件初始化加载
  422. private void InitFromLoad()
  423. {
  424. try
  425. {
  426. RESTfulResult<List<MeterBaseMatterInfo>> rmx = meterBaseMatterInfo.doQueryListLike(new MeterBaseMatterInfo { validFlag = "1", pageNum = 1, pageSize = 9999 });
  427. RESTfulResult<List<MeterBaseCustomerSupplier>> rmx2 = customerSupplierService.doQuery(new MeterBaseCustomerSupplier { validFlag = "1"});
  428. if (rmx.Succeed && rmx.Data != null && rmx.Data.Count > 0)
  429. {
  430. dtMaterial = rmx.Data.ListToDataTable<MeterBaseMatterInfo>();
  431. dtMaterial2 = dtMaterial.Copy();
  432. }
  433. if (dtMaterial != null)
  434. {
  435. DataRow d1 = dtMaterial.NewRow();
  436. d1["matterName"] = "全部";
  437. d1["matterNo"] = "0";
  438. dtMaterial.Rows.InsertAt(d1, 0);
  439. cmMatName.DataSource = dtMaterial;
  440. cmMatName.DisplayMember = "matterName";
  441. cmMatName.ValueMember = "matterNo";
  442. cmMatname_1.DataSource = dtMaterial2;
  443. cmMatname_1.DisplayMember = "matterName";
  444. cmMatname_1.ValueMember = "matterNo";
  445. cmMatname_1.SelectedIndex = -1;
  446. }
  447. if (rmx2.Succeed && rmx2.Data != null && rmx2.Data.Count > 0)
  448. {
  449. dtcustomerSupplier = rmx2.Data.ListToDataTable<MeterBaseCustomerSupplier>();
  450. }
  451. if (dtcustomerSupplier != null)
  452. {
  453. DataRow d1 = dtcustomerSupplier.NewRow();
  454. d1["customerSupplierName"] = "全部";
  455. d1["customerSupplierNo"] = "0";
  456. dtcustomerSupplier.Rows.InsertAt(d1, 0);
  457. cbfahuo.DataSource = dtcustomerSupplier;
  458. cbfahuo.DisplayMember = "customerSupplierName";
  459. cbfahuo.ValueMember = "customerSupplierNo";
  460. cbfahuo_1.DataSource = dtcustomerSupplier.Copy();
  461. cbfahuo_1.DisplayMember = "customerSupplierName";
  462. cbfahuo_1.ValueMember = "customerSupplierNo";
  463. cbfahuo_1.SelectedIndex = -1;
  464. DataTable dt2 = new DataTable();
  465. dt2.Columns.Add("TEXT");
  466. dt2.Columns.Add("VALUE");
  467. dt2.Rows.Add("0", "西区炼铁");
  468. dt2.Rows.Add("1", "东区炼铁");
  469. valueToCombo1(dt2, cbshouh);
  470. valueToCombo1(dt2.Copy(), cbshouh_1);
  471. this.cbshouh.SelectedIndex = -1;
  472. this.cbshouh_1.SelectedIndex = -1;
  473. }
  474. }
  475. catch (Exception ex)
  476. {
  477. MessageBox.Show("初始化失败 " + ex.ToString());
  478. }
  479. }
  480. //计量点信息
  481. private void InitPntInfo() {
  482. MeterBaseSpotInfoService meterBaseSpotInfoService = new MeterBaseSpotInfoService();//计量点信息
  483. RESTfulResult<List<MeterBaseSpotInfo>> spo = meterBaseSpotInfoService.doQueryWf(new MeterBaseSpotInfo { validFlag = "1", spotTypeNo = "001002005" });
  484. if (spo.Succeed && spo.Data != null && spo.Data.Count > 0)
  485. {
  486. dtPoint = spo.Data.ListToDataTable<MeterBaseSpotInfo>();
  487. }
  488. if (dtPoint != null)
  489. {
  490. cbPntName.DataSource = dtPoint;
  491. cbPntName.DisplayMember = "baseSpotName";
  492. cbPntName.ValueMember = "baseSpotNo";
  493. }
  494. cbPntName.SelectedIndex = -1;
  495. }
  496. private bool checkIsNull(string str="", int count=0) {
  497. if (str == "from") {
  498. if (actualNoTxt.Text.ToString().Trim() == "")
  499. {
  500. return false;
  501. }
  502. } else if (str =="check") {
  503. if (count<1)
  504. {
  505. return false;
  506. }
  507. }
  508. return true;
  509. }
  510. //日期选择框
  511. private void checkDate_CheckedChanged(object sender, EventArgs e)
  512. {
  513. if (checkDate.Checked)
  514. {
  515. cbDateFlag.Enabled = true;
  516. dtStartTime.Enabled = true;
  517. dtEndTime.Enabled = true;
  518. }
  519. else
  520. {
  521. cbDateFlag.Enabled = false;
  522. dtStartTime.Enabled = false;
  523. dtEndTime.Enabled = false;
  524. }
  525. }
  526. //双击表格事件
  527. private void beltActualGrid_DoubleClickRow(object sender, DoubleClickRowEventArgs e)
  528. {
  529. try
  530. {
  531. if (beltActualGrid.ActiveRow == null)
  532. {
  533. return;
  534. }
  535. MeterWorkBeltActual beltActual = new MeterWorkBeltActual();//实绩实体
  536. //界面赋值
  537. UltraGridRow ugr = beltActualGrid.ActiveRow;
  538. if (ugr != null)
  539. {
  540. beltActual.actualNo = ugr.Cells["actualNo"].Text.Trim(); //实绩编号
  541. //beltActual.baseSpotNo = ugr.Cells["baseSpotNo"].Text.ToString();//计量点编码
  542. beltActual.baseSpotName = ugr.Cells["baseSpotName"].Text.ToString();//计量点
  543. beltActual.scaleName = ugr.Cells["scaleName"].Text.ToString();//AB秤
  544. beltActual.createManName = ugr.Cells["createManName"].Text.ToString();//计量员
  545. beltActual.overstock = ugr.Cells["overstock"].Text.ToString()==""? DateTime.Now: Convert.ToDateTime(ugr.Cells["overstock"].Text.ToString());//压港时间
  546. beltActual.startTime = ugr.Cells["startTime"].Text.ToString()==""? DateTime.Now: Convert.ToDateTime(ugr.Cells["startTime"].Text.ToString());//开始时间
  547. beltActual.endTime = ugr.Cells["endTime"].Text.ToString()==""? DateTime.Now: Convert.ToDateTime(ugr.Cells["endTime"].Text.ToString());//结束时间
  548. beltActual.forwardingWeight = ugr.Cells["forwardingWeight"].Text.Trim() == "" ? 0 : Convert.ToDouble(ugr.Cells["forwardingWeight"].Text.Trim());//报港数量
  549. beltActual.startWeight = ugr.Cells["startWeight"].Text.Trim() == "" ? 0 : Convert.ToDouble(ugr.Cells["startWeight"].Text.Trim());//开始重量
  550. beltActual.endWeight = ugr.Cells["endWeight"].Text.Trim() == "" ? 0 : Convert.ToDouble(ugr.Cells["endWeight"].Text.Trim());//结束重量
  551. beltActual.netWeight = ugr.Cells["netWeight"].Text.Trim() == "" ? 0 : Convert.ToDouble(ugr.Cells["netWeight"].Text.Trim());//结束重量
  552. //beltActual.unloadSite = ugr.Cells["unloadSite"].Text.Trim();//卸货地点
  553. //beltActual.unloadWharf = ugr.Cells["unloadWharf"].Text.Trim();//卸货码头
  554. beltActual.shipNo = ugr.Cells["shipNo"].Text.Trim();//船号
  555. beltActual.newSupplier = ugr.Cells["newSupplier"].Text.Trim();//发货单位
  556. beltActual.receivingUintName = ugr.Cells["receivingUintName"].Text.Trim(); //收货单位
  557. //beltActual.forwardingUnitNo = ugr.Cells["forwardingUnitNo"].Text.Trim();//发货单位编号
  558. //beltActual.receivingUintNo = ugr.Cells["receivingUintNo"].Text.Trim();//收货单位编号
  559. beltActual.newMatName = ugr.Cells["newMatName"].Text.Trim(); //物料名称
  560. //beltActual.productNo = ugr.Cells["productNo"].Text.Trim();//物料编号
  561. autoAutoFill(beltActual);
  562. }
  563. }
  564. catch (Exception ex)
  565. {
  566. MessageBox.Show("beltActualGrid_DoubleClickRow方法处理异常:" + ex);
  567. }
  568. }
  569. //船号选择框
  570. private void ckShipNo_CheckedChanged(object sender, EventArgs e)
  571. {
  572. if (ckShipNo.Checked)
  573. {
  574. ShipnoTxt_1.Enabled = true;
  575. }
  576. else
  577. {
  578. ShipnoTxt_1.Enabled = false;
  579. }
  580. }
  581. //填充窗口表单
  582. private void autoAutoFill(MeterWorkBeltActual beltActual)
  583. {
  584. if (beltActual == null || string.IsNullOrEmpty(beltActual.actualNo))
  585. {
  586. return;
  587. }
  588. cbPntName.Text = beltActual.baseSpotName;//计量点
  589. cbfahuo_1.Text = beltActual.newSupplier;//发货单位
  590. cbshouh_1.Text = beltActual.receivingUintName;//收货单位
  591. cmMatname_1.Text = beltActual.newMatName;//物料名称
  592. shipnoTxt.Text = beltActual.shipNo;//船号
  593. actualNoTxt.Text = beltActual.actualNo;//实绩编号
  594. startWeightTxt.Text = beltActual.startWeight.ToString();//开始重量
  595. endWeight_Txt.Text = beltActual.endWeight.ToString();//结束重量
  596. netWeightTxt.Text = beltActual.netWeight.ToString();//净重
  597. meterStaffTxt.Text = beltActual.createManName;//计量员
  598. ScaleName.Text = beltActual.scaleName;//ab秤
  599. requiteWeightTxt.Text = beltActual.forwardingWeight.ToString();//发运重量
  600. startTime.Value = (DateTime)beltActual.startTime;//开始时间
  601. endTime.Value = (DateTime)beltActual.endTime;//开始时间
  602. moteTxt.Text = beltActual.memo;
  603. }
  604. #region 单选按钮 和文本框控制
  605. private void Rbtn_AB_CheckedChanged(object sender, EventArgs e)
  606. {
  607. if (Rbtn_AB.Checked) {
  608. Rbtn_A.Checked = false;
  609. Rbtn_B.Checked = false;
  610. }
  611. }
  612. private void Rbtn_A_CheckedChanged(object sender, EventArgs e)
  613. {
  614. if (Rbtn_A.Checked)
  615. {
  616. Rbtn_AB.Checked = false;
  617. Rbtn_B.Checked = false;
  618. }
  619. }
  620. private void radioButton3_CheckedChanged(object sender, EventArgs e)
  621. {
  622. if (Rbtn_B.Checked)
  623. {
  624. Rbtn_AB.Checked = false;
  625. Rbtn_A.Checked = false;
  626. }
  627. }
  628. private void startWeightTxt_KeyPress(object sender, KeyPressEventArgs e)
  629. {
  630. int keyValue = (int)e.KeyChar;
  631. if ((keyValue >= 48 && keyValue <= 57) || keyValue == 8 || keyValue == 46)
  632. {
  633. if (sender != null && sender is TextBox && keyValue == 46)
  634. {
  635. if (((TextBox)sender).Text.IndexOf(".") >= 0)
  636. e.Handled = true;
  637. else
  638. e.Handled = false;
  639. }
  640. else
  641. e.Handled = false;
  642. }
  643. else
  644. e.Handled = true;
  645. }
  646. private void endWeight_Txt_KeyPress(object sender, KeyPressEventArgs e)
  647. {
  648. int keyValue = (int)e.KeyChar;
  649. if ((keyValue >= 48 && keyValue <= 57) || keyValue == 8 || keyValue == 46)
  650. {
  651. if (sender != null && sender is TextBox && keyValue == 46)
  652. {
  653. if (((TextBox)sender).Text.IndexOf(".") >= 0)
  654. e.Handled = true;
  655. else
  656. e.Handled = false;
  657. }
  658. else
  659. e.Handled = false;
  660. }
  661. else
  662. e.Handled = true;
  663. }
  664. private void netWeightTxt_KeyPress(object sender, KeyPressEventArgs e)
  665. {
  666. int keyValue = (int)e.KeyChar;
  667. if ((keyValue >= 48 && keyValue <= 57) || keyValue == 8 || keyValue == 46)
  668. {
  669. if (sender != null && sender is TextBox && keyValue == 46)
  670. {
  671. if (((TextBox)sender).Text.IndexOf(".") >= 0)
  672. e.Handled = true;
  673. else
  674. e.Handled = false;
  675. }
  676. else
  677. e.Handled = false;
  678. }
  679. else
  680. e.Handled = true;
  681. }
  682. private void beltActualGrid_CellChange(object sender, CellEventArgs e)
  683. {
  684. }
  685. #endregion
  686. //获取表单数据
  687. private MeterWorkBeltActual findFromInfo(int no)
  688. {
  689. MeterWorkBeltActual beltActual = new MeterWorkBeltActual();
  690. beltActual.baseSpotName= cbPntName.Text;//计量点
  691. beltActual.newSupplier = cbfahuo_1.Text;//发货单位
  692. beltActual.forwardingUnitNo = cbfahuo_1.SelectedValue.ToString();//发货单位编码
  693. beltActual.receivingUintName=cbshouh_1.Text;//收货单位
  694. beltActual.receivingUintNo=cbshouh_1.SelectedValue.ToString();//收货单位编码
  695. beltActual.newMatName = cmMatname_1.Text;//物料名称
  696. beltActual.shipNo= shipnoTxt.Text;//船号
  697. beltActual.actualNo= actualNoTxt.Text;//实绩编号
  698. beltActual.startWeight= Convert.ToDouble(startWeightTxt.Text.Trim());//开始重量
  699. beltActual.endWeight = Convert.ToDouble(endWeight_Txt.Text.Trim());//结束重量
  700. beltActual.netWeight = Convert.ToDouble(netWeightTxt.Text.Trim());//净重重量
  701. beltActual.createManName=meterStaffTxt.Text;//计量员
  702. beltActual.scaleName=ScaleName.Text;//ab秤
  703. beltActual.forwardingWeight= Convert.ToDouble(requiteWeightTxt.Text);//发运重量
  704. beltActual.startTime=startTime.Value;//开始时间
  705. beltActual.endTime=endTime.Value;//结束时间
  706. beltActual.memo=moteTxt.Text;
  707. if (no == 1)
  708. {
  709. beltActual.createManNo = userId;
  710. beltActual.createManName = userName;
  711. beltActual.meterClass = userinfo.userClass;//班级班组
  712. beltActual.meterGroup = userinfo.userGroup;
  713. }
  714. else {
  715. beltActual.updateManNo = userId;
  716. beltActual.updateManName = userName;
  717. }
  718. return beltActual;
  719. }
  720. #endregion
  721. }
  722. }