request = $request; } public function apply($builder) { $this->queryBuilder = $builder; $filters = array_filter($this->request->only($this->filters), function ($item) { return $item !== null; }); foreach ($filters as $filter => $value) { if (method_exists($this, $filter)) { $this->$filter($value, $this->queryBuilder); } } return $this->queryBuilder; } public function created_at_start($created_at_start) { $this->queryBuilder->whereDate('created_at', '>=', $created_at_start); } public function created_at_end($created_at_end) { $this->queryBuilder->whereDate('created_at', '<=', $created_at_end); } //user_work_group public function apply_user($apply_user) { $user_ids = \App\User::query() ->select('id') ->where('name', 'like', $apply_user . '%') ->pluck('id'); $this->queryBuilder->whereIn('apply_user_id', $user_ids); } public function warehouse($warehouse) { $warehouse = array_filter(preg_split('/[,, ]+/is', $warehouse), function ($item) { return $item !== null; }); $this->queryBuilder->whereIn('warehouse_id', $warehouse); } public function status($status) { $status = array_filter(preg_split('/[,, ]+/is', $status), function ($item) { return $item !== null; }); $this->queryBuilder->whereIn('status', $status); } public function remark($remark) { $this->queryBuilder->where('remark', 'like', $remark . '%'); } public function user_work_group($user_work_group) { $user_work_group = array_filter(preg_split('/[,, ]+/is', $user_work_group), function ($item) { return $item !== null; }); $this->queryBuilder->whereIn('user_workgroup_id', $user_work_group); } }