Compare commits

..

No commits in common. "master" and "Deve" have entirely different histories.
master ... Deve

8 changed files with 11 additions and 281 deletions

View File

@ -11,7 +11,7 @@
<ItemGroup>
<PackageReference Include="Avalonia.Desktop" Version="11.2.3" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="9.0.0" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="8.0.11" />
<PackageReference Include="Microsoft.OpenApi" Version="1.6.23" />
</ItemGroup>

View File

@ -17,13 +17,7 @@
<!--Condition below is needed to remove Avalonia.Diagnostics package from build output in Release configuration.-->
<PackageReference Condition="'$(Configuration)' == 'Debug'" Include="Avalonia.Diagnostics" Version="11.2.3" />
<PackageReference Include="Microsoft.EntityFrameworkCore" Version="9.0.0" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="9.0.0" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="8.0.11" />
<PackageReference Include="Microsoft.OpenApi" Version="1.6.23" />
</ItemGroup>
<ItemGroup>
<Compile Update="Views\ServiceFormWindow.axaml.cs">
<DependentUpon>ServiceFormWindow.axaml</DependentUpon>
</Compile>
</ItemGroup>
</Project>

View File

@ -8,6 +8,6 @@ public class AppDbContext : DbContext
protected override void OnConfiguring(DbContextOptionsBuilder oB)
{
oB.UseSqlServer("Server=45.67.56.214,5421;Database=user16;User Id=user16;Password=dZ28IVE5;");
oB.UseSqlServer("Host=45.67.56.214;Port=5421;Username=user16;Password=dZ28IVE5;Database=user16");
}
}

View File

@ -1,13 +1,7 @@
using System;
using System.ComponentModel.DataAnnotations;
namespace Demka_2.Use;
namespace Demka_2.Use;
public class Service
{
[Key]
public Guid guid { get; set; }
public string Name { get; set; }
public string ImagePath { get; set; }
public decimal Price { get; set; }
public decimal Discount { get; set; }
public int Duration { get; set; }

View File

@ -1,7 +1,7 @@
<Window xmlns="https://github.com/avaloniaui"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
x:Class="Demka_2.Views.MainWindow"
Width="1200" Height="800"
Width="800" Height="600"
Title="Список услуг">
<DockPanel>
<StackPanel Orientation="Horizontal" DockPanel.Dock="Top" Margin="5">
@ -16,22 +16,11 @@
<TextBlock Text="70-100%" />
</ComboBox.Items>
</ComboBox>
<StackPanel Orientation="Horizontal" DockPanel.Dock="Top" Margin="5">
<TextBox Width="200" Watermark="Код администратора..." Name="AdminCodeBox" />
<Button Content="Войти как администратор" Name="AdminLoginButton" Margin="5" />
</StackPanel>
<Button Content="Сортировка ↑" Name="SortAscButton" Margin="5" />
<Button Content="Сортировка ↓" Name="SortDescButton" />
</StackPanel>
<StackPanel Orientation="Horizontal" DockPanel.Dock="Bottom" Margin="5" Name="AdminControls" IsVisible="False">
<Button Content="Добавить услугу" Name="AddServiceButton" Margin="5" />
<Button Content="Редактировать услугу" Name="EditServiceButton" Margin="5" />
<Button Content="Удалить услугу" Name="DeleteServiceButton" Margin="5" />
<!-- <Button Content="Открыть форму для добавления товаров" Name="OpenServiceFormWindow" Click="OpenServiceFormWindow_Click" Margin="5" /> -->
</StackPanel>
<ListBox Name="ServiceList" Margin="5" Width="600">
<ListBox Name="ServiceList" Margin="5">
<ListBox.ItemTemplate>
<DataTemplate>
<StackPanel Orientation="Vertical" Background="{Binding BackgroundColor}" Margin="5">
@ -46,6 +35,7 @@
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
<TextBlock Name="ServiceCountText" DockPanel.Dock="Bottom" Margin="50" HorizontalAlignment="Center" />
<TextBlock Name="ServiceCountText" DockPanel.Dock="Bottom" Margin="5" HorizontalAlignment="Center" />
</DockPanel>
</Window>

View File

@ -4,8 +4,6 @@ using System.Collections.ObjectModel;
using System.Linq;
using Demka_2.Use;
using System;
using Avalonia.Interactivity;
using DynamicData;
namespace Demka_2.Views;
@ -18,12 +16,7 @@ public partial class MainWindow : Window
private ComboBox _discountFilter;
private ListBox _serviceList;
private TextBlock _serviceCountText;
private TextBox _adminCodeBox;
private Button _adminLoginButton;
private StackPanel _adminControls;
private const string AdminCode = "0000";
private bool IsAdminMode = false;
public MainWindow()
{
InitializeComponent();
@ -38,40 +31,15 @@ public partial class MainWindow : Window
_discountFilter = this.FindControl<ComboBox>("DiscountFilter");
_serviceList = this.FindControl<ListBox>("ServiceList");
_serviceCountText = this.FindControl<TextBlock>("ServiceCountText");
_adminCodeBox = this.FindControl<TextBox>("AdminCodeBox");
_adminLoginButton = this.FindControl<Button>("AdminLoginButton");
_adminControls = this.FindControl<StackPanel>("AdminControls");
_serviceList.ItemsSource = FilteredServices;
_searchBox.TextChanged += SearchBox_TextChanged;
_discountFilter.SelectionChanged += DiscountFilter_SelectionChanged;
_adminLoginButton.Click += AdminLoginButton_Click;
}
private void AdminLoginButton_Click(object? sender, EventArgs e)
{
if (_adminCodeBox.Text == AdminCode)
{
IsAdminMode = true;
_adminControls.IsVisible = true;
}
else
{
IsAdminMode = false;
_adminControls.IsVisible = false;
}
}
private void OpenServiceFormWindow_Click(object sender, RoutedEventArgs e)
{
var selectedService = _serviceList.SelectedItem as Service;
var serviceFormWindow = new ServiceFormWindow(selectedService, Services);
serviceFormWindow.Show();
}
private void LoadServices()
{
/*using (var context = new AppDbContext())
using (var context = new AppDbContext())
{
var services = context.Services.ToList();
foreach (var service in services)
@ -79,29 +47,7 @@ public partial class MainWindow : Window
Services.Add(service);
}
}*/
Services.Add(new Service { Name = "Услуга 1", Price = 100, Duration = 30, Discount = 0 });
Services.Add(new Service { Name = "Услуга 2", Price = 200, Duration = 60, Discount = 10 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 40 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 60 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 80 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
Services.Add(new Service { Name = "Услуга 3", Price = 150, Duration = 45, Discount = 20 });
}
}
private void UpdateFilteredServices()
@ -145,27 +91,6 @@ public partial class MainWindow : Window
UpdateFilteredServices();
}
public async void ShowMessage(string message)
{
var messageBox = new Window
{
Title = "Сообщение",
Content = message,
Width = 300,
Height = 150,
WindowStartupLocation = WindowStartupLocation.CenterScreen
};
var okButton = new Button { Content = "ОК" };
okButton.Click += (s, e) => messageBox.Close();
messageBox.Content = new StackPanel
{
Children = { new TextBlock { Text = message }, okButton }
};
await messageBox.ShowDialog(this);
}
private (decimal min, decimal max)? ParseDiscountRange(string rangeText)
{
return rangeText switch

View File

@ -1,31 +0,0 @@
<Window xmlns="https://github.com/avaloniaui"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
x:Class="Demka_2.Views.ServiceFormWindow"
Width="1200"
Height="800"
Title="Редактор Услуг">
<StackPanel Margin="10">
<TextBlock Text="Название" />
<TextBox Name="NameTextBox" />
<TextBlock Text="Стоимость" Margin="0,10" />
<TextBox Name="PriceTextBox" />
<TextBlock Text="Скидка (%)" Margin="0,10" />
<TextBox Name="DiscountTextBox" />
<TextBlock Text="Длительность (минуты)" Margin="0,10" />
<TextBox Name="DurationTextBox" />
<TextBlock Text="Описание" Margin="0,10" />
<TextBox Name="DescriptionTextBox" AcceptsReturn="True" Height="80" />
<TextBlock Text="Изображение" Margin="0,10" />
<StackPanel Orientation="Horizontal">
<Image Name="ThumbnailImage" Width="100" Height="100" Margin="0,0,10,0" />
<Button Content="Выбрать изображение" Name="SelectImageButton" />
</StackPanel>
<Button Content="Сохранить" Name="SaveButton" Margin="0,20" HorizontalAlignment="Center" />
</StackPanel>
</Window>

View File

@ -1,142 +0,0 @@
using Avalonia.Controls;
using Avalonia.Interactivity;
using Avalonia.Media.Imaging;
using Demka_2.Use;
using System;
using System.Collections.ObjectModel;
using System.Linq;
namespace Demka_2.Views
{
public partial class ServiceFormWindow : Window
{
private Service _service;
private ObservableCollection<Service> _services;
public ServiceFormWindow(Service service, ObservableCollection<Service> services)
{
InitializeComponent();
_service = service;
_services = services;
LoadServiceData();
SaveButton.Click += SaveButton_Click;
SelectImageButton.Click += SelectImageButton_Click;
//AddServiceButton.Click += (s, e) =>
//{
// var serviceForm = new ServiceFormWindow(new Service(), Services);
// serviceForm.ShowDialog(this).ContinueWith(_ => UpdateFilteredServices());
//};
//EditServiceButton.Click += (s, e) =>
//{
// if (_serviceList.SelectedItem is Service selectedService)
// {
// var serviceForm = new ServiceFormWindow(selectedService, Services);
// serviceForm.ShowDialog(this).ContinueWith(_ => UpdateFilteredServices());
// }
// else
// {
// ShowMessage("Выберите услугу для редактирования.");
// }
//};
}
private void LoadServiceData()
{
NameTextBox.Text = _service.Name;
PriceTextBox.Text = _service.Price.ToString();
DiscountTextBox.Text = _service.Discount.ToString();
DurationTextBox.Text = _service.Duration.ToString();
DescriptionTextBox.Text = _service.Description;
if (!string.IsNullOrEmpty(_service.ImagePath))
{
ThumbnailImage.Source = new Bitmap(_service.ImagePath);
}
}
public async void ShowMessage(string message)
{
var messageBox = new Window
{
Title = "Сообщение",
Content = message,
Width = 300,
Height = 150,
WindowStartupLocation = WindowStartupLocation.CenterScreen
};
var okButton = new Button { Content = "ОК" };
okButton.Click += (s, e) => messageBox.Close();
messageBox.Content = new StackPanel
{
Children = { new TextBlock { Text = message }, okButton }
};
await messageBox.ShowDialog(this);
}
private void SaveButton_Click(object? sender, RoutedEventArgs e)
{
if (string.IsNullOrWhiteSpace(NameTextBox.Text))
{
ShowMessage("Название услуги не может быть пустым.");
return;
}
if (_services.Any(s => s.Name == NameTextBox.Text && s.guid != _service.guid))
{
ShowMessage("Услуга с таким названием уже существует.");
return;
}
if (!decimal.TryParse(PriceTextBox.Text, out var price) || price < 0)
{
ShowMessage("Введите корректную стоимость.");
return;
}
if (!decimal.TryParse(DiscountTextBox.Text, out var discount) || discount < 0 || discount > 100)
{
ShowMessage("Введите корректную скидку (0-100%).");
return;
}
if (!int.TryParse(DurationTextBox.Text, out var duration) || duration <= 0 || duration > 240)
{
ShowMessage("Введите корректную длительность (1-240 минут).");
return;
}
_service.Name = NameTextBox.Text;
_service.Price = price;
_service.Discount = discount;
_service.Duration = duration;
_service.Description = DescriptionTextBox.Text;
if (_service.guid == Guid.Empty)
{
_service.guid = Guid.NewGuid();
_services.Add(_service);
}
this.Close();
}
private async void SelectImageButton_Click(object? sender, RoutedEventArgs e)
{
var openFileDialog = new OpenFileDialog
{
Filters = { new FileDialogFilter { Name = "Images", Extensions = { "jpg", "png" } } }
};
var result = await openFileDialog.ShowAsync(this);
if (result?.Length > 0)
{
var imagePath = result[0];
_service.ImagePath = imagePath;
ThumbnailImage.Source = new Bitmap(imagePath);
}
}
}
}