From 5ec06c513fd1060c9a91c9205bb2f0b96ca2ee2a Mon Sep 17 00:00:00 2001 From: Helius <wangdoubleone@gmail.com> Date: Fri, 27 May 2022 17:11:38 +0800 Subject: [PATCH] fix --- src/main/java/cc/mrbird/febs/mall/dto/AgentLevelUpdateDto.java | 2 src/main/java/cc/mrbird/febs/mall/vo/AdminAgentLevelUpdateInfoVo.java | 2 src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate-bak.html | 119 +++++++++++++++++++++++++++++ src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate.html | 48 +---------- src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java | 17 ++- src/main/java/cc/mrbird/febs/common/enumerates/AgentLevelEnum.java | 12 +- src/main/resources/templates/febs/views/modules/mallMember/agentList.html | 12 +- src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java | 21 +---- src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java | 2 9 files changed, 156 insertions(+), 79 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/common/enumerates/AgentLevelEnum.java b/src/main/java/cc/mrbird/febs/common/enumerates/AgentLevelEnum.java index 6e73596..784c505 100644 --- a/src/main/java/cc/mrbird/febs/common/enumerates/AgentLevelEnum.java +++ b/src/main/java/cc/mrbird/febs/common/enumerates/AgentLevelEnum.java @@ -9,14 +9,12 @@ @Getter public enum AgentLevelEnum { - ZERO_LEVEL("未激活"), + ZERO_LEVEL("非会员"), FIRST_LEVEL("普通会员"), - SECOND_LEVEL("业务经理"), - THIRD_LEVEL("区域代理"), - FOUR_LEVEL("代理"), - FIFTH_LEVEL("总代"), - SIX_LEVEL("董事"), - SEVEN_LEVEL("股东"); + SECOND_LEVEL("区级代理"), + THIRD_LEVEL("市级代理"), + FOUR_LEVEL("省级代理"), + FIFTH_LEVEL("全国总代"); private String name; diff --git a/src/main/java/cc/mrbird/febs/mall/dto/AgentLevelUpdateDto.java b/src/main/java/cc/mrbird/febs/mall/dto/AgentLevelUpdateDto.java index 8029766..9fadc33 100644 --- a/src/main/java/cc/mrbird/febs/mall/dto/AgentLevelUpdateDto.java +++ b/src/main/java/cc/mrbird/febs/mall/dto/AgentLevelUpdateDto.java @@ -41,4 +41,6 @@ * 团队收益 1-指定金额 2-比例 */ private Integer teamIncomeType; + + private BigDecimal profitProp; } diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java index d6a1e7b..91fb9a4 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java @@ -192,17 +192,10 @@ @Override public AdminAgentLevelUpdateInfoVo getAgentLevelUpdateInfoById(long id) { - AdminAgentLevelUpdateInfoVo adminAgentLevelUpdateInfoVo = new AdminAgentLevelUpdateInfoVo(); DataDictionaryCustom dataDictionaryCustom = dataDictionaryCustomMapper.selectById(id); String value = dataDictionaryCustom.getValue(); //{"directIncome":36,"lastCnt":3,"orderCnt":500,"orderType":2,"teamIncome":6,"teamIncomeType":2} - JSONObject jsonObject = JSONObject.parseObject(value); - adminAgentLevelUpdateInfoVo.setDirectIncome(new BigDecimal((jsonObject.get("directIncome")==null?0:jsonObject.get("directIncome")).toString())); - adminAgentLevelUpdateInfoVo.setLastCnt(Integer.parseInt((jsonObject.get("lastCnt")==null?0:jsonObject.get("lastCnt")).toString())); - adminAgentLevelUpdateInfoVo.setOrderCnt(Integer.parseInt((jsonObject.get("orderCnt")==null?0:jsonObject.get("orderCnt")).toString())); - adminAgentLevelUpdateInfoVo.setOrderType(Integer.parseInt(jsonObject.get("orderType").toString())); - adminAgentLevelUpdateInfoVo.setTeamIncome(new BigDecimal((jsonObject.get("teamIncome")==null?0:jsonObject.get("teamIncome")).toString())); - adminAgentLevelUpdateInfoVo.setTeamIncomeType(Integer.parseInt(jsonObject.get("orderType").toString())); + AdminAgentLevelUpdateInfoVo adminAgentLevelUpdateInfoVo = JSONObject.parseObject(value, AdminAgentLevelUpdateInfoVo.class); adminAgentLevelUpdateInfoVo.setId(id); return adminAgentLevelUpdateInfoVo; } @@ -210,15 +203,9 @@ @Override public FebsResponse agentLevelUpdate(AgentLevelUpdateDto agentLevelUpdateDto) { DataDictionaryCustom dataDictionaryCustom = dataDictionaryCustomMapper.selectById(agentLevelUpdateDto.getId()); - AgentLevelUpdateDto agentLevelUpdateDtoJson = new AgentLevelUpdateDto(); - agentLevelUpdateDtoJson.setDirectIncome(agentLevelUpdateDto.getDirectIncome()); - agentLevelUpdateDtoJson.setLastCnt(agentLevelUpdateDto.getLastCnt()); - agentLevelUpdateDtoJson.setOrderCnt(agentLevelUpdateDto.getOrderCnt()); - agentLevelUpdateDtoJson.setTeamIncome(agentLevelUpdateDto.getTeamIncome()); - agentLevelUpdateDtoJson.setOrderType(agentLevelUpdateDto.getOrderType()); - agentLevelUpdateDtoJson.setTeamIncomeType(agentLevelUpdateDto.getTeamIncomeType()); - JSONObject jsonObject = (JSONObject)JSONObject.toJSON(agentLevelUpdateDtoJson); - dataDictionaryCustom.setValue(jsonObject.toString()); + + agentLevelUpdateDto.setId(null); + dataDictionaryCustom.setValue(JSONObject.toJSONString(agentLevelUpdateDto)); dataDictionaryCustomMapper.updateById(dataDictionaryCustom); return new FebsResponse().success(); } diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java index 100b886..01d5eaf 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java @@ -110,7 +110,7 @@ mallMember.setName(registerDto.getName()); mallMember.setAccountStatus(MallMember.ACCOUNT_STATUS_ENABLE); mallMember.setAccountType(MallMember.ACCOUNT_TYPE_NORMAL); - mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name()); + mallMember.setLevel(AgentLevelEnum.ZERO_LEVEL.name()); mallMember.setSex("男"); mallMember.setBindPhone(registerDto.getAccount()); diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java index 61ded98..a21cfb8 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallOrderInfoServiceImpl.java @@ -225,12 +225,7 @@ orderInfo.setPayTime(new Date()); orderInfo.setPayResult("1"); -// MallMember mallMember = memberMapper.selectById(member.getId()); -// if (AgentLevelEnum.ZERO_LEVEL.name().equals(mallMember.getLevel())) { -// mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name()); -// memberMapper.updateById(mallMember); -// } - + boolean hasTc = false; // 静态倍数 List<MallOrderItem> orderItems = this.baseMapper.getMallOrderItemByOrderId(orderInfo.getId()); if (CollUtil.isNotEmpty(orderItems)) { @@ -238,6 +233,7 @@ MallGoods mallGoods = mallGoodsMapper.selectById(orderItem.getGoodsId()); if (mallGoods.getIsNormal() == 2) { + hasTc = true; MallGoodsSku sku = mallGoodsSkuMapper.selectById(orderItem.getSkuId()); BigDecimal score = sku.getOriginalPrice().multiply(mallGoods.getStaticMulti()); @@ -247,6 +243,15 @@ } } + // 购买套餐后,升级为普通会员 + if (hasTc) { + MallMember mallMember = memberMapper.selectById(member.getId()); + if (AgentLevelEnum.ZERO_LEVEL.name().equals(mallMember.getLevel())) { + mallMember.setLevel(AgentLevelEnum.FIRST_LEVEL.name()); + memberMapper.updateById(mallMember); + } + } + mallMoneyFlowService.addMoneyFlow(member.getId(), orderInfo.getAmount().negate(), MoneyFlowTypeEnum.PAY.getValue(), orderInfo.getOrderNo(), FlowTypeEnum.BALANCE.getValue()); // agentProducer.sendAutoLevelUpMsg(member.getId()); agentProducer.sendOrderReturn(orderInfo.getId()); diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminAgentLevelUpdateInfoVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminAgentLevelUpdateInfoVo.java index 3181d8f..49aab25 100644 --- a/src/main/java/cc/mrbird/febs/mall/vo/AdminAgentLevelUpdateInfoVo.java +++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminAgentLevelUpdateInfoVo.java @@ -41,4 +41,6 @@ * 团队收益 1-指定金额 2-比例 */ private Integer teamIncomeType; + + private BigDecimal profitProp; } diff --git a/src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate-bak.html b/src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate-bak.html new file mode 100644 index 0000000..3f29742 --- /dev/null +++ b/src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate-bak.html @@ -0,0 +1,119 @@ +<style> + #agent-level-edit { + padding: 20px 25px 25px 0; + } + + #agent-level-edit .layui-treeSelect .ztree li a, .ztree li span { + margin: 0 0 2px 3px !important; + } + #agent-level-edit #data-permission-tree-block { + border: 1px solid #eee; + border-radius: 2px; + padding: 3px 0; + } + #agent-level-edit .layui-treeSelect .ztree li span.button.switch { + top: 1px; + left: 3px; + } + #agent-level-edit img{ + max-width:200px + } + +</style> +<div class="layui-fluid" id="agent-level-edit"> + <form class="layui-form" action="" lay-filter="agent-level-edit-form"> + <div class="layui-form-item febs-hide"> + <label class="layui-form-label">id:</label> + <div class="layui-input-block"> + <input type="text" name="id"> + </div> + </div> + <div class="layui-form-item"> + <label class="layui-form-label febs-form-item-require">下单数量要求:</label> + <div class="layui-input-block"> + <input type="radio" name="orderType" value="1" title="直推" > + <input type="radio" name="orderType" value="2" title="团队"> + </div> + </div> + <div class="layui-form-item"> + <label class="layui-form-label febs-form-item-require">下单数量:</label> + <div class="layui-input-block"> + <input type="number" name="orderCnt" class="layui-input"> + </div> + </div> + <div class="layui-form-item"> + <label class="layui-form-label febs-form-item-require">需要上一级的数量:</label> + <div class="layui-input-block"> + <input type="number" name="lastCnt" class="layui-input"> + </div> + </div> + <div class="layui-form-item"> + <label class="layui-form-label febs-form-item-require">团队收益类型:</label> + <div class="layui-input-block"> + <input type="radio" name="teamIncomeType" value="1" title="指定金额" > + <input type="radio" name="teamIncomeType" value="2" title="比例"> + </div> + </div> + <div class="layui-form-item"> + <div style="text-align:center;color: red">提示:【团队收益】如果选择【比例】,请输入百分比数字,如:80%,请输入80</div> + </div> + <div class="layui-form-item"> + <label class="layui-form-label febs-form-item-require">团队收益:</label> + <div class="layui-input-block"> + <input type="number" name="teamIncome" class="layui-input"> + </div> + </div> + <div class="layui-form-item"> + <div style="text-align:center;color: red">提示:【直推收益】请输入百分比数字,如:80%,请输入80</div> + </div> + <div class="layui-form-item"> + <label class="layui-form-label febs-form-item-require">直推收益:</label> + <div class="layui-input-block"> + <input type="number" name="directIncome" class="layui-input"> + </div> + </div> + <div class="layui-form-item febs-hide"> + <button class="layui-btn" lay-submit="" lay-filter="agent-level-edit-submit" id="submit"></button> + </div> + </form> +</div> + +<script data-th-inline="javascript"> + layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree'], function () { + var $ = layui.$, + febs = layui.febs, + layer = layui.layer, + formSelects = layui.formSelects, + treeSelect = layui.treeSelect, + form = layui.form, + eleTree = layui.eleTree, + agentLevelUpdateInfo = [[${agentLevelUpdateInfo}]], + $view = $('#agent-level-edit'), + validate = layui.validate, + _deptTree; + form.render(); + + initUserValue(); + + function initUserValue() { + form.val("agent-level-edit-form", { + "id": agentLevelUpdateInfo.id, + "orderType": agentLevelUpdateInfo.orderType, + "orderCnt": agentLevelUpdateInfo.orderCnt, + "directIncome": agentLevelUpdateInfo.directIncome, + "teamIncome": agentLevelUpdateInfo.teamIncome, + "teamIncomeType": agentLevelUpdateInfo.teamIncomeType, + "lastCnt": agentLevelUpdateInfo.lastCnt + }); + } + + form.on('submit(agent-level-edit-submit)', function (data) { + febs.post(ctx + 'admin/mallMember/agentLevelUpdate', data.field, function () { + layer.closeAll(); + febs.alert.success('操作成功'); + $('#febs-user-agent-level').find('#reset').click(); + }); + return false; + }); + }); +</script> \ No newline at end of file diff --git a/src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate.html b/src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate.html index 3f29742..0735a7c 100644 --- a/src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate.html +++ b/src/main/resources/templates/febs/views/modules/mallMember/agentLevelUpdate.html @@ -29,47 +29,17 @@ </div> </div> <div class="layui-form-item"> - <label class="layui-form-label febs-form-item-require">下单数量要求:</label> + <label class="layui-form-label febs-form-item-require">团队业绩:</label> <div class="layui-input-block"> - <input type="radio" name="orderType" value="1" title="直推" > - <input type="radio" name="orderType" value="2" title="团队"> + <input type="number" name="teamIncome" class="layui-input" placeholder="万元"> + <div class="layui-form-mid layui-word-aux">万元</div> </div> </div> <div class="layui-form-item"> - <label class="layui-form-label febs-form-item-require">下单数量:</label> + <label class="layui-form-label febs-form-item-require">返利比例:</label> <div class="layui-input-block"> - <input type="number" name="orderCnt" class="layui-input"> - </div> - </div> - <div class="layui-form-item"> - <label class="layui-form-label febs-form-item-require">需要上一级的数量:</label> - <div class="layui-input-block"> - <input type="number" name="lastCnt" class="layui-input"> - </div> - </div> - <div class="layui-form-item"> - <label class="layui-form-label febs-form-item-require">团队收益类型:</label> - <div class="layui-input-block"> - <input type="radio" name="teamIncomeType" value="1" title="指定金额" > - <input type="radio" name="teamIncomeType" value="2" title="比例"> - </div> - </div> - <div class="layui-form-item"> - <div style="text-align:center;color: red">提示:【团队收益】如果选择【比例】,请输入百分比数字,如:80%,请输入80</div> - </div> - <div class="layui-form-item"> - <label class="layui-form-label febs-form-item-require">团队收益:</label> - <div class="layui-input-block"> - <input type="number" name="teamIncome" class="layui-input"> - </div> - </div> - <div class="layui-form-item"> - <div style="text-align:center;color: red">提示:【直推收益】请输入百分比数字,如:80%,请输入80</div> - </div> - <div class="layui-form-item"> - <label class="layui-form-label febs-form-item-require">直推收益:</label> - <div class="layui-input-block"> - <input type="number" name="directIncome" class="layui-input"> + <input type="number" name="profitProp" class="layui-input" placeholder="%"> + <div class="layui-form-mid layui-word-aux">%</div> </div> </div> <div class="layui-form-item febs-hide"> @@ -98,12 +68,8 @@ function initUserValue() { form.val("agent-level-edit-form", { "id": agentLevelUpdateInfo.id, - "orderType": agentLevelUpdateInfo.orderType, - "orderCnt": agentLevelUpdateInfo.orderCnt, - "directIncome": agentLevelUpdateInfo.directIncome, "teamIncome": agentLevelUpdateInfo.teamIncome, - "teamIncomeType": agentLevelUpdateInfo.teamIncomeType, - "lastCnt": agentLevelUpdateInfo.lastCnt + "profitProp": agentLevelUpdateInfo.profitProp }); } diff --git a/src/main/resources/templates/febs/views/modules/mallMember/agentList.html b/src/main/resources/templates/febs/views/modules/mallMember/agentList.html index dcf2afe..f704b1f 100644 --- a/src/main/resources/templates/febs/views/modules/mallMember/agentList.html +++ b/src/main/resources/templates/febs/views/modules/mallMember/agentList.html @@ -18,17 +18,15 @@ </div> </div> <div class="layui-inline"> - <label class="layui-form-label layui-form-label-sm">账户状态</label> + <label class="layui-form-label layui-form-label-sm">代理层级</label> <div class="layui-input-inline"> <select name="level"> <option value="">请选择</option> - <option value="ZERO_LEVEL">未激活</option> <option value="FIRST_LEVEL">普通会员</option> - <option value="SECOND_LEVEL">业务经理</option> - <option value="THIRD_LEVEL">区域代理</option> - <option value="FOUR_LEVEL">代理</option> - <option value="FIFTH_LEVEL">总代</option> - <option value="SIX_LEVEL">董事</option> + <option value="SECOND_LEVEL">区级代理</option> + <option value="THIRD_LEVEL">市级代理</option> + <option value="FOUR_LEVEL">省级代理</option> + <option value="FIFTH_LEVEL">全国总代</option> </select> </div> </div> -- Gitblit v1.9.1