adminorder
This commit is contained in:
@@ -3,9 +3,10 @@ using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Threading.Tasks;
|
||||
using Webshop.Application;
|
||||
using Webshop.Application.DTOs.Customers;
|
||||
using Webshop.Application.DTOs.Orders;
|
||||
using Webshop.Domain.Enums; // Wichtig für Enum-Konvertierung
|
||||
using Webshop.Domain.Enums;
|
||||
using Webshop.Domain.Interfaces;
|
||||
|
||||
namespace Webshop.Application.Services.Admin
|
||||
@@ -19,28 +20,32 @@ namespace Webshop.Application.Services.Admin
|
||||
_orderRepository = orderRepository;
|
||||
}
|
||||
|
||||
public async Task<IEnumerable<OrderSummaryDto>> GetAllOrdersAsync()
|
||||
public async Task<ServiceResult<IEnumerable<OrderSummaryDto>>> GetAllOrdersAsync()
|
||||
{
|
||||
var orders = await _orderRepository.GetAllAsync();
|
||||
return orders.Select(o => new OrderSummaryDto
|
||||
var dtos = orders.Select(o => new OrderSummaryDto
|
||||
{
|
||||
Id = o.Id,
|
||||
OrderNumber = o.OrderNumber,
|
||||
OrderDate = o.OrderDate,
|
||||
CustomerName = o.Customer != null ? $"{o.Customer.FirstName} {o.Customer.LastName}" : o.GuestEmail ?? "Gastbestellung",
|
||||
TotalAmount = o.OrderTotal,
|
||||
// << KORREKTUR: String zu Enum parsen >>
|
||||
Status = Enum.TryParse<OrderStatus>(o.OrderStatus, true, out var orderStatus) ? orderStatus : OrderStatus.Pending,
|
||||
PaymentStatus = Enum.TryParse<PaymentStatus>(o.PaymentStatus, true, out var paymentStatus) ? paymentStatus : PaymentStatus.Pending
|
||||
}).ToList();
|
||||
|
||||
return ServiceResult.Ok<IEnumerable<OrderSummaryDto>>(dtos);
|
||||
}
|
||||
|
||||
public async Task<OrderDetailDto?> GetOrderByIdAsync(Guid id)
|
||||
public async Task<ServiceResult<OrderDetailDto>> GetOrderByIdAsync(Guid id)
|
||||
{
|
||||
var order = await _orderRepository.GetByIdAsync(id);
|
||||
if (order == null) return null;
|
||||
if (order == null)
|
||||
{
|
||||
return ServiceResult.Fail<OrderDetailDto>(ServiceResultType.NotFound, $"Bestellung mit ID '{id}' nicht gefunden.");
|
||||
}
|
||||
|
||||
return new OrderDetailDto
|
||||
var orderDetailDto = new OrderDetailDto
|
||||
{
|
||||
Id = order.Id,
|
||||
OrderNumber = order.OrderNumber,
|
||||
@@ -48,8 +53,6 @@ namespace Webshop.Application.Services.Admin
|
||||
CustomerId = order.CustomerId,
|
||||
Status = Enum.TryParse<OrderStatus>(order.OrderStatus, true, out var orderStatus) ? orderStatus : OrderStatus.Pending,
|
||||
TotalAmount = order.OrderTotal,
|
||||
|
||||
// << KORREKTUR: Manuelles Mapping von Address-Entität zu AddressDto >>
|
||||
ShippingAddress = new AddressDto
|
||||
{
|
||||
Id = order.ShippingAddress.Id,
|
||||
@@ -70,7 +73,6 @@ namespace Webshop.Application.Services.Admin
|
||||
Country = order.BillingAddress.Country,
|
||||
Type = order.BillingAddress.Type
|
||||
},
|
||||
|
||||
PaymentMethod = order.PaymentMethod,
|
||||
PaymentStatus = Enum.TryParse<PaymentStatus>(order.PaymentStatus, true, out var paymentStatus) ? paymentStatus : PaymentStatus.Pending,
|
||||
OrderItems = order.OrderItems.Select(oi => new OrderItemDto
|
||||
@@ -85,26 +87,33 @@ namespace Webshop.Application.Services.Admin
|
||||
TotalPrice = oi.TotalPrice
|
||||
}).ToList()
|
||||
};
|
||||
|
||||
return ServiceResult.Ok(orderDetailDto);
|
||||
}
|
||||
|
||||
public async Task<(bool Success, string? ErrorMessage)> UpdateOrderStatusAsync(Guid id, OrderStatus newStatus)
|
||||
public async Task<ServiceResult> UpdateOrderStatusAsync(Guid id, OrderStatus newStatus)
|
||||
{
|
||||
if (!Enum.IsDefined(typeof(OrderStatus), newStatus))
|
||||
{
|
||||
return ServiceResult.Fail(ServiceResultType.InvalidInput, $"Der Status '{newStatus}' ist ungültig.");
|
||||
}
|
||||
|
||||
var order = await _orderRepository.GetByIdAsync(id);
|
||||
if (order == null)
|
||||
{
|
||||
return (false, "Bestellung nicht gefunden.");
|
||||
return ServiceResult.Fail(ServiceResultType.NotFound, $"Bestellung mit ID '{id}' nicht gefunden.");
|
||||
}
|
||||
|
||||
// << KORREKTUR: Enum zu String konvertieren >>
|
||||
order.OrderStatus = newStatus.ToString();
|
||||
|
||||
// Hier könnte zusätzliche Logik stehen (z.B. Tracking-Nummer verlangen)
|
||||
if (newStatus == OrderStatus.Shipped && string.IsNullOrEmpty(order.ShippingTrackingNumber))
|
||||
{
|
||||
// Hier könnten Sie Logik hinzufügen, um eine Tracking-Nummer zu verlangen
|
||||
// return ServiceResult.Fail(ServiceResultType.InvalidInput, "Für den Status 'Versandt' wird eine Tracking-Nummer benötigt.");
|
||||
}
|
||||
|
||||
await _orderRepository.UpdateAsync(order);
|
||||
return (true, null);
|
||||
return ServiceResult.Ok();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user