diff --git a/application/controllers/jobs/AmpelMail.php b/application/controllers/jobs/AmpelMail.php index f77122735..fdc6ad405 100644 --- a/application/controllers/jobs/AmpelMail.php +++ b/application/controllers/jobs/AmpelMail.php @@ -17,10 +17,10 @@ if (! defined('BASEPATH')) class AmpelMail extends FHC_Controller { const CIS_AMPELVERWALTUNG_URL = - CIS_ROOT. "index.php?sprache=German&content_id=&menu=". - CIS_ROOT. "menu.php?content_id=&content=". - CIS_ROOT. "private/tools/ampelverwaltung.php"; - + CIS_ROOT. "cis/index.php?menu=". + CIS_ROOT. "cis/menu.php?content_id=&content=". + CIS_ROOT. "cis/private/tools/ampelverwaltung.php"; + /** * Constructor */ @@ -39,11 +39,11 @@ class AmpelMail extends FHC_Controller echo "Jobs must be run from the CLI"; exit; } - + // Load models $this->load->model('content/Ampel_model', 'AmpelModel'); $this->load->model('person/Person_model', 'PersonModel'); - + // Load helpers $this->load->helper('sancho'); } @@ -60,7 +60,7 @@ class AmpelMail extends FHC_Controller echo $result. PHP_EOL; } - + /** * Generates mail content for new and overdue Ampeln, which * 1. are not confirmed by the user yet and @@ -81,7 +81,7 @@ class AmpelMail extends FHC_Controller if (hasData($result_active_ampeln)) { $ampel_arr = $result_active_ampeln->retval; - + // Loop through ampeln foreach ($ampel_arr as $ampel) { @@ -95,11 +95,11 @@ class AmpelMail extends FHC_Controller // get all user, who get this ampel $result_ampel_user = $this->AmpelModel->execBenutzerSelect($qry_all_ampel_user); - + if (hasData($result_ampel_user)) { $ampel_user_arr = $result_ampel_user->retval; - + // loop through all user, who get this ampel foreach ($ampel_user_arr as $ampel_user) { @@ -131,7 +131,7 @@ class AmpelMail extends FHC_Controller $html_text = '

'. strtoupper($ampel->kurzbz). '
- Die Deadline für die Bestätigung war am + Die Deadline für die Bestätigung war am '. date_format($deadline, 'Y-m-d'). '


'; @@ -177,7 +177,7 @@ class AmpelMail extends FHC_Controller ); }; } - + // ------------------------------------------------------------------------ // Private methods /** @@ -190,10 +190,10 @@ class AmpelMail extends FHC_Controller private function _getAmpelContentData($uid, $html_text, $ampel_data_arr) { $firstName = $this->PersonModel->getByUid($uid)->retval[0]->vorname; - + // check if user already exists in the array $key_position = array_search($uid, array_column($ampel_data_arr, 'uid')); - + // If user already exists in the array, add only new ampel data to users ampel list if ($key_position !== false) { diff --git a/application/controllers/system/infocenter/InfoCenter.php b/application/controllers/system/infocenter/InfoCenter.php index 4360494ea..c87425b56 100644 --- a/application/controllers/system/infocenter/InfoCenter.php +++ b/application/controllers/system/infocenter/InfoCenter.php @@ -1180,14 +1180,16 @@ class InfoCenter extends FHC_Controller $notizenBewerbung = $this->NotizModel->getNotizByTitel($person_id, 'Anmerkung zur Bewerbung')->retval; - $notizentext = ''; - $lastElement = end($notizenBewerbung); + $notizentext = ''; $mailadresse = ''; foreach ($person->kontakte as $kontakt) diff --git a/application/models/content/Ampel_model.php b/application/models/content/Ampel_model.php index e569755df..aeb260a5c 100644 --- a/application/models/content/Ampel_model.php +++ b/application/models/content/Ampel_model.php @@ -10,7 +10,7 @@ class Ampel_model extends DB_Model $this->dbTable = 'public.tbl_ampel'; $this->pk = 'ampel_id'; } - + /** * Returns all active Ampeln, that are actually: * 1. not after the deadline date @@ -25,24 +25,24 @@ class Ampel_model extends DB_Model SELECT * FROM public.tbl_ampel WHERE'; - + if ($email === true) { $parametersArray['email'] = $email; $query .= ' email = ? AND'; } - + $query .= ' - (NOW()<(deadline+(verfallszeit || \' days\')::interval)::date) - OR (verfallszeit IS NULL AND NOW() < deadline) - AND (NOW()>(deadline-(vorlaufzeit || \' days\')::interval)::date) - OR (vorlaufzeit IS NULL AND NOW() > deadline)'; - + (NOW()<(deadline+(COALESCE(verfallszeit,0) || \' days\')::interval)::date) + OR (verfallszeit IS NULL) + AND (NOW()>(deadline-(COALESCE(vorlaufzeit,0) || \' days\')::interval)::date) + OR (vorlaufzeit IS NULL AND NOW() < deadline)'; + $query .= ' ORDER BY deadline DESC'; - + return $this->execQuery($query, $parametersArray); } - + /** * Returns all Ampel-receiver of a specific Ampel. * @param string $benutzer_select SQL Statement which defines the Ampel-receiver. @@ -55,7 +55,7 @@ class Ampel_model extends DB_Model return $this->execQuery($benutzer_select); } } - + /** * Checks if Ampel was confirmed by the user. * @param int $ampel_id Ampel-ID @@ -75,7 +75,7 @@ class Ampel_model extends DB_Model { $result = $this->execQuery($query, array($ampel_id, $uid)); } - + if ($result) { if (count($result->retval) > 0) @@ -87,7 +87,7 @@ class Ampel_model extends DB_Model return false; } } - else + else return $result; //will contain the error-msg from execQuery } } diff --git a/cis/ampel.php b/cis/ampel.php index e767d9a6f..2f80092d5 100644 --- a/cis/ampel.php +++ b/cis/ampel.php @@ -24,75 +24,75 @@ function hide_ampel_div() if(is_user_logged_in()) { $user = get_uid(); - + $ampel = new ampel(); $ampel->loadUserAmpel($user); $rot=0; - $gelb = 0; + $gelb = 0; $gruen = 0; $verpflichtend = false; - $cnt_verpflichtend = 0; - $cnt_abgelaufen = 0; + $cnt_verpflichtend = 0; + $cnt_abgelaufen = 0; $cnt_notConf_notOverdue = 0; //counts mandatory, not confirmed && not overdued ampeln (for popup) - + $datum = new datum(); $now = $datum->mktime_fromdate(date('Y-m-d')); foreach($ampel->result as $row) - { + { $deadline =$datum->mktime_fromdate($row->deadline); $vorlaufzeit = $row->vorlaufzeit; $verfallszeit = $row->verfallszeit; $bestaetigt = $ampel->isBestaetigt($user, $row->ampel_id); $verpflichtend = $row->verpflichtend; $abgelaufen = false; - + $datum_liegt_vor_vorlaufzeit = false; $datum_liegt_nach_verfallszeit = false; - + if (!is_null($vorlaufzeit)) - $datum_liegt_vor_vorlaufzeit = $now < strtotime('-' . $vorlaufzeit . ' day', $deadline); - + $datum_liegt_vor_vorlaufzeit = $now < strtotime('-' . $vorlaufzeit . ' day', $deadline); + if (!is_null($verfallszeit)) $datum_liegt_nach_verfallszeit = $now > strtotime('+' . $verfallszeit . ' day', $deadline); - + //count mandatory if($verpflichtend == 't') $cnt_verpflichtend++; - + //count overdue if ($datum_liegt_nach_verfallszeit) $cnt_abgelaufen++; //set status if ($bestaetigt) - $gruen++; - else if ($now >= $deadline && !$datum_liegt_nach_verfallszeit && !$bestaetigt) + $gruen++; + else if ($now >= $deadline && !$datum_liegt_nach_verfallszeit && !$bestaetigt) $rot++; else if (!$datum_liegt_nach_verfallszeit && !$datum_liegt_vor_vorlaufzeit) - $gelb++; - + $gelb++; + //count mandatory ampeln that are not confirmed and not overdue (for popup) if ($verpflichtend == 't' && !$bestaetigt && !$datum_liegt_nach_verfallszeit && !$datum_liegt_vor_vorlaufzeit) - $cnt_notConf_notOverdue++; + $cnt_notConf_notOverdue++; } - + //if at least ONE mandatory notification, which is not overdue -> trigger notification-POPUP if ($cnt_notConf_notOverdue > 0) - { + { echo ' '; - + echo ' '; } - + //show & color header ampel-link if($rot > 0) echo ''.$p->t("tools/ampelsystem").'  |  '; elseif($gelb > 0) echo ''.$p->t("tools/ampelsystem").'  |  '; elseif($rot==0 || $rot <= $cnt_abgelaufen && $gelb==0) - echo ''.$p->t("tools/ampelsystem").'  |  '; + echo ''.$p->t("tools/ampelsystem").'  |  '; } else { echo ""; } -?> \ No newline at end of file +?> diff --git a/cis/index.php b/cis/index.php index 401f0d51f..60c9aceeb 100644 --- a/cis/index.php +++ b/cis/index.php @@ -165,11 +165,12 @@ $db = new basis_db(); - - - - - + + + + + + -
+
' . $p->t('tools/ampelsystem') . ''; - //title in popup for mandatory ampeln + //***************************************** AROUSE SANCHO for mandatory ampeln if ($is_popup) - echo '

' . $p->t('tools/ampelPopupTitel'). '


'; + { + //sancho message if mandatory ampeln exist + if (count($user_ampel_arr) > 0) + { + echo ' +
+ sancho_verpflichtende_ampeln +
+



'; + } + } ?> -
+
1) - $ovdue_txt = 'ich habe ' . count($user_ampel_arr) . ' Nachrichten entdeckt, die verpflichtend zu bestätigen sind.'; - if (count($user_ampel_arr) > 0) - { - echo ' -
-
- sancho_ampel_ueberfaellig -
-
-

-
-
-



'; - } - } //***************************************** COLLAPSED PANELS WITH AMPELN $cnt = 1; //counter to set iterative id's @@ -418,7 +402,17 @@ $(document).ready(function(){
'; - + } + elseif ($cnt_active != 0 && !$is_popup) + { + echo ' +
+
+ +
+
'; } //fill panel with ampeln @@ -435,6 +429,7 @@ $(document).ready(function(){
@@ -492,8 +487,6 @@ $(document).ready(function(){
- -
isLocked($id)) $dokumente_person = new dokument(); $dokumente_person->getAllDokumenteForPerson($person_id, true); + $dokumente_arr = array(); foreach ($dokumente_person->result AS $row) $dokumente_arr[] .= $row->dokument_kurzbz; - + + // An der FHTW wird das vorläufige ZGV Dokument verlangt und kann somit auch heruntergeladen werden + if (CAMPUS_NAME == 'FH Technikum Wien') + { + $dokumente_arr[] .= 'ZgvBaPre'; + } if ($person_id!=$akte_person || !in_array($akte_dokument_kurzbz, $dokumente_arr)) die('Sie haben keinen Zugriff auf dieses Dokument'); } diff --git a/include/akte.class.php b/include/akte.class.php index 6c053f6a5..8a454c0bf 100644 --- a/include/akte.class.php +++ b/include/akte.class.php @@ -316,7 +316,7 @@ class akte extends basis_db $qry.=" AND dokument_kurzbz=".$this->db_add_param($dokument_kurzbz); if($stg_kz != null && $prestudent_id != null) $qry.=" AND dokument_kurzbz not in (SELECT dokument_kurzbz FROM public.tbl_dokument JOIN public.tbl_dokumentstudiengang USING(dokument_kurzbz) - WHERE studiengang_kz= ".$this->db_add_param($stg_kz).") AND dokument_kurzbz NOT IN ('Zeugnis') AND dokument_kurzbz NOT IN + WHERE studiengang_kz= ".$this->db_add_param($stg_kz).") AND dokument_kurzbz NOT IN ('Zeugnis','DiplSupp','Bescheid') AND dokument_kurzbz NOT IN (SELECT dokument_kurzbz FROM public.tbl_dokumentprestudent JOIN public.tbl_dokument USING(dokument_kurzbz) WHERE prestudent_id=".$this->db_add_param($prestudent_id).")"; diff --git a/locale/de-AT/tools.php b/locale/de-AT/tools.php index 7465d93c2..5d579e177 100644 --- a/locale/de-AT/tools.php +++ b/locale/de-AT/tools.php @@ -57,8 +57,10 @@ $this->phrasen['tools/ampelBitteBestaetigen']='Bitte bestätigen Sie diese jetzt $this->phrasen['tools/ampelAbgelaufenTitel']='Abgelaufene oder bereits bestätigte Ampeln'; $this->phrasen['tools/ampelAbgelaufenTxt']='Sie können diese Ampeln weiterhin lesen, aber nicht mehr bestätigen.'; $this->phrasen['tools/ampelBestaetigtAbgelaufen']='Bereits bestätigt oder abgelaufen'; +$this->phrasen['tools/ampelAktuelleAmpeln']='Aktuelle Ampeln'; $this->phrasen['tools/ampelKeineAktuellen']='Keine aktuellen Ampeln'; $this->phrasen['tools/ampelKeineAktuellenTxt']='Sie haben zur Zeit keine aktuellen Ampeln.'; +$this->phrasen['tools/ampelClose']='Jetzt nicht'; //Software fuer Lehre -> Softgrid $this->phrasen['tools/applikationsliste']='Applikationsliste'; diff --git a/locale/en-US/tools.php b/locale/en-US/tools.php index 33e95efdc..276c72bbb 100644 --- a/locale/en-US/tools.php +++ b/locale/en-US/tools.php @@ -59,6 +59,7 @@ $this->phrasen['tools/ampelBitteBestaetigen']='Please confirm now!'; $this->phrasen['tools/ampelAbgelaufenTitel']='Notifications expired or confirmed'; $this->phrasen['tools/ampelAbgelaufenTxt']='Notifications can still be read, but not confirmed anymore.'; $this->phrasen['tools/ampelBestaetigtAbgelaufen']='Almost confirmed or expired'; +$this->phrasen['tools/ampelAktuelleAmpeln']='Actual notifications'; $this->phrasen['tools/ampelKeineAktuellen']='No current notifications.'; $this->phrasen['tools/ampelKeineAktuellenTxt']='You currently do not have any notifications.'; diff --git a/skin/images/sancho/sancho_header_du_hast_verpflichtende_ampeln.jpg b/skin/images/sancho/sancho_header_du_hast_verpflichtende_ampeln.jpg new file mode 100644 index 000000000..5ee6ca180 Binary files /dev/null and b/skin/images/sancho/sancho_header_du_hast_verpflichtende_ampeln.jpg differ diff --git a/skin/vilesci.css b/skin/vilesci.css index 35e3d07ca..433ca0a4c 100644 --- a/skin/vilesci.css +++ b/skin/vilesci.css @@ -46,8 +46,9 @@ tr.liste1 background-color: #EFEFDD; } -table.tablesorter tr:hover td { - background-color: rgb(226, 255, 226) !important; +table.tablesorter tr:hover td +{ + background-color: #DCE4EF !important; } td.button diff --git a/system/xsl/bescheid_style_0.xsl b/system/xsl/bescheid_style_0.xsl index b60996661..016ce0980 100644 --- a/system/xsl/bescheid_style_0.xsl +++ b/system/xsl/bescheid_style_0.xsl @@ -149,7 +149,7 @@ xmlns:form="urn:oasis:names:tc:opendocument:xmlns:form:1.0" - + diff --git a/vilesci/stammdaten/ampel_details.php b/vilesci/stammdaten/ampel_details.php index f4bad58ee..f3432a7e6 100644 --- a/vilesci/stammdaten/ampel_details.php +++ b/vilesci/stammdaten/ampel_details.php @@ -45,11 +45,11 @@ $datum_obj = new datum(); Ampel - Details - - - - + + + +