getCourses($relations); foreach ($relations as $key => $value) { $relations[$key]['course'] = $courses[$value['course_id']] ?? new \stdClass(); } return $relations; } public function handleUsers($relations) { $users = $this->getUsers($relations); foreach ($relations as $key => $value) { $relations[$key]['user'] = $users[$value['user_id']] ?? new \stdClass(); } return $relations; } public function getCourses($relations) { $ids = kg_array_column($relations, 'course_id'); $courseRepo = new CourseRepo(); $columns = [ 'id', 'title', 'cover', 'market_price', 'vip_price', 'rating', 'model', 'level', 'attrs', 'user_count', 'lesson_count', 'review_count', 'favorite_count', ]; $courses = $courseRepo->findByIds($ids, $columns); $baseUrl = kg_ci_base_url(); $result = []; foreach ($courses->toArray() as $course) { $course['cover'] = $baseUrl . $course['cover']; $course['attrs'] = json_decode($course['attrs'], true); $result[$course['id']] = $course; } return $result; } public function getUsers($relations) { $ids = kg_array_column($relations, 'user_id'); $userRepo = new UserRepo(); $users = $userRepo->findByIds($ids, ['id', 'name', 'avatar']); $baseUrl = kg_ci_base_url(); $result = []; foreach ($users->toArray() as $user) { $user['avatar'] = $baseUrl . $user['avatar']; $result[$user['id']] = $user; } return $result; } }