ny
23 小时以前 b6f169fe43a2b13f351aefc152374fc7f0bc8cb7
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
package jnpf.base.controller;
 
import cn.dev33.satoken.annotation.SaCheckPermission;
import cn.dev33.satoken.annotation.SaMode;
import cn.hutool.core.bean.BeanUtil;
import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.Parameter;
import io.swagger.v3.oas.annotations.Parameters;
import io.swagger.v3.oas.annotations.tags.Tag;
import jakarta.validation.Valid;
import jnpf.base.ActionResult;
import jnpf.base.entity.BaseLangEntity;
import jnpf.base.entity.DictionaryDataEntity;
import jnpf.base.model.language.*;
import jnpf.base.service.BaseLangService;
import jnpf.base.service.DictionaryDataService;
import jnpf.file.util.ExcelTool;
import jnpf.base.vo.DownloadVO;
import jnpf.config.ConfigValueUtil;
import jnpf.constant.ConfigConst;
import jnpf.constant.MsgCode;
import jnpf.model.ExcelColumnAttr;
import jnpf.model.ExcelImportVO;
import jnpf.model.ExcelModel;
import jnpf.util.JsonUtil;
import jnpf.util.RegexUtils;
import jnpf.util.StringUtil;
import org.apache.commons.collections4.MapUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
 
import java.util.*;
 
/**
 * 多语言管理
 *
 * @author JNPF开发平台组
 * @version v5.0.0
 * @copyright 引迈信息技术有限公司
 * @date 2024/4/28 11:26:57
 */
@Tag(name = "多语言配置", description = "BaseLang")
@RestController
@RequestMapping("/BaseLang")
public class BaseLangController {
 
    @Autowired
    private BaseLangService baseLangService;
 
    @Autowired
    private ConfigValueUtil configValueUtil;
 
    @Autowired
    private DictionaryDataService dictionaryDataApi;
 
    @Operation(summary = "标记翻译列表")
    @SaCheckPermission("sysData.language")
    @GetMapping()
    public ActionResult list(BaseLangPage pagination) {
        BaseLangListVO list = baseLangService.list(pagination);
        return ActionResult.success(list);
    }
 
    @Operation(summary = "创建")
    @Parameters({
            @Parameter(name = "form", description = "多语言表单对象", required = true)
    })
    @SaCheckPermission(value = {"sysData.language", "onlineDev.webDesign"}, mode = SaMode.OR)
    @PostMapping()
    public ActionResult create(@RequestBody @Valid BaseLangForm form) {
        if (RegexUtils.checkEnCode2(form.getEnCode())) {
            ActionResult.fail(MsgCode.SYS050.get());
        }
        baseLangService.create(form);
        return ActionResult.success(MsgCode.SU001.get());
    }
 
    @Operation(summary = "修改")
    @Parameters({
            @Parameter(name = "form", description = "多语言表单对象", required = true)
    })
    @SaCheckPermission("sysData.language")
    @PutMapping("/{id}")
    public ActionResult update(@PathVariable("id") String id, @RequestBody @Valid BaseLangForm form) {
        if (RegexUtils.checkEnCode2(form.getEnCode())) {
            ActionResult.fail(MsgCode.SYS050.get());
        }
        form.setId(id);
        baseLangService.update(form);
        return ActionResult.success(MsgCode.SU004.get());
    }
 
    @Operation(summary = "详情")
    @Parameters({
            @Parameter(name = "enCode", description = "翻译标记", required = true)
    })
    @SaCheckPermission("sysData.language")
    @GetMapping("/{id}")
    public ActionResult info(@PathVariable("id") String id) {
        BaseLangForm info = baseLangService.getInfo(id);
        return ActionResult.success(info);
    }
 
    @Operation(summary = "删除")
    @Parameters({
            @Parameter(name = "id", description = "翻译标记", required = true)
    })
    @SaCheckPermission("sysData.language")
    @DeleteMapping("/{id}")
    public ActionResult delete(@PathVariable("id") String id) {
        baseLangService.delete(id);
        return ActionResult.success();
    }
 
    @Operation(summary = "获取语种json")
    @Parameters({
            @Parameter(name = "language", description = "语种编码", required = true)
    })
    @GetMapping("/LangJson")
    public ActionResult LangJson(Locale locale) {
        if (locale == null || StringUtil.isEmpty(locale.toLanguageTag()) || "und".equals(locale.toLanguageTag())) {
            locale = Locale.SIMPLIFIED_CHINESE;
        }
        String languageJson = baseLangService.getLanguageJson(locale);
        return ActionResult.success(MsgCode.SU000.get(), languageJson);
    }
 
    @Operation(summary = "获取语种json")
    @Parameters({
            @Parameter(name = "language", description = "语种编码", required = true)
    })
    @GetMapping("/ServerLang")
    public ActionResult<List<BaseLangVo>> getServerLang(Locale locale) {
        List<BaseLangEntity> serverLang = baseLangService.getServerLang(locale);
        List<BaseLangVo> list = JsonUtil.getJsonToList(serverLang, BaseLangVo.class);
        return ActionResult.success(list);
    }
 
    //++++++++++++++++++++++++++++++++++以下导入导出接口++++++++++++++++++++++++++++++++++++++++++
 
    @Operation(summary = "模板下载")
    @SaCheckPermission("sysData.language")
    @GetMapping("/TemplateDownload")
    public ActionResult<DownloadVO> TemplateDownload() {
        BaseLangColumn columnMap = new BaseLangColumn(getDicLangMap());
        String excelName = columnMap.getExcelName();
        Map<String, String> keyMap = columnMap.getColumnByType(0);
        List<ExcelColumnAttr> models = columnMap.getFieldsModel(false);
        List<Map<String, Object>> list = columnMap.getDefaultList();
        Map<String, String[]> optionMap = new HashMap<>();
        optionMap.put("type", new String[]{"客户端", "服务端"});
 
        ExcelModel excelModel = ExcelModel.builder().models(models).selectKey(new ArrayList<>(keyMap.keySet())).optionMap(optionMap).hasHeader(true).build();
        DownloadVO vo = ExcelTool.getImportTemplate(configValueUtil.getTemporaryFilePath(), excelName, keyMap, list, excelModel);
        return ActionResult.success(vo);
    }
 
    /**
     * 从字典获取语言map
     *
     * @return
     */
    private Map<String, String> getDicLangMap() {
        List<DictionaryDataEntity> langTypeList = dictionaryDataApi.getListByTypeDataCode(ConfigConst.BASE_LANGUAGE);
        Map<String, String> collect = new LinkedHashMap<>();
        langTypeList.forEach(t -> collect.put(t.getEnCode(), t.getFullName()));
        return collect;
    }
 
    @Operation(summary = "上传导入Excel")
    @SaCheckPermission("sysData.language")
    @PostMapping("/Uploader")
    public ActionResult<Object> Uploader() {
        return ExcelTool.uploader();
    }
 
    @Operation(summary = "导入数据")
    @SaCheckPermission("sysData.language")
    @PostMapping("/ImportData")
    public ActionResult<ExcelImportVO> ImportData(@RequestBody BaseLangModel model) {
        // 导入字段
        BaseLangColumn columnMap = new BaseLangColumn(getDicLangMap());
        Map<String, String> keyMap = columnMap.getColumnByType(0);
        Map<String, Object> headAndDataMap = ExcelTool.importPreview(configValueUtil.getTemporaryFilePath(), model.getFileName(), keyMap,1,1);
        List<Map<String, Object>> listData = (List<Map<String, Object>>) headAndDataMap.get("dataRow");
        List<BaseLangEntity> addList = new ArrayList<>();
        List<Map<String, Object>> failList = new ArrayList<>();
        // 对数据做校验 (处理)
        this.validateImportData(listData, addList, failList);
        //写入数据
        baseLangService.importSaveOrUpdate(addList);
        return ActionResult.success(MsgCode.IMP001.get());
    }
 
    public void validateImportData(List<Map<String, Object>> listData, List<BaseLangEntity> addList, List<Map<String, Object>> failList) {
        List<DictionaryDataEntity> langTypeList = dictionaryDataApi.getListByTypeDataCode(ConfigConst.BASE_LANGUAGE);
        for (Map<String, Object> map : listData) {
            if (MapUtils.isNotEmpty(map) && map.get("enCode")!=null && StringUtil.isNotBlank(map.get("enCode").toString()) && RegexUtils.checkEnCode2(map.get("enCode").toString())) {
                BaseLangEntity baseLangEntity = new BaseLangEntity();
                baseLangEntity.setEnCode(map.get("enCode").toString());
                Integer type = 0;
                if (map.get("type") != null && StringUtil.isNotBlank(map.get("type").toString())) {
                    type = "服务端".equals(map.get("type").toString()) ? 1 : 0;
                }
                baseLangEntity.setType(type);
                boolean allNull = true;
                List<BaseLangEntity> thisList =new ArrayList<>();
                for (DictionaryDataEntity item : langTypeList) {
                    String enCode = item.getEnCode();
                    String fullName = "";
                    if (map.get(enCode) != null) {
                        fullName = map.get(enCode).toString();
                    }
                    if(StringUtil.isNotBlank(fullName)){
                        allNull = false;
                    }
                    baseLangEntity.setLanguage(enCode);
                    baseLangEntity.setFullName(fullName);
                    BaseLangEntity entity = BeanUtil.copyProperties(baseLangEntity, BaseLangEntity.class);
                    thisList.add(entity);
                }
                if(!allNull){
                    addList.addAll(thisList);
                }
            } else {
                failList.add(map);
            }
        }
    }
}