thematic_controller.php 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * Thematic Controller script.
  5. * Prepares the common background variables to give to the scripts corresponding to
  6. * the requested action
  7. *
  8. * This file contains class used like controller for thematic,
  9. * it should be included inside a dispatcher file (e.g: index.php)
  10. *
  11. * !!! WARNING !!! : ALL DATES IN THIS MODULE ARE STORED IN UTC !
  12. * DO NOT CONVERT DURING THE TRANSITION FROM CHAMILO 1.8.x TO 2.0
  13. *
  14. * @author Christian Fasanando <christian1827@gmail.com>
  15. * @author Julio Montoya <gugli100@gmail.com> token support improving UI
  16. *
  17. * @package chamilo.course_progress
  18. */
  19. class ThematicController
  20. {
  21. /**
  22. * Constructor
  23. */
  24. public function __construct()
  25. {
  26. $this->toolname = 'course_progress';
  27. $this->view = new View($this->toolname);
  28. }
  29. /**
  30. * This method is used for thematic control (update, insert or listing)
  31. * @param string $action
  32. * render to thematic.php
  33. */
  34. public function thematic($action)
  35. {
  36. $thematic = new Thematic();
  37. $data = array();
  38. $check = Security::check_token('request');
  39. $thematic_id = isset($_REQUEST['thematic_id']) ? intval($_REQUEST['thematic_id']) : null;
  40. $displayHeader = !empty($_REQUEST['display']) && $_REQUEST['display'] === 'no_header' ? false : true;
  41. if (true) {
  42. switch ($action) {
  43. case 'thematic_add':
  44. case 'thematic_edit':
  45. // insert or update a thematic
  46. if (strtoupper($_SERVER['REQUEST_METHOD']) == "POST") {
  47. if (trim($_POST['title']) !== '') {
  48. if (api_is_allowed_to_edit(null, true)) {
  49. $id = isset($_POST['thematic_id']) ? $_POST['thematic_id'] : null;
  50. $title = trim($_POST['title']);
  51. $content = trim($_POST['content']);
  52. $session_id = api_get_session_id();
  53. $thematic->set_thematic_attributes($id, $title, $content, $session_id);
  54. $last_id = $thematic->thematic_save();
  55. if ($_POST['action'] == 'thematic_add') {
  56. $action = 'thematic_details';
  57. $thematic_id = null;
  58. if ($last_id) {
  59. $data['last_id'] = $last_id;
  60. }
  61. } else {
  62. $action = 'thematic_details';
  63. $thematic_id = null;
  64. }
  65. }
  66. } else {
  67. $error = true;
  68. $data['error'] = $error;
  69. $data['action'] = $_POST['action'];
  70. $data['thematic_id'] = $_POST['thematic_id'];
  71. // render to the view
  72. $this->view->set_data($data);
  73. $this->view->set_layout('layout');
  74. $this->view->set_template('thematic');
  75. $this->view->render();
  76. }
  77. }
  78. break;
  79. case 'thematic_copy':
  80. //Copy a thematic to a session
  81. $thematic->copy($thematic_id);
  82. $thematic_id = null;
  83. $action = 'thematic_details';
  84. break;
  85. case 'thematic_delete_select':
  86. //Delete many thematics
  87. if (strtoupper($_SERVER['REQUEST_METHOD']) == "POST") {
  88. if (api_is_allowed_to_edit(null, true)) {
  89. $thematic_ids = $_POST['id'];
  90. $affected_rows = $thematic->thematic_destroy($thematic_ids);
  91. }
  92. $action = 'thematic_details';
  93. }
  94. break;
  95. case 'thematic_delete':
  96. // Delete a thematic
  97. if (isset($thematic_id)) {
  98. if (api_is_allowed_to_edit(null, true)) {
  99. $thematic->thematic_destroy($thematic_id);
  100. }
  101. $thematic_id = null;
  102. $action = 'thematic_details';
  103. }
  104. break;
  105. case 'thematic_import_select':
  106. break;
  107. case 'thematic_import':
  108. $csv_import_array = Import::csvToArray($_FILES['file']['tmp_name']);
  109. if (isset($_POST['replace']) && $_POST['replace']) {
  110. // Remove current thematic.
  111. $list = $thematic->get_thematic_list();
  112. foreach ($list as $i) {
  113. $thematic->thematic_destroy($i);
  114. }
  115. }
  116. // Import the progress.
  117. $current_thematic = null;
  118. foreach ($csv_import_array as $item) {
  119. $key = $item['type'];
  120. switch ($key) {
  121. case 'title':
  122. $thematic->set_thematic_attributes(
  123. null,
  124. $item['data1'],
  125. $item['data2'],
  126. api_get_session_id()
  127. );
  128. $current_thematic = $thematic->thematic_save();
  129. $description_type = 0;
  130. break;
  131. case 'plan':
  132. $thematic->set_thematic_plan_attributes(
  133. $current_thematic,
  134. $item['data1'],
  135. $item['data2'],
  136. $description_type
  137. );
  138. $thematic->thematic_plan_save();
  139. $description_type++;
  140. break;
  141. case 'progress':
  142. $thematic->set_thematic_advance_attributes(
  143. null,
  144. $current_thematic,
  145. 0,
  146. $item['data3'],
  147. $item['data1'],
  148. $item['data2']
  149. );
  150. $thematic->thematic_advance_save();
  151. break;
  152. }
  153. }
  154. $action = 'thematic_details';
  155. break;
  156. case 'thematic_export':
  157. $list = $thematic->get_thematic_list();
  158. $csv = array();
  159. $csv[] = array('type', 'data1', 'data2', 'data3');
  160. foreach ($list as $theme) {
  161. $csv[] = array('title', $theme['title'], $theme['content']);
  162. $data = $thematic->get_thematic_plan_data($theme['id']);
  163. if (!empty($data)) {
  164. foreach ($data as $plan) {
  165. if (empty($plan['description'])) {
  166. continue;
  167. }
  168. $csv[] = [
  169. 'plan',
  170. strip_tags($plan['title']),
  171. strip_tags($plan['description'])
  172. ];
  173. }
  174. }
  175. $data = $thematic->get_thematic_advance_by_thematic_id($theme['id']);
  176. if (!empty($data)) {
  177. foreach ($data as $advance) {
  178. $csv[] = array(
  179. 'progress',
  180. strip_tags($advance['start_date']),
  181. strip_tags($advance['duration']),
  182. strip_tags($advance['content']),
  183. );
  184. }
  185. }
  186. }
  187. Export::arrayToCsv($csv);
  188. exit;
  189. // Don't continue building a normal page.
  190. return;
  191. case 'thematic_export_pdf':
  192. $list = $thematic->get_thematic_list();
  193. $table = array();
  194. $table[] = array(
  195. get_lang('Thematic'),
  196. get_lang('ThematicPlan'),
  197. get_lang('ThematicAdvance')
  198. );
  199. foreach ($list as $theme) {
  200. $data = $thematic->get_thematic_plan_data($theme['id']);
  201. $plan_html = null;
  202. if (!empty($data)) {
  203. foreach ($data as $plan) {
  204. if (empty($plan['description'])) {
  205. continue;
  206. }
  207. $plan_html .= '<strong>' . $plan['title'] . '</strong><br /> ' . $plan['description'] . '<br />';
  208. }
  209. }
  210. $data = $thematic->get_thematic_advance_by_thematic_id($theme['id']);
  211. $advance_html = null;
  212. if (!empty($data)) {
  213. foreach ($data as $advance) {
  214. $advance_html .= api_convert_and_format_date($advance['start_date'], DATE_FORMAT_LONG) . ' ('.$advance['duration'].' '.get_lang('HourShort').')<br />'.$advance['content'].'<br />';
  215. }
  216. }
  217. $table[] = array($theme['title'], $plan_html, $advance_html);
  218. }
  219. $params = array(
  220. 'filename' => get_lang('Thematic') . '-' . api_get_local_time(),
  221. 'pdf_title' => get_lang('Thematic'),
  222. 'add_signatures' => true,
  223. 'format' => 'A4-L',
  224. 'orientation' => 'L'
  225. );
  226. Export::export_table_pdf($table, $params);
  227. break;
  228. case 'moveup':
  229. $thematic->move_thematic('up', $thematic_id);
  230. $action = 'thematic_details';
  231. $thematic_id = null;
  232. break;
  233. case 'movedown':
  234. $thematic->move_thematic('down', $thematic_id);
  235. $action = 'thematic_details';
  236. $thematic_id = null;
  237. break;
  238. }
  239. Security::clear_token();
  240. } else {
  241. $action = 'thematic_details';
  242. $thematic_id = null;
  243. }
  244. if (isset($thematic_id)) {
  245. $data['thematic_data'] = $thematic->get_thematic_list($thematic_id);
  246. $data['thematic_id'] = $thematic_id;
  247. }
  248. if ($action == 'thematic_details') {
  249. if (isset($thematic_id)) {
  250. $thematic_data_result = $thematic->get_thematic_list($thematic_id);
  251. if (!empty($thematic_data_result)) {
  252. $thematic_data[$thematic_id] = $thematic_data_result;
  253. }
  254. $data['total_average_of_advances'] = $thematic->get_average_of_advances_by_thematic($thematic_id);
  255. } else {
  256. $thematic_data = $thematic->get_thematic_list(null, api_get_course_id(), api_get_session_id());
  257. $data['max_thematic_item'] = $thematic->get_max_thematic_item();
  258. $data['last_done_thematic_advance'] = $thematic->get_last_done_thematic_advance();
  259. $data['total_average_of_advances'] = $thematic->get_total_average_of_thematic_advances();
  260. }
  261. // Second column
  262. $thematic_plan_data = $thematic->get_thematic_plan_data();
  263. // Third column
  264. $thematic_advance_data = $thematic->get_thematic_advance_list(null, null, true);
  265. $data['thematic_plan_div'] = $thematic->get_thematic_plan_div($thematic_plan_data);
  266. $data['thematic_advance_div'] = $thematic->get_thematic_advance_div($thematic_advance_data);
  267. $data['thematic_plan_data'] = $thematic_plan_data;
  268. $data['thematic_advance_data'] = $thematic_advance_data;
  269. $data['thematic_data'] = $thematic_data;
  270. }
  271. $data['default_thematic_plan_title'] = $thematic->get_default_thematic_plan_title();
  272. $data['action'] = $action;
  273. $layoutName = $displayHeader ? 'layout' : 'layout_no_header';
  274. // render to the view
  275. $this->view->set_data($data);
  276. $this->view->set_layout($layoutName);
  277. $this->view->set_template('thematic');
  278. $this->view->render();
  279. }
  280. /**
  281. * This method is used for thematic plan control (update, insert or listing)
  282. * @param string $action
  283. * render to thematic_plan.php
  284. */
  285. public function thematic_plan($action)
  286. {
  287. $thematic = new Thematic();
  288. $data = array();
  289. if (strtoupper($_SERVER['REQUEST_METHOD']) == "POST") {
  290. if (isset($_POST['action']) && ($_POST['action'] == 'thematic_plan_add' || $_POST['action'] == 'thematic_plan_edit')) {
  291. if (isset($_POST['title'])) {
  292. if (api_is_allowed_to_edit(null, true)) {
  293. $title_list = $_REQUEST['title'];
  294. $description_list = $_REQUEST['description'];
  295. $description_type = $_REQUEST['description_type'];
  296. for ($i = 1; $i < count($title_list) + 1; $i++) {
  297. $thematic->set_thematic_plan_attributes(
  298. $_REQUEST['thematic_id'],
  299. $title_list[$i],
  300. $description_list[$i],
  301. $description_type[$i]
  302. );
  303. $thematic->thematic_plan_save();
  304. }
  305. $data['message'] = 'ok';
  306. $saveRedirect = api_get_path(WEB_PATH) . 'main/course_progress/index.php?';
  307. $saveRedirect.= api_get_cidreq() . '&';
  308. $saveRedirect.= 'thematic_plan_save_message=ok';
  309. header("Location: $saveRedirect");
  310. exit;
  311. }
  312. $data['action'] = 'thematic_plan_list';
  313. } else {
  314. $error = true;
  315. $action = $_POST['action'];
  316. $data['error'] = $error;
  317. $data['thematic_plan_data'] = $thematic->get_thematic_plan_data($_POST['thematic_id'], $_POST['description_type']);
  318. $data['thematic_id'] = $_POST['thematic_id'];
  319. $data['description_type'] = $_POST['description_type'];
  320. $data['action'] = $action;
  321. $data['default_thematic_plan_title'] = $thematic->get_default_thematic_plan_title();
  322. $data['default_thematic_plan_icon'] = $thematic->get_default_thematic_plan_icon();
  323. $data['default_thematic_plan_question'] = $thematic->get_default_question();
  324. $data['next_description_type'] = $thematic->get_next_description_type($_POST['thematic_id']);
  325. // render to the view
  326. $this->view->set_data($data);
  327. $this->view->set_layout('layout');
  328. $this->view->set_template('thematic_plan');
  329. $this->view->render();
  330. }
  331. }
  332. }
  333. $thematic_id = intval($_GET['thematic_id']);
  334. if ($action == 'thematic_plan_list') {
  335. $data['thematic_plan_data'] = $thematic->get_thematic_plan_data($thematic_id);
  336. }
  337. $description_type = isset($_GET['description_type']) ? intval($_GET['description_type']) : null;
  338. if (!empty($thematic_id) && !empty($description_type)) {
  339. if ($action === 'thematic_plan_delete') {
  340. if (api_is_allowed_to_edit(null, true)) {
  341. $thematic->thematic_plan_destroy($thematic_id, $description_type);
  342. }
  343. $data['thematic_plan_data'] = $thematic->get_thematic_plan_data($thematic_id);
  344. $action = 'thematic_plan_list';
  345. } else {
  346. $data['thematic_plan_data'] = $thematic->get_thematic_plan_data($thematic_id, $description_type);
  347. }
  348. $data['thematic_id'] = $thematic_id;
  349. $data['description_type'] = $description_type;
  350. } else if (!empty($thematic_id) && $action === 'thematic_plan_list') {
  351. $data['thematic_plan_data'] = $thematic->get_thematic_plan_data($thematic_id);
  352. $data['thematic_id'] = $thematic_id;
  353. }
  354. $data['thematic_id'] = $thematic_id;
  355. $data['action'] = $action;
  356. $data['default_thematic_plan_title'] = $thematic->get_default_thematic_plan_title();
  357. $data['default_thematic_plan_icon'] = $thematic->get_default_thematic_plan_icon();
  358. $data['next_description_type'] = $thematic->get_next_description_type($thematic_id);
  359. $data['default_thematic_plan_question'] = $thematic->get_default_question();
  360. $data['thematic_data'] = $thematic->get_thematic_list($thematic_id);
  361. //render to the view
  362. $this->view->set_data($data);
  363. $this->view->set_layout('layout');
  364. $this->view->set_template('thematic_plan');
  365. $this->view->render();
  366. exit;
  367. }
  368. /**
  369. * This method is used for thematic advance control (update, insert or listing)
  370. * render to thematic_advance.php
  371. * @param string $action
  372. *
  373. */
  374. public function thematic_advance($action)
  375. {
  376. $thematic = new Thematic();
  377. $attendance = new Attendance();
  378. $data = array();
  379. $displayHeader = (!empty($_REQUEST['display']) && $_REQUEST['display'] === 'no_header') ? false : true;
  380. // get data for attendance input select
  381. $attendance_list = $attendance->get_attendances_list();
  382. $attendance_select = array();
  383. $attendance_select[0] = get_lang('SelectAnAttendance');
  384. foreach ($attendance_list as $attendance_id => $attendance_data) {
  385. $attendance_select[$attendance_id] = $attendance_data['name'];
  386. }
  387. $thematic_id = intval($_REQUEST['thematic_id']);
  388. $thematic_advance_id = isset($_REQUEST['thematic_advance_id']) ? intval($_REQUEST['thematic_advance_id']) : null;
  389. $thematic_advance_data = array();
  390. switch ($action) {
  391. case 'thematic_advance_delete':
  392. if (!empty($thematic_advance_id)) {
  393. if (api_is_allowed_to_edit(null, true)) {
  394. $thematic->thematic_advance_destroy($thematic_advance_id);
  395. }
  396. header('Location: index.php?'.api_get_cidreq());
  397. exit;
  398. }
  399. break;
  400. case 'thematic_advance_list':
  401. if (!api_is_allowed_to_edit(null, true)) {
  402. echo '';
  403. exit;
  404. }
  405. if ((isset($_REQUEST['start_date_type']) && $_REQUEST['start_date_type'] == 1 && empty($_REQUEST['start_date_by_attendance'])) ||
  406. (!empty($_REQUEST['duration_in_hours']) && !is_numeric($_REQUEST['duration_in_hours']))
  407. ) {
  408. if ($_REQUEST['start_date_type'] == 1 && empty($_REQUEST['start_date_by_attendance'])) {
  409. $start_date_error = true;
  410. $data['start_date_error'] = $start_date_error;
  411. }
  412. if (!empty($_REQUEST['duration_in_hours']) && !is_numeric($_REQUEST['duration_in_hours'])) {
  413. $duration_error = true;
  414. $data['duration_error'] = $duration_error;
  415. }
  416. $data['action'] = $_REQUEST['action'];
  417. $data['thematic_id'] = $_REQUEST['thematic_id'];
  418. $data['attendance_select'] = $attendance_select;
  419. if (isset($_REQUEST['thematic_advance_id'])) {
  420. $data['thematic_advance_id'] = $_REQUEST['thematic_advance_id'];
  421. $thematic_advance_data = $thematic->get_thematic_advance_list($_REQUEST['thematic_advance_id']);
  422. $data['thematic_advance_data'] = $thematic_advance_data;
  423. }
  424. } else {
  425. if (api_is_allowed_to_edit(null, true)) {
  426. $thematic_advance_id = isset($_REQUEST['thematic_advance_id']) ? $_REQUEST['thematic_advance_id'] : null;
  427. $thematic_id = $_REQUEST['thematic_id'];
  428. $content = isset($_REQUEST['content']) ? $_REQUEST['content'] : null;
  429. $duration = isset($_REQUEST['duration_in_hours']) ? $_REQUEST['duration_in_hours'] : null;
  430. if (isset($_REQUEST['start_date_type']) && $_REQUEST['start_date_type'] == 2) {
  431. $start_date = $_REQUEST['custom_start_date'];
  432. $attendance_id = 0;
  433. } else {
  434. $start_date = isset($_REQUEST['start_date_by_attendance']) ? $_REQUEST['start_date_by_attendance'] : null;
  435. $attendance_id = isset($_REQUEST['attendance_select']) ? $_REQUEST['attendance_select'] : null;
  436. }
  437. $thematic->set_thematic_advance_attributes(
  438. $thematic_advance_id,
  439. $thematic_id,
  440. $attendance_id,
  441. $content,
  442. $start_date,
  443. $duration
  444. );
  445. $affected_rows = $thematic->thematic_advance_save();
  446. if ($affected_rows) {
  447. // get last done thematic advance before move thematic list
  448. $last_done_thematic_advance = $thematic->get_last_done_thematic_advance();
  449. // update done advances with de current thematic list
  450. if (!empty($last_done_thematic_advance)) {
  451. $thematic->update_done_thematic_advances($last_done_thematic_advance);
  452. }
  453. }
  454. }
  455. }
  456. break;
  457. default:
  458. $thematic_advance_data = $thematic->get_thematic_advance_list($thematic_advance_id);
  459. break;
  460. }
  461. // get calendar select by attendance id
  462. $calendar_select = array();
  463. if (!empty($thematic_advance_data)) {
  464. if (!empty($thematic_advance_data['attendance_id'])) {
  465. $attendance_calendar = $attendance->get_attendance_calendar($thematic_advance_data['attendance_id']);
  466. if (!empty($attendance_calendar)) {
  467. foreach ($attendance_calendar as $calendar) {
  468. $calendar_select[$calendar['date_time']] = $calendar['date_time'];
  469. }
  470. }
  471. }
  472. }
  473. $data['action'] = $action;
  474. $data['thematic_id'] = $thematic_id;
  475. $data['thematic_advance_id'] = $thematic_advance_id;
  476. $data['attendance_select'] = $attendance_select;
  477. $data['thematic_advance_data'] = $thematic_advance_data;
  478. $data['calendar_select'] = $calendar_select;
  479. $layoutName = $displayHeader ? 'layout' : 'layout_no_header';
  480. // render to the view
  481. $this->view->set_data($data);
  482. $this->view->set_layout($layoutName);
  483. $this->view->set_template('thematic_advance');
  484. $this->view->render();
  485. }
  486. }