using Infrastructure; using Infrastructure.Attribute; using Infrastructure.Enums; using Infrastructure.Model; using Mapster; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using ARW.Admin.WebApi.Extensions; using ARW.Admin.WebApi.Filters; using ARW.Common; using ARW.Model.Dto.Business.OrderManage.OrderRefunds; using ARW.Service.Business.IBusinessService.OrderManage.OrderRefunds; using ARW.Admin.WebApi.Controllers; using ARW.Model.Models.Business.OrderManage.OrderRefunds; using ARW.Model.Vo.Business.OrderManage.OrderRefunds; using Microsoft.AspNetCore.Authorization; using ARW.Admin.WebApi.Framework; namespace ARW.WebApi.Controllers.Business.OrderManage.OrderRefunds { /// /// 售后单记录表控制器 /// /// @author lwh /// @date 2023-08-29 /// [Verify] [Route("business/[controller]")] public class OrderRefundController : BaseController { private readonly IOrderRefundService _OrderRefundService; /// /// 依赖注入 /// /// 售后单记录表服务 public OrderRefundController(IOrderRefundService OrderRefundService) { _OrderRefundService = OrderRefundService; } /// /// 获取售后单记录表列表 /// /// 查询参数 /// [HttpGet("getOrderRefundList")] [ActionPermissionFilter(Permission = "business:orderrefund:list")] public async Task GetOrderRefundList([FromQuery] OrderRefundQueryDto parm) { var res = await _OrderRefundService.GetOrderRefundList(parm); return SUCCESS(res); } /// /// 添加或修改售后单记录表 /// /// /// [HttpPost("addOrUpdateOrderRefund")] [ActionPermissionFilter(Permission = "business:orderrefund:addOrUpdate")] [Log(Title = "添加或修改售后单记录表", BusinessType = BusinessType.ADDORUPDATE)] public async Task AddOrUpdateOrderRefund([FromBody] OrderRefundDto parm) { if (parm == null) { throw new CustomException("请求参数错误"); } var modal = new OrderRefund(); if (parm.OrderRefundId != 0) modal = parm.Adapt().ToUpdate(HttpContext); else modal = parm.Adapt().ToCreate(HttpContext); var res = await _OrderRefundService.AddOrUpdateOrderRefund(modal); return SUCCESS(res); } /// /// 删除售后单记录表 /// /// [HttpDelete("{ids}")] [ActionPermissionFilter(Permission = "business:orderrefund:delete")] [Log(Title = "售后单记录表删除", BusinessType = BusinessType.DELETE)] public IActionResult Delete(string ids) { long[] idsArr = Tools.SpitLongArrary(ids); if (idsArr.Length <= 0) { return ToResponse(ApiResult.Error($"删除失败Id 不能为空")); } var response = _OrderRefundService.Delete(idsArr); return SUCCESS("删除成功!"); } /// /// 导出售后单记录表 /// /// [Log(Title = "售后单记录表导出", BusinessType = BusinessType.EXPORT, IsSaveResponseData = false)] [HttpGet("exportOrderRefund")] [ActionPermissionFilter(Permission = "business:orderrefund:export")] public async Task ExportExcel([FromQuery] OrderRefundQueryDto parm) { parm.PageSize = 10000; var list = await _OrderRefundService.GetOrderRefundList(parm); var data = list.Result; // 选中数据 if (!string.IsNullOrEmpty(parm.ids)) { int[] idsArr = Tools.SpitIntArrary(parm.ids); var selectDataList = new List(); foreach (var item in idsArr) { var select_data = data.Where(s => s.OrderRefundId == item).First(); selectDataList.Add(select_data); } data = selectDataList; } // 导出数据处理 var handleData = await _OrderRefundService.HandleExportData(data); string sFileName = ExportExcel(handleData, "OrderRefund", "售后单记录表列表"); return SUCCESS(new { path = "/export/" + sFileName, fileName = sFileName }); } } }