demka/demofinish/MainWindow.axaml.cs

348 lines
10 KiB
C#
Raw Normal View History

2025-03-25 18:36:42 +00:00
using System;
using System.Collections.Generic;
using System.Collections.ObjectModel;
using System.IO;
using System.Linq;
2024-12-26 13:15:57 +00:00
using Avalonia.Controls;
2025-03-26 09:39:33 +00:00
using Avalonia.Interactivity;
2025-04-03 20:00:11 +00:00
using Avalonia.Media;
2025-03-25 18:36:42 +00:00
using Avalonia.Media.Imaging;
2025-04-03 20:00:11 +00:00
using demofinish.Model;
using Microsoft.EntityFrameworkCore;
2024-12-26 13:15:57 +00:00
namespace demofinish
{
public partial class MainWindow : Window
{
2025-03-25 18:36:42 +00:00
private ObservableCollection<Agent> agents = new ObservableCollection<Agent>();
2025-03-31 18:03:22 +00:00
public List<AgentPresenter> agentsList = new List<AgentPresenter>();
2025-03-26 09:39:33 +00:00
private const int pageSize = 10;
private int currentPage = 1;
private int pageCount = 0;
2025-03-25 18:36:42 +00:00
2024-12-26 13:15:57 +00:00
public MainWindow()
{
InitializeComponent();
2025-03-25 18:36:42 +00:00
LoadAgents();
2025-03-31 18:03:22 +00:00
ComboboxAgentType();
2025-04-02 11:50:36 +00:00
SearchFiels();
2025-03-31 18:03:22 +00:00
TypeAgentCombobox.SelectionChanged += TypeAgentCombobox_SelectionChanged;
NameComboBox.SelectionChanged += SortName_SelectedChanged;
PriorityCombobox.SelectionChanged += PrioritySort_SelectedChanged;
2025-04-03 20:00:11 +00:00
SaleCombobox.SelectionChanged += SaleSort_SelectedChanged;
2025-04-02 11:50:36 +00:00
2025-03-25 18:36:42 +00:00
}
2025-04-02 11:50:36 +00:00
private void SearchFiels()
{
using var context = new User1Context();
var searchItems = context.Agents
.Select(a => a.Title)
.Union(context.Agents.Select(a => a.Phone))
.Union(context.Agents.Select(a => a.Email))
.Where(x => !string.IsNullOrEmpty(x))
.ToList();
SearchBox.ItemsSource = searchItems;
SearchBox.SelectionChanged += SearchBox_SelectionChanged;
}
2025-03-26 09:39:33 +00:00
2025-04-02 11:50:36 +00:00
private void SearchBox_SelectionChanged(object sender, SelectionChangedEventArgs e)
{
2025-04-03 20:00:11 +00:00
if (SearchBox.SelectedItem == null || string.IsNullOrEmpty(SearchBox.Text))
{
AgentListBox.ItemsSource = agents;
return;
}
2025-04-02 11:50:36 +00:00
string searchValue = SearchBox.SelectedItem.ToString();
var filtered = agentsList
.Where(a => a.Title == searchValue ||
a.Phone == searchValue ||
a.Email == searchValue)
.ToList();
AgentListBox.ItemsSource = filtered;
}
2025-03-26 09:39:33 +00:00
public class AgentPresenter : Agent
2025-03-25 18:36:42 +00:00
{
2025-04-03 20:00:11 +00:00
public string AgentTypeName { get; set; }
public int DiscountPercent { get; set; }
public decimal TotalSales { get; set; }
2025-03-26 09:39:33 +00:00
Bitmap? LogoImage
2025-03-25 18:36:42 +00:00
{
2025-03-26 09:39:33 +00:00
get
{
try
{
2025-04-03 20:00:11 +00:00
string absolutepass = Path.Combine(AppContext.BaseDirectory, Logo);
return new Bitmap(absolutepass);
2025-03-26 09:39:33 +00:00
}
catch
{
2025-04-03 20:00:11 +00:00
return null;
2025-03-26 09:39:33 +00:00
}
}
2025-03-25 18:36:42 +00:00
}
2025-03-26 09:39:33 +00:00
}
2025-03-31 18:03:22 +00:00
private void ComboboxAgentType()
2025-03-26 09:39:33 +00:00
{
using var context = new User1Context();
2025-03-31 18:03:22 +00:00
var type = context.Agenttypes.Select(x => x.Title).ToList();
2025-03-26 09:39:33 +00:00
2025-03-31 18:03:22 +00:00
type.Insert(0, "Все типы");
TypeAgentCombobox.ItemsSource = type;
TypeAgentCombobox.SelectedIndex = 0;
2025-03-26 09:39:33 +00:00
}
2025-04-01 11:42:23 +00:00
2025-03-26 09:39:33 +00:00
2025-03-31 18:03:22 +00:00
private void TypeAgentCombobox_SelectionChanged(object sender, SelectionChangedEventArgs e)
2025-03-26 09:39:33 +00:00
{
2025-03-31 18:03:22 +00:00
using var context = new User1Context();
string selectedType = TypeAgentCombobox.SelectedItem.ToString();
if (TypeAgentCombobox.SelectedItem == null)
2025-03-26 09:39:33 +00:00
return;
2025-03-31 18:03:22 +00:00
if (TypeAgentCombobox.SelectedItem is string && (string)TypeAgentCombobox.SelectedItem == "Все типы")
2025-03-25 18:36:42 +00:00
{
2025-03-26 09:39:33 +00:00
AgentListBox.ItemsSource = agents;
}
2025-03-31 18:03:22 +00:00
else
2025-03-26 09:39:33 +00:00
{
2025-03-31 18:03:22 +00:00
var selectedTypeId = context.Agenttypes
.Where(at => at.Title == selectedType)
.Select(at => at.Id)
.FirstOrDefault();
var filteredAgents = agentsList
.Where(x => x.Agenttypeid == selectedTypeId)
.ToList();
AgentListBox.ItemsSource = filteredAgents;
}
ShowCurrentPage();
}
private void SortName_SelectedChanged(object sender, SelectionChangedEventArgs e)
{
2025-04-03 20:00:11 +00:00
if (NameComboBox.SelectionBoxItem == null)
2025-03-31 18:03:22 +00:00
return;
var currentPageItems = agents.ToList();
List<Agent> sorted;
2025-04-03 20:00:11 +00:00
if (NameComboBox.SelectionBoxItem.ToString() == "по возрастанию")
2025-03-31 18:03:22 +00:00
{
sorted = currentPageItems.OrderBy(it => it.Title).ToList();
}
else
{
sorted = currentPageItems.OrderByDescending(it => it.Title).ToList();
}
agents.Clear();
foreach (var item in sorted)
{
agents.Add(item);
}
}
private void PrioritySort_SelectedChanged(object sender, SelectionChangedEventArgs e)
{
2025-04-03 20:00:11 +00:00
if (PriorityCombobox.SelectionBoxItem == null)
2025-03-31 18:03:22 +00:00
return;
var currentPageItems = agents.ToList();
List<Agent> sorted;
2025-04-03 20:00:11 +00:00
if (PriorityCombobox.SelectionBoxItem.ToString() == "по возрастанию")
2025-03-31 18:03:22 +00:00
{
sorted = currentPageItems.OrderBy(it => it.Priority).ToList();
}
else
{
sorted = currentPageItems.OrderByDescending(it => it.Priority).ToList();
}
agents.Clear();
foreach (var item in sorted)
{
agents.Add(item);
2025-03-25 18:36:42 +00:00
}
2025-04-03 20:00:11 +00:00
2024-12-26 13:15:57 +00:00
}
2025-03-25 18:36:42 +00:00
2024-12-26 13:15:57 +00:00
2025-03-26 09:39:33 +00:00
2025-04-03 20:00:11 +00:00
private void LoadAgents()
2024-12-26 13:15:57 +00:00
{
2025-03-25 18:36:42 +00:00
using var context = new User1Context();
2025-04-03 20:00:11 +00:00
agentsList = context.Agents
.Include(a => a.Agenttype)
.Include(a => a.Productsales)
.ThenInclude(ps => ps.Product)
.AsEnumerable()
.Select(agent =>
{
decimal totalSales = agent.Productsales?.Sum(ps =>
ps.Productcount * (ps.Product?.Mincostforagent ?? 0)) ?? 0;
return new AgentPresenter
{
Id = agent.Id,
Title = agent.Title,
Agenttypeid = agent.Agenttypeid,
AgentTypeName = agent.Agenttype?.Title ?? "Неизвестный тип",
Address = agent.Address,
Inn = agent.Inn,
Kpp = agent.Kpp,
Directorname = agent.Directorname,
Phone = agent.Phone,
Email = agent.Email,
Logo = agent.Logo,
Priority = agent.Priority,
TotalSales = totalSales,
DiscountPercent = CalculateDiscount(totalSales)
};
})
.ToList();
agents.Clear();
2025-03-25 18:36:42 +00:00
foreach (var agent in agentsList)
{
2025-03-26 09:39:33 +00:00
agents.Add(agent);
2025-03-25 18:36:42 +00:00
}
2025-04-03 20:00:11 +00:00
2025-03-26 09:39:33 +00:00
AgentListBox.ItemsSource = agents;
2025-04-03 20:00:11 +00:00
pageCount = (int)Math.Ceiling(agentsList.Count / (double)pageSize);
2025-03-26 09:39:33 +00:00
ShowCurrentPage();
}
2025-04-03 20:00:11 +00:00
private int CalculateDiscount(decimal totalSales)
{
if (totalSales >= 500000) return 25;
if (totalSales >= 150000) return 20;
if (totalSales >= 50000) return 10;
if (totalSales >= 10000) return 5;
return 0;
}
2025-04-01 11:42:23 +00:00
2025-04-03 20:00:11 +00:00
private void SaleSort_SelectedChanged(object sender, SelectionChangedEventArgs e)
{
if (SaleCombobox.SelectionBoxItem == null)
return;
var currentPageItems = agents.OfType<AgentPresenter>().ToList();
List<AgentPresenter> sorted;
if (SaleCombobox.SelectionBoxItem.ToString() == "по возрастанию")
{
sorted = currentPageItems.OrderBy(it => it.DiscountPercent).ToList();
}
else
{
sorted = currentPageItems.OrderByDescending(it => it.DiscountPercent).ToList();
}
agents.Clear();
foreach (var item in sorted)
{
agents.Add(item);
}
}
2025-04-01 11:42:23 +00:00
2025-03-25 18:36:42 +00:00
2025-03-26 09:39:33 +00:00
private void ShowCurrentPage()
{
2025-03-25 18:36:42 +00:00
agents.Clear();
2025-03-31 18:03:22 +00:00
var pageAgents = agentsList
.Skip((currentPage - 1) * pageSize)
.Take(pageSize);
2025-03-26 09:39:33 +00:00
foreach (var e in pageAgents)
2025-03-25 18:36:42 +00:00
{
2025-03-26 09:39:33 +00:00
agents.Add(e);
2025-03-25 18:36:42 +00:00
}
2025-04-03 20:00:11 +00:00
AgentListBox.ItemsSource = agents;
2025-03-31 18:03:22 +00:00
pageCount = (int)Math.Ceiling(agentsList.Count / (double)pageSize);
2025-03-26 09:39:33 +00:00
}
2025-03-25 18:36:42 +00:00
2025-03-26 09:39:33 +00:00
private void NextPage()
{
if (currentPage < pageCount)
{
currentPage++;
ShowCurrentPage();
}
}
private void PrevPage()
{
if (currentPage > 1)
{
currentPage--;
ShowCurrentPage();
}
2024-12-26 13:15:57 +00:00
}
2025-03-26 09:39:33 +00:00
2025-03-31 18:04:07 +00:00
2025-04-02 11:50:36 +00:00
2025-03-26 09:39:33 +00:00
2025-04-01 11:42:23 +00:00
2025-03-26 09:39:33 +00:00
private void PrevPage_Click(object sender, RoutedEventArgs e) => PrevPage();
private void NextPage_Click(object sender, RoutedEventArgs e) => NextPage();
2025-04-01 11:42:23 +00:00
private void AddNew_Agent(object? sender, RoutedEventArgs e)
{
new AddAgent_Window().ShowDialog(this);
}
2025-04-02 10:09:44 +00:00
private void AgentListBox_OnSelectionChanged(object? sender, SelectionChangedEventArgs e)
{
if (AgentListBox.SelectedItem is AgentPresenter selectedAgent)
{
var editWindow = new EditWindow(selectedAgent);
editWindow.ShowDialog(this);
}
}
2024-12-26 13:15:57 +00:00
}
}