mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-28 09:29:38 +00:00
120 lines
3.5 KiB
PHP
120 lines
3.5 KiB
PHP
<?php
|
|
class Projektarbeit_model extends DB_Model
|
|
{
|
|
|
|
/**
|
|
* Constructor
|
|
*/
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
$this->dbTable = 'lehre.tbl_projektarbeit';
|
|
$this->pk = 'projektarbeit_id';
|
|
|
|
$this->load->model('education/Projektarbeit_model', 'ProjektarbeitModel');
|
|
}
|
|
|
|
/**
|
|
* Gets Projektarbeit(en) of a student for a Studiengang, Semester, Projekttyp, final.
|
|
* @param $student_uid
|
|
* @param $studiengang_kz
|
|
* @param $studiensemester_kurzbz
|
|
* @param $projekttyp
|
|
* @param $final
|
|
* @return object
|
|
*/
|
|
public function getProjektarbeit($student_uid, $studiengang_kz = null, $studiensemester_kurzbz = null, $projekttyp = null, $final = null)
|
|
{
|
|
$qry = "SELECT
|
|
tbl_projektarbeit.* , tbl_projekttyp.bezeichnung
|
|
FROM
|
|
lehre.tbl_projektarbeit
|
|
JOIN
|
|
lehre.tbl_projekttyp USING (projekttyp_kurzbz), lehre.tbl_lehreinheit, lehre.tbl_lehrveranstaltung
|
|
|
|
WHERE
|
|
tbl_projektarbeit.lehreinheit_id=tbl_lehreinheit.lehreinheit_id AND
|
|
tbl_lehreinheit.lehrveranstaltung_id = tbl_lehrveranstaltung.lehrveranstaltung_id AND
|
|
tbl_projektarbeit.student_uid = ?";
|
|
|
|
$params = array($student_uid);
|
|
|
|
if (isset($studiengang_kz))
|
|
{
|
|
$qry .= ' AND tbl_lehrveranstaltung.studiengang_kz=?';
|
|
$params[] = $studiengang_kz;
|
|
}
|
|
|
|
if (isset($studiensemester_kurzbz))
|
|
{
|
|
$qry .= ' AND tbl_lehreinheit.studiensemester_kurzbz=?';
|
|
$params[] = $studiensemester_kurzbz;
|
|
}
|
|
|
|
if (isset($projekttyp))
|
|
{
|
|
if (is_array($projekttyp))
|
|
$qry .= ' AND tbl_projektarbeit.projekttyp_kurzbz IN ?';
|
|
else
|
|
$qry .= ' AND tbl_projektarbeit.projekttyp_kurzbz=?';
|
|
|
|
$params[] = $projekttyp;
|
|
}
|
|
|
|
if (isset($final))
|
|
{
|
|
$qry .= ' AND tbl_projektarbeit.final=?';
|
|
$params[] = $final;
|
|
}
|
|
|
|
$qry .= ' ORDER BY beginn DESC, projektarbeit_id DESC';
|
|
|
|
return $this->execQuery($qry, $params);
|
|
}
|
|
|
|
/**
|
|
* Gets all Projektarbeiten not uploaded in Time
|
|
* @param String $startDate project works before this date will be ignored (in Dateformat: 'Y'-'m'-'d')
|
|
* @return object
|
|
*/
|
|
public function getAllProjektarbeitenNotUploadedInTime($startDate = null)
|
|
{
|
|
$allowedProjekttypes = ['Bachelor', 'Diplom'];
|
|
$now = new DateTime();
|
|
|
|
$this->db->distinct();
|
|
$this->addSelect($this->dbTable. '.projektarbeit_id');
|
|
$this->addSelect($this->dbTable. '.titel');
|
|
$this->addSelect($this->dbTable. '.student_uid');
|
|
$this->addSelect($this->dbTable. '.note');
|
|
$this->addSelect('p'. '.person_id');
|
|
$this->addSelect('p'. '.nachname');
|
|
$this->addSelect('p'. '.vorname');
|
|
$this->addSelect('le'. '.lehreinheit_id');
|
|
$this->addSelect('sg'. '.studiengang_kz');
|
|
|
|
$this->addJoin('campus.tbl_paabgabe pa', 'projektarbeit_id');
|
|
$this->addJoin('lehre.tbl_projektbetreuer pb', 'projektarbeit_id');
|
|
$this->addJoin('public.tbl_benutzer ben', 'ben.uid = tbl_projektarbeit.student_uid');
|
|
$this->addJoin('public.tbl_person p', 'p.person_id = ben.person_id', 'LEFT');
|
|
$this->addJoin('lehre.tbl_lehreinheit le', 'lehreinheit_id', 'LEFT');
|
|
$this->addJoin('lehre.tbl_lehrveranstaltung lv', 'lehrveranstaltung_id', 'LEFT');
|
|
$this->addJoin('public.tbl_studiengang sg', 'studiengang_kz', 'LEFT');
|
|
|
|
$this->db->where_in($this->dbTable. '.projekttyp_kurzbz', $allowedProjekttypes);
|
|
|
|
if($startDate)
|
|
$this->db->where('pa.datum >', $startDate);
|
|
|
|
$this->db->where($this->dbTable. '.note', null);
|
|
|
|
return $this->loadWhere([
|
|
'pa.fixtermin' => 'true',
|
|
'pa.paabgabetyp_kurzbz' => 'end',
|
|
'pa.abgabedatum' => null,
|
|
'pa.datum < ' => $now->format('c'),
|
|
'pb.betreuerart_kurzbz' => 'Erstbegutachter'
|
|
]);
|
|
}
|
|
}
|