|
|
@ -3,6 +3,8 @@ package com.gxwebsoft.cms.controller; |
|
|
|
import cn.afterturn.easypoi.excel.ExcelImportUtil; |
|
|
|
import cn.afterturn.easypoi.excel.entity.ImportParams; |
|
|
|
import cn.hutool.core.util.ObjectUtil; |
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; |
|
|
|
import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; |
|
|
|
import com.gxwebsoft.common.core.web.BaseController; |
|
|
|
import com.gxwebsoft.cms.service.CmsWebsiteFieldService; |
|
|
|
import com.gxwebsoft.cms.entity.CmsWebsiteField; |
|
|
@ -57,6 +59,7 @@ public class CmsWebsiteFieldController extends BaseController { |
|
|
|
return success(cmsWebsiteFieldService.getByIdRel(id)); |
|
|
|
} |
|
|
|
|
|
|
|
@PreAuthorize("hasAuthority('cms:cmsWebsiteField:save')") |
|
|
|
@Operation(summary = "添加应用参数") |
|
|
|
@PostMapping() |
|
|
|
public ApiResult<?> save(@RequestBody CmsWebsiteField cmsWebsiteField) { |
|
|
@ -66,6 +69,7 @@ public class CmsWebsiteFieldController extends BaseController { |
|
|
|
return fail("添加失败"); |
|
|
|
} |
|
|
|
|
|
|
|
@PreAuthorize("hasAuthority('cms:cmsWebsiteField:update')") |
|
|
|
@Operation(summary = "修改应用参数") |
|
|
|
@PutMapping() |
|
|
|
public ApiResult<?> update(@RequestBody CmsWebsiteField cmsWebsiteField) { |
|
|
@ -75,6 +79,7 @@ public class CmsWebsiteFieldController extends BaseController { |
|
|
|
return fail("修改失败"); |
|
|
|
} |
|
|
|
|
|
|
|
@PreAuthorize("hasAuthority('cms:cmsWebsiteField:remove')") |
|
|
|
@Operation(summary = "删除应用参数") |
|
|
|
@DeleteMapping("/{id}") |
|
|
|
public ApiResult<?> remove(@PathVariable("id") Integer id) { |
|
|
@ -84,6 +89,7 @@ public class CmsWebsiteFieldController extends BaseController { |
|
|
|
return fail("删除失败"); |
|
|
|
} |
|
|
|
|
|
|
|
@PreAuthorize("hasAuthority('cms:cmsWebsiteField:save')") |
|
|
|
@Operation(summary = "批量添加应用参数") |
|
|
|
@PostMapping("/batch") |
|
|
|
public ApiResult<?> saveBatch(@RequestBody List<CmsWebsiteField> list) { |
|
|
@ -93,6 +99,7 @@ public class CmsWebsiteFieldController extends BaseController { |
|
|
|
return fail("添加失败"); |
|
|
|
} |
|
|
|
|
|
|
|
@PreAuthorize("hasAuthority('cms:cmsWebsiteField:update')") |
|
|
|
@Operation(summary = "批量修改应用参数") |
|
|
|
@PutMapping("/batch") |
|
|
|
public ApiResult<?> removeBatch(@RequestBody BatchParam<CmsWebsiteField> batchParam) { |
|
|
@ -102,6 +109,7 @@ public class CmsWebsiteFieldController extends BaseController { |
|
|
|
return fail("修改失败"); |
|
|
|
} |
|
|
|
|
|
|
|
@PreAuthorize("hasAuthority('cms:cmsWebsiteField:remove')") |
|
|
|
@Operation(summary = "批量删除应用参数") |
|
|
|
@DeleteMapping("/batch") |
|
|
|
public ApiResult<?> removeBatch(@RequestBody List<Integer> ids) { |
|
|
@ -134,17 +142,28 @@ public class CmsWebsiteFieldController extends BaseController { |
|
|
|
public ApiResult<List<String>> importBatch(MultipartFile file) { |
|
|
|
ImportParams importParams = new ImportParams(); |
|
|
|
try { |
|
|
|
// 第一步:永久删除已标记为 deleted=1 的记录
|
|
|
|
cmsWebsiteFieldService.remove(new LambdaQueryWrapper<CmsWebsiteField>().eq(CmsWebsiteField::getDeleted, 1)); |
|
|
|
|
|
|
|
// 第二步:将现有未删除的记录(deleted=0)标记为 deleted=1
|
|
|
|
LambdaUpdateWrapper<CmsWebsiteField> updateWrapper = new LambdaUpdateWrapper<>(); |
|
|
|
updateWrapper.eq(CmsWebsiteField::getDeleted, 0); |
|
|
|
updateWrapper.set(CmsWebsiteField::getDeleted, 1); |
|
|
|
cmsWebsiteFieldService.update(updateWrapper); |
|
|
|
|
|
|
|
// 第三步:导入XLS文件的内容
|
|
|
|
List<CmsWebsiteFieldImportParam> list = ExcelImportUtil.importExcel(file.getInputStream(), CmsWebsiteFieldImportParam.class, importParams); |
|
|
|
list.forEach(d -> { |
|
|
|
CmsWebsiteField item = JSONUtil.parseObject(JSONUtil.toJSONString(d), CmsWebsiteField.class); |
|
|
|
assert item != null; |
|
|
|
if (ObjectUtil.isNotEmpty(item)) { |
|
|
|
System.out.println("item = " + item); |
|
|
|
// 设置默认值
|
|
|
|
if (item.getDeleted() == null) { |
|
|
|
item.setDeleted(0); |
|
|
|
item.setDeleted(0); // 新导入的数据deleted设为0
|
|
|
|
} |
|
|
|
if (item.getSortNumber() == null) { |
|
|
|
item.setSortNumber(0); |
|
|
|
item.setSortNumber(100); |
|
|
|
} |
|
|
|
if (item.getEncrypted() == null) { |
|
|
|
item.setEncrypted(false); |
|
|
|