"../group/group_space.php?gidReq=".$_SESSION['_gid'], "name" => get_lang('GroupSpace')); $noPHP_SELF = true; $to_group_id = $_SESSION['_gid']; $group = GroupManager :: get_group_properties($to_group_id); $path = explode('/', $dir); if ('/'.$path[1] != $group['directory']) { api_not_allowed(); } } $interbreadcrumb[] = array ("url" => "./document.php?curdirpath=".urlencode($_GET['dir']).$req_gid, "name" => get_lang('Documents')); if (!$is_allowed_in_course) api_not_allowed(); $is_allowedToEdit = $is_courseAdmin; if (!($is_allowedToEdit || $_SESSION['group_member_with_upload_rights'])) { api_not_allowed(); } /* ----------------------------------------------------------- Header ----------------------------------------------------------- */ event_access_tool(TOOL_DOCUMENT); $display_dir = $dir; if (isset ($group)) { $display_dir = explode('/', $dir); unset ($display_dir[0]); unset ($display_dir[1]); $display_dir = implode('/', $display_dir); } // Create a new form $form = new FormValidator('create_document'); // Hidden element with current directory $form->addElement('hidden', 'dir'); $default['dir'] = $dir; // Filename $form->add_textfield('filename', get_lang('FileName'),true,'class="input_titles"'); $form->addRule('filename', get_lang('FileExists'), 'callback', 'document_exists'); /** * Check if a document width the choosen filename allready exists */ function document_exists($filename) { global $filepath; $filename = replace_dangerous_char($filename); return !file_exists($filepath.$filename.'.html'); } // Change the default renderer for the filename-field to display the dir and extension $renderer = & $form->defaultRenderer(); $filename_template = str_replace('{element}', "$display_dir {element} .html", $renderer->_elementTemplate); $renderer->setElementTemplate($filename_template, 'filename'); // If allowed, add element for document title if (get_setting('use_document_title') == 'true') { $form->add_textfield('title', get_lang('Title'),true,'class="input_titles"'); } // HTML-editor $form->add_html_editor('content', get_lang('Content'), false, true); // Comment-field //$form->addElement('textarea', 'comment', get_lang('Comment'), array ('rows' => 5, 'cols' => 50)); $form->addElement('submit', 'submit', get_lang('Ok')); $form->setDefaults($default); // If form validates -> save the new document if ($form->validate()) { $values = $form->exportValues(); if (get_setting('use_document_title') != 'true') { $values['title'] = $values['filename']; } $filename = replace_dangerous_char($values['filename']); $texte = $values['content']; $title = $values['filename']; $extension = 'html'; if (!strstr($texte, '/css/frames.css')) { $texte = str_replace('', '', $texte); } if ($fp = @ fopen($filepath.$filename.'.'.$extension, 'w')) { $texte = text_filter($texte); $path_to_remove = api_get_path('WEB_COURSE_PATH').$_course['path'].'/document'.$dir; $texte = str_replace($path_to_remove, './', $texte); $texte = str_replace('mp3player.swf?son='.urlencode($path_to_remove), 'mp3player.swf?son=.%2F', $texte); fputs($fp, $texte); fclose($fp); if (!is_dir($filepath.'css')) { mkdir($filepath.'css', 0777); $doc_id = add_document($_course, $dir.'css', 'folder', 0, 'css'); api_item_property_update($_course, TOOL_DOCUMENT, $doc_id, 'FolderCreated', $_user['user_id']); api_item_property_update($_course, TOOL_DOCUMENT, $doc_id, 'invisible', $_user['user_id']); } if (!is_file($filepath.'css/frames.css')) { copy(api_get_path(SYS_CODE_PATH).'css/frames.css', $filepath.'css/frames.css'); $doc_id = add_document($_course, $dir.'css/frames.css', 'file', filesize($filepath.'css/frames.css'), 'frames.css'); api_item_property_update($_course, TOOL_DOCUMENT, $doc_id, 'DocumentAdded', $_user['user_id']); api_item_property_update($_course, TOOL_DOCUMENT, $doc_id, 'invisible', $_user['user_id']); } $file_size = filesize($filepath.$filename.'.'.$extension); $save_file_path = $dir.$filename.'.'.$extension; $document_id = add_document($_course, $save_file_path, 'file', $file_size, $filename); if ($document_id) { api_item_property_update($_course, TOOL_DOCUMENT, $document_id, 'DocumentAdded', $_user['user_id'], $to_group_id); //update parent folders item_property_update_on_folder($_course, $_GET['dir'], $_user['user_id']); $new_comment = isset ($_POST['comment']) ? trim($_POST['comment']) : ''; $new_title = isset ($_POST['title']) ? trim($_POST['title']) : ''; if ($new_comment || $new_title) { $TABLE_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT); $ct = ''; if ($new_comment) $ct .= ", comment='$new_comment'"; if ($new_title) $ct .= ", title='$new_title'"; api_sql_query("UPDATE $TABLE_DOCUMENT SET".substr($ct, 1)." WHERE id = '$document_id'", __FILE__, __LINE__); } $dir= substr($dir,0,-1); header('Location: document.php?curdirpath='.urlencode($dir)); exit (); } } else { Display :: display_header($nameTools, "Doc"); api_display_tool_title($nameTools); Display :: display_error_message(get_lang('Impossible')); Display :: display_footer(); } } else { Display :: display_header($nameTools, "Doc"); api_display_tool_title($nameTools); $form->display(); Display :: display_footer(); } ?>