package com.kidgrow.oprationcenter.controller;
import com.kidgrow.common.controller.BaseController;
import com.kidgrow.common.model.PageResult;
import com.kidgrow.common.model.ResultBody;
import com.kidgrow.oprationcenter.model.ProductOrderDetail;
import com.kidgrow.oprationcenter.service.IBusinessRecordsService;
import com.kidgrow.oprationcenter.service.IProductOrderDetailService;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiImplicitParam;
import io.swagger.annotations.ApiImplicitParams;
import io.swagger.annotations.ApiOperation;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections.MapUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.BindingResult;
import org.springframework.validation.ObjectError;
import org.springframework.web.bind.annotation.*;
import javax.servlet.http.HttpServletRequest;
import javax.validation.Valid;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
/**
* 石家庄喜高科技有限责任公司 版权所有 © Copyright 2020
* @Description: 产品/明显的充值记录
* @Project: 运营中心
* @CreateDate: Created in 2020-04-02 18:25:34
* @Author: liuke
* @version: 1.0
*/
@Slf4j
@RestController
@RequestMapping("/productorderdetail")
@Api(tags = "产品/明显的充值记录")
public class ProductOrderDetailController extends BaseController{
@Autowired
private IProductOrderDetailService productOrderDetailService;
@Autowired
private IBusinessRecordsService businessRecordsService;
/**
* 列表
*/
@ApiOperation(value = "查询列表")
@ApiImplicitParams({
@ApiImplicitParam(name = "page", value = "分页起始位置", required = true, dataType = "Integer"),
@ApiImplicitParam(name = "limit", value = "分页结束位置", required = true, dataType = "Integer")
})
@GetMapping
public PageResult list(@RequestParam Map params) {
if(params.size()==0){
params.put("page",1);
params.put("limit",10);
}
return productOrderDetailService.findList(params);
}
/**
* 列表
*/
@ApiOperation(value = "查询列表")
@ApiImplicitParams({
@ApiImplicitParam(name = "page", value = "分页起始位置", required = true, dataType = "Integer"),
@ApiImplicitParam(name = "limit", value = "分页结束位置", required = true, dataType = "Integer")
})
@GetMapping("/all")
public PageResult findAllList(@RequestParam Map params) {
if(params.size()==0){
params.put("page",1);
params.put("limit",10);
}
return productOrderDetailService.findAllList(params);
}
/**
* 列表
*/
@ApiOperation(value = "查询列表")
@ApiImplicitParams({
@ApiImplicitParam(name = "page", value = "分页起始位置", required = true, dataType = "Integer"),
@ApiImplicitParam(name = "limit", value = "分页结束位置", required = true, dataType = "Integer")
})
@GetMapping("/group")
public PageResult groupList(@RequestParam Map params) {
if(params.size()==0){
params.put("page",1);
params.put("limit",10);
}
return productOrderDetailService.groupList(params);
}
/**
* 查询
*/
@ApiOperation(value = "查询")
@GetMapping("/{id}")
public ResultBody findById(@PathVariable Long id) {
ProductOrderDetail model = productOrderDetailService.getById(id);
return ResultBody.ok().data(model).msg("查询成功");
}
/**
* 根据ProductOrderDetail当做查询条件进行查询
*/
@ApiOperation(value = "根据ProductOrderDetail当做查询条件进行查询")
@PostMapping("/query")
public ResultBody findByObject(@RequestBody ProductOrderDetail productOrderDetail) {
ProductOrderDetail model = productOrderDetailService.findByObject(productOrderDetail);
return ResultBody.ok().data(model).msg("查询成功");
}
/**
* 新增or更新
*/
@ApiOperation(value = "保存")
@PostMapping
public ResultBody save(@Valid @RequestBody ProductOrderDetail productOrderDetail, BindingResult bindingResult) {
List errMsg= new ArrayList<>();
if (bindingResult.hasErrors()) {
for (ObjectError error : bindingResult.getAllErrors()) {
errMsg.add(error.getDefaultMessage());
}
return ResultBody.failed().msg(errMsg.toString());
} else {
boolean v= productOrderDetailService.saveOrUpdate(productOrderDetail);
if(v) {
return ResultBody.ok().data(productOrderDetail).msg("保存成功");
}
else {
return ResultBody.failed().msg("保存失败");
}
}
}
/**
* 删除
*/
@ApiOperation(value = "删除")
@DeleteMapping("/{id}")
public ResultBody delete(@PathVariable Long id) {
boolean v= productOrderDetailService.removeById(id);
if(v) {
if (!businessRecordsService.recordBusinessData("删除订单明细:"+id,id.toString())) {
//log.error(String.format("删除订单明细id为:{1}",id));
}
return ResultBody.ok().msg("删除成功");
}
else {
return ResultBody.failed().msg("删除失败");
}
}
/**
* 修改状态
*
* @param params
* @return
*/
@ApiOperation(value = "修改数据状态")
@GetMapping("/updateEnabled")
@ApiImplicitParams({
@ApiImplicitParam(name = "id", value = "id", required = true, dataType = "Integer"),
@ApiImplicitParam(name = "enabled", value = "是否启用", required = true, dataType = "Boolean")
})
public ResultBody updateEnabled(@RequestParam Map params, HttpServletRequest request) {
if (params.size() == 0) {
return ResultBody.failed().msg("参数异常!");
}
ResultBody resultBody=productOrderDetailService.updateEnabled(params);
//记录业务日志
if (resultBody.getCode()==0) {
String enablad=(MapUtils.getBoolean(params, "enabled"))?"启用":"禁用";
if (!businessRecordsService.recordBusinessData("修改订单明细状态为:"+enablad,enablad)) {
//log.error(String.format("修改合同状态为:{0},写入业务日志失败!合同管理id为:{1}",enablad,MapUtils.getString(params,"id")));
}
}
return resultBody;
}
}