You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
636 lines
24 KiB
636 lines
24 KiB
using System;
|
|
using System.Collections.Generic;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Microsoft.Extensions.Caching.Distributed;
|
|
using AutoMapper;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using Volo.Abp.Guids;
|
|
using Volo.Abp.Application.Services;
|
|
using Volo.Abp.Caching;
|
|
|
|
using Volo.Abp.ObjectMapping;
|
|
using Win.Sfs.SettleAccount.ExcelImporter;
|
|
using Win.Sfs.Shared.CacheBase;
|
|
using Win.Utils;
|
|
using Volo.Abp.Application.Dtos;
|
|
using Win.Sfs.BaseData.ImportExcelCommon;
|
|
using Volo.Abp.Domain.Repositories;
|
|
using EFCore.BulkExtensions;
|
|
using System.IO;
|
|
using Microsoft.EntityFrameworkCore;
|
|
using Win.Sfs.SettleAccount.Entities.SettleAccountVersion;
|
|
using Win.Sfs.SettleAccount.FISes;
|
|
using Win.Sfs.Shared.Enums.SettleAccount;
|
|
using Win.Sfs.Shared.Filter;
|
|
using Shouldly;
|
|
using Magicodes.ExporterAndImporter.Csv;
|
|
using Magicodes.ExporterAndImporter.Core;
|
|
using Magicodes.ExporterAndImporter.Excel;
|
|
using System.Data.Common;
|
|
using Volo.Abp.Uow;
|
|
using Volo.Abp;
|
|
using Win.Abp.Snowflakes;
|
|
using Win.Sfs.SettleAccount.CommonManagers;
|
|
using Win.Sfs.SettleAccount.ExportReports;
|
|
using Win.Sfs.SettleAccount.Constant;
|
|
using Win.Sfs.SettleAccount.MaterialRelationships;
|
|
using Win.Sfs.SettleAccount.Entities.TaskJobs;
|
|
using Magicodes.ExporterAndImporter.Core.Models;
|
|
|
|
using TaskJob.Services;
|
|
using TaskJob.EventArgs;
|
|
using Win.Sfs.SettleAccount.Entities.WMS;
|
|
using Win.Sfs.SettleAccount.Entities.Wms;
|
|
using Win.Sfs.SettleAccount.Repository;
|
|
using WY.NewJit.Extends.PaiGe.WMS;
|
|
|
|
namespace Win.Sfs.SettleAccount.Entities.SettleAccounts
|
|
{
|
|
/// <summary>
|
|
/// wms出库
|
|
/// </summary>
|
|
|
|
[Authorize(SettleAccountPermissions.WMSJIT.Default)]
|
|
[Route("api/settleaccount/wmsjitoutput")]
|
|
|
|
public class WMSJitAppService :
|
|
SettleAccountApplicationBase<WmsJitOutPutDetial>
|
|
{
|
|
private readonly ISettleAccountBranchEfCoreRepository<WmsJitOutPutDetial, Guid> _wmsRepository;
|
|
private readonly ISettleAccountBranchEfCoreRepository<WmsJitOutPut, Guid> _wmsVersionRepository;
|
|
private readonly WMSEfCoreRepository<WmsJitOutPutDetial> _wmsefRespository;
|
|
private readonly WMSEfCoreRepository<TB_BILL> _wmstbRespository;
|
|
private readonly ISettleAccountBranchEfCoreRepository<TaskJob, Guid> _job;
|
|
private readonly IExcelImportAppService _excelImportService;
|
|
private readonly TaskJobService _service;
|
|
/// <summary>
|
|
///
|
|
/// </summary>
|
|
/// <param name="wmsRepository"></param>
|
|
/// <param name="job"></param>
|
|
/// <param name="wmsVersionRepository"></param>
|
|
/// <param name="wmsefRespository"></param>
|
|
/// <param name="wmstbRespository"></param>
|
|
public WMSJitAppService(
|
|
IExcelImportAppService excelImportService,
|
|
ISettleAccountBranchEfCoreRepository<WmsJitOutPutDetial, Guid> wmsRepository,
|
|
ISettleAccountBranchEfCoreRepository<TaskJob, Guid> job,
|
|
ISettleAccountBranchEfCoreRepository<WmsJitOutPut, Guid> wmsVersionRepository,
|
|
WMSEfCoreRepository<WmsJitOutPutDetial> wmsefRespository,
|
|
WMSEfCoreRepository<TB_BILL> wmstbRespository,
|
|
IDistributedCache<WmsJitOutPutDetial> cache,
|
|
ISnowflakeIdGenerator snowflakeIdGenerator,
|
|
ICommonManager commonManager
|
|
) : base(cache, excelImportService, snowflakeIdGenerator, commonManager)
|
|
{
|
|
_job = job;
|
|
_wmstbRespository = wmstbRespository;
|
|
_wmsRepository = wmsRepository;
|
|
_wmsVersionRepository = wmsVersionRepository;
|
|
_wmsefRespository = wmsefRespository;
|
|
_excelImportService = excelImportService;
|
|
}
|
|
|
|
|
|
[HttpPost]
|
|
[Route("ExcelImport")]
|
|
[DisableRequestSizeLimit]
|
|
[Authorize(SettleAccountPermissions.WMSJIT.Create)]
|
|
public async Task<string> ExcelImport([FromForm] IFormFileCollection files, string version)
|
|
{
|
|
var _billNum = "T" + DateTime.Now.ToString("yyyyMMddhhmmss");
|
|
ExportImporter _exportImporter = new ExportImporter();
|
|
var result = await _exportImporter.ExtendExcelImport<WmsJitOutPutDetial>(files, _excelImportService);
|
|
List<WmsJitOutPutDetial> _lst = new List<WmsJitOutPutDetial>();
|
|
var _lsCopy = new List<WmsJitOutPutDetial>();
|
|
foreach (var itm in result)
|
|
{
|
|
WmsJitOutPutDetial _detail = new WmsJitOutPutDetial(
|
|
GuidGenerator.Create(),
|
|
itm.WmsBillNum,
|
|
itm.KennCode,
|
|
itm.ChassisNumber,
|
|
itm.MaterialCode,
|
|
itm.MaterialDesc,
|
|
itm.MaterialGroup,
|
|
string.Empty,
|
|
string.Empty,
|
|
0,
|
|
!string.IsNullOrEmpty(itm.Extend1) ? itm.Extend1 : string.Empty,
|
|
!string.IsNullOrEmpty(itm.Extend2) ? itm.Extend2 : string.Empty,
|
|
version,
|
|
itm.ParentMaterialCode,
|
|
itm.BillNum,
|
|
GuidGenerator.Create()
|
|
, string.Empty
|
|
, itm.Qty
|
|
,itm.Price
|
|
,itm.Amt
|
|
);
|
|
_lsCopy.Add(_detail);
|
|
}
|
|
_lst.AddRange(_lsCopy.ToArray());
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var _ls1 = _lst.Where(p => p.ParentMaterialCode == p.MaterialCode).ToList();
|
|
var outPutDetail = await _wmsRepository.Where(p => p.Version == version && p.State!=4).ToListAsync();
|
|
|
|
|
|
var error = from itm1 in outPutDetail
|
|
join itm2 in _ls1 on
|
|
new { itm1.MaterialCode, itm1.KennCode, itm1.ChassisNumber }
|
|
equals
|
|
new { itm2.MaterialCode, itm2.KennCode, itm2.ChassisNumber }
|
|
select itm1;
|
|
var errList = error.GroupBy(p => new { p.BillNum }).Select(p => new { BillNum = p.Key.BillNum, Number = p.Sum(itm => itm.Qty) });
|
|
|
|
var checkList = new List<ErrorExportDto>();
|
|
foreach (var itm in errList)
|
|
{
|
|
checkList.Add( new ErrorExportDto() { Message = string.Format("出库单号:{0}重复记录数:{1}条", itm.BillNum, itm.Number) });
|
|
}
|
|
|
|
|
|
if (checkList.Count > 0)
|
|
{
|
|
|
|
return await ExportErrorReportAsync(checkList);
|
|
}
|
|
|
|
|
|
|
|
var query = from itm1 in _ls1
|
|
join itm2 in outPutDetail on
|
|
new { itm1.MaterialCode, itm1.KennCode, itm1.ChassisNumber }
|
|
equals
|
|
new { itm2.MaterialCode, itm2.KennCode, itm2.ChassisNumber } into temp1
|
|
from tm1 in temp1.DefaultIfEmpty()
|
|
where tm1 == null
|
|
select itm1;
|
|
var _wmslst = query.ToList();
|
|
foreach (var itm in _wmslst)
|
|
{
|
|
itm.BillNum = _billNum;
|
|
}
|
|
await _wmsRepository.GetDbContext().BulkInsertAsync(_wmslst, new BulkConfig() { BulkCopyTimeout = 0, BatchSize = 10000 });
|
|
int _count = _wmsVersionRepository.Count(p => p.Version == version && p.BillNum == _billNum);
|
|
if (_count == 0 && _wmslst.Count()>0)
|
|
{
|
|
var _version = new WmsJitOutPut(GuidGenerator.Create(), version, _billNum, CurrentUser.Email);
|
|
await _wmsVersionRepository.InsertAsync(_version, true);
|
|
}
|
|
return ApplicationConsts.SuccessStr;
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
private async Task<long> GetCountAsync(WmsJitOutPutDetialRequestDto input)
|
|
{
|
|
input.Filters.Add(new FilterCondition() { Action = EnumFilterAction.Equal, Column = "BillNum", Logic = EnumFilterLogic.And, Value = input.BillNum });
|
|
return await _wmsRepository.GetCountByFilterAsync(GuidGenerator.Create(), input.Filters);
|
|
}
|
|
|
|
private async Task<long> GetCountAsync(WmsJitOutPutRequestDto input)
|
|
{
|
|
return await _wmsVersionRepository.GetCountByFilterAsync(GuidGenerator.Create(), input.Filters);
|
|
}
|
|
|
|
/// <summary>
|
|
/// 准时化出库主表
|
|
/// </summary>
|
|
/// <param name="input"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("WmsJitList")]
|
|
//[Authorize(SettleAccountPermissions.SettleAccounts.Default)]
|
|
virtual public async Task<PagedResultDto<WmsJitOutPut>> GetListAsync(WmsJitOutPutRequestDto input)
|
|
{
|
|
|
|
var entities = await _wmsVersionRepository.GetListByFilterAsync(GuidGenerator.Create(), input.Filters, input.Sorting, input.MaxResultCount,
|
|
input.SkipCount, true);
|
|
|
|
var totalCount = await GetCountAsync(input);
|
|
|
|
|
|
return new PagedResultDto<WmsJitOutPut>(totalCount, entities);
|
|
}
|
|
|
|
|
|
|
|
///// <summary>
|
|
///// 准时化出库明细
|
|
///// </summary>
|
|
///// <param name="input"></param>
|
|
///// <returns></returns>
|
|
//[HttpPost]
|
|
//[Route("Export")]
|
|
////[Authorize(SettleAccountPermissions.SettleAccounts.Default)]
|
|
//virtual public async Task<string> ExportAsync(WmsJitOutPutDetialRequestDto input)
|
|
//{
|
|
|
|
// input.Filters.Add(new FilterCondition() { Action = EnumFilterAction.Equal, Column = "BillNum", Logic = EnumFilterLogic.And, Value = input.BillNum });
|
|
// var entities = await _wmsRepository.GetListByFilterAsync(GuidGenerator.Create(), input.Filters, input.Sorting, input.MaxResultCount,
|
|
// input.SkipCount, true);
|
|
|
|
// IExporter _csv = new CsvExporter();
|
|
// IExporter _excel = new ExcelExporter();
|
|
// string _fileName = string.Empty;
|
|
// //声明导出容器
|
|
|
|
// byte[] result = null;
|
|
|
|
// _fileName = string.Format("准时化出库单_{0}.xlsx", Guid.NewGuid().ToString());
|
|
// result = await _csv.ExportAsByteArray(entities);
|
|
|
|
// result.ShouldNotBeNull();
|
|
|
|
// //保存导出文件到服务器存成二进制
|
|
// await _excelImportService.SaveBlobAsync(
|
|
// new SaveExcelImportInputDto
|
|
// {
|
|
// Name = _fileName,
|
|
// Content = result
|
|
// }
|
|
// );
|
|
// return _fileName;
|
|
|
|
//}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
/// 准时化出库明细
|
|
/// </summary>
|
|
/// <param name="input"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("WmsJitDetailList")]
|
|
//[Authorize(SettleAccountPermissions.SettleAccounts.Default)]
|
|
virtual public async Task<PagedResultDto<WmsJitOutPutDetial>> GetListAsync(WmsJitOutPutDetialRequestDto input)
|
|
{
|
|
|
|
input.Filters.Add(new FilterCondition() { Action = EnumFilterAction.Equal, Column = "BillNum", Logic = EnumFilterLogic.And, Value = input.BillNum });
|
|
var entities = await _wmsRepository.GetListByFilterAsync(GuidGenerator.Create(), input.Filters, input.Sorting, input.MaxResultCount,
|
|
input.SkipCount, true);
|
|
|
|
var totalCount = await GetCountAsync(input);
|
|
//var dtoDetails = ObjectMapper.Map<List<WmsJitOutPutDetial>, List<WmsJitOutPutDetialDto>>(entities);
|
|
|
|
return new PagedResultDto<WmsJitOutPutDetial>(totalCount, entities);
|
|
}
|
|
/// <summary>
|
|
/// 任务明细标记已确认
|
|
/// </summary>
|
|
/// <param name="files">上传的文件(前端已经限制只能上传一个附件)</param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("WmsJitOutPutAudit")]
|
|
[DisableRequestSizeLimit]
|
|
|
|
public async Task<bool> WmsJitAudit(List<Guid> ids)
|
|
{
|
|
var _joblist = await _job.Where(p => ids.Contains(p.Id)).ToListAsync();
|
|
foreach (var itm in _joblist)
|
|
{
|
|
itm.FileName = "已确认";
|
|
await _job.UpdateAsync(itm);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 任务明细标记已确认
|
|
/// </summary>
|
|
/// <param name="files">上传的文件(前端已经限制只能上传一个附件)</param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("WmsJitOutPutCancel")]
|
|
[DisableRequestSizeLimit]
|
|
[UnitOfWork(false)]
|
|
public async Task<bool> WmsJitCancel(List<Guid> ids)
|
|
{
|
|
var _joblist = await _job.Where(p => ids.Contains(p.Id) && p.FileName == "已确认").ToListAsync();
|
|
foreach (var itm in _joblist)
|
|
{
|
|
itm.FileName = "取消确认";
|
|
await _job.UpdateAsync(itm);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/// <summary>
|
|
///更新备注
|
|
/// </summary>
|
|
/// <param name="input"></param>
|
|
/// <returns></returns>
|
|
[HttpGet]
|
|
[Route("UpdateRemark")]
|
|
|
|
public async Task<bool> UpdateRemark(Guid id, string remark)
|
|
{
|
|
var entity = _wmsVersionRepository.FirstOrDefault(p => p.Id == id);
|
|
if (entity != null)
|
|
{
|
|
entity.Remark = remark;
|
|
await _wmsVersionRepository.UpdateAsync(entity);
|
|
|
|
}
|
|
return true;
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 选择任务,生成出库单,只包含已确认的单据
|
|
/// </summary>
|
|
/// <param name="ids"></param>
|
|
/// <param name="version"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("WmsJitOutPut")]
|
|
public async Task<string> WmsJitOutPut(WmsJitRequestDto input)
|
|
{
|
|
var _billNum = "T" + DateTime.Now.ToString("yyyyMMddhhmmss");
|
|
var _joblist = _job.Where(p => input.Guids.Contains(p.Id) && p.FileName == "已确认").ToList();
|
|
if (_joblist.Count() > 0)
|
|
{
|
|
var fileList = _joblist.Select(p => p.RealDownFileName).ToList();
|
|
List<WmsJitOutPutDetial> _lst = new List<WmsJitOutPutDetial>();
|
|
foreach (var filename in fileList)
|
|
{
|
|
string fileSavePath = Environment.CurrentDirectory + @"\wwwroot\files\host\my-file-container\" + filename;
|
|
ExcelHelper _excelHelper = new ExcelHelper(fileSavePath);
|
|
var _list = _excelHelper.ExcelToList<WmsJitOutPutDetial>();
|
|
var _lsCopy = new List<WmsJitOutPutDetial>();
|
|
foreach (var itm in _list)
|
|
{
|
|
WmsJitOutPutDetial _detail = new WmsJitOutPutDetial(
|
|
GuidGenerator.Create(),
|
|
itm.WmsBillNum,
|
|
itm.KennCode,
|
|
itm.ChassisNumber,
|
|
itm.MaterialCode,
|
|
itm.MaterialDesc,
|
|
itm.MaterialGroup,
|
|
string.Empty,
|
|
string.Empty,
|
|
0,
|
|
itm.Extend1,
|
|
itm.Extend2,
|
|
input.Version,
|
|
itm.ParentMaterialCode,
|
|
itm.BillNum,
|
|
GuidGenerator.Create()
|
|
,string.Empty
|
|
,itm.Qty
|
|
,itm.Price
|
|
,Math.Round(itm.Qty*itm.Price,2)
|
|
|
|
);
|
|
_lsCopy.Add(_detail);
|
|
}
|
|
_lst.AddRange(_lsCopy.ToArray());
|
|
}
|
|
var _ls1 = _lst.Where(p => p.ParentMaterialCode == p.MaterialCode).ToList();
|
|
var outPutDetail = await _wmsRepository.Where(p => p.Version == input.Version && p.State != 4 ).ToListAsync();
|
|
|
|
var error = from itm1 in outPutDetail
|
|
join itm2 in _ls1 on
|
|
new { itm1.MaterialCode, itm1.KennCode, itm1.ChassisNumber }
|
|
equals
|
|
new { itm2.MaterialCode, itm2.KennCode, itm2.ChassisNumber }
|
|
select itm1;
|
|
var errList= error.GroupBy(p => new { p.BillNum }).Select(p => new {BillNum=p.Key.BillNum,Number=p.Sum(itm=>itm.Qty) });
|
|
if (errList.Count() == 0)
|
|
{
|
|
var query = from itm1 in _ls1
|
|
join itm2 in outPutDetail on
|
|
new { itm1.MaterialCode, itm1.KennCode, itm1.ChassisNumber }
|
|
equals
|
|
new { itm2.MaterialCode, itm2.KennCode, itm2.ChassisNumber } into temp1
|
|
from tm1 in temp1.DefaultIfEmpty()
|
|
where tm1 == null
|
|
select itm1;
|
|
var _wmslst = query.ToList();
|
|
foreach (var itm in _wmslst)
|
|
{
|
|
itm.BillNum = _billNum;
|
|
}
|
|
await _wmsRepository.GetDbContext().BulkInsertAsync(_wmslst, new BulkConfig() { BulkCopyTimeout = 0, BatchSize = 10000 });
|
|
int _count = _wmsVersionRepository.Count(p => p.Version == input.Version && p.BillNum == _billNum);
|
|
if (_count == 0 && _wmslst.Count()>0)
|
|
{
|
|
var _version = new WmsJitOutPut(GuidGenerator.Create(), input.Version, _billNum, CurrentUser.Email);
|
|
_version.Remark = !string.IsNullOrEmpty(_joblist.FirstOrDefault().Remark) ? _joblist.FirstOrDefault().Remark : string.Empty;
|
|
//var _ls = new List<WmsJitOutPut>();
|
|
//_ls.Add(_version);
|
|
await _wmsVersionRepository.InsertAsync(_version, true);
|
|
}
|
|
foreach (var job in _joblist)
|
|
{
|
|
job.FileName = _billNum;
|
|
await _job.UpdateAsync(job);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
StringBuilder _buffer = new StringBuilder();
|
|
foreach (var itm in errList)
|
|
{
|
|
_buffer.AppendFormat("出库单号:{0}重复记录数:{1}条", itm.BillNum, itm.Number);
|
|
}
|
|
var _errinfo= _buffer.ToString();
|
|
|
|
foreach (var job in _joblist)
|
|
{
|
|
job.FileName =_errinfo;
|
|
await _job.UpdateAsync(job);
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
_billNum = string.Empty;
|
|
}
|
|
return ApplicationConsts.SuccessStr;
|
|
}
|
|
/// <summary>
|
|
/// 出库界面功能,核准出库功能
|
|
/// </summary>
|
|
/// <param name="version"></param>
|
|
/// <param name="p_list"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("WmsJitOutPut-Pass")]
|
|
[UnitOfWork(false)]
|
|
[Authorize(SettleAccountPermissions.WMSJIT.Create)]
|
|
public async Task<bool> WmsJitOutPutPass(WmsJitRequestDto input)
|
|
{
|
|
if (DateTime.Now.ToString("yyyyMM") != input.AccountDate.ToString("yyyyMM"))
|
|
{
|
|
throw new BusinessException("8989", "填写过账日期应该为当月!");
|
|
|
|
}
|
|
|
|
var sql = "DECLARE @return_value int\n" +
|
|
"EXEC @return_value = [dbo].[p_wms_output]\n" +
|
|
" @billnum = N'{0}',\n" +
|
|
" @type = 0,\n" +
|
|
" @date = N'{1}'\n"+
|
|
"SELECT 'Return Value' = @return_value";
|
|
await _wmsRepository.GetDbContext().Database.ExecuteSqlRawAsync(
|
|
string.Format(sql,input.BillNum,input.AccountDate.ToShortDateString())
|
|
);
|
|
|
|
|
|
|
|
return true;
|
|
}
|
|
|
|
/// <summary>
|
|
/// 出库界面功能删除
|
|
/// </summary>
|
|
/// <param name="version"></param>
|
|
/// <param name="p_list"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("WmsOutPutDelete")]
|
|
[UnitOfWork(false)]
|
|
public async Task<bool> WmsOutPutDelete(WmsJitRequestDto input)
|
|
{
|
|
var count = _wmsRepository.Count(p => p.BillNum == input.BillNum && p.State != 0);
|
|
|
|
if (count > 0)
|
|
{
|
|
return false;
|
|
}
|
|
var sql = "DECLARE @return_value int\n" +
|
|
"EXEC @return_value = [dbo].[p_wms_output_cancel_all]\n" +
|
|
" @billnum = N'{0}',\n" +
|
|
" type=0\n" +
|
|
"SELECT 'Return Value' = @return_value";
|
|
await _wmsRepository.GetDbContext().Database.ExecuteSqlRawAsync(
|
|
string.Format(sql, input.BillNum)
|
|
);
|
|
|
|
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
///出库界面功能, 撤销核准出库
|
|
/// </summary>
|
|
/// <param name="ids"></param>
|
|
/// <param name="version"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("WmsJitOutPut-Cancel")]
|
|
[Authorize(SettleAccountPermissions.WMSJIT.Delete)]
|
|
public async Task<bool> WmsJitOutPutCancel(WmsJitRequestDto input)
|
|
{
|
|
|
|
|
|
if (input.Guids != null && input.Guids.Count() > 0)
|
|
{
|
|
List<string> _ls = new List<string>();
|
|
foreach (var itm in input.Guids)
|
|
{
|
|
_ls.Add(string.Format("{0}",itm));
|
|
}
|
|
|
|
string str= string.Join(",",_ls.ToArray());
|
|
|
|
var sql = "DECLARE @return_value int\n" +
|
|
"EXEC @return_value = [dbo].[p_wms_output_cancel]\n" +
|
|
" @Guids ='{0}', \n" +
|
|
" @billnum = N'{1}',\n" +
|
|
" @type = 0,\n" +
|
|
" @accountdate = N'{2}'\n" +
|
|
"SELECT 'Return Value' = @return_value";
|
|
|
|
sql= string.Format(sql, str, input.BillNum, input.AccountDate.ToShortDateString());
|
|
|
|
await _wmsRepository.GetDbContext().Database.ExecuteSqlRawAsync(
|
|
sql
|
|
);
|
|
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
|
|
/// <summary>
|
|
/// 导出
|
|
/// </summary>
|
|
/// <param name="input"></param>
|
|
/// <returns></returns>
|
|
[HttpPost]
|
|
[Route("Export")]
|
|
//[Authorize(SettleAccountPermissions.SettleAccounts.Default)]
|
|
virtual public async Task<string> ExportAsync(WmsKanbanOutPutDetialRequestDto input)
|
|
{
|
|
input.Filters.Add(new FilterCondition() { Action = EnumFilterAction.Equal, Column = "BillNum", Logic = EnumFilterLogic.And, Value = input.BillNum });
|
|
var entities = await _wmsRepository.GetListByFilterAsync(GuidGenerator.Create(), input.Filters, input.Sorting, int.MaxValue,
|
|
0, true);
|
|
var dtos = ObjectMapper.Map<List<WmsJitOutPutDetial>, List<WmsJitOutPutDetialDto>>(entities);
|
|
|
|
|
|
IExporter _excel = new ExcelExporter();
|
|
byte[] result = null;
|
|
|
|
var _fileName = string.Format("准时化出库单_{0}.xlsx", Guid.NewGuid().ToString());
|
|
result = await _excel.ExportAsByteArray(dtos);
|
|
|
|
|
|
result.ShouldNotBeNull();
|
|
|
|
//保存导出文件到服务器存成二进制
|
|
await _excelImportService.SaveBlobAsync(
|
|
new SaveExcelImportInputDto
|
|
{
|
|
Name = _fileName,
|
|
Content = result
|
|
}
|
|
);
|
|
return _fileName;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
}
|