184 lines
6.4 KiB
C#
Raw Normal View History

2025-11-06 20:28:30 +08:00
using DOAN.Admin.WebApi.Filters;
2025-11-03 16:57:55 +08:00
using DOAN.Model.Business;
2025-11-06 20:28:30 +08:00
using DOAN.Model.Dto;
using DOAN.Service.Business;
2025-11-03 16:57:55 +08:00
using DOAN.Service.Business.IBusinessService;
2025-11-06 20:28:30 +08:00
using Microsoft.AspNetCore.Mvc;
2025-11-03 16:57:55 +08:00
2025-11-06 20:28:30 +08:00
//创建时间2025-11-06
2025-11-03 16:57:55 +08:00
namespace DOAN.Admin.WebApi.Controllers
{
/// <summary>
2025-11-06 20:28:30 +08:00
/// 工艺建模项目表
2025-11-03 16:57:55 +08:00
/// </summary>
[Verify]
2025-11-06 20:28:30 +08:00
[Route("mes/process/proModelProject")]
public class ProModelProjectController : BaseController
2025-11-03 16:57:55 +08:00
{
/// <summary>
2025-11-06 20:28:30 +08:00
/// 工艺建模项目表接口
2025-11-03 16:57:55 +08:00
/// </summary>
2025-11-06 20:28:30 +08:00
private readonly IProModelProjectService _ProModelProjectService;
2025-11-03 16:57:55 +08:00
2025-11-06 20:28:30 +08:00
public ProModelProjectController(IProModelProjectService ProModelProjectService)
2025-11-03 16:57:55 +08:00
{
2025-11-06 20:28:30 +08:00
_ProModelProjectService = ProModelProjectService;
2025-11-03 16:57:55 +08:00
}
/// <summary>
2025-11-06 20:28:30 +08:00
/// 查询工艺建模项目表列表
2025-11-03 16:57:55 +08:00
/// </summary>
/// <param name="parm"></param>
/// <returns></returns>
[HttpGet("list")]
2025-11-06 20:28:30 +08:00
[ActionPermissionFilter(Permission = "process:promodelproject:list")]
public IActionResult QueryProModelProject([FromQuery] ProModelProjectQueryDto parm)
2025-11-03 16:57:55 +08:00
{
2025-11-06 20:28:30 +08:00
var response = _ProModelProjectService.GetList(parm);
2025-11-03 16:57:55 +08:00
return SUCCESS(response);
}
/// <summary>
2025-11-06 20:28:30 +08:00
/// 查询工艺建模项目表详情
2025-11-03 16:57:55 +08:00
/// </summary>
/// <param name="Id"></param>
/// <returns></returns>
[HttpGet("{Id}")]
2025-11-06 20:28:30 +08:00
[ActionPermissionFilter(Permission = "process:promodelproject:query")]
public IActionResult GetProModelProject(long Id)
2025-11-03 16:57:55 +08:00
{
2025-11-06 20:28:30 +08:00
var response = _ProModelProjectService.GetInfo(Id);
2025-11-03 16:57:55 +08:00
2025-11-06 20:28:30 +08:00
var info = response.Adapt<ProModelProject>();
2025-11-03 16:57:55 +08:00
return SUCCESS(info);
}
/// <summary>
2025-11-06 20:28:30 +08:00
/// 添加工艺建模项目表
2025-11-03 16:57:55 +08:00
/// </summary>
/// <returns></returns>
[HttpPost]
2025-11-06 20:28:30 +08:00
[ActionPermissionFilter(Permission = "process:promodelproject:add")]
[Log(Title = "工艺建模项目表", BusinessType = BusinessType.INSERT)]
public IActionResult AddProModelProject([FromBody] ProModelProjectDto parm)
2025-11-03 16:57:55 +08:00
{
2025-11-06 20:28:30 +08:00
var modal = parm.Adapt<ProModelProject>().ToCreate(HttpContext);
2025-11-03 16:57:55 +08:00
2025-11-06 20:28:30 +08:00
var response = _ProModelProjectService.AddProModelProject(modal);
2025-11-03 16:57:55 +08:00
return SUCCESS(response);
}
/// <summary>
2025-11-06 20:28:30 +08:00
/// 更新工艺建模项目表
2025-11-03 16:57:55 +08:00
/// </summary>
/// <returns></returns>
[HttpPut]
2025-11-06 20:28:30 +08:00
[ActionPermissionFilter(Permission = "process:promodelproject:edit")]
[Log(Title = "工艺建模项目表", BusinessType = BusinessType.UPDATE)]
public IActionResult UpdateProModelProject([FromBody] ProModelProjectDto parm)
2025-11-03 16:57:55 +08:00
{
2025-11-06 20:28:30 +08:00
var modal = parm.Adapt<ProModelProject>().ToUpdate(HttpContext);
var response = _ProModelProjectService.UpdateProModelProject(modal);
2025-11-03 16:57:55 +08:00
return ToResponse(response);
}
/// <summary>
2025-11-06 20:28:30 +08:00
/// 删除工艺建模项目表
2025-11-03 16:57:55 +08:00
/// </summary>
/// <returns></returns>
[HttpDelete("{ids}")]
2025-11-06 20:28:30 +08:00
[ActionPermissionFilter(Permission = "process:promodelproject:delete")]
[Log(Title = "工艺建模项目表", BusinessType = BusinessType.DELETE)]
public IActionResult DeleteProModelProject(string ids)
2025-11-03 16:57:55 +08:00
{
int[] idsArr = Tools.SpitIntArrary(ids);
if (idsArr.Length <= 0) { return ToResponse(ApiResult.Error($"删除失败Id 不能为空")); }
2025-11-06 20:28:30 +08:00
var response = _ProModelProjectService.Delete(idsArr);
2025-11-03 16:57:55 +08:00
return ToResponse(response);
}
2025-11-04 20:56:03 +08:00
/// <summary>
/// 新增导入Excel
/// </summary>
/// <param name="formFile">使用IFromFile必须使用name属性否则获取不到文件</param>
/// <returns>导入成功数 若-1 则Excel读取异常</returns>
[HttpPost("addImportProject")]
[Log(Title = "新增导入Excel", BusinessType = BusinessType.IMPORT, IsSaveRequestData = false, IsSaveResponseData = true)]
[AllowAnonymous]
public IActionResult AddImportData([FromForm(Name = "file")] IFormFile formFile)
{
if (formFile == null)
{
SUCCESS(null);
}
2025-11-06 20:28:30 +08:00
int result = _ProModelProjectService.AddImportExcel(formFile, HttpContext.GetName());
2025-11-04 20:56:03 +08:00
return ToResponse(result);
}
2025-11-03 16:57:55 +08:00
2025-11-04 20:56:03 +08:00
/// <summary>
/// 覆盖导入Excel
/// </summary>
/// <param name="formFile">使用IFromFile必须使用name属性否则获取不到文件</param>
/// <returns>导入成功数 若-1 则Excel读取异常</returns>
[HttpPost("coverImportProject")]
[Log(Title = "覆盖导入Excel", BusinessType = BusinessType.IMPORT, IsSaveRequestData = false, IsSaveResponseData = true)]
[AllowAnonymous]
public IActionResult CoverImportData([FromForm(Name = "file")] IFormFile formFile)
{
if (formFile == null)
{
SUCCESS(null);
}
2025-11-06 20:28:30 +08:00
int result = _ProModelProjectService.CoverImportExcel(formFile, HttpContext.GetName());
2025-11-04 20:56:03 +08:00
return ToResponse(result);
}
2025-11-03 16:57:55 +08:00
2025-11-04 20:56:03 +08:00
/// <summary>
/// 导出Excel模板
/// </summary>
/// <returns></returns>
[HttpGet("exportTemplate")]
[Log(Title = "产品项目模板导出", BusinessType = BusinessType.EXPORT, IsSaveRequestData = true, IsSaveResponseData = false)]
[AllowAnonymous]
public IActionResult ExportTemplateExcel()
{
2025-11-05 08:51:50 +08:00
(string, string) result = DownloadImportTemplate("processmodel");
2025-11-04 20:56:03 +08:00
return ExportExcel(result.Item2, result.Item1);
}
2025-11-03 16:57:55 +08:00
2025-11-04 20:56:03 +08:00
/// <summary>
/// 导出Excel
/// </summary>
/// <returns></returns>
[HttpGet("exportProject")]
[AllowAnonymous]
public IActionResult ExportData()
{
try
{
// 调用Service层方法获取Excel字节数组和文件名
2025-11-06 20:28:30 +08:00
var (fileBytes, fileName) = _ProModelProjectService.ExportProjectExcel();
2025-11-04 20:56:03 +08:00
// 在Controller中使用File方法返回文件下载响应
return File(
fileBytes,
"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
fileName);
}
catch (Exception ex)
{
// 错误处理
return BadRequest(ex.Message);
}
}
2025-11-06 20:28:30 +08:00
2025-11-03 16:57:55 +08:00
}
}