Bismeldestichtag Management: improved GUI layout, studiensemester is optional for "bismeldestichtag reached" check

This commit is contained in:
KarpAlex
2023-06-29 19:19:00 +02:00
parent 18d25069f3
commit 74814db900
6 changed files with 81 additions and 53 deletions
+53 -34
View File
@@ -8,9 +8,6 @@
'filtercomponent' => true,
'navigationcomponent' => true,
'tabulator5' => true,
'customCSSs' => array(
'public/css/components/verticalsplit.css'
),
'customJSModules' => array('public/js/apps/Bismeldestichtag/Bismeldestichtag.js')
);
@@ -31,35 +28,55 @@
</core-fetch-cmpt>
<div id="content">
<div>
<verticalsplit>
<template #top>
<!-- input fields -->
<div class="row">
<div class="col-9">
<div class="input-group">
<input type="date" class="form-control" name="meldestichtag" v-model="meldestichtag">
<select class="form-control" name="studiensemester_kurzbz" v-model="currSem">
<option v-for="sem in semList" :value="sem.studiensemester_kurzbz">
{{ sem.studiensemester_kurzbz }}
</option>
</select>
<div class="input-group-btn">
<button type="button" class="btn btn-dark" @click="handlerAddBismeldestichtag">
<?php echo $this->p->t('bismeldestichtag', 'stichtagHinzufuegen') ?>
</button>
</div>
</div>
</div>
<div class="col-3 text-center">
<button type="button" class="btn btn-dark" @click="handlerDeleteBismeldestichtag">
<?php echo $this->p->t('bismeldestichtag', 'stichtagLoeschen') ?>
</button>
</div>
</div>
</template>
<template #bottom>
<!-- Filter component -->
<!-- input fields -->
<!--
<div class="row">
<div class="col-6">
<input type="date" class="form-control" name="meldestichtag" v-model="meldestichtag">
</div>
<div class="col-3">
<select class="form-control" name="studiensemester_kurzbz" v-model="currSem">
<option v-for="sem in semList" :value="sem.studiensemester_kurzbz">
{{ sem.studiensemester_kurzbz }}
</option>
</select>
</div>
<div class="col-3 text-center">
<button type="button" class="btn btn-primary" @click="handlerAddBismeldestichtag">
<?php //echo $this->p->t('bismeldestichtag', 'stichtagHinzufuegen') ?>
</button>
</div>
-->
<div class="input-group">
<input type="date" class="form-control" name="meldestichtag" v-model="meldestichtag">
<select class="form-select" name="studiensemester_kurzbz" v-model="currSem">
<option v-for="sem in semList" :value="sem.studiensemester_kurzbz">
{{ sem.studiensemester_kurzbz }}
</option>
</select>
<div class="input-group-btn">
<button type="button" class="btn btn-primary" @click="handlerAddBismeldestichtag">
<?php echo $this->p->t('bismeldestichtag', 'stichtagHinzufuegen') ?>
</button>
</div>
</div>
<!--
<div class="col-2 text-center">
<button type="button" class="btn btn-primary" @click="handlerDeleteBismeldestichtag">
<?php echo $this->p->t('bismeldestichtag', 'stichtagLoeschen') ?>
</button>
</div>
-->
<!--
</div>
-->
<br />
<!-- Filter component -->
<!--
<div class="row">
<div class="col-12">
-->
<core-filter-cmpt
title="<?php echo $this->p->t('bismeldestichtag', 'stichtageVerwalten') ?>"
filter-type="Bismeldestichtag"
@@ -67,8 +84,10 @@
:tabulator-events="bismeldestichtagTabulatorEventHandlers"
@nw-new-entry="newSideMenuEntryHandler">
</core-filter-cmpt>
</template>
</verticalsplit>
<!--
</div>
</div>
-->
</div>
</div>
</div>
+3 -3
View File
@@ -997,7 +997,7 @@ if(!$error)
$bismeldestichtag = new bismeldestichtag();
$meldestichtag_erreicht = $bismeldestichtag->checkMeldestichtagErreicht($studiensemester, $new_status_datum);
$meldestichtag_erreicht = $bismeldestichtag->checkMeldestichtagErreicht($new_status_datum);
if ($meldestichtag_erreicht === true)
{
@@ -1223,7 +1223,7 @@ if(!$error)
$erweiterteBerechtigungen = $rechte->isBerechtigt('admin', null, 'suid') || $rechte->isBerechtigt('student/keine_studstatuspruefung', null, 'suid');
$bismeldestichtag = new bismeldestichtag();
$meldestichtag_erreicht = $bismeldestichtag->checkMeldestichtagErreicht($_POST['studiensemester_kurzbz'], $_POST['datum']);
$meldestichtag_erreicht = $bismeldestichtag->checkMeldestichtagErreicht($_POST['datum']);
if($_POST['status_kurzbz']=='Student' && !$erweiterteBerechtigungen)
{
@@ -1557,7 +1557,7 @@ if(!$error)
// Prüfung, ob Meldestichtag erreicht ist
$bismeldestichtag = new bismeldestichtag();
$meldestichtag_erreicht = $bismeldestichtag->checkMeldestichtagErreicht($_POST['studiensemester_kurzbz'], $_POST['datum']);
$meldestichtag_erreicht = $bismeldestichtag->checkMeldestichtagErreicht($_POST['datum']);
if ($meldestichtag_erreicht === true)
{
+1 -1
View File
@@ -76,7 +76,7 @@ if($prestudent_id!='')
// Prüfen, ob Studnetrolle vor dem aktuellen Meldestichtag ist. In diesem Fall darf die Rolle nicht mehr bearbeitet werden.
$bismeldestichtag = new bismeldestichtag();
$disabled = $bismeldestichtag->checkMeldestichtagErreicht($studiensemester_kurzbz, $datum) ? ' disabled="true"' : '';
$disabled = $bismeldestichtag->checkMeldestichtagErreicht($datum) ? ' disabled="true"' : '';
}
$db = new basis_db();
$user=get_uid();
+22 -11
View File
@@ -27,9 +27,9 @@ class bismeldestichtag extends basis_db
public $meldestichtag; // date
public $studiensemester_kurzbz; // varchar(16)
public $insertamum; // timestamp
public $insertvon; // varchar(16)
public $insertvon; // varchar(32)
public $updateamum; // timestamp
public $updatevon; // varchar(16)
public $updatevon; // varchar(32)
// ErgebnisArray
public $result=array();
@@ -144,19 +144,23 @@ class bismeldestichtag extends basis_db
}
/**
* Prüft, ob Meldestichtag für ein bestimmtes Studiensemester und Statusdatum erreicht ist.
* Prüft, ob Meldestichtag für ein bestimmtes Statusdatum und Studiensemester erreicht ist.
*
* @param $studiensemester_kurzbz
* @param $status_datum
* @param $studiensemester_kurzbz
* @return boolean true wenn erreicht, oder false
*/
public function checkMeldestichtagErreicht($studiensemester_kurzbz, $status_datum)
public function checkMeldestichtagErreicht($status_datum, $studiensemester_kurzbz = null)
{
$erreicht = false;
// Studiensemester ende holen
$studiensemester = new studiensemester();
if ($studiensemester->load($studiensemester_kurzbz))
$studiensemester_ende = new DateTime($studiensemester->ende);
if (isset($studiensemester_kurzbz))
{
// Studiensemester ende holen
$studiensemester = new studiensemester();
if ($studiensemester->load($studiensemester_kurzbz))
$studiensemester_ende = new DateTime($studiensemester->ende);
}
// letztes erreichtes Bismeldedatum holen
if ($this->getLastReachedMeldestichtag() && isset($this->result[0]))
@@ -165,8 +169,15 @@ class bismeldestichtag extends basis_db
$statusDatum = new DateTime($status_datum);
// Prüfen, ob Studentstatusdatum oder Studiensemester vor dem Stichtagsdatum liegen
if (isset($studiensemester_ende) && isset($lastReachedMeldestichtag) && isset($statusDatum))
$erreicht = $statusDatum < $lastReachedMeldestichtag || $studiensemester_ende < $lastReachedMeldestichtag;
if (isset($statusDatum))
{
if (isset($lastReachedMeldestichtag))
$erreicht = $statusDatum < $lastReachedMeldestichtag;
if (isset($studiensemester_ende))
$erreicht = $erreicht || $studiensemester_ende < $lastReachedMeldestichtag;
}
return $erreicht;
}
@@ -23,7 +23,6 @@ import {CoreNavigationCmpt} from '../../components/navigation/Navigation.js';
import {CoreRESTClient} from '../../RESTClient.js';
import {CoreFetchCmpt} from '../../components/Fetch.js';
import {BismeldestichtagAPIs} from './API.js';
import verticalsplit from '../../components/verticalsplit/verticalsplit.js';
const bismeldestichtagApp = Vue.createApp({
data: function() {
@@ -44,8 +43,7 @@ const bismeldestichtagApp = Vue.createApp({
CoreNavigationCmpt,
CoreFilterCmpt,
BismeldestichtagAPIs,
CoreFetchCmpt,
verticalsplit
CoreFetchCmpt
},
created() {
this.handlerStudiensemester();
+1 -1
View File
@@ -104,7 +104,7 @@ foreach($ps->result as $row)
// prüfen, ob Meldestichtag erreicht
$bismeldestichtag = new bismeldestichtag();
$stichtag_erreicht = $bismeldestichtag->checkMeldestichtagErreicht($row->studiensemester_kurzbz, $row->datum);
$stichtag_erreicht = $bismeldestichtag->checkMeldestichtagErreicht($row->datum);
// Variablen für layout von prestudentstatus Anzeige
$stichtagsaktiv = $stichtag_erreicht ? 'stichtagsinaktiv' : 'stichtagsaktiv';