mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 20:29:29 +00:00
391 lines
13 KiB
PHP
391 lines
13 KiB
PHP
<?php
|
|
|
|
$APP = '\'infocenter\'';
|
|
$REJECTED_STATUS = '\'Abgewiesener\'';
|
|
$INTERESSENT_STATUS = '\'Interessent\'';
|
|
$STUDIENGANG_TYP = '\'b\'';
|
|
$TAETIGKEIT_KURZBZ = '\'bewerbung\', \'kommunikation\'';
|
|
$LOGDATA_NAME = '\'Login with code\', \'Login with user\', \'New application\', \'Interessent rejected\'';
|
|
$LOGDATA_NAME_PARKED = '\'Parked\'';
|
|
$LOGTYPE_KURZBZ = '\'Processstate\'';
|
|
$STATUS_KURZBZ = '\'Wartender\', \'Bewerber\', \'Aufgenommener\', \'Student\'';
|
|
$ADDITIONAL_STG = '10021,10027';
|
|
$AKTE_TYP = '\'identity\', \'zgv_bakk\'';
|
|
$STUDIENSEMESTER = '\''.$this->variablelib->getVar('infocenter_studiensemester').'\'';
|
|
|
|
$query = '
|
|
SELECT
|
|
p.person_id AS "PersonId",
|
|
p.vorname AS "Vorname",
|
|
p.nachname AS "Nachname",
|
|
p.gebdatum AS "Gebdatum",
|
|
p.geschlecht AS "Geschlecht",
|
|
p.staatsbuergerschaft AS "Nation",
|
|
pl.zeitpunkt AS "LockDate",
|
|
pl.lockuser AS "LockUser",
|
|
pd.parkdate AS "ParkDate",
|
|
(
|
|
SELECT l.zeitpunkt
|
|
FROM system.tbl_log l
|
|
WHERE l.taetigkeit_kurzbz IN ('.$TAETIGKEIT_KURZBZ.')
|
|
AND l.logdata->>\'name\' NOT IN ('.$LOGDATA_NAME.')
|
|
AND l.person_id = p.person_id
|
|
ORDER BY l.zeitpunkt DESC
|
|
LIMIT 1
|
|
) AS "LastAction",
|
|
(
|
|
SELECT l.taetigkeit_kurzbz
|
|
FROM system.tbl_log l
|
|
WHERE l.taetigkeit_kurzbz IN('.$TAETIGKEIT_KURZBZ.')
|
|
AND l.logdata->>\'name\' NOT IN ('.$LOGDATA_NAME.')
|
|
AND l.person_id = p.person_id
|
|
ORDER BY l.zeitpunkt DESC
|
|
LIMIT 1
|
|
) AS "LastActionType",
|
|
(
|
|
SELECT count(akte_id)
|
|
FROM public.tbl_akte a
|
|
WHERE
|
|
a.person_id = p.person_id
|
|
AND
|
|
a.dokument_kurzbz in ('.$AKTE_TYP.')
|
|
) AS "AnzahlAkte",
|
|
(
|
|
SELECT l.insertvon
|
|
FROM system.tbl_log l
|
|
WHERE l.taetigkeit_kurzbz IN ('.$TAETIGKEIT_KURZBZ.')
|
|
AND l.logdata->>\'name\' NOT IN ('.$LOGDATA_NAME.')
|
|
AND l.person_id = p.person_id
|
|
ORDER BY l.zeitpunkt DESC
|
|
LIMIT 1
|
|
) AS "User/Operator",
|
|
(
|
|
SELECT pss.studiensemester_kurzbz
|
|
FROM public.tbl_prestudentstatus pss
|
|
JOIN public.tbl_prestudent ps USING(prestudent_id)
|
|
JOIN public.tbl_studiengang sg USING(studiengang_kz)
|
|
WHERE pss.status_kurzbz = '.$INTERESSENT_STATUS.'
|
|
AND pss.bestaetigtam IS NULL
|
|
AND ps.person_id = p.person_id
|
|
AND (sg.typ IN ('.$STUDIENGANG_TYP.')
|
|
OR
|
|
sg.studiengang_kz in('.$ADDITIONAL_STG.')
|
|
)
|
|
AND NOT EXISTS (
|
|
SELECT 1
|
|
FROM tbl_prestudentstatus spss
|
|
WHERE spss.prestudent_id = ps.prestudent_id
|
|
AND spss.status_kurzbz = '.$REJECTED_STATUS.'
|
|
)
|
|
ORDER BY pss.datum DESC, pss.insertamum DESC, pss.ext_id DESC
|
|
LIMIT 1
|
|
) AS "Studiensemester",
|
|
(
|
|
SELECT pss.bewerbung_abgeschicktamum
|
|
FROM public.tbl_prestudentstatus pss
|
|
JOIN public.tbl_prestudent ps USING(prestudent_id)
|
|
JOIN public.tbl_studiengang sg USING(studiengang_kz)
|
|
WHERE pss.status_kurzbz = '.$INTERESSENT_STATUS.'
|
|
AND pss.bewerbung_abgeschicktamum IS NOT NULL
|
|
AND pss.bestaetigtam IS NULL
|
|
AND ps.person_id = p.person_id
|
|
AND (sg.typ IN ('.$STUDIENGANG_TYP.')
|
|
OR
|
|
sg.studiengang_kz in('.$ADDITIONAL_STG.')
|
|
)
|
|
AND pss.studiensemester_kurzbz = '.$STUDIENSEMESTER.'
|
|
AND NOT EXISTS (
|
|
SELECT 1
|
|
FROM tbl_prestudentstatus spss
|
|
WHERE spss.prestudent_id = pss.prestudent_id
|
|
AND spss.status_kurzbz = '.$REJECTED_STATUS.'
|
|
AND spss.studiensemester_kurzbz IN (SELECT ss.studiensemester_kurzbz FROM public.tbl_studiensemester ss WHERE ss.ende >
|
|
(SELECT start FROM public.tbl_studiensemester sss WHERE studiensemester_kurzbz = '.$STUDIENSEMESTER.'))
|
|
)
|
|
ORDER BY pss.datum DESC, pss.insertamum DESC, pss.ext_id DESC
|
|
LIMIT 1
|
|
) AS "SendDate",
|
|
(
|
|
SELECT COUNT(*)
|
|
FROM public.tbl_prestudentstatus pss
|
|
JOIN public.tbl_prestudent ps USING(prestudent_id)
|
|
JOIN public.tbl_studiengang sg USING(studiengang_kz)
|
|
WHERE pss.status_kurzbz = '.$INTERESSENT_STATUS.'
|
|
AND pss.bewerbung_abgeschicktamum IS NOT NULL
|
|
AND pss.bestaetigtam IS NULL
|
|
AND ps.person_id = p.person_id
|
|
AND (
|
|
sg.typ IN ('.$STUDIENGANG_TYP.')
|
|
OR
|
|
sg.studiengang_kz in('.$ADDITIONAL_STG.')
|
|
)
|
|
AND pss.studiensemester_kurzbz = '.$STUDIENSEMESTER.'
|
|
AND NOT EXISTS (
|
|
SELECT 1
|
|
FROM tbl_prestudentstatus spss
|
|
WHERE spss.prestudent_id = pss.prestudent_id
|
|
AND spss.status_kurzbz = '.$REJECTED_STATUS.'
|
|
AND spss.studiensemester_kurzbz IN (SELECT ss.studiensemester_kurzbz FROM public.tbl_studiensemester ss WHERE ss.ende >
|
|
(SELECT start FROM public.tbl_studiensemester sss WHERE studiensemester_kurzbz = '.$STUDIENSEMESTER.'))
|
|
)
|
|
LIMIT 1
|
|
) AS "AnzahlAbgeschickt",
|
|
(
|
|
SELECT ARRAY_TO_STRING(ARRAY_AGG(DISTINCT UPPER(sg.typ || sg.kurzbz) || \':\' || sp.orgform_kurzbz), \', \')
|
|
FROM public.tbl_prestudentstatus pss
|
|
JOIN public.tbl_prestudent ps USING(prestudent_id)
|
|
JOIN public.tbl_studiengang sg USING(studiengang_kz)
|
|
JOIN lehre.tbl_studienplan sp USING(studienplan_id)
|
|
WHERE pss.status_kurzbz = '.$INTERESSENT_STATUS.'
|
|
AND pss.bewerbung_abgeschicktamum IS NOT NULL
|
|
-- AND pss.bestaetigtam IS NULL
|
|
AND ps.person_id = p.person_id
|
|
AND (sg.typ IN ('.$STUDIENGANG_TYP.')
|
|
OR
|
|
sg.studiengang_kz in('.$ADDITIONAL_STG.')
|
|
)
|
|
AND pss.studiensemester_kurzbz = '.$STUDIENSEMESTER.'
|
|
AND NOT EXISTS (
|
|
SELECT 1
|
|
FROM tbl_prestudentstatus spss
|
|
WHERE spss.prestudent_id = pss.prestudent_id
|
|
AND spss.status_kurzbz = '.$REJECTED_STATUS.'
|
|
AND spss.studiensemester_kurzbz IN (SELECT ss.studiensemester_kurzbz FROM public.tbl_studiensemester ss WHERE ss.ende >
|
|
(SELECT start FROM public.tbl_studiensemester sss WHERE studiensemester_kurzbz = '.$STUDIENSEMESTER.'))
|
|
)
|
|
LIMIT 1
|
|
) AS "StgAbgeschickt",
|
|
(
|
|
SELECT ARRAY_TO_STRING(ARRAY_AGG(DISTINCT UPPER(sg.typ || sg.kurzbz) || \':\' || sp.orgform_kurzbz), \', \')
|
|
FROM public.tbl_prestudentstatus pss
|
|
JOIN public.tbl_prestudent ps USING(prestudent_id)
|
|
JOIN public.tbl_studiengang sg USING(studiengang_kz)
|
|
JOIN lehre.tbl_studienplan sp USING(studienplan_id)
|
|
WHERE pss.status_kurzbz = '.$INTERESSENT_STATUS.'
|
|
AND pss.bewerbung_abgeschicktamum IS NULL
|
|
AND pss.bestaetigtam IS NULL
|
|
AND ps.person_id = p.person_id
|
|
AND (sg.typ IN ('.$STUDIENGANG_TYP.')
|
|
OR
|
|
sg.studiengang_kz in('.$ADDITIONAL_STG.')
|
|
)
|
|
AND pss.studiensemester_kurzbz = '.$STUDIENSEMESTER.'
|
|
|
|
AND NOT EXISTS (
|
|
SELECT 1
|
|
FROM tbl_prestudentstatus spss
|
|
WHERE spss.prestudent_id = pss.prestudent_id
|
|
AND spss.status_kurzbz = '.$REJECTED_STATUS.'
|
|
AND spss.studiensemester_kurzbz IN (SELECT ss.studiensemester_kurzbz FROM public.tbl_studiensemester ss WHERE ss.ende >
|
|
(SELECT start FROM public.tbl_studiensemester sss WHERE studiensemester_kurzbz = '.$STUDIENSEMESTER.'))
|
|
)
|
|
LIMIT 1
|
|
) AS "StgNichtAbgeschickt",
|
|
(
|
|
SELECT ARRAY_TO_STRING(ARRAY_AGG(DISTINCT UPPER(sg.typ || sg.kurzbz) || \':\' || sp.orgform_kurzbz), \', \')
|
|
FROM public.tbl_prestudentstatus pss
|
|
JOIN public.tbl_prestudent ps USING(prestudent_id)
|
|
JOIN public.tbl_studiengang sg USING(studiengang_kz)
|
|
JOIN lehre.tbl_studienplan sp USING(studienplan_id)
|
|
WHERE pss.status_kurzbz IN ('.$STATUS_KURZBZ.')
|
|
AND pss.bewerbung_abgeschicktamum IS NULL
|
|
AND ps.person_id = p.person_id
|
|
AND (sg.typ IN ('.$STUDIENGANG_TYP.')
|
|
OR
|
|
sg.studiengang_kz in('.$ADDITIONAL_STG.')
|
|
)
|
|
AND pss.studiensemester_kurzbz = '.$STUDIENSEMESTER.'
|
|
AND NOT EXISTS (
|
|
SELECT 1
|
|
FROM tbl_prestudentstatus spss
|
|
WHERE spss.prestudent_id = pss.prestudent_id
|
|
AND spss.status_kurzbz = '.$REJECTED_STATUS.'
|
|
AND spss.studiensemester_kurzbz IN (SELECT ss.studiensemester_kurzbz FROM public.tbl_studiensemester ss WHERE ss.ende >
|
|
(SELECT start FROM public.tbl_studiensemester sss WHERE studiensemester_kurzbz = '.$STUDIENSEMESTER.'))
|
|
)
|
|
LIMIT 1
|
|
) AS "StgAktiv",
|
|
(
|
|
SELECT ps.zgvnation
|
|
FROM public.tbl_prestudent ps
|
|
WHERE ps.person_id = p.person_id
|
|
ORDER BY ps.zgvnation DESC NULLS LAST, ps.prestudent_id DESC
|
|
LIMIT 1
|
|
) AS "ZGVNation"
|
|
FROM public.tbl_person p
|
|
LEFT JOIN (
|
|
SELECT tpl.person_id,
|
|
tpl.zeitpunkt,
|
|
tpl.uid AS lockuser
|
|
FROM system.tbl_person_lock tpl
|
|
WHERE tpl.app = '.$APP.'
|
|
) pl USING(person_id)
|
|
LEFT JOIN (
|
|
SELECT l.person_id,
|
|
l.zeitpunkt AS parkdate
|
|
FROM system.tbl_log l
|
|
WHERE l.logtype_kurzbz = '.$LOGTYPE_KURZBZ.'
|
|
AND l.logdata->>\'name\' = '.$LOGDATA_NAME_PARKED.'
|
|
AND l.zeitpunkt >= NOW()
|
|
) pd USING(person_id)
|
|
WHERE
|
|
EXISTS (
|
|
SELECT 1
|
|
FROM public.tbl_prestudent sps
|
|
JOIN public.tbl_studiengang ssg USING(studiengang_kz)
|
|
WHERE sps.person_id = p.person_id
|
|
AND (ssg.typ IN ('.$STUDIENGANG_TYP.')
|
|
OR
|
|
ssg.studiengang_kz in('.$ADDITIONAL_STG.')
|
|
)
|
|
AND '.$INTERESSENT_STATUS.' = (
|
|
SELECT spss.status_kurzbz
|
|
FROM public.tbl_prestudentstatus spss
|
|
WHERE spss.prestudent_id = sps.prestudent_id
|
|
ORDER BY spss.datum DESC, spss.insertamum DESC, spss.ext_id DESC
|
|
LIMIT 1
|
|
)
|
|
AND EXISTS (
|
|
SELECT 1
|
|
FROM public.tbl_prestudentstatus spss
|
|
WHERE spss.prestudent_id = sps.prestudent_id
|
|
AND spss.status_kurzbz = '.$INTERESSENT_STATUS.'
|
|
AND spss.bestaetigtam IS NULL
|
|
AND spss.studiensemester_kurzbz = '.$STUDIENSEMESTER.'
|
|
)
|
|
)
|
|
ORDER BY "LastAction" ASC';
|
|
|
|
$filterWidgetArray = array(
|
|
'query' => $query,
|
|
'app' => InfoCenter::APP,
|
|
'datasetName' => 'overview',
|
|
'filterKurzbz' => 'InfoCenterSentApplicationAll',
|
|
'filter_id' => $this->input->get('filter_id'),
|
|
'requiredPermissions' => 'infocenter',
|
|
'datasetRepresentation' => 'tablesorter',
|
|
'reloadDataset' => ($this->input->get('reloadDataset')=='true'?true:false),
|
|
'customMenu' => true,
|
|
'checkboxes' => 'PersonId',
|
|
'additionalColumns' => array('Details'),
|
|
'columnsAliases' => array(
|
|
'PersonID',
|
|
ucfirst($this->p->t('person', 'vorname')) ,
|
|
ucfirst($this->p->t('person', 'nachname')),
|
|
ucfirst($this->p->t('person', 'geburtsdatum')),
|
|
ucfirst($this->p->t('person', 'geschlecht')),
|
|
ucfirst($this->p->t('person', 'nation')),
|
|
ucfirst($this->p->t('global', 'sperrdatum')),
|
|
ucfirst($this->p->t('global', 'gesperrtVon')),
|
|
ucfirst($this->p->t('global', 'parkdatum')),
|
|
ucfirst($this->p->t('global', 'letzteAktion')),
|
|
'Aktionstyp',
|
|
'AnzahlAktePflicht',
|
|
ucfirst($this->p->t('global', 'letzterBearbeiter')),
|
|
ucfirst($this->p->t('lehre', 'studiensemester')),
|
|
ucfirst($this->p->t('global', 'gesendetAm')),
|
|
ucfirst($this->p->t('global', 'abgeschickt')).' ('.$this->p->t('global', 'anzahl').')',
|
|
ucfirst($this->p->t('lehre', 'studiengang')).' ('.$this->p->t('global', 'gesendet').')',
|
|
ucfirst($this->p->t('lehre', 'studiengang')).' ('.$this->p->t('global', 'nichtGesendet').')',
|
|
ucfirst($this->p->t('lehre', 'studiengang')).' ('.$this->p->t('global', 'aktiv').')',
|
|
'ZGV Nation'
|
|
),
|
|
'formatRow' => function($datasetRaw) {
|
|
|
|
/* NOTE: Dont use $this here for PHP Version compatibility */
|
|
$datasetRaw->{'Details'} = sprintf(
|
|
'<a href="%s?person_id=%s&origin_page=%s&fhc_controller_id=%s&prev_filter_id=%s">Details</a>',
|
|
site_url('system/infocenter/InfoCenter/showDetails'),
|
|
$datasetRaw->{'PersonId'},
|
|
'index',
|
|
(isset($_GET['fhc_controller_id']) ? $_GET['fhc_controller_id'] : ''),
|
|
(isset($_GET['filter_id']) ? $_GET['filter_id'] : '')
|
|
);
|
|
|
|
if ($datasetRaw->{'SendDate'} == null)
|
|
{
|
|
$datasetRaw->{'SendDate'} = 'Not sent';
|
|
}
|
|
else
|
|
{
|
|
$datasetRaw->{'SendDate'} = date_format(date_create($datasetRaw->{'SendDate'}), 'Y-m-d H:i');
|
|
}
|
|
|
|
if ($datasetRaw->{'LastAction'} == null)
|
|
{
|
|
$datasetRaw->{'LastAction'} = '-';
|
|
}
|
|
else
|
|
{
|
|
$datasetRaw->{'LastAction'} = date_format(date_create($datasetRaw->{'LastAction'}), 'Y-m-d H:i');
|
|
}
|
|
|
|
if ($datasetRaw->{'User/Operator'} == '')
|
|
{
|
|
$datasetRaw->{'User/Operator'} = 'NA';
|
|
}
|
|
|
|
if ($datasetRaw->{'LockDate'} == null)
|
|
{
|
|
$datasetRaw->{'LockDate'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'LockUser'} == null)
|
|
{
|
|
$datasetRaw->{'LockUser'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'ParkDate'} == null)
|
|
{
|
|
$datasetRaw->{'ParkDate'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'StgAbgeschickt'} == null)
|
|
{
|
|
$datasetRaw->{'StgAbgeschickt'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'StgNichtAbgeschickt'} == null)
|
|
{
|
|
$datasetRaw->{'StgNichtAbgeschickt'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'StgAktiv'} == null)
|
|
{
|
|
$datasetRaw->{'StgAktiv'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'Nation'} == null)
|
|
{
|
|
$datasetRaw->{'Nation'} = '-';
|
|
}
|
|
|
|
if ($datasetRaw->{'ZGVNation'} == null)
|
|
{
|
|
$datasetRaw->{'ZGVNation'} = '-';
|
|
}
|
|
|
|
return $datasetRaw;
|
|
},
|
|
'markRow' => function($datasetRaw) {
|
|
|
|
$mark = '';
|
|
|
|
if ($datasetRaw->LockDate != null)
|
|
{
|
|
$mark = FilterWidget::DEFAULT_MARK_ROW_CLASS;
|
|
}
|
|
|
|
// Parking has priority over locking
|
|
if ($datasetRaw->ParkDate != null)
|
|
{
|
|
$mark = "text-info";
|
|
}
|
|
|
|
return $mark;
|
|
}
|
|
);
|
|
|
|
echo $this->widgetlib->widget('FilterWidget', $filterWidgetArray);
|
|
?>
|