|
|
|
<?php
|
|
|
|
// +----------------------------------------------------------------------
|
|
|
|
// | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
|
|
|
|
// +----------------------------------------------------------------------
|
|
|
|
// | Copyright (c) 2017~2023 https://www.yiovo.com All rights reserved.
|
|
|
|
// +----------------------------------------------------------------------
|
|
|
|
// | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
|
|
|
|
// +----------------------------------------------------------------------
|
|
|
|
// | Author: 萤火科技 <admin@yiovo.com>
|
|
|
|
// +----------------------------------------------------------------------
|
|
|
|
declare (strict_types=1);
|
|
|
|
|
|
|
|
namespace app\timer\model\dealer;
|
|
|
|
|
|
|
|
use app\common\enum\order\OrderStatus as OrderStatusEnum;
|
|
|
|
use app\common\model\dealer\Order as OrderModel;
|
|
|
|
use app\timer\model\dealer\Setting as DealerSettingModel;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 分销商订单模型
|
|
|
|
* Class Apply
|
|
|
|
* @package app\timer\model\dealer
|
|
|
|
*/
|
|
|
|
class Order extends OrderModel
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* 获取未结算的分销订单
|
|
|
|
* @param int $storeId
|
|
|
|
* @return mixed
|
|
|
|
* @throws \think\db\exception\DataNotFoundException
|
|
|
|
* @throws \think\db\exception\DbException
|
|
|
|
* @throws \think\db\exception\ModelNotFoundException
|
|
|
|
*/
|
|
|
|
public function getUnSettledList(int $storeId)
|
|
|
|
{
|
|
|
|
// 可结算的订单条件
|
|
|
|
$filter = [
|
|
|
|
['order.is_delete', '=', 0],
|
|
|
|
['order.order_status', '=', OrderStatusEnum::COMPLETED]
|
|
|
|
];
|
|
|
|
// 佣金结算天数
|
|
|
|
$filter[] = ['order.receipt_time', '<=', DealerSettingModel::getSettleTerm($storeId)];
|
|
|
|
// 获取订单列表记录
|
|
|
|
return $this->alias('m')
|
|
|
|
->field(['m.*'])
|
|
|
|
->with(['order' => ['goods' => ['refund']]])
|
|
|
|
->join('order', 'm.order_id = order.order_id')
|
|
|
|
->where($filter)
|
|
|
|
->where('m.is_invalid', '=', 0)
|
|
|
|
->where('m.is_settled', '=', 0)
|
|
|
|
->where('m.store_id', '=', $storeId)
|
|
|
|
->select();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 获取失效的分销订单ID集
|
|
|
|
* @param int $storeId
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getInvalidOrderIds(int $storeId)
|
|
|
|
{
|
|
|
|
// 失效订单条件
|
|
|
|
$filter = [
|
|
|
|
['order.is_delete', '=', 1],
|
|
|
|
['order.order_status', '=', OrderStatusEnum::CANCELLED]
|
|
|
|
];
|
|
|
|
return $this->alias('m')
|
|
|
|
->join('order', 'm.order_id = order.order_id')
|
|
|
|
->whereOr($filter)
|
|
|
|
->where('m.is_invalid', '=', 0)
|
|
|
|
->where('m.is_settled', '=', 0)
|
|
|
|
->where('m.store_id', '=', $storeId)
|
|
|
|
->column('m.order_id');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 标记订单已失效(批量)
|
|
|
|
* @param array $orderIds
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function setInvalid(array $orderIds)
|
|
|
|
{
|
|
|
|
return static::updateBase(['is_invalid' => 1], [['order_id', 'in', $orderIds]]);
|
|
|
|
}
|
|
|
|
}
|