using Microsoft.AspNetCore.Mvc; using MiniExcelLibs; using ZR.Admin.WebApi.Filters; using ZR.Model; using ZR.Model.Dto; using ZR.Model.Models; namespace ZR.Admin.WebApi.Controllers { /// /// 多语言配置Controller /// [Route("system/CommonLang")] [ApiExplorerSettings(GroupName = "sys")] public class CommonLangController : BaseController { /// /// 多语言配置接口 /// private readonly ICommonLangService _CommonLangService; public CommonLangController(ICommonLangService CommonLangService) { _CommonLangService = CommonLangService; } /// /// 查询多语言配置列表 /// /// /// [HttpGet("list")] [ActionPermissionFilter(Permission = "system:lang:list")] public IActionResult QueryCommonLang([FromQuery] CommonLangQueryDto parm) { if (parm.ShowMode == 2) { PagedInfo pagedInfo = new() { Result = _CommonLangService.GetListToPivot(parm) }; return SUCCESS(pagedInfo); } return SUCCESS(_CommonLangService.GetList(parm)); } /// /// 查询多语言配置列表 /// /// [HttpGet("list/{lang}")] [AllowAnonymous] public IActionResult QueryCommonLangs(string lang) { var msgList = _CommonLangService.GetLangList(new CommonLangQueryDto() { LangCode = lang }); return SUCCESS(_CommonLangService.SetLang(msgList)); } /// /// 查询多语言配置详情 /// /// /// [HttpGet("{Id}")] [ActionPermissionFilter(Permission = "system:lang:query")] public IActionResult GetCommonLang(long Id) { var response = _CommonLangService.GetFirst(x => x.Id == Id); var list = _CommonLangService.GetList(x => x.LangKey == response.LangKey); var vo = list.Adapt>(); var modal = new CommonLangDto() { LangKey = response.LangKey, LangList = vo }; return SUCCESS(modal); } /// /// 查询多语言配置详情 /// /// /// [HttpGet("key/{langKey}")] [ActionPermissionFilter(Permission = "system:lang:query")] public IActionResult GetCommonLangByKey(string langKey) { var list = _CommonLangService.GetList(x => x.LangKey == langKey); var vo = list.Adapt>(); var modal = new CommonLangDto() { LangKey = langKey, LangList = vo }; return SUCCESS(modal); } /// /// 更新多语言配置 /// /// [HttpPut] [ActionPermissionFilter(Permission = "system:lang:edit")] [Log(Title = "多语言配置", BusinessType = BusinessType.UPDATE)] public IActionResult UpdateCommonLang([FromBody] CommonLangDto parm) { if (parm == null || parm.LangKey.IsEmpty()) { throw new CustomException("请求实体不能为空"); } _CommonLangService.StorageCommonLang(parm); return ToResponse(1); } /// /// 删除多语言配置 /// /// [HttpDelete("{ids}")] [ActionPermissionFilter(Permission = "system:lang:delete")] [Log(Title = "多语言配置", BusinessType = BusinessType.DELETE)] public IActionResult DeleteCommonLang(string ids) { long[] idsArr = Tools.SpitLongArrary(ids); if (idsArr.Length <= 0) { return ToResponse(ApiResult.Error($"删除失败Id 不能为空")); } var response = _CommonLangService.Delete(idsArr); return ToResponse(response); } /// /// 删除多语言配置 /// /// [HttpDelete("ByKey")] [ActionPermissionFilter(Permission = "system:lang:delete")] [Log(Title = "多语言配置", BusinessType = BusinessType.DELETE)] public IActionResult DeleteCommonLangByKey(string langkey) { if (langkey.IsEmpty()) { return ToResponse(ApiResult.Error($"删除失败Id 不能为空")); } var response = _CommonLangService .Deleteable() .EnableDiffLogEvent() .Where(f => f.LangKey == langkey) .ExecuteCommand(); return ToResponse(response); } /// /// 导出多语言配置 /// /// [Log(Title = "多语言配置", BusinessType = BusinessType.EXPORT, IsSaveResponseData = false)] [HttpGet("export")] [ActionPermissionFilter(Permission = "system:lang:export")] public IActionResult Export([FromQuery] CommonLangQueryDto parm) { parm.PageSize = 10000; var list = _CommonLangService.GetListToPivot(parm); string sFileName = ExportExcel(list, "CommonLang", "多语言配置"); return SUCCESS(new { path = "/export/" + sFileName, fileName = sFileName }); } /// /// 导入 /// /// /// [HttpPost("importData")] [Log(Title = "多语言设置导入", BusinessType = BusinessType.IMPORT, IsSaveRequestData = false, IsSaveResponseData = true)] [ActionPermissionFilter(Permission = "system:lang:import")] public IActionResult ImportData([FromForm(Name = "file")] IFormFile formFile) { List list = new(); var nowTime = DateTime.Now; using (var stream = formFile.OpenReadStream()) { var rows = stream.Query(startCell: "A2").ToList(); foreach (var item in rows) { list.Add(new CommonLang() { LangCode = "zh-cn", LangKey = item.A, LangName = item.B, Addtime = nowTime }); list.Add(new CommonLang() { LangCode = "en", LangKey = item.A, LangName = item.C, Addtime = nowTime }); list.Add(new CommonLang() { LangCode = "zh-tw", LangKey = item.A, LangName = item.D, Addtime = nowTime }); } } return SUCCESS(_CommonLangService.ImportCommonLang(list)); } /// /// 多语言设置导入模板下载 /// /// [HttpGet("importTemplate")] [Log(Title = "多语言设置模板", BusinessType = BusinessType.EXPORT, IsSaveRequestData = true, IsSaveResponseData = false)] [AllowAnonymous] public IActionResult ImportTemplateExcel() { var result = DownloadImportTemplate(new List() { }, "lang"); return ExportExcel(result.Item2, result.Item1); } } }