From 780ddc0d6df50bbb59b84ef61668da7c2deacc21 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Mon, 11 Sep 2023 10:32:26 +0800
Subject: [PATCH] 优惠卷

---
 src/main/java/cc/mrbird/febs/mall/entity/MallGoods.java                        |    4 
 src/main/resources/templates/febs/views/modules/goods/goodsCouponList.html     |   55 +
 src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponTreeListVo.java       |   13 
 src/main/java/cc/mrbird/febs/mall/vo/AdminCouponSelectVo.java                  |   14 
 src/main/java/cc/mrbird/febs/mall/dto/GetCouponDto.java                        |   17 
 src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java                     |    3 
 src/main/java/cc/mrbird/febs/mall/dto/CouponRuleAddDto.java                    |   30 +
 src/main/java/cc/mrbird/febs/mall/service/IApiMallMemberService.java           |    4 
 src/main/resources/mapper/modules/SalemanCouponMapper.xml                      |   11 
 src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java |   81 +++
 src/main/resources/templates/febs/views/modules/goods/goodsCouponUpdate.html   |  128 +++++
 src/main/resources/mapper/modules/MallMemberCouponMapper.xml                   |   18 
 src/main/resources/templates/febs/views/modules/goods/goodsAddNew.html         |   47 +
 src/main/java/cc/mrbird/febs/mall/service/IAdminMallGoodsService.java          |   16 
 src/main/java/cc/mrbird/febs/mall/entity/MallMemberCoupon.java                 |   22 
 src/main/java/cc/mrbird/febs/mall/controller/ApiMallMemberController.java      |   16 
 src/main/java/cc/mrbird/febs/mall/entity/SalemanCoupon.java                    |   13 
 src/main/java/cc/mrbird/febs/mall/mapper/MallMemberCouponMapper.java           |   14 
 src/main/resources/templates/febs/views/modules/goods/goodsCouponAdd.html      |  116 ++++
 src/main/resources/templates/febs/views/modules/goods/goodsUpdateNew.html      |   52 ++
 src/main/java/cc/mrbird/febs/mall/mapper/MallGoodsCouponMapper.java            |    2 
 src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java         |   10 
 src/main/java/cc/mrbird/febs/mall/dto/MallMemberCouponDto.java                 |   23 
 src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java      |  156 ++++++
 src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponVo.java               |   31 +
 src/main/java/cc/mrbird/febs/mall/mapper/SalemanCouponMapper.java              |   11 
 src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java     |   61 ++
 src/main/java/cc/mrbird/febs/mall/mapper/MallMemberMapper.java                 |    2 
 src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java    |   53 ++
 src/main/java/cc/mrbird/febs/mall/entity/MallGoodsCoupon.java                  |    2 
 src/main/resources/mapper/modules/MallGoodsCouponMapper.xml                    |    6 
 src/main/resources/mapper/modules/MallMemberMapper.xml                         |   25 +
 src/main/java/cc/mrbird/febs/mall/vo/MallMemberCouponVo.java                   |   27 +
 src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java   |   41 +
 src/main/resources/mapper/modules/CouponGoodsMapper.xml                        |   18 
 src/main/resources/templates/febs/views/modules/mallMember/mallMemberList.html |   44 +
 src/main/resources/templates/febs/views/modules/mallMember/couponSelect.html   |   98 +++
 src/main/java/cc/mrbird/febs/mall/entity/MallMember.java                       |   10 
 src/main/java/cc/mrbird/febs/mall/controller/ViewMallMemberController.java     |   28 +
 src/main/resources/templates/febs/views/modules/mallMember/memberSaleman.html  |   80 +-
 src/main/java/cc/mrbird/febs/mall/controller/ViewMallGoodsController.java      |   22 
 src/main/java/cc/mrbird/febs/mall/entity/CouponGoods.java                      |   14 
 src/main/java/cc/mrbird/febs/mall/dto/MallGoodsUpdateDto.java                  |    2 
 src/main/java/cc/mrbird/febs/mall/mapper/CouponGoodsMapper.java                |   14 
 src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponTreeVo.java           |   12 
 45 files changed, 1,400 insertions(+), 66 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java
index 7e827f2..fff94ad 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallGoodsController.java
@@ -11,10 +11,7 @@
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper;
 import cc.mrbird.febs.mall.service.IAdminMallGoodsService;
-import cc.mrbird.febs.mall.vo.AdminHomeDeliverySettingVo;
-import cc.mrbird.febs.mall.vo.AdminMallGoodsCategoryTreeVo;
-import cc.mrbird.febs.mall.vo.AdminMallGoodsTreeVo;
-import cc.mrbird.febs.mall.vo.AdminRangeSettingVo;
+import cc.mrbird.febs.mall.vo.*;
 import cn.hutool.core.util.IdUtil;
 import cn.hutool.core.util.StrUtil;
 import lombok.RequiredArgsConstructor;
@@ -292,5 +289,61 @@
         return new FebsResponse().success().data(data);
     }
 
+    /**
+     * 优惠卷列表-新增
+     */
+    @PostMapping("couponRuleAdd")
+    @ControllerEndpoint(operation = " 优惠卷列表-新增", exceptionMessage = "操作失败")
+    public FebsResponse couponRuleAdd(@RequestBody @Valid CouponRuleAddDto couponRuleAddDto) {
+        return adminMallGoodsService.couponRuleAdd(couponRuleAddDto);
+    }
+
+    /**
+     * 优惠卷列表-删除
+     */
+    @GetMapping("couponRuleDel/{id}")
+    @ControllerEndpoint(operation = "优惠卷列表-删除", exceptionMessage = "操作失败")
+    public FebsResponse couponRuleDel(@NotNull(message = "{required}") @PathVariable Long id) {
+        return adminMallGoodsService.couponRuleDel(id);
+    }
+
+    /**
+     * 优惠卷列表-上架
+     */
+    @GetMapping("upCoupon/{id}")
+    @ControllerEndpoint(operation = " 优惠卷列表-上架", exceptionMessage = "上架失败")
+    public FebsResponse upCoupon(@NotNull(message = "{required}") @PathVariable Long id) {
+        return adminMallGoodsService.upCoupon(id);
+    }
+
+    /**
+     * 优惠卷列表-下架
+     */
+    @GetMapping("downCoupon/{id}")
+    @ControllerEndpoint(operation = " 优惠卷列表-下架", exceptionMessage = "下架失败")
+    public FebsResponse downCoupon(@NotNull(message = "{required}") @PathVariable Long id) {
+        return adminMallGoodsService.downCoupon(id);
+    }
+
+    /**
+     * 优惠卷列表-更新
+     */
+    @PostMapping("couponUpdate")
+    @ControllerEndpoint(operation = "优惠卷列表-更新", exceptionMessage = "操作失败")
+    public FebsResponse couponUpdate(@RequestBody @Valid AdminMallGoodsCouponVo adminMallGoodsCouponVo) {
+        return adminMallGoodsService.couponUpdate(adminMallGoodsCouponVo);
+    }
+
+
+    @GetMapping("coupon/tree")
+    public List<AdminMallGoodsCouponTreeVo> couponTree() {
+        return adminMallGoodsService.findAdminMallGoodsCouponVoTree();
+    }
+
+    @GetMapping(value = "/couponTreeSet")
+    public FebsResponse couponTreeSet() {
+        return new FebsResponse().success().data(adminMallGoodsService.findAdminMallGoodsCouponVoTreeList());
+    }
+
 
 }
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..e10ec84 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java
@@ -72,6 +72,18 @@
     }
 
     /**
+     * 会员列表---注销
+     *
+     * @param id
+     * @return
+     */
+    @GetMapping("memberOut/{id}")
+    @ControllerEndpoint(operation = "会员列表---注销", exceptionMessage = "操作失败")
+    public FebsResponse memberOut(@NotNull(message = "{required}") @PathVariable Long id) {
+        return mallMemberService.memberOut(id);
+    }
+
+    /**
      * 会员列表---开启
      *
      * @param id
@@ -553,4 +565,45 @@
         return mallMemberService.agentVerifyUpdate(adminAgentVerifyVo);
     }
 
+    /**
+     * 会员列表-推销员设置
+     */
+    @GetMapping("upSale/{id}")
+    @ControllerEndpoint(operation = " 会员列表-推销员设置", exceptionMessage = "操作失败")
+    public FebsResponse upSale(@NotNull(message = "{required}") @PathVariable Long id) {
+        return mallMemberService.upCoupon(id);
+    }
+
+    /**
+     * 会员列表-推销员设置
+     */
+    @GetMapping("downSale/{id}")
+    @ControllerEndpoint(operation = " 会员列表-推销员设置", exceptionMessage = "操作失败")
+    public FebsResponse downSale(@NotNull(message = "{required}") @PathVariable Long id) {
+        return mallMemberService.downCoupon(id);
+    }
+
+    /**
+     * 推销员列表
+     *
+     * @param mallMember
+     * @param request
+     * @return
+     */
+    @GetMapping("getsalemanRuleList")
+    public FebsResponse getsalemanRuleList(MallMember mallMember, QueryRequest request) {
+        mallMember.setIsSale(1);
+        Map<String, Object> data = getDataTable(mallMemberService.getsalemanRuleList(mallMember, request));
+        return new FebsResponse().success().data(data);
+    }
+
+    /**
+     * 推销员列表-优惠卷绑定
+     */
+    @PostMapping("salemanCoupon")
+    @ControllerEndpoint(operation = "推销员列表-优惠卷绑定", exceptionMessage = "操作失败")
+    public FebsResponse salemanCoupon(@Valid MallMember mallmember) {
+        return mallMemberService.salemanCoupon(mallmember);
+    }
+
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/ApiMallMemberController.java b/src/main/java/cc/mrbird/febs/mall/controller/ApiMallMemberController.java
index b9b7639..682a494 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/ApiMallMemberController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/ApiMallMemberController.java
@@ -3,6 +3,7 @@
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.mall.dto.*;
 import cc.mrbird.febs.mall.entity.MallMember;
+import cc.mrbird.febs.mall.entity.MallMemberCoupon;
 import cc.mrbird.febs.mall.entity.MallMemberPayment;
 import cc.mrbird.febs.mall.service.*;
 import cc.mrbird.febs.mall.vo.*;
@@ -219,4 +220,19 @@
         return memberService.activityInfo();
     }
 
+    @ApiOperation(value = "通过邀请链接领取优惠卷")
+    @PostMapping(value = "/getCoupon")
+    public FebsResponse getCoupon(@RequestBody GetCouponDto getCouponDto) {
+        return memberService.getCoupon(getCouponDto);
+    }
+
+    @ApiOperation(value = "优惠卷列表")
+    @ApiResponses({
+            @ApiResponse(code = 200, message = "success", response = MallMemberCouponVo.class)
+    })
+    @PostMapping(value = "/memberCoupon")
+    public FebsResponse memberCoupon(@RequestBody MallMemberCouponDto mallMemberCouponDto) {
+        return memberService.memberCoupon(mallMemberCouponDto);
+    }
+
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/ViewMallGoodsController.java b/src/main/java/cc/mrbird/febs/mall/controller/ViewMallGoodsController.java
index 9935ba3..5a34524 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/ViewMallGoodsController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/ViewMallGoodsController.java
@@ -175,6 +175,26 @@
     @GetMapping("goodsCouponList")
     @RequiresPermissions("goodsCouponList:view")
     public String goodsCouponList() {
-        return FebsUtil.view("modules/goods/goodsCoupon");
+        return FebsUtil.view("modules/goods/goodsCouponList");
+    }
+
+    /**
+     * 优惠卷列表-新增
+     */
+    @GetMapping("goodsCouponAdd")
+    @RequiresPermissions("goodsCouponAdd:add")
+    public String goodsCouponAdd() {
+        return FebsUtil.view("modules/goods/goodsCouponAdd");
+    }
+
+    /**
+     * 优惠卷列表-编辑-详情
+     */
+    @GetMapping("goodsCouponUpdate/{id}")
+    @RequiresPermissions("goodsCouponUpdate:update")
+    public String goodsCouponUpdate(@PathVariable long id, Model model) {
+        AdminMallGoodsCouponVo adminMallGoodsCouponVo = mallGoodsService.selectGoodsCouponById(id);
+        model.addAttribute("couponRule", adminMallGoodsCouponVo);
+        return FebsUtil.view("modules/goods/goodsCouponUpdate");
     }
 }
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..09bfe1a 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.MallMemberMapper;
 import cc.mrbird.febs.mall.mapper.MallSalesmanMapper;
 import cc.mrbird.febs.mall.service.IAdminMallMemberService;
 import cc.mrbird.febs.mall.vo.*;
@@ -24,6 +25,7 @@
     private final IAdminMallMemberService mallMemberService;
 
     private final MallSalesmanMapper mallSalesmanMapper;
+    private final MallMemberMapper mallMemberMapper;
     private final MallAgentRecordMapper mallAgentRecordMapper;
 
     public static long idFromMoneyFlow;
@@ -364,5 +366,31 @@
         return FebsUtil.view("modules/mallMember/agentVerify");
     }
 
+    /**
+     * 推销员列表
+     * @return
+     */
+    @GetMapping("memberSaleman")
+    @RequiresPermissions("memberSaleman:view")
+    public String memberSaleman() {
+        return FebsUtil.view("modules/mallMember/memberSaleman");
+    }
+
+    /**
+     * 优惠卷列表-选择
+     * @param id
+     * @param model
+     * @return
+     */
+    @GetMapping("couponSelect/{id}")
+    @RequiresPermissions("couponSelect:update")
+    public String couponSelect(@PathVariable long id, Model model) {
+        MallMember mallMember = mallMemberMapper.selectById(id);
+        AdminCouponSelectVo data = new AdminCouponSelectVo();
+        data.setId(mallMember.getId());
+        model.addAttribute("adminCouponSelectVo", data);
+        return FebsUtil.view("modules/mallMember/couponSelect");
+    }
+
 
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java b/src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java
index a219fdc..fdf6ed7 100644
--- a/src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java
+++ b/src/main/java/cc/mrbird/febs/mall/dto/AddMallGoodsDto.java
@@ -95,4 +95,7 @@
     private String levelTwoPrice;
     private String levelThreePrice;
 
+    //优惠卷IDs
+    private List<Long> couponIds;
+
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/CouponRuleAddDto.java b/src/main/java/cc/mrbird/febs/mall/dto/CouponRuleAddDto.java
new file mode 100644
index 0000000..7a2c95b
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/CouponRuleAddDto.java
@@ -0,0 +1,30 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+import javax.validation.constraints.*;
+import java.math.BigDecimal;
+@Data
+@ApiModel(value = "CouponRuleAddDto", description = "参数类")
+public class CouponRuleAddDto {
+
+    @NotBlank(message = "名称不能为空")
+    private String name;
+    //过期天数
+    @NotNull(message = "过期天数不能为空")
+    @Min(value = 0, message = "整数字段不能小于0")
+    private Integer expireDay;
+    //满1000减100,满0减50;
+    //满足金额
+    @NotNull(message = "满足金额不能为空")
+    @DecimalMin(value = "0", message = "字段不能小于0")
+    @DecimalMax(value = "10000", inclusive = false, message = "字段不能大于10000")
+    private BigDecimal costAmount;
+    //减免金额
+    @NotNull(message = "减免金额不能为空")
+    @DecimalMin(value = "0", inclusive = false, message = "字段不能小于0")
+    @DecimalMax(value = "10000", inclusive = false, message = "字段不能大于10000")
+    private BigDecimal realAmount;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/GetCouponDto.java b/src/main/java/cc/mrbird/febs/mall/dto/GetCouponDto.java
new file mode 100644
index 0000000..98a0291
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/GetCouponDto.java
@@ -0,0 +1,17 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+import javax.validation.constraints.NotBlank;
+
+@Data
+@ApiModel(value = "GetCouponDto", description = "参数类")
+public class GetCouponDto {
+
+    private Long goodsId;
+
+    @NotBlank(message = "inviteId不能为空")
+    private String inviteId;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/MallGoodsUpdateDto.java b/src/main/java/cc/mrbird/febs/mall/dto/MallGoodsUpdateDto.java
index 64085e9..3d8e80a 100644
--- a/src/main/java/cc/mrbird/febs/mall/dto/MallGoodsUpdateDto.java
+++ b/src/main/java/cc/mrbird/febs/mall/dto/MallGoodsUpdateDto.java
@@ -99,4 +99,6 @@
     private BigDecimal levelOnePrice;
     private BigDecimal levelTwoPrice;
     private BigDecimal levelThreePrice;
+
+    private List<Long> couponIds;
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/MallMemberCouponDto.java b/src/main/java/cc/mrbird/febs/mall/dto/MallMemberCouponDto.java
new file mode 100644
index 0000000..db96c75
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/MallMemberCouponDto.java
@@ -0,0 +1,23 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "MallMemberCouponDto", description = "参数类")
+public class MallMemberCouponDto {
+
+    @ApiModelProperty(value = "1:待使用 2:已使用 3:已过期", example = "1")
+    private Integer state;
+
+    @ApiModelProperty(value = "一页多少个", example = "10")
+    private Integer pageSize;
+
+    @ApiModelProperty(value = "页码", example = "1")
+    private Integer pageNum;
+
+    @ApiModelProperty(hidden = true)
+    private Long memberId;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/CouponGoods.java b/src/main/java/cc/mrbird/febs/mall/entity/CouponGoods.java
new file mode 100644
index 0000000..2352657
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/entity/CouponGoods.java
@@ -0,0 +1,14 @@
+package cc.mrbird.febs.mall.entity;
+
+import cc.mrbird.febs.common.entity.BaseEntity;
+import com.baomidou.mybatisplus.annotation.TableName;
+import lombok.Data;
+
+@Data
+@TableName("coupon_goods")
+public class CouponGoods extends BaseEntity {
+
+    private Long goodsId;
+
+    private Long couponId;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallGoods.java b/src/main/java/cc/mrbird/febs/mall/entity/MallGoods.java
index 2e3fa09..fe7f3be 100644
--- a/src/main/java/cc/mrbird/febs/mall/entity/MallGoods.java
+++ b/src/main/java/cc/mrbird/febs/mall/entity/MallGoods.java
@@ -133,4 +133,8 @@
     private BigDecimal levelTwoPrice;
     private BigDecimal levelThreePrice;
 
+
+    @TableField(exist = false)
+    private List<Long> couponIds;
+
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallGoodsCoupon.java b/src/main/java/cc/mrbird/febs/mall/entity/MallGoodsCoupon.java
index c2fcd81..d4a760c 100644
--- a/src/main/java/cc/mrbird/febs/mall/entity/MallGoodsCoupon.java
+++ b/src/main/java/cc/mrbird/febs/mall/entity/MallGoodsCoupon.java
@@ -14,6 +14,8 @@
     private String name;
     //过期天数
     private Integer expireDay;
+    //1:未生效 2:生效中
+    private Integer state;
     //满1000减100,满0减50;
     //满足金额
     private BigDecimal costAmount;
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallMember.java b/src/main/java/cc/mrbird/febs/mall/entity/MallMember.java
index 0f110ab..2f6511b 100644
--- a/src/main/java/cc/mrbird/febs/mall/entity/MallMember.java
+++ b/src/main/java/cc/mrbird/febs/mall/entity/MallMember.java
@@ -155,4 +155,14 @@
     private String salesmansName;
 
     private String inviteImg;
+    //是否是推销员1:是 2:否
+    private Integer isSale;
+
+    //优惠卷名称
+    @TableField(exist = false)
+    private String couponName;
+
+    //优惠卷名称
+    @TableField(exist = false)
+    private Long couponId;
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/MallMemberCoupon.java b/src/main/java/cc/mrbird/febs/mall/entity/MallMemberCoupon.java
new file mode 100644
index 0000000..17916ab
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/entity/MallMemberCoupon.java
@@ -0,0 +1,22 @@
+package cc.mrbird.febs.mall.entity;
+
+import cc.mrbird.febs.common.entity.BaseEntity;
+import com.baomidou.mybatisplus.annotation.TableName;
+import com.fasterxml.jackson.annotation.JsonFormat;
+import lombok.Data;
+
+import java.util.Date;
+
+@Data
+@TableName("mall_member_coupon")
+public class MallMemberCoupon extends BaseEntity {
+
+    private Long memberId;
+    private Long couponId;
+    private String couponName;
+    private String inviteId;
+    //1:待使用 2:已使用 3:已过期
+    private Integer state;
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    private Date expireTime;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/entity/SalemanCoupon.java b/src/main/java/cc/mrbird/febs/mall/entity/SalemanCoupon.java
new file mode 100644
index 0000000..e1cf494
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/entity/SalemanCoupon.java
@@ -0,0 +1,13 @@
+package cc.mrbird.febs.mall.entity;
+
+import cc.mrbird.febs.common.entity.BaseEntity;
+import com.baomidou.mybatisplus.annotation.TableName;
+import lombok.Data;
+
+@Data
+@TableName("saleman_coupon")
+public class SalemanCoupon  extends BaseEntity {
+
+    private Long couponId;
+    private Long memberId;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/CouponGoodsMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/CouponGoodsMapper.java
new file mode 100644
index 0000000..d4469a6
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/CouponGoodsMapper.java
@@ -0,0 +1,14 @@
+package cc.mrbird.febs.mall.mapper;
+
+import cc.mrbird.febs.mall.entity.CouponGoods;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import org.apache.ibatis.annotations.Param;
+
+import java.util.List;
+
+public interface CouponGoodsMapper extends BaseMapper<CouponGoods> {
+
+    List<Long> selectByGoodId(Long id);
+
+    List<CouponGoods> selectByGoodIdAndCouponId(@Param("goodsId")Long goodsId, @Param("couponId")Long couponId);
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallGoodsCouponMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallGoodsCouponMapper.java
index 2130af8..1c939ac 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallGoodsCouponMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallGoodsCouponMapper.java
@@ -1,6 +1,7 @@
 package cc.mrbird.febs.mall.mapper;
 
 import cc.mrbird.febs.mall.entity.MallGoodsCoupon;
+import cc.mrbird.febs.mall.vo.AdminMallGoodsCouponVo;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -10,4 +11,5 @@
 
     IPage<MallGoodsCoupon> selectMallGoodsCouponListInPage(Page<MallGoodsCoupon> page, @Param("record")MallGoodsCoupon mallGoodsCoupon);
 
+    AdminMallGoodsCouponVo selectGoodsCouponById(@Param("id")long id);
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberCouponMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberCouponMapper.java
new file mode 100644
index 0000000..2e73ab9
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberCouponMapper.java
@@ -0,0 +1,14 @@
+package cc.mrbird.febs.mall.mapper;
+
+import cc.mrbird.febs.mall.dto.MallMemberCouponDto;
+import cc.mrbird.febs.mall.entity.MallMemberCoupon;
+import cc.mrbird.febs.mall.vo.MallMemberCouponVo;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import org.apache.ibatis.annotations.Param;
+
+public interface MallMemberCouponMapper extends BaseMapper<MallMemberCoupon> {
+
+    IPage<MallMemberCouponVo> selectListInPage(IPage<MallMemberCouponVo> page,  @Param("record") MallMemberCouponDto mallMemberCouponDto);
+
+}
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 8f83a2d..ea962f9 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberMapper.java
@@ -87,4 +87,6 @@
     List<MallMember> selectMemberWithLevel(String level);
 
     MallMember selectMemberByOpenId(@Param("openId")String openId);
+
+    IPage<MallMember> getsalemanRuleList(Page<MallMember> page, @Param("record")MallMember mallMember);
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/SalemanCouponMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/SalemanCouponMapper.java
new file mode 100644
index 0000000..5909232
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/SalemanCouponMapper.java
@@ -0,0 +1,11 @@
+package cc.mrbird.febs.mall.mapper;
+
+import cc.mrbird.febs.mall.entity.SalemanCoupon;
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import org.apache.ibatis.annotations.Param;
+
+public interface SalemanCouponMapper extends BaseMapper<SalemanCoupon> {
+
+    SalemanCoupon selectByMemberId(@Param("memberId")Long memberId);
+
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/service/IAdminMallGoodsService.java b/src/main/java/cc/mrbird/febs/mall/service/IAdminMallGoodsService.java
index 08b8680..6164200 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/IAdminMallGoodsService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/IAdminMallGoodsService.java
@@ -56,4 +56,20 @@
     List<MallCarriageRule> findAllCarriageRuleTree();
 
     IPage<MallGoodsCoupon> getMallGoodsCouponListInPage(MallGoodsCoupon mallGoodsCoupon, QueryRequest request);
+
+    FebsResponse couponRuleAdd(CouponRuleAddDto couponRuleAddDto);
+
+    FebsResponse couponRuleDel(Long id);
+
+    FebsResponse upCoupon(Long id);
+
+    FebsResponse downCoupon(Long id);
+
+    AdminMallGoodsCouponVo selectGoodsCouponById(long id);
+
+    FebsResponse couponUpdate(AdminMallGoodsCouponVo adminMallGoodsCouponVo);
+
+    List<AdminMallGoodsCouponTreeVo> findAdminMallGoodsCouponVoTree();
+
+    List<AdminMallGoodsCouponTreeListVo> findAdminMallGoodsCouponVoTreeList();
 }
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..106cb62 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,14 @@
     List<AdminAgentLevelOptionTreeVo> agentLevelOption();
 
     FebsResponse agentVerifyUpdate(AdminAgentVerifyVo adminAgentVerifyVo);
+
+    FebsResponse upCoupon(Long id);
+
+    FebsResponse downCoupon(Long id);
+
+    FebsResponse memberOut(Long id);
+
+    IPage<MallMember> getsalemanRuleList(MallMember mallMember, QueryRequest request);
+
+    FebsResponse salemanCoupon(MallMember mallmember);
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/service/IApiMallMemberService.java b/src/main/java/cc/mrbird/febs/mall/service/IApiMallMemberService.java
index 1565337..bb68b55 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/IApiMallMemberService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/IApiMallMemberService.java
@@ -83,4 +83,8 @@
     FebsResponse activityInfo();
 
     FebsResponse agentApplyInfo();
+
+    FebsResponse getCoupon(GetCouponDto getCouponDto);
+
+    FebsResponse memberCoupon(MallMemberCouponDto mallMemberCouponDto);
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java
index c0fffa2..6764092 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java
@@ -43,6 +43,7 @@
     private final MallCarriageRuleMapper mallCarriageRuleMapper;
     private final MallCarriageRuleInfoMapper mallCarriageRuleInfoMapper;
     private final MallGoodsCouponMapper mallGoodsCouponMapper;
+    private final CouponGoodsMapper couponGoodsMapper;
 
     @Override
     public IPage<AdminMallGoodsVo> getCategoryListInPage(MallGoods mallGoods, QueryRequest request) {
@@ -156,6 +157,25 @@
                     mallGoodsImagesMapper.insert(mallGoodsImages);
                     i++;
                 }
+            }
+        }
+
+        Long goodsId = mallGoods.getId();
+        QueryWrapper<CouponGoods> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("goods_id",goodsId);
+        List<CouponGoods> mallGoodsCoupons = couponGoodsMapper.selectList(objectQueryWrapper);
+        if(CollUtil.isNotEmpty(mallGoodsCoupons)){
+            for(CouponGoods couponGoods : mallGoodsCoupons){
+                couponGoodsMapper.deleteById(couponGoods);
+            }
+        }
+        if(CollUtil.isNotEmpty(addMallGoodsDto.getCouponIds())){
+            List<Long> couponIds = addMallGoodsDto.getCouponIds();
+            for(Long couponId : couponIds){
+                CouponGoods couponGoods = new CouponGoods();
+                couponGoods.setGoodsId(goodsId);
+                couponGoods.setCouponId(couponId);
+                couponGoodsMapper.insert(couponGoods);
             }
         }
 
@@ -304,8 +324,10 @@
 
         List<MallGoodsSku> skus = mallGoodsSkuMapper.selectSkuByGoodsId(mallGoods.getId());
         List<String> thumbs = mallGoodsImagesMapper.selectByGoodId(mallGoods.getId());
+        List<Long> couponIds = couponGoodsMapper.selectByGoodId(mallGoods.getId());
         mallGoods.setImages(thumbs);
         mallGoods.setSkus(skus);
+        mallGoods.setCouponIds(couponIds);
         return mallGoods;
     }
 
@@ -423,6 +445,25 @@
                     mallGoodsImagesMapper.insert(mallGoodsImages);
                     i++;
                 }
+            }
+        }
+
+        Long goodsId = mallGoodsUpdateDto.getId();
+        QueryWrapper<CouponGoods> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("goods_id",goodsId);
+        List<CouponGoods> mallGoodsCoupons = couponGoodsMapper.selectList(objectQueryWrapper);
+        if(CollUtil.isNotEmpty(mallGoodsCoupons)){
+            for(CouponGoods couponGoods : mallGoodsCoupons){
+                couponGoodsMapper.deleteById(couponGoods);
+            }
+        }
+        if(CollUtil.isNotEmpty(mallGoodsUpdateDto.getCouponIds())){
+            List<Long> couponIds = mallGoodsUpdateDto.getCouponIds();
+            for(Long couponId : couponIds){
+                CouponGoods couponGoods = new CouponGoods();
+                couponGoods.setGoodsId(goodsId);
+                couponGoods.setCouponId(couponId);
+                couponGoodsMapper.insert(couponGoods);
             }
         }
 
@@ -807,4 +848,119 @@
         IPage<MallGoodsCoupon> mallGoodsCouponIPage = mallGoodsCouponMapper.selectMallGoodsCouponListInPage(page, mallGoodsCoupon);
         return mallGoodsCouponIPage;
     }
+
+    @Override
+    public FebsResponse couponRuleAdd(CouponRuleAddDto couponRuleAddDto) {
+        String name = couponRuleAddDto.getName();
+        QueryWrapper<MallGoodsCoupon> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("name",name);
+        List<MallGoodsCoupon> mallGoodsCoupons = mallGoodsCouponMapper.selectList(objectQueryWrapper);
+        if(CollUtil.isNotEmpty(mallGoodsCoupons)){
+            return new FebsResponse().fail().message("名称不能重复");
+        }
+
+        MallGoodsCoupon mallGoodsCoupon = new MallGoodsCoupon();
+        mallGoodsCoupon.setName(name);
+        mallGoodsCoupon.setExpireDay(couponRuleAddDto.getExpireDay());
+        mallGoodsCoupon.setCostAmount(couponRuleAddDto.getCostAmount());
+        mallGoodsCoupon.setRealAmount(couponRuleAddDto.getRealAmount());
+        mallGoodsCouponMapper.insert(mallGoodsCoupon);
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    public FebsResponse couponRuleDel(Long id) {
+        MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(id);
+        if (ObjectUtil.isEmpty(mallGoodsCoupon)) {
+            return new FebsResponse().fail().message("优惠卷不存在,请刷新当前页面");
+        }
+        Integer state = mallGoodsCoupon.getState();
+        if(2 == state){
+            return new FebsResponse().fail().message("请先下架优惠卷");
+        }
+        mallGoodsCouponMapper.deleteById(id);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public FebsResponse upCoupon(Long id) {
+        MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(id);
+        if (ObjectUtil.isEmpty(mallGoodsCoupon)) {
+            return new FebsResponse().fail().message("优惠卷不存在,请刷新当前页面");
+        }
+        mallGoodsCoupon.setState(2);
+        mallGoodsCouponMapper.updateById(mallGoodsCoupon);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public FebsResponse downCoupon(Long id) {
+        MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(id);
+        if (ObjectUtil.isEmpty(mallGoodsCoupon)) {
+            return new FebsResponse().fail().message("优惠卷不存在,请刷新当前页面");
+        }
+        mallGoodsCoupon.setState(1);
+        mallGoodsCouponMapper.updateById(mallGoodsCoupon);
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    public AdminMallGoodsCouponVo selectGoodsCouponById(long id) {
+        return mallGoodsCouponMapper.selectGoodsCouponById(id);
+    }
+
+    @Override
+    public FebsResponse couponUpdate(AdminMallGoodsCouponVo adminMallGoodsCouponVo) {
+        Long id = adminMallGoodsCouponVo.getId();
+        MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(id);
+        if (ObjectUtil.isEmpty(mallGoodsCoupon)) {
+            return new FebsResponse().fail().message("优惠卷不存在,请刷新当前页面");
+        }
+        Integer state = mallGoodsCoupon.getState();
+        if(2 == state){
+            return new FebsResponse().fail().message("请先下架优惠卷");
+        }
+        mallGoodsCoupon.setName(adminMallGoodsCouponVo.getName());
+        mallGoodsCoupon.setExpireDay(adminMallGoodsCouponVo.getExpireDay());
+        mallGoodsCoupon.setCostAmount(adminMallGoodsCouponVo.getCostAmount());
+        mallGoodsCoupon.setRealAmount(adminMallGoodsCouponVo.getRealAmount());
+        mallGoodsCouponMapper.updateById(mallGoodsCoupon);
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    public List<AdminMallGoodsCouponTreeVo> findAdminMallGoodsCouponVoTree() {
+        QueryWrapper<MallGoodsCoupon> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("state",2);
+        List<MallGoodsCoupon> mallGoodsCoupons = mallGoodsCouponMapper.selectList(objectQueryWrapper);
+
+        List<AdminMallGoodsCouponTreeVo> objects = new ArrayList<>();
+        if(CollUtil.isNotEmpty(mallGoodsCoupons)){
+            for(MallGoodsCoupon mallGoodsCoupon : mallGoodsCoupons){
+                AdminMallGoodsCouponTreeVo adminMallGoodsCouponTreeVo = new AdminMallGoodsCouponTreeVo();
+                adminMallGoodsCouponTreeVo.setCouponId(mallGoodsCoupon.getId());
+                adminMallGoodsCouponTreeVo.setCouponName(mallGoodsCoupon.getName());
+                objects.add(adminMallGoodsCouponTreeVo);
+            }
+        }
+        return objects;
+    }
+
+    @Override
+    public List<AdminMallGoodsCouponTreeListVo> findAdminMallGoodsCouponVoTreeList() {
+        QueryWrapper<MallGoodsCoupon> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("state",2);
+        List<MallGoodsCoupon> mallGoodsCoupons = mallGoodsCouponMapper.selectList(objectQueryWrapper);
+
+        List<AdminMallGoodsCouponTreeListVo> objects = new ArrayList<>();
+        if(CollUtil.isNotEmpty(mallGoodsCoupons)){
+            for(MallGoodsCoupon mallGoodsCoupon : mallGoodsCoupons){
+                AdminMallGoodsCouponTreeListVo adminMallGoodsCouponTreeListVo = new AdminMallGoodsCouponTreeListVo();
+                adminMallGoodsCouponTreeListVo.setId(mallGoodsCoupon.getId());
+                adminMallGoodsCouponTreeListVo.setName(mallGoodsCoupon.getName());
+                objects.add(adminMallGoodsCouponTreeListVo);
+            }
+        }
+        return objects;
+    }
 }
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 d681674..cfee35e 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
@@ -6,8 +6,10 @@
 import cc.mrbird.febs.common.enumerates.FlowTypeEnum;
 import cc.mrbird.febs.common.enumerates.MoneyFlowTypeEnum;
 import cc.mrbird.febs.common.exception.FebsException;
+import cc.mrbird.febs.common.utils.AppContants;
 import cc.mrbird.febs.common.utils.LoginUserUtil;
 import cc.mrbird.febs.common.utils.MallUtils;
+import cc.mrbird.febs.common.utils.RedisUtils;
 import cc.mrbird.febs.mall.dto.*;
 import cc.mrbird.febs.mall.entity.*;
 import cc.mrbird.febs.mall.entity.MallNewsInfo;
@@ -47,6 +49,8 @@
 @Transactional
 public class AdminMallMemberServiceImpl extends ServiceImpl<MallMemberMapper, MallMember> implements IAdminMallMemberService {
 
+    private final RedisUtils redisUtils;
+
     private final MallMemberMapper mallMemberMapper;
 
     private final MallMemberWalletMapper mallMemberWalletMapper;
@@ -70,6 +74,7 @@
 
     private final MallAgentRecordMapper mallAgentRecordMapper;
     private final MallSalesmanMapper mallSalesmanMapper;
+    private final SalemanCouponMapper salemanCouponMapper;
 
     @Override
     public IPage<MallMember> getMallMemberList(MallMember mallMember, QueryRequest request) {
@@ -311,6 +316,82 @@
     }
 
     @Override
+    public FebsResponse upCoupon(Long id) {
+        MallMember mallMember = this.baseMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMember)){
+            throw new FebsException("请刷新页面");
+        }
+        mallMember.setIsSale(1);
+        this.baseMapper.updateById(mallMember);
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    public FebsResponse downCoupon(Long id) {
+        MallMember mallMember = this.baseMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMember)){
+            throw new FebsException("请刷新页面");
+        }
+        mallMember.setIsSale(2);
+        this.baseMapper.updateById(mallMember);
+
+        QueryWrapper<SalemanCoupon> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("member_id",mallMember.getId());
+        List<SalemanCoupon> salemanCouponList = salemanCouponMapper.selectList(objectQueryWrapper);
+        if(CollUtil.isNotEmpty(salemanCouponList)){
+            for(SalemanCoupon salemanCoupon : salemanCouponList){
+                salemanCouponMapper.deleteById(salemanCoupon);
+            }
+        }
+
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    public FebsResponse memberOut(Long id) {
+
+        MallMember mallMember = this.baseMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMember)){
+            throw new FebsException("请刷新页面");
+        }
+        redisUtils.del(AppContants.XCX_LOGIN_PREFIX + id);
+        redisUtils.del(AppContants.XCX_LOGIN_PHONE_PREFIX + id);
+        this.baseMapper.deleteById(mallMember);
+        return new FebsResponse().success().message("操作成功");
+    }
+
+    @Override
+    public IPage<MallMember> getsalemanRuleList(MallMember mallMember, QueryRequest request) {
+        Page<MallMember> page = new Page<>(request.getPageNum(), request.getPageSize());
+        IPage<MallMember> mallMembers = this.baseMapper.getsalemanRuleList(page, mallMember);
+        return mallMembers;
+    }
+
+    @Override
+    public FebsResponse salemanCoupon(MallMember mallmember) {
+        MallMember member = this.baseMapper.selectById(mallmember.getId());
+        if(ObjectUtil.isEmpty(member)){
+            throw new FebsException("请刷新页面");
+        }
+        Long couponId = mallmember.getCouponId();
+
+        QueryWrapper<SalemanCoupon> objectQueryWrapper = new QueryWrapper<>();
+        objectQueryWrapper.eq("member_id",member.getId());
+        List<SalemanCoupon> salemanCouponList = salemanCouponMapper.selectList(objectQueryWrapper);
+        if(CollUtil.isNotEmpty(salemanCouponList)){
+            SalemanCoupon salemanCoupon = salemanCouponList.get(0);
+            salemanCoupon.setCouponId(couponId);
+            salemanCouponMapper.updateById(salemanCoupon);
+            return new FebsResponse().success().message("操作成功");
+        }
+        SalemanCoupon salemanCoupon = new SalemanCoupon();
+        salemanCoupon.setMemberId(member.getId());
+        salemanCoupon.setCouponId(couponId);
+        salemanCouponMapper.insert(salemanCoupon);
+        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/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/ApiMallMemberServiceImpl.java
index b369f4a..0722003 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
@@ -19,6 +19,7 @@
 import cc.mrbird.febs.pay.service.IXcxPayService;
 import cn.hutool.core.bean.BeanUtil;
 import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.IdUtil;
 import cn.hutool.core.util.ObjectUtil;
 import cn.hutool.core.util.StrUtil;
@@ -69,6 +70,10 @@
     private final IMallMoneyFlowService mallMoneyFlowService;
     private final IMallMemberCollectionService mallMemberCollectionService;
     private final IMallMemberFootprintService mallMemberFootprintService;
+    private final SalemanCouponMapper salemanCouponMapper;
+    private final CouponGoodsMapper couponGoodsMapper;
+    private final MallGoodsCouponMapper mallGoodsCouponMapper;
+    private final MallMemberCouponMapper mallMemberCouponMapper;
 
 
     @Value("${spring.profiles.active}")
@@ -869,6 +874,42 @@
         return new FebsResponse().success().data(apiMallAgentRecordVo);
     }
 
+    @Override
+    public FebsResponse getCoupon(GetCouponDto getCouponDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        //通过邀请人信息,获取能领取的优惠卷信息
+        MallMember mallMember = this.baseMapper.selectInfoByInviteId(getCouponDto.getInviteId());
+        SalemanCoupon salemanCoupon = salemanCouponMapper.selectByMemberId(mallMember.getId());
+        if(ObjectUtil.isNotEmpty(salemanCoupon)){
+            Long couponId = salemanCoupon.getCouponId();
+            Long goodsId = getCouponDto.getGoodsId();
+            //商品优惠卷如果绑定了,那么当前登陆者获取一张卷
+            List<CouponGoods> couponGoodsList = couponGoodsMapper.selectByGoodIdAndCouponId(goodsId,couponId);
+            MallGoodsCoupon mallGoodsCoupon = mallGoodsCouponMapper.selectById(couponId);
+            if(CollUtil.isNotEmpty(couponGoodsList)){
+                MallMemberCoupon mallMemberCoupon = new MallMemberCoupon();
+                mallMemberCoupon.setCouponId(couponId);
+                mallMemberCoupon.setCouponName(mallGoodsCoupon.getName());
+                mallMemberCoupon.setMemberId(memberId);
+                mallMemberCoupon.setInviteId(mallMemberCoupon.getInviteId());
+                mallMemberCoupon.setState(1);
+                mallMemberCoupon.setExpireTime(DateUtil.offsetDay(DateUtil.date(),mallGoodsCoupon.getExpireDay()));
+                mallMemberCouponMapper.insert(mallMemberCoupon);
+            }
+        }
+
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public FebsResponse memberCoupon(MallMemberCouponDto mallMemberCouponDto) {
+        Long memberId = LoginUserUtil.getLoginUser().getId();
+        IPage<MallMemberCouponVo> page = new Page<>(mallMemberCouponDto.getPageNum(), mallMemberCouponDto.getPageSize());
+        mallMemberCouponDto.setMemberId(memberId);
+        IPage<MallMemberCouponVo> pages = mallMemberCouponMapper.selectListInPage(page, mallMemberCouponDto);
+        return new FebsResponse().success().data(pages);
+    }
+
     private  String getXcxLoginUrl(String code) {
         String wechatLoginUrl =xcxProperties.getWecharLoginUrl();
         return String.format(wechatLoginUrl, xcxProperties.getXcxAppid(), xcxProperties.getXcxSecret(), code);
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminCouponSelectVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminCouponSelectVo.java
new file mode 100644
index 0000000..4e84aba
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminCouponSelectVo.java
@@ -0,0 +1,14 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "AdminCouponSelectVo", description = "信息返回类")
+public class AdminCouponSelectVo {
+    private Long id;
+
+    private Long couponId;
+
+    private String couponName;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponTreeListVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponTreeListVo.java
new file mode 100644
index 0000000..0ee53bc
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponTreeListVo.java
@@ -0,0 +1,13 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "AdminMallGoodsCouponTreeListVo", description = "信息返回类")
+public class AdminMallGoodsCouponTreeListVo {
+
+    private Long id;
+
+    private String name;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponTreeVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponTreeVo.java
new file mode 100644
index 0000000..46c1dfd
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponTreeVo.java
@@ -0,0 +1,12 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "AdminMallGoodsCouponTreeVo", description = "信息返回类")
+public class AdminMallGoodsCouponTreeVo {
+    private Long couponId;
+
+    private String couponName;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponVo.java
new file mode 100644
index 0000000..09628ee
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallGoodsCouponVo.java
@@ -0,0 +1,31 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+import javax.validation.constraints.*;
+import java.math.BigDecimal;
+
+@Data
+@ApiModel(value = "AdminMallGoodsCouponVo", description = "信息返回类")
+public class AdminMallGoodsCouponVo {
+    private Long id;
+
+    @NotBlank(message = "名称不能为空")
+    private String name;
+    //过期天数
+    @NotNull(message = "过期天数不能为空")
+    @Min(value = 0, message = "整数字段不能小于0")
+    private Integer expireDay;
+    //满1000减100,满0减50;
+    //满足金额
+    @NotNull(message = "满足金额不能为空")
+    @DecimalMin(value = "0", message = "字段不能小于0")
+    @DecimalMax(value = "10000", inclusive = false, message = "字段不能大于10000")
+    private BigDecimal costAmount;
+    //减免金额
+    @NotNull(message = "减免金额不能为空")
+    @DecimalMin(value = "0", inclusive = false, message = "字段不能小于0")
+    @DecimalMax(value = "10000", inclusive = false, message = "字段不能大于10000")
+    private BigDecimal realAmount;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/MallMemberCouponVo.java b/src/main/java/cc/mrbird/febs/mall/vo/MallMemberCouponVo.java
new file mode 100644
index 0000000..a4e9af8
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/MallMemberCouponVo.java
@@ -0,0 +1,27 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "MallMemberCouponVo", description = "商城商品列表")
+public class MallMemberCouponVo {
+
+    private Long id;
+
+    @ApiModelProperty(value = "优惠卷名称")
+    private String couponName;
+
+    @ApiModelProperty(value = "优惠卷ID")
+    private Long couponId;
+
+    @ApiModelProperty(value = "邀请人邀请码")
+    private String inviteId;
+
+    @ApiModelProperty(value = "过期时间")
+    private String expireTime;
+
+    @ApiModelProperty(value = "1:待使用 2:已使用 3:已过期")
+    private Integer state;
+}
diff --git a/src/main/resources/mapper/modules/CouponGoodsMapper.xml b/src/main/resources/mapper/modules/CouponGoodsMapper.xml
new file mode 100644
index 0000000..b8eb6a1
--- /dev/null
+++ b/src/main/resources/mapper/modules/CouponGoodsMapper.xml
@@ -0,0 +1,18 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="cc.mrbird.febs.mall.mapper.CouponGoodsMapper">
+
+    <select id="selectByGoodId" resultType="java.lang.Long">
+        select a.coupon_id
+        from coupon_goods a
+        where goods_id = #{id}
+    </select>
+
+    <select id="selectByGoodIdAndCouponId" resultType="cc.mrbird.febs.mall.entity.CouponGoods">
+        select a.*
+        from coupon_goods a
+        where goods_id = #{goodsId}
+        and coupon_id = #{couponId}
+    </select>
+
+</mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/modules/MallGoodsCouponMapper.xml b/src/main/resources/mapper/modules/MallGoodsCouponMapper.xml
index 4713566..942827e 100644
--- a/src/main/resources/mapper/modules/MallGoodsCouponMapper.xml
+++ b/src/main/resources/mapper/modules/MallGoodsCouponMapper.xml
@@ -7,4 +7,10 @@
         from mall_goods_coupon a
         order by a.created_time desc
     </select>
+
+    <select id="selectGoodsCouponById" resultType="cc.mrbird.febs.mall.vo.AdminMallGoodsCouponVo">
+        select *
+        from mall_goods_coupon
+        where id = #{id}
+    </select>
 </mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/modules/MallMemberCouponMapper.xml b/src/main/resources/mapper/modules/MallMemberCouponMapper.xml
new file mode 100644
index 0000000..fcc415c
--- /dev/null
+++ b/src/main/resources/mapper/modules/MallMemberCouponMapper.xml
@@ -0,0 +1,18 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="cc.mrbird.febs.mall.mapper.MallMemberCouponMapper">
+
+    <select id="selectListInPage" resultType="cc.mrbird.febs.mall.vo.MallMemberCouponVo">
+        select
+        a.*
+        from mall_member_coupon a
+        <where>
+            a.member_id=#{record.memberId}
+            <if test="record.state != null and record.state != ''">
+                and a.state=#{record.state}
+            </if>
+        </where>
+        order by a.CREATED_TIME desc
+    </select>
+
+</mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/modules/MallMemberMapper.xml b/src/main/resources/mapper/modules/MallMemberMapper.xml
index 79f460a..e653c6b 100644
--- a/src/main/resources/mapper/modules/MallMemberMapper.xml
+++ b/src/main/resources/mapper/modules/MallMemberMapper.xml
@@ -31,6 +31,9 @@
                 <if test="record.level!=null and record.level!=''">
                     and m.level=#{record.level}
                 </if>
+                <if test="record.isSale!=null and record.isSale!=''">
+                    and m.is_sale=#{record.isSale}
+                </if>
             </if>
         </where>
         GROUP BY m.id order by m.CREATED_TIME desc
@@ -406,4 +409,26 @@
         where a.open_id = #{openId} limit 1
     </select>
 
+    <select id="getsalemanRuleList" resultType="cc.mrbird.febs.mall.entity.MallMember">
+        SELECT m.*,
+               b.name couponName
+        FROM mall_member m
+        LEFT Join saleman_coupon a on m.id = a.member_id
+        LEFT Join mall_goods_coupon b on b.id = a.coupon_id and b.state = 2
+        <where>
+            <if test="record != null" >
+                <if test="record.name!=null and record.name!=''">
+                    and m.name like concat('%',  #{record.name},'%')
+                </if>
+                <if test="record.account!=null and record.account!=''">
+                    and m.phone like concat('%',  #{record.account},'%')
+                </if>
+                <if test="record.isSale!=null and record.isSale!=''">
+                    and m.is_sale=#{record.isSale}
+                </if>
+            </if>
+        </where>
+        order by m.CREATED_TIME desc
+    </select>
+
 </mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/modules/SalemanCouponMapper.xml b/src/main/resources/mapper/modules/SalemanCouponMapper.xml
new file mode 100644
index 0000000..8755b8f
--- /dev/null
+++ b/src/main/resources/mapper/modules/SalemanCouponMapper.xml
@@ -0,0 +1,11 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
+<mapper namespace="cc.mrbird.febs.mall.mapper.SalemanCouponMapper">
+
+    <select id="selectByMemberId" resultType="cc.mrbird.febs.mall.entity.SalemanCoupon">
+        select a.*
+        from saleman_coupon a
+        where a.member_id = #{memberId}
+    </select>
+
+</mapper>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/goods/goodsAddNew.html b/src/main/resources/templates/febs/views/modules/goods/goodsAddNew.html
index 10c3e1f..2d303d3 100644
--- a/src/main/resources/templates/febs/views/modules/goods/goodsAddNew.html
+++ b/src/main/resources/templates/febs/views/modules/goods/goodsAddNew.html
@@ -257,6 +257,16 @@
                                             </div>
                                         </div>
 
+                                        <blockquote class="layui-elem-quote blue-border">优惠卷设置</blockquote>
+                                        <div class="layui-form-item coupon-rule">
+                                            <div class="layui-col-lg6">
+                                                <label class="layui-form-label febs-form-item-require">优惠卷:</label>
+                                                <div class="layui-input-block">
+                                                    <div id="coupon-rule"></div>
+                                                </div>
+                                            </div>
+                                        </div>
+
                                         <blockquote class="layui-elem-quote blue-border">多规格设置</blockquote>
                                         <div class="layui-col-lg6">
                                             <label class="layui-form-label">开启多规格:</label>
@@ -395,6 +405,8 @@
             iconfont: {
                 parent: 'hidden',
             },
+            tips: '请选择',
+            filterable: true,
             radio: true,
             clickClose: true,
             tree: {
@@ -434,6 +446,33 @@
 
         febs.get(ctx + 'admin/goods/carriageRuleTree', null, function(res) {
             carriageRule.update({
+                data : res.data,
+                autoRow: true,
+            });
+        })
+
+        var couponRule = xmSelect.render({
+            el: '#coupon-rule',
+            language: 'zn',
+            prop : {
+                value : 'id',
+                children : 'child'
+            },
+            iconfont: {
+                parent: 'hidden',
+            },
+            // radio: true,
+            clickClose: true,
+            tree: {
+                show: true,
+                //非严格模式
+                strict: false,
+            },
+            data: []
+        })
+
+        febs.get(ctx + 'admin/goods/couponTreeSet', null, function(res) {
+            couponRule.update({
                 data : res.data,
                 autoRow: true,
             });
@@ -697,6 +736,14 @@
 
         form.on('submit(goods-add-form-submit)', function (data) {
             data.field.goodsType = 1;
+            let couponRuleList = couponRule.getValue();
+            if (couponRuleList.length > 0) {
+                var couponIds = [];
+                layui.each(couponRuleList, function (key, item) {
+                    couponIds.push(item.id)
+                });
+                data.field.couponIds=couponIds;
+            }
             data.field.addMallGoodsSkuDtos = tableSkuData;
             data.field.categoryId = category.getValue('valueStr');
             data.field.carriageRuleId = carriageRule.getValue('valueStr');
diff --git a/src/main/resources/templates/febs/views/modules/goods/goodsCouponAdd.html b/src/main/resources/templates/febs/views/modules/goods/goodsCouponAdd.html
new file mode 100644
index 0000000..fa6895b
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/goods/goodsCouponAdd.html
@@ -0,0 +1,116 @@
+<div class="layui-fluid layui-anim febs-anim" id="febs-coupon-rule-add" lay-title="优惠卷新增">
+    <div class="layui-row febs-container">
+        <div class="layui-col-md12">
+            <div class="layui-fluid" id="coupon-rule-add">
+                <form class="layui-form" action="" lay-filter="coupon-rule-add-form">
+                    <div class="layui-tab layui-tab-brief" lay-filter="docDemoTabBrief">
+                        <ul class="layui-tab-title">
+                            <li class="layui-this">优惠卷</li>
+                        </ul>
+                        <div class="layui-tab-content">
+                            <div class="layui-tab-item layui-show">
+                                <blockquote class="layui-elem-quote blue-border">基本信息</blockquote>
+                                <div class="layui-row layui-col-space10 layui-form-item">
+                                    <div class="layui-col-lg6">
+                                        <label class="layui-form-label febs-form-item-require">名称:</label>
+                                        <div class="layui-input-block">
+                                            <input type="text" name="name" lay-verify="required" placeholder="" autocomplete="off" class="layui-input">
+                                        </div>
+                                    </div>
+                                </div>
+                                <div class="layui-row layui-col-space10 layui-form-item">
+                                    <div class="layui-col-lg6">
+                                        <label class="layui-form-label febs-form-item-require">过期天数:</label>
+                                        <div class="layui-input-block">
+<!--                                            <input type="text" name="expireDay" lay-verify="required" placeholder="" autocomplete="off" class="layui-input">-->
+
+                                            <div class="layui-input-inline" style="width: 80px">
+                                                <input type="text" name="expireDay" lay-verify="required" autocomplete="off" class="layui-input" >
+                                            </div>
+                                            <div class="layui-form-mid">后,过期。</div>
+                                            <div class="layui-form-mid layui-word-aux">领取优惠卷开始计算过期时间。设置为0,则永不过期。</div>
+                                        </div>
+                                    </div>
+                                </div>
+
+                                <blockquote class="layui-elem-quote blue-border">规则</blockquote>
+                                <div class="layui-form-item">
+                                    <label class="layui-form-label febs-form-item-require">满足:</label>
+                                    <div class="layui-input-inline" style="width: 80px">
+                                        <input type="text" name="costAmount" lay-verify="required" autocomplete="off" class="layui-input" >
+                                    </div>
+                                    <div class="layui-form-mid">(元)金额,</div>
+                                    <div class="layui-form-mid">减免</div>
+                                    <div class="layui-input-inline" style="width: 80px">
+                                        <input type="text" name="realAmount" lay-verify="required" autocomplete="off" class="layui-input" >
+                                    </div>
+                                    <div class="layui-form-mid">(元)金额。</div>
+                                    <div class="layui-form-mid layui-word-aux">满足0元减免100元,则代表100元无门槛优惠卷。</div>
+                                </div>
+                            </div>
+                        </div>
+                    </div>
+                    <div class="layui-form-item febs-hide">
+                        <button class="layui-btn" lay-submit="" lay-filter="coupon-rule-add-form-submit" id="submit">保存</button>
+                    </div>
+                </form>
+            </div>
+        </div>
+    </div>
+</div>
+<style>
+    .blue-border {
+        border-left-color: #2db7f5;
+        font-size: 18px;
+    }
+</style>
+<script type="text/html" id="toolbar">
+    <div class="layui-btn-container">
+        <button class="layui-btn layui-btn-danger layui-btn-sm" type="button" lay-event="delSku">删除</button>
+    </div>
+</script>
+<!-- 表格操作栏 end -->
+<script data-th-inline="javascript">
+    layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree','dropdown', 'laydate', 'layedit', 'upload', 'element', 'table', 'xmSelect'], function () {
+        var $ = layui.jquery,
+            febs = layui.febs,
+            layer = layui.layer,
+            table = layui.table,
+            formSelects = layui.formSelects,
+            treeSelect = layui.treeSelect,
+            form = layui.form,
+            laydate = layui.laydate,
+            eleTree = layui.eleTree,
+            $view = $('#coupon-rule-add'),
+            layedit = layui.layedit,
+            upload = layui.upload,
+            validate = layui.validate,
+            element = layui.element;
+
+        form.render();
+
+        form.on('submit(coupon-rule-add-form-submit)', function (data) {
+            $.ajax({
+                'url':ctx + 'admin/goods/couponRuleAdd',
+                'type':'post',
+                'dataType':'json',
+                'headers' : {'Content-Type' : 'application/json;charset=utf-8'}, //接口json格式
+                'traditional': true,//ajax传递数组必须添加属性
+                'data':JSON.stringify(data.field),
+                'success':function (data) {
+                    if(data.code==200){
+                        layer.closeAll();
+                        febs.alert.success(data.message);
+                        $('#febs-coupon-rule').find('#reset').click();
+                    }else{
+                        febs.alert.warn(data.message);
+                    }
+                },
+                'error':function () {
+                    febs.alert.warn('服务器繁忙');
+                }
+            })
+            return false;
+        });
+    });
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/goods/goodsCoupon.html b/src/main/resources/templates/febs/views/modules/goods/goodsCouponList.html
similarity index 74%
rename from src/main/resources/templates/febs/views/modules/goods/goodsCoupon.html
rename to src/main/resources/templates/febs/views/modules/goods/goodsCouponList.html
index 2aea078..b94cf36 100644
--- a/src/main/resources/templates/febs/views/modules/goods/goodsCoupon.html
+++ b/src/main/resources/templates/febs/views/modules/goods/goodsCouponList.html
@@ -53,6 +53,14 @@
         background-color: #5FB878 !important;
     }
 </style>
+
+<script type="text/html" id="isStateSwitch">
+    {{# if(d.state === 2) { }}
+    <input type="checkbox" value={{d.id}} lay-text="上架|下架" checked lay-skin="switch" lay-filter="isStateSwitch">
+    {{# } else { }}
+    <input type="checkbox" value={{d.id}} lay-text="上架|下架" lay-skin="switch" lay-filter="isStateSwitch">
+    {{# } }}
+</script>
 <!-- 表格操作栏 end -->
 <script data-th-inline="none" type="text/javascript">
     // 引入组件并初始化
@@ -78,13 +86,13 @@
         table.on('tool(couponRuleTable)', function (obj) {
             var data = obj.data,
                 layEvent = obj.event;
-            if (layEvent === 'carriageRuleDel') {
-                febs.modal.confirm('删除', '确认删除['+data.name+']运费模板?', function () {
-                    carriageRuleDel(data.id);
+            if (layEvent === 'couponRuleDel') {
+                febs.modal.confirm('删除', '确认删除['+data.name+']优惠卷?', function () {
+                    couponRuleDel(data.id);
                 });
             }
-            if (layEvent === 'carriageRuleUpdate') {
-                febs.modal.open('运费模板编辑', 'modules/goods/carriageRuleUpdate/' + data.id, {
+            if (layEvent === 'couponRuleUpdate') {
+                febs.modal.open('优惠卷编辑', 'modules/goods/goodsCouponUpdate/' + data.id, {
                     btn: ['提交', '取消'],
                     area:['100%','100%'],
                     yes: function (index, layero) {
@@ -96,8 +104,29 @@
                 });
             }
         });
-        function carriageRuleDel(id) {
-            febs.get(ctx + 'admin/goods/carriageRuleDel/' + id, null, function () {
+        function couponRuleDel(id) {
+            febs.get(ctx + 'admin/goods/couponRuleDel/' + id, null, function () {
+                febs.alert.success('操作成功');
+                $query.click();
+            });
+        }
+
+        form.on('switch(isStateSwitch)', function (data) {
+            if (data.elem.checked) {
+                upCoupon(data.value);
+            } else {
+                downCoupon(data.value);
+            }
+        })
+
+        function upCoupon(id) {
+            febs.get(ctx + 'admin/goods/upCoupon/' + id, null, function () {
+                febs.alert.success('操作成功');
+                $query.click();
+            });
+        }
+        function downCoupon(id) {
+            febs.get(ctx + 'admin/goods/downCoupon/' + id, null, function () {
                 febs.alert.success('操作成功');
                 $query.click();
             });
@@ -117,7 +146,7 @@
         });
 
         $add.on('click', function () {
-            febs.modal.open('运费模板新增', 'modules/goods/carriageRuleAdd/', {
+            febs.modal.open('优惠卷新增', 'modules/goods/goodsCouponAdd/', {
                 btn: ['提交', '取消'],
                 area:['100%','100%'],
                 yes: function (index, layero) {
@@ -136,16 +165,22 @@
                 url: ctx + 'admin/goods/couponRuleList',
                 cols: [[
                     {field: 'name', title: '名称', minWidth: 200,align:'left'},
+                    {field: 'isState', title: '是否生效', templet: '#isStateSwitch', minWidth: 100,align:'center'},
                     {field: 'costAmount', title: '满足金额', minWidth: 200,align:'left'},
                     {field: 'realAmount', title: '减免金额', minWidth: 200,align:'left'},
                     {field: 'expireDay', title: '过期天数', minWidth: 200,align:'left'},
                     {field: 'createdTime', title: '创建时间', minWidth: 140,align:'left'},
                     {title: '操作',
                         templet: function (d) {
+                            if (d.state === 1) {
                                 return ''
-                                + '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="carriageRuleUpdate" shiro:hasPermission="user:update">编辑</button>'
-                                    + '<button class="layui-btn layui-btn-normal layui-btn-xs febs-bg-red" lay-event="carriageRuleDel" shiro:hasPermission="user:update">删除</button>'
+                                    + '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="couponRuleUpdate" shiro:hasPermission="user:update">编辑</button>'
+                                    + '<button class="layui-btn layui-btn-normal layui-btn-xs febs-bg-red" lay-event="couponRuleDel" shiro:hasPermission="user:update">删除</button>'
 
+                            }else{
+                                return '';
+
+                            }
                         },minWidth: 160,align:'center'}
                 ]]
             });
diff --git a/src/main/resources/templates/febs/views/modules/goods/goodsCouponUpdate.html b/src/main/resources/templates/febs/views/modules/goods/goodsCouponUpdate.html
new file mode 100644
index 0000000..3237da3
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/goods/goodsCouponUpdate.html
@@ -0,0 +1,128 @@
+<div class="layui-fluid layui-anim febs-anim" id="febs-coupon-rule-update" lay-title="优惠卷编辑">
+    <div class="layui-row febs-container">
+        <div class="layui-col-md12">
+            <div class="layui-fluid" id="coupon-rule-update">
+                <form class="layui-form" action="" lay-filter="coupon-rule-update-form">
+                    <div class="layui-tab layui-tab-brief" lay-filter="docDemoTabBrief">
+                        <ul class="layui-tab-title">
+                            <li class="layui-this">运费模板</li>
+                        </ul>
+                        <div class="layui-tab-content">
+                            <div class="layui-tab-item layui-show">
+                                <input type="text" name="id" placeholder="" autoComplete="off" class="layui-input febs-hide">
+                                <blockquote class="layui-elem-quote blue-border">基本信息</blockquote>
+                                <div class="layui-row layui-col-space10 layui-form-item">
+                                    <div class="layui-col-lg6">
+                                        <label class="layui-form-label febs-form-item-require">名称:</label>
+                                        <div class="layui-input-block">
+                                            <input type="text" name="name" lay-verify="required" placeholder="" autocomplete="off" class="layui-input">
+                                        </div>
+                                    </div>
+                                </div>
+                                <div class="layui-row layui-col-space10 layui-form-item">
+                                    <div class="layui-col-lg6">
+                                        <label class="layui-form-label febs-form-item-require">过期天数:</label>
+                                        <div class="layui-input-block">
+                                            <div class="layui-input-inline" style="width: 80px">
+                                                <input type="text" name="expireDay" lay-verify="required" autocomplete="off" class="layui-input" >
+                                            </div>
+                                            <div class="layui-form-mid">后,过期。</div>
+                                            <div class="layui-form-mid layui-word-aux">领取优惠卷开始计算过期时间。设置为0,则永不过期。</div>
+                                        </div>
+                                    </div>
+                                </div>
+
+                                <blockquote class="layui-elem-quote blue-border">规则</blockquote>
+                                <div class="layui-form-item">
+                                    <label class="layui-form-label febs-form-item-require">满足:</label>
+                                    <div class="layui-input-inline" style="width: 80px">
+                                        <input type="text" name="costAmount" lay-verify="required" autocomplete="off" class="layui-input" >
+                                    </div>
+                                    <div class="layui-form-mid">(元)金额,</div>
+                                    <div class="layui-form-mid">减免</div>
+                                    <div class="layui-input-inline" style="width: 80px">
+                                        <input type="text" name="realAmount" lay-verify="required" autocomplete="off" class="layui-input" >
+                                    </div>
+                                    <div class="layui-form-mid">(元)金额。</div>
+                                    <div class="layui-form-mid layui-word-aux">满足0元减免100元,则代表100元无门槛优惠卷。</div>
+                                </div>
+                            </div>
+                        </div>
+                    </div>
+                    <div class="layui-form-item febs-hide">
+                        <button class="layui-btn" lay-submit="" lay-filter="coupon-rule-update-form-submit" id="submit">保存</button>
+                    </div>
+                </form>
+            </div>
+        </div>
+    </div>
+</div>
+<style>
+    .blue-border {
+        border-left-color: #2db7f5;
+        font-size: 18px;
+    }
+</style>
+<script type="text/html" id="toolbar">
+    <div class="layui-btn-container">
+        <button class="layui-btn layui-btn-danger layui-btn-sm" type="button" lay-event="delSku">删除</button>
+    </div>
+</script>
+<!-- 表格操作栏 end -->
+<script data-th-inline="javascript">
+    layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree','dropdown', 'laydate', 'layedit', 'upload', 'element', 'table', 'xmSelect'], function () {
+        var $ = layui.jquery,
+            febs = layui.febs,
+            layer = layui.layer,
+            table = layui.table,
+            formSelects = layui.formSelects,
+            treeSelect = layui.treeSelect,
+            form = layui.form,
+            laydate = layui.laydate,
+            eleTree = layui.eleTree,
+            $view = $('#coupon-rule-update'),
+            layedit = layui.layedit,
+            couponRule = [[${couponRule}]],
+            upload = layui.upload,
+            validate = layui.validate,
+            element = layui.element;
+
+        form.render();
+
+        initValue();
+
+        function initValue() {
+            form.val("coupon-rule-update-form", {
+                "id": couponRule.id,
+                "name": couponRule.name,
+                "expireDay": couponRule.expireDay,
+                "costAmount": couponRule.costAmount,
+                "realAmount": couponRule.realAmount
+            });
+        }
+
+        form.on('submit(coupon-rule-update-form-submit)', function (data) {
+            $.ajax({
+                'url':ctx + 'admin/goods/couponUpdate',
+                'type':'post',
+                'dataType':'json',
+                'headers' : {'Content-Type' : 'application/json;charset=utf-8'}, //接口json格式
+                'traditional': true,//ajax传递数组必须添加属性
+                'data':JSON.stringify(data.field),
+                'success':function (data) {
+                    if(data.code==200){
+                        layer.closeAll();
+                        febs.alert.success(data.message);
+                        $('#febs-coupon-rule').find('#reset').click();
+                    }else{
+                        febs.alert.warn(data.message);
+                    }
+                },
+                'error':function () {
+                    febs.alert.warn('服务器繁忙');
+                }
+            })
+            return false;
+        });
+    });
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/goods/goodsUpdateNew.html b/src/main/resources/templates/febs/views/modules/goods/goodsUpdateNew.html
index 8ac71dd..8f253a2 100644
--- a/src/main/resources/templates/febs/views/modules/goods/goodsUpdateNew.html
+++ b/src/main/resources/templates/febs/views/modules/goods/goodsUpdateNew.html
@@ -283,6 +283,16 @@
                                             </div>
                                         </div>
 
+                                        <blockquote class="layui-elem-quote blue-border">优惠卷设置</blockquote>
+                                        <div class="layui-form-item coupon-rule">
+                                            <div class="layui-col-lg6">
+                                                <label class="layui-form-label febs-form-item-require">优惠卷:</label>
+                                                <div class="layui-input-block">
+                                                    <div id="coupon-rule"></div>
+                                                </div>
+                                            </div>
+                                        </div>
+
                                         <blockquote class="layui-elem-quote blue-border">多规格设置</blockquote>
                                         <div class="layui-col-lg6">
                                             <label class="layui-form-label">开启多规格:</label>
@@ -441,6 +451,35 @@
             // initValue();
         })
 
+        var couponRule = xmSelect.render({
+            el: '#coupon-rule',
+            language: 'zn',
+            prop : {
+                value : 'id',
+                children : 'child'
+            },
+            iconfont: {
+                parent: 'hidden',
+            },
+            // radio: true,
+            clickClose: true,
+            tree: {
+                show: true,
+                //非严格模式
+                strict: false,
+            },
+            data: []
+        })
+
+        febs.get(ctx + 'admin/goods/couponTreeSet', null, function(res) {
+            couponRule.update({
+                data : res.data,
+                autoRow: true,
+            });
+
+            initValue();
+        })
+
         var carriageRule = xmSelect.render({
             el: '#carriage-rule',
             language: 'zn',
@@ -466,9 +505,8 @@
                 data : res.data,
                 autoRow: true,
             });
-
-            initValue();
         })
+
 
         var tableSkuData = [];
         var tableIns = table.render({
@@ -770,6 +808,8 @@
             arrCarriageRule.push(goodsInfo.carriageRuleId)
             carriageRule.setValue(arrCarriageRule);
 
+            couponRule.setValue(goodsInfo.couponIds);
+
             if (goodsInfo.isNormal == 2) {
                 $(".tc-set").show();
             }
@@ -822,6 +862,14 @@
         }
 
         form.on('submit(goods-update-form-submit)', function (data) {
+            let couponRuleList = couponRule.getValue();
+            if (couponRuleList.length > 0) {
+                var couponIds = [];
+                layui.each(couponRuleList, function (key, item) {
+                    couponIds.push(item.id)
+                });
+                data.field.couponIds=couponIds;
+            }
             data.field.goodsType=1;
             data.field.mailGoodsSkuDto = tableSkuData;
             data.field.delSkuId=delSku;
diff --git a/src/main/resources/templates/febs/views/modules/mallMember/couponSelect.html b/src/main/resources/templates/febs/views/modules/mallMember/couponSelect.html
new file mode 100644
index 0000000..0b7995f
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/mallMember/couponSelect.html
@@ -0,0 +1,98 @@
+<style>
+    #coupon-select {
+        padding: 20px 25px 25px 0;
+    }
+
+    #coupon-select .layui-treeSelect .ztree li a, .ztree li span {
+        margin: 0 0 2px 3px !important;
+    }
+    #coupon-select #data-permission-tree-block {
+        border: 1px solid #eee;
+        border-radius: 2px;
+        padding: 3px 0;
+    }
+    #coupon-select .layui-treeSelect .ztree li span.button.switch {
+        top: 1px;
+        left: 3px;
+    }
+    #coupon-select img{
+        max-width:100px
+    }
+
+</style>
+<div class="layui-fluid" id="coupon-select">
+    <form class="layui-form" action="" lay-filter="coupon-select-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" data-th-value="${adminCouponSelectVo.id}">
+            </div>
+        </div>
+
+        <div class="layui-form-item">
+            <label class="layui-form-label">优惠卷:</label>
+            <div class="layui-input-inline">
+                <select name="couponId" class="coupon-select-category" id="couponCategarySelect">
+                    <option value="">请选择</option>
+                </select>
+            </div>
+        </div>
+
+        <div class="layui-form-item febs-hide">
+            <button class="layui-btn" lay-submit="" lay-filter="coupon-select-form-submit" id="submit"></button>
+        </div>
+    </form>
+</div>
+
+<script data-th-inline="javascript">
+    layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree', 'laydate','upload'], function () {
+        var $ = layui.$,
+            febs = layui.febs,
+            layer = layui.layer,
+            formSelects = layui.formSelects,
+            treeSelect = layui.treeSelect,
+            form = layui.form,
+            laydate = layui.laydate,
+            eleTree = layui.eleTree,
+            adminCouponSelectVo = [[${adminCouponSelectVo}]],
+            $view = $('#coupon-select'),
+            upload = layui.upload,
+            validate = layui.validate;
+
+        form.render();
+        laydate.render({
+            elem: '#febs-form-group-date'
+        });
+
+        formSelects.render();
+
+        //(下拉框)
+        $.get(ctx + 'admin/goods/coupon/tree', function (data) {
+            for (var k in data)
+            {
+                $(".coupon-select-category").append("<option value='" + data[k].couponId + "'>" + data[k].couponName + "</option>");
+            }
+            layui.use('form', function () {
+                var form = layui.form;
+                $("#couponCategarySelect").val('')
+                form.render();
+            });
+        });
+        initUserValue();
+
+        function initUserValue() {
+            form.val("coupon-select-form", {
+                "id": adminCouponSelectVo.id,
+            });
+        }
+
+        form.on('submit(coupon-select-form-submit)', function (data) {
+            febs.post(ctx + 'admin/mallMember/salemanCoupon', data.field, function () {
+                layer.closeAll();
+                febs.alert.success('操作成功');
+                $('#febs-saleman-rule').find('#reset').click();
+            });
+            return false;
+        });
+    });
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/mallMember/mallMemberList.html b/src/main/resources/templates/febs/views/modules/mallMember/mallMemberList.html
index b305536..1f9324a 100644
--- a/src/main/resources/templates/febs/views/modules/mallMember/mallMemberList.html
+++ b/src/main/resources/templates/febs/views/modules/mallMember/mallMemberList.html
@@ -95,6 +95,14 @@
     <input type="checkbox" value={{d.id}} lay-text="是|否" lay-skin="switch" lay-filter="switchDirector">
     {{# } }}
 </script>
+
+<script type="text/html" id="isSalesmanSwitch">
+    {{# if(d.isSale === 1) { }}
+    <input type="checkbox" value={{d.id}} lay-text="是|否" checked lay-skin="switch" lay-filter="isSalesmanSwitch">
+    {{# } else { }}
+    <input type="checkbox" value={{d.id}} lay-text="是|否" lay-skin="switch" lay-filter="isSalesmanSwitch">
+    {{# } }}
+</script>
 <style>
     .layui-form-onswitch {
         background-color: #5FB878 !important;
@@ -135,6 +143,12 @@
         table.on('tool(userTable)', function (obj) {
             var data = obj.data,
                 layEvent = obj.event;
+
+            if (layEvent === 'memberOut') {
+                febs.modal.confirm('注销', '确认注销该账号?', function () {
+                    memberOut(data.id);
+                });
+            }
 
             if (layEvent === 'close') {
                 febs.modal.confirm('禁用', '确认禁用该账号?', function () {
@@ -202,6 +216,12 @@
             }
 
         });
+        function memberOut(id) {
+            febs.get(ctx + 'admin/mallMember/memberOut/' + id, null, function () {
+                febs.alert.success('操作成功');
+                $query.click();
+            });
+        }
         function closeAccount(id) {
             febs.get(ctx + 'admin/mallMember/closeAccount/' + id, null, function () {
                 febs.alert.success('禁用成功');
@@ -235,6 +255,26 @@
             });
         }
 
+        form.on('switch(isSalesmanSwitch)', function (data) {
+            if (data.elem.checked) {
+                upSale(data.value);
+            } else {
+                downSale(data.value);
+            }
+        })
+
+        function upSale(id) {
+            febs.get(ctx + 'admin/mallMember/upSale/' + id, null, function () {
+                febs.alert.success('操作成功');
+                $query.click();
+            });
+        }
+        function downSale(id) {
+            febs.get(ctx + 'admin/mallMember/downSale/' + id, null, function () {
+                febs.alert.success('操作成功');
+                $query.click();
+            });
+        }
 
         // 查询按钮
         $query.on('click', function () {
@@ -268,7 +308,7 @@
                     {field: 'referrerName', title: '推荐人', minWidth: 100,align:'left'},
                     {field: 'levelName', title: '会员类型', minWidth: 100,align:'left'},
                     // {field: 'referrerName', title: '推荐人', minWidth: 100,align:'left'},
-                    // {field: 'storeMaster', title: '店长', templet:'#switchStoreMaster', minWidth: 100},
+                    {field: 'isSalesman', title: '推销员设置', templet: '#isSalesmanSwitch', minWidth: 100,align:'center'},
                     // {field: 'director', title: '总监', templet:'#switchDirector', minWidth: 100},
                     // {field: 'accountType', title: '账号类型',
                     //     templet: function (d) {
@@ -297,7 +337,7 @@
                     {title: '操作',
                         templet: function (d) {
                             return  ''
-                                // '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="moneyFlow" shiro:hasPermission="user:update">资金流水</button>'
+                                +'<button class="layui-btn layui-btn-normal layui-btn-xs febs-bg-red" lay-event="memberOut" shiro:hasPermission="user:update">注销</button>'
                                 // + '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="addLeader" shiro:hasPermission="user:update">设置为团长</button>'
 
                         },minWidth: 200,align:'center'}
diff --git a/src/main/resources/templates/febs/views/modules/goods/goodsCoupon.html b/src/main/resources/templates/febs/views/modules/mallMember/memberSaleman.html
similarity index 62%
copy from src/main/resources/templates/febs/views/modules/goods/goodsCoupon.html
copy to src/main/resources/templates/febs/views/modules/mallMember/memberSaleman.html
index 2aea078..ece0c51 100644
--- a/src/main/resources/templates/febs/views/modules/goods/goodsCoupon.html
+++ b/src/main/resources/templates/febs/views/modules/mallMember/memberSaleman.html
@@ -1,14 +1,27 @@
-<div class="layui-fluid layui-anim febs-anim" id="febs-coupon-rule" lay-title="优惠卷管理">
+<div class="layui-fluid layui-anim febs-anim" id="febs-saleman-rule" 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="coupon-table-form">
+                    <form class="layui-form layui-table-form" lay-filter="saleman-table-form">
                         <div class="layui-row">
-                            <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-green-plain table-action" id="add">
-                                    新增
+                            <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="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="account" autocomplete="off" class="layui-input">
+                                        </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">&#xe848;</i>
                                 </div>
@@ -18,7 +31,7 @@
                             </div>
                         </div>
                     </form>
-                    <table lay-filter="couponRuleTable" lay-data="{id: 'couponRuleTable'}"></table>
+                    <table lay-filter="salemanRuleTable" lay-data="{id: 'salemanRuleTable'}"></table>
                     <style type="text/css">
                         .layui-table-cell{
                             text-align:center;
@@ -61,7 +74,7 @@
             febs = layui.febs,
             form = layui.form,
             table = layui.table,
-            $view = $('#febs-coupon-rule'),
+            $view = $('#febs-saleman-rule'),
             $query = $view.find('#query'),
             $reset = $view.find('#reset'),
             $searchForm = $view.find('form'),
@@ -75,20 +88,14 @@
         initTable();
 
         // 初始化表格操作栏各个按钮功能
-        table.on('tool(couponRuleTable)', function (obj) {
+        table.on('tool(salemanRuleTable)', function (obj) {
             var data = obj.data,
                 layEvent = obj.event;
-            if (layEvent === 'carriageRuleDel') {
-                febs.modal.confirm('删除', '确认删除['+data.name+']运费模板?', function () {
-                    carriageRuleDel(data.id);
-                });
-            }
-            if (layEvent === 'carriageRuleUpdate') {
-                febs.modal.open('运费模板编辑', 'modules/goods/carriageRuleUpdate/' + data.id, {
+            if (layEvent === 'couponUpdate') {
+                febs.modal.open('绑定优惠卷', 'modules/mallMember/couponSelect/' + data.id, {
                     btn: ['提交', '取消'],
-                    area:['100%','100%'],
                     yes: function (index, layero) {
-                        $('#febs-coupon-rule-update').find('#submit').trigger('click');
+                        $('#coupon-select').find('#submit').trigger('click');
                     },
                     btn2: function () {
                         layer.closeAll();
@@ -96,13 +103,6 @@
                 });
             }
         });
-        function carriageRuleDel(id) {
-            febs.get(ctx + 'admin/goods/carriageRuleDel/' + id, null, function () {
-                febs.alert.success('操作成功');
-                $query.click();
-            });
-        }
-
         // 查询按钮
         $query.on('click', function () {
             var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type});
@@ -116,36 +116,20 @@
             tableIns.reload({where: getQueryParams(), page: {curr: 1}, initSort: sortObject});
         });
 
-        $add.on('click', function () {
-            febs.modal.open('运费模板新增', 'modules/goods/carriageRuleAdd/', {
-                btn: ['提交', '取消'],
-                area:['100%','100%'],
-                yes: function (index, layero) {
-                    $('#febs-coupon-rule-add').find('#submit').trigger('click');
-                },
-                btn2: function () {
-                    layer.closeAll();
-                }
-            });
-        });
-
         function initTable() {
             tableIns = febs.table.init({
                 elem: $view.find('table'),
-                id: 'couponRuleTable',
-                url: ctx + 'admin/goods/couponRuleList',
+                id: 'salemanRuleTable',
+                url: ctx + 'admin/mallMember/getsalemanRuleList',
                 cols: [[
-                    {field: 'name', title: '名称', minWidth: 200,align:'left'},
-                    {field: 'costAmount', title: '满足金额', minWidth: 200,align:'left'},
-                    {field: 'realAmount', title: '减免金额', minWidth: 200,align:'left'},
-                    {field: 'expireDay', title: '过期天数', minWidth: 200,align:'left'},
-                    {field: 'createdTime', title: '创建时间', minWidth: 140,align:'left'},
+                    {field: 'phone', title: '手机号码', minWidth: 150,align:'left'},
+                    {field: 'name', title: '用户昵称', minWidth: 100,align:'left'},
+                    {field: 'inviteId', title: '邀请码', minWidth: 100,align:'left'},
+                    {field: 'couponName', title: '优惠卷名称', minWidth: 100,align:'left'},
                     {title: '操作',
                         templet: function (d) {
                                 return ''
-                                + '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="carriageRuleUpdate" shiro:hasPermission="user:update">编辑</button>'
-                                    + '<button class="layui-btn layui-btn-normal layui-btn-xs febs-bg-red" lay-event="carriageRuleDel" shiro:hasPermission="user:update">删除</button>'
-
+                                    + '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="couponUpdate" shiro:hasPermission="user:update">绑定优惠卷</button>'
                         },minWidth: 160,align:'center'}
                 ]]
             });
@@ -154,6 +138,8 @@
         // 获取查询参数
         function getQueryParams() {
             return {
+                name: $searchForm.find('input[name="name"]').val().trim(),
+                account: $searchForm.find('input[name="account"]').val().trim(),
             };
         }
 

--
Gitblit v1.9.1