You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

312 lines
11 KiB
C#

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

using Admin.Core.IService;
using Admin.Core.Model.Model_New;
using Admin.Core.Service;
using Aucma.Core.OldBoxFoam.Business;
using Aucma.Core.OldBoxFoam.Models;
using Aucma.Core.OldBoxFoam.Views;
using CommunityToolkit.Mvvm.ComponentModel;
using CommunityToolkit.Mvvm.Input;
using CommunityToolkit.Mvvm.Messaging;
using LiveCharts.Wpf;
using LiveCharts;
using Microsoft.Extensions.DependencyInjection;
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Timers;
using System.Windows;
using Admin.Core.Model;
using NPOI.SS.Formula.Functions;
using System.Windows.Documents;
using static Npgsql.Replication.PgOutput.Messages.RelationMessage;
using System.Windows.Media;
namespace Aucma.Core.OldBoxFoam.ViewModels
{
/**
* 发泡计划
*
* */
public partial class RealRoadPageViewModel : ObservableObject
{
protected readonly IBoxFoamPlanServices? _boxFoamPlanServices;
private IOldBoxFoamTypeServices? _oldBoxFoamTypeServices;
private IBoxFoamDataServices? _boxFoamDataServices;
System.Timers.Timer timer2 = new System.Timers.Timer(3000);
public RealRoadPageViewModel()
{
YAxisLabelFormatter = value => Math.Round(value, 2).ToString();
_boxFoamPlanServices = App.ServiceProvider.GetService<IBoxFoamPlanServices>();
_oldBoxFoamTypeServices = App.ServiceProvider.GetService<IOldBoxFoamTypeServices>();
_boxFoamDataServices = App.ServiceProvider.GetService<IBoxFoamDataServices>();
//InitData();
Collection.RefreshSpaceEvent += InitData;
timer2.Elapsed += new System.Timers.ElapsedEventHandler(InitData); //到达时间的时候执行事件;
timer2.AutoReset = true;//设置是执行一次false还是一直执行(true)
timer2.Enabled = true;//需要调用 timer.Start()或者timer.Enabled = true来启动它
timer2.Start();//timer.Start()的内部原理还是设置timer.Enabled = true;
//RefreshHourOutPutChart();
//RefreshMaterialTypeChart();
}
#region 参数定义
private Func<double, string> _yAxisLabelFormatter;
public Func<double, string> YAxisLabelFormatter
{
get { return _yAxisLabelFormatter; }
set
{
_yAxisLabelFormatter = value;
OnPropertyChanged(nameof(YAxisLabelFormatter));
}
}
/// <summary>
/// 小时产量统计图表
/// </summary>
private SeriesCollection _hourAchievement = new SeriesCollection();
public SeriesCollection HourAchievement
{
get { return _hourAchievement; }
set
{
_hourAchievement = value;
OnPropertyChanged(nameof(HourAchievement));
}
}
/// <summary>
/// 小时产量统计图表X轴
/// </summary>
private List<string> _hourOutPutList;
public List<string> HourOutPutList
{
get { return _hourOutPutList; }
set
{
_hourOutPutList = value;
OnPropertyChanged(nameof(HourOutPutList));
}
}
/// <summary>
/// 型号统计图表
/// </summary>
private SeriesCollection _materialTypeAchievement = new SeriesCollection();
public SeriesCollection MaterialTypeAchievement
{
get { return _materialTypeAchievement; }
set
{
_materialTypeAchievement = value;
OnPropertyChanged(nameof(MaterialTypeAchievement));
}
}
private List<string> _materialTypeOutPutList;
public List<string> MaterialTypeOutPutList
{
get { return _materialTypeOutPutList; }
set
{
_materialTypeOutPutList = value;
OnPropertyChanged(nameof(MaterialTypeOutPutList));
}
}
#endregion
public async void InitData(object? sender, ElapsedEventArgs e)
{
List<OldBoxFoamType> list = await _oldBoxFoamTypeServices.QueryAsync();
if (list == null) return;
System.Windows.Application.Current.Dispatcher.Invoke((Action)(() =>
{
ListItems.Clear();
foreach (OldBoxFoamType item in list)
{
ListItems.Add(new OldBoxFoamTypeModel()
{
ObjId = item.ObjId,
Local = item.Local,
Status = item.Storeamount==3?"1":"0",
Storeamount = item.Storeamount,
MaterialCode = item.MaterialCode,
MaterialName = item.MaterialName,
Boxtype = item.Boxtype,
}); ;
}
}));
}
#region 初始化datagrid
private ObservableCollection<OldBoxFoamTypeModel> listItems = new ObservableCollection<OldBoxFoamTypeModel>();
public ObservableCollection<OldBoxFoamTypeModel> ListItems
{
get { return listItems; }
set
{
listItems = value;
OnPropertyChanged();//属性通知
}
}
#endregion
/// <summary>
/// 更新货道信息
/// </summary>
/// <param name="spaceDetailModel"></param>
public async void InitData(List<SpaceDetailModel> spaceDetailModel)
{
if (spaceDetailModel == null) return;
var spaceList = _oldBoxFoamTypeServices.QueryAsync().Result;
List<OldBoxFoamType> storeList = new List<OldBoxFoamType>();
foreach (var item in spaceDetailModel)
{
var space = spaceList.FirstOrDefault(x=>x.ObjId == item.ObjId);
if(spaceList != null)
{
if(spaceDetailModel.Count > 0)
{
var spaceInfo = space;
spaceInfo.Storeamount = item.StoreAmount;
spaceInfo.Boxtype = item.StoreType;
storeList.Add(spaceInfo);
//_oldBoxFoamTypeServices.UpdateAsync(spaceInfo);
}
}
}
if (storeList!=null&&storeList.Count>0)
{
await _oldBoxFoamTypeServices.UpdateAsync(storeList);
}
RefreshHourOutPutChart();
RefreshMaterialTypeChart();
}
/// <summary>
/// 小时统计图表
/// </summary>
private void RefreshHourOutPutChart()
{
ChartValues<double> hourAchievement = new ChartValues<double>();
HourOutPutList = new List<string>();
App.Current.Dispatcher.BeginInvoke((Action)(() =>
{
DateTime now = DateTime.Now;
// 判断当前是否是白班时间段
if (now.Hour >= 8 && now.Hour < 20)
{
HourOutPutList = new List<string>() { "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19" };
}
else
{
HourOutPutList = new List<string>() { "20", "21", "22", "23", "00", "01", "02", "03", "04", "05", "06", "07" };
}
var hourFoamDataList = _boxFoamDataServices.Query(x=>x.ProductLineCode == "CX_01" && x.StationCode == "1105");
List<int> hours = new List<int>();
if (hourFoamDataList != null)
{
hourAchievement.Add(hourFoamDataList.Sum(x => x.AnHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.TwoHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.ThreeHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.FourHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.FiveHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.SixHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.SevenHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.EightHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.NineHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.TenHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.ElevenHour));
hourAchievement.Add(hourFoamDataList.Sum(x => x.TwelveHour));
}
var shellColumn = new ColumnSeries();
shellColumn.DataLabels = true;
shellColumn.Title = "小时产量";
shellColumn.Values = hourAchievement;
shellColumn.Foreground = Brushes.White;
if (HourAchievement.Count > 0)
{
for (int i = 0; i < hourAchievement.Count; i++)
{
//hours
HourAchievement.FirstOrDefault().Values[i] = hourAchievement.ElementAt(i);
}
}
else
{
HourAchievement.Add(shellColumn);
}
}));
}
/// <summary>
/// 型号统计图表
/// </summary>
private void RefreshMaterialTypeChart()
{
ChartValues<double> materialTypeAchievement = new ChartValues<double>();
MaterialTypeOutPutList = new List<string>();
App.Current.Dispatcher.BeginInvoke((Action)(() =>
{
DateTime now = DateTime.Now;
var hourFoamDataList = _boxFoamDataServices.Query(x => x.ProductLineCode == "CX_01" && x.StationCode == "1105");
if (hourFoamDataList != null)
{
var grouped = hourFoamDataList.GroupBy(x => x.Fixtureboxtype);
foreach (var item in grouped)
{
var flattenedList = item.SelectMany(p => new[] { p.AnHour, p.TwoHour, p.ThreeHour, p.FourHour, p.FiveHour, p.SixHour, p.SevenHour, p.EightHour, p.NineHour, p.TenHour, p.ElevenHour, p.TwelveHour }).ToList();
MaterialTypeOutPutList.Add(item.Key);
materialTypeAchievement.Add(flattenedList.Sum());
}
}
var shellColumn = new ColumnSeries();
shellColumn.DataLabels = true;
shellColumn.Title = "型号统计";
shellColumn.Values = materialTypeAchievement;
shellColumn.Foreground = Brushes.White;
if (MaterialTypeAchievement.Count > 0)
{
for (int i = 0; i < materialTypeAchievement.Count; i++)
{
MaterialTypeAchievement.FirstOrDefault().Values[i] = materialTypeAchievement.ElementAt(i);
}
}
else
{
MaterialTypeAchievement.Add(shellColumn);
}
}));
}
}
}