123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Class CourseDescriptionController
- * This file contains class used like controller,
- * it should be included inside a dispatcher file (e.g: index.php).
- *
- * @author Christian Fasanando <christian1827@gmail.com>
- *
- * @package chamilo.course_description
- */
- class CourseDescriptionController
- {
- private $toolname;
- private $view;
- /**
- * Constructor.
- */
- public function __construct()
- {
- $this->toolname = 'course_description';
- $this->view = new View($this->toolname);
- }
- /**
- * It's used for listing course description,
- * render to listing view.
- *
- * @param bool true for listing history (optional)
- * @param array message for showing by action['edit','add','destroy'] (optional)
- */
- public function listing($history = false, $messages = [])
- {
- $is_allowed_to_edit = api_is_allowed_to_edit(null, true);
- $course_description = new CourseDescription();
- $session_id = api_get_session_id();
- $data = [];
- $course_description->set_session_id($session_id);
- $course_description_data = $course_description->get_description_data();
- $data['descriptions'] = isset($course_description_data['descriptions']) ? $course_description_data['descriptions'] : '';
- $data['default_description_titles'] = $course_description->get_default_description_title();
- $data['default_description_title_editable'] = $course_description->get_default_description_title_editable();
- $data['default_description_icon'] = $course_description->get_default_description_icon();
- $data['messages'] = $messages;
- $browser = api_get_navigator();
- api_protect_course_script(true);
- if (!is_array($data['descriptions'])) {
- $data['descriptions'] = [$data['descriptions']];
- }
- // Prepare confirmation code for item deletion
- global $htmlHeadXtra;
- $htmlHeadXtra[] = "<script>
- function confirmation(name) {
- if (confirm(\" ".trim(get_lang('AreYouSureToDeleteJS'))." \"+name+\"?\")) {
- return true;
- } else {
- return false;
- }
- }
- </script>";
- foreach ($data['descriptions'] as $id => $description) {
- if (!empty($description['content'])
- && strpos($description['content'], '<iframe') !== false
- && $browser['name'] == 'Chrome'
- ) {
- header("X-XSS-Protection: 0");
- }
- // Add an escape version for the JS code of delete confirmation
- if ($description) {
- $data['descriptions'][$id]['title_js'] = addslashes($description['title']);
- }
- }
- $actions = null;
- $actionLeft = null;
- // display actions menu
- if ($is_allowed_to_edit) {
- $categories = [];
- foreach ($data['default_description_titles'] as $id => $title) {
- $categories[$id] = $title;
- }
- $categories[ADD_BLOCK] = get_lang('NewBloc');
- $i = 1;
- ksort($categories);
- foreach ($categories as $id => $title) {
- if ($i == ADD_BLOCK) {
- $actionLeft .= '<a href="index.php?'.api_get_cidreq().'&action=add">'.
- Display::return_icon(
- $data['default_description_icon'][$id],
- $title,
- '',
- ICON_SIZE_MEDIUM
- ).
- '</a>';
- break;
- } else {
- $actionLeft .= '<a href="index.php?action=edit&'.api_get_cidreq().'&description_type='.$id.'">'.
- Display::return_icon(
- $data['default_description_icon'][$id],
- $title,
- '',
- ICON_SIZE_MEDIUM
- ).
- '</a>';
- $i++;
- }
- }
- $actions = Display::toolbarAction('toolbar', [0 => $actionLeft]);
- }
- $tpl = new Template(get_lang('CourseProgram'));
- $tpl->assign('listing', $data);
- $tpl->assign('is_allowed_to_edit', $is_allowed_to_edit);
- $tpl->assign('actions', $actions);
- $tpl->assign('session_id', $session_id);
- $templateName = $tpl->get_template('course_description/index.tpl');
- $content = $tpl->fetch($templateName);
- $tpl->assign('content', $content);
- $tpl->display_one_col_template();
- }
- /**
- * It's used for editing a course description,
- * render to listing or edit view.
- *
- * @param int $id description item id
- * @param int $description_type description type id
- */
- public function edit($id, $description_type)
- {
- $course_description = new CourseDescription();
- $session_id = api_get_session_id();
- $course_description->set_session_id($session_id);
- $data = [];
- $data['id'] = $id;
- $affected_rows = null;
- if (strtoupper($_SERVER['REQUEST_METHOD']) == "POST") {
- if (!empty($_POST['title']) && !empty($_POST['contentDescription'])) {
- if (1) {
- $title = $_POST['title'];
- $content = $_POST['contentDescription'];
- $description_type = $_POST['description_type'];
- $id = $_POST['id'];
- if (empty($id)) {
- // If the ID was not provided, find the first matching description item given the item type
- $description = $course_description->get_data_by_description_type(
- $description_type
- );
- if (count($description) > 0) {
- $id = $description['id'];
- }
- // If no corresponding description is found, edit a new one
- }
- $progress = isset($_POST['progress']) ? $_POST['progress'] : '';
- $course_description->set_description_type($description_type);
- $course_description->set_title($title);
- $course_description->set_content($content);
- $course_description->set_progress($progress);
- $thematic_advance = $course_description->get_data_by_id($id);
- if (!empty($thematic_advance)) {
- $course_description->set_id($id);
- $course_description->update();
- } else {
- $course_description->insert();
- }
- Display::addFlash(
- Display::return_message(
- get_lang('CourseDescriptionUpdated')
- )
- );
- }
- $this->listing(false);
- } else {
- $data['error'] = 1;
- $data['default_description_titles'] = $course_description->get_default_description_title();
- $data['default_description_title_editable'] = $course_description->get_default_description_title_editable();
- $data['default_description_icon'] = $course_description->get_default_description_icon();
- $data['question'] = $course_description->get_default_question();
- $data['information'] = $course_description->get_default_information();
- $data['description_title'] = $_POST['title'];
- $data['description_content'] = $_POST['contentDescription'];
- $data['description_type'] = $_POST['description_type'];
- $data['progress'] = $_POST['progress'];
- $data['descriptions'] = $course_description->get_data_by_id($_POST['id']);
- // render to the view
- $this->view->set_data($data);
- $this->view->set_layout('layout');
- $this->view->set_template('edit');
- $this->view->render();
- }
- } else {
- $data['default_description_titles'] = $course_description->get_default_description_title();
- $data['default_description_title_editable'] = $course_description->get_default_description_title_editable();
- $data['default_description_icon'] = $course_description->get_default_description_icon();
- $data['question'] = $course_description->get_default_question();
- $data['information'] = $course_description->get_default_information();
- $data['description_type'] = $description_type;
- if (empty($id)) {
- // If the ID was not provided, find the first matching description item given the item type
- $description = $course_description->get_data_by_description_type($description_type);
- if (count($description) > 0) {
- $id = $description['id'];
- }
- // If no corresponding description is found, edit a new one
- }
- if (!empty($id)) {
- if (isset($_GET['id_session'])) {
- $session_id = intval($_GET['id_session']);
- }
- $course_description_data = $course_description->get_data_by_id(
- $id,
- null,
- $session_id
- );
- $data['description_type'] = $course_description_data['description_type'];
- $data['description_title'] = $course_description_data['description_title'];
- $data['description_content'] = $course_description_data['description_content'];
- $data['progress'] = $course_description_data['progress'];
- $data['descriptions'] = $course_description->get_data_by_description_type(
- $description_type,
- null,
- $session_id
- );
- }
- // render to the view
- $this->view->set_data($data);
- $this->view->set_layout('layout');
- $this->view->set_template('edit');
- $this->view->render();
- }
- }
- /**
- * It's used for adding a course description,
- * render to listing or add view.
- */
- public function add()
- {
- $course_description = new CourseDescription();
- $session_id = api_get_session_id();
- $course_description->set_session_id($session_id);
- $data = [];
- if (strtoupper($_SERVER['REQUEST_METHOD']) == "POST") {
- if (!empty($_POST['title']) && !empty($_POST['contentDescription'])) {
- if (1) {
- $title = $_POST['title'];
- $content = $_POST['contentDescription'];
- $description_type = $_POST['description_type'];
- if ($description_type >= ADD_BLOCK) {
- $course_description->set_description_type($description_type);
- $course_description->set_title($title);
- $course_description->set_content($content);
- $course_description->insert(api_get_course_int_id());
- }
- Display::addFlash(
- Display::return_message(
- get_lang('CourseDescriptionUpdated')
- )
- );
- }
- $this->listing(false);
- } else {
- $data['error'] = 1;
- $data['default_description_titles'] = $course_description->get_default_description_title();
- $data['default_description_title_editable'] = $course_description->get_default_description_title_editable();
- $data['default_description_icon'] = $course_description->get_default_description_icon();
- $data['question'] = $course_description->get_default_question();
- $data['information'] = $course_description->get_default_information();
- $data['description_title'] = $_POST['title'];
- $data['description_content'] = $_POST['contentDescription'];
- $data['description_type'] = $_POST['description_type'];
- $this->view->set_data($data);
- $this->view->set_layout('layout');
- $this->view->set_template('add');
- $this->view->render();
- }
- } else {
- $data['default_description_titles'] = $course_description->get_default_description_title();
- $data['default_description_title_editable'] = $course_description->get_default_description_title_editable();
- $data['default_description_icon'] = $course_description->get_default_description_icon();
- $data['question'] = $course_description->get_default_question();
- $data['information'] = $course_description->get_default_information();
- $data['description_type'] = $course_description->get_max_description_type();
- // render to the view
- $this->view->set_data($data);
- $this->view->set_layout('layout');
- $this->view->set_template('add');
- $this->view->render();
- }
- }
- /**
- * It's used for destroy a course description,
- * render to listing view.
- *
- * @param int $id description type
- */
- public function destroy($id)
- {
- $course_description = new CourseDescription();
- $session_id = api_get_session_id();
- $course_description->set_session_id($session_id);
- if (!empty($id)) {
- $course_description->set_id($id);
- $course_description->delete();
- Display::addFlash(
- Display::return_message(get_lang('CourseDescriptionDeleted'))
- );
- }
- $this->listing(false);
- }
- }
|