package com.doumee.api.business;
|
|
import com.doumee.api.BaseController;
|
import com.doumee.core.annotation.excel.ExcelExporter;
|
import com.doumee.core.annotation.pr.PreventRepeat;
|
import com.doumee.core.model.ApiResponse;
|
import com.doumee.core.model.PageWrap;
|
import com.doumee.core.model.PageData;
|
import com.doumee.core.utils.Constants;
|
import com.doumee.core.utils.DateUtil;
|
import com.doumee.dao.business.model.Fund;
|
import com.doumee.dao.business.model.Integral;
|
import com.doumee.service.business.IntegralService;
|
import io.swagger.annotations.Api;
|
import io.swagger.annotations.ApiOperation;
|
import org.apache.shiro.authz.annotation.RequiresPermissions;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.web.bind.annotation.*;
|
import javax.servlet.http.HttpServletResponse;
|
|
import java.util.ArrayList;
|
import java.util.List;
|
|
/**
|
* @author 江蹄蹄
|
* @date 2023/03/21 15:48
|
*/
|
@Api(tags = "用户积分明细表")
|
@RestController
|
@RequestMapping("/business/integral")
|
public class IntegralController extends BaseController {
|
|
@Autowired
|
private IntegralService integralService;
|
|
@PreventRepeat
|
@ApiOperation("新建")
|
@PostMapping("/create")
|
@RequiresPermissions("business:integral:create")
|
public ApiResponse create(@RequestBody Integral integral) {
|
return ApiResponse.success(integralService.createUpIntegral(integral));
|
}
|
|
@ApiOperation("根据ID删除")
|
@GetMapping("/delete/{id}")
|
@RequiresPermissions("business:integral:delete")
|
public ApiResponse deleteById(@PathVariable Integer id) {
|
integralService.deleteById(id);
|
return ApiResponse.success(null);
|
}
|
|
@ApiOperation("批量删除")
|
@GetMapping("/delete/batch")
|
@RequiresPermissions("business:integral:delete")
|
public ApiResponse deleteByIdInBatch(@RequestParam String ids) {
|
String [] idArray = ids.split(",");
|
List<Integer> idList = new ArrayList<>();
|
for (String id : idArray) {
|
idList.add(Integer.valueOf(id));
|
}
|
integralService.deleteByIdInBatch(idList);
|
return ApiResponse.success(null);
|
}
|
|
@ApiOperation("根据ID修改")
|
@PostMapping("/updateById")
|
@RequiresPermissions("business:integral:update")
|
public ApiResponse updateById(@RequestBody Integral integral) {
|
integralService.updateById(integral);
|
return ApiResponse.success(null);
|
}
|
|
@ApiOperation("分页查询")
|
@PostMapping("/page")
|
@RequiresPermissions("business:integral:query")
|
public ApiResponse<PageData<Integral>> findPage (@RequestBody PageWrap<Integral> pageWrap) {
|
return ApiResponse.success(integralService.findPage(pageWrap));
|
}
|
|
@ApiOperation("导出Excel")
|
@PostMapping("/exportExcel")
|
@RequiresPermissions("business:integral:exportExcel")
|
public void exportExcel (@RequestBody PageWrap<Integral> pageWrap, HttpServletResponse response) throws Exception {
|
List<Integral> list=integralService.findPage(pageWrap).getRecords();
|
for(Integral model:list){
|
if(Constants.equalsInteger(model.getType(),Constants.ZERO)){
|
model.setStrType("收入");
|
}else if(Constants.equalsInteger(model.getType(),Constants.ONE)){
|
model.setStrType("支出");
|
}
|
model.setStrObjType(Constants.IntegralObjType.getName(model.getObjType()));
|
|
}
|
ExcelExporter.build(Integral.class).export(list, "用户积分明细"+ DateUtil.getNowLongTime(), response);
|
}
|
|
@ApiOperation("根据ID查询")
|
@GetMapping("/{id}")
|
@RequiresPermissions("business:integral:query")
|
public ApiResponse findById(@PathVariable Integer id) {
|
return ApiResponse.success(integralService.findById(id));
|
}
|
}
|