feat: 新增财务交易流水后端模块

This commit is contained in:
2026-03-04 11:33:29 +08:00
parent 2970134200
commit d437b146d1
24 changed files with 2602 additions and 0 deletions

View File

@@ -0,0 +1,173 @@
using TakeoutSaaS.Domain.Finance.Enums;
using TakeoutSaaS.Domain.Orders.Enums;
using TakeoutSaaS.Domain.Payments.Enums;
namespace TakeoutSaaS.Domain.Finance.Models;
/// <summary>
/// 交易流水统一记录。
/// </summary>
public sealed record FinanceTransactionRecord
{
/// <summary>
/// 来源类型。
/// </summary>
public required FinanceTransactionSourceType SourceType { get; init; }
/// <summary>
/// 来源标识。
/// </summary>
public required long SourceId { get; init; }
/// <summary>
/// 所属门店。
/// </summary>
public required long StoreId { get; init; }
/// <summary>
/// 交易单号。
/// </summary>
public string? TransactionNo { get; init; }
/// <summary>
/// 交易类型。
/// </summary>
public required FinanceTransactionType TransactionType { get; init; }
/// <summary>
/// 关联订单标识。
/// </summary>
public long? OrderId { get; init; }
/// <summary>
/// 关联订单号。
/// </summary>
public string? OrderNo { get; init; }
/// <summary>
/// 渠道。
/// </summary>
public DeliveryType? DeliveryType { get; init; }
/// <summary>
/// 支付方式。
/// </summary>
public PaymentMethod? PaymentMethod { get; init; }
/// <summary>
/// 交易金额(收入为正,退款为负)。
/// </summary>
public required decimal AmountSigned { get; init; }
/// <summary>
/// 交易时间。
/// </summary>
public required DateTime OccurredAt { get; init; }
/// <summary>
/// 备注。
/// </summary>
public string? Remark { get; init; }
/// <summary>
/// 顾客姓名。
/// </summary>
public string? CustomerName { get; init; }
/// <summary>
/// 顾客手机号。
/// </summary>
public string? CustomerPhone { get; init; }
/// <summary>
/// 退款单号。
/// </summary>
public string? RefundNo { get; init; }
/// <summary>
/// 退款原因。
/// </summary>
public string? RefundReason { get; init; }
/// <summary>
/// 会员名称。
/// </summary>
public string? MemberName { get; init; }
/// <summary>
/// 会员手机号脱敏值。
/// </summary>
public string? MemberMobileMasked { get; init; }
/// <summary>
/// 充值金额。
/// </summary>
public decimal? RechargeAmount { get; init; }
/// <summary>
/// 赠送金额。
/// </summary>
public decimal? GiftAmount { get; init; }
/// <summary>
/// 到账金额。
/// </summary>
public decimal? ArrivedAmount { get; init; }
/// <summary>
/// 积分变动值。
/// </summary>
public int? PointChangeAmount { get; init; }
/// <summary>
/// 积分变动后余额。
/// </summary>
public int? PointBalanceAfterChange { get; init; }
}
/// <summary>
/// 交易流水分页快照。
/// </summary>
public sealed record FinanceTransactionPageSnapshot
{
/// <summary>
/// 分页记录。
/// </summary>
public required IReadOnlyList<FinanceTransactionRecord> Items { get; init; }
/// <summary>
/// 总记录数。
/// </summary>
public required int TotalCount { get; init; }
/// <summary>
/// 本页收入合计。
/// </summary>
public required decimal PageIncomeAmount { get; init; }
/// <summary>
/// 本页退款合计。
/// </summary>
public required decimal PageRefundAmount { get; init; }
}
/// <summary>
/// 交易流水统计快照。
/// </summary>
public sealed record FinanceTransactionStatsSnapshot
{
/// <summary>
/// 总收入。
/// </summary>
public required decimal TotalIncome { get; init; }
/// <summary>
/// 总退款。
/// </summary>
public required decimal TotalRefund { get; init; }
/// <summary>
/// 总交易笔数。
/// </summary>
public required int TotalCount { get; init; }
}