Order.php 1.55 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14
<?php

namespace yiiunit\data\ar\elasticsearch;

/**
 * Class Order
 *
 * @property integer $id
 * @property integer $customer_id
 * @property integer $create_time
 * @property string $total
 */
class Order extends ActiveRecord
{
15
	public function attributes()
16
	{
17
		return ['customer_id', 'create_time', 'total'];
18 19 20 21
	}

	public function getCustomer()
	{
22
		return $this->hasOne(Customer::className(), [ActiveRecord::PRIMARY_KEY_NAME => 'customer_id']);
23 24 25 26
	}

	public function getOrderItems()
	{
27
		return $this->hasMany(OrderItem::className(), ['order_id' => ActiveRecord::PRIMARY_KEY_NAME]);
28 29 30 31
	}

	public function getItems()
	{
32
		return $this->hasMany(Item::className(), [ActiveRecord::PRIMARY_KEY_NAME => 'item_id'])
33
			->via('orderItems')->orderBy('id');
34 35
	}

36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
	public function getItemsInOrder1()
	{
		return $this->hasMany(Item::className(), ['id' => 'item_id'])
			->via('orderItems', function ($q) {
				$q->orderBy(['subtotal' => SORT_ASC]);
			})->orderBy('name');
	}

	public function getItemsInOrder2()
	{
		return $this->hasMany(Item::className(), ['id' => 'item_id'])
			->via('orderItems', function ($q) {
				$q->orderBy(['subtotal' => SORT_DESC]);
			})->orderBy('name');
	}

52 53
//	public function getBooks()
//	{
54 55
//		return $this->hasMany('Item', [ActiveRecord::PRIMARY_KEY_NAME => 'item_id'])
//			->viaTable('tbl_order_item', ['order_id' => ActiveRecord::PRIMARY_KEY_NAME])
56 57
//			->where(['category_id' => 1]);
//	}
58 59 60 61

	public function beforeSave($insert)
	{
		if (parent::beforeSave($insert)) {
62
//			$this->create_time = time();
63 64 65 66 67 68
			return true;
		} else {
			return false;
		}
	}
}