emoticon_api/ARW.Service/Business/BusinessService/OrderManage/OrderRefunds/OrderRefundService.cs
2023-08-29 18:36:32 +08:00

120 lines
4.3 KiB
C#

using Infrastructure.Attribute;
using Microsoft.AspNetCore.Http;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Infrastructure;
using ARW.Model;
using ARW.Repository;
using ARW.Repository.Business.OrderManage.OrderRefunds;
using ARW.Service.Business.IBusinessService.OrderManage.OrderRefunds;
using ARW.Model.Dto.Business.OrderManage.OrderRefunds;
using ARW.Model.Models.Business.OrderManage.OrderRefunds;
using ARW.Model.Vo.Business.OrderManage.OrderRefunds;
namespace ARW.Service.Business.BusinessService.OrderManage.OrderRefunds
{
/// <summary>
/// 售后单记录表接口实现类
///
/// @author lwh
/// @date 2023-08-29
/// </summary>
[AppService(ServiceType = typeof(IOrderRefundService), ServiceLifetime = LifeTime.Transient)]
public class OrderRefundServiceImpl : BaseService<OrderRefund>, IOrderRefundService
{
private readonly OrderRefundRepository _OrderRefundRepository;
public OrderRefundServiceImpl(OrderRefundRepository OrderRefundRepository)
{
this._OrderRefundRepository = OrderRefundRepository;
}
#region
/// <summary>
/// 查询售后单记录表分页列表
/// </summary>
public async Task<PagedInfo<OrderRefundVo>> GetOrderRefundList(OrderRefundQueryDto parm)
{
//开始拼装查询条件d
var predicate = Expressionable.Create<OrderRefund>();
predicate = predicate.AndIF(parm.RefundType != null, s => s.RefundType == parm.RefundType);
predicate = predicate.AndIF(parm.RefundReason != null, s => s.RefundReason == parm.RefundReason);
predicate = predicate.AndIF(parm.GoodsReceiveStatus != null, s => s.GoodsReceiveStatus == parm.GoodsReceiveStatus);
predicate = predicate.AndIF(parm.MerchantAuditStatus != null, s => s.MerchantAuditStatus == parm.MerchantAuditStatus);
predicate = predicate.AndIF(parm.IsCustomerSend != null, s => s.IsCustomerSend == parm.IsCustomerSend);
predicate = predicate.AndIF(parm.OrderRefundStatus != null, s => s.OrderRefundStatus == parm.OrderRefundStatus);
var query = _OrderRefundRepository
.Queryable()
.Where(predicate.ToExpression())
.OrderBy(s => s.Create_time,OrderByType.Desc)
.Select(s => new OrderRefundVo
{
OrderRefundId = s.OrderRefundId,
OrderRefundGuid = s.OrderRefundGuid,
OrderGuid = s.OrderGuid,
CustomerGuid = s.CustomerGuid,
RefundType = s.RefundType,
RefundReason = s.RefundReason,
CustomerRefundDesc = s.CustomerRefundDesc,
CustomerRefundImg = s.CustomerRefundImg,
GoodsReceiveStatus = s.GoodsReceiveStatus,
MerchantAuditStatus = s.MerchantAuditStatus,
MerchantRefuseDesc = s.MerchantRefuseDesc,
RefundMoney = s.RefundMoney,
ShopRefundAddressGuid = s.ShopRefundAddressGuid,
IsCustomerSend = s.IsCustomerSend,
CustomerSendTime = s.CustomerSendTime,
LogisticsCompanyGuid = s.LogisticsCompanyGuid,
ExpressNo = s.ExpressNo,
OrderRefundStatus = s.OrderRefundStatus,
});
return await query.ToPageAsync(parm);
}
/// <summary>
/// 添加或修改售后单记录表
/// </summary>
public async Task<string> AddOrUpdateOrderRefund(OrderRefund model)
{
if (model.OrderRefundId != 0)
{
var response = await _OrderRefundRepository.UpdateAsync(model);
return "修改成功!";
}
else
{
var response = await _OrderRefundRepository.InsertReturnSnowflakeIdAsync(model);
return "添加成功!";
}
}
#region Excel处理
/// <summary>
/// Excel数据导出处理
/// </summary>
public async Task<List<OrderRefundVo>> HandleExportData(List<OrderRefundVo> data)
{
return data;
}
#endregion
#endregion
}
}