using GalaSoft.MvvmLight; using GalaSoft.MvvmLight.Command; using LiveCharts; using LiveCharts.Defaults; using LiveCharts.Wpf; using Microsoft.Extensions.DependencyInjection; using SlnMesnac.Business; using SlnMesnac.Model.domain; using SlnMesnac.Model.dto; using SlnMesnac.WPF.MessageTips; using SlnMesnac.WPF.Model; using SqlSugar; using System; using System.Collections.Generic; using System.Collections.ObjectModel; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows; using System.Windows.Media; #region << 版 本 注 释 >> /*-------------------------------------------------------------------- * 版权所有 (c) 2024 WenJY 保留所有权利。 * CLR版本:4.0.30319.42000 * 机器名称:LAPTOP-E0N2L34V * 命名空间:SlnMesnac.WPF.ViewModel * 唯一标识:14008fcc-0a31-4f1e-bc80-9f9ea84d3de5 * * 创建者:WenJY * 电子邮箱:wenjy@mesnac.com * 创建时间:2024-04-10 16:18:57 * 版本:V1.0.0 * 描述: * *-------------------------------------------------------------------- * 修改人: * 时间: * 修改说明: * * 版本:V1.0.0 *--------------------------------------------------------------------*/ #endregion << 版 本 注 释 >> namespace SlnMesnac.WPF.ViewModel { /// /// 生产统计ViewModel /// internal class ProdStatisticsViewModel : ViewModelBase { private readonly PalletStowBusiness _palletStowBusiness; private readonly ProdCompletionBusiness _prodCompletionBusiness; private readonly ISqlSugarClient sqlClient; public ProdStatisticsViewModel() { _palletStowBusiness = App.ServiceProvider.GetService(); _prodCompletionBusiness = App.ServiceProvider.GetService(); sqlClient = App.ServiceProvider.GetService(); QueryCommand = new RelayCommand(obj => Query()); BeginDate = DateTime.Now.AddDays(-3); EndDate = DateTime.Now; Query(); } #region 参数定义 #region 投料X轴日期 /// /// 日产量柱状图X轴日期 /// private List outDayList = new List(); public List OutDayList { get { return outDayList; } set { outDayList = value; } } #endregion #region 投料柱状图 /// /// 投料统计柱状图 /// private SeriesCollection outAchievement = new SeriesCollection(); public SeriesCollection OutAchievement { get { return outAchievement; } set { outAchievement = value; } } #endregion #region 日产量柱状图X轴日期 /// /// 日产量柱状图X轴日期 /// private List productDayList = new List(); public List ProductDayList { get { return productDayList; } set { productDayList = value; } } #endregion #region 型号统计柱状图 /// /// 日产量统计柱状图 /// private SeriesCollection productAchievement = new SeriesCollection(); public SeriesCollection ProductAchievement { get { return productAchievement; } set { productAchievement = value; } } #endregion private DateTime _BeginDate; public DateTime BeginDate { get { return _BeginDate; } set { if (_BeginDate != value) { _BeginDate = value; RaisePropertyChanged();//属性通知 } } } private DateTime _EndDate; public DateTime EndDate { get { return _EndDate; } set { _EndDate = value; RaisePropertyChanged();//属性通知 } } /// /// 原材料投料明细DataGrid /// private ObservableCollection wmsRawOutstockDetailDataGrid = new ObservableCollection(); public ObservableCollection WmsRawOutstockDetailDataGrid { get { return wmsRawOutstockDetailDataGrid; } set { wmsRawOutstockDetailDataGrid = value; RaisePropertyChanged(() => WmsRawOutstockDetailDataGrid); } } /// /// 成品入库记录DataGrid /// private ObservableCollection productDataGrid = new ObservableCollection(); public ObservableCollection ProductDataGrid { get { return productDataGrid; } set { productDataGrid = value; RaisePropertyChanged(() => ProductDataGrid); } } #endregion #region 事件定义 /// /// 时间查询事件 /// public RelayCommand QueryCommand { get; set; } public RelayCommand DeleteBarCodeCommand { get; set; } #endregion #region 时间查询 private async Task Query() { try { BeginDate = BeginDate.Date; EndDate = EndDate.AddDays(1).Date; if (EndDate < BeginDate) { Application.Current.Dispatcher.Invoke(() => { Msg.MsgShow("结束时间要大于开始时间", 2, 3); }); return; } else { await RefreshWmsRawOutstockDetailDataGrid(BeginDate, EndDate); await RefreshProductDataGrid(BeginDate, EndDate); } } catch (Exception ex) { Console.WriteLine(ex.ToString()); } } #endregion #region 3F原材料出库记录及图表 /// /// 刷新原材料出库记录 /// private async Task RefreshWmsRawOutstockDetailDataGrid(DateTime beginDate, DateTime endDate) { List list; list = await sqlClient.AsTenant().GetConnection("mes").Queryable().Where(x => x.WarehouseId == 311 && x.OutstockTime >= beginDate && x.OutstockTime <= endDate).OrderByDescending(t => t.OutstockTime).ToListAsync(); if (list != null && list.Count > 0) { await App.Current.Dispatcher.BeginInvoke((Action)(() => { WmsRawOutstockDetailDataGrid.Clear(); int i = 1; foreach (WmsRawOutstockDetail verify in list) { verify.RawOutstockDetailId = i++; WmsRawOutstockDetailDataGrid.Add(verify); } })); // 刷新图表 RefreshWmsRawOutstockDetailChart(list); } } /// /// 刷新原材料出库图表 /// /// private void RefreshWmsRawOutstockDetailChart(List list) { list = list.OrderBy(x => x.CreateDate).ToList(); App.Current.Dispatcher.BeginInvoke((Action)(() => { OutAchievement.Clear(); OutDayList.Clear(); ChartValues achievement = new ChartValues(); var listByDate = list .GroupBy(detail => detail.OutstockTime.Value.Date) // 按日期分组 .Select(group => new { Date = group.Key, TotalAmount = group.Count() // 统计出库数量 }) .ToList(); int i = 0; foreach (var item in listByDate) { outDayList.Add(item.Date.ToString("MM-dd")); achievement.Add(new ObservablePoint(i++, double.Parse(item.TotalAmount.ToString()))); } //加一个汇总柱状图 outDayList.Add("合计"); achievement.Add(new ObservablePoint(i, list.Count)); var column = new ColumnSeries(); column.DataLabels = true; column.Title = "日投料量"; column.Values = achievement; column.Foreground = Brushes.White; column.Fill = new SolidColorBrush(Brushes.YellowGreen.Color); OutAchievement.Add(column); })); } #endregion #region 2F成品生产记录及统计图表 private async Task RefreshProductDataGrid(DateTime beginDate, DateTime endDate) { List list; list = await sqlClient.AsTenant().GetConnection("mes").Queryable().Where(x => x.warehouseId == 231 && x.beginTime >= beginDate && x.beginTime <= endDate).OrderByDescending(t => t.beginTime).ToListAsync(); if (list != null && list.Count > 0) { await App.Current.Dispatcher.BeginInvoke((Action)(() => { productDataGrid.Clear(); int i = 1; foreach (WmsProductInstock verify in list) { verify.productInstockId = i++; productDataGrid.Add(verify); } })); // 刷新图表 RefreshProductChart(list); } } private void RefreshProductChart(List list) { list = list.OrderBy(x => x.updateDate).ToList(); App.Current.Dispatcher.BeginInvoke((Action)(() => { ProductAchievement.Clear(); ProductDayList.Clear(); ChartValues achievement = new ChartValues(); var listByDate = list .GroupBy(detail => detail.updateDate.Value.Date) // 按日期分组 .Select(group => new { Date = group.Key, TotalAmount = group.Count() // 统计出库数量 }) .ToList(); int i = 0; foreach (var item in listByDate) { ProductDayList.Add(item.Date.ToString("MM-dd")); achievement.Add(new ObservablePoint(i++, double.Parse(item.TotalAmount.ToString()))); } //加一个汇总柱状图 ProductDayList.Add("合计"); achievement.Add(new ObservablePoint(i, list.Count)); var column = new ColumnSeries(); column.DataLabels = true; column.Title = "日生产量"; column.Values = achievement; column.Foreground = Brushes.White; column.Fill = new SolidColorBrush(Brushes.LimeGreen.Color); ProductAchievement.Add(column); })); } #endregion } }