quanwei
18 hours ago c441dea81bd86bdfb12dff35821fed51f4cc91c2
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
<?php
 
namespace app\operations\model\plus\bargain;
 
use app\common\enum\order\OrderSourceEnum;
use app\common\model\plus\bargain\Task as TaskModel;
use app\common\model\plus\bargain\Active as ActiveModel;
use app\operations\model\order\Order as OrderModel;
use app\operations\model\plus\bargain\Product as BargainProductModel;
 
/**
 * 砍价模型
 */
class Active extends ActiveModel
{
    /**
     *列表
     */
    public function getList($param)
    {
        $model = $this;
        //检索活动名称
        if (isset($param['search']) && $param['search']) {
            $model = $model->where('title', 'like', '%' . trim($param['search']) . '%');
        }
        $list = $model->with(['file'])
            ->order(['sort' => 'asc', 'create_time' => 'desc'])
            ->where('is_delete', '=', 0)
            ->paginate($param);
        foreach ($list as $active) {
            //商品数
            $product_model = new BargainProductModel();
            $active['product_num'] = $product_model
                ->where('bargain_activity_id', '=', $active['bargain_activity_id'])
                ->where('status', '=', 10)
                ->count();
            $active['product_audit_num'] = $product_model
                ->where('bargain_activity_id', '=', $active['bargain_activity_id'])
                ->where('status', '=', 0)
                ->count();
            //订单数
            $active['total_sales'] = $product_model->where('bargain_activity_id', '=', $active['bargain_activity_id'])->sum('total_sales');
        }
        return $list;
    }
 
    /**
     * 添加
     * @param $data
     */
    public function add($data)
    {
        $this->startTrans();
        try {
            $arr = $this->setData($data);
            $this->save($arr);
            // 事务提交
            $this->commit();
            return true;
        } catch (\Exception $e) {
            $this->error = $e->getMessage();
            $this->rollback();
            return false;
        }
    }
 
    /**
     * 修改
     */
    public function edit($data)
    {
        $this->startTrans();
        try {
            $arr = $this->setData($data);
            $this->save($arr);
            // 事务提交
            $this->commit();
            return true;
        } catch (\Exception $e) {
            $this->error = $e->getMessage();
            $this->rollback();
            return false;
        }
    }
 
    /**
     *删除
     */
    public function del()
    {
        //如果有正在拼团的商品
        $count = (new TaskModel())->whereRaw('(status = 0) OR (status = 1 and is_buy = 0)')
            ->where('bargain_activity_id', '=', $this['bargain_activity_id'])
            ->where('is_delete', '=', 0)
            ->count();
        if($count > 0){
            $this->error = '该活动下有正在砍价的订单';
            return false;
        }
        // 如果有未付款订单不能删除
        $count = (new OrderModel())->where('pay_status', '=', 10)
            ->where('order_source', '=', OrderSourceEnum::BARGAIN)
            ->where('activity_id', '=', $this['bargain_activity_id'])
            ->where('is_delete', '=', 0)
            ->count();
        if($count > 0){
            $this->error = '该活动下有未付款的订单';
            return false;
        }
        return $this->save([
            'is_delete' => 1
        ]);
    }
 
 
 
    /**
     * 修改信息
     * @param $data
     */
    public function editBargain($param)
    {
        $data = array(
            'name' => $param['name'],
            'start_time' => $param['start_time']['value'],
            'end_time' => $param['end_time']['value'],
            'image_id' => $param['image_id'],
            'conditions' => $param['conditions'],
            'status' => $param['status']['value'],
            'sort' => $param['sort'],
        );
        $this->where('bargain_id', '=', $param['bargain_id'])->save($data);
        return true;
    }
 
 
    /**
     * 验证并组装数据
     * @param $data array  添加/新增数据
     * @return array
     */
    private function setData($data)
    {
        $data['active_time'][0] = substr($data['active_time'][0],0, 16);
        $data['active_time'][1] = substr($data['active_time'][1],0, 16);
        $arr = [
            'image_id' => $data['image_id'],
            'title' => $data['title'],
            'start_time' => strtotime($data['active_time'][0] . ':00'),
            'end_time' => strtotime($data['active_time'][1]. ':59'),
            'join_end_time' => strtotime($data['join_end_time']),
            'conditions' => $data['conditions'],
            'together_time' => $data['together_time'],
            'status' => $data['status'],
            'sort' => $data['sort'],
            'app_id' => self::$app_id,
        ];
        return $arr;
    }
}