discount und summary
This commit is contained in:
@@ -1,24 +1,86 @@
|
||||
// Auto-generiert von CreateWebshopFiles.ps1
|
||||
// src/Webshop.Application/DTOs/Discounts/DiscountDto.cs
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
|
||||
using Webshop.Domain.Enums;
|
||||
|
||||
namespace Webshop.Application.DTOs.Discounts
|
||||
{
|
||||
/// <summary>
|
||||
/// Repr<70>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;
|
||||
public DiscountType Type { get; set; }
|
||||
public decimal Value { get; set; }
|
||||
public string? CouponCode { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Der Typ des Rabatts. 'Percentage' f<>r prozentuale Rabatte, 'FixedAmount' f<>r feste Betr<74>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<30>.
|
||||
/// </summary>
|
||||
public decimal DiscountValue { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Das Datum, an dem der Rabatt aktiv wird.
|
||||
/// </summary>
|
||||
public DateTimeOffset StartDate { get; set; }
|
||||
public DateTimeOffset EndDate { 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; }
|
||||
public int? MaxUses { get; set; }
|
||||
public int CurrentUses { 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<65>st werden kann.
|
||||
/// </summary>
|
||||
public int? MaximumUsageCount { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Die aktuelle Anzahl der Einl<6E>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>();
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -1,46 +1,88 @@
|
||||
// src/Webshop.Application/DTOs/Admin/AdminShopInfoDto.cs
|
||||
// src/Webshop.Application/DTOs/Shop/AdminShopInfoDto.cs
|
||||
using System.ComponentModel.DataAnnotations;
|
||||
|
||||
namespace Webshop.Application.DTOs.Shop
|
||||
{
|
||||
/// <summary>
|
||||
/// Repräsentiert alle zentralen Stammdaten des Shops für die administrative Verwaltung.
|
||||
/// </summary>
|
||||
public class AdminShopInfoDto
|
||||
{
|
||||
/// <summary>
|
||||
/// Der offizielle Name des Webshops.
|
||||
/// </summary>
|
||||
[Required, MaxLength(255)]
|
||||
public string ShopName { get; set; } = string.Empty;
|
||||
|
||||
/// <summary>
|
||||
/// Ein kurzer Marketing-Slogan, der auf der Startseite angezeigt werden kann.
|
||||
/// </summary>
|
||||
[MaxLength(500)]
|
||||
public string? Slogan { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Die primäre Kontakt-E-Mail-Adresse für Kundenanfragen.
|
||||
/// </summary>
|
||||
[Required, EmailAddress, MaxLength(255)]
|
||||
public string ContactEmail { get; set; } = string.Empty;
|
||||
|
||||
/// <summary>
|
||||
/// Die offizielle Telefonnummer des Shops.
|
||||
/// </summary>
|
||||
[Phone, MaxLength(50)]
|
||||
public string? PhoneNumber { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Straße und Hausnummer der Firmenadresse.
|
||||
/// </summary>
|
||||
[MaxLength(255)]
|
||||
public string? Street { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Stadt der Firmenadresse.
|
||||
/// </summary>
|
||||
[MaxLength(100)]
|
||||
public string? City { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Postleitzahl der Firmenadresse.
|
||||
/// </summary>
|
||||
[MaxLength(20)]
|
||||
public string? PostalCode { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Land der Firmenadresse.
|
||||
/// </summary>
|
||||
[MaxLength(100)]
|
||||
public string? Country { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Die Umsatzsteuer-Identifikationsnummer des Unternehmens.
|
||||
/// </summary>
|
||||
[MaxLength(50)]
|
||||
public string? VatNumber { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Die Handelsregisternummer des Unternehmens.
|
||||
/// </summary>
|
||||
[MaxLength(100)]
|
||||
public string? CompanyRegistrationNumber { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Die URL zur offiziellen Facebook-Seite.
|
||||
/// </summary>
|
||||
[Url, MaxLength(255)]
|
||||
public string? FacebookUrl { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Die URL zum offiziellen Instagram-Profil.
|
||||
/// </summary>
|
||||
[Url, MaxLength(255)]
|
||||
public string? InstagramUrl { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Die URL zum offiziellen Twitter/X-Profil.
|
||||
/// </summary>
|
||||
[Url, MaxLength(255)]
|
||||
public string? TwitterUrl { get; set; }
|
||||
}
|
||||
|
||||
@@ -1,19 +1,64 @@
|
||||
// src/Webshop.Application/DTOs/Shop/PublicShopInfoDto.cs
|
||||
namespace Webshop.Application.DTOs.Shop
|
||||
{
|
||||
// Dieses DTO enthält nur die Informationen, die ein normaler Kunde sehen soll.
|
||||
/// <summary>
|
||||
/// Enthält die öffentlichen Stammdaten des Shops, die für Kunden sichtbar sind (z.B. im Footer oder auf der Kontaktseite).
|
||||
/// </summary>
|
||||
public class PublicShopInfoDto
|
||||
{
|
||||
/// <summary>
|
||||
/// Der offizielle Name des Webshops.
|
||||
/// </summary>
|
||||
public string ShopName { get; set; } = string.Empty;
|
||||
|
||||
/// <summary>
|
||||
/// Ein kurzer Marketing-Slogan.
|
||||
/// </summary>
|
||||
public string? Slogan { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Die primäre Kontakt-E-Mail-Adresse.
|
||||
/// </summary>
|
||||
public string ContactEmail { get; set; } = string.Empty;
|
||||
|
||||
/// <summary>
|
||||
/// Die offizielle Telefonnummer.
|
||||
/// </summary>
|
||||
public string? PhoneNumber { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Straße und Hausnummer.
|
||||
/// </summary>
|
||||
public string? Street { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Stadt.
|
||||
/// </summary>
|
||||
public string? City { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Postleitzahl.
|
||||
/// </summary>
|
||||
public string? PostalCode { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// Land.
|
||||
/// </summary>
|
||||
public string? Country { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// URL zur Facebook-Seite.
|
||||
/// </summary>
|
||||
public string? FacebookUrl { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// URL zum Instagram-Profil.
|
||||
/// </summary>
|
||||
public string? InstagramUrl { get; set; }
|
||||
|
||||
/// <summary>
|
||||
/// URL zum Twitter/X-Profil.
|
||||
/// </summary>
|
||||
public string? TwitterUrl { get; set; }
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user