diff --git a/application/controllers/system/Users.php b/application/controllers/system/Users.php deleted file mode 100644 index db58980ea..000000000 --- a/application/controllers/system/Users.php +++ /dev/null @@ -1,222 +0,0 @@ -load->helper('message'); - - // Load the library to use the widgets - $this->load->library('TemplateLib'); - } - - public function index() - { - $studiengang = $this->input->post('studiengang'); - $studiensemester = $this->input->post('studiensemester'); - $gruppe = $this->input->post('gruppe'); - $reihungstest = $this->input->post('reihungstest'); - $stufe = $this->input->post('stufe'); - - $returnUsers = null; - if ($studiengang != null || $studiensemester != null || $gruppe!= null - || $reihungstest != null || $stufe != null) - { - $returnUsers = $this->_getUsers($studiengang, $studiensemester, $gruppe, $reihungstest, $stufe); - } - - $users = null; - if (hasData($returnUsers)) - { - $users = $returnUsers->retval; - } - - // Gruppen - $this->load->model('organisation/Gruppe_model', 'GruppeModel'); - $this->GruppeModel->addOrder('beschreibung'); - $gruppen = $this->GruppeModel->loadWhere(array('aktiv' => true, 'aufnahmegruppe' => true)); - if (hasData($gruppen)) - { - // Adding an empty element at the beginning - $emptyElement = new stdClass(); - $emptyElement->gruppe_kurzbz = '-1'; - $emptyElement->beschreibung = 'Select a group...'; - array_unshift($gruppen->retval, $emptyElement); - } - else - { - show_error($gruppen->retval); - } - - // Stufe - $this->load->model('crm/Reihungstest_model', 'ReihungstestModel'); - $this->ReihungstestModel->addSelect('DISTINCT ON(stufe) stufe, stufe AS beschreibung'); - $this->ReihungstestModel->addOrder('stufe'); - $stufen = $this->ReihungstestModel->loadWhere('stufe IS NOT NULL'); - if (hasData($stufen)) - { - // Adding an empty element at the beginning - $emptyElement = new stdClass(); - $emptyElement->stufe = '-1'; - $emptyElement->beschreibung = 'Select a stufe...'; - array_unshift($stufen->retval, $emptyElement); - } - else - { - show_error($stufen->retval); - } - - if ($returnUsers == null || isSuccess($returnUsers)) - { - $viewData = array( - 'studiengang' => $studiengang, - 'studiensemester' => $studiensemester, - 'gruppe' => $gruppe, - 'reihungstest' => $reihungstest, - 'stufe' => $stufe, - 'users' => $users, - 'gruppen' => $gruppen->retval, - 'stufen' => $stufen->retval - ); - - $this->load->view('system/users', $viewData); - } - else if (isError($returnUsers)) - { - show_error($returnUsers->retval); - } - } - - public function linkToStufe() - { - $prestudentIdArray = $this->input->post('prestudent_id'); - $stufe = $this->input->post('stufe'); - - // Load model PrestudentstatusModel - $this->load->model('crm/Prestudentstatus_model', 'PrestudentstatusModel'); - - $result = error("No valid parameters"); - if (isset($stufe) && isset($prestudentIdArray) && is_array($prestudentIdArray) && count($prestudentIdArray) >0) - { - $result = $this->PrestudentstatusModel->updateStufe($prestudentIdArray, $stufe); - } - - $this->output->set_header('Content-Type: application/json; charset=utf-8'); - - if (isSuccess($result)) - { - $href = str_replace("/system/Users/linkToStufe", "/system/Users", $_SERVER["REQUEST_URI"]); - echo '{"msg": "Data correctly saved"}'; - } - else - { - echo '{"msg": "Error occurred while saving data, please contact the administrator"}'; - } - } - - public function linkToAufnahmegruppe() - { - $prestudentIdArray = $this->input->post('prestudent_id'); - $aufnahmegruppe = $this->input->post('aufnahmegruppe'); - - // Load model PrestudentstatusModel - $this->load->model('crm/Prestudent_model', 'PrestudentModel'); - - $result = error("No valid parameters"); - if (isset($aufnahmegruppe) && isset($prestudentIdArray) && is_array($prestudentIdArray) && count($prestudentIdArray) >0) - { - $result = $this->PrestudentModel->updateAufnahmegruppe($prestudentIdArray, $aufnahmegruppe); - } - - if (isSuccess($result)) - { - $href = str_replace("/system/Users/linkToAufnahmegruppe", "/system/Users", $_SERVER["REQUEST_URI"]); - echo '{"msg": "Data correctly saved"}'; - } - else - { - echo '{"msg": "Error occurred while saving data, please contact the administrator"}'; - } - } - - private function _getUsers($studiengang, $studiensemester, $gruppe, $reihungstest, $stufe) - { - // Load model prestudentm_model - $this->load->model('crm/Prestudent_model', 'PrestudentModel'); - - $this->PrestudentModel->addSelect( - 'DISTINCT ON(p.person_id, prestudent_id) p.person_id, - prestudent_id, - p.nachname, - p.vorname, - p.geschlecht, - p.gebdatum, - k.kontakt AS email, - sg.kurzbzlang, - sg.bezeichnung, - sg.orgform_kurzbz, - sgt.bezeichnung AS typ, - s.bezeichnung AS studienplan, - ps.rt_stufe, - aufnahmegruppe_kurzbz, - rtp.punkte' - ); - - $this->PrestudentModel->addJoin('public.tbl_rt_person rtp', 'person_id'); - $this->PrestudentModel->addJoin('public.tbl_person p', 'person_id', 'LEFT'); - $this->PrestudentModel->addJoin( - '( - SELECT person_id, - kontakt - FROM public.tbl_kontakt - WHERE zustellung = TRUE - AND kontakttyp = \'email\' - ORDER BY kontakt_id DESC - ) k', - 'person_id', - 'LEFT' - ); - $this->PrestudentModel->addJoin('public.tbl_prestudentstatus ps', 'prestudent_id'); - $this->PrestudentModel->addJoin('lehre.tbl_studienplan s', 's.studienplan_id = ps.studienplan_id'); - $this->PrestudentModel->addJoin('lehre.tbl_studienordnung so', 'studienordnung_id'); - $this->PrestudentModel->addJoin('public.tbl_studiengang sg', 'sg.studiengang_kz = so.studiengang_kz'); - $this->PrestudentModel->addJoin('public.tbl_studiengangstyp sgt', 'typ'); - - $this->PrestudentModel->addOrder('p.person_id', 'ASC'); - $this->PrestudentModel->addOrder('prestudent_id', 'ASC'); - - $parametersArray = array('p.aktiv' => true, 'ps.status_kurzbz' => 'Interessent'); - - if ($studiengang != null && $studiengang != '-1') - { - $parametersArray['sg.studiengang_kz'] = $studiengang; - } - - if ($studiensemester != null && $studiensemester != '-1') - { - $parametersArray['ps.studiensemester_kurzbz'] = $studiensemester; - } - - if ($gruppe != null && $gruppe != '-1') - { - $parametersArray['aufnahmegruppe_kurzbz'] = $gruppe; - } - - if ($reihungstest != null && $reihungstest != '-1') - { - $parametersArray['rtp.rt_id'] = $reihungstest; - } - - if ($stufe != null && $stufe != '-1') - { - $parametersArray['ps.rt_stufe'] = $stufe; - } - - return $this->PrestudentModel->loadWhere($parametersArray); - } -} \ No newline at end of file diff --git a/application/controllers/system/aufnahme/PrestudentMultiAssign.php b/application/controllers/system/aufnahme/PrestudentMultiAssign.php new file mode 100644 index 000000000..b171f432e --- /dev/null +++ b/application/controllers/system/aufnahme/PrestudentMultiAssign.php @@ -0,0 +1,157 @@ +load->helper('message'); + + // Loads the widget library + $this->load->library('WidgetLib'); + } + + public function index() + { + $studiengang = $this->input->post('studiengang'); + $studiensemester = $this->input->post('studiensemester'); + $aufnahmegruppe = $this->input->post('aufnahmegruppe'); + $reihungstest = $this->input->post('reihungstest'); + $stufe = $this->input->post('stufe'); + + $returnUsers = null; + if ($studiengang != null || $studiensemester != null || $aufnahmegruppe!= null + || $reihungstest != null || $stufe != null) + { + $returnUsers = $this->_getPrestudents($studiengang, $studiensemester, $aufnahmegruppe, $reihungstest, $stufe); + } + + $users = null; + if (hasData($returnUsers)) + { + $users = $returnUsers->retval; + } + + if ($returnUsers == null || isSuccess($returnUsers)) + { + $viewData = array( + 'studiengang' => $studiengang, + 'studiensemester' => $studiensemester, + 'aufnahmegruppe' => $aufnahmegruppe, + 'reihungstest' => $reihungstest, + 'stufe' => $stufe, + 'users' => $users + ); + + $this->load->view('system/aufnahme/prestudentMultiAssign', $viewData); + } + else if (isError($returnUsers)) + { + show_error($returnUsers->retval); + } + } + + /** + * To assign a stufe to one or more prestudents + */ + public function linkToStufe() + { + $prestudentIdArray = $this->input->post('prestudent_id'); + $stufe = $this->input->post('stufe'); + + // Load model PrestudentstatusModel + $this->load->model('crm/Prestudentstatus_model', 'PrestudentstatusModel'); + + $result = error("No valid parameters"); + if (isset($stufe) && isset($prestudentIdArray) && is_array($prestudentIdArray) && count($prestudentIdArray) >0) + { + $result = $this->PrestudentstatusModel->updateStufe($prestudentIdArray, $stufe); + } + + $this->output->set_header('Content-Type: application/json; charset=utf-8'); + + if (isSuccess($result)) + { + echo '{"msg": "Data correctly saved"}'; + } + else + { + echo '{"msg": "Error occurred while saving data, please contact the administrator"}'; + } + } + + /** + * To assign one or more prestudents to a gruppe + */ + public function linkToAufnahmegruppe() + { + $prestudentIdArray = $this->input->post('prestudent_id'); + $aufnahmegruppe = $this->input->post('aufnahmegruppe'); + + // Load model PrestudentstatusModel + $this->load->model('crm/Prestudent_model', 'PrestudentModel'); + + $result = error("No valid parameters"); + if (isset($aufnahmegruppe) && isset($prestudentIdArray) && is_array($prestudentIdArray) && count($prestudentIdArray) >0) + { + $result = $this->PrestudentModel->updateAufnahmegruppe($prestudentIdArray, $aufnahmegruppe); + } + + $this->output->set_header('Content-Type: application/json; charset=utf-8'); + + if (isSuccess($result)) + { + echo '{"msg": "Data correctly saved"}'; + } + else + { + echo '{"msg": "Error occurred while saving data, please contact the administrator"}'; + } + } + + /** + * Get the prestudents using search parameters + */ + private function _getPrestudents($studiengang, $studiensemester, $aufnahmegruppe, $reihungstest, $stufe) + { + // Load model prestudentm_model + $this->load->model('crm/Prestudent_model', 'PrestudentModel'); + + if ($studiengang == '' || empty($studiengang)) + { + $studiengang = null; + } + + if ($studiensemester == '' || empty($studiensemester)) + { + $studiensemester = null; + } + + if ($aufnahmegruppe == '' || empty($aufnahmegruppe)) + { + $aufnahmegruppe = null; + } + + if ($reihungstest == '' || empty($reihungstest)) + { + $reihungstest = null; + } + + if ($stufe == '' || empty($stufe)) + { + $stufe = null; + } + + return $this->PrestudentModel->getPrestudentMultiAssign( + $studiengang, + $studiensemester, + $aufnahmegruppe, + $reihungstest, + $stufe + ); + } +} \ No newline at end of file diff --git a/application/libraries/WidgetLib.php b/application/libraries/WidgetLib.php index e8e8d302a..61128d7ed 100644 --- a/application/libraries/WidgetLib.php +++ b/application/libraries/WidgetLib.php @@ -181,7 +181,8 @@ class WidgetLib * @param array $data * @return Widget */ - public function widget($name, $data = array()) { + public function widget($name, $data = array(), $htmlArgs = array()) + { $class = str_replace('.php', '', trim($name, '/')); // determine path and widget class name @@ -208,7 +209,7 @@ class WidgetLib show_error("Widget '" . $class . "' was not found."); } - return new $class($class, $data); + return new $class($class, $data, $htmlArgs); } /** @@ -333,6 +334,7 @@ class WidgetLib class Partial { + const HTML_DEFAULT_VALUE = ''; // Default value of the html element protected $_ci, $_content, $_name, $_cache_ttl = 0, $_cached = false, $_identifier, $_trigger; protected $_args = array(); @@ -341,10 +343,17 @@ class Partial * Construct with optional parameters * @param array $args */ - public function __construct($name, $args = array()) { + public function __construct($name, $args = array(), $htmlArgs = array()) + { $this->_ci = &get_instance(); $this->_args = $args; $this->_name = $name; + + // Initialising properties + $this->_setHtmlProperties($htmlArgs); + + // Loads helper message to manage returning messages + $this->load->helper('message'); } /** @@ -598,6 +607,35 @@ class Partial $this->_trigger = FALSE; } } + + /** + * Initialising properties + */ + private function _setHtmlProperties($htmlArgs) + { + if (isset($htmlArgs) && is_array($htmlArgs)) + { + $this->_args['html'] = array(); + + if (!isset($htmlArgs['id']) || (isset($htmlArgs['id']) && $htmlArgs['id'] == '')) + { + $this->_args['html']['id'] = ''; + } + else + { + $this->_args['html']['id'] = $htmlArgs['id']; + } + + if (!isset($htmlArgs['name']) || (isset($htmlArgs['name']) && $htmlArgs['name'] == '')) + { + $this->_args['html']['name'] = ''; + } + else + { + $this->_args['html']['name'] = $htmlArgs['name']; + } + } + } } class Widget extends Partial diff --git a/application/models/crm/Prestudent_model.php b/application/models/crm/Prestudent_model.php index a638f04fa..eeeaf5c69 100644 --- a/application/models/crm/Prestudent_model.php +++ b/application/models/crm/Prestudent_model.php @@ -74,4 +74,87 @@ class Prestudent_model extends DB_Model ) ); } + + /** + * Returns a list of prestudent with additional information: + * - person_id + * - name, surname, gender and birthday + * - email + * - studiengang and orgform + * - studienplan + * - stufe and aufnahmegruppe + * - reihungstest score + */ + public function getPrestudentMultiAssign($studiengang = null, $studiensemester = null, $gruppe = null, $reihungstest = null, $stufe = null) + { + $this->addSelect( + 'DISTINCT ON(p.person_id, prestudent_id) p.person_id, + prestudent_id, + p.nachname, + p.vorname, + p.geschlecht, + p.gebdatum, + k.kontakt AS email, + sg.kurzbzlang, + sg.bezeichnung, + sg.orgform_kurzbz, + sgt.bezeichnung AS typ, + s.bezeichnung AS studienplan, + ps.rt_stufe, + aufnahmegruppe_kurzbz, + rtp.punkte' + ); + + $this->addJoin('public.tbl_rt_person rtp', 'person_id'); + $this->addJoin('public.tbl_person p', 'person_id', 'LEFT'); + $this->addJoin( + '( + SELECT person_id, + kontakt + FROM public.tbl_kontakt + WHERE zustellung = TRUE + AND kontakttyp = \'email\' + ORDER BY kontakt_id DESC + ) k', + 'person_id', + 'LEFT' + ); + $this->addJoin('public.tbl_prestudentstatus ps', 'prestudent_id'); + $this->addJoin('lehre.tbl_studienplan s', 's.studienplan_id = ps.studienplan_id'); + $this->addJoin('lehre.tbl_studienordnung so', 'studienordnung_id'); + $this->addJoin('public.tbl_studiengang sg', 'sg.studiengang_kz = so.studiengang_kz'); + $this->addJoin('public.tbl_studiengangstyp sgt', 'typ'); + + $this->addOrder('p.person_id', 'ASC'); + $this->addOrder('prestudent_id', 'ASC'); + + $parametersArray = array('p.aktiv' => true, 'ps.status_kurzbz' => 'Interessent'); + + if ($studiengang != null) + { + $parametersArray['sg.studiengang_kz'] = $studiengang; + } + + if ($studiensemester != null) + { + $parametersArray['ps.studiensemester_kurzbz'] = $studiensemester; + } + + if ($gruppe != null) + { + $parametersArray['aufnahmegruppe_kurzbz'] = $gruppe; + } + + if ($reihungstest != null) + { + $parametersArray['rtp.rt_id'] = $reihungstest; + } + + if ($stufe != null) + { + $parametersArray['ps.rt_stufe'] = $stufe; + } + + return $this->loadWhere($parametersArray); + } } \ No newline at end of file diff --git a/application/views/system/aufnahme/prestudentMultiAssign.php b/application/views/system/aufnahme/prestudentMultiAssign.php new file mode 100644 index 000000000..769e6f834 --- /dev/null +++ b/application/views/system/aufnahme/prestudentMultiAssign.php @@ -0,0 +1,333 @@ +load->view("templates/header", array("title" => "Users manager", "jquery" => true, "tablesort" => true, "jquery_checkboxes" => true, "jquery_custom" => true)); ?> + +
+ + +| - - | -- - | -- - | -
| - - | -- - | -|