QueryViewModel.cs 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605
  1. using AutoMapper;
  2. using BizService;
  3. using Microsoft.Extensions.Logging;
  4. using MiniExcelLibs;
  5. using Model.Dto;
  6. using Model.Entities;
  7. using NetTaste;
  8. using Newtonsoft.Json;
  9. using PLCTool.Pdf;
  10. using Prism.Commands;
  11. using Prism.Mvvm;
  12. using Prism.Services.Dialogs;
  13. using QuestPDF;
  14. using QuestPDF.Fluent;
  15. using QuestPDF.Helpers;
  16. using QuestPDF.Infrastructure;
  17. using QuestPDF.Previewer;
  18. using SqlSugar;
  19. using System;
  20. using System.Collections.Generic;
  21. using System.Collections.ObjectModel;
  22. using System.Linq;
  23. using System.Reflection.Metadata;
  24. using System.Text;
  25. using System.Threading.Tasks;
  26. using System.Windows;
  27. using WPFDevelopers.Controls.Runtimes.Shell32;
  28. using static System.Windows.Forms.VisualStyles.VisualStyleElement.ListView;
  29. namespace PLCTool.ViewModels.BusinessManageViewModel
  30. {
  31. internal class QueryViewModel : BindableBase
  32. {
  33. private readonly IDialogService _dialog;
  34. private readonly IOptionConfigService _optionConfigService;
  35. private readonly IBasicPlcTestSchemeService _basicPlcTestSchemeService;
  36. private readonly IBasicPlcTestSchemeDtlService _basicPlcTestSchemeDtlService;
  37. private readonly IBizTestRecordDtlService _iBizTestRecordDtlService;
  38. private readonly ILogger _logger;
  39. private readonly IMapper _mapper;
  40. private readonly IMenuService _menuService;
  41. private List<SchDtlWithResultModel> allConfigList = new List<SchDtlWithResultModel>();//所有方案
  42. private List<SchDtlWithResultModel> conditionConfig = new List<SchDtlWithResultModel>();//符合条件的方案
  43. private const int PageCount = 1; //每一页显示个数
  44. public QueryViewModel(IDialogService dialog, IMenuService menuService, IOptionConfigService optionConfigService, IBasicPlcTestSchemeService basicPlcTestSchemeService, IBasicPlcTestSchemeDtlService basicPlcTestSchemeDtlService, IBizTestRecordDtlService iBizTestRecordDtlService,IMapper mapper, ILogger logger)
  45. {
  46. _dialog = dialog;
  47. _optionConfigService = optionConfigService;
  48. _basicPlcTestSchemeService = basicPlcTestSchemeService;
  49. _basicPlcTestSchemeDtlService = basicPlcTestSchemeDtlService;
  50. _iBizTestRecordDtlService = iBizTestRecordDtlService;
  51. _logger = logger;
  52. _mapper = mapper;
  53. _menuService = menuService;
  54. QueryCommand = new DelegateCommand<object>(Query);
  55. ResetCommand = new DelegateCommand<object>(Reset);
  56. ExportCommand = new DelegateCommand<string>(Export);
  57. OnLoadCommand = new DelegateCommand(OnLoad);
  58. CheckDetailCommand = new DelegateCommand<object>(CheckDetail);
  59. PdfReportCommand = new DelegateCommand<object>(CreatePdf);
  60. GetConfigOption();
  61. }
  62. #region 私有方法
  63. private InvoiceModel GetReportPLCInfo(int schDtlId)
  64. {
  65. //测试方案明细主键ID
  66. InvoiceModel invoiceModel = new InvoiceModel();
  67. invoiceModel.ReportPLCModels = new List<ReportPLCModel>();
  68. //根据 测试方案明细主键ID 查找测试方案id 及方案名和设备名
  69. var findEntity = _basicPlcTestSchemeDtlService.Find(schDtlId);
  70. var findresult = _mapper.Map<bas_plc_test_scheme_dtl, BasicPlcTestSchemeDtlDto>(findEntity);
  71. if (findresult != null)
  72. {
  73. //根据方案id 在方案表中查找方案名 设备名
  74. int schID = Convert.ToInt32(findresult.SchemeId);
  75. var findSch = _basicPlcTestSchemeService.Find(schID);
  76. if (findSch != null)
  77. {
  78. invoiceModel.SchemeName = findSch.scheme_name;
  79. invoiceModel.DeviceName = findSch.device_name;
  80. }
  81. //此测试方案下的所有测试项
  82. var allResult = allConfigList.FindAll(X => X.SchemeName == findSch.scheme_name);
  83. foreach (var each in allResult)
  84. {
  85. long schDetailId = each.SchemeId;
  86. //根据测试方案明细id查找结果
  87. var recordDetail = _iBizTestRecordDtlService.FindRecordDetailBySchDtlID(schDetailId);
  88. if (recordDetail != null)
  89. { //前置项结果解析
  90. string preconStr = recordDetail.precondition_final?.ToString();
  91. if (!string.IsNullOrEmpty(preconStr))
  92. {
  93. JsonModel preconditionModel = JsonConvert.DeserializeObject<JsonModel>(preconStr);
  94. foreach (var detail in preconditionModel.DetailInfo)
  95. {
  96. invoiceModel.ReportPLCModels.Add(new ReportPLCModel()
  97. {
  98. ItemName = each.ItemName,
  99. ItemType = each.ItemType,
  100. Type = "前置项",
  101. JudgeType = preconditionModel.ItemType,
  102. SelectLogic = preconditionModel.ItemLogical,
  103. Detail = preconditionModel.Description,
  104. Id = detail.Id,
  105. PlcAddress = detail.PlcAddress,
  106. PlcItem = detail.PlcItem,
  107. PlcValue = detail.PlcValue,
  108. Remark = detail.Remark,
  109. TestTime = detail.TestTime,
  110. RealValue = detail.RealValue,
  111. TestResult = detail.TestResult,
  112. });
  113. }
  114. }
  115. //输入项解析
  116. string inStr = recordDetail.action_final?.ToString();
  117. if (!string.IsNullOrEmpty(inStr))
  118. {
  119. JsonModel inModel = JsonConvert.DeserializeObject<JsonModel>(inStr);
  120. foreach (var detail in inModel.DetailInfo)
  121. {
  122. invoiceModel.ReportPLCModels.Add(new ReportPLCModel()
  123. {
  124. ItemName = each.ItemName,
  125. ItemType = each.ItemType,
  126. Type = "输入项",
  127. JudgeType = inModel.ItemType,
  128. SelectLogic = inModel.ItemLogical,
  129. Detail = inModel.Description,
  130. Id = detail.Id,
  131. PlcAddress = detail.PlcAddress,
  132. PlcItem = detail.PlcItem,
  133. PlcValue = detail.PlcValue,
  134. Remark = detail.Remark,
  135. TestTime = detail.TestTime,
  136. RealValue = detail.RealValue,
  137. TestResult = detail.TestResult,
  138. });
  139. }
  140. }
  141. //输出项解析
  142. string outStr = recordDetail.judgement_result_final?.ToString();
  143. if (!string.IsNullOrEmpty(outStr))
  144. {
  145. JsonModel outModel = JsonConvert.DeserializeObject<JsonModel>(outStr);
  146. foreach (var detail in outModel.DetailInfo)
  147. {
  148. invoiceModel.ReportPLCModels.Add(new ReportPLCModel()
  149. {
  150. ItemName = each.ItemName,
  151. ItemType = each.ItemType,
  152. Type = "结果项",
  153. JudgeType = outModel.ItemType,
  154. SelectLogic = outModel.ItemLogical,
  155. Detail = outModel.Description,
  156. Id = detail.Id,
  157. PlcAddress = detail.PlcAddress,
  158. PlcItem = detail.PlcItem,
  159. PlcValue = detail.PlcValue,
  160. Remark = detail.Remark,
  161. TestTime = detail.TestTime,
  162. RealValue = detail.RealValue,
  163. TestResult = detail.TestResult,
  164. });
  165. }
  166. }
  167. }
  168. }
  169. //判断方案结果是否通过
  170. var testCount = allConfigList.FindAll(X => X.SchemeName == findSch.scheme_name&&X.TestResult=="通过")?.Count;
  171. if(testCount== allResult.Count)
  172. {
  173. invoiceModel.FinalReuslt = "通过";
  174. }
  175. else
  176. {
  177. invoiceModel.FinalReuslt = "不通过";
  178. }
  179. }
  180. return invoiceModel;
  181. }
  182. /// <summary>
  183. /// 生成pdf
  184. /// </summary>
  185. /// <param name="obj"></param>
  186. public void CreatePdf(object obj)
  187. {
  188. int id = Convert.ToInt32(obj);
  189. try
  190. {
  191. Settings.License = LicenseType.Community;
  192. var model = GetReportPLCInfo(id);
  193. var document = new InvoiceDocument(model);
  194. //pdf名称为轴编号+时间
  195. //输出文件
  196. using (System.Windows.Forms.SaveFileDialog saveFileDialog = new System.Windows.Forms.SaveFileDialog()
  197. {
  198. //设置文件类型
  199. //书写规则例如:txt files(*.txt)|*.txt
  200. Filter = "pdf文件|*.pdf",
  201. //设置默认文件名(可以不设置)
  202. FileName = "报表" + string.Format("{0:yyyyMMddHHmm}", DateTime.Now),
  203. //获取或设置一个值,该值指示如果用户省略扩展名,文件对话框是否自动在文件名中添加扩展名。(可以不设置)
  204. AddExtension = true,
  205. //保存对话框是否记忆上次打开的目录
  206. RestoreDirectory = true
  207. })
  208. {
  209. //点了保存按钮进入
  210. if (saveFileDialog.ShowDialog() == System.Windows.Forms.DialogResult.OK)
  211. {
  212. //获得文件路径
  213. string localFilePath = saveFileDialog.FileName.ToString();
  214. document.GeneratePdf(localFilePath);
  215. }
  216. }
  217. }
  218. catch(Exception ex)
  219. {
  220. _logger.LogError(ex.ToString());
  221. }
  222. }
  223. private void CheckDetail(object obj)
  224. {
  225. //测试方案明细主键ID
  226. long id = Convert.ToInt64(obj);
  227. DialogParameters parm = new DialogParameters();
  228. parm.Add("Key", id);
  229. //弹出详情对话框
  230. //弹出详情对话框
  231. _dialog.ShowDialog("TestResultDetailView", parm, async callback =>
  232. {
  233. if (callback.Result == ButtonResult.OK)
  234. {
  235. //更新表格,重新获取
  236. GetContent();
  237. }
  238. });
  239. }
  240. /// <summary>
  241. /// 每次进入页面加载
  242. /// </summary>
  243. private void OnLoad()
  244. {
  245. GetContent();
  246. }
  247. private void Reset(object obj)
  248. {
  249. ScheduleName = string.Empty;
  250. DeviceName = string.Empty;
  251. TestName = string.Empty;
  252. SelectTest = string.Empty;
  253. }
  254. private void Query(object obj)
  255. {
  256. if (StartTime > EndTime)
  257. {
  258. MessageBox.Show("起始时间大于结束时间,请重新输入", "确认", MessageBoxButton.OK, MessageBoxImage.Warning);
  259. return;
  260. }
  261. conditionConfig = (from a in allConfigList
  262. where (EndTime == DateTime.MinValue ? true : (a.CreateTime < Convert.ToDateTime(EndTime)) && (Convert.ToDateTime(StartTime) < a.CreateTime))
  263. && (string.IsNullOrEmpty(ScheduleName) ? true : (a.SchemeName == ScheduleName))
  264. && (string.IsNullOrEmpty(TestName) ? true : (a.ItemName == TestName))
  265. && (string.IsNullOrEmpty(DeviceName) ? true : (a.DeviceName == DeviceName))
  266. && (string.IsNullOrEmpty(SelectTest) ? true : (a.ItemType == SelectTest))
  267. select a).ToList();
  268. //默认显示的第一页
  269. Getpage();
  270. //BaseConfigList = new ObservableCollection<BasicPlcTestSchemeDto>(conditionConfig);
  271. }
  272. /// <summary>
  273. /// 获取配置
  274. /// </summary>
  275. private void GetConfigOption()
  276. {
  277. var configList = _optionConfigService.QueryList();
  278. var _optionConfigs = _mapper.Map<List<OptionConfig>, List<OptionConfigDto>>(configList);
  279. var tests = _optionConfigs.FindAll(x => x.TypeID == 1);
  280. TestKinds = new List<string>();
  281. foreach (var test in tests)
  282. {
  283. TestKinds.Add(test.ContentOption);
  284. }
  285. }
  286. /// <summary>
  287. /// excel导出
  288. /// </summary>
  289. /// <param name="obj"></param>
  290. private void Export(object obj)
  291. {
  292. using (System.Windows.Forms.SaveFileDialog saveFileDialog = new System.Windows.Forms.SaveFileDialog()
  293. {
  294. //设置文件类型
  295. //书写规则例如:txt files(*.txt)|*.txt
  296. Filter = "Excel files(*.xlsx)|*.xlsx|All files(*.*)|*.*",
  297. //设置默认文件名(可以不设置)
  298. FileName = "配置导出",
  299. //获取或设置一个值,该值指示如果用户省略扩展名,文件对话框是否自动在文件名中添加扩展名。(可以不设置)
  300. AddExtension = true,
  301. //保存对话框是否记忆上次打开的目录
  302. RestoreDirectory = true
  303. })
  304. {
  305. // Show save file dialog box
  306. //点了保存按钮进入
  307. if (saveFileDialog.ShowDialog() == System.Windows.Forms.DialogResult.OK)
  308. {
  309. try
  310. {
  311. //获得文件路径
  312. string localFilePath = saveFileDialog.FileName.ToString();
  313. //string filePathWithName = localFilePath + ".xlsx";
  314. //获取文件内容
  315. MiniExcel.SaveAs(localFilePath, BaseConfigList);
  316. }
  317. catch (Exception ex)
  318. {
  319. }
  320. }
  321. }
  322. }
  323. /// <summary>
  324. /// 获取解决方案
  325. /// </summary>
  326. private void GetContent()
  327. {
  328. //所有测试方案
  329. var schlist = _basicPlcTestSchemeService.QueryList();
  330. var configList = _mapper.Map<List<bas_plc_test_scheme>, List<BasicPlcTestSchemeDto>>(schlist);
  331. //清空集合
  332. BaseConfigList.Clear();
  333. allConfigList.Clear();
  334. conditionConfig.Clear();
  335. //查找测试项名称
  336. foreach (var sch in configList)
  337. {
  338. long schId = sch.SchemeId;
  339. //在解决方案详细表中查找所有的测试项
  340. var items = _basicPlcTestSchemeDtlService.FindAllBySchId(schId);
  341. foreach (var item in items)
  342. {
  343. //上面是测试方案明细
  344. SchDtlWithResultModel basicPlcTestSchemeDto = new SchDtlWithResultModel();
  345. basicPlcTestSchemeDto.SchemeId = item.scheme_dtl_id;
  346. basicPlcTestSchemeDto.SchemeName = sch.SchemeName;
  347. basicPlcTestSchemeDto.DeviceName = sch.DeviceName;
  348. switch (item.item_type)
  349. {
  350. case 0:
  351. basicPlcTestSchemeDto.ItemType = "前置项";
  352. break;
  353. case 1:
  354. basicPlcTestSchemeDto.ItemType = "PLC点位测试项";
  355. break;
  356. case 2:
  357. basicPlcTestSchemeDto.ItemType = "Robot动作测试";
  358. break;
  359. }
  360. basicPlcTestSchemeDto.ItemName = item.item_name;
  361. basicPlcTestSchemeDto.CreateBy = sch.CreateBy;
  362. basicPlcTestSchemeDto.CreateTime = sch.CreateTime;
  363. //这里是测试项 结果和 测试记录明细状态
  364. var recordDetail=_iBizTestRecordDtlService.FindRecordDetailBySchDtlID(item.scheme_dtl_id);
  365. if(recordDetail != null)
  366. {
  367. basicPlcTestSchemeDto.StartTestTime = recordDetail.start_test_time.Value;
  368. basicPlcTestSchemeDto.FinishTestTime = recordDetail.finish_test_time.Value;
  369. basicPlcTestSchemeDto.TestMode= recordDetail.test_mode;
  370. switch (recordDetail.test_result)
  371. {
  372. case 0:
  373. basicPlcTestSchemeDto.TestResult = "不通过";
  374. break;
  375. case 1:
  376. basicPlcTestSchemeDto.TestResult = "通过";
  377. break;
  378. }
  379. switch (recordDetail.status)
  380. {
  381. case 0:
  382. basicPlcTestSchemeDto.TestStatus = "未测试";
  383. break;
  384. case 99:
  385. basicPlcTestSchemeDto.TestStatus = "已测试";
  386. break;
  387. }
  388. //只显示已测试的项
  389. allConfigList.Add(basicPlcTestSchemeDto);
  390. conditionConfig.Add(basicPlcTestSchemeDto);
  391. }
  392. }
  393. //默认显示的第一页
  394. Getpage();
  395. }
  396. }
  397. /// <summary>
  398. /// 获取页面
  399. /// </summary>
  400. private void Getpage()
  401. {
  402. CurrentPage = 1;
  403. TotalCount = conditionConfig.Count;
  404. CurrentPageChanged();
  405. }
  406. /// <summary>
  407. /// 页面变化
  408. /// </summary>
  409. private void CurrentPageChanged()
  410. {
  411. BaseConfigList.Clear();
  412. foreach (var i in conditionConfig.Skip((CurrentPage - 1) * CountPerPage).Take(CountPerPage))
  413. {
  414. BaseConfigList.Add(i);
  415. }
  416. }
  417. #endregion
  418. #region 命令绑定
  419. public DelegateCommand<object> QueryCommand { set; get; }
  420. public DelegateCommand<object> ResetCommand { set; get; }
  421. public DelegateCommand<string> ExportCommand { set; get; }
  422. public DelegateCommand OnLoadCommand { set; get; }
  423. public DelegateCommand<object> PdfReportCommand { set; get; }
  424. public DelegateCommand<object> CheckDetailCommand { set; get; }
  425. #endregion
  426. #region 数据绑定
  427. /// <summary>
  428. /// 测试方案编码
  429. /// </summary>
  430. private string scheduleName;
  431. public string ScheduleName
  432. {
  433. get { return scheduleName; }
  434. set { scheduleName = value; RaisePropertyChanged(); }
  435. }
  436. /// <summary>
  437. /// 设备名称
  438. /// </summary>
  439. private string deviceName;
  440. public string DeviceName
  441. {
  442. get { return deviceName; }
  443. set { deviceName = value; RaisePropertyChanged(); }
  444. }
  445. /// <summary>
  446. /// 测试项名称
  447. /// </summary>
  448. private string testName;
  449. public string TestName
  450. {
  451. get { return testName; }
  452. set { testName = value; RaisePropertyChanged(); }
  453. }
  454. /// <summary>
  455. /// 测试项类型
  456. /// </summary>
  457. private List<string> testKinds = new List<string>();
  458. public List<string> TestKinds
  459. {
  460. get { return testKinds; }
  461. set { testKinds = value; RaisePropertyChanged(); }
  462. }
  463. /// <summary>
  464. ///
  465. /// </summary>
  466. private string selectTest;
  467. public string SelectTest
  468. {
  469. get { return selectTest; }
  470. set { selectTest = value; RaisePropertyChanged(); }
  471. }
  472. private DateTime startTime = DateTime.Now;
  473. public DateTime StartTime
  474. {
  475. get { return startTime; }
  476. set { startTime = value; RaisePropertyChanged(); }
  477. }
  478. private DateTime endTime = DateTime.Now;
  479. public DateTime EndTime
  480. {
  481. get { return endTime; }
  482. set { endTime = value; RaisePropertyChanged(); }
  483. }
  484. /// <summary>
  485. /// 总条数
  486. /// </summary>
  487. private int totalCount;
  488. public int TotalCount
  489. {
  490. get { return totalCount; }
  491. set { totalCount = value; RaisePropertyChanged(); CurrentPageChanged(); }
  492. }
  493. /// <summary>
  494. /// 每页数量
  495. /// </summary>
  496. private int countPerPage = 10;
  497. public int CountPerPage
  498. {
  499. get { return countPerPage; }
  500. set { countPerPage = value; RaisePropertyChanged(); CurrentPageChanged(); }
  501. }
  502. /// <summary>
  503. /// 单前页
  504. /// </summary>
  505. private int currentPage = 1;
  506. public int CurrentPage
  507. {
  508. get { return currentPage; }
  509. set { currentPage = value; RaisePropertyChanged(); CurrentPageChanged(); }
  510. }
  511. private ObservableCollection<SchDtlWithResultModel> baseConfigList = new ObservableCollection<SchDtlWithResultModel>();
  512. public ObservableCollection<SchDtlWithResultModel> BaseConfigList
  513. {
  514. get { return baseConfigList; }
  515. set { SetProperty(ref baseConfigList, value); }
  516. }
  517. #endregion
  518. }
  519. }