From 1af6c4c935d3ee880c61a5ab067a9b4196d2a796 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Fri, 28 Jul 2023 15:48:00 +0800 Subject: [PATCH] 赠送积分更新状态 --- src/main/java/cc/mrbird/febs/mall/dto/AdminRollHouseCheckDto.java | 16 ++ src/main/java/cc/mrbird/febs/mall/controller/ViewMallMemberController.java | 26 +++ src/main/resources/templates/febs/views/modules/mallMember/rollHouseList.html | 200 ++++++++++++++++++++++++++++ src/main/resources/templates/febs/views/modules/mallMember/rollHouseCheck.html | 82 +++++++++++ src/main/java/cc/mrbird/febs/mall/mapper/MallMemberMapper.java | 2 src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java | 18 ++ src/main/java/cc/mrbird/febs/mall/entity/MallMemberHouse.java | 7 + src/main/resources/mapper/modules/MallMemberMapper.xml | 25 +++ src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java | 4 src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java | 25 +++ 10 files changed, 405 insertions(+), 0 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java index f26cca9..8e58190 100644 --- a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java +++ b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java @@ -553,4 +553,22 @@ return mallMemberService.agentVerifyUpdate(adminAgentVerifyVo); } + /** + * 民宿核销列表 + */ + @GetMapping("rollHouseList") + public FebsResponse rollHouseList(MallMemberHouse mallMemberHouse, QueryRequest request) { + Map<String, Object> data = getDataTable(mallMemberService.getMallRollHouseList(mallMemberHouse, request)); + return new FebsResponse().success().data(data); + } + + /** + * 民宿核销列表-核销 + */ + @PostMapping("rollHouseCheck") + @ControllerEndpoint(operation = "民宿核销列表-核销", exceptionMessage = "操作失败") + public FebsResponse rollHouseCheck(@Valid AdminRollHouseCheckDto rollHouseCheckDto) { + return mallMemberService.rollHouseCheck(rollHouseCheckDto); + } + } diff --git a/src/main/java/cc/mrbird/febs/mall/controller/ViewMallMemberController.java b/src/main/java/cc/mrbird/febs/mall/controller/ViewMallMemberController.java index 25c2a31..8ff5849 100644 --- a/src/main/java/cc/mrbird/febs/mall/controller/ViewMallMemberController.java +++ b/src/main/java/cc/mrbird/febs/mall/controller/ViewMallMemberController.java @@ -5,6 +5,7 @@ import cc.mrbird.febs.common.utils.FebsUtil; import cc.mrbird.febs.mall.entity.*; import cc.mrbird.febs.mall.mapper.MallAgentRecordMapper; +import cc.mrbird.febs.mall.mapper.MallMemberHouseMapper; import cc.mrbird.febs.mall.mapper.MallSalesmanMapper; import cc.mrbird.febs.mall.service.IAdminMallMemberService; import cc.mrbird.febs.mall.vo.*; @@ -25,6 +26,7 @@ private final MallSalesmanMapper mallSalesmanMapper; private final MallAgentRecordMapper mallAgentRecordMapper; + private final MallMemberHouseMapper mallMemberHouseMapper; public static long idFromMoneyFlow; @@ -364,5 +366,29 @@ return FebsUtil.view("modules/mallMember/agentVerify"); } + /** + * 民宿核销列表 + * @return + */ + @GetMapping("rollHouseList") + @RequiresPermissions("rollHouseList:view") + public String rollHouseList() { + return FebsUtil.view("modules/mallMember/rollHouseList"); + } + + /** + * 民宿核销列表-核销 + * @param id + * @param model + * @return + */ + @GetMapping("rollHouseCheck/{id}") + @RequiresPermissions("rollHouseCheck:update") + public String rollHouseCheck(@PathVariable long id, Model model) { + MallMemberHouse mallMemberHouse = mallMemberHouseMapper.selectById(id); + model.addAttribute("mallMemberHouse", mallMemberHouse); + return FebsUtil.view("modules/mallMember/rollHouseCheck"); + } + } diff --git a/src/main/java/cc/mrbird/febs/mall/dto/AdminRollHouseCheckDto.java b/src/main/java/cc/mrbird/febs/mall/dto/AdminRollHouseCheckDto.java new file mode 100644 index 0000000..4a38ee7 --- /dev/null +++ b/src/main/java/cc/mrbird/febs/mall/dto/AdminRollHouseCheckDto.java @@ -0,0 +1,16 @@ +package cc.mrbird.febs.mall.dto; + +import io.swagger.annotations.ApiModel; +import lombok.Data; + +import javax.validation.constraints.NotNull; + +@Data +@ApiModel(value = "AdminRollHouseCheckDto", description = "参数接收类") +public class AdminRollHouseCheckDto { + + private Long id; + @NotNull(message = "参数不能为空") + private String takeCode; + +} diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallMemberHouse.java b/src/main/java/cc/mrbird/febs/mall/entity/MallMemberHouse.java index be8507b..d3e300d 100644 --- a/src/main/java/cc/mrbird/febs/mall/entity/MallMemberHouse.java +++ b/src/main/java/cc/mrbird/febs/mall/entity/MallMemberHouse.java @@ -1,6 +1,7 @@ package cc.mrbird.febs.mall.entity; import com.baomidou.mybatisplus.annotation.IdType; +import com.baomidou.mybatisplus.annotation.TableField; import com.baomidou.mybatisplus.annotation.TableId; import com.baomidou.mybatisplus.annotation.TableName; import com.fasterxml.jackson.annotation.JsonFormat; @@ -35,4 +36,10 @@ private String houseAddress; private String housePic; + + @TableField(exist = false) + private String name; + @TableField(exist = false) + private String phone; + } diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberMapper.java index 993ae13..2d7e61d 100644 --- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberMapper.java +++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberMapper.java @@ -92,4 +92,6 @@ IPage<MallMemberClass> findMallMemberClassInPage(Page<MallMemberClass> page, @Param("record")MallMemberClass mallMemberClass); IPage<MallMemberHouse> findMallMemberHouseInPage(Page<MallMemberHouse> page, @Param("record")MallMemberHouse mallMemberHouse); + + IPage<MallMemberHouse> getMallRollHouseListInPage(Page<MallMemberHouse> page, @Param("record")MallMemberHouse mallMemberHouse); } diff --git a/src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java b/src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java index 86c2992..18a1c54 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java +++ b/src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java @@ -126,4 +126,8 @@ List<AdminAgentLevelOptionTreeVo> agentLevelOption(); FebsResponse agentVerifyUpdate(AdminAgentVerifyVo adminAgentVerifyVo); + + IPage<MallMemberHouse> getMallRollHouseList(MallMemberHouse mallMemberHouse, QueryRequest request); + + FebsResponse rollHouseCheck(AdminRollHouseCheckDto rollHouseCheckDto); } 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 5f92116..d4aceb4 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 @@ -70,6 +70,8 @@ private final MallAgentRecordMapper mallAgentRecordMapper; private final MallSalesmanMapper mallSalesmanMapper; + private final MallMemberHouseMapper mallMemberHouseMapper; + private final MallOrderInfoMapper mallOrderInfoMapper; @Override public IPage<MallMember> getMallMemberList(MallMember mallMember, QueryRequest request) { @@ -311,6 +313,29 @@ } @Override + public IPage<MallMemberHouse> getMallRollHouseList(MallMemberHouse mallMemberHouse, QueryRequest request) { + Page<MallMemberHouse> page = new Page<>(request.getPageNum(), request.getPageSize()); + IPage<MallMemberHouse> mallMemberHouseIPage = this.baseMapper.getMallRollHouseListInPage(page, mallMemberHouse); + return mallMemberHouseIPage; + } + + @Override + public FebsResponse rollHouseCheck(AdminRollHouseCheckDto rollHouseCheckDto) { + MallMemberHouse mallMemberHouse = mallMemberHouseMapper.selectById(rollHouseCheckDto.getId()); + String takeCode = rollHouseCheckDto.getTakeCode(); + + Long orderId = mallMemberHouse.getOrderId(); + MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(orderId); + String takeCode1 = mallOrderInfo.getTakeCode(); + if(!takeCode1.equals(takeCode)){ + throw new FebsException("核销码不正确"); + } + mallMemberHouse.setState(2); + mallMemberHouseMapper.updateById(mallMemberHouse); + return new FebsResponse().success().message("操作成功"); + } + + @Override public IPage<AdminAgentMemberVo> agentChild(QueryRequest request, MallMember mallMember) { Long memberId = mallMember.getId(); mallMember = mallMemberMapper.selectById(memberId); diff --git a/src/main/resources/mapper/modules/MallMemberMapper.xml b/src/main/resources/mapper/modules/MallMemberMapper.xml index 93b9456..d859b84 100644 --- a/src/main/resources/mapper/modules/MallMemberMapper.xml +++ b/src/main/resources/mapper/modules/MallMemberMapper.xml @@ -431,4 +431,29 @@ </if> order by id desc </select> + + <select id="getMallRollHouseListInPage" resultType="cc.mrbird.febs.mall.entity.MallMemberHouse"> + select + a.*, + b.name, + b.phone + from mall_member_house a + left join mall_member b on a.member_id = b.id + <where> + <if test="record.state != null and record.state != ''"> + and a.state = #{record.state} + </if> + <if test="record.orderNo != null and record.orderNo != ''"> + and a.order_no = #{record.orderNo} + </if> + <if test="record.name != null and record.name != ''"> + and b.name = #{record.name} + </if> + <if test="record.phone != null and record.phone != ''"> + and b.phone = #{record.phone} + </if> + + </where> + order by id desc + </select> </mapper> \ No newline at end of file diff --git a/src/main/resources/templates/febs/views/modules/mallMember/rollHouseCheck.html b/src/main/resources/templates/febs/views/modules/mallMember/rollHouseCheck.html new file mode 100644 index 0000000..d5164a6 --- /dev/null +++ b/src/main/resources/templates/febs/views/modules/mallMember/rollHouseCheck.html @@ -0,0 +1,82 @@ +<style> + #houseCheck-update { + padding: 20px 25px 25px 0; + } + + #houseCheck-update .layui-treeSelect .ztree li a, .ztree li span { + margin: 0 0 2px 3px !important; + } + #houseCheck-update #data-permission-tree-block { + border: 1px solid #eee; + border-radius: 2px; + padding: 3px 0; + } + #houseCheck-update .layui-treeSelect .ztree li span.button.switch { + top: 1px; + left: 3px; + } + #houseCheck-update img{ + max-width:100px + } + +</style> +<div class="layui-fluid" id="houseCheck-update"> + <form class="layui-form" action="" lay-filter="houseCheck-update-form"> + <div class="layui-form-item febs-hide"> + <label class="layui-form-label febs-form-item-require">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="number" name="takeCode" lay-verify="required" autocomplete="off" class="layui-input"> + <div class="layui-word-aux">请输入我的民宿中的验证码。</div> + </div> + </div> + <div class="layui-form-item febs-hide"> + <button class="layui-btn" lay-submit="" lay-filter="houseCheck-update-form-submit" id="submit"></button> + </div> + </form> +</div> + +<script data-th-inline="javascript"> + layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree', 'laydate'], function () { + var $ = layui.$, + febs = layui.febs, + layer = layui.layer, + formSelects = layui.formSelects, + form = layui.form, + laydate = layui.laydate, + mallMemberHouse = [[${mallMemberHouse}]], + type = [[${type}]], + $view = $('#houseCheck-update'), + validate = layui.validate; + + form.render(); + laydate.render({ + elem: '#febs-form-group-date' + }); + + formSelects.render(); + + + initUserValue(); + + function initUserValue() { + form.val("houseCheck-update-form", { + "id": mallMemberHouse.id, + }); + } + + form.on('submit(houseCheck-update-form-submit)', function (data) { + febs.post(ctx + 'admin/mallMember/rollHouseCheck', data.field, function () { + layer.closeAll(); + febs.alert.success('操作成功'); + $('#febs-roll-house-list').find('#query').click(); + }); + return false; + }); + }); +</script> \ No newline at end of file diff --git a/src/main/resources/templates/febs/views/modules/mallMember/rollHouseList.html b/src/main/resources/templates/febs/views/modules/mallMember/rollHouseList.html new file mode 100644 index 0000000..4dc56c1 --- /dev/null +++ b/src/main/resources/templates/febs/views/modules/mallMember/rollHouseList.html @@ -0,0 +1,200 @@ +<div class="layui-fluid layui-anim febs-anim" id="febs-roll-house-list" lay-title="民宿核销"> + <div class="layui-row febs-container"> + <div class="layui-col-md12"> + <div class="layui-card"> + <div class="layui-card-body febs-table-full"> + <form class="layui-form layui-table-form" lay-filter="user-table-form"> + <div class="layui-row"> + <div class="layui-col-md10"> + <div class="layui-form-item"> + <div class="layui-inline"> + <label class="layui-form-label layui-form-label-sm">订单编号</label> + <div class="layui-input-inline"> + <input type="text" placeholder="订单编号" name="orderNo" autocomplete="off" class="layui-input"> + </div> + </div> + <div class="layui-inline"> + <label class="layui-form-label layui-form-label-sm">用户昵称</label> + <div class="layui-input-inline"> + <input type="text" placeholder="用户昵称" name="name" autocomplete="off" class="layui-input"> + </div> + </div> + <div class="layui-inline"> + <label class="layui-form-label layui-form-label-sm">手机号码</label> + <div class="layui-input-inline"> + <input type="text" placeholder="手机号码" name="phone" autocomplete="off" class="layui-input"> + </div> + </div> + <div class="layui-inline"> + <label class="layui-form-label layui-form-label-sm">状态</label> + <div class="layui-input-inline"> + <select name="state"> + <option value="">请选择</option> + <option value="1">待使用</option> + <option value="2">已使用</option> + <option value="3">已过期</option> + </select> + </div> + </div> + </div> + </div> + <div class="layui-col-md2 layui-col-sm12 layui-col-xs12 table-action-area"> + <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain table-action" id="query"> + <i class="layui-icon"></i> + </div> + <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="reset"> + <i class="layui-icon"></i> + </div> + </div> + </div> + </form> + <table lay-filter="rollHouseTable" lay-data="{id: 'rollHouseTable'}"></table> + <style type="text/css"> + ::-webkit-scrollbar { + height: 20px !important; + background-color: #f4f4f4; + } + </style> + </div> + </div> + </div> + </div> +</div> +<!-- 表格操作栏 start --> +<script type="text/html" id="user-option"> + <span shiro:lacksPermission="user:view,user:update,user:delete"> + <span class="layui-badge-dot febs-bg-orange"></span> 无权限 + </span> + <a lay-event="edit" shiro:hasPermission="user:update"><i + class="layui-icon febs-edit-area febs-blue"></i></a> +</script> +<script type="text/html" id="stateNormalFormat"> + {{# + var state = { + 1: {title: '待使用', color: 'green'}, + 2: {title: '已使用', color: 'blue'}, + 3: {title: '已过期', color: 'red'}, + }[d.state]; + }} + <span class="layui-badge febs-bg-{{state.color}}">{{ state.title }}</span> +</script> +<style> + .layui-form-onswitch { + background-color: #5FB878 !important; + } +</style> +<!-- 表格操作栏 end --> +<script data-th-inline="none" type="text/javascript"> + // 引入组件并初始化 + layui.use([ 'jquery', 'form', 'table', 'febs'], function () { + var $ = layui.jquery, + febs = layui.febs, + form = layui.form, + table = layui.table, + $view = $('#febs-roll-house-list'), + $query = $view.find('#query'), + $reset = $view.find('#reset'), + $searchForm = $view.find('form'), + sortObject = {field: 'phone', type: null}, + tableIns; + + form.render(); + + // 表格初始化 + initTable(); + + // 初始化表格操作栏各个按钮功能 + table.on('tool(rollHouseTable)', function (obj) { + var data = obj.data, + layEvent = obj.event; + + if (layEvent === 'seeImgThumb') { + var t = $view.find('#seeImgThumb'+data.id+''); + //页面层 + layer.open({ + type: 1, + title: "图片", + skin: 'layui-layer-rim', //加上边框 + area: ['80%', '80%'], //宽高 + shadeClose: true, //开启遮罩关闭 + end: function (index, layero) { + return false; + }, + content: '<div style="text-align:center"><img src="' + $(t).attr('src') + '" /></div>' + }); + } + + if (layEvent === 'houseCheck') { + houseCheck("民宿核销", data.id); + } + }); + // 查询按钮 + $query.on('click', function () { + var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type}); + tableIns.reload({where: params, page: {curr: 1}}); + }); + + // 刷新按钮 + $reset.on('click', function () { + $searchForm[0].reset(); + sortObject.type = 'null'; + tableIns.reload({where: getQueryParams(), page: {curr: 1}, initSort: sortObject}); + }); + + + function houseCheck(text, id) { + febs.modal.open('text', 'modules/mallMember/rollHouseCheck/'+ id, { + btn: ['确认', '取消'], + yes: function (index, layero) { + $('#houseCheck-update').find('#submit').trigger('click'); + }, + btn2: function () { + layer.closeAll(); + } + }); + } + + // 获取查询参数 + function getQueryParams() { + return { + orderNo: $searchForm.find('input[name="orderNo"]').val().trim(), + name: $searchForm.find('input[name="name"]').val().trim(), + phone: $searchForm.find('input[name="phone"]').val().trim(), + state: $searchForm.find("select[name='state']").val(), + }; + } + + function initTable() { + tableIns = febs.table.init({ + elem: $view.find('table'), + id: 'rollHouseTable', + url: ctx + 'admin/mallMember/rollHouseList', + defaultToolbar:[], + cols: [[ + {field: 'orderNo', title: '订单编号', minWidth: 220,align:'center'}, + {field: 'name', title: '用户昵称', minWidth: 100,align:'center'}, + {field: 'phone', title: '手机号码', minWidth: 150,align:'center'}, + {field: 'housePic', title: '图片', + templet: function (d) { + return '<a lay-event="seeImgThumb"><img id="seeImgThumb'+d.id+'" src="'+d.housePic+'" alt=""></a>'; + }, minWidth: 150,align:'center'}, + {field: 'createTime', title: '下单时间', minWidth: 80,align:'center'}, + {field: 'updateTime', title: '入住时间', minWidth: 80,align:'center'}, + {field: 'unuseTime', title: '过期时间', minWidth: 80,align:'center'}, + {title: '状态', minWidth: 100,templet: '#stateNormalFormat',align:'center'}, + {field: 'houseName', title: '名称', minWidth: 100,align:'center'}, + {field: 'houseAddress', title: '地址', minWidth: 100,align:'center'}, + {title: '操作', + templet: function (d) { + if (d.state === 1) { + return '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="houseCheck" shiro:hasPermission="rollHouseCheck:update">核销</button>'; + }else{ + return '' + } + },minWidth: 200,align:'center'} + ]] + }); + } + + }) +</script> \ No newline at end of file -- Gitblit v1.9.1