From f8d201010acbb9c530a38e64201d6b2a205fe394 Mon Sep 17 00:00:00 2001
From: xiaoyong931011 <15274802129@163.com>
Date: Sat, 25 Sep 2021 17:20:08 +0800
Subject: [PATCH] 20210925

---
 src/main/java/cc/mrbird/febs/mall/controller/ViewMallOrderController.java      |   26 +
 src/main/resources/mapper/modules/MallMemberPaymentMapper.xml                  |    4 
 src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallMemberServiceImpl.java |   58 ++
 src/main/java/cc/mrbird/febs/mall/vo/AdminMallMemberPaymentVo.java             |   40 ++
 src/main/resources/templates/febs/views/modules/mallMember/moneyFlowList.html  |  116 +++++
 src/main/java/cc/mrbird/febs/mall/mapper/DataDictionaryCustomMapper.java       |   10 
 src/main/resources/templates/febs/views/modules/order/payMethodList.html       |  134 ++++++
 src/main/java/cc/mrbird/febs/mall/vo/AdminMallOrderRefundVo.java               |    6 
 src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java     |   21 +
 src/main/java/cc/mrbird/febs/mall/dto/PayMethodEditDto.java                    |   20 +
 src/main/resources/mapper/modules/DataDictionaryCustomMapper.xml               |    9 
 src/main/resources/mapper/modules/MallMoneyFlowMapper.xml                      |   45 ++
 src/main/java/cc/mrbird/febs/mall/vo/AdminMallPayMethodEditVo.java             |   19 
 src/main/java/cc/mrbird/febs/mall/mapper/MallMoneyFlowMapper.java              |    8 
 src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java         |   17 
 src/main/resources/templates/febs/views/modules/order/payMethodEdit.html       |  122 ++++++
 src/main/resources/templates/febs/views/modules/mallMember/paymentInfo.html    |  117 +++++
 src/main/java/cc/mrbird/febs/mall/dto/MoneyChargeListDto.java                  |   15 
 src/main/java/cc/mrbird/febs/mall/vo/AdminPayMethodVo.java                     |   19 
 src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallOrderService.java      |   27 +
 src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java    |   48 ++
 src/main/resources/templates/febs/views/modules/mallMember/chargeFlowList.html |  162 ++++++++
 src/main/resources/templates/febs/views/modules/order/refundList.html          |    1 
 src/main/java/cc/mrbird/febs/mall/vo/AdminMoneyChargeListVo.java               |   34 +
 src/main/java/cc/mrbird/febs/mall/mapper/MallMemberPaymentMapper.java          |    3 
 src/main/java/cc/mrbird/febs/mall/dto/MoneyFlowListDto.java                    |   14 
 src/main/java/cc/mrbird/febs/mall/service/IAdminMallOrderService.java          |    6 
 src/main/java/cc/mrbird/febs/mall/controller/ViewMallMemberController.java     |   35 +
 src/main/java/cc/mrbird/febs/mall/dto/PayMethodDto.java                        |   10 
 src/main/resources/templates/febs/views/modules/goods/detailGoods.html         |    3 
 src/main/resources/templates/febs/views/modules/order/withAddress.html         |    2 
 src/main/java/cc/mrbird/febs/mall/vo/AdminMoneyFlowListVo.java                 |   35 +
 32 files changed, 1,177 insertions(+), 9 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java
index 9ef0804..e688cbb 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallMemberController.java
@@ -4,6 +4,8 @@
 import cc.mrbird.febs.common.controller.BaseController;
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.entity.QueryRequest;
+import cc.mrbird.febs.mall.dto.MoneyChargeListDto;
+import cc.mrbird.febs.mall.dto.MoneyFlowListDto;
 import cc.mrbird.febs.mall.entity.MallMember;
 import cc.mrbird.febs.mall.entity.MallOrderRefund;
 import cc.mrbird.febs.mall.service.IAdminMallMemberService;
@@ -74,6 +76,52 @@
         return new FebsResponse().success().data(dataTable);
     }
 
+    /**
+     * 资金流水-列表
+     * @param moneyFlowListDto
+     * @param request
+     * @return
+     */
+    @GetMapping("getMoneyFlowList")
+    public FebsResponse getMoneyFlowList(MoneyFlowListDto moneyFlowListDto, QueryRequest request) {
+        Map<String, Object> data = getDataTable(mallMemberService.getMoneyFlowListInPage(moneyFlowListDto, request));
+        return new FebsResponse().success().data(data);
+    }
+
+    /**
+     * 会员提现-列表
+     * @param moneyChargeListDto
+     * @param request
+     * @return
+     */
+    @GetMapping("getMoneyChargeList")
+    public FebsResponse getMoneyChargeList(MoneyChargeListDto moneyChargeListDto, QueryRequest request) {
+        Map<String, Object> data = getDataTable(mallMemberService.getMoneyChargeListInPage(moneyChargeListDto, request));
+        return new FebsResponse().success().data(data);
+    }
+
+    /**
+     * 会员提现-同意
+     * @param id
+     * @return
+     */
+    @GetMapping("chargeAgree/{id}")
+    @ControllerEndpoint(operation = "会员提现-同意", exceptionMessage = "操作失败")
+    public FebsResponse chargeAgree(@NotNull(message = "{required}") @PathVariable Long id) {
+        return mallMemberService.chargeAgree(id);
+    }
+
+    /**
+     * 会员提现-拒绝
+     * @param id
+     * @return
+     */
+    @GetMapping("chargeDisagree/{id}")
+    @ControllerEndpoint(operation = "会员提现-拒绝", exceptionMessage = "操作失败")
+    public FebsResponse chargeDisagree(@NotNull(message = "{required}") @PathVariable Long id) {
+        return mallMemberService.chargeDisagree(id);
+    }
+
 
 
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java
index 6ffc601..532aade 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/AdminMallOrderController.java
@@ -171,6 +171,27 @@
         return adminMallOrderService.withAddressUpdate(withAddressUpdateDto);
     }
 
+    /**
+     * 商家支付方式-列表
+     * @param payMethodDto
+     * @param request
+     * @return
+     */
+    @GetMapping("payMethodList")
+    public FebsResponse getPayMethodList(PayMethodDto payMethodDto, QueryRequest request) {
+        Map<String, Object> data = getDataTable(adminMallOrderService.getPayMethodListInPage(payMethodDto, request));
+        return new FebsResponse().success().data(data);
+    }
+
+    /**
+     * 商家支付方式-更新
+     */
+    @PostMapping("payMethodEdit")
+    @ControllerEndpoint(operation = "商家支付方式-更新", exceptionMessage = "操作失败")
+    public FebsResponse payMethodEdit(@Valid PayMethodEditDto payMethodEditDto) {
+        return adminMallOrderService.payMethodEdit(payMethodEditDto);
+    }
+
 
 
 
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 9057754..a3a48a7 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.MallMember;
 import cc.mrbird.febs.mall.service.IAdminMallMemberService;
+import cc.mrbird.febs.mall.vo.AdminMallMemberPaymentVo;
 import cc.mrbird.febs.mall.vo.MallMemberVo;
 import lombok.RequiredArgsConstructor;
 import org.apache.shiro.authz.annotation.RequiresPermissions;
@@ -59,6 +60,40 @@
         return FebsUtil.view("modules/mallMember/moneyFlow");
     }
 
+    /**
+     * 资金流水列表
+     * @return
+     */
+    @GetMapping("moneyFlowList")
+    @RequiresPermissions("moneyFlowList:view")
+    public String moneyFlowList() {
+        return FebsUtil.view("modules/mallMember/moneyFlowList");
+    }
+
+    /**
+     * 提现列表
+     * @return
+     */
+    @GetMapping("chargeFlowList")
+    @RequiresPermissions("chargeFlowList:view")
+    public String chargeFlowList() {
+        return FebsUtil.view("modules/mallMember/chargeFlowList");
+    }
+
+    /**
+     * 提现列表-收款方式
+     * @param id
+     * @param model
+     * @return
+     */
+    @GetMapping("paymentInfo/{id}")
+    @RequiresPermissions("paymentInfo:update")
+    public String paymentInfo(@PathVariable long id, Model model) {
+        AdminMallMemberPaymentVo data = mallMemberService.getMallMemberPaymentInfoByFlowId(id);
+        model.addAttribute("paymentInfo", data);
+        return FebsUtil.view("modules/mallMember/paymentInfo");
+    }
+
 
 
 
diff --git a/src/main/java/cc/mrbird/febs/mall/controller/ViewMallOrderController.java b/src/main/java/cc/mrbird/febs/mall/controller/ViewMallOrderController.java
index ab7d5a5..9030282 100644
--- a/src/main/java/cc/mrbird/febs/mall/controller/ViewMallOrderController.java
+++ b/src/main/java/cc/mrbird/febs/mall/controller/ViewMallOrderController.java
@@ -134,4 +134,30 @@
         return FebsUtil.view("modules/order/withAddress");
     }
 
+    /**
+     * 商家支付方式-列表
+     * @return
+     */
+    @GetMapping("payMethodList")
+    @RequiresPermissions("payMethodList:view")
+    public String payMethodList() {
+        return FebsUtil.view("modules/order/payMethodList");
+    }
+
+
+
+    /**
+     * 商家支付方式-详情
+     * @param id
+     * @param model
+     * @return
+     */
+    @GetMapping("payMethodEdit/{id}")
+    @RequiresPermissions("payMethodEdit:update")
+    public String payMethodEdit(@PathVariable long id, Model model) {
+        AdminMallPayMethodEditVo data = adminMallOrderService.getMallPayMethodEditInfoById(id);
+        model.addAttribute("payMethodEdit", data);
+        return FebsUtil.view("modules/order/payMethodEdit");
+    }
+
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/MoneyChargeListDto.java b/src/main/java/cc/mrbird/febs/mall/dto/MoneyChargeListDto.java
new file mode 100644
index 0000000..f8cd89a
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/MoneyChargeListDto.java
@@ -0,0 +1,15 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "MoneyChargeListDto", description = "地址接收参数类")
+public class MoneyChargeListDto {
+
+    private String name;
+
+    private String phone;
+
+    private Integer status;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/MoneyFlowListDto.java b/src/main/java/cc/mrbird/febs/mall/dto/MoneyFlowListDto.java
new file mode 100644
index 0000000..7e5bd6e
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/MoneyFlowListDto.java
@@ -0,0 +1,14 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "MoneyFlowListDto", description = "接收参数类")
+public class MoneyFlowListDto {
+
+    private String name;
+
+    private String phone;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/PayMethodDto.java b/src/main/java/cc/mrbird/febs/mall/dto/PayMethodDto.java
new file mode 100644
index 0000000..2fa8d81
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/PayMethodDto.java
@@ -0,0 +1,10 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "PayMethodDto", description = "接收参数类")
+public class PayMethodDto {
+    private String type;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/dto/PayMethodEditDto.java b/src/main/java/cc/mrbird/febs/mall/dto/PayMethodEditDto.java
new file mode 100644
index 0000000..b083ecb
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/dto/PayMethodEditDto.java
@@ -0,0 +1,20 @@
+package cc.mrbird.febs.mall.dto;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "PayMethodEditDto", description = "接收参数类")
+public class PayMethodEditDto {
+
+    private Long id;
+
+    private String type;
+
+    private String code;
+
+    private String value;
+
+    private String description;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/DataDictionaryCustomMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/DataDictionaryCustomMapper.java
index e793dfb..602eb3a 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/DataDictionaryCustomMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/DataDictionaryCustomMapper.java
@@ -1,11 +1,21 @@
 package cc.mrbird.febs.mall.mapper;
 
+import cc.mrbird.febs.mall.dto.PayMethodDto;
 import cc.mrbird.febs.mall.entity.DataDictionaryCustom;
+import cc.mrbird.febs.mall.vo.AdminMallPayMethodEditVo;
+import cc.mrbird.febs.mall.vo.AdminPayMethodVo;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import org.apache.ibatis.annotations.Param;
 
 import java.util.List;
 
 public interface DataDictionaryCustomMapper extends BaseMapper<DataDictionaryCustom> {
 
     List<DataDictionaryCustom> selectDicByType(String type);
+
+    IPage<AdminPayMethodVo> getPayMethodListInPage(Page<AdminPayMethodVo> page, @Param("record")PayMethodDto payMethodDto);
+
+    AdminMallPayMethodEditVo getMallPayMethodEditInfoById(@Param("id")long id);
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberPaymentMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberPaymentMapper.java
index 9d37b08..99dfd94 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberPaymentMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMemberPaymentMapper.java
@@ -1,10 +1,13 @@
 package cc.mrbird.febs.mall.mapper;
 
 import cc.mrbird.febs.mall.entity.MallMemberPayment;
+import cc.mrbird.febs.mall.vo.AdminMallMemberPaymentVo;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
 import org.apache.ibatis.annotations.Param;
 
 public interface MallMemberPaymentMapper extends BaseMapper<MallMemberPayment> {
 
     MallMemberPayment selectByMemberId(@Param("memberId") Long memberId);
+
+    AdminMallMemberPaymentVo getMallMemberPaymentInfoByMemberId(@Param("memberId")Long memberId);
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/mapper/MallMoneyFlowMapper.java b/src/main/java/cc/mrbird/febs/mall/mapper/MallMoneyFlowMapper.java
index 2a1f6e4..5cb4c6c 100644
--- a/src/main/java/cc/mrbird/febs/mall/mapper/MallMoneyFlowMapper.java
+++ b/src/main/java/cc/mrbird/febs/mall/mapper/MallMoneyFlowMapper.java
@@ -1,9 +1,13 @@
 package cc.mrbird.febs.mall.mapper;
 
+import cc.mrbird.febs.mall.dto.MoneyChargeListDto;
 import cc.mrbird.febs.mall.dto.MoneyFlowDto;
+import cc.mrbird.febs.mall.dto.MoneyFlowListDto;
 import cc.mrbird.febs.mall.entity.MallMember;
 import cc.mrbird.febs.mall.entity.MallMoneyFlow;
 import cc.mrbird.febs.mall.vo.AdminMallMoneyFlowVo;
+import cc.mrbird.febs.mall.vo.AdminMoneyChargeListVo;
+import cc.mrbird.febs.mall.vo.AdminMoneyFlowListVo;
 import cc.mrbird.febs.mall.vo.MoneyFlowVo;
 import com.baomidou.mybatisplus.core.mapper.BaseMapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
@@ -15,4 +19,8 @@
     IPage<AdminMallMoneyFlowVo> selectMoneyFlowInPage(Page<AdminMallMoneyFlowVo> page, @Param("record")MallMember mallMember);
 
     IPage<MoneyFlowVo> selectApiMoneyFlowInPage(IPage<MoneyFlowVo> page, @Param("record") MoneyFlowDto moneyFlowDto);
+
+    IPage<AdminMoneyFlowListVo> getMoneyFlowListInPage(Page<AdminMoneyFlowListVo> page,  @Param("record")MoneyFlowListDto moneyFlowListDto);
+
+    IPage<AdminMoneyChargeListVo> getMoneyChargeListInPage(Page<AdminMoneyChargeListVo> page, @Param("record")MoneyChargeListDto moneyChargeListDto);
 }
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 174be53..9be5be2 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/IAdminMallMemberService.java
@@ -2,11 +2,10 @@
 
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.entity.QueryRequest;
-import cc.mrbird.febs.mall.dto.RegisterDto;
+import cc.mrbird.febs.mall.dto.MoneyChargeListDto;
+import cc.mrbird.febs.mall.dto.MoneyFlowListDto;
 import cc.mrbird.febs.mall.entity.MallMember;
-import cc.mrbird.febs.mall.entity.MallMoneyFlow;
-import cc.mrbird.febs.mall.vo.AdminMallMoneyFlowVo;
-import cc.mrbird.febs.mall.vo.MallMemberVo;
+import cc.mrbird.febs.mall.vo.*;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.service.IService;
 
@@ -23,4 +22,14 @@
     MallMemberVo getMallMemberInfoById(@NotNull(message = "{required}") long id);
 
     IPage<AdminMallMoneyFlowVo> moneyFlow(QueryRequest request, MallMember mallMember);
+
+    IPage<AdminMoneyFlowListVo> getMoneyFlowListInPage(MoneyFlowListDto moneyFlowListDto, QueryRequest request);
+
+    IPage<AdminMoneyChargeListVo> getMoneyChargeListInPage(MoneyChargeListDto moneyChargeListDto, QueryRequest request);
+
+    FebsResponse chargeAgree(Long id);
+
+    FebsResponse chargeDisagree(Long id);
+
+    AdminMallMemberPaymentVo getMallMemberPaymentInfoByFlowId(long id);
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/service/IAdminMallOrderService.java b/src/main/java/cc/mrbird/febs/mall/service/IAdminMallOrderService.java
index 8dbd792..3560aed 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/IAdminMallOrderService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/IAdminMallOrderService.java
@@ -46,4 +46,10 @@
     FebsResponse withAddressUpdate(WithAddressUpdateDto withAddressUpdateDto);
 
     AdminMallOrderRefundVo getMallOrderRefundInfoById(long id);
+
+    IPage<AdminPayMethodVo> getPayMethodListInPage(PayMethodDto payMethodDto, QueryRequest request);
+
+    AdminMallPayMethodEditVo getMallPayMethodEditInfoById(long id);
+
+    FebsResponse payMethodEdit(PayMethodEditDto payMethodEditDto);
 }
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 6a0273e..cd82db8 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
@@ -2,13 +2,15 @@
 
 import cc.mrbird.febs.common.entity.FebsResponse;
 import cc.mrbird.febs.common.entity.QueryRequest;
+import cc.mrbird.febs.mall.dto.MoneyChargeListDto;
+import cc.mrbird.febs.mall.dto.MoneyFlowListDto;
 import cc.mrbird.febs.mall.entity.MallMember;
+import cc.mrbird.febs.mall.entity.MallMoneyFlow;
 import cc.mrbird.febs.mall.mapper.MallMemberMapper;
+import cc.mrbird.febs.mall.mapper.MallMemberPaymentMapper;
 import cc.mrbird.febs.mall.mapper.MallMoneyFlowMapper;
 import cc.mrbird.febs.mall.service.IAdminMallMemberService;
-import cc.mrbird.febs.mall.vo.AdminMallMoneyFlowVo;
-import cc.mrbird.febs.mall.vo.AdminMallOrderRefundOperationVo;
-import cc.mrbird.febs.mall.vo.MallMemberVo;
+import cc.mrbird.febs.mall.vo.*;
 import cn.hutool.core.util.ObjectUtil;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -16,6 +18,7 @@
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 
 /**
  * @author wzy
@@ -30,6 +33,8 @@
 
     private final MallMoneyFlowMapper mallMoneyFlowMapper;
 
+    private final MallMemberPaymentMapper mallMemberPaymentMapper;
+
     @Override
     public IPage<MallMember> getMallMemberList(MallMember mallMember, QueryRequest request) {
         Page<MallMember> page = new Page<>(request.getPageNum(), request.getPageSize());
@@ -38,6 +43,7 @@
     }
 
     @Override
+    @Transactional
     public FebsResponse closeAccount(Long id) {
         MallMember mallMember = mallMemberMapper.selectById(id);
         if(ObjectUtil.isEmpty(mallMember)) {
@@ -49,6 +55,7 @@
     }
 
     @Override
+    @Transactional
     public FebsResponse openAccount(Long id) {
         MallMember mallMember = mallMemberMapper.selectById(id);
         if(ObjectUtil.isEmpty(mallMember)) {
@@ -72,4 +79,49 @@
         return adminMallMoneyFlowVos;
     }
 
+    @Override
+    public IPage<AdminMoneyFlowListVo> getMoneyFlowListInPage(MoneyFlowListDto moneyFlowListDto, QueryRequest request) {
+        Page<AdminMoneyFlowListVo> page = new Page<>(request.getPageNum(), request.getPageSize());
+        IPage<AdminMoneyFlowListVo> adminMoneyFlowListVos = mallMoneyFlowMapper.getMoneyFlowListInPage(page, moneyFlowListDto);
+        return adminMoneyFlowListVos;
+    }
+
+    @Override
+    public IPage<AdminMoneyChargeListVo> getMoneyChargeListInPage(MoneyChargeListDto moneyChargeListDto, QueryRequest request) {
+        Page<AdminMoneyChargeListVo> page = new Page<>(request.getPageNum(), request.getPageSize());
+        IPage<AdminMoneyChargeListVo> adminMoneyChargeListVos = mallMoneyFlowMapper.getMoneyChargeListInPage(page, moneyChargeListDto);
+        return adminMoneyChargeListVos;
+    }
+
+    @Override
+    @Transactional
+    public FebsResponse chargeAgree(Long id) {
+        MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMoneyFlow)){
+            return new FebsResponse().fail().message("系统繁忙,请刷新后重试");
+        }
+        mallMoneyFlow.setStatus(2);
+        mallMoneyFlowMapper.insert(mallMoneyFlow);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    @Transactional
+    public FebsResponse chargeDisagree(Long id) {
+        MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectById(id);
+        if(ObjectUtil.isEmpty(mallMoneyFlow)){
+            return new FebsResponse().fail().message("系统繁忙,请刷新后重试");
+        }
+        mallMoneyFlow.setStatus(3);
+        mallMoneyFlowMapper.insert(mallMoneyFlow);
+        return new FebsResponse().success();
+    }
+
+    @Override
+    public AdminMallMemberPaymentVo getMallMemberPaymentInfoByFlowId(long id) {
+        MallMoneyFlow mallMoneyFlow = mallMoneyFlowMapper.selectById(id);
+        AdminMallMemberPaymentVo adminMallMemberPaymentVo = mallMemberPaymentMapper.getMallMemberPaymentInfoByMemberId(mallMoneyFlow.getMemberId());
+        return adminMallMemberPaymentVo;
+    }
+
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallOrderService.java b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallOrderService.java
index 3416ef8..9a9e5d8 100644
--- a/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallOrderService.java
+++ b/src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallOrderService.java
@@ -41,6 +41,8 @@
 
     private final IApiMallMemberWalletService iApiMallMemberWalletService;
 
+    private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
+
     @Override
     public IPage<AdminMallOrderInfoVo> getOrderListInPage(MallOrderInfoDto mallOrderInfo, QueryRequest request) {
         Page<AdminMallOrderInfoVo> page = new Page<>(request.getPageNum(), request.getPageSize());
@@ -266,5 +268,30 @@
         return mallOrderRefundMapper.getMallOrderRefundInfoById(id);
     }
 
+    @Override
+    public IPage<AdminPayMethodVo> getPayMethodListInPage(PayMethodDto payMethodDto, QueryRequest request) {
+        payMethodDto.setType("PAYMENT_METHOD");
+        Page<AdminPayMethodVo> page = new Page<>(request.getPageNum(), request.getPageSize());
+        IPage<AdminPayMethodVo> adminPayMethodVos = dataDictionaryCustomMapper.getPayMethodListInPage(page, payMethodDto);
+        return adminPayMethodVos;
+    }
+
+    @Override
+    public AdminMallPayMethodEditVo getMallPayMethodEditInfoById(long id) {
+        AdminMallPayMethodEditVo adminMallPayMethodEditVo = dataDictionaryCustomMapper.getMallPayMethodEditInfoById(id);
+        return adminMallPayMethodEditVo;
+    }
+
+    @Override
+    public FebsResponse payMethodEdit(PayMethodEditDto payMethodEditDto) {
+        DataDictionaryCustom dataDictionaryCustom = dataDictionaryCustomMapper.selectById(payMethodEditDto.getId());
+        if(ObjectUtil.isEmpty(dataDictionaryCustom)){
+            return new FebsResponse().fail().message("系统繁忙,请刷新重试");
+        }
+        dataDictionaryCustom.setValue(payMethodEditDto.getValue());
+        dataDictionaryCustomMapper.updateById(dataDictionaryCustom);
+        return new FebsResponse().success();
+    }
+
 
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMallMemberPaymentVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallMemberPaymentVo.java
new file mode 100644
index 0000000..803ba01
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallMemberPaymentVo.java
@@ -0,0 +1,40 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "AdminMallMemberPaymentVo", description = "商城商品列表")
+public class AdminMallMemberPaymentVo {
+
+    private Long id;
+
+    private Long memberId;
+
+    private String wxQrcode;
+
+    private String wxName;
+
+    private String wxAccount;
+
+    private String aliQrcode;
+
+    private String aliName;
+
+    private String aliAccount;
+
+    /**
+     * 持卡人姓名
+     */
+    private String bankName;
+
+    /**
+     * 银行卡号
+     */
+    private String bankNo;
+
+    /**
+     * 开户行
+     */
+    private String bank;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMallOrderRefundVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallOrderRefundVo.java
index 4464c85..18be1e5 100644
--- a/src/main/java/cc/mrbird/febs/mall/vo/AdminMallOrderRefundVo.java
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallOrderRefundVo.java
@@ -1,7 +1,10 @@
 package cc.mrbird.febs.mall.vo;
 
+import com.fasterxml.jackson.annotation.JsonFormat;
 import io.swagger.annotations.ApiModel;
 import lombok.Data;
+
+import java.util.Date;
 
 @Data
 @ApiModel(value = "AdminMallOrderRefundVo", description = "信息返回类")
@@ -38,4 +41,7 @@
     private Integer type;
 
     private String expressCom;
+
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    private Date createdTime;
 }
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMallPayMethodEditVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallPayMethodEditVo.java
new file mode 100644
index 0000000..4153bc6
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMallPayMethodEditVo.java
@@ -0,0 +1,19 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "AdminMallPayMethodEditVo", description = "信息返回类")
+public class AdminMallPayMethodEditVo {
+
+    private Long id;
+
+    private String type;
+
+    private String code;
+
+    private String value;
+
+    private String description;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMoneyChargeListVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMoneyChargeListVo.java
new file mode 100644
index 0000000..05dfcab
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMoneyChargeListVo.java
@@ -0,0 +1,34 @@
+package cc.mrbird.febs.mall.vo;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+@Data
+@ApiModel(value = "AdminMoneyChargeListVo", description = "信息返回类")
+public class AdminMoneyChargeListVo {
+
+    private Long id;
+
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    private Date createdTime;
+
+    private BigDecimal amount;
+
+    private Integer type;
+
+    private String orderNo;
+
+    private String description;
+
+    private String remark;
+
+    private String name;
+
+    private String phone;
+
+    private Integer status;
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminMoneyFlowListVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminMoneyFlowListVo.java
new file mode 100644
index 0000000..49f5801
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminMoneyFlowListVo.java
@@ -0,0 +1,35 @@
+package cc.mrbird.febs.mall.vo;
+
+import com.fasterxml.jackson.annotation.JsonFormat;
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+import java.math.BigDecimal;
+import java.util.Date;
+
+@Data
+@ApiModel(value = "AdminMoneyFlowListVo", description = "信息返回类")
+public class AdminMoneyFlowListVo {
+
+    private Long id;
+
+    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
+    private Date createdTime;
+
+    private BigDecimal amount;
+
+    private Integer type;
+
+    private String orderNo;
+
+    private String description;
+
+    private String remark;
+
+    private String name;
+
+    private String phone;
+
+    private Integer status;
+
+}
diff --git a/src/main/java/cc/mrbird/febs/mall/vo/AdminPayMethodVo.java b/src/main/java/cc/mrbird/febs/mall/vo/AdminPayMethodVo.java
new file mode 100644
index 0000000..0f512ba
--- /dev/null
+++ b/src/main/java/cc/mrbird/febs/mall/vo/AdminPayMethodVo.java
@@ -0,0 +1,19 @@
+package cc.mrbird.febs.mall.vo;
+
+import io.swagger.annotations.ApiModel;
+import lombok.Data;
+
+@Data
+@ApiModel(value = "AdminPayMethodVo", description = "信息返回类")
+public class AdminPayMethodVo {
+
+    private Long id;
+
+    private String type;
+
+    private String code;
+
+    private String value;
+
+    private String description;
+}
diff --git a/src/main/resources/mapper/modules/DataDictionaryCustomMapper.xml b/src/main/resources/mapper/modules/DataDictionaryCustomMapper.xml
index 29b8282..390daa3 100644
--- a/src/main/resources/mapper/modules/DataDictionaryCustomMapper.xml
+++ b/src/main/resources/mapper/modules/DataDictionaryCustomMapper.xml
@@ -5,4 +5,13 @@
     <select id="selectDicByType" resultType="cc.mrbird.febs.mall.entity.DataDictionaryCustom">
         select * from data_dictionary_custom where type=#{type}
     </select>
+
+    <select id="getPayMethodListInPage" resultType="cc.mrbird.febs.mall.vo.AdminPayMethodVo">
+        select * from data_dictionary_custom where type = #{record.type}
+    </select>
+
+    <select id="getMallPayMethodEditInfoById" resultType="cc.mrbird.febs.mall.vo.AdminMallPayMethodEditVo">
+        select * from data_dictionary_custom where id = #{id}
+    </select>
+
 </mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/modules/MallMemberPaymentMapper.xml b/src/main/resources/mapper/modules/MallMemberPaymentMapper.xml
index 17aaeef..bb80933 100644
--- a/src/main/resources/mapper/modules/MallMemberPaymentMapper.xml
+++ b/src/main/resources/mapper/modules/MallMemberPaymentMapper.xml
@@ -5,4 +5,8 @@
     <select id="selectByMemberId" resultType="cc.mrbird.febs.mall.entity.MallMemberPayment">
         select * from mall_member_payment where member_id=#{id}
     </select>
+
+    <select id="getMallMemberPaymentInfoByMemberId" resultType="cc.mrbird.febs.mall.vo.AdminMallMemberPaymentVo">
+        select * from mall_member_payment where member_id = #{memberId}
+    </select>
 </mapper>
\ No newline at end of file
diff --git a/src/main/resources/mapper/modules/MallMoneyFlowMapper.xml b/src/main/resources/mapper/modules/MallMoneyFlowMapper.xml
index e01b963..69e9ebf 100644
--- a/src/main/resources/mapper/modules/MallMoneyFlowMapper.xml
+++ b/src/main/resources/mapper/modules/MallMoneyFlowMapper.xml
@@ -26,4 +26,49 @@
         </where>
         order by a.created_time desc
     </select>
+
+    <select id="getMoneyFlowListInPage" resultType="cc.mrbird.febs.mall.vo.AdminMoneyFlowListVo">
+        select
+        a.*,
+        b.name,
+        b.phone
+        from mall_money_flow a
+        inner join mall_member b on a.member_id=b.id
+        <where>
+            a.type != 6
+            <if test="record != null" >
+                <if test="record.name!=null and record.name!=''">
+                    and b.name like concat('%',  #{record.name},'%')
+                </if>
+                <if test="record.phone!=null and record.phone!=''">
+                    and b.phone like concat('%',  #{record.phone},'%')
+                </if>
+            </if>
+        </where>
+        order by a.created_time desc
+    </select>
+
+    <select id="getMoneyChargeListInPage" resultType="cc.mrbird.febs.mall.vo.AdminMoneyChargeListVo">
+        select
+        a.*,
+        b.name,
+        b.phone
+        from mall_money_flow a
+        inner join mall_member b on a.member_id=b.id
+        <where>
+            a.type = 6
+            <if test="record != null" >
+                <if test="record.name!=null and record.name!=''">
+                    and b.name like concat('%',  #{record.name},'%')
+                </if>
+                <if test="record.phone!=null and record.phone!=''">
+                    and b.phone like concat('%',  #{record.phone},'%')
+                </if>
+                <if test="record.status!=null and record.status!=''">
+                    and a.status = #{record.status}
+                </if>
+            </if>
+        </where>
+        order by a.created_time desc
+    </select>
 </mapper>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/goods/detailGoods.html b/src/main/resources/templates/febs/views/modules/goods/detailGoods.html
index d4b0fff..52640f8 100644
--- a/src/main/resources/templates/febs/views/modules/goods/detailGoods.html
+++ b/src/main/resources/templates/febs/views/modules/goods/detailGoods.html
@@ -38,7 +38,8 @@
                     <input type="text" name="goodsNo" class="layui-input" readonly>
                 </div>
             </div>
-        </div><div class="layui-row layui-col-space10 layui-form-item">
+        </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">
diff --git a/src/main/resources/templates/febs/views/modules/mallMember/chargeFlowList.html b/src/main/resources/templates/febs/views/modules/mallMember/chargeFlowList.html
new file mode 100644
index 0000000..ff44032
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/mallMember/chargeFlowList.html
@@ -0,0 +1,162 @@
+<div class="layui-fluid layui-anim febs-anim" id="febs-money-flow-charge" lay-title="提现管理">
+    <div class="layui-row febs-container">
+        <div class="layui-col-md12">
+            <div class="layui-card">
+                <div class="layui-card-body febs-table-full">
+                    <form class="layui-form layui-table-form" lay-filter="user-table-form">
+                        <div class="layui-row">
+                            <div class="layui-col-md10">
+                                <div class="layui-form-item">
+                                    <div class="layui-inline">
+                                        <div class="layui-input-inline">
+                                            <input type="text" placeholder="用户名" name="name" autocomplete="off" class="layui-input">
+                                        </div>
+                                    </div>
+                                    <div class="layui-inline">
+                                        <div class="layui-input-inline">
+                                            <input type="text" placeholder="手机号" name="phone" autocomplete="off" class="layui-input">
+                                        </div>
+                                    </div>
+                                    <div class="layui-inline">
+                                        <label class="layui-form-label layui-form-label-sm">状态</label>
+                                        <div class="layui-input-inline">
+                                            <select name="status">
+                                                <option value="">请选择</option>
+                                                <option value="1">提现中</option>
+                                                <option value="2">成功</option>
+                                                <option value="3">拒绝</option>
+                                            </select>
+                                        </div>
+                                    </div>
+                                </div>
+                            </div>
+                            <div class="layui-col-md2 layui-col-sm12 layui-col-xs12 table-action-area">
+                                <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain table-action" id="query">
+                                    <i class="layui-icon">&#xe848;</i>
+                                </div>
+                                <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="reset">
+                                    <i class="layui-icon">&#xe79b;</i>
+                                </div>
+                            </div>
+                        </div>
+                    </form>
+                    <table lay-filter="moneyFlowChargeTable" lay-data="{id: 'moneyFlowChargeTable'}"></table>
+                </div>
+            </div>
+        </div>
+    </div>
+</div>
+<!-- 表格操作栏 end -->
+<script data-th-inline="none" type="text/javascript">
+    // 引入组件并初始化
+    layui.use([ 'jquery', 'form', 'table', 'febs'], function () {
+        var $ = layui.jquery,
+            febs = layui.febs,
+            form = layui.form,
+            table = layui.table,
+            $view = $('#febs-money-flow-charge'),
+            $query = $view.find('#query'),
+            $reset = $view.find('#reset'),
+            $searchForm = $view.find('form'),
+            sortObject = {field: 'phone', type: null},
+            tableIns;
+
+        form.render();
+
+        // 表格初始化
+        initTable();
+
+        // 初始化表格操作栏各个按钮功能
+        table.on('tool(moneyFlowChargeTable)', function (obj) {
+            var data = obj.data,
+                layEvent = obj.event;
+            if (layEvent === 'chargeAgree') {
+                febs.modal.confirm('同意', '同意提现?', function () {
+                    chargeAgree(data.id);
+                });
+            }
+            if (layEvent === 'chargeDisagree') {
+                febs.modal.confirm('拒绝', '拒绝提现?', function () {
+                    chargeDisagree(data.id);
+                });
+            }
+            if (layEvent === 'paymentInfo') {
+                febs.modal.open( '收款信息', 'modules/mallMember/paymentInfo/' + data.id, {
+                    maxmin: true,
+                });
+            }
+        });
+        function chargeAgree(id) {
+            febs.get(ctx + 'admin/mallMember/chargeAgree/' + id, null, function () {
+                febs.alert.success('操作成功');
+                $query.click();
+            });
+        }
+        function chargeDisagree(id) {
+            febs.get(ctx + 'admin/mallMember/chargeDisagree/' + id, null, function () {
+                febs.alert.success('操作成功');
+                $query.click();
+            });
+        }
+
+
+        // 查询按钮
+        $query.on('click', function () {
+            var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type});
+            tableIns.reload({where: params, page: {curr: 1}});
+        });
+
+        // 刷新按钮
+        $reset.on('click', function () {
+            $searchForm[0].reset();
+            sortObject.type = 'null';
+            tableIns.reload({where: getQueryParams(), page: {curr: 1}, initSort: sortObject});
+        });
+
+        function initTable() {
+            tableIns = febs.table.init({
+                elem: $view.find('table'),
+                id: 'moneyFlowChargeTable',
+                url: ctx + 'admin/mallMember/getMoneyChargeList',
+                cols: [[
+                    {field: 'name', title: '名称', minWidth: 100,align:'left'},
+                    {field: 'phone', title: '手机号', minWidth: 150,align:'left'},
+                    {field: 'amount', title: '金额', minWidth: 150,align:'left'},
+                    {field: 'status', title: '状态',
+                        templet: function (d) {
+                            if (d.status === 1) {
+                                return '<span style="color:green;">提现中</span>'
+                            } else if (d.status === 2) {
+                                return '<span style="color:red;">成功</span>'
+                            } else if (d.status === 3) {
+                                return '<span style="color:red;">拒绝</span>'
+                            } else{
+                                return ''
+                            }
+                        }, minWidth: 80,align:'center'},
+                    {field: 'createdTime', title: '创建时间', minWidth: 180,align:'center'},
+                    {title: '操作',
+                        templet: function (d) {
+                            if (d.status === 1) {
+                                return '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="chargeAgree" shiro:hasPermission="user:update">同意</button>'
+                                    +'<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="chargeDisagree" shiro:hasPermission="user:update">拒绝</button>'
+                                    +'<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="paymentInfo" shiro:hasPermission="user:update">查看收款方式</button>'
+                            }else{
+                                return '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="paymentInfo" shiro:hasPermission="user:update">查看收款方式</button>'
+                            }
+                        },minWidth: 300,align:'center'}
+                ]]
+            });
+        }
+
+        // 获取查询参数
+        function getQueryParams() {
+            return {
+                name: $searchForm.find('input[name="name"]').val().trim(),
+                phone: $searchForm.find('input[name="phone"]').val().trim(),
+                status: $searchForm.find("select[name='status']").val(),
+            };
+        }
+
+    })
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/mallMember/moneyFlowList.html b/src/main/resources/templates/febs/views/modules/mallMember/moneyFlowList.html
new file mode 100644
index 0000000..8e58caf
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/mallMember/moneyFlowList.html
@@ -0,0 +1,116 @@
+<div class="layui-fluid layui-anim febs-anim" id="febs-money-flow" lay-title="资金流水">
+    <div class="layui-row febs-container">
+        <div class="layui-col-md12">
+            <div class="layui-card">
+                <div class="layui-card-body febs-table-full">
+                    <form class="layui-form layui-table-form" lay-filter="user-table-form">
+                        <div class="layui-row">
+                            <div class="layui-col-md10">
+                                <div class="layui-form-item">
+                                    <div class="layui-inline">
+                                        <div class="layui-input-inline">
+                                            <input type="text" placeholder="用户名" name="name" autocomplete="off" class="layui-input">
+                                        </div>
+                                    </div>
+                                    <div class="layui-inline">
+                                        <div class="layui-input-inline">
+                                            <input type="text" placeholder="手机号" name="phone" 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>
+                                <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="reset">
+                                    <i class="layui-icon">&#xe79b;</i>
+                                </div>
+                            </div>
+                        </div>
+                    </form>
+                    <table lay-filter="moneyFlowTable" lay-data="{id: 'moneyFlowTable'}"></table>
+                </div>
+            </div>
+        </div>
+    </div>
+</div>
+<!-- 表格操作栏 end -->
+<script data-th-inline="none" type="text/javascript">
+    // 引入组件并初始化
+    layui.use([ 'jquery', 'form', 'table', 'febs'], function () {
+        var $ = layui.jquery,
+            febs = layui.febs,
+            form = layui.form,
+            table = layui.table,
+            $view = $('#febs-money-flow'),
+            $query = $view.find('#query'),
+            $reset = $view.find('#reset'),
+            $searchForm = $view.find('form'),
+            sortObject = {field: 'phone', type: null},
+            tableIns;
+
+        form.render();
+
+        // 表格初始化
+        initTable();
+
+        // 初始化表格操作栏各个按钮功能
+        table.on('tool(moneyFlowTable)', function (obj) {
+            var data = obj.data,
+                layEvent = obj.event;
+        });
+
+        // 查询按钮
+        $query.on('click', function () {
+            var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type});
+            tableIns.reload({where: params, page: {curr: 1}});
+        });
+
+        // 刷新按钮
+        $reset.on('click', function () {
+            $searchForm[0].reset();
+            sortObject.type = 'null';
+            tableIns.reload({where: getQueryParams(), page: {curr: 1}, initSort: sortObject});
+        });
+
+        function initTable() {
+            tableIns = febs.table.init({
+                elem: $view.find('table'),
+                id: 'moneyFlowTable',
+                url: ctx + 'admin/mallMember/getMoneyFlowList',
+                cols: [[
+                    {field: 'name', title: '名称', minWidth: 100,align:'left'},
+                    {field: 'phone', title: '手机号', minWidth: 150,align:'left'},
+                    {field: 'amount', title: '金额', minWidth: 150,align:'left'},
+                    {field: 'type', title: '流水类型',
+                        templet: function (d) {
+                            if (d.type === 1) {
+                                return '<span>分红收入</span>'
+                            } else if (d.type === 2) {
+                                return '<span>业绩奖励</span>'
+                            } else if (d.type === 3) {
+                                return '<span>订单支付</span>'
+                            } else if (d.type === 4) {
+                                return '<span>退款</span>'
+                            } else if (d.type === 5) {
+                                return '<span>转账</span>'
+                            } else{
+                                return ''
+                            }
+                        }, minWidth: 80,align:'center'},
+                    {field: 'createdTime', title: '创建时间', minWidth: 180,align:'center'}
+                ]]
+            });
+        }
+
+        // 获取查询参数
+        function getQueryParams() {
+            return {
+                name: $searchForm.find('input[name="name"]').val().trim(),
+                phone: $searchForm.find('input[name="phone"]').val().trim(),
+            };
+        }
+
+    })
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/mallMember/paymentInfo.html b/src/main/resources/templates/febs/views/modules/mallMember/paymentInfo.html
new file mode 100644
index 0000000..f3f9d86
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/mallMember/paymentInfo.html
@@ -0,0 +1,117 @@
+<style>
+    #user-payment-info {
+        padding: 20px 25px 25px 0;
+    }
+
+    #user-payment-info .layui-treeSelect .ztree li a, .ztree li span {
+        margin: 0 0 2px 3px !important;
+    }
+    #user-payment-info #data-permission-tree-block {
+        border: 1px solid #eee;
+        border-radius: 2px;
+        padding: 3px 0;
+    }
+    #user-payment-info .layui-treeSelect .ztree li span.button.switch {
+        top: 1px;
+        left: 3px;
+    }
+
+</style>
+<div class="layui-fluid" id="user-payment-info">
+    <form class="layui-form" action="" lay-filter="user-payment-info-form">
+        <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="wxName" class="layui-input" readonly>
+                </div>
+            </div>
+            <div class="layui-col-lg6">
+                <label class="layui-form-label febs-form-item-require">微信账号:</label>
+                <div class="layui-input-block">
+                    <input type="text" name="wxAccount" class="layui-input" readonly>
+                </div>
+            </div>
+        </div>
+        <div class="layui-form-item">
+            <label class="layui-form-label">微信收款码:</label>
+            <div class="layui-input-block">
+                <img alt="微信收款码" data-th-src="${paymentInfo.wxQrcode}"  style="width: 200px">
+            </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="aliName" class="layui-input" readonly>
+                </div>
+            </div>
+            <div class="layui-col-lg6">
+                <label class="layui-form-label febs-form-item-require">支付宝账号:</label>
+                <div class="layui-input-block">
+                    <input type="text" name="aliAccount" class="layui-input" readonly>
+                </div>
+            </div>
+        </div>
+        <div class="layui-form-item">
+            <label class="layui-form-label">支付宝收款码:</label>
+            <div class="layui-input-block">
+                <img alt="支付宝收款码" data-th-src="${paymentInfo.aliQrcode}"  style="width: 200px">
+            </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="bankName" class="layui-input" readonly>
+                </div>
+            </div>
+            <div class="layui-col-lg6">
+                <label class="layui-form-label febs-form-item-require">开户行:</label>
+                <div class="layui-input-block">
+                    <input type="text" name="bank" class="layui-input" readonly>
+                </div>
+            </div>
+        </div>
+        <div class="layui-form-item">
+            <label class="layui-form-label febs-form-item-require">银行卡号:</label>
+            <div class="layui-input-block">
+                <input type="text" name="bankNo" class="layui-input" readonly>
+            </div>
+        </div>
+    </form>
+</div>
+
+<script data-th-inline="javascript">
+    layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree'], function () {
+        var $ = layui.$,
+            febs = layui.febs,
+            layer = layui.layer,
+            formSelects = layui.formSelects,
+            treeSelect = layui.treeSelect,
+            form = layui.form,
+            eleTree = layui.eleTree,
+            paymentInfo = [[${paymentInfo}]],
+            $view = $('#user-payment-info'),
+            validate = layui.validate,
+            _deptTree;
+
+        form.render();
+
+        initUserValue();
+
+        function initUserValue() {
+            form.val("user-payment-info-form", {
+                "wxName": paymentInfo.wxName,
+                "wxAccount": paymentInfo.wxAccount,
+                "wxQrcode": paymentInfo.wxQrcode,
+                "aliName": paymentInfo.aliName,
+                "aliAccount": paymentInfo.aliAccount,
+                "aliQrcode": paymentInfo.aliQrcode,
+                "bankName": paymentInfo.bankName,
+                "bankNo": paymentInfo.bankNo,
+                "bank": paymentInfo.bank
+            });
+        }
+    });
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/order/payMethodEdit.html b/src/main/resources/templates/febs/views/modules/order/payMethodEdit.html
new file mode 100644
index 0000000..8fc6928
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/order/payMethodEdit.html
@@ -0,0 +1,122 @@
+<style>
+    #user-payment-edit {
+        padding: 20px 25px 25px 0;
+    }
+
+    #user-payment-edit .layui-treeSelect .ztree li a, .ztree li span {
+        margin: 0 0 2px 3px !important;
+    }
+    #user-payment-edit #data-permission-tree-block {
+        border: 1px solid #eee;
+        border-radius: 2px;
+        padding: 3px 0;
+    }
+    #user-payment-edit .layui-treeSelect .ztree li span.button.switch {
+        top: 1px;
+        left: 3px;
+    }
+    #user-payment-edit img{
+        max-width:200px
+    }
+
+</style>
+<div class="layui-fluid" id="user-payment-edit">
+    <form class="layui-form" action="" lay-filter="user-payment-edit-form">
+        <div class="layui-form-item febs-hide">
+            <label class="layui-form-label">id:</label>
+            <div class="layui-input-block">
+                <input type="text" name="id">
+            </div>
+        </div>
+        <div class="layui-row layui-col-space10 layui-form-item">
+            <div class="layui-col-lg6">
+                <label class="layui-form-label">编码:</label>
+                <div class="layui-input-block">
+                    <input type="text" name="code" class="layui-input" readonly>
+                </div>
+            </div>
+            <div class="layui-col-lg6">
+                <label class="layui-form-label">描述:</label>
+                <div class="layui-input-block">
+                    <input type="text" name="description" class="layui-input" readonly>
+                </div>
+            </div>
+        </div>
+        <div class="layui-form-item">
+            <label class="layui-form-label">收款码:</label>
+            <div class="layui-upload">
+                <button type="button" class="layui-btn" id="test1">上传图片</button>
+                <div class="layui-input-block">
+                    <div class="layui-upload-list">
+                        <img class="layui-upload-img" id="imageUrls" width="100%" >
+                    </div>
+                </div>
+            </div>
+        </div>
+        <div class="layui-form-item">
+            <label class="layui-form-label">图片链接:</label>
+            <div class="layui-input-block">
+                <input type="text" id="imageUrl" name="value" class="layui-input" readonly>
+            </div>
+        </div>
+        <div class="layui-form-item febs-hide">
+            <button class="layui-btn" lay-submit="" lay-filter="user-payment-edit-submit" id="submit"></button>
+        </div>
+    </form>
+</div>
+
+<script data-th-inline="javascript">
+    layui.use(['febs', 'form', 'formSelects', 'validate', 'treeSelect', 'eleTree','upload'], function () {
+        var $ = layui.$,
+            febs = layui.febs,
+            layer = layui.layer,
+            formSelects = layui.formSelects,
+            treeSelect = layui.treeSelect,
+            form = layui.form,
+            eleTree = layui.eleTree,
+            payMethodEdit = [[${payMethodEdit}]],
+            $view = $('#user-payment-edit'),
+            validate = layui.validate,
+            upload = layui.upload,
+            _deptTree;
+
+        //普通图片上传
+        var uploadInst = upload.render({
+            elem: '#test1'
+            ,url: ctx + 'admin/goods/uploadFileBase64' //改成您自己的上传接口
+            ,before: function(obj){
+                //预读本地文件示例,不支持ie8
+                obj.preview(function(index, file, result){
+                    $('#imageUrls').attr('src', result); //图片链接(base64)
+                });
+            }
+            ,done: function(res){
+                febs.alert.success(res.data.src);
+                $("#imageUrl").val(res.data.src);
+            }
+        });
+
+        form.render();
+
+        initUserValue();
+
+        function initUserValue() {
+            $('#imageUrls').attr('src', payMethodEdit.value);
+            form.val("user-payment-edit-form", {
+                "id": payMethodEdit.id,
+                "code": payMethodEdit.code,
+                "description": payMethodEdit.description,
+                "value": payMethodEdit.value
+            });
+        }
+
+        form.on('submit(user-payment-edit-submit)', function (data) {
+            febs.post(ctx + 'admin/order/payMethodEdit', data.field, function () {
+                layer.closeAll();
+                febs.alert.success('操作成功');
+                $('#febs-order-paymethod').find('#reset').click();
+            });
+            return false;
+        });
+    });
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/order/payMethodList.html b/src/main/resources/templates/febs/views/modules/order/payMethodList.html
new file mode 100644
index 0000000..707a24d
--- /dev/null
+++ b/src/main/resources/templates/febs/views/modules/order/payMethodList.html
@@ -0,0 +1,134 @@
+<div class="layui-fluid layui-anim febs-anim" id="febs-order-paymethod" lay-title="商家收款">
+
+    <div class="layui-row febs-container">
+        <div class="layui-col-md12">
+            <div class="layui-card">
+                <div class="layui-card-body febs-table-full">
+                    <form class="layui-form layui-table-form" lay-filter="user-table-form">
+                        <div class="layui-form-item">
+                            <div class="layui-col-md10">
+                            </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>
+                                <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="reset">
+                                    <i class="layui-icon">&#xe79b;</i>
+                                </div>
+                            </div>
+                        </div>
+                    </form>
+                    <table lay-filter="orderPaymethodTable" lay-data="{id: 'orderPaymethodTable'}"></table>
+                    <style type="text/css">
+                    .layui-table-cell{
+                        text-align:center;
+                        height: auto;
+                        white-space: normal;
+                    }
+                    .layui-table img{
+                        max-width:200px
+                    }
+                </style>
+                </div>
+            </div>
+        </div>
+    </div>
+</div>
+<!-- 表格操作栏 end -->
+<script data-th-inline="none" type="text/javascript">
+    // 引入组件并初始化
+    layui.use([ 'jquery', 'form', 'table', 'febs'], function () {
+        var $ = layui.jquery,
+            febs = layui.febs,
+            form = layui.form,
+            table = layui.table,
+            $view = $('#febs-order-paymethod'),
+            $query = $view.find('#query'),
+            $reset = $view.find('#reset'),
+            $searchForm = $view.find('form'),
+            $add = $view.find('#add'),
+            sortObject = {field: 'phone', type: null},
+            tableIns;
+
+        form.render();
+
+        // 表格初始化
+        initTable();
+
+        // 初始化表格操作栏各个按钮功能
+        table.on('tool(orderPaymethodTable)', function (obj) {
+            var data = obj.data,
+                layEvent = obj.event;
+            if (layEvent === 'payMethodedit') {
+                febs.modal.open('选择退货地址', 'modules/order/payMethodEdit/' + data.id, {
+                    btn: ['确认', '取消'],
+                    yes: function (index, layero) {
+                        $('#user-payment-edit').find('#submit').trigger('click');
+                    },
+                    btn2: function () {
+                        layer.closeAll();
+                    }
+                });
+            }
+            if (layEvent === 'seeImg') {
+                    var t = $view.find('#seeImg'+data.id+'');
+                    //页面层
+                    layer.open({
+                        type: 1,
+                        title: "图片",
+                        skin: 'layui-layer-rim', //加上边框
+                        area: ['80%', '80%'], //宽高
+                        shadeClose: true, //开启遮罩关闭
+                        end: function (index, layero) {
+                            return false;
+                        },
+                        content: '<div style="text-align:center"><img src="' + $(t).attr('src') + '" /></div>'
+                    });
+            }
+        });
+
+        // 查询按钮
+        $query.on('click', function () {
+            var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type});
+            tableIns.reload({where: params, page: {curr: 1}});
+        });
+
+        // 刷新按钮
+        $reset.on('click', function () {
+            $searchForm[0].reset();
+            sortObject.type = 'null';
+            tableIns.reload({where: getQueryParams(), page: {curr: 1}, initSort: sortObject});
+        });
+
+        function initTable() {
+            tableIns = febs.table.init({
+                elem: $view.find('table'),
+                id: 'orderPaymethodTable',
+                url: ctx + 'admin/order/payMethodList',
+                cols: [[
+                    {field: 'code', title: '编码', minWidth: 150,align:'left'},
+                    {field: 'description', title: '描述', minWidth: 150,align:'left'},
+                    {field: 'value', title: '收款码',
+                        templet: function (d) {
+                            return '<a lay-event="seeImg"><img id="seeImg'+d.id+'" src="'+d.value+'" alt=""></a>';
+                        }, minWidth: 200,align:'center'},
+                    {title: '操作',
+                        templet: function (d) {
+                            return '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="payMethodedit" shiro:hasPermission="user:update">编辑</button>'
+                        },minWidth: 300,align:'center'}
+                ]]
+            });
+        }
+
+        // 获取查询参数
+        function getQueryParams() {
+            return {
+                name: $searchForm.find('input[name="name"]').val().trim(),
+                phone: $searchForm.find('input[name="phone"]').val().trim(),
+                orderNo: $searchForm.find('input[name="orderNo"]').val().trim(),
+                status: $searchForm.find("select[name='status']").val(),
+            };
+        }
+
+    })
+</script>
\ No newline at end of file
diff --git a/src/main/resources/templates/febs/views/modules/order/refundList.html b/src/main/resources/templates/febs/views/modules/order/refundList.html
index cbfffef..cca5d22 100644
--- a/src/main/resources/templates/febs/views/modules/order/refundList.html
+++ b/src/main/resources/templates/febs/views/modules/order/refundList.html
@@ -189,6 +189,7 @@
                             }
                         }, minWidth: 80,align:'center'},
                     {field: 'addressDetail', title: '收货信息', minWidth: 150,align:'left'},
+                    {field: 'createdTime', title: '创建时间', minWidth: 150,align:'left'},
                     {title: '操作',
                         templet: function (d) {
                         if(d.status === 1){
diff --git a/src/main/resources/templates/febs/views/modules/order/withAddress.html b/src/main/resources/templates/febs/views/modules/order/withAddress.html
index 0048222..b8cfc79 100644
--- a/src/main/resources/templates/febs/views/modules/order/withAddress.html
+++ b/src/main/resources/templates/febs/views/modules/order/withAddress.html
@@ -65,7 +65,7 @@
             });
         }
 
-        //付款方式(下拉框)
+        //(下拉框)
         $.get(ctx + 'admin/order/addAddress/tree', function (data) {
             for (var k in data)
             {

--
Gitblit v1.9.1