mirror of
https://github.com/FH-Complete/FHC-Core.git
synced 2026-06-01 12:19:28 +00:00
Merge branch 'feature-61164/AbgabetoolQualityGates'
This commit is contained in:
@@ -26,7 +26,9 @@ $config['RELEVANT_PAABGABETYPEN_SAMMELMAIL_ASSISTENZ'] = ['end'];
|
|||||||
$config['RELEVANT_PAABGABETYPEN_SAMMELMAIL_STUDENT'] = ['qualgate1', 'qualgate2', 'zwischen', 'note', 'abstract', 'end', 'enda'];
|
$config['RELEVANT_PAABGABETYPEN_SAMMELMAIL_STUDENT'] = ['qualgate1', 'qualgate2', 'zwischen', 'note', 'abstract', 'end', 'enda'];
|
||||||
//$config['ALLOWED_NOTEN_ABGABETOOL'] = ['Bestanden', 'Nicht bestanden'];
|
//$config['ALLOWED_NOTEN_ABGABETOOL'] = ['Bestanden', 'Nicht bestanden'];
|
||||||
$config['ALLOWED_NOTEN_ABGABETOOL'] = [10, 14]; // tbl_note pk
|
$config['ALLOWED_NOTEN_ABGABETOOL'] = [10, 14]; // tbl_note pk
|
||||||
|
// benotete projektarbeiten sperren weitere terminanlage & bearbeitung, diese noten sind ausnahmen dieser Regel
|
||||||
|
// wie zB "Nicht beurteilt" & "Noch nicht eingetragen"
|
||||||
|
$config['NONFINAL_NOTEN_ABGABETOOL'] = [9];
|
||||||
$config['beurteilung_link_fallback'] = 'addons/fhtw/content/projektbeurteilung/projektbeurteilungDocumentExport.php?projektarbeit_id=?&betreuerart_kurzbz=?&person_id=?';
|
$config['beurteilung_link_fallback'] = 'addons/fhtw/content/projektbeurteilung/projektbeurteilungDocumentExport.php?projektarbeit_id=?&betreuerart_kurzbz=?&person_id=?';
|
||||||
|
|
||||||
$config['PROJEKTARBEITSBEURTEILUNG_MAIL_BASELINK_ERSTBEGUTACHTER'] = 'index.ci.php/extensions/FHC-Core-Projektarbeitsbeurteilung/ProjektarbeitsbeurteilungErstbegutachter';
|
$config['PROJEKTARBEITSBEURTEILUNG_MAIL_BASELINK_ERSTBEGUTACHTER'] = 'index.ci.php/extensions/FHC-Core-Projektarbeitsbeurteilung/ProjektarbeitsbeurteilungErstbegutachter';
|
||||||
@@ -36,3 +38,6 @@ $config['SIGNATUR_CHECK_PAABGABETYPEN'] = ['end'];
|
|||||||
|
|
||||||
// to be used as "https://moodle.technikum-wien.at/course/view.php?idnumber=dl{$stg_kz}" for stg specific moodle routing
|
// to be used as "https://moodle.technikum-wien.at/course/view.php?idnumber=dl{$stg_kz}" for stg specific moodle routing
|
||||||
$config['STG_MOODLE_LINK'] = 'https://moodle.technikum-wien.at/course/view.php?idnumber=dl';
|
$config['STG_MOODLE_LINK'] = 'https://moodle.technikum-wien.at/course/view.php?idnumber=dl';
|
||||||
|
|
||||||
|
$config['ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT'] = true;
|
||||||
|
$config['ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER'] = true;
|
||||||
|
|||||||
@@ -45,8 +45,9 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
'getProjektarbeitenForStudiengang' =>array('basis/abgabe_assistenz:rw'),
|
'getProjektarbeitenForStudiengang' =>array('basis/abgabe_assistenz:rw'),
|
||||||
'getStudiengaenge' => array('basis/abgabe_assistenz:rw'),
|
'getStudiengaenge' => array('basis/abgabe_assistenz:rw'),
|
||||||
'getStudentProjektarbeitAbgabeFile' => array('basis/abgabe_student:rw', 'basis/abgabe_lektor:rw', 'basis/abgabe_assistenz:rw'),
|
'getStudentProjektarbeitAbgabeFile' => array('basis/abgabe_student:rw', 'basis/abgabe_lektor:rw', 'basis/abgabe_assistenz:rw'),
|
||||||
'postStudentProjektarbeitZusatzdaten' => array('basis/abgabe_lektor:rw', 'basis/abgabe_assistenz:rw')
|
'postStudentProjektarbeitZusatzdaten' => array('basis/abgabe_lektor:rw', 'basis/abgabe_assistenz:rw'),
|
||||||
]);
|
'getSignaturStatusForProjektarbeitAbgaben' => array('basis/abgabe_lektor:rw', 'basis/abgabe_assistenz:rw')
|
||||||
|
]);
|
||||||
|
|
||||||
$this->load->library('PhrasesLib');
|
$this->load->library('PhrasesLib');
|
||||||
$this->load->library('SignatureLib');
|
$this->load->library('SignatureLib');
|
||||||
@@ -86,11 +87,15 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
$old_abgabe_beurteilung_link =$this->config->item('old_abgabe_beurteilung_link');
|
$old_abgabe_beurteilung_link =$this->config->item('old_abgabe_beurteilung_link');
|
||||||
$turnitin_link = $this->config->item('turnitin_link');
|
$turnitin_link = $this->config->item('turnitin_link');
|
||||||
$abgabetypenBetreuer = $this->config->item('ALLOWED_ABGABETYPEN_BETREUER');
|
$abgabetypenBetreuer = $this->config->item('ALLOWED_ABGABETYPEN_BETREUER');
|
||||||
|
$ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT = $this->config->item('ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT');
|
||||||
|
$ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER = $this->config->item('ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER');
|
||||||
|
|
||||||
$ret = array(
|
$ret = array(
|
||||||
'old_abgabe_beurteilung_link' => $old_abgabe_beurteilung_link,
|
'old_abgabe_beurteilung_link' => $old_abgabe_beurteilung_link,
|
||||||
'turnitin_link' => $turnitin_link,
|
'turnitin_link' => $turnitin_link,
|
||||||
'abgabetypenBetreuer' => $abgabetypenBetreuer
|
'abgabetypenBetreuer' => $abgabetypenBetreuer,
|
||||||
|
'ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT' => $ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT,
|
||||||
|
'ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER' => $ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER
|
||||||
);
|
);
|
||||||
|
|
||||||
$this->terminateWithSuccess($ret);
|
$this->terminateWithSuccess($ret);
|
||||||
@@ -151,7 +156,7 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
$ret = $this->ProjektarbeitModel->getProjektarbeitAbgabetermine($projektarbeit_id);
|
$ret = $this->ProjektarbeitModel->getProjektarbeitAbgabetermine($projektarbeit_id);
|
||||||
|
|
||||||
foreach ($ret->retval as $termin) {
|
foreach ($ret->retval as $termin) {
|
||||||
$this->checkAbgabeSignatur($termin, $projektarbeit);
|
$this->checkAbgabeSignatur($termin, $projektarbeit->student_uid);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->terminateWithSuccess(array($ret, $projektarbeitIsCurrent));
|
$this->terminateWithSuccess(array($ret, $projektarbeitIsCurrent));
|
||||||
@@ -398,7 +403,7 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
$this->terminateWithError($this->p->t('abgabetool', 'c4projektabgabeNichtGefunden'), 'general');
|
$this->terminateWithError($this->p->t('abgabetool', 'c4projektabgabeNichtGefunden'), 'general');
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->checkAbgabeSignatur($paabgabe, $projektarbeit);
|
$this->checkAbgabeSignatur($paabgabe, $projektarbeit->student_uid);
|
||||||
$signaturstatus = $paabgabe->signatur;
|
$signaturstatus = $paabgabe->signatur;
|
||||||
|
|
||||||
// update projektarbeit cols
|
// update projektarbeit cols
|
||||||
@@ -761,7 +766,7 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
/**
|
/**
|
||||||
* helper function to fetch the correct email for a projektarbeits erstbetreuer
|
* helper function to fetch the correct email for a projektarbeits erstbetreuer
|
||||||
*/
|
*/
|
||||||
private function getProjektbetreuerEmail($projektarbeit_id) {
|
private function getProjektbetreuerEmailByProjektarbeitID($projektarbeit_id) {
|
||||||
$this->load->model('education/Projektarbeit_model', 'ProjektarbeitModel');
|
$this->load->model('education/Projektarbeit_model', 'ProjektarbeitModel');
|
||||||
$result = $this->ProjektarbeitModel->getProjektbetreuerEmail($projektarbeit_id);
|
$result = $this->ProjektarbeitModel->getProjektbetreuerEmail($projektarbeit_id);
|
||||||
$email = $this->getDataOrTerminateWithError($result, 'general');
|
$email = $this->getDataOrTerminateWithError($result, 'general');
|
||||||
@@ -770,6 +775,18 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* helper function to fetch the correct email for a projektarbeits zweitbetreuer by their person id
|
||||||
|
* can be used for erstbetreuer aswell if necessary
|
||||||
|
*/
|
||||||
|
private function getProjektbetreuerEmailByPersonID($person_id) {
|
||||||
|
$this->load->model('education/Projektarbeit_model', 'ProjektarbeitModel');
|
||||||
|
$result = $this->ProjektarbeitModel->getProjektbetreuerEmailByPersonID($person_id);
|
||||||
|
$email = $this->getDataOrTerminateWithError($result, 'general');
|
||||||
|
|
||||||
|
return $email[0]->uid ? $email[0]->uid.'@'.DOMAIN : $email[0]->private_email;
|
||||||
|
}
|
||||||
|
|
||||||
//TODO: SWITCH TO NOTEN API ONCE NOTENTOOL IS IN MASTER TO AVOID DUPLICATE API
|
//TODO: SWITCH TO NOTEN API ONCE NOTENTOOL IS IN MASTER TO AVOID DUPLICATE API
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -784,7 +801,10 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
|
|
||||||
$allowed_noten_abgabetool = $this->config->item('ALLOWED_NOTEN_ABGABETOOL');
|
$allowed_noten_abgabetool = $this->config->item('ALLOWED_NOTEN_ABGABETOOL');
|
||||||
|
|
||||||
$this->terminateWithSuccess(array($noten, $allowed_noten_abgabetool));
|
$nonfinal_noten_abgabetool = $this->config->item('NONFINAL_NOTEN_ABGABETOOL');
|
||||||
|
|
||||||
|
|
||||||
|
$this->terminateWithSuccess(array($noten, $allowed_noten_abgabetool, $nonfinal_noten_abgabetool));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -886,16 +906,17 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
|
|
||||||
// map the abgaben into projektarbeiten
|
// map the abgaben into projektarbeiten
|
||||||
foreach($projektarbeiten as $projektarbeit) {
|
foreach($projektarbeiten as $projektarbeit) {
|
||||||
|
$projektarbeit->betreuer_mail = $this->getProjektbetreuerEmailByProjektarbeitID($projektarbeit->projektarbeit_id);
|
||||||
|
|
||||||
|
if($projektarbeit->zweitbetreuer_person_id !== null) {
|
||||||
|
$projektarbeit->zweitbetreuer_mail = $this->getProjektbetreuerEmailByPersonID($projektarbeit->zweitbetreuer_person_id);
|
||||||
|
}
|
||||||
|
|
||||||
$filterFunc = function($projektabgabe) use ($projektarbeit) {
|
$filterFunc = function($projektabgabe) use ($projektarbeit) {
|
||||||
return $projektabgabe->projektarbeit_id == $projektarbeit->projektarbeit_id;
|
return $projektabgabe->projektarbeit_id == $projektarbeit->projektarbeit_id;
|
||||||
};
|
};
|
||||||
|
|
||||||
$projektarbeit->abgabetermine = array_values(array_filter($projektabgaben, $filterFunc));
|
$projektarbeit->abgabetermine = array_values(array_filter($projektabgaben, $filterFunc));
|
||||||
|
|
||||||
// check the signature status for enduploads
|
|
||||||
foreach($projektarbeit->abgabetermine as $abgabe) {
|
|
||||||
$this->checkAbgabeSignatur($abgabe, $projektarbeit);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->terminateWithSuccess(array($projektarbeiten, DOMAIN));
|
$this->terminateWithSuccess(array($projektarbeiten, DOMAIN));
|
||||||
@@ -1021,10 +1042,33 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
$this->terminateWithSuccess($result);
|
$this->terminateWithSuccess($result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// used to lazy load signatur status for assistenzen, since they could run into very long fetch times
|
||||||
|
// since they fetch the projektarbeiten with paabgaben included and could have a lot of huge endupload files
|
||||||
|
// in their stg resulting in huge loading times -> use this api call on opening detail component instead
|
||||||
|
public function getSignaturStatusForProjektarbeitAbgaben() {
|
||||||
|
$paabgabe_ids = $this->input->post('paabgabe_ids');
|
||||||
|
$student_uid = $this->input->post('student_uid');
|
||||||
|
|
||||||
|
if ($paabgabe_ids === NULL || $student_uid === NULL || trim((string)$student_uid) === '') {
|
||||||
|
$this->terminateWithError($this->p->t('global', 'wrongParameters'), 'general');
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->load->model('education/Paabgabe_model', 'PaabgabeModel');
|
||||||
|
|
||||||
|
$result = $this->PaabgabeModel->loadByIDs($paabgabe_ids);
|
||||||
|
$data = $this->getDataOrTerminateWithError($result);
|
||||||
|
|
||||||
|
foreach($data as $paabgabetermin) {
|
||||||
|
$this->checkAbgabeSignatur($paabgabetermin, $student_uid);
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->terminateWithSuccess($data);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* helper function to check the signature status of uploaded files for zwischenabgabe & endupload
|
* helper function to check the signature status of uploaded files for zwischenabgabe & endupload
|
||||||
*/
|
*/
|
||||||
private function checkAbgabeSignatur($abgabe, $projektarbeit) {
|
private function checkAbgabeSignatur($abgabe, $student_uid) {
|
||||||
$paabgabetypenToCheck = $this->config->item('SIGNATUR_CHECK_PAABGABETYPEN');
|
$paabgabetypenToCheck = $this->config->item('SIGNATUR_CHECK_PAABGABETYPEN');
|
||||||
|
|
||||||
if(!in_array($abgabe->paabgabetyp_kurzbz, $paabgabetypenToCheck)) {
|
if(!in_array($abgabe->paabgabetyp_kurzbz, $paabgabetypenToCheck)) {
|
||||||
@@ -1036,7 +1080,7 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$path = PAABGABE_PATH.$abgabe->paabgabe_id.'_'.$projektarbeit->student_uid.'.pdf';
|
$path = PAABGABE_PATH.$abgabe->paabgabe_id.'_'.$student_uid.'.pdf';
|
||||||
|
|
||||||
$signaturVorhanden = null; // if frontend receives null -> indicates no file found at path
|
$signaturVorhanden = null; // if frontend receives null -> indicates no file found at path
|
||||||
if(file_exists($path)) {
|
if(file_exists($path)) {
|
||||||
@@ -1121,7 +1165,7 @@ class Abgabe extends FHCAPI_Controller
|
|||||||
$maildata['bewertunglink'] = $projektarbeitIsCurrent && $paabgabetyp_kurzbz == 'end' ? "<p><a href='$mail_fulllink'>Zur Beurteilung der Arbeit</a></p>" : "";
|
$maildata['bewertunglink'] = $projektarbeitIsCurrent && $paabgabetyp_kurzbz == 'end' ? "<p><a href='$mail_fulllink'>Zur Beurteilung der Arbeit</a></p>" : "";
|
||||||
$maildata['token'] = "";
|
$maildata['token'] = "";
|
||||||
|
|
||||||
$email = $this->getProjektbetreuerEmail($projektarbeit_id);
|
$email = $this->getProjektbetreuerEmailByProjektarbeitID($projektarbeit_id);
|
||||||
|
|
||||||
if(!$email) $this->terminateWithError($this->p->t('abgabetool', 'c4fehlerMailBegutachter'), 'general');
|
if(!$email) $this->terminateWithError($this->p->t('abgabetool', 'c4fehlerMailBegutachter'), 'general');
|
||||||
|
|
||||||
|
|||||||
@@ -108,4 +108,10 @@ class Paabgabe_model extends DB_Model
|
|||||||
|
|
||||||
return $this->execQuery($query, [$interval]);
|
return $this->execQuery($query, [$interval]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function loadByIDs($paabgabe_ids) {
|
||||||
|
$qry = "SELECT * FROM campus.tbl_paabgabe WHERE paabgabe_id IN ?";
|
||||||
|
|
||||||
|
return $this->execReadOnlyQuery($qry, [$paabgabe_ids]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -244,6 +244,28 @@ class Projektarbeit_model extends DB_Model
|
|||||||
|
|
||||||
return $this->execReadOnlyQuery($qry, [$projektarbeit_id]);
|
return $this->execReadOnlyQuery($qry, [$projektarbeit_id]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function getProjektbetreuerEmailByPersonID($person_id) {
|
||||||
|
$qry = "SELECT (
|
||||||
|
SELECT kontakt
|
||||||
|
FROM public.tbl_kontakt
|
||||||
|
WHERE kontakttyp = 'email'
|
||||||
|
AND person_id = pers.person_id
|
||||||
|
ORDER BY
|
||||||
|
CASE WHEN zustellung THEN 0 ELSE 1 END,
|
||||||
|
insertamum DESC NULLS LAST
|
||||||
|
LIMIT 1
|
||||||
|
) AS private_email, mitarbeiter_uid as uid
|
||||||
|
FROM lehre.tbl_projektarbeit pa
|
||||||
|
JOIN lehre.tbl_projektbetreuer USING (projektarbeit_id)
|
||||||
|
JOIN public.tbl_person pers USING (person_id)
|
||||||
|
LEFT JOIN public.tbl_benutzer ben USING (person_id)
|
||||||
|
LEFT JOIN public.tbl_mitarbeiter ma ON ben.uid = ma.mitarbeiter_uid
|
||||||
|
WHERE (ben.aktiv OR ben.aktiv IS NULL)
|
||||||
|
AND person_id = ?";
|
||||||
|
|
||||||
|
return $this->execReadOnlyQuery($qry, [$person_id]);
|
||||||
|
}
|
||||||
|
|
||||||
public function getProjektarbeitBenutzer($uid) {
|
public function getProjektarbeitBenutzer($uid) {
|
||||||
$qry="SELECT * FROM campus.vw_benutzer where uid=?";
|
$qry="SELECT * FROM campus.vw_benutzer where uid=?";
|
||||||
@@ -277,7 +299,7 @@ class Projektarbeit_model extends DB_Model
|
|||||||
*
|
*
|
||||||
FROM
|
FROM
|
||||||
(SELECT tbl_person.vorname, tbl_person.nachname, tbl_studiengang.typ, tbl_studiengang.kurzbz,
|
(SELECT tbl_person.vorname, tbl_person.nachname, tbl_studiengang.typ, tbl_studiengang.kurzbz,
|
||||||
tbl_projektarbeit.projekttyp_kurzbz, tbl_projekttyp.bezeichnung, tbl_projektarbeit.titel, tbl_projektarbeit.projektarbeit_id,
|
tbl_projektarbeit.projekttyp_kurzbz, tbl_projekttyp.bezeichnung, tbl_projektarbeit.titel, tbl_projektarbeit.projektarbeit_id, tbl_projektarbeit.note,
|
||||||
tbl_projektbetreuer.person_id as betreuer_person_id, tbl_projektbetreuer.betreuerart_kurzbz, tbl_betreuerart.beschreibung AS betreuerart_beschreibung,
|
tbl_projektbetreuer.person_id as betreuer_person_id, tbl_projektbetreuer.betreuerart_kurzbz, tbl_betreuerart.beschreibung AS betreuerart_beschreibung,
|
||||||
tbl_benutzer.uid, tbl_student.matrikelnr, tbl_lehreinheit.studiensemester_kurzbz, public.tbl_student.student_uid
|
tbl_benutzer.uid, tbl_student.matrikelnr, tbl_lehreinheit.studiensemester_kurzbz, public.tbl_student.student_uid
|
||||||
FROM lehre.tbl_projektarbeit
|
FROM lehre.tbl_projektarbeit
|
||||||
|
|||||||
@@ -27,6 +27,7 @@ $includesArray = array(
|
|||||||
'vendor/npm-asset/primevue/timeline/timeline.min.js',
|
'vendor/npm-asset/primevue/timeline/timeline.min.js',
|
||||||
'vendor/npm-asset/primevue/inplace/inplace.min.js',
|
'vendor/npm-asset/primevue/inplace/inplace.min.js',
|
||||||
'vendor/npm-asset/primevue/message/message.min.js',
|
'vendor/npm-asset/primevue/message/message.min.js',
|
||||||
|
'vendor/npm-asset/primevue/tieredmenu/tieredmenu.js',
|
||||||
'vendor/moment/luxonjs/luxon.min.js'
|
'vendor/moment/luxonjs/luxon.min.js'
|
||||||
),
|
),
|
||||||
'customJSModules' => array(
|
'customJSModules' => array(
|
||||||
|
|||||||
@@ -35,6 +35,7 @@ $includesArray = array(
|
|||||||
'vendor/npm-asset/primevue/timeline/timeline.min.js',
|
'vendor/npm-asset/primevue/timeline/timeline.min.js',
|
||||||
'vendor/npm-asset/primevue/inplace/inplace.min.js',
|
'vendor/npm-asset/primevue/inplace/inplace.min.js',
|
||||||
'vendor/npm-asset/primevue/message/message.min.js',
|
'vendor/npm-asset/primevue/message/message.min.js',
|
||||||
|
'vendor/npm-asset/primevue/tieredmenu/tieredmenu.js',
|
||||||
'vendor/moment/luxonjs/luxon.min.js'
|
'vendor/moment/luxonjs/luxon.min.js'
|
||||||
),
|
),
|
||||||
'customJSModules' => array(
|
'customJSModules' => array(
|
||||||
|
|||||||
@@ -132,5 +132,13 @@ export default {
|
|||||||
params: formData,
|
params: formData,
|
||||||
config: {Headers: { "Content-Type": "multipart/form-data" }}
|
config: {Headers: { "Content-Type": "multipart/form-data" }}
|
||||||
};
|
};
|
||||||
|
},
|
||||||
|
getSignaturStatusForProjektarbeitAbgaben(paabgabe_ids, student_uid) {
|
||||||
|
return {
|
||||||
|
method: 'post',
|
||||||
|
url: '/api/frontend/v1/Abgabe/getSignaturStatusForProjektarbeitAbgaben',
|
||||||
|
params: {paabgabe_ids, student_uid},
|
||||||
|
|
||||||
|
};
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@@ -21,6 +21,7 @@ export const AbgabeMitarbeiterDetail = {
|
|||||||
'abgabeTypeOptions',
|
'abgabeTypeOptions',
|
||||||
'abgabetypenBetreuer',
|
'abgabetypenBetreuer',
|
||||||
'allowedNotenOptions',
|
'allowedNotenOptions',
|
||||||
|
'notenOptionsNonFinal',
|
||||||
'turnitin_link',
|
'turnitin_link',
|
||||||
'old_abgabe_beurteilung_link'
|
'old_abgabe_beurteilung_link'
|
||||||
],
|
],
|
||||||
@@ -48,7 +49,7 @@ export const AbgabeMitarbeiterDetail = {
|
|||||||
label: Vue.computed(() => this.$p.t('abgabetool/c4newAbgabetermin')),
|
label: Vue.computed(() => this.$p.t('abgabetool/c4newAbgabetermin')),
|
||||||
icon: "fa fa-plus",
|
icon: "fa fa-plus",
|
||||||
command: this.openCreateNewAbgabeModal,
|
command: this.openCreateNewAbgabeModal,
|
||||||
disabled: Vue.computed(() => this.projektarbeit?.betreuerart_kurzbz == 'Zweitbegutachter')
|
disabled: Vue.computed(() => !this.getAllowedToCreateNewTermin)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: Vue.computed(() => this.$p.t('abgabetool/c4benoten')),
|
label: Vue.computed(() => this.$p.t('abgabetool/c4benoten')),
|
||||||
@@ -478,6 +479,21 @@ export const AbgabeMitarbeiterDetail = {
|
|||||||
|
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
|
getAllowedToCreateNewTermin() {
|
||||||
|
if(this.assistenzMode) return true
|
||||||
|
if(this.projektarbeit?.betreuerart_kurzbz == 'Zweitbegutachter') return false
|
||||||
|
if(this.projektarbeit?.note !== undefined && this.projektarbeit.note !== null) {
|
||||||
|
// check if the note is not defined as a non final projektarbeit note
|
||||||
|
const opt = this.notenOptionsNonFinal.find(opt => opt.note)
|
||||||
|
// if thats the case allow further work
|
||||||
|
if(opt) return true
|
||||||
|
// else the PA is to be considered finished
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
// normally should be allowed if no rules apply
|
||||||
|
return true
|
||||||
|
},
|
||||||
allowedToSaveZusatzdaten() {
|
allowedToSaveZusatzdaten() {
|
||||||
return this.form.schlagwoerter.length > 0 && this.form.schlagwoerter_en.length > 0 && this.form.abstract.length > 0 && this.form.abstract_en.length > 0 && this.form.seitenanzahl > 0
|
return this.form.schlagwoerter.length > 0 && this.form.schlagwoerter_en.length > 0 && this.form.abstract.length > 0 && this.form.abstract_en.length > 0 && this.form.seitenanzahl > 0
|
||||||
},
|
},
|
||||||
@@ -755,9 +771,8 @@ export const AbgabeMitarbeiterDetail = {
|
|||||||
</div>
|
</div>
|
||||||
<div class="row" style="margin-bottom: 12px;">
|
<div class="row" style="margin-bottom: 12px;">
|
||||||
<div class="col-auto">
|
<div class="col-auto">
|
||||||
<!-- TODO: tooltip why this button is disabled as zweitbegutachter-->
|
<!-- TODO: tooltip why this button is disabled-->
|
||||||
<!-- TODO: fix bug where this button is sometimes correctly disabled, sometimes just wrong when betreuer is both first and second assesor-->
|
<button type="button" :disabled="!getAllowedToCreateNewTermin" class="btn btn-primary" @click="openCreateNewAbgabeModal">
|
||||||
<button type="button" :disabled="projektarbeit?.betreuerart_kurzbz == 'Zweitbegutachter'" class="btn btn-primary" @click="openCreateNewAbgabeModal">
|
|
||||||
<i class="fa-solid fa-plus"></i>
|
<i class="fa-solid fa-plus"></i>
|
||||||
{{$capitalize( $p.t('abgabetool/c4newAbgabetermin') )}}
|
{{$capitalize( $p.t('abgabetool/c4newAbgabetermin') )}}
|
||||||
</button>
|
</button>
|
||||||
|
|||||||
@@ -30,6 +30,7 @@ export const AbgabetoolAssistenz = {
|
|||||||
Inplace: primevue.inplace,
|
Inplace: primevue.inplace,
|
||||||
Textarea: primevue.textarea,
|
Textarea: primevue.textarea,
|
||||||
Timeline: primevue.timeline,
|
Timeline: primevue.timeline,
|
||||||
|
TieredMenu: primevue.tieredmenu,
|
||||||
VueDatePicker,
|
VueDatePicker,
|
||||||
FhcOverlay
|
FhcOverlay
|
||||||
},
|
},
|
||||||
@@ -37,6 +38,7 @@ export const AbgabetoolAssistenz = {
|
|||||||
return {
|
return {
|
||||||
abgabeTypeOptions: Vue.computed(() => this.abgabeTypeOptions),
|
abgabeTypeOptions: Vue.computed(() => this.abgabeTypeOptions),
|
||||||
allowedNotenOptions: Vue.computed(() => this.allowedNotenOptions),
|
allowedNotenOptions: Vue.computed(() => this.allowedNotenOptions),
|
||||||
|
notenOptionsNonFinal: Vue.computed(() => this.notenOptionsNonFinal),
|
||||||
turnitin_link: Vue.computed(() => this.turnitin_link),
|
turnitin_link: Vue.computed(() => this.turnitin_link),
|
||||||
old_abgabe_beurteilung_link: Vue.computed(() => this.old_abgabe_beurteilung_link),
|
old_abgabe_beurteilung_link: Vue.computed(() => this.old_abgabe_beurteilung_link),
|
||||||
abgabetypenBetreuer: Vue.computed(() => this.abgabeTypeOptions)
|
abgabetypenBetreuer: Vue.computed(() => this.abgabeTypeOptions)
|
||||||
@@ -77,12 +79,15 @@ export const AbgabetoolAssistenz = {
|
|||||||
phrasenResolved: false,
|
phrasenResolved: false,
|
||||||
turnitin_link: null,
|
turnitin_link: null,
|
||||||
old_abgabe_beurteilung_link: null,
|
old_abgabe_beurteilung_link: null,
|
||||||
|
ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT: null,
|
||||||
|
ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER: null,
|
||||||
saving: false,
|
saving: false,
|
||||||
loading: false,
|
loading: false,
|
||||||
abgabeTypeOptions: null,
|
abgabeTypeOptions: null,
|
||||||
notenOptions: null,
|
notenOptions: null,
|
||||||
allowedNotenFilterOptions: null,
|
allowedNotenFilterOptions: null,
|
||||||
allowedNotenOptions: null,
|
allowedNotenOptions: null,
|
||||||
|
notenOptionsNonFinal: null,
|
||||||
serienTermin: Vue.reactive({
|
serienTermin: Vue.reactive({
|
||||||
datum: new Date(),
|
datum: new Date(),
|
||||||
bezeichnung: {
|
bezeichnung: {
|
||||||
@@ -221,6 +226,32 @@ export const AbgabetoolAssistenz = {
|
|||||||
]};
|
]};
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
|
sammelMailStudent() {
|
||||||
|
const emails = this.selectedData
|
||||||
|
.map(row => `${row.student_uid}@${this.domain}`)
|
||||||
|
.join(',');
|
||||||
|
|
||||||
|
const subject = this.$p.t('abgabetool/c4sammelmailStudentBetreff', [this.selectedStudiengangOption?.bezeichnung]);
|
||||||
|
|
||||||
|
const href = `mailto:${emails}?subject=${subject}`;
|
||||||
|
|
||||||
|
window.location.href = href
|
||||||
|
},
|
||||||
|
sammelMailBetreuer() {
|
||||||
|
const recipientList = [];
|
||||||
|
this.selectedData.forEach(row => {
|
||||||
|
if (row.betreuer_mail) recipientList.push(row.betreuer_mail);
|
||||||
|
if (row.zweitbetreuer_mail) recipientList.push(row.zweitbetreuer_mail);
|
||||||
|
});
|
||||||
|
|
||||||
|
// actually not necessary for email clients but looks better for assistenz if we avoid duplicates here
|
||||||
|
const uniqueRecipients = [...new Set(recipientList)];
|
||||||
|
|
||||||
|
const subject = this.$p.t('abgabetool/c4sammelmailBetreuerBetreff', [this.selectedStudiengangOption?.bezeichnung]);
|
||||||
|
const href = `mailto:${uniqueRecipients.join(',')}?subject=${encodeURIComponent(subject)}`;
|
||||||
|
|
||||||
|
window.location.href = href;
|
||||||
|
},
|
||||||
selectHandler(e, cell) {
|
selectHandler(e, cell) {
|
||||||
const row = cell.getRow();
|
const row = cell.getRow();
|
||||||
|
|
||||||
@@ -620,9 +651,8 @@ export const AbgabetoolAssistenz = {
|
|||||||
|
|
||||||
const mappedData = this.mapProjekteToTableData(this.projektarbeiten)
|
const mappedData = this.mapProjekteToTableData(this.projektarbeiten)
|
||||||
|
|
||||||
this.$refs.abgabeTable.tabulator.setColumns(this.abgabeTableOptions.columns)
|
|
||||||
this.$refs.abgabeTable.tabulator.setData(mappedData)
|
this.$refs.abgabeTable.tabulator.setData(mappedData)
|
||||||
|
this.$refs.abgabeTable.tabulator.redraw(true)
|
||||||
}).finally(()=>{
|
}).finally(()=>{
|
||||||
this.saving = false
|
this.saving = false
|
||||||
})
|
})
|
||||||
@@ -684,7 +714,18 @@ export const AbgabetoolAssistenz = {
|
|||||||
|
|
||||||
const pa = this.projektarbeiten.find(projektarbeit => projektarbeit.projektarbeit_id == details.projektarbeit_id)
|
const pa = this.projektarbeiten.find(projektarbeit => projektarbeit.projektarbeit_id == details.projektarbeit_id)
|
||||||
|
|
||||||
// pa.isCurrent = res.data[1]
|
if(pa?.abgabetermine?.length) {
|
||||||
|
this.$api.call(ApiAbgabe.getSignaturStatusForProjektarbeitAbgaben(pa.abgabetermine.map(termin => termin.paabgabe_id), pa.student_uid))
|
||||||
|
.then(res => {
|
||||||
|
if(res.meta.status === 'success') {
|
||||||
|
res.data.forEach(paabgabe => {
|
||||||
|
const termin = pa.abgabetermine.find(abgabe => abgabe.paabgabe_id == paabgabe.paabgabe_id)
|
||||||
|
if(termin && paabgabe.signatur !== undefined) termin.signatur = paabgabe.signatur
|
||||||
|
})
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
const paIsBenotet = pa.note !== null
|
const paIsBenotet = pa.note !== null
|
||||||
|
|
||||||
pa.abgabetermine.forEach(termin => {
|
pa.abgabetermine.forEach(termin => {
|
||||||
@@ -856,8 +897,8 @@ export const AbgabetoolAssistenz = {
|
|||||||
tableResolve(resolve) {
|
tableResolve(resolve) {
|
||||||
this.tableBuiltResolve = resolve
|
this.tableBuiltResolve = resolve
|
||||||
},
|
},
|
||||||
buildMailToLink(abgabe) {
|
buildMailToLink(projekt) {
|
||||||
return 'mailto:' + abgabe.student_uid +'@'+ this.domain
|
return 'mailto:' + projekt.student_uid +'@'+ this.domain
|
||||||
},
|
},
|
||||||
buildPKZ(projekt) {
|
buildPKZ(projekt) {
|
||||||
return `${projekt.student_uid} / ${projekt.matrikelnr}`
|
return `${projekt.student_uid} / ${projekt.matrikelnr}`
|
||||||
@@ -930,6 +971,48 @@ export const AbgabetoolAssistenz = {
|
|||||||
this.calcMaxTableHeight()
|
this.calcMaxTableHeight()
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
computed: {
|
||||||
|
emailItems() {
|
||||||
|
const menu = []
|
||||||
|
|
||||||
|
if(this.ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT){
|
||||||
|
menu.push({
|
||||||
|
label: this.$p.t('abgabetool/c4sendEmailStudierendev2', [this.uniqueStudentEmailCount]),
|
||||||
|
command: this.sammelMailStudent
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
if(this.ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER) {
|
||||||
|
menu.push({
|
||||||
|
label: this.$p.t('abgabetool/c4sendEmailBetreuerv2', [this.uniqueBetreuerEmailCount]),
|
||||||
|
command: this.sammelMailBetreuer
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
return menu
|
||||||
|
},
|
||||||
|
uniqueBetreuerEmailCount() {
|
||||||
|
const emails = new Set();
|
||||||
|
|
||||||
|
this.selectedData.forEach(row => {
|
||||||
|
if (row.betreuer_mail) emails.add(row.betreuer_mail);
|
||||||
|
if (row.zweitbetreuer_mail) emails.add(row.zweitbetreuer_mail);
|
||||||
|
});
|
||||||
|
|
||||||
|
return emails.size;
|
||||||
|
},
|
||||||
|
uniqueStudentEmailCount() {
|
||||||
|
const emails = new Set();
|
||||||
|
|
||||||
|
this.selectedData.forEach(row => {
|
||||||
|
if (row.student_uid) {
|
||||||
|
emails.add(row.student_uid); // actually dont need domain for this
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return emails.size;
|
||||||
|
}
|
||||||
|
},
|
||||||
watch: {
|
watch: {
|
||||||
'serienTermin.bezeichnung'(newVal) {
|
'serienTermin.bezeichnung'(newVal) {
|
||||||
if(newVal?.paabgabetyp_kurzbz === 'qualgate1' || newVal?.paabgabetyp_kurzbz === 'qualgate2') {
|
if(newVal?.paabgabetyp_kurzbz === 'qualgate1' || newVal?.paabgabetyp_kurzbz === 'qualgate2') {
|
||||||
@@ -976,6 +1059,8 @@ export const AbgabetoolAssistenz = {
|
|||||||
const res = results[0].value;
|
const res = results[0].value;
|
||||||
this.turnitin_link = res.data?.turnitin_link;
|
this.turnitin_link = res.data?.turnitin_link;
|
||||||
this.old_abgabe_beurteilung_link = res.data?.old_abgabe_beurteilung_link;
|
this.old_abgabe_beurteilung_link = res.data?.old_abgabe_beurteilung_link;
|
||||||
|
this.ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT = res.data?.ASSISTENZ_SAMMELMAIL_BUTTON_STUDENT;
|
||||||
|
this.ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER = res.data?.ASSISTENZ_SAMMELMAIL_BUTTON_BETREUER;
|
||||||
}
|
}
|
||||||
|
|
||||||
// 2. Studiengänge
|
// 2. Studiengänge
|
||||||
@@ -1006,6 +1091,10 @@ export const AbgabetoolAssistenz = {
|
|||||||
this.allowedNotenOptions = this.notenOptions.filter(
|
this.allowedNotenOptions = this.notenOptions.filter(
|
||||||
opt => res.data[1].includes(opt.note)
|
opt => res.data[1].includes(opt.note)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
this.notenOptionsNonFinal = this.notenOptions.filter(
|
||||||
|
opt => res.data[2].includes(opt.note)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
this.allowedNotenFilterOptions = [
|
this.allowedNotenFilterOptions = [
|
||||||
@@ -1293,6 +1382,17 @@ export const AbgabetoolAssistenz = {
|
|||||||
<div>{{ option.studiensemester_kurzbz }}</div>
|
<div>{{ option.studiensemester_kurzbz }}</div>
|
||||||
</template>
|
</template>
|
||||||
</Dropdown>
|
</Dropdown>
|
||||||
|
|
||||||
|
<button
|
||||||
|
v-if="emailItems.length"
|
||||||
|
role="button"
|
||||||
|
@click="evt => $refs.menu.toggle(evt)"
|
||||||
|
class="btn btn-outline-secondary dropdown-toggle"
|
||||||
|
aria-haspopup="true"
|
||||||
|
>
|
||||||
|
<i class="fa fa-envelope"></i>
|
||||||
|
</button>
|
||||||
|
<tiered-menu ref="menu" :model="emailItems" popup/>
|
||||||
</template>
|
</template>
|
||||||
</core-filter-cmpt>
|
</core-filter-cmpt>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -22,6 +22,7 @@ export const AbgabetoolMitarbeiter = {
|
|||||||
abgabeTypeOptions: Vue.computed(() => this.abgabeTypeOptions),
|
abgabeTypeOptions: Vue.computed(() => this.abgabeTypeOptions),
|
||||||
abgabetypenBetreuer: Vue.computed(() => this.abgabetypenBetreuer),
|
abgabetypenBetreuer: Vue.computed(() => this.abgabetypenBetreuer),
|
||||||
allowedNotenOptions: Vue.computed(() => this.allowedNotenOptions),
|
allowedNotenOptions: Vue.computed(() => this.allowedNotenOptions),
|
||||||
|
notenOptionsNonFinal: Vue.computed(() => this.notenOptionsNonFinal),
|
||||||
turnitin_link: Vue.computed(() => this.turnitin_link),
|
turnitin_link: Vue.computed(() => this.turnitin_link),
|
||||||
old_abgabe_beurteilung_link: Vue.computed(() => this.old_abgabe_beurteilung_link)
|
old_abgabe_beurteilung_link: Vue.computed(() => this.old_abgabe_beurteilung_link)
|
||||||
}
|
}
|
||||||
@@ -50,6 +51,7 @@ export const AbgabetoolMitarbeiter = {
|
|||||||
abgabeTypeOptions: null,
|
abgabeTypeOptions: null,
|
||||||
notenOptions: null,
|
notenOptions: null,
|
||||||
allowedNotenOptions: null,
|
allowedNotenOptions: null,
|
||||||
|
notenOptionsNonFinal: null,
|
||||||
serienTermin: Vue.reactive({
|
serienTermin: Vue.reactive({
|
||||||
datum: new Date(),
|
datum: new Date(),
|
||||||
bezeichnung: {
|
bezeichnung: {
|
||||||
@@ -301,7 +303,15 @@ export const AbgabetoolMitarbeiter = {
|
|||||||
pa.abgabetermine = res.data[0].retval
|
pa.abgabetermine = res.data[0].retval
|
||||||
pa.isCurrent = res.data[1]
|
pa.isCurrent = res.data[1]
|
||||||
|
|
||||||
const paIsBenotet = pa.note !== null
|
let paIsBenotet = false
|
||||||
|
if(pa.note !== undefined && pa !== null) {
|
||||||
|
// check if the note is not defined as a non final projektarbeit note
|
||||||
|
const opt = this.notenOptionsNonFinal.find(opt => opt.note)
|
||||||
|
// if thats the case allow further work
|
||||||
|
if(opt) paIsBenotet = false
|
||||||
|
// else the PA is to be considered finished
|
||||||
|
paIsBenotet = true
|
||||||
|
}
|
||||||
|
|
||||||
pa.abgabetermine.forEach(termin => {
|
pa.abgabetermine.forEach(termin => {
|
||||||
termin.note = this.allowedNotenOptions.find(opt => opt.note == termin.note)
|
termin.note = this.allowedNotenOptions.find(opt => opt.note == termin.note)
|
||||||
@@ -471,6 +481,10 @@ export const AbgabetoolMitarbeiter = {
|
|||||||
this.allowedNotenOptions = this.notenOptions.filter(
|
this.allowedNotenOptions = this.notenOptions.filter(
|
||||||
opt => res.data[1].includes(opt.note)
|
opt => res.data[1].includes(opt.note)
|
||||||
)
|
)
|
||||||
|
|
||||||
|
this.notenOptionsNonFinal = this.notenOptions.filter(
|
||||||
|
opt => res.data[2].includes(opt.note)
|
||||||
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
}).catch(e => {
|
}).catch(e => {
|
||||||
|
|||||||
@@ -45550,18 +45550,18 @@ array(
|
|||||||
array(
|
array(
|
||||||
'app' => 'core',
|
'app' => 'core',
|
||||||
'category' => 'abgabetool',
|
'category' => 'abgabetool',
|
||||||
'phrase' => 'c4sendEmailStudierende',
|
'phrase' => 'c4sendEmailStudierendev2',
|
||||||
'insertvon' => 'system',
|
'insertvon' => 'system',
|
||||||
'phrases' => array(
|
'phrases' => array(
|
||||||
array(
|
array(
|
||||||
'sprache' => 'German',
|
'sprache' => 'German',
|
||||||
'text' => 'Email an Studierende schicken',
|
'text' => 'Email an {0} Studierende schicken',
|
||||||
'description' => '',
|
'description' => '',
|
||||||
'insertvon' => 'system'
|
'insertvon' => 'system'
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
'sprache' => 'English',
|
'sprache' => 'English',
|
||||||
'text' => 'Send Email to students',
|
'text' => 'Send Email to {0} students',
|
||||||
'description' => '',
|
'description' => '',
|
||||||
'insertvon' => 'system'
|
'insertvon' => 'system'
|
||||||
)
|
)
|
||||||
@@ -45570,18 +45570,58 @@ array(
|
|||||||
array(
|
array(
|
||||||
'app' => 'core',
|
'app' => 'core',
|
||||||
'category' => 'abgabetool',
|
'category' => 'abgabetool',
|
||||||
'phrase' => 'c4sendEmailBetreuer',
|
'phrase' => 'c4sammelmailStudentBetreff',
|
||||||
'insertvon' => 'system',
|
'insertvon' => 'system',
|
||||||
'phrases' => array(
|
'phrases' => array(
|
||||||
array(
|
array(
|
||||||
'sprache' => 'German',
|
'sprache' => 'German',
|
||||||
'text' => 'Email an Betreuende schicken',
|
'text' => 'Betreuungen Bachelorarbeit bzw. Master Thesis bei Studiengang {0}',
|
||||||
'description' => '',
|
'description' => '',
|
||||||
'insertvon' => 'system'
|
'insertvon' => 'system'
|
||||||
),
|
),
|
||||||
array(
|
array(
|
||||||
'sprache' => 'English',
|
'sprache' => 'English',
|
||||||
'text' => 'Send Email to assessors',
|
'text' => "Supervision of Bachelor's thesis or Master's thesis for degree program {0}",
|
||||||
|
'description' => '',
|
||||||
|
'insertvon' => 'system'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'app' => 'core',
|
||||||
|
'category' => 'abgabetool',
|
||||||
|
'phrase' => 'c4sendEmailBetreuerv2',
|
||||||
|
'insertvon' => 'system',
|
||||||
|
'phrases' => array(
|
||||||
|
array(
|
||||||
|
'sprache' => 'German',
|
||||||
|
'text' => 'Email an {0} Betreuende schicken',
|
||||||
|
'description' => '',
|
||||||
|
'insertvon' => 'system'
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'sprache' => 'English',
|
||||||
|
'text' => 'Send Email to {0} assessors',
|
||||||
|
'description' => '',
|
||||||
|
'insertvon' => 'system'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'app' => 'core',
|
||||||
|
'category' => 'abgabetool',
|
||||||
|
'phrase' => 'c4sammelmailBetreuerBetreff',
|
||||||
|
'insertvon' => 'system',
|
||||||
|
'phrases' => array(
|
||||||
|
array(
|
||||||
|
'sprache' => 'German',
|
||||||
|
'text' => 'Betreuungen Bachelorarbeit bzw. Master Thesis bei Studiengang {0}',
|
||||||
|
'description' => '',
|
||||||
|
'insertvon' => 'system'
|
||||||
|
),
|
||||||
|
array(
|
||||||
|
'sprache' => 'English',
|
||||||
|
'text' => "Supervision of Bachelor's thesis or Master's thesis for degree program {0}",
|
||||||
'description' => '',
|
'description' => '',
|
||||||
'insertvon' => 'system'
|
'insertvon' => 'system'
|
||||||
)
|
)
|
||||||
|
|||||||
Reference in New Issue
Block a user