SysLangService.cs 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. // Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
  2. //
  3. // 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
  4. //
  5. // 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
  6. namespace Admin.NET.Core.Service;
  7. /// <summary>
  8. /// 语言服务 🧩
  9. /// </summary>
  10. [ApiDescriptionSettings(Order = 100, Description = "语言服务")]
  11. public partial class SysLangService : IDynamicApiController, ITransient
  12. {
  13. private readonly SqlSugarRepository<SysLang> _sysLangRep;
  14. public SysLangService(SqlSugarRepository<SysLang> sysLangRep)
  15. {
  16. _sysLangRep = sysLangRep;
  17. }
  18. /// <summary>
  19. /// 分页查询语言 🔖
  20. /// </summary>
  21. /// <param name="input"></param>
  22. /// <returns></returns>
  23. [DisplayName("分页查询语言")]
  24. [ApiDescriptionSettings(Name = "Page"), HttpPost]
  25. public async Task<SqlSugarPagedList<SysLangOutput>> Page(PageSysLangInput input)
  26. {
  27. input.Keyword = input.Keyword?.Trim();
  28. var query = _sysLangRep.AsQueryable()
  29. .WhereIF(!string.IsNullOrWhiteSpace(input.Keyword), u => u.Name.Contains(input.Keyword) || u.Code.Contains(input.Keyword) || u.IsoCode.Contains(input.Keyword) || u.UrlCode.Contains(input.Keyword))
  30. .WhereIF(!string.IsNullOrWhiteSpace(input.Name), u => u.Name.Contains(input.Name.Trim()))
  31. .WhereIF(!string.IsNullOrWhiteSpace(input.Code), u => u.Code.Contains(input.Code.Trim()))
  32. .WhereIF(!string.IsNullOrWhiteSpace(input.IsoCode), u => u.IsoCode.Contains(input.IsoCode.Trim()))
  33. .WhereIF(!string.IsNullOrWhiteSpace(input.UrlCode), u => u.UrlCode.Contains(input.UrlCode.Trim()))
  34. .Select<SysLangOutput>();
  35. return await query.OrderBuilder(input).ToPagedListAsync(input.Page, input.PageSize);
  36. }
  37. /// <summary>
  38. /// 获取语言详情 ℹ️
  39. /// </summary>
  40. /// <param name="input"></param>
  41. /// <returns></returns>
  42. [DisplayName("获取语言详情")]
  43. [ApiDescriptionSettings(Name = "Detail"), HttpGet]
  44. public async Task<SysLang> Detail([FromQuery] QueryByIdSysLangInput input)
  45. {
  46. return await _sysLangRep.GetFirstAsync(u => u.Id == input.Id);
  47. }
  48. /// <summary>
  49. /// 增加语言 ➕
  50. /// </summary>
  51. /// <param name="input"></param>
  52. /// <returns></returns>
  53. [DisplayName("增加语言")]
  54. [ApiDescriptionSettings(Name = "Add"), HttpPost]
  55. public async Task<long> Add(AddSysLangInput input)
  56. {
  57. var entity = input.Adapt<SysLang>();
  58. return await _sysLangRep.InsertAsync(entity) ? entity.Id : 0;
  59. }
  60. /// <summary>
  61. /// 更新语言 ✏️
  62. /// </summary>
  63. /// <param name="input"></param>
  64. /// <returns></returns>
  65. [DisplayName("更新语言")]
  66. [ApiDescriptionSettings(Name = "Update"), HttpPost]
  67. public async Task Update(UpdateSysLangInput input)
  68. {
  69. var entity = input.Adapt<SysLang>();
  70. await _sysLangRep.AsUpdateable(entity)
  71. .ExecuteCommandAsync();
  72. }
  73. /// <summary>
  74. /// 删除语言 ❌
  75. /// </summary>
  76. /// <param name="input"></param>
  77. /// <returns></returns>
  78. [DisplayName("删除语言")]
  79. [ApiDescriptionSettings(Name = "Delete"), HttpPost]
  80. public async Task Delete(DeleteSysLangInput input)
  81. {
  82. var entity = await _sysLangRep.GetFirstAsync(u => u.Id == input.Id) ?? throw Oops.Oh(ErrorCodeEnum.D1002);
  83. await _sysLangRep.DeleteAsync(entity); //真删除
  84. }
  85. /// <summary>
  86. /// 获取下拉列表数据 🔖
  87. /// </summary>
  88. /// <returns></returns>
  89. [AllowAnonymous]
  90. [DisplayName("获取下拉列表数据")]
  91. [ApiDescriptionSettings(Name = "DropdownData"), HttpPost]
  92. public async Task<dynamic> DropdownData()
  93. {
  94. var data = await _sysLangRep.Context.Queryable<SysLang>()
  95. .Where(m => m.Active == true)
  96. .Select(u => new
  97. {
  98. Code = u.Code,
  99. Value = u.UrlCode,
  100. Label = $"{u.Name}"
  101. }).ToListAsync();
  102. return data;
  103. }
  104. }