using Infrastructure;
using Infrastructure.Attribute;
using Infrastructure.Enums;
using Infrastructure.Model;
using Mapster;
using Microsoft.AspNetCore.Mvc;
using ZR.Model.Dto;
using ZR.Model.Models;
using ZR.Service.Business.IBusinessService;
using ZR.Admin.WebApi.Extensions;
using ZR.Admin.WebApi.Filters;
using ZR.Common;
using Microsoft.AspNetCore.Authorization;
using MiniExcelLibs;
using ZR.Service.Business;
namespace ZR.Admin.WebApi.Controllers
{
///
/// 接口管理/SAP交验单记录表Controller
///
/// @tableName sap_deliver_record
/// @author admin
/// @date 2023-05-05
///
[Verify]
[Route("business/SapDeliverRecord")]
public class SapDeliverRecordController : BaseController
{
///
/// 接口管理/SAP交验单记录表接口
///
private readonly ISapDeliverRecordService _SapDeliverRecordService;
public SapDeliverRecordController(ISapDeliverRecordService SapDeliverRecordService)
{
_SapDeliverRecordService = SapDeliverRecordService;
}
///
/// 查询接口管理/SAP交验单记录表列表
///
///
///
[HttpGet("list")]
[ActionPermissionFilter(Permission = "business:sapdeliverrecord:list")]
public IActionResult QuerySapDeliverRecord([FromQuery] SapDeliverRecordQueryDto parm)
{
var response = _SapDeliverRecordService.GetList(parm);
return SUCCESS(response);
}
///
/// 查询接口管理/SAP交验单记录表详情
///
///
///
[HttpGet("{Id}")]
[ActionPermissionFilter(Permission = "business:sapdeliverrecord:query")]
public IActionResult GetSapDeliverRecord(int Id)
{
var response = _SapDeliverRecordService.GetFirst(x => x.Id == Id);
return SUCCESS(response);
}
///
/// 添加接口管理/SAP交验单记录表
///
///
[HttpPost]
[ActionPermissionFilter(Permission = "business:sapdeliverrecord:add")]
[Log(Title = "接口管理/SAP交验单记录表", BusinessType = BusinessType.INSERT)]
public IActionResult AddSapDeliverRecord([FromBody] SapDeliverRecordDto parm)
{
if (parm == null)
{
throw new CustomException("请求参数错误");
}
var modal = parm.Adapt().ToCreate(HttpContext);
var response = _SapDeliverRecordService.AddSapDeliverRecord(modal);
return ToResponse(response);
}
///
/// 更新接口管理/SAP交验单记录表
///
///
[HttpPut]
[ActionPermissionFilter(Permission = "business:sapdeliverrecord:edit")]
[Log(Title = "接口管理/SAP交验单记录表", BusinessType = BusinessType.UPDATE)]
public IActionResult UpdateSapDeliverRecord([FromBody] SapDeliverRecordDto parm)
{
if (parm == null)
{
throw new CustomException("请求实体不能为空");
}
var modal = parm.Adapt().ToUpdate(HttpContext);
var response = _SapDeliverRecordService.UpdateSapDeliverRecord(modal);
return ToResponse(response);
}
///
/// 删除接口管理/SAP交验单记录表
///
///
[HttpDelete("{ids}")]
[ActionPermissionFilter(Permission = "business:sapdeliverrecord:delete")]
[Log(Title = "接口管理/SAP交验单记录表", BusinessType = BusinessType.DELETE)]
public IActionResult DeleteSapDeliverRecord(string ids)
{
int[] idsArr = Tools.SpitIntArrary(ids);
if (idsArr.Length <= 0) { return ToResponse(ApiResult.Error($"删除失败Id 不能为空")); }
var response = _SapDeliverRecordService.Delete(idsArr);
return ToResponse(response);
}
///
/// 导入
///
/// 使用IFromFile必须使用name属性否则获取不到文件
///
[HttpPost("importData")]
[Log(Title = "交验单导入", BusinessType = BusinessType.IMPORT, IsSaveRequestData = false, IsSaveResponseData = false)]
[ActionPermissionFilter(Permission = "business:sapdeliverrecord:import")]
public IActionResult ImportData([FromForm(Name = "file")] IFormFile formFile)
{
List? list = new();
//读取上传文件内容。
using (var stream = formFile.OpenReadStream())
{
//list = stream.Query(startCell:"A6").ToList();
list = stream.Query().ToList();
//var test= stream.Query(sheetName:"sheet1");
}
string deliverNo = list[2].M;
if (string.IsNullOrEmpty(deliverNo))
{
return SUCCESS("未找到交验单编号,导入文件格式错误");
}
deliverNo = deliverNo.Replace("编号", "").Replace(":", "").Replace(":", "");
string checkName = list[3].A;
checkName = string.IsNullOrEmpty(checkName) ? "" : checkName.Replace("送检人员", "").Replace(":", "").Replace(":", "");
List sapDeliverRecords = new();
for (int i = 6; i < list.Count; i++)
{
if (string.IsNullOrEmpty($"{list[i].A}"))
{
break;//序号一列出现空,即交验单内容结束
}
SapDeliverRecord sapDeliverRecord = new()
{
DeliverNo = deliverNo,
CheckName = checkName,
BomNo = list[i].B,
RowNo = Convert.ToInt32(list[i].D),
MaterialCode = $"MAT{list[i].F}",//非空 模拟数据
MaterialName = list[i].E,
MaterialSpec = list[i].F,
Category = (i % 2) > 0 ? "外协件" : "外购件",//非空 模拟数据
KeyFlag = (i % 2) > 0,//非空 模拟数据
Qty = Convert.ToInt32(list[i].H),
SpotCheckQty = Convert.ToInt32(list[i].I),
CheckQty = Convert.ToInt32(list[i].M),
CheckResult = "OK",//非空 模拟数据
InstoreResult = 99,//非空 模拟数据
CreateBy=HttpContext.GetName(),
CreateTime = DateTime.Now,
Remark = "导入数据"
};
sapDeliverRecords.Add(sapDeliverRecord);
}
string msg = _SapDeliverRecordService.ImportDatas(sapDeliverRecords);
//TODO 业务逻辑,自行插入数据到db
return SUCCESS(list);
}
///
/// 用户导入模板下载 //这里是根据对象字段自动生成的模板,不符合实际使用需要。
///
///
[HttpGet("importTemplate")]
[Log(Title = "交验单模板", BusinessType = BusinessType.EXPORT, IsSaveRequestData = false, IsSaveResponseData = false)]
[AllowAnonymous]
public IActionResult ImportTemplateExcel()
{
List list = new();
MemoryStream stream = new();
var fileInfo = DownloadImportTemplate(list, stream, "交验单");
return ExportExcel(fileInfo.Item1, fileInfo.Item2);
}
}
}