123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * @author Patrick Cool, original code
- * @author Denes Nagy - many bugfixes and improvements, adjusted for learning path
- * @author Roan Embrechts - refactoring, code cleaning
- * @package chamilo.resourcelinker
- * @todo reorganise code,
- * use Database API instead of creating table names locally.
- */
- /**
- * Code
- */
- /* INIT SECTION */
- // Flag to allow for anonymous user - needs to be set before global.inc.php.
- use \ChamiloSession as Session;
- $use_anonymous = true;
- // Name of the language file that needs to be included.
- $language_file = 'resourcelinker';
- require_once 'back_compat.inc.php';
- $this_section = SECTION_COURSES;
- api_protect_course_script();
- /* Libraries */
- include 'resourcelinker.inc.php';
- /* Constants and variables */
- $link_table = Database :: get_course_table(TABLE_LINK);
- $item_property_table = Database :: get_course_table(TABLE_ITEM_PROPERTY);
- //$tbl_learnpath_main = Database :: get_course_table(TABLE_LEARNPATH_MAIN);
- //$tbl_learnpath_chapter = Database :: get_course_table(TABLE_LEARNPATH_CHAPTER);
- //$tbl_learnpath_item = Database :: get_course_table(TABLE_LEARNPATH_ITEM);
- $tbl_lp = Database::get_course_table(TABLE_LP_MAIN);
- $tbl_lp_item = Database::get_course_table(TABLE_LP_ITEM);
- $action = $_REQUEST['action'];
- $add = $_REQUEST['add'];
- $chapter_id = $_REQUEST['parent_item_id'];
- $content = $_REQUEST['content'];
- // Note by Patrick Cool: This has been solved belowd. This piece of code hacking produced too much errors.
- /*
- if (empty($content)) {
- // Adds a default to the item-type selection.
- $content = 'Document';
- }
- */
- $folder = $_REQUEST['folder'];
- $id = $_REQUEST['id'];
- $learnpath_id = $_REQUEST['lp_id'];
- $originalresource = $_REQUEST['originalresource'];
- $show_resources = $_REQUEST['show_resources'];
- $source_forum = $_REQUEST['source_forum'];
- $source_id = $_REQUEST['source_id'];
- $target = $_REQUEST['target'];
- $external_link = $_REQUEST['external_link'];
- $from_learnpath = $_SESSION['from_learnpath'];
- // This variable controls wether the link to add a chapter in a module or
- // another chapter is shown. This allows to create multi-level learnpaths,
- // but export features are not ready for this, yet, so use at your own risks
- // default : false -> do not display link
- // This setting should be moved to the platform configuration page in time...
- $multi_level_learnpath = true;
- /* MAIN CODE */
- if ($from_learnpath == 'yes') {
- // Start from clear every time in LearnPath Builder.
- $_SESSION['addedresource'] = null;
- $_SESSION['addedresourceid'] = null;
- $_SESSION['addedresourceassigned'] = null;
- unset ($_SESSION['addedresource']);
- unset ($_SESSION['addedresourceid']);
- unset ($_SESSION['addedresourceassigned']);
- }
- $course_id = api_get_course_int_id();
- // Process a new chapter?
- if (!empty ($_POST['add_chapter']) && !empty ($_POST['title'])) {
- $title = $_POST['title'];
- $description = '';
- /*if (!empty ($_POST['description'])) {
- $description = $_POST['description'];
- }*/
- // Get max display_order so far in this parent chapter.
- $sql = "SELECT MAX(display_order) as maxi FROM $tbl_lp_item " .
- "WHERE c_id = $course_id AND lp_id = $learnpath_id ".
- " AND parent_item_id = $chapter_id";
- $res = Database::query($sql);
- $row = Database::fetch_array($res);
- $lastorder_item = $row['maxi'];
- if (empty($lastorder_item)) {
- $lastorder_item = 0;
- $previous = 0;
- } else {
- $sql = "SELECT id FROM $tbl_lp_item " .
- "WHERE lp_id = $learnpath_id AND parent_item_id=$chapter_id AND display_order = $lastorder_item";
- $result = Database::query($sql);
- $row = Database::fetch_array($result);
- $previous = $row['id'];
- }
- $order = $lastorder_item + 1;
- $sql = "INSERT INTO $tbl_lp_item "."(c_id, lp_id,item_type,title,parent_item_id,previous_item_id, next_item_id, display_order) " .
- "VALUES "."($course_id, $learnpath_id,'dokeos_chapter','$title', $chapter_id, $previous, 0, $order )";
- //error_log('New LP - Inserting new resource: '.$sql, 0);
- $res = Database::query($sql);
- $my_id = Database::insert_id($res);
- if ($previous > 0) {
- $sql = "UPDATE $tbl_lp_item SET next_item_id = $my_id WHERE id=$previous";
- $res = Database::query($sql);
- }
- if ($res !== false) {
- $title = '';
- $description = '';
- }
- $resource_added = true;
- }
- // This if when a external link is submitted.
- if (!empty ($_POST['external_link_submit'])) {
- if ($external_link == '' || $external_link == 'http://') {
- $InvalidURL = 1;
- } else {
- $add = true;
- if ($add_2_links != 'niet toevoegen') {
- // Add external link to the links table.
- $pos = strpos($external_link, 'ttp:');
- if ($pos == '') {
- $external_link = 'http://'.$external_link;
- }
- $sql = "INSERT INTO $link_table (c_id, url, title, category_id) VALUES ($course_id, '$external_link','$external_link','$add_2_links')";
- $result = Database::query($sql);
- $addedresource[] = "Link";
- $addedresourceid[] = Database::insert_id();
- $_SESSION['addedresource'] = $addedresource;
- $_SESSION['addedresourceid'] = $addedresourceid;
- } else {
- // Do not add external link to the links table.
- $addedresource[] = "Externallink";
- $addedresourceid[] = $external_link;
- $_SESSION['addedresource'] = $addedresource;
- $_SESSION['addedresourceid'] = $addedresourceid;
- }
- }
- }
- // Loading the session variables into local array.
- $addedresource = $_SESSION['addedresource'];
- $addedresourceid = $_SESSION['addedresourceid'];
- // This is when a resource was added to the session.
- if ($add) {
- // Adding the new variable to the local array.
- if (empty($_POST['external_link_submit'])) {
- // That case is already arranged, see upwards.
- $addedresource[] = $content;
- $addedresourceid[] = $add;
- }
- $addedresourceassigned[] = 0;
- // Loading the local array into the session variable.
- $_SESSION['addedresource'] = $addedresource;
- $_SESSION['addedresourceid'] = $addedresourceid;
- // We assign to chapters immediately!
- $resource_added = false;
- if ($from_learnpath == 'yes') {
- $i = 0;
- // Calculating the last order of the items of this chapter.
- $sql = "SELECT MAX(display_order) as maxi FROM $tbl_lp_item " .
- "WHERE c_id = $course_id AND lp_id = $learnpath_id AND parent_item_id=$chapter_id";
- $result = Database::query($sql);
- $row = Database::fetch_array($result);
- $lastorder_item = $row['maxi'];
- if (empty($lastorder_item)) {
- $lastorder_item = 0;
- $previous = 0;
- } else {
- $sql = "SELECT id FROM $tbl_lp_item " .
- "WHERE lp_id = $learnpath_id AND parent_item_id=$chapter_id AND display_order = $lastorder_item";
- //error_log('New LP - resourcelinker.php - '.$sql, 0);
- $result = Database::query($sql);
- $row = Database::fetch_array($result);
- $previous = $row['id'];
- }
- $lastorder = $lastorder_item + 1;
- foreach ($addedresource as $addedresource_item) {
- // In the case we added a chapter, add this into the chapters list with the correct parent_id.
- if ($addedresource_item == 'Chap') {
- $sql = "INSERT INTO $tbl_lp_item " .
- "(c_id, lp_id,item_type,title,parent_item_id,previous_item_id,next_item_id,display_order) " .
- "VALUES ($course_id, ".$learnpath_id.",'dokeos_chapter','".$learnpath_chapter_name."',".$chapter_id.",$previous,0,".$lastorder.")";
- //error_log('New LP - Inserting new resource: '.$sql, 0);
- $res = Database::query($sql);
- $my_id = Database::insert_id($res);
- if ($previous > 0) {
- $sql = "UPDATE $tbl_lp_item SET next_item_id = $my_id WHERE id=$previous";
- $res = Database::query($sql);
- }
- }
- if (!$addedresourceassigned[$i]) {
- // Not to assign it twice
- switch ($addedresource_item) {
- case 'Assignment':
- case 'Ass':
- //set tool type
- $addedresource_item = 'Assignments';
- $title = get_lang('Assignments');
- break;
- case 'Drop':
- //$addedresource_item = 'Dropbox';
- $addedresource_item = TOOL_DROPBOX;
- $title = get_lang('Dropbox');
- break;
- case 'Intro':
- $addedresource_item = 'Introduction_text';
- //$addedresource_item = TOOL_INTRO;
- $title = get_lang('IntroductionText');
- break;
- case 'Course_desc':
- //$addedresource_item = 'Course_description';
- $addedresource_item = TOOL_COURSE_DESCRIPTION;
- $title = get_lang('CourseDescription');
- break;
- case 'Group':
- //$addedresource_item = 'Groups';
- $addedresource_item = TOOL_GROUP;
- $title = get_lang('Groups');
- break;
- case 'User':
- //$addedresource_item = 'Users';
- $addedresource_item = TOOL_USER;
- $title = get_lang('Users');
- break;
- case 'Link':
- /*
- if ($target == '') {
- $target = '_self';
- }
- */
- //$addedresource_item .= ' '.$target;
- //error_log('New LP - resourcelinker.php - In Link addition: '.$external_link);
- $addedresource_item = TOOL_LINK;
- $title = $external_link;
- break;
- case 'Document':
- $addedresource_item = TOOL_DOCUMENT;
- //get title from tool-type table
- $tooltable = Database::get_course_table(TABLE_DOCUMENT);
- $result = Database::query("SELECT * FROM $tooltable WHERE id=".$addedresourceid[$i]);
- $myrow=Database::fetch_array($result);
- $title = $myrow['title'];
- break;
- case 'Exercise':
- $addedresource_item = TOOL_QUIZ;
- //get title from tool-type table
- $tooltable = Database::get_course_table(TABLE_QUIZ_TEST);
- $result = Database::query("SELECT * FROM $tooltable WHERE id=".$addedresourceid[$i]);
- $myrow=Database::fetch_array($result);
- $title = $myrow['title'];
- break;
- case 'Forum':
- $addedresource_item = TOOL_FORUM;
- //TODO
- break;
- case 'Agenda':
- $addedresource_item = TOOL_CALENDAR_EVENT;
- //get title from tool-type table
- $tooltable = Database::get_course_table(TABLE_AGENDA);
- $result = Database::query("SELECT * FROM $tooltable WHERE id=".$addedresourceid[$i]);
- $myrow=Database::fetch_array($result);
- $title = $myrow['title'];
- break;
- case 'Ad_Valvas':
- $addedresource_item = TOOL_ANNOUNCEMENT;
- //get title from tool-type table
- $tooltable = Database::get_course_table(TABLE_ANNOUNCEMENT);
- $result = Database::query("SELECT * FROM $tooltable WHERE id=".$addedresourceid[$i]);
- $myrow=Database::fetch_array($result);
- $title = $myrow['title'];
- break;
- }
- $sql = "INSERT INTO $tbl_lp_item (c_id, lp_id, title, parent_item_id, item_type, ref, previous_item_id, next_item_id, display_order) " .
- "VALUES ($course_id, $learnpath_id, '$title','$chapter_id', '$addedresource_item','$addedresourceid[$i]',$previous,0,'".$lastorder."')";
- //error_log('New LP - Inserting new resource: '.$sql, 0);
- $result = Database::query($sql);
- $my_id = Database::insert_id($result);
- if ($previous > 0) {
- $sql = "UPDATE $tbl_lp_item SET next_item_id = $my_id WHERE id = $previous";
- //error_log($sql, 0);
- $res = Database::query($sql);
- }
- $addedresourceassigned[$i] = 1;
- $resource_added = true;
- }
- $i ++;
- $lastorder ++;
- }
- //$_SESSION['addedresource']=null;
- //$_SESSION['addedresourceid']=null;
- // cleaning up the session once again
- $_SESSION['addedresource'] = null;
- $_SESSION['addedresourceid'] = null;
- $_SESSION['addedresourceassigned'] = null;
- unset ($_SESSION['addedresource']);
- unset ($_SESSION['addedresourceid']);
- unset ($_SESSION['addedresourceassigned']);
- }
- }
- /*
- BREADCRUMBS
- This part is to allow going back to the tool where you came from
- in a previous version I used the table tool_list, but since the forum can access the
- resource_linker from two different pages (newtopic.php and editpost.php) and this is different
- from the link field in tool_list, I decide to hardcode this stuff here.
- By doing this, you can easily control which pages can access the toollinker and which not.
- */
- if (isset($_SESSION['gradebook'])) {
- $gradebook = $_SESSION['gradebook'];
- }
- if (!empty($gradebook) && $gradebook == 'view') {
- $interbreadcrumb[] = array (
- 'url' => '../gradebook/'.$_SESSION['gradebook_dest'],
- 'name' => get_lang('ToolGradebook')
- );
- }
- if ($_GET['source_id']) {
- switch ($_GET['source_id']) {
- case '1': // coming from Agenda
- if ($action == 'edit') {
- $url = "../calendar/agenda.php?action=edit&id=49&originalresource=$originalresource";
- }
- elseif ($action == 'add') {
- $url = "../calendar/agenda.php?action=add&originalresource=$originalresource";
- } else {
- $url = "../calendar/agenda.php?action=add";
- }
- $originaltoolname = get_lang('Agenda');
- $breadcrumbelement = array ('url' => $url, 'name' => $originaltoolname);
- session_unregister('from_learnpath');
- unset ($from_learnpath);
- break;
- case '2': // coming from forum: new topic
- $url = "../phpbb/newtopic.php?forum=$source_forum&md5=$md5";
- $originaltoolname = get_lang('ForumAddNewTopic');
- $breadcrumbelement = array ('url' => $url, 'name' => $originaltoolname);
- session_unregister('from_learnpath');
- unset ($from_learnpath);
- break;
- case '3': // coming from forum: edit topic
- $url = "../phpbb/editpost.php?post_id=$post_id&topic=$topic&forum=$forum&md5=$md5&originalresource=no";
- $originaltoolname = get_lang('ForumEditTopic');
- $breadcrumbelement = array ('url' => $url, 'name' => $originaltoolname);
- session_unregister('from_learnpath');
- unset ($from_learnpath);
- break;
- case '4': // coming from exercises: edit topic
- $url = "../exercice/admin.php?modifyAnswers=$modifyAnswers";
- $originaltoolname = get_lang('ExerciseAnswers');
- $breadcrumbelement = array ('url' => $url, 'name' => $originaltoolname);
- session_unregister('from_learnpath');
- unset ($from_learnpath);
- break;
- case '5': // coming from learning path
- $from_learnpath = 'yes';
- Session::write('from_learnpath',$from_learnpath);
- break;
- case '6': // coming from forum: reply
- $url = "../phpbb/reply.php?topic=$topic&forum=$forum&parentid=$parentid";
- $url = $_SESSION['origintoolurl'];
- $originaltoolname = get_lang('ForumReply');
- $breadcrumbelement = array ('url' => $url, 'name' => $originaltoolname);
- session_unregister('from_learnpath');
- unset ($from_learnpath);
- break;
- /* add Frederik.Vermeire@pandora.be */
- case '7': // coming from Ad_Valvas
- if ($action == 'edit') {
- $url = "../announcements/announcements.php?action=edit&id=49&originalresource=$originalresource";
- } elseif ($action == 'add') {
- $url = "../announcements/announcements.php?action=add&originalresource=$originalresource";
- } else {
- $url = "../announcements/announcements.php?action=add";
- }
- $originaltoolname = get_lang('AdValvas');
- $breadcrumbelement = array ('url' => $url, 'name' => $originaltoolname);
- session_unregister('from_learnpath');
- unset ($from_learnpath);
- break;
- /* end add Frederik.Vermeire@pandora.be */
- }
- // We do not come from the learning path. We store the name of the tool & url in a session.
- if ($from_learnpath != 'yes') {
- if (!$_SESSION['origintoolurl'] || $_SESSION['origintoolurl'] != $interbreadcrumb['url']) {
- $_SESSION['origintoolurl'] = $breadcrumbelement['url'];
- $_SESSION['origintoolname'] = $breadcrumbelement['name'];
- $interbreadcrumb = '';
- }
- }
- }
- // This part of the code is the actual breadcrumb mechanism. If we do not come from the learning path we use
- // the information from the session. Else we use the information of the learningpath itself.
- if ($from_learnpath != 'yes') {
- $nameTools = get_lang('Attachment');
- $interbreadcrumb[] = array ('url' => $_SESSION['origintoolurl'], 'name' => $_SESSION['origintoolname']);
- } else {
- $learnpath_select_query = " SELECT * FROM $tbl_lp
- WHERE id=$learnpath_id";
- $sql_result = Database::query($learnpath_select_query);
- $therow = Database::fetch_array($sql_result);
- $learnpath_chapter_query = " SELECT * FROM $tbl_lp_item
- WHERE (lp_id = '$learnpath_id' and id = '$chapter_id')";
- $sql_result = Database::query($learnpath_chapter_query);
- $therow2 = Database::fetch_array($sql_result);
- $from_learnpath = 'yes';
- session_register('from_learnpath');
- $interbreadcrumb[] = array ('url' => "../newscorm/lp_controller.php?action=list", 'name' => get_lang('LearningPath'));
- $interbreadcrumb[] = array ('url' => "../newscorm/lp_controller.php?action=admin_view&lp_id=$learnpath_id", 'name' => stripslashes("{$therow['name']}"));
- $interbreadcrumb[] = array ('url' => api_get_self()."?action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no", 'name' => "{$therow2['title']}");
- }
- $htmlHeadXtra[] = '<script type="text/javascript">
- /* <![CDATA[ */
- function targetfunc(input)
- {
- window.location=window.location+"&target="+document.learnpath_link.target.value;
- }
- /* ]]> */
- </script>';
- Display :: display_header($nameTools);
- echo "<h3>".$nameTools;
- if ($from_learnpath == 'yes') {
- echo get_lang('AddResource')." - {$therow2['title']}";
- }
- echo "</h3>";
- // We retrieve the tools that are active.
- // We use this to check which resources a student may add (only the modules that are active).
- // See http://www.dokeos.com/forum/viewtopic.php?t=4858
- $active_modules = array();
- $tool_table = Database::get_course_table(TABLE_TOOL_LIST);
- $sql_select_active = "SELECT * FROM $tool_table WHERE visibility='1'";
- $result_select_active = Database::query($sql_select_active);
- while ($row=Database::fetch_array($result_select_active)) {
- $active_modules[] = $row['name'];
- }
- ?>
- <table width="100%" border="0" cellspacing="0" cellpadding="0">
- <tr>
- <td width="300" valign="top" style='padding-right:15px;'>
- <table width="300" border="0" cellspacing="0" cellpadding="0" style='border-right:1px solid grey;'>
- <?php if ($from_learnpath != 'yes') { ?>
- <tr>
- <td width="26%"><b><?php echo get_lang('CourseResources'); ?></b></td>
- </tr>
- <?php
- if (api_is_allowed_to_edit() || in_array(TOOL_DOCUMENT, $active_modules)) {
- ?>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Document&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Documents')."</a>"; ?></td>
- </tr>
- <?php
- }
- if (api_is_allowed_to_edit() || in_array(TOOL_CALENDAR_EVENT, $active_modules)) {
- ?>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Agenda&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Agenda')."</a>"; ?></td>
- </tr>
- <?php
- }
- if (api_is_allowed_to_edit() || in_array(TOOL_ANNOUNCEMENT, $active_modules)) {
- ?>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Ad_Valvas&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('AdValvas')."</a>"; ?></td>
- </tr>
- <?php
- }
- if (api_is_allowed_to_edit() || in_array(TOOL_BB_FORUM, $active_modules)) {
- ?>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Forum&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Forum')."</a>"; ?></td>
- </tr>
- <?php
- }
- if (api_is_allowed_to_edit() || in_array(TOOL_LINK, $active_modules)) {
- ?>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Link&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Links')."</a>"; ?></td>
- </tr>
- <?php
- }
- if (api_is_allowed_to_edit() || in_array(TOOL_QUIZ, $active_modules)) {
- ?>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Exercise&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Exercise')."</a>"; ?></td>
- </tr>
- <?php
- }
- } else {
- ?>
- <!--tr>
- <td width="26%"><b><?php echo get_lang('ExportableCourseResources'); ?></b></td>
- </tr-->
- <?php if ($multi_level_learnpath === true ) { ?>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=chapter&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Chapter')."</a>"; ?></td>
- </tr>
- <?php } ?>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Document&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Document')."</a>"; ?></td>
- </tr>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Exercise&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Exercise')."</a>"; ?></td>
- </tr>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Link&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Link')."</a>"; ?></td>
- </tr>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Forum&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Forum')."</a>"; ?></td>
- </tr>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Agenda&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Agenda')."</a>"; ?></td>
- </tr>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Ad_Valvas&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('AdValvas')."</a>"; ?></td>
- </tr>
- <!--tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Course_description&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('CourseDescription')."</a>"; ?></td>
- </tr-->
- <!--tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Introduction_text&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('IntroductionText')."</a>"; ?></td>
- </tr-->
- <!--tr>
- <td> </td>
- </tr-->
- <!--tr>
- <td width="26%"><b><?php echo get_lang('DokeosRelatedCourseMaterial'); ?></b></td>
- </tr-->
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Dropbox&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Dropbox')."</a>"; ?></td>
- </tr>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Assignment&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Assignments')."</a>"; ?></td>
- </tr>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Groups&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Groups')."</a>"; ?></td>
- </tr>
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Users&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('Users')."</a>"; ?></td>
- </tr>
- <?php
- }
- ?>
- <!--tr>
- <td> </td>
- </tr-->
- <!--tr>
- <td><b><?php echo get_lang('ExternalResources'); ?></b></td>
- </tr-->
- <tr>
- <td><?php echo "<a href=\"".api_get_self()."?content=Externallink&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('ExternalLink')."</a>"; ?></td>
- </tr>
- <?php
- if ($from_learnpath != 'yes') {
- echo "<tr><td> </td></tr>";
- echo "<tr><td><b>".get_lang('ResourcesAdded')." (";
- echo count($addedresource);
- echo ")</b></td></tr>";
- echo "<tr><td nowrap><a href=\"".api_get_self()."?showresources=true&action=$action&id=$id&lp_id=$learnpath_id&parent_item_id=$chapter_id&source_forum=$source_forum&originalresource=no\">".get_lang('ShowDelete')."</a>";
- echo "</td></tr>";
- }
- ?>
- <tr>
- <td> </td>
- </tr>
- <!--<tr>
- <td><b><?php echo get_lang('BackTo'); ?></b></td>
- </tr>//-->
- <tr>
- <td>
- <?php
- if ($from_learnpath != 'yes') {
- echo "<form method=\"post\" action=\"{$_SESSION['origintoolurl']}\" style=\"margin: 0px;\"><input type=\"submit\" value=\"".' '.get_lang('Ok').' '."\"></form>";
- } else {
- echo "<form method=\"get\" action=\"lp_controller.php\" style=\"margin: 0px;\"><input type=\"hidden\" name=\"lp_id\" value=\"".htmlentities($learnpath_id)."\"><input type=\"hidden\" name=\"action\" value=\"admin_view\"><input type=\"submit\" value=\"".' '.get_lang('Ok').' '."\"></form>";
- }
- ?>
- </td>
- </tr>
- <tr>
- <td> </td>
- </tr>
- </table>
- </td>
- <td valign="top">
- <?php
- if ($resource_added) {
- Display :: display_normal_message(get_lang('ResourceAdded'));
- }
- if ($InvalidURL) {
- Display :: display_normal_message(get_lang('GiveURL'));
- }
- if ($from_learnpath != 'yes') {
- echo count($addedresource)." ".strtolower(get_lang('ResourcesAdded'))."<br />";
- }
- //echo "<hr />";
- // Agenda items -->
- if ($content == 'Agenda') {
- $TABLEAGENDA = Database::get_course_table(TABLE_AGENDA);
- $TABLE_ITEM_PROPERTY = Database::get_course_table(TABLE_ITEM_PROPERTY);
- $sql = "SELECT agenda.*, toolitemproperties.*
- FROM ".$TABLEAGENDA." agenda, ".$TABLE_ITEM_PROPERTY." toolitemproperties
- WHERE agenda.id = toolitemproperties.ref
- AND toolitemproperties.tool='".TOOL_CALENDAR_EVENT."'
- AND toolitemproperties.to_group_id='0'
- AND toolitemproperties.visibility='1'";
- $result = Database::query($sql);
- while ($myrow = Database::fetch_array($result)) {
- echo "<table width=\"100%\"><tr><td bgcolor=\"#E6E6E6\">";
- echo "<img src='../img/agenda.gif' alt='agenda'>";
- echo api_convert_and_format_date($myrow['start_date'], null, date_default_timezone_get())."<br />";
- echo "<b>".$myrow['title']."</b></td></tr><tr><td>";
- echo $myrow['content']."<br />";
- showorhide_addresourcelink($content, $myrow['id']);
- echo "</td></tr></table><br />";
- }
- } // end if ($_GET['resource'] == 'Agenda')
- /* Chapter */
- if ($content == 'chapter') {
- echo '<table><form name="add_chapter" action="'.'" method="POST">'."\n";
- echo ' <tr><td>'.get_lang('Title').'</td><td><input type="text" name="title" value="'.$title.'"></input></td></tr>'."\n";
- echo ' <tr><td>'.get_lang('Description').'</td><td><input type="text" name="description" value="'.$description.'"></input></td></tr>'."\n";
- echo ' <tr><td></td><td><input type="submit" name="add_chapter" value="'.get_lang('AddIt').'"/></td></tr>'."\n";
- echo '</form></table>'."\n";
- //echo "<hr />";
- }
- /* Documents */
- // We show the documents in the following cases
- // 1. the link to add documenets in the resource linker was clicked
- // 2. we come to the resource linker for the first time (documents = default). In this case it can only be shown if
- // a. one is a teacher (documents can be shown even if the tool is inactive)
- // b. one is a student AND the documents tool is active. Student cannot add documents if the documents tool is inactive (teacher can do this)
- if ($content == 'Document' || (empty($content) && (api_is_allowed_to_edit() || in_array(TOOL_DOCUMENT, $active_modules))) && !$_GET['showresources']) {
- // setting variables for file locations
- $baseServDir = $_configuration['root_sys'];
- $courseDir = $_course['path'].'/document';
- $baseWorkDir = $baseServDir.$courseDir;
- // showing the link to move one folder up (when not in the root folder)
- show_folder_up();
- // showing the blue bar with the path in it when we are not in the root
- if (get_levels($folder)) {
- echo "<table width=\"100%\"><tr><td bgcolor=\"#4171B5\">";
- echo "<img src=\"../img/opendir.gif\" alt='directory'><font color=\"#ffffff\"><b>";
- echo $folder."</b></font></td></tr></table>";
- }
- // Showing the documents and subfolders of the folder we are in.
- show_documents($folder);
- //echo "<hr />";
- }
- /* Ad Valvas */
- if ($content == 'Ad_Valvas') {
- $tbl_announcement = Database :: get_course_table(TABLE_ANNOUNCEMENT);
- $sql = "SELECT * FROM ".$tbl_announcement." a, ".$item_property_table." i WHERE i.tool = '".TOOL_ANNOUNCEMENT."' AND a.id=i.ref AND i.visibility='1' AND i.to_group_id = 0 AND i.to_user_id IS NULL ORDER BY a.display_order ASC";
- //error_log($sql, 0);
- $result = Database::query($sql);
- while ($myrow = Database::fetch_array($result)) {
- echo "<table width=\"100%\"><tr><td>";
- echo "<img src='../img/valves.gif' alt='advalvas'>";
- echo api_convert_and_format_date($myrow['end_date'], DATE_FORMAT_LONG, date_default_timezone_get());
- echo "</td></tr><tr><td>";
- echo $myrow['title']."<br />";
- showorhide_addresourcelink($content, $myrow['id']);
- echo "</td></tr></table>";
- }
- }
- /* Forums */
- if ($content == 'Forum') {
- $TBL_FORUMS = Database::get_course_table(TABLE_FORUM);
- $TBL_CATAGORIES = Database::get_course_table(TABLE_FORUM_CATEGORY);
- $TBL_FORUMTOPICS = Database::get_course_table(TABLE_FORUM_THREAD);
- $tbl_posts = Database::get_course_table(TABLE_FORUM_POST);
- echo "<table width='100%'>";
- // Displaying the categories and the forums.
- if (!$forum and !$thread) {
- $sql = "SELECT * FROM ".$TBL_FORUMS." forums, ".$TBL_CATAGORIES." categories WHERE forums.forum_category=categories.cat_id ORDER BY forums.forum_category DESC";
- //error_log($sql, 0);
- $result = Database::query($sql);
- while ($myrow = Database::fetch_array($result)) {
- if ($myrow['cat_title'] !== $old_cat_title) {
- echo "<tr><td bgcolor='#4171B5' colspan='2'><font color='white'><b>".$myrow['cat_title']."</b></font></td></tr>";
- }
- $old_cat_title = $myrow['cat_title'];
- echo "<tr><td><img src='../img/forum.gif'><a href='".api_get_self()."?content=Forum&category=".$myrow['cat_id']."&forum=".$myrow['forum_id']."&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no'>".$myrow['forum_name']."</td><td>";
- showorhide_addresourcelink('Forum', $myrow['forum_id']);
- echo "</td></tr>";
- }
- }
- // Displaying all the threads of one forum.
- if ($forum) {
- // Displaying the category title.
- $sql = "SELECT * FROM ".$TBL_CATAGORIES." WHERE cat_id=$category";
- $result = Database::query($sql);
- $myrow = Database::fetch_array($result);
- echo "<tr><td bgcolor='#4171B5' colspan='2'><font color='white'><b>".$myrow['cat_title']."</b></font></td></tr>";
- // Displaying the forum title.
- $sql = "SELECT * FROM ".$TBL_FORUMS." forums, ".$TBL_FORUMTOPICS." topics WHERE forums.forum_id=topics.forum_id";
- $result = Database::query($sql);
- $myrow = Database::fetch_array($result);
- echo "<tr><td bgcolor='#cccccc' colspan='2'><b>".$myrow['forum_name']."</b></td></tr>";
- if (!$thread) {
- // Displaying all the threads of this forum.
- $sql = "SELECT * FROM ".$TBL_FORUMTOPICS." WHERE forum_id=$forum";
- $result = Database::query($sql);
- while ($myrow = Database::fetch_array($result)) {
- echo "<tr><td><a href='".api_get_self()."?content=Forum&category=$category&forum=1&thread=".$myrow['topic_id']."&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no'>".$myrow['topic_title']."</a> (".$myrow['prenom']." ".$myrow['nom'].")</td><td>";
- showorhide_addresourcelink("Thread", $myrow['topic_id']);
- echo "</td></tr>";
- }
- } else {
- // Displaying all the replies.
- $sql = "SELECT * FROM ".$tbl_posts." post WHERE post.topic_id=$thread ORDER BY post.post_id ASC";
- $result = Database::query($sql);
- while ($myrow = Database::fetch_array($result)) {
- echo "<tr><td><b>".$myrow['post_title']."</b><br />";
- echo $myrow['post_text']."</td>";
- echo "<td>";
- showorhide_addresourcelink('Post', $myrow['post_id']);
- echo "</td></tr><tr><td colspan='2'><hr noshade></td></tr>";
- }
- }
- }
- echo "</table>";
- }
- /* Links */
- if ($content == 'Link') {
- // Including the links language file.
- include "../lang/$language/link.inc.php";
- // Including the links functions file.
- require_once api_get_path(LIBRARY_PATH).'link.lib.php';
- $tbl_categories = Database::get_course_table(TABLE_LINK_CATEGORY);
- if (($learnpath_id != '') and ($content == 'Link')) {
- echo "<form name='learnpath_link'><table>";
- echo "<tr></td><td align='left'>".get_lang('LinkTarget')." :</td><td align='left'><select name='target' onchange='javascript: targetfunc();'><option value='_self' ";
- if ($target == '_self') {
- echo "selected";
- }
- echo ">".get_lang('SameWindow')."</option><option value='_blank'";
- if ($target == '_blank') {
- echo "selected";
- }
- echo ">".get_lang('NewWindow')."</option></select></td></tr></table></form>";
- }
- // Showing the links that are in the root (having no category).
- $sql = "SELECT * FROM ".$link_table." l, ".$item_property_table." ip WHERE (l.category_id=0 or l.category_id IS NULL) AND ip.tool = '".TOOL_LINK."' AND l.id=ip.ref AND ip.visibility='1'";
- $result = Database::query($sql);
- if (Database::num_rows($result) > 0) {
- echo "<table width=\"100%\"><tr><td bgcolor=\"#E6E6E6\"><i>".get_lang('NoCategory')."</i></td></tr></table>";
- while ($myrow = Database::fetch_array($result)) {
- echo "<img src='../img/links.gif'>".$myrow['title'];
- echo "<br />";
- showorhide_addresourcelink($content, $myrow['id']);
- echo "<br /><br />";
- }
- }
- // Showing the categories and the links in it.
- $sqlcategories = "SELECT * FROM ".$tbl_categories." ORDER by display_order DESC";
- $resultcategories = Database::query($sqlcategories) or die;
- while ($myrow = @ Database::fetch_array($resultcategories)) {
- $sql_links = "SELECT * FROM ".$link_table." l, ".$item_property_table." ip WHERE l.category_id='".$myrow['id']."' AND ip.tool = '".TOOL_LINK."' AND l.id=ip.ref AND ip.visibility='1' ORDER BY l.display_order DESC";
- echo "<table width=\"100%\"><tr><td bgcolor=\"#E6E6E6\"><i>".$myrow['category_title']."</i></td></tr></table>";
- $result_links = Database::query($sql_links);
- while ($myrow = Database::fetch_array($result_links)) {
- echo "<img src='../img/links.gif' />".$myrow['title'];
- echo "<br />";
- showorhide_addresourcelink($content, $myrow['id']);
- echo "<br /><br />";
- }
- }
- }
- /* Exercise */
- if (($content == 'Exercise') || ($content == 'HotPotatoes')) {
- $TBL_EXERCICES = Database::get_course_table(TABLE_QUIZ_TEST);
- $result = Database::query("SELECT * FROM ".$TBL_EXERCICES." WHERE active='1' ORDER BY id ASC");
- while ($myrow = Database::fetch_array($result)) {
- echo "<img src='../img/quiz.gif'>".$myrow['title']."<br />";
- showorhide_addresourcelink($content, $myrow["id"]);
- echo "<br /><br />";
- }
- if ($from_learnpath == 'yes') {
- $uploadPath = '/HotPotatoes_files';
- $TBL_DOCUMENT = Database::get_course_table(TABLE_DOCUMENT);
- $documentPath = api_get_path(SYS_COURSE_PATH).$_course['path'].'/document';
- $sql = "SELECT * FROM ".$TBL_DOCUMENT." WHERE (path LIKE '%htm%' OR path LIKE '%html%') AND path LIKE '".$uploadPath."/%/%' ORDER BY id ASC";
- $result = Database::query($sql);
- while ($myrow = Database::fetch_array($result)) {
- $path = $myrow['path'];
- echo "<img src='../img/jqz.jpg'>".GetQuizName($path, $documentPath)."<br />";
- showorhide_addresourcelink('HotPotatoes', $myrow['id']);
- echo "<br /><br />";
- }
- }
- }
- /* External Links */
- if ($content == 'Externallink') {
- ?>
- <form name="form1" method="post" action="">
- <table width="80%" border="0" cellspacing="0" cellpadding="0">
- <tr>
- <td align="right"><?php echo get_lang('ExternalLink'); ?> : </td>
- <td align="left"><input name="external_link" type="text" id="external_link" value="http://"></td>
- <?php
- if ($learnpath_id != '') {
- echo "</tr><tr><td align='right'>".get_lang('LinkTarget')." :</td><td align='left'><select name='target'><option value='_self'>".get_lang('SameWindow')."</option><option value='_blank'>".get_lang('NewWindow')."</option></select></td>";
- }
- ?>
- </tr>
- <tr>
- <td><?php if ($is_allowedToEdit) {echo get_lang('AddToLinks');} ?></td>
- <td>
- <?php if ($is_allowedToEdit){?>
- <select name="add_2_links" id="add_2_links">
- <option value="niet toevoegen" selected="selected">-<?php echo get_lang('DontAdd'); ?>-</option>
- <option value="0"><?php echo get_lang('MainCategory'); ?></option>
- <?php
- $tbl_categories = Database::get_course_table(TABLE_LINK_CATEGORY);
- $sql = "SELECT * FROM $tbl_categories ORDER BY display_order ASC";
- echo $sql;
- $result = Database::query($sql);
- while ($row = Database::fetch_array($result)) {
- echo "<option value='".$row['id']."'>".$row['category_title']."</option>";
- }
- ?>
- </select><?php } ?></td>
- </tr>
- <tr>
- <td> </td>
- <td><input name="external_link_submit" type="submit" id="external_link_submit" value="<?php echo get_lang('AddIt'); ?>"></td>
- </tr>
- <tr>
- <td> </td>
- <td> </td>
- </tr>
- <tr>
- <td colspan="2"> </td>
- </tr>
- </table>
- </form>
- <?php
- }
- /* Assignments */
- if ($content == 'Assignment') {
- echo "<a href=".api_get_self()."?content=Ass&add=Ass&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no>".get_lang('AddAssignmentPage')."</a>";
- }
- /* Dropbox */
- if ($content == 'Dropbox') {
- echo "<a href='".api_get_self()."?content=Drop&add=Drop&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no'>".get_lang('DropboxAdd')."</a>";
- }
- /* Introduction text */
- if ($content == 'Introduction_text') {
- echo "<a href='".api_get_self()."?content=Intro&add=Intro&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no'>".get_lang('IntroductionTextAdd')."</a>";
- }
- /* Course description */
- if ($content == 'Course_description') {
- echo "<a href='".api_get_self()."?content=Course_desc&add=Course_desc&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no'>".get_lang('CourseDescriptionAdd')."</a>";
- }
- /* Groups */
- if ($content == 'Groups') {
- echo "<a href='".api_get_self()."?content=Group&add=Group&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no'>".get_lang('GroupsAdd')."</a>";
- }
- /* Users */
- if ($content == 'Users') {
- echo "<a href='".api_get_self()."?content=User&add=User&action=$action&lp_id=$learnpath_id&parent_item_id=$chapter_id&originalresource=no'>".get_lang('UsersAdd')."</a>";
- }
- if ($showresources) {
- //echo "<h4>".get_lang('ResourceAdded')."</h4>";
- display_resources(1);
- }
- echo "</td></tr></table>";
- /* FOOTER */
- Display :: display_footer();
|