<?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="com.ycwl.basic.mapper.OrderMapper">
    <resultMap id="PCBaseResultMap" type="com.ycwl.basic.model.pc.order.resp.OrderRespVO">
        <id column="id" property="id"/>
        <result column="scenic_id" property="scenicId"/>
        <result column="scenic_name" property="scenicName"/>
        <result column="member_id" property="memberId"/>
        <result column="nickname" property="memberNickname"/>
        <result column="real_name" property="memberRealName"/>
        <result column="openid" property="openId"/>
        <result column="price" property="price"/>
        <result column="pay_price" property="payPrice"/>
        <result column="remark" property="remark"/>
        <result column="broker_id" property="brokerId"/>
        <result column="promo_code" property="promoCode"/>
        <result column="refund_reason" property="refundReason"/>
        <result column="refund_status" property="refundStatus"/>
        <result column="status" property="status"/>
        <result column="refund_at" property="refundAt"/>
        <result column="pay_at" property="payAt"/>
        <result column="cancel_at" property="cancelAt"/>
        <result column="create_at" property="createAt"/>
        <result column="update_at" property="updateAt"/>
        <collection property="orderItemList" select="getOrderItemList" column="id" ofType="com.ycwl.basic.model.pc.order.resp.OrderItemVO">
            <result column="oiId" property="id"/>
            <result column="orderId" property="orderId"/>
            <result column="goods_id" property="goodsId"/>
            <result column="scenicName" property="scenicName"/>
            <result column="goodsName" property="goodsName"/>
            <result column="videoUrl" property="videoUrl"/>
            <result column="imgUrl" property="imgUrl"/>
            <result column="sourceType" property="sourceType"/>
            <result column="createTime" property="createTime"/>
        </collection>
    </resultMap>
    <resultMap id="AppBaseResultMap" type="com.ycwl.basic.model.pc.order.resp.OrderAppRespVO">
        <id column="id" property="id"/>
        <result column="price" property="price"/>
        <result column="pay_price" property="payPrice"/>
        <result column="remark" property="remark"/>
        <result column="refund_reason" property="refundReason"/>
        <result column="refund_status" property="refundStatus"/>
        <result column="status" property="status"/>
        <result column="refund_at" property="refundAt"/>
        <result column="pay_at" property="payAt"/>
        <result column="cancel_at" property="cancelAt"/>
        <result column="create_at" property="createAt"/>
        <result column="update_at" property="updateAt"/>
        <result column="scenic_id" property="scenicId"/>
        <result column="scenicName" property="scenicName"/>
        <collection property="orderItemList" select="getOrderItemList" column="id" ofType="com.ycwl.basic.model.pc.order.resp.OrderItemVO">
            <result column="oiId" property="id"/>
            <result column="orderId" property="orderId"/>
            <result column="goods_id" property="goodsId"/>
            <result column="face_id" property="faceId"/>
            <result column="scenic_name" property="scenicName"/>
            <result column="goods_name" property="goodsName"/>
            <result column="videoUrl" property="videoUrl"/>
            <result column="coverUrl" property="coverUrl"/>
            <result column="imgUrl" property="imgUrl"/>
        </collection>
    </resultMap>
    <select id="getOrderItemList" parameterType="java.lang.Long" resultType="com.ycwl.basic.model.pc.order.resp.OrderItemVO">
        WITH member_video_data AS (
            SELECT mv.member_id, mv.video_id, t.cover_url, t.name, mv.face_id, v.video_url
            FROM member_video mv
                     LEFT JOIN template t ON mv.template_id = t.id
                     LEFT JOIN video v ON mv.video_id = v.id
        ),
             member_source_data AS (
                 SELECT ms.member_id, ms.source_id, ms.face_id, s.video_url, s.url
                 FROM member_source ms
                          LEFT JOIN source s ON ms.source_id = s.id
             )
        SELECT
            oi.id AS oiId,
            oi.order_id AS orderId,
            oi.goods_id,
            sc.id AS scenic_id,
            sc.name AS scenic_name,
            CASE oi.goods_type
                WHEN '0' THEN mvd.cover_url
                END AS coverUrl,
            oi.goods_type,
            CASE oi.goods_type
                WHEN '0' THEN mvd.name
                WHEN '1' THEN '原片包'
                WHEN '2' THEN '照片包'
                ELSE '其他'
                END AS goods_name,
            CASE oi.goods_type
                WHEN '0' THEN mvd.face_id
                WHEN '1' THEN oi.goods_id
                WHEN '2' THEN oi.goods_id
                END AS face_id,
            CASE oi.goods_type
                WHEN '0' THEN mvd.video_url
                WHEN '1' THEN msd.video_url
                END AS videoUrl,
            CASE oi.goods_type
                WHEN '1' THEN msd.url
                WHEN '2' THEN msd.url
                END AS imgUrl
        FROM order_item oi
                 LEFT JOIN `order` o ON oi.order_id = o.id
                 LEFT JOIN scenic sc ON o.scenic_id = sc.id
                 LEFT JOIN member_video_data mvd ON o.member_id = mvd.member_id AND oi.goods_id = mvd.video_id
                 LEFT JOIN member_source_data msd ON o.member_id = msd.member_id AND oi.goods_id = msd.source_id
        WHERE oi.order_id = #{id};
    </select>

    <insert id="add">
        insert into `order`(id, member_id, openid, slash_price, price, pay_price, remark, broker_id, promo_code, scenic_id, status)
        VALUES (#{id}, #{memberId}, #{openId}, #{slashPrice}, #{price}, #{payPrice}, #{remark}, #{brokerId}, #{promoCode}, #{scenicId}, #{status})
    </insert>
    <insert id="addOrderItems">
        insert into order_item(order_id,goods_type, goods_id) VALUES
        <foreach collection="orderItems" item="item" index="index" separator=",">
            (#{item.orderId}, #{item.goodsType},#{item.goodsId})
        </foreach>
    </insert>
    <update id="update">
        update `order`
        <set>
            <if test="price!= null ">
                price = #{price},
            </if>
            <if test="payPrice!= null ">
                pay_price = #{payPrice},
            </if>
            <if test="remark!= null and remark!= ''">
                remark = #{remark},
            </if>
            <if test="refundReason!= null and refundReason!= ''">
                refund_reason = #{refundReason},
            </if>
            <if test="refundStatus!= null ">
                refund_status = #{refundStatus},
            </if>
            <if test="status!= null ">
                `status` = #{status},
            </if>
            <if test="refundAt!= null ">
                refund_at = #{refundAt},
            </if>
            <if test="payAt!= null ">
                pay_at = #{payAt},
            </if>
            <if test="cancelAt!= null ">
                cancel_at = #{cancelAt},
            </if>
        </set>
        where id = #{id}
    </update>
    <delete id="deleteById">
        delete from `order` where id = #{id}
    </delete>
    <select id="list" resultMap="PCBaseResultMap">
        select distinct o.id, o.scenic_id, s.name as scenic_name, o.member_id,m.nickname ,m.real_name , o.openid, o.price, pay_price, remark, o.broker_id, o.promo_code,
               refund_reason, refund_status, o.`status`, refund_at, pay_at, cancel_at,oi.id oiId, oi.goods_id, o.create_at
        from `order`  AS o
        left join member m on o.member_id = m.id
        left join scenic s on o.scenic_id = s.id
        left join order_item oi on o.id = oi.order_id
        <where>
            <if test="id!= null ">
                and o.id = #{id}
            </if>
            <if test="scenicId != null">
                and o.scenic_id = #{scenicId}
            </if>
            <if test="memberNickname!= null and memberNickname!=''">
                and m.nickname like concat('%',#{memberNickname},'%')
            </if>
            <if test="memberRealName!= null and memberRealName!=''">
                and m.real_name like concat('%',#{memberRealName},'%')
            </if>
            <if test="price!= null ">
                and o.price = #{price}
            </if>
            <if test="payPrice!= null ">
                and pay_price = #{payPrice}
            </if>
            <if test="remark!= null and remark!= ''">
                and remark like concat('%',#{remark},'%')
            </if>
            <if test="brokerId!= null ">
                and o.broker_id = #{brokerId}
            </if>
            <if test="promoCode!= null and promoCode!= ''">
                and o.promo_code like concat('%',#{promoCode},'%')
            </if>
            <if test="refundReason!= null and refundReason!= ''">
                and refund_reason like concat('%',#{refundReason},'%')
            </if>
            <if test="refundStatus!= null ">
                and refund_status = #{refundStatus}
            </if>
            <if test="status!= null ">
                and o.`status` = #{status}
            </if>
            <if test="startCreateTime!= null ">
                and o.create_at >= #{startCreateTime}
            </if>
            <if test="endCreateTime!= null ">
                and o.create_at &lt;= #{endCreateTime}
            </if>
            <if test="startPayTime!= null ">
                and pay_at &gt;= #{startPayTime}
            </if>
            <if test="endPayTime!= null ">
                and pay_at &lt;= #{endPayTime}
            </if>
            <if test="startRefundTime!= null ">
                and refund_at &gt;= #{startRefundTime}
            </if>
            <if test="endRefundTime!= null ">
                and refund_at &lt;= #{endRefundTime}
            </if>
            <if test="startCancelTime!= null ">
                and cancel_at &gt;= #{startCancelTime}
            </if>
            <if test="endCancelTime!= null ">
                and cancel_at &lt;= #{endCancelTime}
            </if>
        </where>
        order by o.create_at desc
    </select>
    <select id="getById" resultMap="PCBaseResultMap">
        select o.id, o.scenic_id, s.name as scenic_name, o.member_id, o.openid, o.price, o.pay_price, o.remark, o.broker_id, o.promo_code, o.refund_reason,
               o.refund_status, o.status, o.create_at, o.update_at, o.pay_at, o.cancel_at, o.refund_at,
               m.nickname , m.real_name
            from `order` o
        left join member m on m.id = o.member_id
        left join scenic s on o.scenic_id = s.id
        where o.id = #{id}
    </select>
    <select id="countByUserId" resultType="java.lang.Integer">
        select count(1) num
        from `order` o
        where o.member_id = #{userId}
    </select>
    <select id="appList" resultMap="AppBaseResultMap">
        select DISTINCT  o.id, o.member_id,o.openid, o.price, pay_price, remark, o.broker_id, o.promo_code,
        refund_reason, refund_status, o.`status`, o.create_at, refund_at, pay_at, cancel_at,
        sc.name scenicName
        from `order` AS o
        left join scenic sc on o.scenic_id = sc.id
        <where>
            <if test="memberId!=null">
                and o.member_id=#{memberId}
            </if>
        </where>
        order by o.create_at desc
    </select>
    <select id="appDetail" resultMap="AppBaseResultMap">
        select distinct o.id, o.member_id,o.openid, o.price, pay_price, remark, o.broker_id, o.promo_code,
                        refund_reason, refund_status, o.`status`, o.create_at, refund_at, pay_at, cancel_at,
                        o.scenic_id, sc.name scenicName
        from `order`  AS o
                 left join member m on o.member_id = m.id
                 left join scenic sc on o.scenic_id = sc.id
        where o.id = #{id}
    </select>
    <select id="refundList" resultType="com.ycwl.basic.model.pc.order.resp.OrderRespVO">
        select distinct o.id, o.scenic_id, s.name as scenic_name, o.member_id,m.nickname ,m.real_name , o.openid, o.price, pay_price, remark, o.broker_id, o.promo_code,
        refund_reason, refund_status, o.`status`, refund_at, pay_at, cancel_at,oi.id oiId, oi.goods_id, o.create_at
        from `order`  AS o
        left join member m on o.member_id = m.id
        left join scenic s on o.scenic_id = s.id
        left join order_item oi on o.id = oi.order_id
        <where>
            o.refund_status != 0
            <if test="id!= null ">
                and o.id = #{id}
            </if>
            <if test="scenicId != null">
                and o.scenic_id = #{scenicId}
            </if>
            <if test="memberNickname!= null and memberNickname!=''">
                and m.nickname like concat('%',#{memberNickname},'%')
            </if>
            <if test="memberRealName!= null and memberRealName!=''">
                and m.real_name like concat('%',#{memberRealName},'%')
            </if>
            <if test="price!= null ">
                and o.price = #{price}
            </if>
            <if test="payPrice!= null ">
                and pay_price = #{payPrice}
            </if>
            <if test="remark!= null and remark!= ''">
                and remark like concat('%',#{remark},'%')
            </if>
            <if test="brokerId!= null ">
                and o.broker_id = #{brokerId}
            </if>
            <if test="promoCode!= null and promoCode!= ''">
                and o.promo_code like concat('%',#{promoCode},'%')
            </if>
            <if test="refundReason!= null and refundReason!= ''">
                and refund_reason like concat('%',#{refundReason},'%')
            </if>
            <if test="status!= null ">
                and o.`status` = #{status}
            </if>
            <if test="startCreateTime!= null ">
                and o.create_at >= #{startCreateTime}
            </if>
            <if test="endCreateTime!= null ">
                and o.create_at &lt;= #{endCreateTime}
            </if>
            <if test="startPayTime!= null ">
                and pay_at &gt;= #{startPayTime}
            </if>
            <if test="endPayTime!= null ">
                and pay_at &lt;= #{endPayTime}
            </if>
            <if test="startRefundTime!= null ">
                and refund_at &gt;= #{startRefundTime}
            </if>
            <if test="endRefundTime!= null ">
                and refund_at &lt;= #{endRefundTime}
            </if>
            <if test="startCancelTime!= null ">
                and cancel_at &gt;= #{startCancelTime}
            </if>
            <if test="endCancelTime!= null ">
                and cancel_at &lt;= #{endCancelTime}
            </if>
        </where>
        order by o.create_at desc
    </select>
    <select id="listOrderItemByOrderId" resultType="com.ycwl.basic.model.pc.order.entity.OrderItemEntity">
        select * from order_item where order_id = #{orderId}
    </select>
    <select id="getUserBuyItem" resultType="com.ycwl.basic.model.pc.order.entity.OrderEntity">
        select o.*
        from order_item oi
        left join `order` o on o.id = oi.order_id
        where o.member_id = #{userId}
          and oi.goods_id = #{goodsId}
          and oi.goods_type = #{goodsType}
          and o.status = 1
        limit 1
    </select>
</mapper>