123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284 |
- <?php
- /* For licensing terms, see /license.txt */
- /* INIT SECTION */
- $language_file = array('create_course', 'document');
- require 'global.inc.php';
- /* Libraries */
- require_once api_get_path(LIBRARY_PATH).'course_document.lib.php';
- require_once api_get_path(LIBRARY_PATH).'fckeditor/repository.php';
- require_once api_get_path(SYS_CODE_PATH).'document/document.inc.php';
- require_once api_get_path(LIBRARY_PATH).'fileDisplay.lib.php';
- require_once api_get_path(LIBRARY_PATH).'document.lib.php';
- //require_once api_get_path(LIBRARY_PATH).'tablesort.lib.php'; moved to autoload
- require_once api_get_path(LIBRARY_PATH).'fileManage.lib.php';
- //if(!$is_in_admin){
- if (!api_is_platform_admin()){
- api_protect_course_script();
- }
- //session
- if(isset($_GET['id_session'])) {
- $_SESSION['id_session'] = intval($_GET['id_session']);
- }
- $htmlHeadXtra[] =
- "<script type=\"text/javascript\">
- function confirmation (name)
- {
- if (confirm(\" ". api_utf8_encode(get_lang('AreYouSureToDelete')) ." \"+ name + \" ?\"))
- {return true;}
- else
- {return false;}
- }
- </script>";
- /* Variables
- - some need defining before inclusion of libraries */
- $sType = isset($sType) ? $sType : '';
- if ($sType=="MP3") $sType="audio";
- // Resource type
- $sType = strtolower($sType);
- // Choosing the repository to be used.
- if (api_is_in_course()) {
- if (!api_is_in_group()) {
- // 1. We are inside a course and not in a group.
- if (api_is_allowed_to_edit()) {
- // 1.1. Teacher
- $base_work_dir = api_get_path(SYS_COURSE_PATH).api_get_course_path().'/document/';
- $http_www = api_get_path(WEB_COURSE_PATH).api_get_course_path().'/document/';
- } else {
- // 1.2. Student
- $base_work_dir = api_get_path(SYS_COURSE_PATH).api_get_course_path().'/document/shared_folder/'.api_get_user_id().'/';
- $http_www = api_get_path(WEB_COURSE_PATH).api_get_course_path().'/document/shared_folder/'.api_get_user_id().'/';
- }
- } else {
- // 2. Inside a course and inside a group.
- $base_work_dir = api_get_path(SYS_COURSE_PATH).api_get_course_path().'/document'.$group_properties['directory'].'/';
- $http_www = api_get_path(WEB_COURSE_PATH).api_get_course_path().'/document'.$group_properties['directory'].'/';
- }
- } else {
- if (api_is_platform_admin() && $_SESSION['this_section'] == 'platform_admin') {
- // 3. Platform administration activities.
- $base_work_dir = $_configuration['root_sys'].'home/default_platform_document/';
- $http_www = $_configuration['root_web'].'home/default_platform_document/';
- } else {
- // 4. The user is outside courses.
- $my_path = UserManager::get_user_picture_path_by_id(api_get_user_id(),'system');
- $base_work_dir = $my_path['dir'].'my_files/';
- $my_path = UserManager::get_user_picture_path_by_id(api_get_user_id(),'web');
- $http_www = $my_path['dir'].'my_files/';
- }
- }
- // Set the upload path according to the resource type.
- if ($sType == 'audio') {
- check_and_create_resource_directory($base_work_dir, '/audio', get_lang('Audio'));
- $base_work_dir = $base_work_dir.'audio/';
- $http_www = $http_www.'audio/';
- $path = "/audio/";
- } elseif ($sType == 'flash') {
- check_and_create_resource_directory($base_work_dir, '/flash', get_lang('Flash'));
- $base_work_dir = $base_work_dir.'flash/';
- $http_www = $http_www.'flash/';
- $path = "/flash/";
- } elseif ($sType == 'images') {
- check_and_create_resource_directory($base_work_dir, '/images', get_lang('Images'));
- $base_work_dir = $base_work_dir.'images/';
- $http_www = $http_www.'images/';
- $path = "/images/";
- } elseif ($sType == 'video') {
- check_and_create_resource_directory($base_work_dir, '/video', get_lang('Video'));
- $base_work_dir = $base_work_dir.'video/';
- $http_www = $http_www.'video/';
- $path = "/video/";
- } elseif ($sType == 'video/flv') {
- check_and_create_resource_directory($base_work_dir, '/video', get_lang('Video'));
- check_and_create_resource_directory($base_work_dir, '/video/flv', 'flv');
- $base_work_dir = $base_work_dir.'video/flv/';
- $http_www = $http_www.'video/flv/';
- $path = "/video/flv/";
- }
- $course_dir = $_course['path'].'/document/'.$sType;
- $sys_course_path = api_get_path(SYS_COURSE_PATH);
- $dbl_click_id = 0; // used to avoid double-click
- $is_allowed_to_edit = api_is_allowed_to_edit();
- $req_gid = '';
- /* Constants and variables */
- $course_quota = DocumentManager::get_course_quota();
- /* MAIN SECTION */
- /* Header */
- $tool_name = get_lang('Doc'); // Title of the page (should come from the language file)
- ?>
- <style type="text/css" media="screen, projection">
- /*<![CDATA[*/
- @import "<?php echo api_get_path(WEB_CSS_PATH); ?>public_admin/default.css";
- /*]]>*/
- </style>
- <?php
- if(api_get_setting('stylesheets')<>'')
- {
- ?>
- <style type="text/css" media="screen, projection">
- /*<![CDATA[*/
- @import "<?php echo api_get_path(WEB_CSS_PATH), api_get_setting('stylesheets'); ?>/default.css";
- /*]]>*/
- </style>
- <?php
- }
- $is_allowed_to_edit = api_is_allowed_to_edit();
- if ($is_allowed_to_edit) { // TEACHER ONLY
- /* DELETE FILE OR DIRECTORY */
- if (isset($_GET['delete'])) {
- if (DocumentManager::delete_document($_course,$_GET['delete'], $base_work_dir)) {
- Display::display_normal_message(api_utf8_encode(get_lang('DocDeleted')));
- } else {
- Display::display_normal_message(api_utf8_encode(get_lang('DocDeleteError')));
- }
- }
- if (isset($_POST['action'])) {
- switch ($_POST['action']) {
- case 'delete':
- foreach ($_POST['path'] as $index => $path) {
- DocumentManager::delete_document($_course, $path, $base_work_dir);
- }
- Display::display_normal_message(api_utf8_encode(get_lang('DocDeleted')));
- break;
- }
- }
- }
- /* GET ALL DOCUMENT DATA FOR CURDIRPATH */
- $docs_and_folders = getlist ($base_work_dir.'/');
- if ($docs_and_folders) {
- //create a sortable table with our data
- $sortable_data = array();
- while (list ($key, $id) = each($docs_and_folders)) {
- // Skip directories.
- if ($id['filetype'] != 'file') {
- continue;
- }
- $row = array ();
- //if the item is invisible, wrap it in a span with class invisible
- $invisibility_span_open = ($id['visibility'] == 0) ? '<span class="invisible">' : '';
- $invisibility_span_close = ($id['visibility'] == 0) ? '</span>' : '';
- //size (or total size of a directory)
- $size = $id['filetype'] == 'folder' ? get_total_folder_size($id['path'], $is_allowed_to_edit) : $id[size];
- //get the title or the basename depending on what we're using
- if ($id['title'] != '') {
- $document_name = $id['title'];
- } else {
- $document_name = basename($id['path']);
- }
- //$row[] = $key; //testing
- //data for checkbox
- /*
- if ($is_allowed_to_edit AND count($docs_and_folders) > 1) {
- $row[] = $id['path'];
- }
- */
- // icons with hyperlinks
- $row[]= '<a href="#" onclick="javascript: OpenFile(\''.$http_www.'/'.$id['title'].'\', \''.$sType.'\');return false;">'.build_document_icon_tag($id['filetype'],$id['path']).'</a>';
- //document title with hyperlink
- $row[] = '<a href="#" onclick="javascript: OpenFile(\''.$http_www.'/'.$id['title'].'\', \''.$sType.'\');return false;">'.$id['title'].'</a>';
- //comments => display comment under the document name
- //$row[] = $invisibility_span_open.nl2br(htmlspecialchars($id['comment'])).$invisibility_span_close;
- $display_size = format_file_size($size);
- $row[] = '<span style="display:none;">'.$size.'</span>'.$invisibility_span_open.$display_size.$invisibility_span_close;
- //last edit date
- $display_date = format_date(strtotime($id['lastedit_date']));
- $row[] = '<span style="display:none;">'.$id['lastedit_date'].'</span>'.$invisibility_span_open.$display_date.$invisibility_span_close;
- $sortable_data[] = $row;
- }
- } else {
- $sortable_data = array();
- //$table_footer='<div style="text-align:center;"><strong>'.get_lang('NoDocsInFolder').'</strong></div>';
- }
- $table = new SortableTableFromArray($sortable_data, 4, 10);
- $query_vars['curdirpath'] = $curdirpath;
- if (isset($_SESSION['_gid'])) {
- $query_vars['gidReq'] = $_SESSION['_gid'];
- }
- $table->set_additional_parameters($query_vars);
- $column = 0;
- /*
- if ($is_allowed_to_edit AND count($docs_and_folders) > 1) {
- $table->set_header($column++, '', false);
- }
- */
- $table->set_header($column++, api_htmlentities(get_lang('Type'), ENT_QUOTES));
- $table->set_header($column++, api_htmlentities(get_lang('Title'), ENT_QUOTES));
- //$column_header[] = array(get_lang('Comment'),true); => display comment under the document name
- $table->set_header($column++, api_htmlentities(get_lang('Size'), ENT_QUOTES));
- $table->set_header($column++, api_htmlentities(get_lang('Date'), ENT_QUOTES));
- //currently only delete action -> take only DELETE right into account
- /*
- if (count($docs_and_folders) > 1) {
- if ($is_allowed_to_edit) {
- $form_actions = array();
- $form_action['delete'] = get_lang('Delete');
- $table->set_form_actions($form_action, 'path');
- }
- }
- */
- echo api_utf8_encode($table->get_table_html());
- echo api_utf8_encode($table_footer);
- // Functions
- ?>
- <script type="text/javascript">
- <!--
- function OpenFile( fileUrl, type )
- {
- if (type=="audio")
- {
- ret = confirm('<?php echo api_utf8_encode(get_lang('AutostartMp3')); ?>');
- if (ret)
- {
- GetE('autostart').checked = true;
- }
- else
- {
- GetE('autostart').checked = false;
- }
- }
- SetUrl( fileUrl ) ;
- //window.close() ;
- }
- //-->
- </script>
|