PageRenderTime 27ms CodeModel.GetById 0ms RepoModel.GetById 0ms app.codeStats 1ms

/main/document/showinframesmin.php

https://bitbucket.org/hanutimes/hanutimes
PHP | 152 lines | 125 code | 13 blank | 14 comment | 11 complexity | 0b59bb25a1e1434e6b7c9bffa34b85b2 MD5 | raw file
  1. <?php
  2. /* For licensing terms, see /license.txt */
  3. /**
  4. * @author Juan Carlos RaƱa Trabado (herodoto@telefonica.net)
  5. *
  6. * @package chamilo.document
  7. */
  8. /**
  9. * Code
  10. */
  11. /* INITIALIZATION */
  12. $language_file[] = 'document';
  13. require_once '../inc/global.inc.php';
  14. // Protection
  15. api_protect_course_script();
  16. $noPHP_SELF = true;
  17. $header_file = Security::remove_XSS($_GET['file']);
  18. $document_id = intval($_GET['id']);
  19. $course_info = api_get_course_info();
  20. $course_code = api_get_course_id();
  21. if (empty($course_info)) {
  22. api_not_allowed(true);
  23. }
  24. //Generate path
  25. if (!$document_id) {
  26. $document_id = DocumentManager::get_document_id($course_info, $header_file);
  27. }
  28. $document_data = DocumentManager::get_document_data_by_id($document_id, $course_code);
  29. if (empty($document_data)) {
  30. api_not_allowed(true);
  31. }
  32. $header_file = $document_data['path'];
  33. $name_to_show = Text::cut($header_file, 80);
  34. $path_array = explode('/', str_replace('\\', '/', $header_file));
  35. $path_array = array_map('urldecode', $path_array);
  36. $header_file = implode('/', $path_array);
  37. $file = Security::remove_XSS(urldecode($document_data['path']));
  38. $file_root = $course_info['path'].'/document'.str_replace('%2F', '/', $file);
  39. $file_url_sys = api_get_path(SYS_COURSE_PATH).$file_root;
  40. $file_url_web = api_get_path(WEB_COURSE_PATH).$file_root;
  41. if (!file_exists($file_url_sys)) {
  42. api_not_allowed(true);
  43. }
  44. if (is_dir($file_url_sys)) {
  45. api_not_allowed(true);
  46. }
  47. //Check user visibility
  48. //$is_visible = DocumentManager::is_visible_by_id($document_id, $course_info, api_get_session_id(), api_get_user_id());
  49. $is_visible = DocumentManager::check_visibility_tree($document_id, api_get_course_id(), api_get_session_id(), api_get_user_id());
  50. if (!api_is_allowed_to_edit() && !$is_visible) {
  51. api_not_allowed(true);
  52. }
  53. //TODO:clean all code
  54. /* Main section */
  55. header('Expires: Wed, 01 Jan 1990 00:00:00 GMT');
  56. //header('Last-Modified: '.gmdate('D, d M Y H:i:s').' GMT');
  57. header('Last-Modified: Wed, 01 Jan 2100 00:00:00 GMT');
  58. header('Cache-Control: no-cache, must-revalidate');
  59. header('Pragma: no-cache');
  60. $browser_display_title = 'Documents - '.Security::remove_XSS($_GET['cidReq']).' - '.$file;
  61. $js_glossary_in_documents = '';
  62. if (api_get_setting('show_glossary_in_documents') == 'ismanual') {
  63. $js_glossary_in_documents = ' // $(document).ready(function() {
  64. $.frameReady(function() {
  65. // $("<div>I am a div courses</div>").prependTo("body");
  66. }, "mainFrame",
  67. { load: [
  68. {type:"script", id:"_fr1", src:"'.api_get_path(WEB_LIBRARY_PATH).'javascript/jquery.min.js"},
  69. {type:"script", id:"_fr2", src:"'.api_get_path(WEB_LIBRARY_PATH).'javascript/jquery.highlight.js"},
  70. {type:"script", id:"_fr3", src:"'.api_get_path(WEB_LIBRARY_PATH).'fckeditor/editor/plugins/glossary/fck_glossary_manual.js"}
  71. ]
  72. }
  73. );
  74. //});';
  75. } elseif (api_get_setting('show_glossary_in_documents') == 'isautomatic') {
  76. $js_glossary_in_documents = '// $(document).ready(function() {
  77. $.frameReady(function(){
  78. // $("<div>I am a div courses</div>").prependTo("body");
  79. }, "mainFrame",
  80. { load: [
  81. {type:"script", id:"_fr1", src:"'.api_get_path(WEB_LIBRARY_PATH).'javascript/jquery.min.js"},
  82. {type:"script", id:"_fr2", src:"'.api_get_path(WEB_LIBRARY_PATH).'javascript/jquery.highlight.js"},
  83. {type:"script", id:"_fr3", src:"'.api_get_path(WEB_LIBRARY_PATH).'fckeditor/editor/plugins/glossary/fck_glossary_automatic.js"}
  84. ]
  85. }
  86. );
  87. // });';
  88. }
  89. $htmlHeadXtra[] = '<script type="text/javascript">
  90. <!--
  91. var jQueryFrameReadyConfigPath = \''.api_get_path(WEB_LIBRARY_PATH).'javascript/jquery.min.js\';
  92. -->
  93. </script>';
  94. $htmlHeadXtra[] = '<script type="text/javascript" src="'.api_get_path(WEB_LIBRARY_PATH).'javascript/jquery.frameready.js"></script>';
  95. $htmlHeadXtra[] = '
  96. <script type="text/javascript">
  97. <!--
  98. var updateContentHeight = function() {
  99. //HeaderHeight = document.getElementById("header").offsetHeight;
  100. //FooterHeight = document.getElementById("footer").offsetHeight;
  101. //document.getElementById("mainFrame").style.height = ((docHeight-(parseInt(HeaderHeight)+parseInt(FooterHeight)))+60)+"px";
  102. my_iframe = document.getElementById("mainFrame");
  103. new_height = my_iframe.contentWindow.document.body.scrollHeight;
  104. my_iframe.height = my_iframe.contentWindow.document.body.scrollHeight + "px";
  105. };
  106. // Fixes the content height of the frame
  107. window.onload = function() {
  108. updateContentHeight();
  109. '.$js_glossary_in_documents.'
  110. }
  111. -->
  112. </script>';
  113. Display::display_reduced_header();
  114. echo '<div align="center">';
  115. $file_url_web = api_get_path(WEB_COURSE_PATH).$_course['path'].'/document'.$header_file.'?'.api_get_cidreq();
  116. $pathinfo = pathinfo($header_file);
  117. if ($pathinfo['extension']=='wav' && preg_match('/_chnano_.wav/i', $file_url_web) && api_get_setting('enable_nanogong') == 'true'){
  118. echo '<div align="center">';
  119. echo '<br/>';
  120. echo '<applet id="applet" archive="../inc/lib/nanogong/nanogong.jar" code="gong.NanoGong" width="160" height="40" >';
  121. echo '<param name="SoundFileURL" value="'.$file_url_web.'" />';
  122. echo '<param name="ShowSaveButton" value="false" />';
  123. echo '<param name="ShowTime" value="true" />';
  124. echo '<param name="ShowRecordButton" value="false" />';
  125. echo '</applet>';
  126. echo '</div>';
  127. } else {
  128. if ($pathinfo['extension']=='swf'){ $width='83%'; $height='83%';} else {$width='100%'; $height='';}
  129. echo '<iframe border="0" frameborder="0" scrolling="no" style="width:'.$width.'; height:'.$height.';background-color:#ffffff;" id="mainFrame" name="mainFrame" src="'.$file_url_web.'&amp;rand='.mt_rand(1, 10000).'"></iframe>';
  130. }