get seller entry goods list
Showing
7 changed files
with
225 additions
and
3 deletions
1 | +package com.yohoufo.dal.order; | ||
2 | + | ||
3 | +import com.yohoufo.dal.order.model.SellerOrderGoods; | ||
4 | +import org.apache.ibatis.annotations.Param; | ||
5 | + | ||
6 | +import java.util.List; | ||
7 | + | ||
8 | +/** | ||
9 | + * Created by chao.chen on 2018/12/19. | ||
10 | + */ | ||
11 | +public interface SellerOrderGoodsViewMapper { | ||
12 | + | ||
13 | + int selectEntryCntByUidStatusGBSkc(@Param("uid")int uid, @Param("statusList") List<Integer> statusList); | ||
14 | + | ||
15 | + List<SellerOrderGoods> selectEntryListByUidStatusGBSkc(@Param("uid")int uid, | ||
16 | + @Param("statusList") List<Integer> statusList, | ||
17 | + @Param("offset")Integer offset, | ||
18 | + @Param("limit")Integer limit); | ||
19 | +} |
1 | +<?xml version="1.0" encoding="UTF-8"?> | ||
2 | +<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> | ||
3 | +<mapper namespace="com.yohoufo.dal.order.SellerOrderGoodsViewMapper"> | ||
4 | + <resultMap id="BaseResultMap" type="com.yohoufo.dal.order.model.SellerOrderGoods"> | ||
5 | + <id column="id" jdbcType="INTEGER" property="id" /> | ||
6 | + <result column="product_id" jdbcType="INTEGER" property="productId" /> | ||
7 | + <result column="uid" jdbcType="INTEGER" property="uid" /> | ||
8 | + <result column="product_name" jdbcType="VARCHAR" property="productName" /> | ||
9 | + <result column="storage_id" jdbcType="INTEGER" property="storageId" /> | ||
10 | + <result column="depot_no" jdbcType="INTEGER" property="depotNo" /> | ||
11 | + <result column="size_id" jdbcType="INTEGER" property="sizeId" /> | ||
12 | + <result column="size_name" jdbcType="VARCHAR" property="sizeName" /> | ||
13 | + <result column="color_id" jdbcType="SMALLINT" property="colorId" /> | ||
14 | + <result column="color_name" jdbcType="VARCHAR" property="colorName" /> | ||
15 | + <result column="goods_price" jdbcType="DECIMAL" property="goodsPrice" /> | ||
16 | + <result column="status" jdbcType="TINYINT" property="status" /> | ||
17 | + <result column="image_url" jdbcType="VARCHAR" property="imageUrl" /> | ||
18 | + <result column="is_del" jdbcType="TINYINT" property="isDel" /> | ||
19 | + <result column="batch_no" jdbcType="BIGINT" property="batchNo" /> | ||
20 | + <result column="num" jdbcType="INTEGER" property="num" /> | ||
21 | + <result column="skup_list" jdbcType="VARCHAR" property="skupList" /> | ||
22 | + </resultMap> | ||
23 | + <sql id="Base_Column_List"> | ||
24 | + id, uid, product_id, product_name, storage_id, depot_no, size_id, size_name, | ||
25 | + color_id, color_name, goods_price, status, image_url, is_del, batch_no | ||
26 | + </sql> | ||
27 | + | ||
28 | + <select id="selectEntryCntByUidStatusGBSkc" resultType="java.lang.Integer"> | ||
29 | + SELECT COUNT(*) from (select sog.id FROM seller_order_goods sog,seller_order so | ||
30 | + WHERE sog.id = so.skup and sog.uid = #{uid,jdbcType=INTEGER} and sog.is_del = 1 | ||
31 | + AND so.payment = 11 | ||
32 | + <if test="statusList != null"> | ||
33 | + and sog.status in | ||
34 | + <foreach item="status" index="index" collection="statusList" open="(" separator="," close=")"> | ||
35 | + #{status, jdbcType=TINYINT} | ||
36 | + </foreach> | ||
37 | + </if> | ||
38 | + GROUP BY sog.uid,product_id) t | ||
39 | + </select> | ||
40 | + | ||
41 | + <sql id="Base_Column_List_with_table_name"> | ||
42 | + sog.id as id, sog.uid as uid, product_id, product_name,storage_id,depot_no,size_id,size_name, | ||
43 | + color_id, color_name, goods_price, sog.status as status, image_url, sog.is_del as is_del, batch_no | ||
44 | + </sql> | ||
45 | + | ||
46 | + <select id="selectEntryListByUidStatusGBSkc" resultMap="BaseResultMap"> | ||
47 | + SELECT <include refid="Base_Column_List_with_table_name" /> FROM seller_order_goods sog,seller_order so | ||
48 | + WHERE sog.id = so.skup and sog.uid = #{uid,jdbcType=INTEGER} and sog.is_del = 1 AND so.payment = 11 | ||
49 | + <if test="statusList != null"> | ||
50 | + and sog.status in | ||
51 | + <foreach item="status" index="index" collection="statusList" open="(" separator="," close=")"> | ||
52 | + #{status, jdbcType=TINYINT} | ||
53 | + </foreach> | ||
54 | + </if> | ||
55 | + GROUP BY sog.uid,product_id ORDER BY id DESC | ||
56 | + limit #{offset, jdbcType=INTEGER}, #{limit, jdbcType=INTEGER} | ||
57 | + </select> | ||
58 | +</mapper> |
1 | +package com.yohoufo.order.controller; | ||
2 | + | ||
3 | +import com.yohobuy.ufo.model.order.resp.OrderListInfo; | ||
4 | +import com.yohobuy.ufo.model.order.resp.PageResp; | ||
5 | +import com.yohoufo.common.ApiResponse; | ||
6 | +import com.yohoufo.order.model.request.OrderListRequest; | ||
7 | +import com.yohoufo.order.service.impl.SkupListService; | ||
8 | +import com.yohoufo.order.utils.LoggerUtils; | ||
9 | +import org.slf4j.Logger; | ||
10 | +import org.springframework.beans.factory.annotation.Autowired; | ||
11 | +import org.springframework.stereotype.Controller; | ||
12 | +import org.springframework.web.bind.annotation.RequestMapping; | ||
13 | +import org.springframework.web.bind.annotation.RequestParam; | ||
14 | +import org.springframework.web.bind.annotation.ResponseBody; | ||
15 | + | ||
16 | +/** | ||
17 | + * Created by chao.chen on 2018/12/19. | ||
18 | + */ | ||
19 | +@Controller | ||
20 | +public class SellerGoodsController { | ||
21 | + | ||
22 | + | ||
23 | + private final Logger logger = LoggerUtils.getSellerOrderLogger(); | ||
24 | + | ||
25 | + | ||
26 | + @Autowired | ||
27 | + private SkupListService skupListService; | ||
28 | + | ||
29 | + | ||
30 | + | ||
31 | + @RequestMapping(params = "method=ufo.seller.entryPrdList") | ||
32 | + @ResponseBody | ||
33 | + public ApiResponse getEntryGoodsList(@RequestParam("type") int type, | ||
34 | + @RequestParam("uid") int uid, | ||
35 | + @RequestParam(value = "page", required = false, defaultValue = "1") int page, | ||
36 | + @RequestParam(value = "limit", required = false, defaultValue = "10") int limit) { | ||
37 | + OrderListRequest orderListRequest = OrderListRequest.builder() | ||
38 | + .uid(uid) | ||
39 | + .type(type) | ||
40 | + .page(page) | ||
41 | + .limit(limit) | ||
42 | + .build(); | ||
43 | + logger.info("ufo.seller.entryPrdList orderListRequest {}", orderListRequest); | ||
44 | + PageResp<OrderListInfo> orderListInfoRsp; | ||
45 | + orderListInfoRsp = skupListService.getEntryGoodsList(orderListRequest); | ||
46 | + return new ApiResponse.ApiResponseBuilder().code(200).data(orderListInfoRsp).message("卖家订单列表").build(); | ||
47 | + } | ||
48 | + | ||
49 | + @RequestMapping(params = "method=ufo.seller.notEntryPrdList") | ||
50 | + @ResponseBody | ||
51 | + public ApiResponse getNotEntryGoodsList(@RequestParam("type") int type, | ||
52 | + @RequestParam("uid") int uid, | ||
53 | + @RequestParam(value = "page", required = false, defaultValue = "1") int page, | ||
54 | + @RequestParam(value = "limit", required = false, defaultValue = "10") int limit) { | ||
55 | + OrderListRequest orderListRequest = OrderListRequest.builder() | ||
56 | + .uid(uid) | ||
57 | + .type(type) | ||
58 | + .page(page) | ||
59 | + .limit(limit) | ||
60 | + .build(); | ||
61 | + logger.info("ufo.seller.notEntryPrdList orderListRequest {}", orderListRequest); | ||
62 | + PageResp<OrderListInfo> orderListInfoRsp; | ||
63 | + orderListInfoRsp = skupListService.getNotEntryGoodsList(orderListRequest); | ||
64 | + return new ApiResponse.ApiResponseBuilder().code(200).data(orderListInfoRsp).message("卖家订单列表").build(); | ||
65 | + } | ||
66 | + | ||
67 | + @RequestMapping(params = "method=ufo.seller.entryGoodsSizeList") | ||
68 | + @ResponseBody | ||
69 | + public ApiResponse getEntryGoodsSizeList(@RequestParam("type") int type, | ||
70 | + @RequestParam("uid") int uid, | ||
71 | + @RequestParam(value = "page", required = false, defaultValue = "1") int page, | ||
72 | + @RequestParam(value = "limit", required = false, defaultValue = "10") int limit) { | ||
73 | + OrderListRequest orderListRequest = OrderListRequest.builder() | ||
74 | + .uid(uid) | ||
75 | + .type(type) | ||
76 | + .page(page) | ||
77 | + .limit(limit) | ||
78 | + .build(); | ||
79 | + logger.info("ufo.seller.entryGoodsSizeList orderListRequest {}", orderListRequest); | ||
80 | + PageResp<OrderListInfo> orderListInfoRsp; | ||
81 | + orderListInfoRsp = skupListService.getEntryGoodsSizeList(orderListRequest); | ||
82 | + return new ApiResponse.ApiResponseBuilder().code(200).data(orderListInfoRsp).message("卖家订单列表").build(); | ||
83 | + } | ||
84 | + | ||
85 | + | ||
86 | + | ||
87 | +} |
@@ -19,6 +19,7 @@ import com.yohoufo.order.service.handler.SellerOrderComputeHandler; | @@ -19,6 +19,7 @@ import com.yohoufo.order.service.handler.SellerOrderComputeHandler; | ||
19 | import com.yohoufo.order.service.impl.SellerOrderService; | 19 | import com.yohoufo.order.service.impl.SellerOrderService; |
20 | import com.yohoufo.order.service.impl.SellerService; | 20 | import com.yohoufo.order.service.impl.SellerService; |
21 | import com.yohoufo.order.service.impl.SkupListService; | 21 | import com.yohoufo.order.service.impl.SkupListService; |
22 | +import com.yohoufo.order.utils.LoggerUtils; | ||
22 | import org.apache.kafka.common.requests.LeaderAndIsrRequest; | 23 | import org.apache.kafka.common.requests.LeaderAndIsrRequest; |
23 | import org.slf4j.Logger; | 24 | import org.slf4j.Logger; |
24 | import org.slf4j.LoggerFactory; | 25 | import org.slf4j.LoggerFactory; |
@@ -39,7 +40,7 @@ import java.util.Objects; | @@ -39,7 +40,7 @@ import java.util.Objects; | ||
39 | public class SellerOrderController { | 40 | public class SellerOrderController { |
40 | 41 | ||
41 | 42 | ||
42 | - private final Logger logger = LoggerFactory.getLogger(getClass()); | 43 | + private final Logger logger = LoggerUtils.getSellerOrderLogger(); |
43 | 44 | ||
44 | @Autowired | 45 | @Autowired |
45 | private SellerOrderService sellerOrderService; | 46 | private SellerOrderService sellerOrderService; |
@@ -5,8 +5,8 @@ import com.yohobuy.ufo.model.order.common.SellerOrderListType; | @@ -5,8 +5,8 @@ import com.yohobuy.ufo.model.order.common.SellerOrderListType; | ||
5 | import com.yohobuy.ufo.model.order.common.SellerType; | 5 | import com.yohobuy.ufo.model.order.common.SellerType; |
6 | import com.yohobuy.ufo.model.order.resp.OrderListInfo; | 6 | import com.yohobuy.ufo.model.order.resp.OrderListInfo; |
7 | import com.yohobuy.ufo.model.order.resp.PageResp; | 7 | import com.yohobuy.ufo.model.order.resp.PageResp; |
8 | -import com.yohobuy.ufo.model.order.vo.OrderListVo; | ||
9 | import com.yohoufo.dal.order.SellerOrderGoodsMapper; | 8 | import com.yohoufo.dal.order.SellerOrderGoodsMapper; |
9 | +import com.yohoufo.dal.order.SellerOrderGoodsViewMapper; | ||
10 | import com.yohoufo.dal.order.model.SellerOrderGoods; | 10 | import com.yohoufo.dal.order.model.SellerOrderGoods; |
11 | import com.yohoufo.order.model.request.OrderListRequest; | 11 | import com.yohoufo.order.model.request.OrderListRequest; |
12 | import com.yohoufo.order.service.cache.OrderCacheService; | 12 | import com.yohoufo.order.service.cache.OrderCacheService; |
@@ -20,7 +20,6 @@ import org.springframework.stereotype.Service; | @@ -20,7 +20,6 @@ import org.springframework.stereotype.Service; | ||
20 | 20 | ||
21 | import java.util.Comparator; | 21 | import java.util.Comparator; |
22 | import java.util.List; | 22 | import java.util.List; |
23 | -import java.util.Objects; | ||
24 | 23 | ||
25 | /** | 24 | /** |
26 | * Created by chao.chen on 2018/12/13. | 25 | * Created by chao.chen on 2018/12/13. |
@@ -44,6 +43,9 @@ public class SkupListService { | @@ -44,6 +43,9 @@ public class SkupListService { | ||
44 | @Autowired | 43 | @Autowired |
45 | private SellerOrderListService sellerOrderListService; | 44 | private SellerOrderListService sellerOrderListService; |
46 | 45 | ||
46 | + @Autowired | ||
47 | + private SellerOrderGoodsViewMapper sellerOrderGoodsViewMapper; | ||
48 | + | ||
47 | static Integer getMinSkupId(String skupList){ | 49 | static Integer getMinSkupId(String skupList){ |
48 | Integer lastSkup = null; | 50 | Integer lastSkup = null; |
49 | if (StringUtils.isNotBlank(skupList)){ | 51 | if (StringUtils.isNotBlank(skupList)){ |
@@ -96,5 +98,58 @@ public class SkupListService { | @@ -96,5 +98,58 @@ public class SkupListService { | ||
96 | } | 98 | } |
97 | 99 | ||
98 | 100 | ||
101 | + public PageResp<OrderListInfo> getEntryGoodsList(OrderListRequest request){ | ||
102 | + PageResp.PageRespBuilder respBuilder; | ||
103 | + int limit = request.getLimit(); | ||
104 | + respBuilder = PageResp.builder() | ||
105 | + .page(request.getPage()) | ||
106 | + .pageSize(limit); | ||
107 | + int type; | ||
108 | + if ((type=request.getType()) == SellerOrderListType.IN_SALE.getType()) { | ||
109 | + List<Integer> statusList = sellerOrderListService.initOrderListRequest(request); | ||
110 | + int total = sellerOrderGoodsViewMapper.selectEntryCntByUidStatusGBSkc(request.getUid(), statusList); | ||
111 | + respBuilder.total(total) | ||
112 | + .pagetotal((total % limit == 0) ? (total / limit) : (total / limit + 1)); | ||
113 | + if (total == 0){ | ||
114 | + return respBuilder.build(); | ||
115 | + } | ||
116 | + int offset = (request.getPage() - 1) * limit; | ||
117 | + List<SellerOrderGoods> sogList = sellerOrderGoodsViewMapper.selectEntryListByUidStatusGBSkc(request.getUid(), | ||
118 | + statusList, offset , limit); | ||
119 | + if (CollectionUtils.isEmpty(sogList)){ | ||
120 | + logger.warn("seller get entry order list SellerOrderGoods is empty,req {}", request); | ||
121 | + return respBuilder.build(); | ||
122 | + } | ||
123 | + boolean isEntry = userProxyService.isEntryShop(request.getUid()); | ||
124 | + final SellerType sellerType = isEntry ? SellerType.ENTRY : SellerType.COMMON; | ||
125 | + List<OrderListInfo> data = sellerOrderListService.buildOrderList(sogList, sellerType); | ||
126 | + respBuilder.data(data); | ||
127 | + } | ||
99 | 128 | ||
129 | + return respBuilder.build(); | ||
130 | + } | ||
131 | + | ||
132 | + public PageResp<OrderListInfo> getNotEntryGoodsList(OrderListRequest request){ | ||
133 | + PageResp.PageRespBuilder respBuilder; | ||
134 | + int limit = request.getLimit(); | ||
135 | + respBuilder = PageResp.builder() | ||
136 | + .page(request.getPage()) | ||
137 | + .pageSize(limit); | ||
138 | + | ||
139 | + | ||
140 | + return respBuilder.build(); | ||
141 | + } | ||
142 | + | ||
143 | + | ||
144 | + | ||
145 | + public PageResp<OrderListInfo> getEntryGoodsSizeList(OrderListRequest request){ | ||
146 | + PageResp.PageRespBuilder respBuilder; | ||
147 | + int limit = request.getLimit(); | ||
148 | + respBuilder = PageResp.builder() | ||
149 | + .page(request.getPage()) | ||
150 | + .pageSize(limit); | ||
151 | + | ||
152 | + | ||
153 | + return respBuilder.build(); | ||
154 | + } | ||
100 | } | 155 | } |
@@ -60,6 +60,7 @@ datasources: | @@ -60,6 +60,7 @@ datasources: | ||
60 | - com.yohoufo.dal.order.StoredSellerMapper | 60 | - com.yohoufo.dal.order.StoredSellerMapper |
61 | - com.yohoufo.dal.order.SuperEntrySellerMapper | 61 | - com.yohoufo.dal.order.SuperEntrySellerMapper |
62 | - com.yohoufo.dal.order.QiniuLiveRecordMapper | 62 | - com.yohoufo.dal.order.QiniuLiveRecordMapper |
63 | + - com.yohoufo.dal.order.SellerOrderGoodsViewMapper | ||
63 | 64 | ||
64 | ufo_promotion: | 65 | ufo_promotion: |
65 | servers: | 66 | servers: |
@@ -60,6 +60,7 @@ datasources: | @@ -60,6 +60,7 @@ datasources: | ||
60 | - com.yohoufo.dal.order.StoredSellerMapper | 60 | - com.yohoufo.dal.order.StoredSellerMapper |
61 | - com.yohoufo.dal.order.SuperEntrySellerMapper | 61 | - com.yohoufo.dal.order.SuperEntrySellerMapper |
62 | - com.yohoufo.dal.order.QiniuLiveRecordMapper | 62 | - com.yohoufo.dal.order.QiniuLiveRecordMapper |
63 | + - com.yohoufo.dal.order.SellerOrderGoodsViewMapper | ||
63 | 64 | ||
64 | ufo_promotion: | 65 | ufo_promotion: |
65 | servers: | 66 | servers: |
-
Please register or login to post a comment