From f58050b2e5ba95be6dca3e617dfacb7a717d6096 Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Fri, 16 May 2025 17:37:41 +0800 Subject: [PATCH] feat(mall): 添加会员等级图标并更新销售信息 --- src/main/resources/mapper/modules/MallTeamLeaderMapper.xml | 140 ++++++++++++++++++++++++++++++++++++++++++---- 1 files changed, 126 insertions(+), 14 deletions(-) diff --git a/src/main/resources/mapper/modules/MallTeamLeaderMapper.xml b/src/main/resources/mapper/modules/MallTeamLeaderMapper.xml index b80a2d7..2ea6875 100644 --- a/src/main/resources/mapper/modules/MallTeamLeaderMapper.xml +++ b/src/main/resources/mapper/modules/MallTeamLeaderMapper.xml @@ -22,6 +22,7 @@ <select id="selectApiLeaderListInPage" resultType="cc.mrbird.febs.mall.entity.MallTeamLeader"> select a.*, + b.longlatiarr, ROUND( 6378.138 * 2 * ASIN( SQRT( @@ -32,8 +33,9 @@ ) * 1000 ) AS distance from mall_team_leader a + left join mall_electronic_fence b on b.team_leader_code = a.unique_code <where> - a.state = 1 + a.state = 1 and a.online_state = 1 <if test="record.query != null and record.query != ''"> and (a.name like CONCAT('%', CONCAT(#{record.query}, '%')) or a.phone like CONCAT('%', CONCAT(#{record.query}, '%')) @@ -70,9 +72,12 @@ <result column="latitude" property="latitude" /> <result column="order_type" property="orderType" /> <result column="comment_state" property="commentState" /> + <result column="delivery_state" property="deliveryState" /> <result column="carriage" property="carriage" /> + <result column="take_code" property="takeCode" /> <result column="remark" property="remark" /> <result column="del_flag" property="delFlag" /> + <result column="is_home" property="isHome" /> <collection property="items" ofType="cc.mrbird.febs.mall.entity.MallOrderItem"> <id property="id" column="item_id" /> <result property="orderId" column="order_id" /> @@ -86,6 +91,7 @@ <result property="price" column="price" /> <result property="amount" column="amount" /> <result property="isNormal" column="is_normal" /> + <result property="state" column="state" /> </collection> </resultMap> @@ -100,6 +106,7 @@ b.style_name, b.sku_name, b.sku_image, + b.state, b.cnt, b.price, b.amount @@ -107,15 +114,7 @@ inner join mall_order_item b on a.id=b.order_id inner join mall_member c on a.take_unique_code=c.invite_id <where> - a.del_flag=2 - and a.delivery_type = 1 - and c.id=#{record.memberId} - <if test="record.query != null and record.query != ''"> - and ( a.name like CONCAT('%', CONCAT(#{record.query}, '%')) - or a.phone like CONCAT('%', CONCAT(#{record.query}, '%')) - or a.take_code like CONCAT('%', CONCAT(#{record.query}, '%')) - ) - </if> + c.id=#{record.memberId} <if test="record.status == 4 and record.status != 0"> and a.status = 4 </if> @@ -123,14 +122,88 @@ and a.status = #{record.status} </if> <if test="record.status == 5"> - and a.status = 7 + and (a.status = 6 or b.state = 2) </if> <if test="record.status == 1"> and a.status = 2 </if> + <if test="record.status == 0"> + and a.status in (2,3,4) + </if> + <if test="record.query != null and record.query != ''"> + and ( a.name like CONCAT('%', CONCAT(#{record.query}, '%')) + or a.phone like CONCAT('%', CONCAT(#{record.query}, '%')) + or a.take_code like CONCAT('%', CONCAT(#{record.query}, '%')) + or b.goods_name like CONCAT('%', CONCAT(#{record.query}, '%')) + ) + </if> <if test="record.orderType != null"> and a.order_type=#{record.orderType} </if> + and a.delivery_type = 1 + </where> + order by a.created_time desc + </select> + + <resultMap id="NewOrderInfoMap" type="cc.mrbird.febs.mall.entity.MallOrderInfo"> + <id column="id" property="id" /> + <result column="order_no" property="orderNo" /> + <result column="member_id" property="memberId" /> + <result column="order_time" property="orderTime" /> + <result column="pay_time" property="payTime" /> + <result column="amount" property="amount" /> + <result column="pay_method" property="payMethod" /> + <result column="pay_order_no" property="payOrderNo" /> + <result column="pay_result" property="payResult" /> + <result column="status" property="status" /> + <result column="cancel_type" property="cancelType" /> + <result column="name" property="name" /> + <result column="phone" property="phone" /> + <result column="address" property="address" /> + <result column="longitude" property="longitude" /> + <result column="latitude" property="latitude" /> + <result column="order_type" property="orderType" /> + <result column="comment_state" property="commentState" /> + <result column="delivery_state" property="deliveryState" /> + <result column="carriage" property="carriage" /> + <result column="take_code" property="takeCode" /> + <result column="remark" property="remark" /> + <result column="del_flag" property="delFlag" /> + <result column="is_home" property="isHome" /> + </resultMap> + + <select id="selectNewApiLeaderOrderListInPage" resultMap="NewOrderInfoMap"> + select + a.* + from mall_order_info a + inner join mall_member c on a.take_unique_code=c.invite_id + <where> + c.id=#{record.memberId} + <if test="record.status == 4 and record.status != 0"> + and a.status = 4 + </if> + <if test="record.status != 4 and record.status != 1 and record.status != 0 and record.status != 5"> + and a.status = #{record.status} + </if> + <if test="record.status == 5"> + and (a.status = 6 or b.state = 2) + </if> + <if test="record.status == 1"> + and a.status = 2 + </if> + <if test="record.status == 0"> + and a.status in (2,3,4,5,6) + </if> + <if test="record.query != null and record.query != ''"> + and ( a.name like CONCAT('%', CONCAT(#{record.query}, '%')) + or a.phone like CONCAT('%', CONCAT(#{record.query}, '%')) + or a.take_code like CONCAT('%', CONCAT(#{record.query}, '%')) + ) + </if> + <if test="record.orderType != null"> + and a.order_type=#{record.orderType} + </if> + and a.delivery_type = 1 </where> order by a.created_time desc </select> @@ -139,14 +212,14 @@ select a.* from mall_team_leader a - where a.state = 1 + where a.state = 1 and a.online_state = 1 </select> <select id="selectLeaderByUniqueCode" resultType="cc.mrbird.febs.mall.entity.MallTeamLeader"> select a.* from mall_team_leader a - where a.unique_code = #{uniqueCode} limit 1 + where a.unique_code = #{uniqueCode} and a.state = 1 limit 1 </select> <select id="selectLeaderByLonAndLat" resultType="cc.mrbird.febs.mall.entity.MallTeamLeader"> @@ -162,8 +235,47 @@ ) * 1000 ) AS distance from mall_team_leader a - where a.state = 1 + where a.state = 1 and a.online_state = 1 order by distance ASC limit 1 </select> + <select id="selectleaderGoodsStockListInPage" resultType="cc.mrbird.febs.mall.entity.MallLeaderStock"> + select a.* from mall_leader_stock a + where a.team_leader_id = #{record.teamLeaderId} + </select> + + <select id="selectLeaderByUniqueCodeAndOrderBycreateTime" resultType="cc.mrbird.febs.mall.entity.MallTeamLeader"> + select + a.* + from mall_team_leader a + where a.unique_code = #{uniqueCode} + order by a.CREATED_TIME desc + limit 1 + </select> + + <select id="selectByFenceIdAndFenceNameAndLonAndLat" resultType="cc.mrbird.febs.mall.entity.MallTeamLeader"> + select + a.*, + ROUND( + 6378.138 * 2 * ASIN( + SQRT( + POW(SIN((#{latitude} * PI() / 180 - a.latitude * PI() / 180) / 2),2) + + COS(40.0497810000 * PI() / 180) * COS(a.latitude * PI() / 180) + * POW(SIN((#{longitude} * PI() / 180 - a.longitude * PI() / 180) / 2),2) + ) + ) * 1000 + ) AS distance + from mall_team_leader a + inner join mall_electronic_fence b on b.team_leader_code = a.unique_code + where b.gid = #{fenceId} + and b.fence_name = #{fenceName} + </select> + + <select id="getAllMallTeamLeaderList" resultType="cc.mrbird.febs.mall.entity.MallTeamLeader"> + select + a.* + from mall_team_leader a + where a.state = 1 + </select> + </mapper> \ No newline at end of file -- Gitblit v1.9.1