using Ao.Lang;
|
using AutoMapper.Internal.Mappers;
|
using CMS.Extensions.Abp.AspNetCore.Mvc.Filters;
|
using CMS.Plugin.PipeLineLems.Application.Contracts.Dtos.WorkPlan;
|
using CMS.Plugin.PipeLineLems.Application.Contracts.Services;
|
using CMS.Plugin.PipeLineLems.Application.Implements;
|
using CMS.Plugin.PipeLineLems.Domain.WorkPlan;
|
using Microsoft.AspNetCore.Authorization;
|
using Microsoft.AspNetCore.Http;
|
using Microsoft.AspNetCore.Mvc;
|
using MiniExcelLibs;
|
using System.Reflection;
|
using Volo.Abp;
|
using Volo.Abp.Application.Dtos;
|
|
namespace CMS.Plugin.PipeLineLems.Controller
|
{
|
/// <summary>
|
/// 作业计划表服务
|
/// </summary>
|
[ApiController]
|
[TypeFilter(typeof(CMSLanguageFilter))]
|
[TypeFilter(typeof(CMSUowActionFilter))]
|
[TypeFilter(typeof(CMSAuditActionFilter))]
|
[TypeFilter(typeof(CMSExceptionFilter))]
|
[Route("api/v{version:apiVersion}/PipeLineLems/[controller]")]
|
public class WorkPlanController : ControllerBase
|
{
|
private readonly IWorkPlanAppService _workPlanAppService;
|
|
|
/// <summary>
|
/// 获取生产计划.
|
/// </summary>
|
/// <param name="input">标识符.</param>
|
/// <returns></returns>
|
[HttpPost]
|
[Route("GetWorkPlanByAps")]
|
public virtual async Task<MesOrderResponse> CreateWorkPlanByApsAsync([FromBody] List<WorkPlanInput> input)
|
{
|
return await _workPlanAppService.CreatebyApsAsync(input);
|
}
|
|
/// <summary>
|
/// Initializes a new instance of the <see cref="WorkPlanController"/> class.
|
/// </summary>
|
/// <param name="workPlanAppService">The workPlan application service.</param>
|
public WorkPlanController(IWorkPlanAppService workPlanAppService)
|
{
|
_workPlanAppService = workPlanAppService;
|
}
|
|
/// <summary>
|
/// 获取作业计划表
|
/// </summary>
|
/// <param name="id">标识符.</param>
|
/// <returns></returns>
|
[HttpGet]
|
[Route("{id}")]
|
public virtual Task<WorkPlanDto> GetAsync(Guid id)
|
{
|
return _workPlanAppService.GetAsync(id);
|
}
|
|
/// <summary>
|
/// 分页获取作业计划表的列表.
|
/// </summary>
|
/// <param name="input">输入.</param>
|
/// <returns></returns>
|
[HttpGet]
|
[Route("Page")]
|
public virtual Task<PagedResultDto<WorkPlanDto>> GetListAsync([FromQuery] GetWorkPlanInput input)
|
{
|
return _workPlanAppService.GetListAsync(input);
|
}
|
|
/// <summary>
|
/// 创建作业计划表
|
/// </summary>
|
/// <param name="input">输入.</param>
|
/// <returns></returns>
|
//[Authorize]
|
[HttpPost]
|
public virtual Task<WorkPlanDto> CreateAsync(WorkPlanCreateDto input)
|
{
|
return _workPlanAppService.CreateAsync(input);
|
}
|
|
/// <summary>
|
/// 更新作业计划表
|
/// </summary>
|
/// <param name="id">标识符.</param>
|
/// <param name="input">输入.</param>
|
/// <returns></returns>
|
//[Authorize]
|
[HttpPut]
|
[Route("{id}")]
|
public virtual Task<WorkPlanDto> UpdateAsync(Guid id, WorkPlanUpdateDto input)
|
{
|
return _workPlanAppService.UpdateAsync(id, input);
|
}
|
|
/// <summary>
|
/// 克隆作业计划表
|
/// </summary>
|
/// <param name="ids">Id集合.</param>
|
/// <returns></returns>
|
//[Authorize]
|
[HttpPost]
|
[Route("Clone")]
|
public virtual Task<List<WorkPlanDto>> CloneAsync([FromBody] IEnumerable<Guid> ids)
|
{
|
return _workPlanAppService.CloneAsync(ids);
|
}
|
|
/// <summary>
|
/// 删除作业计划表
|
/// </summary>
|
/// <param name="id">标识符.</param>
|
/// <returns></returns>
|
//[Authorize]
|
[HttpDelete]
|
[Route("{id}")]
|
public virtual Task DeleteAsync(Guid id)
|
{
|
return _workPlanAppService.DeleteAsync(id);
|
}
|
|
/// <summary>
|
/// 批量删除作业计划表
|
/// </summary>
|
/// <param name="ids">The ids.</param>
|
/// <returns></returns>
|
//[Authorize]
|
[HttpDelete]
|
public virtual Task DeleteAsync([FromBody] IEnumerable<Guid> ids)
|
{
|
return _workPlanAppService.DeleteManyAsync(ids);
|
}
|
|
/// <summary>
|
/// 调整排序作业计划表
|
/// </summary>
|
/// <param name="id">标识符.</param>
|
/// <returns></returns>
|
[HttpPut]
|
[Route("{id}/AdjustSort/{sort}")]
|
public virtual Task AdjustSortAsync(Guid id, int sort)
|
{
|
return _workPlanAppService.AdjustSortAsync(id, sort);
|
}
|
|
/// <summary>
|
/// 导入作业计划表
|
/// </summary>
|
/// <returns></returns>
|
[Authorize]
|
[HttpPost]
|
[Route("Import")]
|
public virtual async Task<IActionResult> ImportAsync(IFormFile file)
|
{
|
using var stream = new MemoryStream();
|
await file.CopyToAsync(stream);
|
stream.Seek(0L, SeekOrigin.Begin);
|
|
var sheetNames = stream.GetSheetNames();
|
var workPlanRows = sheetNames.Contains("配置") ? MiniExcel.Query<WorkPlansImportModel.WorkPlanImportModel>(stream, sheetName: "配置").ToList() : new();
|
|
if (!workPlanRows.Any())
|
{
|
throw new UserFriendlyException("请检查导入的表格");
|
}
|
|
|
await _workPlanAppService.ImportAsync(new WorkPlansImportModel
|
{
|
WorkPlans = workPlanRows,
|
});
|
|
return Ok();
|
}
|
|
/// <summary>
|
/// 导出作业计划表
|
/// </summary>
|
/// <returns></returns>
|
[HttpGet]
|
[Route("Export")]
|
public virtual async Task<IActionResult> ExportAsync([FromQuery] GetWorkPlanInput input)
|
{
|
input.MaxResultCount = int.MaxValue;
|
var exportData = await _workPlanAppService.ExportAsync(input);
|
var templatePath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, $"Resources/Templates/WorkPlan导出模板.xlsx");
|
if (!System.IO.File.Exists(templatePath))
|
{
|
templatePath = Path.Combine(Path.GetDirectoryName(Assembly.GetExecutingAssembly().Location) ?? string.Empty, $"Resources/Templates/WorkPlan导出模板.xlsx");
|
}
|
|
var memoryStream = new MemoryStream();
|
await memoryStream.SaveAsByTemplateAsync(templatePath, exportData.Sheets);
|
memoryStream.Seek(0L, SeekOrigin.Begin);
|
return new FileStreamResult(memoryStream, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet") { FileDownloadName = $"{exportData.FileName}_{DateTime.Now:yyyyMMddhhmmss}.xlsx" };
|
}
|
}
|
}
|