'=', 'created_at' => 'like', ]; public function model() { return Model::class; } /** * 数据格式化 * * @param mixed $result * * @return mixed */ public function transform($model) { return $model->toArray(); } /** * 查询条件 * * @return void */ public function withConditions(array $conditions = []) { $this->model = $this->model->where(function ($query) use ($conditions) { if (isset($conditions['id'])) { $conditions['id'] = array_wrap($conditions['id']); $query->whereIn('id', $conditions['id']); } if (isset($conditions['type'])) { $conditions['type'] = array_wrap($conditions['type']); $query->whereIn('type', $conditions['type']); } if (isset($conditions['company_id'])) { $conditions['company_id'] = array_wrap($conditions['company_id']); $query->whereIn('company_id', $conditions['company_id']); } if (!empty($conditions['sn'])) { $query->where('sn', "%{$conditions['sn']}%"); } if (isset($conditions['transaction_no'])) { $query->where('transaction_no', $conditions['transaction_no']); } if (isset($conditions['carrier_operator'])) { $query->whereHas('package', function ($relation) use ($conditions) { $relation->withTrashed()->where('carrier_operator', $conditions['carrier_operator']); }); } if (isset($conditions['pay_channel'])) { $query->where('pay_channel', $conditions['pay_channel']); } if (!empty($conditions['company_name'])) { $query->whereHas('company', function ($relation) use ($conditions) { $relation->withTrashed()->where('name', $conditions['company_name']); }); } if (!empty($conditions['package_name'])) { $query->whereHas('package', function ($relation) use ($conditions) { $relation->withTrashed()->where('name', $conditions['package_name']); }); } if (isset($conditions['starttime'])) { $query->where('order_at', '>=', Carbon::parse($conditions['starttime'])); } if (isset($conditions['endtime'])) { $query->where('order_at', '<=', Carbon::parse($conditions['endtime'])); } if (isset($conditions['used'])) { $operator = $conditions['used'] ? '>' : '='; $query->whereHas('cards', function ($relation) use ($conditions) { $relation->withoutTrashed()->where('type', $conditions['type'])->where('virtual_order_id', '<>', 0); }, $operator, 0); } }); return $this; } }