通用数据控制器

This commit is contained in:
陈淳
2022-09-28 18:05:49 +08:00
parent 4796a494de
commit 87a685b823
10 changed files with 155 additions and 80 deletions

View File

@@ -37,58 +37,58 @@ namespace Yi.Framework.ApiMicroservice.Controllers
//数据导入导出将会被写入到基类
/// <summary>
/// 下载模板
/// </summary>
/// <returns></returns>
[HttpGet]
[AllowAnonymous]
public IActionResult Template()
{
List<UserEntity> users = new();
var fileName = nameof(UserEntity) + PathConst.DataTemplate;
var path = ExcelHelper.DownloadImportTemplate(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Excel.ToString()));
var file = System.IO.File.OpenRead(path);
return File(file, "text/plain", $"{DateTime.Now.ToString("yyyyMMddHHmmssffff") + fileName }.xlsx");
}
///// <summary>
///// 下载模板
///// </summary>
///// <returns></returns>
//[HttpGet]
//[AllowAnonymous]
//public IActionResult Template()
//{
// List<UserEntity> users = new();
// var fileName = nameof(UserEntity) + PathConst.DataTemplate;
// var path = ExcelHelper.DownloadImportTemplate(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Excel.ToString()));
// var file = System.IO.File.OpenRead(path);
// return File(file, "text/plain", $"{DateTime.Now.ToString("yyyyMMddHHmmssffff") + fileName }.xlsx");
//}
/// <summary>
/// 导出数据
/// </summary>
/// <returns></returns>
[HttpGet]
[AllowAnonymous]
public async Task<IActionResult> Export()
{
var users = await _iUserService._repository.GetListAsync();
var fileName = DateTime.Now.ToString("yyyyMMddHHmmssffff") + nameof(UserEntity) + PathConst.DataExport;
var path = ExcelHelper.ExportExcel(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Temp.ToString()));
var file = System.IO.File.OpenRead(path);
return File(file, "text/plain", $"{ fileName }.xlsx");
}
///// <summary>
///// 导出数据
///// </summary>
///// <returns></returns>
//[HttpGet]
//[AllowAnonymous]
//public async Task<IActionResult> Export()
//{
// var users = await _iUserService._repository.GetListAsync();
// var fileName = DateTime.Now.ToString("yyyyMMddHHmmssffff") + nameof(UserEntity) + PathConst.DataExport;
// var path = ExcelHelper.ExportExcel(users, fileName, Path.Combine(PathConst.wwwroot, PathEnum.Temp.ToString()));
// var file = System.IO.File.OpenRead(path);
// return File(file, "text/plain", $"{ fileName }.xlsx");
//}
/// <summary>
/// 导入数据
/// </summary>
/// <returns></returns>
[HttpGet]
[AllowAnonymous]
public async Task<Result> Import([FromForm(Name = "file")] IFormFile formFile)
{
List<UserEntity> users = ExcelHelper.ImportData<UserEntity>(formFile.OpenReadStream());
///// <summary>
///// 导入数据
///// </summary>
///// <returns></returns>
//[HttpPost]
//[AllowAnonymous]
//public async Task<Result> Import(IFormFile formFile)
//{
// List<UserEntity> users = ExcelHelper.ImportData<UserEntity>(formFile.OpenReadStream());
var _repository = _iUserService._repository;
// var _repository = _iUserService._repository;
//全量删除在重新插入
var res = await _repository.UseTranAsync(async () =>
{
await _repository.DeleteAsync(u => true);
await _repository.InsertRangeAsync(users);
});
return Result.Success().SetStatus(res);
}
// //全量删除在重新插入
// var res = await _repository.UseTranAsync(async () =>
// {
// await _repository.DeleteAsync(u => true);
// await _repository.InsertRangeAsync(users);
// });
// return Result.Success().SetStatus(res);
//}
/// <summary>
/// 动态条件分页查询
@@ -114,8 +114,7 @@ namespace Yi.Framework.ApiMicroservice.Controllers
[Permission("system:user:edit")]
public async Task<Result> UpdateStatus(long userId, bool isDel)
{
return Result.Success().SetData(await _iUserService._repository.UpdateIgnoreNullAsync(new UserEntity() { Id = userId, IsDeleted = isDel }));
return Result.Success().SetData(await _repository.UpdateIgnoreNullAsync(new UserEntity() { Id = userId, IsDeleted = isDel }));
}
/// <summary>
@@ -153,7 +152,7 @@ namespace Yi.Framework.ApiMicroservice.Controllers
[Permission("system:user:edit")]
public async Task<Result> Update(UserInfoDto userDto)
{
if (await _iUserService._repository.IsAnyAsync(u => userDto.User.UserName.Equals(u.UserName) && !userDto.User.Id.Equals(u.Id)))
if (await _repository.IsAnyAsync(u => userDto.User.UserName.Equals(u.UserName) && !userDto.User.Id.Equals(u.Id)))
{
return Result.Error("用户名已存在,修改失败!");
}
@@ -182,7 +181,7 @@ namespace Yi.Framework.ApiMicroservice.Controllers
[Permission("system:user:add2")]
public async Task<Result> Add(UserInfoDto userDto)
{
if (await _iUserService._repository.IsAnyAsync(u => userDto.User.UserName.Equals(u.UserName)))
if (await _repository.IsAnyAsync(u => userDto.User.UserName.Equals(u.UserName)))
{
return Result.Error("用户已经存在,添加失败!");
}