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
|
|
|
|
}
|
|
|
|
|
}
|