package com.fuint.module.backendApi.controller; import com.fuint.common.dto.AccountInfo; import com.fuint.common.dto.CommissionCashDto; import com.fuint.common.dto.ParamDto; import com.fuint.common.enums.CommissionCashStatusEnum; import com.fuint.common.service.CommissionCashService; import com.fuint.common.service.StoreService; import com.fuint.common.util.TokenUtil; import com.fuint.framework.web.BaseController; import com.fuint.framework.web.ResponseObject; import com.fuint.common.Constants; import com.fuint.common.enums.StatusEnum; import com.fuint.framework.pagination.PaginationRequest; import com.fuint.framework.pagination.PaginationResponse; import com.fuint.framework.exception.BusinessCheckException; import com.fuint.module.backendApi.request.CommissionCashRequest; import com.fuint.module.backendApi.request.CommissionSettleConfirmRequest; import com.fuint.repository.model.MtStore; import com.fuint.utils.StringUtil; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; import lombok.AllArgsConstructor; import org.springframework.security.access.prepost.PreAuthorize; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpServletRequest; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; /** * 分销提成提现管理类controller * * Created by FSQ * CopyRight https://www.fuint.cn */ @Api(tags="管理端-分销提成提现相关接口") @RestController @AllArgsConstructor @RequestMapping(value = "/backendApi/commissionCash") public class BackendCommissionCashController extends BaseController { /** * 店铺服务接口 */ private StoreService storeService; /** * 分销提成提现业务接口 */ private CommissionCashService commissionCashService; /** * 分销提成提现记录列表 * * @param request HttpServletRequest对象 * @return 分销提成记录 */ @ApiOperation(value = "分销提成提现记录列表") @RequestMapping(value = "/list", method = RequestMethod.GET) @CrossOrigin @PreAuthorize("@pms.hasPermission('commission:cash:index')") public ResponseObject list(HttpServletRequest request) throws BusinessCheckException { String token = request.getHeader("Access-Token"); Integer page = request.getParameter("page") == null ? Constants.PAGE_NUMBER : Integer.parseInt(request.getParameter("page")); Integer pageSize = request.getParameter("pageSize") == null ? Constants.PAGE_SIZE : Integer.parseInt(request.getParameter("pageSize")); String realName = request.getParameter("realName"); String mobile = request.getParameter("mobile"); String status = request.getParameter("status"); String searchStoreId = request.getParameter("storeId"); String uuid = request.getParameter("uuid"); String startTime = request.getParameter("startTime") == null ? "" : request.getParameter("startTime"); String endTime = request.getParameter("endTime") == null ? "" : request.getParameter("endTime"); AccountInfo accountInfo = TokenUtil.getAccountInfoByToken(token); Integer storeId; if (accountInfo == null) { return getFailureResult(1001, "请先登录"); } else { storeId = accountInfo.getStoreId(); } PaginationRequest paginationRequest = new PaginationRequest(); paginationRequest.setCurrentPage(page); paginationRequest.setPageSize(pageSize); Map params = new HashMap<>(); if (StringUtil.isNotEmpty(realName)) { params.put("realName", realName); } if (StringUtil.isNotEmpty(mobile)) { params.put("mobile", mobile); } if (StringUtil.isNotEmpty(status)) { params.put("status", status); } if (StringUtil.isNotEmpty(searchStoreId)) { params.put("storeId", searchStoreId); } if (storeId != null && storeId > 0) { params.put("storeId", storeId); } if (StringUtil.isNotEmpty(uuid)) { params.put("uuid", uuid); } if (StringUtil.isNotEmpty(startTime)) { params.put("startTime", startTime); } if (StringUtil.isNotEmpty(endTime)) { params.put("endTime", endTime); } paginationRequest.setSearchParams(params); PaginationResponse paginationResponse = commissionCashService.queryCommissionCashByPagination(paginationRequest); Map paramsStore = new HashMap<>(); paramsStore.put("status", StatusEnum.ENABLED.getKey()); if (accountInfo.getStoreId() != null && accountInfo.getStoreId() > 0) { paramsStore.put("storeId", accountInfo.getStoreId().toString()); } if (accountInfo.getMerchantId() != null && accountInfo.getMerchantId() > 0) { paramsStore.put("merchantId", accountInfo.getMerchantId()); } List storeList = storeService.queryStoresByParams(paramsStore); // 状态列表 CommissionCashStatusEnum[] statusListEnum = CommissionCashStatusEnum.values(); List statusList = new ArrayList<>(); for (CommissionCashStatusEnum enumItem : statusListEnum) { ParamDto paramDto = new ParamDto(); paramDto.setKey(enumItem.getKey()); paramDto.setName(enumItem.getValue()); paramDto.setValue(enumItem.getKey()); statusList.add(paramDto); } Map result = new HashMap<>(); result.put("dataList", paginationResponse); result.put("storeList", storeList); result.put("statusList", statusList); return getSuccessResult(result); } /** * 获取分销提成记录详情 * * @param id * @return */ @ApiOperation(value = "获取分销提成提现详情") @RequestMapping(value = "/info/{id}", method = RequestMethod.GET) @CrossOrigin @PreAuthorize("@pms.hasPermission('commission:cash:index')") public ResponseObject info(HttpServletRequest request, @PathVariable("id") Integer id) throws BusinessCheckException { String token = request.getHeader("Access-Token"); AccountInfo accountInfo = TokenUtil.getAccountInfoByToken(token); if (accountInfo == null) { return getFailureResult(1001, "请先登录"); } CommissionCashDto commissionCash = commissionCashService.queryCommissionCashById(id); Map result = new HashMap<>(); result.put("commissionCash", commissionCash); return getSuccessResult(result); } /** * 修改分销提成提现 * * @param request HttpServletRequest对象 * @return */ @ApiOperation(value = "修改分销提成提现") @RequestMapping(value = "/save", method = RequestMethod.POST) @PreAuthorize("@pms.hasPermission('commission:cash:index')") public ResponseObject save(HttpServletRequest request, @RequestBody CommissionCashRequest commissionCashRequest) throws BusinessCheckException { String token = request.getHeader("Access-Token"); AccountInfo accountDto = TokenUtil.getAccountInfoByToken(token); if (accountDto == null) { return getFailureResult(1001, "请先登录"); } commissionCashRequest.setOperator(accountDto.getAccountName()); commissionCashService.updateCommissionCash(commissionCashRequest); return getSuccessResult(true); } /** * 结算确认 * * @param request HttpServletRequest对象 * @return */ @ApiOperation(value = "结算确认") @RequestMapping(value = "/confirm", method = RequestMethod.POST) @PreAuthorize("@pms.hasPermission('commission:cash:index')") public ResponseObject confirm(HttpServletRequest request, @RequestBody CommissionSettleConfirmRequest requestParam) throws BusinessCheckException { String token = request.getHeader("Access-Token"); AccountInfo accountDto = TokenUtil.getAccountInfoByToken(token); if (accountDto == null) { return getFailureResult(1001, "请先登录"); } requestParam.setOperator(accountDto.getAccountName()); if (accountDto.getMerchantId() != null && accountDto.getMerchantId() > 0) { requestParam.setMerchantId(accountDto.getMerchantId()); } commissionCashService.confirmCommissionCash(requestParam); return getSuccessResult(true); } /** * 取消结算 * * @param request HttpServletRequest对象 * @return */ @ApiOperation(value = "取消结算") @RequestMapping(value = "/cancel", method = RequestMethod.POST) @PreAuthorize("@pms.hasPermission('commission:cash:index')") public ResponseObject cancel(HttpServletRequest request, @RequestBody CommissionSettleConfirmRequest requestParam) throws BusinessCheckException { String token = request.getHeader("Access-Token"); AccountInfo accountDto = TokenUtil.getAccountInfoByToken(token); if (accountDto == null) { return getFailureResult(1001, "请先登录"); } if (accountDto.getMerchantId() != null && accountDto.getMerchantId() > 0) { requestParam.setMerchantId(accountDto.getMerchantId()); } requestParam.setOperator(accountDto.getAccountName()); commissionCashService.cancelCommissionCash(requestParam); return getSuccessResult(true); } }