You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
63 lines
1.5 KiB
63 lines
1.5 KiB
![]()
10 years ago
|
<?php
|
||
|
/* For licensing terms, see /license.txt */
|
||
![]()
9 years ago
|
|
||
![]()
7 years ago
|
namespace Chamilo\CoreBundle\Repository;
|
||
![]()
10 years ago
|
|
||
![]()
9 years ago
|
use Chamilo\CoreBundle\Entity\Course;
|
||
|
use Chamilo\CoreBundle\Entity\Session;
|
||
![]()
8 years ago
|
use Chamilo\CoreBundle\Entity\Skill;
|
||
|
use Chamilo\UserBundle\Entity\User;
|
||
|
use Doctrine\ORM\EntityRepository;
|
||
![]()
9 years ago
|
use Doctrine\ORM\Query\Expr\Join;
|
||
![]()
10 years ago
|
|
||
|
/**
|
||
![]()
8 years ago
|
* SkillRepository class.
|
||
![]()
10 years ago
|
*
|
||
|
* @author Angel Fernando Quiroz Campos <angel.quiroz@beeznest.com>
|
||
|
*/
|
||
![]()
9 years ago
|
class SkillRepository extends EntityRepository
|
||
|
{
|
||
![]()
10 years ago
|
/**
|
||
![]()
8 years ago
|
* Get the last acquired skill by a user on course and/or session.
|
||
|
*
|
||
|
* @param User $user The user
|
||
|
* @param Course $course The course
|
||
![]()
10 years ago
|
* @param Session $session The session
|
||
![]()
9 years ago
|
*
|
||
![]()
10 years ago
|
* @return Skill
|
||
|
*/
|
||
|
public function getLastByUser(User $user, Course $course = null, Session $session = null)
|
||
|
{
|
||
|
$qb = $this->createQueryBuilder('s');
|
||
|
|
||
![]()
9 years ago
|
$qb
|
||
|
->innerJoin(
|
||
|
'ChamiloCoreBundle:SkillRelUser',
|
||
|
'su',
|
||
|
Join::WITH,
|
||
|
's.id = su.skill'
|
||
|
)
|
||
|
->where(
|
||
|
$qb->expr()->eq('su.user', $user->getId())
|
||
|
);
|
||
![]()
10 years ago
|
|
||
|
if ($course) {
|
||
|
$qb->andWhere(
|
||
![]()
9 years ago
|
$qb->expr()->eq('su.course', $course->getId())
|
||
![]()
10 years ago
|
);
|
||
|
}
|
||
|
|
||
|
if ($session) {
|
||
|
$qb->andWhere(
|
||
![]()
9 years ago
|
$qb->expr()->eq('su.session', $session->getId())
|
||
![]()
10 years ago
|
);
|
||
|
}
|
||
|
|
||
![]()
9 years ago
|
$qb
|
||
|
->setMaxResults(1)
|
||
![]()
10 years ago
|
->orderBy('su.id', 'DESC');
|
||
|
|
||
|
return $qb->getQuery()->getOneOrNullResult();
|
||
|
}
|
||
|
}
|