From 3f5418a52040f187b9ebeef8ea2e13231c624618 Mon Sep 17 00:00:00 2001 From: bekodeg Date: Mon, 5 Feb 2024 16:26:35 +0400 Subject: [PATCH] =?UTF-8?q?=D0=BD=D0=B0=D0=BF=D0=B8=D1=81=D0=B0=D0=BD?= =?UTF-8?q?=D0=B8=D0=B5=20=D0=BA=D0=BE=D0=BD=D1=82=D1=80=D0=B0=D0=BA=D1=82?= =?UTF-8?q?=D0=BE=D0=B2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../AbstractSushiBarDataModels.sln | 25 ------------------- .../BindingModels/ComponentBindingModel.cs | 11 ++++++++ .../BindingModels/OrderBindingModel.cs | 16 ++++++++++++ .../BindingModels/ProductBindingModel.cs | 16 ++++++++++++ .../IComponentLogic.cs | 16 ++++++++++++ .../BusinessLogicsContracts/IOrderLogic.cs | 15 +++++++++++ .../BusinessLogicsContracts/IProductLogic.cs | 15 +++++++++++ .../SearchModels/ComponentSearchModel.cs | 8 ++++++ .../SearchModels/OrderSearchModel.cs | 7 ++++++ .../SearchModels/ProductSearchModel.cs | 8 ++++++ .../StoragesContracts/IComponentStorage.cs | 16 ++++++++++++ .../StoragesContracts/IOrderStorage.cs | 16 ++++++++++++ .../StoragesContracts/IProductStorage.cs | 16 ++++++++++++ .../ViewModels/ComponentViewModel.cs | 14 +++++++++++ .../ViewModels/OrderViewModel.cs | 25 +++++++++++++++++++ .../ViewModels/ProductViewModel.cs | 20 +++++++++++++++ .../Enums/OrderStatus.cs | 0 .../AbstractSushiBarDataModels/IId.cs | 0 .../Models/IComponentModel.cs | 2 +- .../Models/IOrderModel.cs | 2 +- .../Models/IProductModel.cs | 2 +- SushiBar/SushiBar.sln | 14 ++++++++++- 22 files changed, 235 insertions(+), 29 deletions(-) delete mode 100644 AbstractSushiBarDataModels/AbstractSushiBarDataModels.sln create mode 100644 SushiBar/AbstractSushiBarContracts/BindingModels/ComponentBindingModel.cs create mode 100644 SushiBar/AbstractSushiBarContracts/BindingModels/OrderBindingModel.cs create mode 100644 SushiBar/AbstractSushiBarContracts/BindingModels/ProductBindingModel.cs create mode 100644 SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IComponentLogic.cs create mode 100644 SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IOrderLogic.cs create mode 100644 SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IProductLogic.cs create mode 100644 SushiBar/AbstractSushiBarContracts/SearchModels/ComponentSearchModel.cs create mode 100644 SushiBar/AbstractSushiBarContracts/SearchModels/OrderSearchModel.cs create mode 100644 SushiBar/AbstractSushiBarContracts/SearchModels/ProductSearchModel.cs create mode 100644 SushiBar/AbstractSushiBarContracts/StoragesContracts/IComponentStorage.cs create mode 100644 SushiBar/AbstractSushiBarContracts/StoragesContracts/IOrderStorage.cs create mode 100644 SushiBar/AbstractSushiBarContracts/StoragesContracts/IProductStorage.cs create mode 100644 SushiBar/AbstractSushiBarContracts/ViewModels/ComponentViewModel.cs create mode 100644 SushiBar/AbstractSushiBarContracts/ViewModels/OrderViewModel.cs create mode 100644 SushiBar/AbstractSushiBarContracts/ViewModels/ProductViewModel.cs rename {AbstractSushiBarDataModels => SushiBar}/AbstractSushiBarDataModels/Enums/OrderStatus.cs (100%) rename {AbstractSushiBarDataModels => SushiBar}/AbstractSushiBarDataModels/IId.cs (100%) rename {AbstractSushiBarDataModels => SushiBar}/AbstractSushiBarDataModels/Models/IComponentModel.cs (74%) rename {AbstractSushiBarDataModels => SushiBar}/AbstractSushiBarDataModels/Models/IOrderModel.cs (88%) rename {AbstractSushiBarDataModels => SushiBar}/AbstractSushiBarDataModels/Models/IProductModel.cs (86%) diff --git a/AbstractSushiBarDataModels/AbstractSushiBarDataModels.sln b/AbstractSushiBarDataModels/AbstractSushiBarDataModels.sln deleted file mode 100644 index 4367961..0000000 --- a/AbstractSushiBarDataModels/AbstractSushiBarDataModels.sln +++ /dev/null @@ -1,25 +0,0 @@ - -Microsoft Visual Studio Solution File, Format Version 12.00 -# Visual Studio Version 17 -VisualStudioVersion = 17.7.34031.279 -MinimumVisualStudioVersion = 10.0.40219.1 -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AbstractSushiBarDataModels", "AbstractSushiBarDataModels\AbstractSushiBarDataModels.csproj", "{3CA94B77-00EA-45B6-BD88-BDD3EAD3C887}" -EndProject -Global - GlobalSection(SolutionConfigurationPlatforms) = preSolution - Debug|Any CPU = Debug|Any CPU - Release|Any CPU = Release|Any CPU - EndGlobalSection - GlobalSection(ProjectConfigurationPlatforms) = postSolution - {3CA94B77-00EA-45B6-BD88-BDD3EAD3C887}.Debug|Any CPU.ActiveCfg = Debug|Any CPU - {3CA94B77-00EA-45B6-BD88-BDD3EAD3C887}.Debug|Any CPU.Build.0 = Debug|Any CPU - {3CA94B77-00EA-45B6-BD88-BDD3EAD3C887}.Release|Any CPU.ActiveCfg = Release|Any CPU - {3CA94B77-00EA-45B6-BD88-BDD3EAD3C887}.Release|Any CPU.Build.0 = Release|Any CPU - EndGlobalSection - GlobalSection(SolutionProperties) = preSolution - HideSolutionNode = FALSE - EndGlobalSection - GlobalSection(ExtensibilityGlobals) = postSolution - SolutionGuid = {73292010-42D8-482B-90B6-CD302C7EA849} - EndGlobalSection -EndGlobal diff --git a/SushiBar/AbstractSushiBarContracts/BindingModels/ComponentBindingModel.cs b/SushiBar/AbstractSushiBarContracts/BindingModels/ComponentBindingModel.cs new file mode 100644 index 0000000..8edc388 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/BindingModels/ComponentBindingModel.cs @@ -0,0 +1,11 @@ +using AbstractSushiBarDataModels.Models; + +namespace AbstractSushiBarContracts.BindingModels +{ + public class ComponentBindingModel : IComponentModel + { + public int Id { get; set; } + public string ComponentName { get; set; } = string.Empty; + public double Cost { get; set; } + } +} diff --git a/SushiBar/AbstractSushiBarContracts/BindingModels/OrderBindingModel.cs b/SushiBar/AbstractSushiBarContracts/BindingModels/OrderBindingModel.cs new file mode 100644 index 0000000..d37e083 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/BindingModels/OrderBindingModel.cs @@ -0,0 +1,16 @@ +using AbstractSushiBarDataModels.Enums; +using AbstractSushiBarDataModels.Models; + +namespace AbstractSushiBarContracts.BindingModels +{ + public class OrderBindingModel : IOrderModel + { + public int Id { get; set; } + public int ProductId { get; set; } + public int Count { get; set; } + public double Sum { get; set; } + public OrderStatus Status { get; set; } = OrderStatus.Неизвестен; + public DateTime DateCreate { get; set; } = DateTime.Now; + public DateTime? DateImplement { get; set; } + } +} diff --git a/SushiBar/AbstractSushiBarContracts/BindingModels/ProductBindingModel.cs b/SushiBar/AbstractSushiBarContracts/BindingModels/ProductBindingModel.cs new file mode 100644 index 0000000..24e59f7 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/BindingModels/ProductBindingModel.cs @@ -0,0 +1,16 @@ +using AbstractSushiBarDataModels.Models; + +namespace AbstractSushiBarContracts.BindingModels +{ + public class ProductBindingModel : IProductModel + { + public int Id { get; set; } + public string ProductName { get; set; } = string.Empty; + public double Price { get; set; } + public Dictionary ProductComponents + { + get; + set; + } = new(); + } +} diff --git a/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IComponentLogic.cs b/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IComponentLogic.cs new file mode 100644 index 0000000..731a5d3 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IComponentLogic.cs @@ -0,0 +1,16 @@ +using AbstractSushiBarContracts.BindingModels; +using AbstractSushiBarContracts.SearchModels; +using AbstractSushiBarContracts.ViewModels; + +namespace AbstractSushiBarContracts.BusinessLogicsContracts +{ + public interface IComponentLogic + { + List? ReadList(ComponentSearchModel? model); + ComponentViewModel? ReadElement(ComponentSearchModel model); + bool Create(ComponentBindingModel model); + bool Update(ComponentBindingModel model); + bool Delete(ComponentBindingModel model); + + } +} diff --git a/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IOrderLogic.cs b/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IOrderLogic.cs new file mode 100644 index 0000000..0ff7296 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IOrderLogic.cs @@ -0,0 +1,15 @@ +using AbstractSushiBarContracts.BindingModels; +using AbstractSushiBarContracts.SearchModels; +using AbstractSushiBarContracts.ViewModels; + +namespace AbstractSushiBarContracts.BusinessLogicsContracts +{ + public interface IOrderLogic + { + List? ReadList(OrderSearchModel? model); + bool CreateOrder(OrderBindingModel model); + bool TakeOrderInWork(OrderBindingModel model); + bool FinishOrder(OrderBindingModel model); + bool DeliveryOrder(OrderBindingModel model); + } +} diff --git a/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IProductLogic.cs b/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IProductLogic.cs new file mode 100644 index 0000000..0483b5e --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/BusinessLogicsContracts/IProductLogic.cs @@ -0,0 +1,15 @@ +using AbstractSushiBarContracts.BindingModels; +using AbstractSushiBarContracts.SearchModels; +using AbstractSushiBarContracts.ViewModels; + +namespace AbstractSushiBarContracts.BusinessLogicsContracts +{ + public interface IProductLogic + { + List? ReadList(ProductSearchModel? model); + ProductViewModel? ReadElement(ProductSearchModel model); + bool Create(ProductBindingModel model); + bool Update(ProductBindingModel model); + bool Delete(ProductBindingModel model); + } +} diff --git a/SushiBar/AbstractSushiBarContracts/SearchModels/ComponentSearchModel.cs b/SushiBar/AbstractSushiBarContracts/SearchModels/ComponentSearchModel.cs new file mode 100644 index 0000000..524a085 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/SearchModels/ComponentSearchModel.cs @@ -0,0 +1,8 @@ +namespace AbstractSushiBarContracts.SearchModels +{ + public class ComponentSearchModel + { + public int? Id { get; set; } + public string? ComponentName { get; set; } + } +} diff --git a/SushiBar/AbstractSushiBarContracts/SearchModels/OrderSearchModel.cs b/SushiBar/AbstractSushiBarContracts/SearchModels/OrderSearchModel.cs new file mode 100644 index 0000000..21fd7e3 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/SearchModels/OrderSearchModel.cs @@ -0,0 +1,7 @@ +namespace AbstractSushiBarContracts.SearchModels +{ + public class OrderSearchModel + { + public int? Id { get; set; } + } +} diff --git a/SushiBar/AbstractSushiBarContracts/SearchModels/ProductSearchModel.cs b/SushiBar/AbstractSushiBarContracts/SearchModels/ProductSearchModel.cs new file mode 100644 index 0000000..c68c49d --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/SearchModels/ProductSearchModel.cs @@ -0,0 +1,8 @@ +namespace AbstractSushiBarContracts.SearchModels +{ + public class ProductSearchModel + { + public int? Id { get; set; } + public string? ProductName { get; set; } + } +} diff --git a/SushiBar/AbstractSushiBarContracts/StoragesContracts/IComponentStorage.cs b/SushiBar/AbstractSushiBarContracts/StoragesContracts/IComponentStorage.cs new file mode 100644 index 0000000..e516ea7 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/StoragesContracts/IComponentStorage.cs @@ -0,0 +1,16 @@ +using AbstractSushiBarContracts.BindingModels; +using AbstractSushiBarContracts.SearchModels; +using AbstractSushiBarContracts.ViewModels; + +namespace AbstractSushiBarContracts.StoragesContracts +{ + public interface IComponentStorage + { + List GetFullList(); + List GetFilteredList(ComponentSearchModel model); + ComponentViewModel? GetElement(ComponentSearchModel model); + ComponentViewModel? Insert(ComponentBindingModel model); + ComponentViewModel? Update(ComponentBindingModel model); + ComponentViewModel? Delete(ComponentBindingModel model); + } +} diff --git a/SushiBar/AbstractSushiBarContracts/StoragesContracts/IOrderStorage.cs b/SushiBar/AbstractSushiBarContracts/StoragesContracts/IOrderStorage.cs new file mode 100644 index 0000000..7f4d1eb --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/StoragesContracts/IOrderStorage.cs @@ -0,0 +1,16 @@ +using AbstractSushiBarContracts.BindingModels; +using AbstractSushiBarContracts.SearchModels; +using AbstractSushiBarContracts.ViewModels; + +namespace AbstractSushiBarContracts.StoragesContracts +{ + public interface IOrderStorage + { + List GetFullList(); + List GetFilteredList(OrderSearchModel model); + OrderViewModel? GetElement(OrderSearchModel model); + OrderViewModel? Insert(OrderBindingModel model); + OrderViewModel? Update(OrderBindingModel model); + OrderViewModel? Delete(OrderBindingModel model); + } +} diff --git a/SushiBar/AbstractSushiBarContracts/StoragesContracts/IProductStorage.cs b/SushiBar/AbstractSushiBarContracts/StoragesContracts/IProductStorage.cs new file mode 100644 index 0000000..e93bd8e --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/StoragesContracts/IProductStorage.cs @@ -0,0 +1,16 @@ +using AbstractSushiBarContracts.BindingModels; +using AbstractSushiBarContracts.SearchModels; +using AbstractSushiBarContracts.ViewModels; + +namespace AbstractSushiBarContracts.StoragesContracts +{ + public interface IProductStorage + { + List GetFullList(); + List GetFilteredList(ProductSearchModel model); + ProductViewModel? GetElement(ProductSearchModel model); + ProductViewModel? Insert(ProductBindingModel model); + ProductViewModel? Update(ProductBindingModel model); + ProductViewModel? Delete(ProductBindingModel model); + } +} diff --git a/SushiBar/AbstractSushiBarContracts/ViewModels/ComponentViewModel.cs b/SushiBar/AbstractSushiBarContracts/ViewModels/ComponentViewModel.cs new file mode 100644 index 0000000..bc11a92 --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/ViewModels/ComponentViewModel.cs @@ -0,0 +1,14 @@ +using AbstractSushiBarDataModels.Models; +using System.ComponentModel; + +namespace AbstractSushiBarContracts.ViewModels +{ + public class ComponentViewModel : IComponentModel + { + public int Id { get; set; } + [DisplayName("Название компонента")] + public string ComponentName { get; set; } = string.Empty; + [DisplayName("Цена")] + public double Cost { get; set; } + } +} diff --git a/SushiBar/AbstractSushiBarContracts/ViewModels/OrderViewModel.cs b/SushiBar/AbstractSushiBarContracts/ViewModels/OrderViewModel.cs new file mode 100644 index 0000000..f6318af --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/ViewModels/OrderViewModel.cs @@ -0,0 +1,25 @@ +using AbstractSushiBarDataModels.Enums; +using AbstractSushiBarDataModels.Models; +using System.ComponentModel; + +namespace AbstractSushiBarContracts.ViewModels +{ + public class OrderViewModel : IOrderModel + { + [DisplayName("Номер")] + public int Id { get; set; } + public int ProductId { get; set; } + [DisplayName("Изделие")] + public string ProductName { get; set; } = string.Empty; + [DisplayName("Количество")] + public int Count { get; set; } + [DisplayName("Сумма")] + public double Sum { get; set; } + [DisplayName("Статус")] + public OrderStatus Status { get; set; } = OrderStatus.Неизвестен; + [DisplayName("Дата создания")] + public DateTime DateCreate { get; set; } = DateTime.Now; + [DisplayName("Дата выполнения")] + public DateTime? DateImplement { get; set; } + } +} diff --git a/SushiBar/AbstractSushiBarContracts/ViewModels/ProductViewModel.cs b/SushiBar/AbstractSushiBarContracts/ViewModels/ProductViewModel.cs new file mode 100644 index 0000000..55dbbbf --- /dev/null +++ b/SushiBar/AbstractSushiBarContracts/ViewModels/ProductViewModel.cs @@ -0,0 +1,20 @@ +using AbstractSushiBarDataModels.Models; +using System.ComponentModel; + +namespace AbstractSushiBarContracts.ViewModels +{ + public class ProductViewModel : IProductModel + { + public int Id { get; set; } + [DisplayName("Название изделия")] + public string ProductName { get; set; } = string.Empty; + [DisplayName("Цена")] + public double Price { get; set; } + public Dictionary ProductComponents + { + get; + set; + } = new(); + + } +} diff --git a/AbstractSushiBarDataModels/AbstractSushiBarDataModels/Enums/OrderStatus.cs b/SushiBar/AbstractSushiBarDataModels/Enums/OrderStatus.cs similarity index 100% rename from AbstractSushiBarDataModels/AbstractSushiBarDataModels/Enums/OrderStatus.cs rename to SushiBar/AbstractSushiBarDataModels/Enums/OrderStatus.cs diff --git a/AbstractSushiBarDataModels/AbstractSushiBarDataModels/IId.cs b/SushiBar/AbstractSushiBarDataModels/IId.cs similarity index 100% rename from AbstractSushiBarDataModels/AbstractSushiBarDataModels/IId.cs rename to SushiBar/AbstractSushiBarDataModels/IId.cs diff --git a/AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IComponentModel.cs b/SushiBar/AbstractSushiBarDataModels/Models/IComponentModel.cs similarity index 74% rename from AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IComponentModel.cs rename to SushiBar/AbstractSushiBarDataModels/Models/IComponentModel.cs index 0cb698d..136d0b8 100644 --- a/AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IComponentModel.cs +++ b/SushiBar/AbstractSushiBarDataModels/Models/IComponentModel.cs @@ -1,6 +1,6 @@ namespace AbstractSushiBarDataModels.Models { - internal interface IComponentModel : IId + public interface IComponentModel : IId { string ComponentName { get; } double Cost { get; } diff --git a/AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IOrderModel.cs b/SushiBar/AbstractSushiBarDataModels/Models/IOrderModel.cs similarity index 88% rename from AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IOrderModel.cs rename to SushiBar/AbstractSushiBarDataModels/Models/IOrderModel.cs index 975b9fc..047d1e1 100644 --- a/AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IOrderModel.cs +++ b/SushiBar/AbstractSushiBarDataModels/Models/IOrderModel.cs @@ -2,7 +2,7 @@ namespace AbstractSushiBarDataModels.Models { - internal interface IOrderModel : IId + public interface IOrderModel : IId { int ProductId { get; } int Count { get; } diff --git a/AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IProductModel.cs b/SushiBar/AbstractSushiBarDataModels/Models/IProductModel.cs similarity index 86% rename from AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IProductModel.cs rename to SushiBar/AbstractSushiBarDataModels/Models/IProductModel.cs index 846012f..a921f17 100644 --- a/AbstractSushiBarDataModels/AbstractSushiBarDataModels/Models/IProductModel.cs +++ b/SushiBar/AbstractSushiBarDataModels/Models/IProductModel.cs @@ -3,7 +3,7 @@ using System.Collections.Generic; using System.Linq; namespace AbstractSushiBarDataModels.Models { - internal interface IProductModel : IId + public interface IProductModel : IId { string ProductName { get; } double Price { get; } diff --git a/SushiBar/SushiBar.sln b/SushiBar/SushiBar.sln index 7227a18..1b8646d 100644 --- a/SushiBar/SushiBar.sln +++ b/SushiBar/SushiBar.sln @@ -3,7 +3,11 @@ Microsoft Visual Studio Solution File, Format Version 12.00 # Visual Studio Version 17 VisualStudioVersion = 17.7.34031.279 MinimumVisualStudioVersion = 10.0.40219.1 -Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "SushiBar", "SushiBar\SushiBar.csproj", "{B9AC543F-20EE-47B1-9BC4-3F5DADAD931C}" +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "SushiBar", "SushiBar\SushiBar.csproj", "{B9AC543F-20EE-47B1-9BC4-3F5DADAD931C}" +EndProject +Project("{9A19103F-16F7-4668-BE54-9A1E7A4F7556}") = "AbstractSushiBarDataModels", "AbstractSushiBarDataModels\AbstractSushiBarDataModels.csproj", "{6F64D0ED-EAFC-495F-AFAC-FFC9CD4C53BA}" +EndProject +Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "AbstractSushiBarContracts", "AbstractSushiBarContracts\AbstractSushiBarContracts.csproj", "{E02D432A-1BC9-4C65-B8D3-57EC53336DD3}" EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution @@ -15,6 +19,14 @@ Global {B9AC543F-20EE-47B1-9BC4-3F5DADAD931C}.Debug|Any CPU.Build.0 = Debug|Any CPU {B9AC543F-20EE-47B1-9BC4-3F5DADAD931C}.Release|Any CPU.ActiveCfg = Release|Any CPU {B9AC543F-20EE-47B1-9BC4-3F5DADAD931C}.Release|Any CPU.Build.0 = Release|Any CPU + {6F64D0ED-EAFC-495F-AFAC-FFC9CD4C53BA}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {6F64D0ED-EAFC-495F-AFAC-FFC9CD4C53BA}.Debug|Any CPU.Build.0 = Debug|Any CPU + {6F64D0ED-EAFC-495F-AFAC-FFC9CD4C53BA}.Release|Any CPU.ActiveCfg = Release|Any CPU + {6F64D0ED-EAFC-495F-AFAC-FFC9CD4C53BA}.Release|Any CPU.Build.0 = Release|Any CPU + {E02D432A-1BC9-4C65-B8D3-57EC53336DD3}.Debug|Any CPU.ActiveCfg = Debug|Any CPU + {E02D432A-1BC9-4C65-B8D3-57EC53336DD3}.Debug|Any CPU.Build.0 = Debug|Any CPU + {E02D432A-1BC9-4C65-B8D3-57EC53336DD3}.Release|Any CPU.ActiveCfg = Release|Any CPU + {E02D432A-1BC9-4C65-B8D3-57EC53336DD3}.Release|Any CPU.Build.0 = Release|Any CPU EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE