frmTempImportData.cs 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. using ComponentFactory.Krypton.Navigator;
  2. using ComponentFactory.Krypton.Toolkit;
  3. using ComponentFactory.Krypton.Workspace;
  4. using NXWMS.Client.Code.Excel;
  5. using NXWMS.Client.Code.Extends;
  6. using NXWMS.Client.Code.Serialize;
  7. using NXWMS.Client.Model.AppModels.Condition.Common;
  8. using NXWMS.Client.Model.AppModels.Condition.Rule;
  9. using NXWMS.Client.Model.AppModels.Result;
  10. using NXWMS.Client.Model.AppModels.Result.Common;
  11. using NXWMS.Client.Model.AppModels.Result.Rule;
  12. using NXWMS.Client.Model.CoreModels;
  13. using NXWMS.Client.String.Enums;
  14. using NXWMS.Commons;
  15. using NXWMS.Services;
  16. using System;
  17. using System.Collections.Generic;
  18. using System.ComponentModel;
  19. using System.Data;
  20. using System.Drawing;
  21. using System.IO;
  22. using System.Linq;
  23. using System.Text;
  24. using System.Windows.Forms;
  25. using System.Threading;
  26. namespace NXWMS.Forms.Rule
  27. {
  28. public partial class frmTempImportData : Form
  29. {
  30. private string _TemplateCode;
  31. private string _BatchNo;
  32. private int _selectIndex;
  33. private int _selectId;
  34. private string _selectNo;
  35. private int _pageSize;
  36. private int _pageIndex;
  37. private int _totalCount;
  38. private bool _IsCheck;
  39. /// <summary>
  40. /// 模版列表
  41. /// </summary>
  42. private List<ClientFieldOrderResult> _clientFieldOrderTemplateList;
  43. /// <summary>
  44. /// 临时数据列表
  45. /// </summary>
  46. private List<ClientFieldOrderResult> _clientFieldOrderBatchList;
  47. /// <summary>
  48. /// 导入数据列表
  49. /// </summary>
  50. private List<ClientFieldOrderResult> _clientFieldOrderDataList;
  51. /// <summary>
  52. /// 导入模版选择列表
  53. /// </summary>
  54. private List<ImportTemplateResult> _importTemplateSelectList;
  55. /// <summary>
  56. /// 导入模版列表
  57. /// </summary>
  58. private List<ImportTemplateDetailResult> _importTemplateList;
  59. /// <summary>
  60. /// 界面功能类型
  61. /// </summary>
  62. public EnumFunctionType _FunctionType;
  63. /// <summary>
  64. /// 功能类型
  65. /// </summary>
  66. public enum EnumFunctionType
  67. {
  68. Import,
  69. Search,
  70. }
  71. public frmTempImportData(string templateCode = "", string batchNo = "")
  72. {
  73. InitializeComponent();
  74. _TemplateCode = templateCode;
  75. _BatchNo = batchNo;
  76. InitData();
  77. InitControl();
  78. }
  79. /// <summary>
  80. /// 控件初始化
  81. /// </summary>
  82. private void InitControl()
  83. {
  84. CheckForIllegalCrossThreadCalls = false;
  85. dataGridViewBatch.BuildDataGridView(CommonUtil.GetFieldOrderDic(_clientFieldOrderBatchList), false);
  86. dataGridViewFile.BuildDataGridView(CommonUtil.GetFieldOrderDic(_clientFieldOrderDataList), false, false);
  87. dataGridViewTemplate.BuildDataGridView(CommonUtil.GetFieldOrderDic(_clientFieldOrderTemplateList), false, false);
  88. this.SetFormSizeLocation();
  89. //功能类型
  90. switch (_FunctionType)
  91. {
  92. case EnumFunctionType.Import:
  93. txtSearchBatchNo.Text = _BatchNo;
  94. cmbSearchImport.SelectedValue = _TemplateCode;
  95. cmbSearchImport.Enabled = false;
  96. cmbSearchStatus.SelectedValue = (int)TempImportStatus.Init;
  97. txtSearchBatchNo.Text = _TemplateCode.ToUpper().Replace("FRM", "").First()
  98. + DateTime.Now.ToString("yyyyMMDDHHmmss");
  99. var loadfrm = new frmLoading();
  100. loadfrm.Show();
  101. var message = loadfrm.EventCalExec(LoadSearchTemplate, _pageIndex, _pageSize);
  102. if (!string.IsNullOrWhiteSpace(message))
  103. {
  104. KryptonMessageBox.Show($"查询失败!\r\n{message}", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
  105. }
  106. break;
  107. case EnumFunctionType.Search:
  108. break;
  109. }
  110. _pageIndex = 1;
  111. _pageSize = 20;
  112. }
  113. /// <summary>
  114. /// 数据初始化
  115. /// </summary>
  116. private void InitData()
  117. {
  118. //批次组
  119. _clientFieldOrderBatchList = new List<ClientFieldOrderResult>();
  120. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "BATCH_NO", FieldDesc = "批次单号" });
  121. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "IMPORT_DATA_NUMBER", FieldDesc = "导入行数" });
  122. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "ImportStatusName", FieldDesc = "导入状态" });
  123. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "LAST_CHECK_TIME", FieldDesc = "最后检查时间" });
  124. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "LAST_CHECK_MESSAGE", FieldDesc = "最后检查消息" });
  125. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "LAST_IMPORT_TIME", FieldDesc = "最后导入时间" });
  126. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "LAST_IMPORT_MESSAGE", FieldDesc = "最后导入消息" });
  127. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "ImportTemplateCode", FieldDesc = "导入模版编码" });
  128. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "ImportTemplateName", FieldDesc = "导入模版名称" });
  129. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "ImportModeName", FieldDesc = "导入方式" });
  130. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "TargetObjectTypeName", FieldDesc = "目标对象编码" });
  131. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "TargetObjectCode", FieldDesc = "目标对象名称" });
  132. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "TargetObjectName", FieldDesc = "目标对象类型" });
  133. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "IMPORT_DATA_JSON", FieldDesc = "导入数据JSON" });
  134. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "DESCRIBE", FieldDesc = "描述" });
  135. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "CreateName", FieldDesc = "创建人" });
  136. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "CREATE_TIME", FieldDesc = "创建时间" });
  137. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "UpdateName", FieldDesc = "更新人" });
  138. _clientFieldOrderBatchList.Add(new ClientFieldOrderResult { FieldName = "UPDATE_TIME", FieldDesc = "更新时间" });
  139. //Excel数据
  140. _clientFieldOrderDataList = new List<ClientFieldOrderResult>();
  141. _clientFieldOrderDataList.Add(new ClientFieldOrderResult { FieldName = "Data", FieldDesc = "Excel数据" });
  142. //模版数据
  143. _clientFieldOrderTemplateList = new List<ClientFieldOrderResult>();
  144. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "IMPORT_TEMPLATE_CODE", FieldDesc = "导入模版编号" });
  145. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "IMPORT_TEMPLATE_NAME", FieldDesc = "导入模版名称" });
  146. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "ImportModeName", FieldDesc = "导入方式" });
  147. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TARGET_OBJECT_CODE", FieldDesc = "源对象编码" });
  148. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TARGET_OBJECT_NAME", FieldDesc = "源对象名称" });
  149. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TargetObjectType", FieldDesc = "源对象类型" });
  150. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "SOURCE_CODE", FieldDesc = "源结构编码" });
  151. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "SOURCE_NAME", FieldDesc = "源结构名称" });
  152. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "SourceTypeName", FieldDesc = "源结构类型" });
  153. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "SourceLength", FieldDesc = "源结构长度" });
  154. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "SourceRequiredFlagName", FieldDesc = "源结构必填标识" });
  155. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TARGET_CODE", FieldDesc = "目标结构编码" });
  156. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TARGET_NAME", FieldDesc = "目标结构名称" });
  157. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TargetTypeName", FieldDesc = "目标结构类型" });
  158. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TargetLength", FieldDesc = "目标结构长度" });
  159. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TargetRequiredFlagName", FieldDesc = "目标结构必填标识" });
  160. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TargetRelationTypeName", FieldDesc = "目标关联类型编码" });
  161. _clientFieldOrderTemplateList.Add(new ClientFieldOrderResult { FieldName = "TargetRelationContent", FieldDesc = "目标关联类型内容" });
  162. var importTemplateResult = RuleServices.importTemplateService.GetList(new ImportTemplateSearchCondition { IsUsed = true, ItemSQL = "IMPORT_TEMPLATE_CODE,IMPORT_TEMPLATE_NAME" });
  163. if (importTemplateResult.Status == OperateStatus.Success)
  164. {
  165. _importTemplateSelectList = importTemplateResult.Data.RowData.ToList();
  166. }
  167. var fieldList = new List<FieldValue>().Add<FieldValue>(new FieldValue { Code = "", Name = "全部" });
  168. cmbSearchImport.DataSource = fieldList.GetFieldValueIdList(_importTemplateSelectList, "IMPORT_TEMPLATE_CODE", "IMPORT_TEMPLATE_NAME");
  169. cmbSearchImport.DisplayMember = "Name";
  170. cmbSearchImport.ValueMember = "Id";
  171. cmbSearchImport.SelectedIndex = -1;
  172. fieldList = new List<FieldValue>().Add<FieldValue>(new FieldValue { Id = "", Name = "全部" });
  173. cmbSearchStatus.DataSource = new List<FieldValue>().GetFieldValueIdList<TempImportStatus>();
  174. cmbSearchStatus.DisplayMember = "Name";
  175. cmbSearchStatus.ValueMember = "Id";
  176. cmbSearchStatus.SelectedIndex = -1;
  177. }
  178. private void btnSelect_Click(object sender, EventArgs e)
  179. {
  180. OpenFileDialog openFileDialog = new OpenFileDialog();
  181. openFileDialog.Filter = "Files|*.xls;*.xlsx";
  182. openFileDialog.InitialDirectory = Environment.GetFolderPath(Environment.SpecialFolder.Desktop);
  183. if (openFileDialog.ShowDialog() == DialogResult.OK)
  184. {
  185. var filePath = openFileDialog.FileName;
  186. var loadfrm = new frmLoading();
  187. loadfrm._message = "正在加载文件数据,请耐心等待......";
  188. loadfrm.Show();
  189. Thread.Sleep(500);
  190. Application.DoEvents();
  191. var message = loadfrm.EventCalExec(LoadFileData, dataGridViewFile, filePath);
  192. if (!string.IsNullOrWhiteSpace(message))
  193. {
  194. KryptonMessageBox.Show($"加载失败!\r\n{message}", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
  195. return;
  196. }
  197. txtFilePath.Text = filePath;
  198. dataGridViewFile.Columns.Add("$INFO", "执行结果");
  199. dataGridViewFile.Columns["$INFO"].ReadOnly = true;
  200. dataGridViewFile.Columns["$INFO"].DisplayIndex = 0;
  201. navigatorTool.SelectedPage = pagImportFile;
  202. }
  203. }
  204. /// <summary>
  205. /// 加载文件数据
  206. /// </summary>
  207. /// <param name="dataGridView"></param>
  208. /// <param name="filePath"></param>
  209. /// <returns></returns>
  210. private string LoadFileData(DataGridView dataGridView, string filePath)
  211. {
  212. dataGridView.Columns.Clear();
  213. dataGridView.DataSource = SDExcelHelper.GetDataTable(filePath);
  214. return string.Empty;
  215. }
  216. private void btnSearch_Click(object sender, EventArgs e)
  217. {
  218. _pageIndex = 1;
  219. var loadfrm = new frmLoading();
  220. loadfrm.Show();
  221. var message = loadfrm.EventCalExec(LoadSearchBatch, this.pageTool.PageIndex, this.pageTool.PageSize);
  222. pageTool.DataCount = _totalCount;
  223. if (!string.IsNullOrWhiteSpace(message))
  224. {
  225. KryptonMessageBox.Show($"查询失败!\r\n{message}", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
  226. }
  227. }
  228. private string LoadSearchBatch(int pageIndex, int pageSize)
  229. {
  230. var result = TempServices.tempImportService.GetList(new TempImportSearchCondition
  231. {
  232. OperationUserId = AppConfig.UserLoginResult.UserInfo.UserId,
  233. BatchNo = txtSearchBatchNo.Text,
  234. ImportStatus = cmbSearchImport.SelectedValue.GetObjectToInt(),
  235. PageIndex = pageIndex,
  236. PageSize = pageSize
  237. });
  238. if (result.Status == OperateStatus.Success)
  239. {
  240. _totalCount = result.Data.TotalCount;
  241. _pageIndex = pageIndex;
  242. _pageSize = pageSize;
  243. if (result.Data.RowData.Any())
  244. {
  245. dataGridViewBatch.Columns.Clear();
  246. dataGridViewBatch.DataSource = result.Data.RowData.ToList();
  247. dataGridViewBatch.BuildDataGridView(CommonUtil.GetFieldOrderDic(_clientFieldOrderBatchList));
  248. }
  249. else
  250. {
  251. if (dataGridViewBatch.DataSource != null)
  252. {
  253. dataGridViewBatch.DataSource = new List<TempImportResult>();
  254. }
  255. dataGridViewBatch.BuildDataGridView(CommonUtil.GetFieldOrderDic(_clientFieldOrderBatchList), false);
  256. }
  257. return string.Empty;
  258. }
  259. else
  260. {
  261. return result.Message;
  262. }
  263. }
  264. private string LoadSearchTemplate(int pageIndex, int pageSize)
  265. {
  266. var result = RuleServices.importTemplateService.GetDetailList(new ImportTemplateDetailSearchCondition { IsUsed = true, TemplateCode = _TemplateCode });
  267. if (result.Status == OperateStatus.Success)
  268. {
  269. _importTemplateList = result.Data.ToList();
  270. if (result.Data.Any())
  271. {
  272. dataGridViewTemplate.Columns.Clear();
  273. dataGridViewTemplate.DataSource = result.Data;
  274. dataGridViewTemplate.BuildDataGridView(CommonUtil.GetFieldOrderDic(_clientFieldOrderTemplateList));
  275. }
  276. else
  277. {
  278. if (dataGridViewTemplate.DataSource != null)
  279. {
  280. dataGridViewTemplate.DataSource = new List<ImportTemplateResult>();
  281. }
  282. dataGridViewTemplate.BuildDataGridView(CommonUtil.GetFieldOrderDic(_clientFieldOrderTemplateList), false);
  283. }
  284. navigatorTool.SelectedPage = pagTemplate;
  285. return string.Empty;
  286. }
  287. else
  288. {
  289. return result.Message;
  290. }
  291. }
  292. private void btnCheck_Click(object sender, EventArgs e)
  293. {
  294. if (dataGridViewFile.Rows.Count > 0)
  295. {
  296. txtSearchBatchNo.Enabled = false;
  297. var data = (DataTable)dataGridViewFile.DataSource;
  298. int index = 0;
  299. foreach (DataRow dr in data.Rows)
  300. {
  301. DataRow[] dataTemp = { dr };
  302. var detail = new TempImportDetailCondition
  303. {
  304. DataJson = dataTemp.CopyToDataTable(),
  305. BatchNo = txtSearchBatchNo.Text,
  306. ImportTemplateId = _importTemplateList.FirstOrDefault().IMPORT_TEMPLATE_ID,
  307. TempImportExecType = TempImportExecType.Check,
  308. };
  309. //添入临时表
  310. var addResult = TempServices.tempImportService.Add(new TempImportCondition
  311. {
  312. OperationUserId = AppConfig.UserLoginResult.UserInfo.UserId,
  313. DetailList = new List<TempImportDetailCondition>().Add<TempImportDetailCondition>(detail),
  314. });
  315. if (addResult.Status == OperateStatus.Success)
  316. {
  317. dataGridViewFile.Rows[index].Cells["$INFO"].Value = "导入成功!开始执行检查...";
  318. //检查数据
  319. var checkResult = TempServices.tempImportService.Exec(new TempImportExecCondition
  320. {
  321. OperationUserId = AppConfig.UserLoginResult.UserInfo.UserId,
  322. BatchNo = txtSearchBatchNo.Text,
  323. TempImportExecType = TempImportExecType.Check,
  324. });
  325. Application.DoEvents();
  326. //检查成功
  327. if (checkResult.Status == OperateStatus.Success)
  328. {
  329. dataGridViewFile.Rows[index].Cells["$INFO"].Value = "检查成功!可进行导入!";
  330. dataGridViewFile.Rows[index].Cells["$INFO"].Style.ForeColor = Color.Green;
  331. }
  332. else
  333. {
  334. dataGridViewFile.Rows[index].Cells["$INFO"].Value = "检查失败!" + checkResult.Message;
  335. dataGridViewFile.Rows[index].Cells["$INFO"].Style.ForeColor = Color.Red;
  336. }
  337. }
  338. else
  339. {
  340. dataGridViewFile.Rows[index].Cells["$INFO"].Value = "出现位置错误!"+addResult.Message;
  341. dataGridViewFile.Rows[index].Cells["$INFO"].Style.ForeColor = Color.Violet;
  342. }
  343. index++;
  344. }
  345. _IsCheck = true;
  346. }
  347. else
  348. {
  349. _IsCheck = false;
  350. KryptonMessageBox.Show($"请选择导入文件!", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
  351. }
  352. }
  353. private void btnImport_Click(object sender, EventArgs e)
  354. {
  355. if (!_IsCheck)
  356. {
  357. KryptonMessageBox.Show($"请先执行检查数据!", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
  358. return;
  359. }
  360. if (dataGridViewFile.Rows.Count > 0)
  361. {
  362. //导入
  363. var checkResult = TempServices.tempImportService.Exec(new TempImportExecCondition
  364. {
  365. OperationUserId = AppConfig.UserLoginResult.UserInfo.UserId,
  366. BatchNo = txtSearchBatchNo.Text,
  367. TempImportExecType = TempImportExecType.Import,
  368. });
  369. Application.DoEvents();
  370. int index = 0;
  371. //检查成功
  372. if (checkResult.Status == OperateStatus.Success)
  373. {
  374. foreach(DataRow item in dataGridViewFile.Rows)
  375. {
  376. dataGridViewFile.Rows[index].Cells["$INFO"].Value = "导入成功!";
  377. dataGridViewFile.Rows[index].Cells["$INFO"].Style.ForeColor = Color.Green;
  378. }
  379. }
  380. else
  381. {
  382. dataGridViewFile.Rows[index].Cells["$INFO"].Value = "导入失败!" + checkResult.Message;
  383. dataGridViewFile.Rows[index].Cells["$INFO"].Style.ForeColor = Color.Red;
  384. }
  385. index++;
  386. _IsCheck = false;
  387. txtSearchBatchNo.Enabled = true;
  388. txtSearchBatchNo.Text = "";
  389. txtFilePath.Text = "";
  390. dataGridViewFile.DataSource = new DataTable();
  391. }
  392. else
  393. {
  394. KryptonMessageBox.Show($"请选择导入文件!", "提示信息", MessageBoxButtons.OK, MessageBoxIcon.Information);
  395. }
  396. }
  397. }
  398. }