86 lines
3.0 KiB
C#
86 lines
3.0 KiB
C#
// src/Webshop.Application/DTOs/Discounts/DiscountDto.cs
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using Webshop.Domain.Enums;
|
|
|
|
namespace Webshop.Application.DTOs.Discounts
|
|
{
|
|
/// <summary>
|
|
/// Repräsentiert einen Rabatt mit all seinen Konfigurationen und Zuweisungen.
|
|
/// </summary>
|
|
public class DiscountDto
|
|
{
|
|
public Guid Id { get; set; }
|
|
|
|
/// <summary>
|
|
/// Der Name des Rabatts (z.B. "Sommerschlussverkauf", "10% auf alles").
|
|
/// </summary>
|
|
public string Name { get; set; } = string.Empty;
|
|
|
|
/// <summary>
|
|
/// Der Typ des Rabatts. 'Percentage' für prozentuale Rabatte, 'FixedAmount' für feste Beträge.
|
|
/// </summary>
|
|
public DiscountType DiscountType { get; set; }
|
|
|
|
/// <summary>
|
|
/// Der Wert des Rabatts. Bei 'Percentage' z.B. 10 für 10%. Bei 'FixedAmount' z.B. 5 für 5,00€.
|
|
/// </summary>
|
|
public decimal DiscountValue { get; set; }
|
|
|
|
/// <summary>
|
|
/// Das Datum, an dem der Rabatt aktiv wird.
|
|
/// </summary>
|
|
public DateTimeOffset StartDate { get; set; }
|
|
|
|
/// <summary>
|
|
/// Optionales Enddatum. Wenn null, ist der Rabatt unbegrenzt gültig.
|
|
/// </summary>
|
|
public DateTimeOffset? EndDate { get; set; }
|
|
|
|
/// <summary>
|
|
/// Gibt an, ob der Rabatt derzeit aktiv ist und angewendet werden kann.
|
|
/// </summary>
|
|
public bool IsActive { get; set; }
|
|
|
|
/// <summary>
|
|
/// Wenn 'true', muss ein Gutscheincode eingegeben werden, um den Rabatt zu erhalten.
|
|
/// </summary>
|
|
public bool RequiresCouponCode { get; set; }
|
|
|
|
/// <summary>
|
|
/// Der Gutscheincode, der eingegeben werden muss (z.B. "SUMMER2025"). Muss eindeutig sein.
|
|
/// </summary>
|
|
public string? CouponCode { get; set; }
|
|
|
|
/// <summary>
|
|
/// Der Mindestbestellwert, der erreicht werden muss, damit der Rabatt angewendet wird.
|
|
/// </summary>
|
|
public decimal? MinimumOrderAmount { get; set; }
|
|
|
|
/// <summary>
|
|
/// Die maximale Anzahl, wie oft dieser Rabatt insgesamt eingelöst werden kann.
|
|
/// </summary>
|
|
public int? MaximumUsageCount { get; set; }
|
|
|
|
/// <summary>
|
|
/// Die aktuelle Anzahl der Einlösungen. Wird vom System verwaltet.
|
|
/// </summary>
|
|
public int CurrentUsageCount { get; set; }
|
|
|
|
/// <summary>
|
|
/// Eine interne Beschreibung für den Admin.
|
|
/// </summary>
|
|
public string? Description { get; set; }
|
|
|
|
/// <summary>
|
|
/// Eine Liste von Produkt-IDs, auf die dieser Rabatt exklusiv angewendet wird.
|
|
/// Wenn leer, gilt der Rabatt für alle Produkte (sofern keine Kategorien zugewiesen sind).
|
|
/// </summary>
|
|
public List<Guid> AssignedProductIds { get; set; } = new List<Guid>();
|
|
|
|
/// <summary>
|
|
/// Eine Liste von Kategorie-IDs. Der Rabatt wird auf alle Produkte in diesen Kategorien angewendet.
|
|
/// </summary>
|
|
public List<Guid> AssignedCategoryIds { get; set; } = new List<Guid>();
|
|
}
|
|
} |