inbox.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * @package chamilo.messages
  5. */
  6. $cidReset = true;
  7. require_once '../inc/global.inc.php';
  8. api_block_anonymous_users();
  9. if (isset($_GET['messages_page_nr'])) {
  10. $social_link = '';
  11. if ($_REQUEST['f'] == 'social') {
  12. $social_link = '?f=social';
  13. }
  14. if (api_get_setting('allow_social_tool') == 'true' && api_get_setting('allow_message_tool') == 'true') {
  15. header('Location:inbox.php'.$social_link);
  16. exit;
  17. }
  18. }
  19. if (api_get_setting('allow_message_tool') != 'true') {
  20. api_not_allowed();
  21. }
  22. $htmlHeadXtra[] = '<script>
  23. function show_icon_edit(element_html) {
  24. ident="#edit_image";
  25. $(ident).show();
  26. }
  27. function hide_icon_edit(element_html) {
  28. ident="#edit_image";
  29. $(ident).hide();
  30. }
  31. </script>';
  32. /*
  33. MAIN CODE
  34. */
  35. $nameTools = get_lang('Messages');
  36. $request = api_is_xml_http_request();
  37. $show_message = null;
  38. if (isset($_GET['form_reply']) || isset($_GET['form_delete'])) {
  39. $info_reply = array();
  40. $info_delete = array();
  41. if (isset($_GET['form_reply'])) {
  42. //allow to insert messages
  43. $info_reply = explode(base64_encode('&%ff..x'), $_GET['form_reply']);
  44. $count_reply = count($info_reply);
  45. $button_sent = urldecode($info_reply[4]);
  46. }
  47. if (isset($_GET['form_delete'])) {
  48. //allow to delete messages
  49. $info_delete = explode(',', $_GET['form_delete']);
  50. $count_delete = (count($info_delete) - 1);
  51. }
  52. if (isset($button_sent)) {
  53. $title = urldecode($info_reply[0]);
  54. $content = str_replace("\\", "", urldecode($info_reply[1]));
  55. $user_reply = $info_reply[2];
  56. $user_email_base = str_replace(')', '(', $info_reply[5]);
  57. $user_email_prepare = explode('(', $user_email_base);
  58. if (count($user_email_prepare) == 1) {
  59. $user_email = trim($user_email_prepare[0]);
  60. } elseif (count($user_email_prepare) == 3) {
  61. $user_email = trim($user_email_prepare[1]);
  62. }
  63. $user_id_by_email = MessageManager::get_user_id_by_email($user_email);
  64. if ($info_reply[6] == 'save_form') {
  65. $user_id_by_email = $info_reply[2];
  66. }
  67. if (isset($user_reply) && !is_null($user_id_by_email) && strlen($info_reply[0]) > 0) {
  68. MessageManager::send_message($user_id_by_email, $title, $content);
  69. $show_message .= MessageManager::return_message($user_id_by_email, 'confirmation');
  70. $social_right_content .= MessageManager::inbox_display();
  71. exit;
  72. } elseif (is_null($user_id_by_email)) {
  73. $message_box = get_lang('ErrorSendingMessage');
  74. $show_message .= Display::return_message(api_xml_http_response_encode($message_box), 'error');
  75. $social_right_content .= MessageManager::inbox_display();
  76. exit;
  77. }
  78. } elseif (trim($info_delete[0]) == 'delete') {
  79. for ($i = 1; $i <= $count_delete; $i++) {
  80. MessageManager::delete_message_by_user_receiver(api_get_user_id(), $info_delete[$i]);
  81. }
  82. $message_box = get_lang('SelectedMessagesDeleted');
  83. $show_message .= Display::return_message(api_xml_http_response_encode($message_box));
  84. $social_right_content .= MessageManager::inbox_display();
  85. exit;
  86. }
  87. }
  88. if (isset($_GET['f']) && $_GET['f'] == 'social') {
  89. $this_section = SECTION_SOCIAL;
  90. $interbreadcrumb[] = array('url' => api_get_path(WEB_PATH).'main/social/home.php', 'name' => get_lang('SocialNetwork'));
  91. $interbreadcrumb[] = array('url' => '#', 'name' => get_lang('Inbox'));
  92. } else {
  93. $this_section = SECTION_MYPROFILE;
  94. $interbreadcrumb[] = array('url' => api_get_path(WEB_PATH).'main/auth/profile.php', 'name' => get_lang('Profile'));
  95. }
  96. $social_parameter = '';
  97. if ((isset($_GET['f']) && $_GET['f'] == 'social') ||
  98. api_get_setting('allow_social_tool') == 'true'
  99. ) {
  100. $social_parameter = '?f=social';
  101. } else {
  102. $actions = null;
  103. //Comes from normal profile
  104. if (api_get_setting('allow_social_tool') == 'true' && api_get_setting('allow_message_tool') == 'true') {
  105. $actions .= '<a href="'.api_get_path(WEB_PATH).'main/social/profile.php">'.
  106. Display::return_icon('shared_profile.png', get_lang('ViewSharedProfile')).'</a>';
  107. }
  108. if (api_get_setting('allow_message_tool') == 'true') {
  109. $actions .= '<a href="'.api_get_path(WEB_PATH).'main/messages/new_message.php">'.
  110. Display::return_icon('message_new.png', get_lang('ComposeMessage')).'</a>';
  111. $actions .= '<a href="'.api_get_path(WEB_PATH).'main/messages/inbox.php">'.
  112. Display::return_icon('inbox.png', get_lang('Inbox')).'</a>';
  113. $actions .= '<a href="'.api_get_path(WEB_PATH).'main/messages/outbox.php">'.
  114. Display::return_icon('outbox.png', get_lang('Outbox')).'</a>';
  115. }
  116. }
  117. //LEFT CONTENT
  118. if (api_get_setting('allow_social_tool') == 'true') {
  119. //Block Social Menu
  120. $social_menu_block = SocialManager::show_social_menu('messages');
  121. }
  122. //Right content
  123. $social_right_content = null;
  124. $keyword = '';
  125. if (api_get_setting('allow_social_tool') == 'true') {
  126. $actionsLeft = '<a href="'.api_get_path(WEB_PATH).'main/messages/new_message.php?f=social">'.
  127. Display::return_icon('new-message.png', get_lang('ComposeMessage'), array(), 32).'</a>';
  128. $actionsLeft .= '<a href="'.api_get_path(WEB_PATH).'main/messages/outbox.php?f=social">'.
  129. Display::return_icon('outbox.png', get_lang('Outbox'), array(), 32).'</a>';
  130. $form = MessageManager::getSearchForm(api_get_path(WEB_PATH).'main/messages/inbox.php');
  131. if ($form->validate()) {
  132. $values = $form->getSubmitValues();
  133. $keyword = $values['keyword'];
  134. }
  135. $actionsRight = $form->returnForm();
  136. $social_right_content .= Display::toolbarAction('toolbar', [$actionsLeft, $actionsRight]);
  137. }
  138. //MAIN CONTENT
  139. if (!isset($_GET['del_msg'])) {
  140. $social_right_content .= MessageManager::inbox_display($keyword);
  141. } else {
  142. $num_msg = intval($_POST['total']);
  143. for ($i = 0; $i < $num_msg; $i++) {
  144. if ($_POST[$i]) {
  145. //the user_id was necesarry to delete a message??
  146. $show_message .= MessageManager::delete_message_by_user_receiver(api_get_user_id(), $_POST['_'.$i]);
  147. }
  148. }
  149. $social_right_content .= MessageManager::inbox_display();
  150. }
  151. $tpl = new Template(null);
  152. // Block Social Avatar
  153. SocialManager::setSocialUserBlock($tpl, $user_id, 'messages');
  154. if (api_get_setting('allow_social_tool') == 'true') {
  155. $tpl->assign('social_menu_block', $social_menu_block);
  156. $tpl->assign('social_right_content', $social_right_content);
  157. $social_layout = $tpl->get_template('social/inbox.tpl');
  158. $tpl->display($social_layout);
  159. } else {
  160. $content = $social_right_content;
  161. $tpl->assign('actions', $actions);
  162. $tpl->assign('message', $show_message);
  163. $tpl->assign('content', $content);
  164. $tpl->display_one_col_template();
  165. }