1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
<?php
 
namespace app\api\model\plus\operations;
 
use app\api\model\plus\operations\Operations as OperationsModel;
use app\common\enum\order\OrderTypeEnum;
use app\common\model\plus\operations\Order as OrderModel;
use app\common\service\order\OrderService;
 
/**
 * 运营中心订单模型
 */
class Order extends OrderModel
{
    /**
     * 隐藏字段
     */
    protected $hidden = [
        'update_time',
    ];
 
    /**
     * 获取运营中心订单列表
     */
    public function getList($user_id, $is_settled = -1)
    {
        $model = $this;
        $is_settled > -1 && $model = $model->where('is_settled', '=', !!$is_settled);
        $data = $model->with(['user'])
            ->where('first_user_id|second_user_id|third_user_id', '=', $user_id)
            ->order(['create_time' => 'desc'])
            ->paginate(15);
        if ($data->isEmpty()) {
            return $data;
        }
        // 整理订单信息
        $with = ['product' => ['image', 'refund'], 'address', 'user'];
        return OrderService::getOrderList($data, 'order_master', $with);
    }
    /**
     * 创建运营中心订单
     */
    public static function createOrder( $order, $order_type = OrderTypeEnum::MASTER)
    {
        $model = new self;
 
        $setting = Setting::getItem('basic', $order['app_id']);
        if (!$setting['is_open']) {
            return false;
        }
        $operations=OperationsModel::getOrderOperations($order);
        if ($operations['province_user_id']==0 && $operations['city_user_id']==0 && $operations['area_user_id']==0){
            return false;
        }
        // 计算订单分销佣金
        $capital = $model->getCapitalByOrder($order, 'create',$operations);
        // 如果没有佣金,则不写入订单
        if(!$capital['is_record']){
            return false;
        }
        // 保存分销订单记录
        return $model->save([
            'user_id' => $order['user_id'],
            'order_id' => $order['order_id'],
            'order_type' => $order_type,
            'order_price' => $capital['orderPrice'],
            'first_money' => $operations['province_user_id'] > 0?max($capital['first_money'], 0):0,
            'second_money' => $operations['city_user_id'] > 0?max($capital['second_money'], 0):0,
            'third_money' => $operations['area_user_id'] > 0?max($capital['third_money'], 0):0,
            'first_user_id' => $capital['first_money']>0?$operations['province_user_id']:0,
            'second_user_id' => $capital['second_money']>0?$operations['city_user_id']:0,
            'third_user_id' => $capital['third_money']>0?$operations['area_user_id']:0,
            'is_settled' => 0,
            'shop_supplier_id' => $order['shop_supplier_id'],
            'app_id' => $order['app_id']
        ]);
    }
 
}