order by id fix
This commit is contained in:
@@ -1,9 +1,6 @@
|
|||||||
// Auto-generiert von CreateWebshopFiles.ps1
|
// src/Webshop.Application/DTOs/Customers/AddressDto.cs
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using Webshop.Domain.Enums;
|
||||||
using System.Threading.Tasks;
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
namespace Webshop.Application.DTOs.Customers
|
namespace Webshop.Application.DTOs.Customers
|
||||||
{
|
{
|
||||||
@@ -16,5 +13,9 @@ namespace Webshop.Application.DTOs.Customers
|
|||||||
public string PostalCode { get; set; } = string.Empty;
|
public string PostalCode { get; set; } = string.Empty;
|
||||||
public string Country { get; set; } = string.Empty;
|
public string Country { get; set; } = string.Empty;
|
||||||
public AddressType Type { get; set; }
|
public AddressType Type { get; set; }
|
||||||
|
|
||||||
|
// F<>gen Sie auch FirstName und LastName hinzu, falls diese in der Adresse gespeichert sind
|
||||||
|
public string FirstName { get; set; } = string.Empty;
|
||||||
|
public string LastName { get; set; } = string.Empty;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -2,6 +2,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
using Webshop.Application.DTOs.Customers;
|
||||||
using Webshop.Domain.Entities;
|
using Webshop.Domain.Entities;
|
||||||
|
|
||||||
|
|
||||||
@@ -24,8 +25,9 @@ namespace Webshop.Application.DTOs.Orders
|
|||||||
public DateTimeOffset? DeliveredDate { get; set; }
|
public DateTimeOffset? DeliveredDate { get; set; }
|
||||||
public PaymentStatus PaymentStatus { get; set; }
|
public PaymentStatus PaymentStatus { get; set; }
|
||||||
public List<OrderItemDto> OrderItems { get; set; } = new List<OrderItemDto>();
|
public List<OrderItemDto> OrderItems { get; set; } = new List<OrderItemDto>();
|
||||||
public Address ShippingAddress { get; set; } = default!; // << HINZUF<EFBFBD>GEN >>
|
public AddressDto ShippingAddress { get; set; } = default!; // << KORREKTUR: Typ zu AddressDto ge<67>ndert >>
|
||||||
public Address BillingAddress { get; set; } = default!; // << HINZUF<EFBFBD>GEN >>
|
public AddressDto BillingAddress { get; set; } = default!; // << KORREKTUR: Typ zu AddressDto ge<67>ndert >>
|
||||||
|
|
||||||
public string PaymentMethod { get; set; } = string.Empty; // << HINZUF<55>GEN >>
|
public string PaymentMethod { get; set; } = string.Empty; // << HINZUF<55>GEN >>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ using System;
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
using Webshop.Application.DTOs.Customers;
|
||||||
using Webshop.Application.DTOs.Orders;
|
using Webshop.Application.DTOs.Orders;
|
||||||
using Webshop.Domain.Enums; // Wichtig für Enum-Konvertierung
|
using Webshop.Domain.Enums; // Wichtig für Enum-Konvertierung
|
||||||
using Webshop.Domain.Interfaces;
|
using Webshop.Domain.Interfaces;
|
||||||
@@ -45,13 +46,32 @@ namespace Webshop.Application.Services.Admin
|
|||||||
OrderNumber = order.OrderNumber,
|
OrderNumber = order.OrderNumber,
|
||||||
OrderDate = order.OrderDate,
|
OrderDate = order.OrderDate,
|
||||||
CustomerId = order.CustomerId,
|
CustomerId = order.CustomerId,
|
||||||
// << KORREKTUR: String zu Enum parsen >>
|
|
||||||
Status = Enum.TryParse<OrderStatus>(order.OrderStatus, true, out var orderStatus) ? orderStatus : OrderStatus.Pending,
|
Status = Enum.TryParse<OrderStatus>(order.OrderStatus, true, out var orderStatus) ? orderStatus : OrderStatus.Pending,
|
||||||
TotalAmount = order.OrderTotal,
|
TotalAmount = order.OrderTotal,
|
||||||
ShippingAddress = order.ShippingAddress, // Annahme: Address DTO Mapping
|
|
||||||
BillingAddress = order.BillingAddress, // Annahme: Address DTO Mapping
|
// << KORREKTUR: Manuelles Mapping von Address-Entität zu AddressDto >>
|
||||||
|
ShippingAddress = new AddressDto
|
||||||
|
{
|
||||||
|
Id = order.ShippingAddress.Id,
|
||||||
|
Street = order.ShippingAddress.Street,
|
||||||
|
HouseNumber = order.ShippingAddress.HouseNumber,
|
||||||
|
City = order.ShippingAddress.City,
|
||||||
|
PostalCode = order.ShippingAddress.PostalCode,
|
||||||
|
Country = order.ShippingAddress.Country,
|
||||||
|
Type = order.ShippingAddress.Type
|
||||||
|
},
|
||||||
|
BillingAddress = new AddressDto
|
||||||
|
{
|
||||||
|
Id = order.BillingAddress.Id,
|
||||||
|
Street = order.BillingAddress.Street,
|
||||||
|
HouseNumber = order.BillingAddress.HouseNumber,
|
||||||
|
City = order.BillingAddress.City,
|
||||||
|
PostalCode = order.BillingAddress.PostalCode,
|
||||||
|
Country = order.BillingAddress.Country,
|
||||||
|
Type = order.BillingAddress.Type
|
||||||
|
},
|
||||||
|
|
||||||
PaymentMethod = order.PaymentMethod,
|
PaymentMethod = order.PaymentMethod,
|
||||||
// << KORREKTUR: String zu Enum parsen >>
|
|
||||||
PaymentStatus = Enum.TryParse<PaymentStatus>(order.PaymentStatus, true, out var paymentStatus) ? paymentStatus : PaymentStatus.Pending,
|
PaymentStatus = Enum.TryParse<PaymentStatus>(order.PaymentStatus, true, out var paymentStatus) ? paymentStatus : PaymentStatus.Pending,
|
||||||
OrderItems = order.OrderItems.Select(oi => new OrderItemDto
|
OrderItems = order.OrderItems.Select(oi => new OrderItemDto
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ using System;
|
|||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
using Webshop.Application.DTOs.Customers;
|
||||||
using Webshop.Application.DTOs.Orders;
|
using Webshop.Application.DTOs.Orders;
|
||||||
using Webshop.Domain.Entities;
|
using Webshop.Domain.Entities;
|
||||||
using Webshop.Domain.Enums;
|
using Webshop.Domain.Enums;
|
||||||
@@ -163,24 +164,23 @@ namespace Webshop.Application.Services.Customers
|
|||||||
var customer = await _customerRepository.GetByUserIdAsync(userId);
|
var customer = await _customerRepository.GetByUserIdAsync(userId);
|
||||||
if (customer == null)
|
if (customer == null)
|
||||||
{
|
{
|
||||||
return null; // Kein Kunde, kann keine Bestellung abrufen
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Finde die Bestellung und stelle sicher, dass sie zum eingeloggten Kunden gehört
|
|
||||||
var order = await _context.Orders
|
var order = await _context.Orders
|
||||||
.Include(o => o.BillingAddress)
|
.Include(o => o.BillingAddress) // Lade die Address-Entität
|
||||||
.Include(o => o.ShippingAddress)
|
.Include(o => o.ShippingAddress) // Lade die Address-Entität
|
||||||
.Include(o => o.PaymentMethodInfo) // << HINZUFÜGEN, um PaymentMethodInfo zu laden >>
|
.Include(o => o.PaymentMethodInfo)
|
||||||
.Include(o => o.ShippingMethodInfo) // << HINZUFÜGEN, um ShippingMethodInfo zu laden >>
|
|
||||||
.Include(o => o.OrderItems)
|
.Include(o => o.OrderItems)
|
||||||
.ThenInclude(oi => oi.Product) // Optional: Dann das Produkt laden
|
.ThenInclude(oi => oi.Product)
|
||||||
.FirstOrDefaultAsync(o => o.Id == orderId && o.CustomerId == customer.Id);
|
.FirstOrDefaultAsync(o => o.Id == orderId && o.CustomerId == customer.Id);
|
||||||
|
|
||||||
if (order == null)
|
if (order == null)
|
||||||
{
|
{
|
||||||
return null; // Bestellung nicht gefunden oder gehört nicht diesem Kunden
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// << KORREKTUR: Manuelles Mapping von Address-Entität zu AddressDto >>
|
||||||
return new OrderDetailDto
|
return new OrderDetailDto
|
||||||
{
|
{
|
||||||
Id = order.Id,
|
Id = order.Id,
|
||||||
@@ -189,9 +189,27 @@ namespace Webshop.Application.Services.Customers
|
|||||||
CustomerId = order.CustomerId,
|
CustomerId = order.CustomerId,
|
||||||
Status = Enum.TryParse<OrderStatus>(order.OrderStatus, true, out var orderStatus) ? orderStatus : OrderStatus.Pending,
|
Status = Enum.TryParse<OrderStatus>(order.OrderStatus, true, out var orderStatus) ? orderStatus : OrderStatus.Pending,
|
||||||
TotalAmount = order.OrderTotal,
|
TotalAmount = order.OrderTotal,
|
||||||
ShippingAddress = order.ShippingAddress, // Annahme: Address DTO Mapping
|
ShippingAddress = new AddressDto
|
||||||
BillingAddress = order.BillingAddress, // Annahme: Address DTO Mapping
|
{
|
||||||
PaymentMethod = order.PaymentMethod, // << KORREKTUR: Dies ist ein String in Ihrer Entität >>
|
Id = order.ShippingAddress.Id,
|
||||||
|
Street = order.ShippingAddress.Street,
|
||||||
|
HouseNumber = order.ShippingAddress.HouseNumber,
|
||||||
|
City = order.ShippingAddress.City,
|
||||||
|
PostalCode = order.ShippingAddress.PostalCode,
|
||||||
|
Country = order.ShippingAddress.Country,
|
||||||
|
Type = order.ShippingAddress.Type
|
||||||
|
},
|
||||||
|
BillingAddress = new AddressDto
|
||||||
|
{
|
||||||
|
Id = order.BillingAddress.Id,
|
||||||
|
Street = order.BillingAddress.Street,
|
||||||
|
HouseNumber = order.BillingAddress.HouseNumber,
|
||||||
|
City = order.BillingAddress.City,
|
||||||
|
PostalCode = order.BillingAddress.PostalCode,
|
||||||
|
Country = order.BillingAddress.Country,
|
||||||
|
Type = order.BillingAddress.Type
|
||||||
|
},
|
||||||
|
PaymentMethod = order.PaymentMethod,
|
||||||
PaymentStatus = Enum.TryParse<PaymentStatus>(order.PaymentStatus, true, out var paymentStatus) ? paymentStatus : PaymentStatus.Pending,
|
PaymentStatus = Enum.TryParse<PaymentStatus>(order.PaymentStatus, true, out var paymentStatus) ? paymentStatus : PaymentStatus.Pending,
|
||||||
ShippingTrackingNumber = order.ShippingTrackingNumber,
|
ShippingTrackingNumber = order.ShippingTrackingNumber,
|
||||||
ShippedDate = order.ShippedDate,
|
ShippedDate = order.ShippedDate,
|
||||||
|
|||||||
@@ -1,12 +0,0 @@
|
|||||||
using System;
|
|
||||||
using System.Collections.Generic;
|
|
||||||
using System.Linq;
|
|
||||||
using System.Text;
|
|
||||||
using System.Threading.Tasks;
|
|
||||||
|
|
||||||
namespace Webshop.Infrastructure.Repositories
|
|
||||||
{
|
|
||||||
internal class CustomerAddressesRepository
|
|
||||||
{
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Reference in New Issue
Block a user