improvements, fixes, etc...

This commit is contained in:
Loretta 2024-06-21 17:36:02 +02:00
parent 572473d471
commit 5be059cfeb
9 changed files with 108 additions and 42 deletions

View File

@ -1,4 +1,5 @@
using Microsoft.EntityFrameworkCore; using AyCode.Core.Extensions;
using Microsoft.EntityFrameworkCore;
using TIAM.Entities.Products; using TIAM.Entities.Products;
namespace TIAM.Database.DbSets.Products; namespace TIAM.Database.DbSets.Products;
@ -8,7 +9,11 @@ public static class ProductDbSetExtensions
#region Add, Update, Remove #region Add, Update, Remove
public static bool AddProduct(this IProductDbSet ctx, Product product) public static bool AddProduct(this IProductDbSet ctx, Product product)
=> ctx.Products.Add(product).State == EntityState.Added; {
if (product.Id.IsNullOrEmpty()) product.Id = Guid.NewGuid();
return ctx.Products.Add(product).State == EntityState.Added;
}
public static bool UpdateProduct(this IProductDbSet ctx, Product product) public static bool UpdateProduct(this IProductDbSet ctx, Product product)
=> ctx.Products.Update(product).State == EntityState.Modified; => ctx.Products.Update(product).State == EntityState.Modified;

View File

@ -8,7 +8,7 @@ using TIAM.Entities.Users;
namespace TIAM.Entities.ServiceProviders; namespace TIAM.Entities.ServiceProviders;
[Table("ServiceProviders")] [Table("ServiceProviders")]
public class Company : AcCompany<User, UserToCompany, Profile, Address>, ICompany, IProductsRelation public class Company : AcCompany<User, UserToCompany, Profile, Address>, ICompany, IProductsRelation, IProfileRelation<Profile>
{ {
public virtual List<Product> Products { get; set; } = new(); public virtual List<Product> Products { get; set; } = new();

View File

@ -7,12 +7,21 @@ using TIAM.Entities.Users;
namespace TIAM.Models.Dtos.Users namespace TIAM.Models.Dtos.Users
{ {
public class UserModelDtoDetail : AcUserModelDtoDetailBase<UserDtoDetail, Profile, Company, UserToCompany, Address>, IProductsRelation, IUserModelDtoMinBase public class UserModelDtoDetail : AcUserModelDtoDetailBase<UserDtoDetail, Profile, Company, UserToCompany, Address>, IProductsRelation, IUserModelDtoMinBase, IProfileForeignKey
{ {
public Guid ProfileId
{
get => ProfileDto.Id;
set {}
}
public List<UserProductMapping> UserProductMappings { get; set; } public List<UserProductMapping> UserProductMappings { get; set; }
public List<Product> Products { get; set; } public List<Product> Products { get; set; }
public UserModelDtoDetail() { } public UserModelDtoDetail()
{
}
public UserModelDtoDetail(User user) : base(user) public UserModelDtoDetail(User user) : base(user)
{ {
if (user.Products.Count == 0) return; if (user.Products.Count == 0) return;
@ -40,6 +49,5 @@ namespace TIAM.Models.Dtos.Users
//TODO: Models... - J. //TODO: Models... - J.
throw new NotImplementedException("CreateMainEntity"); throw new NotImplementedException("CreateMainEntity");
} }
} }
} }

View File

@ -60,7 +60,7 @@
<DetailRowTemplate> <DetailRowTemplate>
<DxTabs> <DxTabs>
<DxTabPage Text="Profile"> <DxTabPage Text="Profile">
<ProfileGridComponent ProfileId="((Company)context.DataItem).ProfileId" KeyboardNavigationEnabled="true" /> <ProfileGridComponent ParentData="((Company)context.DataItem)" KeyboardNavigationEnabled="true" />
</DxTabPage> </DxTabPage>
<DxTabPage Text="Products"> <DxTabPage Text="Products">
<ProductDetailGridComponent ContextId="((Company)context.DataItem).Id" KeyboardNavigationEnabled="true" /> <ProductDetailGridComponent ContextId="((Company)context.DataItem).Id" KeyboardNavigationEnabled="true" />

View File

@ -13,6 +13,8 @@
@using TIAM.Entities.Addresses @using TIAM.Entities.Addresses
@using TIAMSharedUI.Shared.Components.Grids @using TIAMSharedUI.Shared.Components.Grids
@using AyCode.Core @using AyCode.Core
@using TIAM.Entities.Products
@using TIAM.Entities.Users
@layout AdminLayout @layout AdminLayout
@inject IEnumerable<IAcLogWriterClientBase> LogWriters @inject IEnumerable<IAcLogWriterClientBase> LogWriters
@inject IStringLocalizer<TIAMResources> localizer @inject IStringLocalizer<TIAMResources> localizer
@ -125,12 +127,12 @@
<CompaniesNestedUserProductMapping CurrentCompany="(TIAM.Entities.ServiceProviders.Company)context.DataItem" KeyboardNavigationEnabled="true" /> <CompaniesNestedUserProductMapping CurrentCompany="(TIAM.Entities.ServiceProviders.Company)context.DataItem" KeyboardNavigationEnabled="true" />
</DetailRowTemplate> *@ </DetailRowTemplate> *@
<DetailRowTemplate> <DetailRowTemplate>
<DxTabs> <DxTabs ActiveTabIndexChanged="ActiveTabIndexChanged">
<DxTabPage Text="Profile"> <DxTabPage Text="Profile">
<ProfileGridComponent ProfileId="((Company)context.DataItem).ProfileId" KeyboardNavigationEnabled="true" /> <ProfileGridComponent ParentData="((Company)context.DataItem)" KeyboardNavigationEnabled="true" />
</DxTabPage> </DxTabPage>
<DxTabPage Text="Products"> <DxTabPage Text="Products">
<ProductDetailGridComponent ProductGrid="" ParentData="(Company)context.DataItem" KeyboardNavigationEnabled="true" /> <ProductDetailGridComponent @ref="_productDetailGridComponent" OnGridEditModelSaving="OnProductGridItemSaving" ParentData="(Company)context.DataItem" KeyboardNavigationEnabled="true" />
</DxTabPage> </DxTabPage>
<DxTabPage Text="Address"> <DxTabPage Text="Address">
<AddressDetailGridComponent ParentData="((Company)context.DataItem).Profile" KeyboardNavigationEnabled="true" /> <AddressDetailGridComponent ParentData="((Company)context.DataItem).Profile" KeyboardNavigationEnabled="true" />
@ -163,6 +165,8 @@
@code { @code {
private LoggerClient<ManageServiceProviders> _logger; private LoggerClient<ManageServiceProviders> _logger;
private ProductDetailGridComponent? _productDetailGridComponent;
//public Transfer myModel = new Transfer(); //public Transfer myModel = new Transfer();
//public List<Company> ServiceProviderDataList { get; set; } //public List<Company> ServiceProviderDataList { get; set; }
@ -173,7 +177,7 @@
private CompanyGrid _gridCompany; private CompanyGrid _gridCompany;
private bool _autoCollapseDetailRow; private bool _autoCollapseDetailRow;
private Company CompanyToSetOwner = null; private Company _companyToSetOwner = null;
public List<string> IgnoreList = public List<string> IgnoreList =
[ [
@ -193,6 +197,7 @@
DateTime StartDate { get; set; } = DateTime.Today; DateTime StartDate { get; set; } = DateTime.Today;
DxSchedulerDataStorage _dataStorage = new(); DxSchedulerDataStorage _dataStorage = new();
void SendMail(Company item) void SendMail(Company item)
{ {
_logger.Info($"Sending mail to {item.OwnerId}, {item.Id}"); _logger.Info($"Sending mail to {item.OwnerId}, {item.Id}");
@ -207,7 +212,7 @@
void SetOwnerPopup(Company item) void SetOwnerPopup(Company item)
{ {
_logger.Info($"Setting owner of {item.OwnerId}, {item.Id}"); _logger.Info($"Setting owner of {item.OwnerId}, {item.Id}");
CompanyToSetOwner = item; _companyToSetOwner = item;
_setOwnerPopupVisible = true; _setOwnerPopupVisible = true;
} }
@ -219,15 +224,15 @@
//overwrite ServiceProvider ownerid //overwrite ServiceProvider ownerid
//var target = await serviceProviderDataService.GetServiceProviderByIdAsync(CompanyToSetOwner.Id); //var target = await serviceProviderDataService.GetServiceProviderByIdAsync(CompanyToSetOwner.Id);
if (CompanyToSetOwner == null) if (_companyToSetOwner == null)
{ {
return null; return null;
} }
else else
{ {
CompanyToSetOwner.OwnerId = userModelDto.Id; _companyToSetOwner.OwnerId = userModelDto.Id;
var result = await serviceProviderDataService.UpdateServiceProviderAsync(CompanyToSetOwner); var result = await serviceProviderDataService.UpdateServiceProviderAsync(_companyToSetOwner);
CompanyToSetOwner = null; _companyToSetOwner = null;
return result; return result;
} }
} }
@ -306,6 +311,30 @@
await base.OnInitializedAsync(); await base.OnInitializedAsync();
} }
private void OnProductGridItemSaving(GridEditModelSavingEventArgs e)
{
_logger.Detail($"OnProductGridItemSaving");
var company = _productDetailGridComponent!.ParentData as Company;
if (company == null || company.OwnerId.IsNullOrEmpty())
{
_logger.Error($"OnProductGridItemSaving; company == null || company.OwnerId.IsNullOrEmpty(); company.OwnerId: {company?.OwnerId}");
return;
}
var product = ((Product)e.EditModel);
if (e.IsNew)
{
if (product.Id.IsNullOrEmpty()) product.Id = Guid.NewGuid();
product.ServiceProviderId = company.Id;
product.UserProductMappings.Add(new UserProductMapping(company.OwnerId.Value, product.Id) { IsAdmin = true });
}
else
{ }
}
void ColumnChooserButton_Click() void ColumnChooserButton_Click()
{ {
_gridCompany.ShowColumnChooser(); _gridCompany.ShowColumnChooser();
@ -328,4 +357,10 @@
_gridCompany.ExpandDetailRow(0); _gridCompany.ExpandDetailRow(0);
_gridCompany.EndUpdate(); _gridCompany.EndUpdate();
} }
private void ActiveTabIndexChanged(int index)
{
_logger.Detail($"ActiveTabIndexChanged");
}
} }

View File

@ -97,7 +97,7 @@
<DetailRowTemplate> <DetailRowTemplate>
<DxTabs> <DxTabs>
<DxTabPage Text="Profile"> <DxTabPage Text="Profile">
<ProfileGridComponent ProfileId="((UserModelDtoDetail)context.DataItem).ProfileDto.Id" KeyboardNavigationEnabled="true" /> <ProfileGridComponent ParentData="((UserModelDtoDetail)context.DataItem)" KeyboardNavigationEnabled="true" />
</DxTabPage> </DxTabPage>
<DxTabPage Text="Address"> <DxTabPage Text="Address">
<AddressDetailGridComponent ParentData="((UserModelDtoDetail)context.DataItem).ProfileDto" KeyboardNavigationEnabled="true" /> <AddressDetailGridComponent ParentData="((UserModelDtoDetail)context.DataItem).ProfileDto" KeyboardNavigationEnabled="true" />

View File

@ -23,7 +23,7 @@
@inject AdminSignalRClient AdminSignalRClient; @inject AdminSignalRClient AdminSignalRClient;
<ProductDetailGrid @ref="ProductGrid" <ProductDetailGrid @ref="_productGrid"
DataSource="ParentData.Products" DataSource="ParentData.Products"
Logger="_logger" Logger="_logger"
SignalRClient="AdminSignalRClient" SignalRClient="AdminSignalRClient"
@ -50,7 +50,7 @@
<DetailRowTemplate> <DetailRowTemplate>
<DxTabs> <DxTabs>
<DxTabPage Text="Profile"> <DxTabPage Text="Profile">
<ProfileGridComponent ProfileId="((Product)context.DataItem).ProfileId" KeyboardNavigationEnabled="true" /> <ProfileGridComponent ParentData="((Product)context.DataItem)" KeyboardNavigationEnabled="true" />
</DxTabPage> </DxTabPage>
</DxTabs> </DxTabs>
</DetailRowTemplate> </DetailRowTemplate>
@ -82,8 +82,9 @@
[Parameter] public bool KeyboardNavigationEnabled { get; set; } [Parameter] public bool KeyboardNavigationEnabled { get; set; }
[Parameter] public Guid? ContextId { get; set; } [Parameter] public Guid? ContextId { get; set; }
[Parameter] public IProductsRelation ParentData { get; set; } = null!; [Parameter] public IProductsRelation ParentData { get; set; } = null!;
[Parameter] public EventCallback<GridEditModelSavingEventArgs> OnGridEditModelSaving { get; set; }
public ProductDetailGrid ProductGrid = null!; private ProductDetailGrid _productGrid = null!;
private LoggerClient<ProductDetailGridComponent> _logger = null!; private LoggerClient<ProductDetailGridComponent> _logger = null!;
protected override void OnInitialized() protected override void OnInitialized()
{ {
@ -97,31 +98,40 @@
{ {
_logger.Debug($"Saving: {args.DataItem.Name}, {args.DataItem.ServiceProviderId}"); _logger.Debug($"Saving: {args.DataItem.Name}, {args.DataItem.ServiceProviderId}");
ProductGrid.SaveChangesAsync(); //ProductGrid.SaveChangesAsync();
} }
private void DataItemSaving(GridEditModelSavingEventArgs e) public async Task DataItemSaving(GridEditModelSavingEventArgs e)
{
await OnGridEditModelSaving.InvokeAsync(e);
if (e.Cancel) return;
var product = ((Product)e.EditModel);
if (e.IsNew)
{ {
_logger.Debug($"DataItemSaving"); _logger.Debug($"DataItemSaving");
((Product)e.EditModel).ServiceProviderId = (Guid)ContextId!;
Guid _profileId = Guid.NewGuid();
((Product)e.EditModel).Profile = new Profile();
((Product)e.EditModel).Profile.Id = _profileId;
((Product)e.EditModel).ProfileId = _profileId;
((Product)e.EditModel).Profile.Name = ((Product)e.EditModel).Name;
Guid _addressId = Guid.NewGuid();
((Product)e.EditModel).Profile.Address = new Address();
((Product)e.EditModel).Profile.AddressId = _addressId;
((Product)e.EditModel).Profile.Address.Id = _addressId;
((Product)e.EditModel).UserProductMappings.Add(new UserProductMapping(Guid.NewGuid, ParentData.));
var profileId = Guid.NewGuid();
product.Profile = new Profile(profileId, product.Name);
product.ProfileId = profileId;
var addressId = Guid.NewGuid();
product.Profile.Address = new Address(addressId);
product.Profile.AddressId = addressId;
//((Product)e.EditModel).UserProductMappings.Add(new UserProductMapping(Guid.NewGuid, ParentData.));
}
else
{
_logger.Debug($"Saving: {((Product)e.EditModel).Name}, {((Product)e.EditModel).ServiceProviderId}"); }
_logger.Debug($"Saving: {product.Name}, {product.ServiceProviderId}");
//var result = serviceProviderDataService.CreateProductAsync((Product)e.EditModel); //var result = serviceProviderDataService.CreateProductAsync((Product)e.EditModel);
_logger.Debug($"saved product: {((Product)e.EditModel).ServiceProviderId}"); //_logger.Debug($"saved product: {product.ServiceProviderId}");
} }
private void DataItemDeleting(GridDataItemDeletingEventArgs obj) private void DataItemDeleting(GridDataItemDeletingEventArgs obj)

View File

@ -8,13 +8,17 @@
@using AyCode.Services.Loggers @using AyCode.Services.Loggers
@using TIAM.Core.Loggers @using TIAM.Core.Loggers
@using AyCode.Core @using AyCode.Core
@using AyCode.Interfaces.Profiles.Dtos
@using TIAM.Entities.Addresses
@using TIAM.Entities.Profiles
@using Profile = TIAM.Entities.Profiles.Profile @using Profile = TIAM.Entities.Profiles.Profile
@inject IServiceProviderDataService serviceProviderDataService @inject IServiceProviderDataService serviceProviderDataService
@inject IUserDataService userDataService @inject IUserDataService userDataService
@inject IEnumerable<IAcLogWriterClientBase> LogWriters @inject IEnumerable<IAcLogWriterClientBase> LogWriters
@inject AdminSignalRClient AdminSignalRClient @inject AdminSignalRClient AdminSignalRClient
<ProfileDetailGrid @ref="_profileGrid" <ProfileDetailGrid @ref="_profileGrid"
ContextId="ProfileId" ContextIds="new[] {ParentData.ProfileId}"
Logger="_logger" Logger="_logger"
SignalRClient="AdminSignalRClient" SignalRClient="AdminSignalRClient"
PageSize="5" PageSize="5"
@ -51,8 +55,8 @@
@code { @code {
[Parameter] [Parameter]
public bool KeyboardNavigationEnabled { get; set; } public bool KeyboardNavigationEnabled { get; set; }
[Parameter]
public Guid ProfileId { get; set; } = Guid.Empty; [Parameter] public IProfileForeignKey ParentData { get; set; } = null!;
private ProfileDetailGrid _profileGrid = null!; private ProfileDetailGrid _profileGrid = null!;
private LoggerClient<ProfileGridComponent> _logger = null!; private LoggerClient<ProfileGridComponent> _logger = null!;
@ -66,7 +70,7 @@
protected override void OnParametersSet() protected override void OnParametersSet()
{ {
_logger.DebugConditional(ProfileId.ToString()); _logger.DebugConditional(ParentData.ProfileId.ToString());
base.OnParametersSet(); base.OnParametersSet();
} }

View File

@ -59,6 +59,8 @@ namespace TIAMWebApp.Server.Controllers
case TrackingState.Remove: case TrackingState.Remove:
return await adminDal.RemoveCompanyAsync(company); return await adminDal.RemoveCompanyAsync(company);
case TrackingState.Get:
case TrackingState.GetAll:
default: default:
throw new ArgumentOutOfRangeException(nameof(trackingState), trackingState, null); throw new ArgumentOutOfRangeException(nameof(trackingState), trackingState, null);
} }
@ -262,6 +264,8 @@ namespace TIAMWebApp.Server.Controllers
case TrackingState.Remove: case TrackingState.Remove:
return await adminDal.RemoveCarAsync(car); return await adminDal.RemoveCarAsync(car);
case TrackingState.Get:
case TrackingState.GetAll:
default: default:
throw new ArgumentOutOfRangeException(nameof(trackingState), trackingState, null); throw new ArgumentOutOfRangeException(nameof(trackingState), trackingState, null);
} }