123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Main script for the links tool.
- *
- * Features:
- * - Organize links into categories;
- * - favorites/bookmarks-like interface;
- * - move links up/down within a category;
- * - move categories up/down;
- * - expand/collapse all categories (except the main "non"-category);
- * - add link to 'root' category => category-less link is always visible.
- *
- * @author Patrick Cool, main author, completely rewritten
- * @author René Haentjens, added CSV file import (October 2004)
- * @package chamilo.link
- * @todo improve organisation, tables should come from database library, use formvalidator
- * @todo Needs serious rewriting here. This doesn't make sense
- */
- /* INIT SECTION */
- // Language files that need to be included
- $language_file = array('link', 'admin');
- // Including libraries
- require_once '../inc/global.inc.php';
- $current_course_tool = TOOL_LINK;
- require_once api_get_path(LIBRARY_PATH).'link.lib.php';
- $this_section = SECTION_COURSES;
- api_protect_course_script();
- $htmlHeadXtra[] = '<script type="text/javascript">
- $(document).ready( function() {
- for (i=0;i<$(".actions").length;i++) {
- if ($(".actions:eq("+i+")").html()=="<table border=\"0\"></table>" || $(".actions:eq("+i+")").html()=="" || $(".actions:eq("+i+")").html()==null) {
- $(".actions:eq("+i+")").hide();
- }
- }
- });
- function check_url(id, url) {
- var url = "'.api_get_path(WEB_AJAX_PATH).'link.ajax.php?a=check_url&url=" +url;
- var loading = " '.addslashes(Display::return_icon('loading1.gif')).'";
- $("#url_id_"+id).html(loading);
- $("#url_id_"+id).load(url);
- }
- </script>';
- // @todo change the $_REQUEST into $_POST or $_GET
- // @todo remove this code
- $link_submitted = isset($_POST['submitLink']);
- $category_submitted = isset($_POST['submitCategory']);
- $urlview = !empty($_GET['urlview']) ? $_GET['urlview'] : '';
- $submit_import = !empty($_POST['submitImport']) ? $_POST['submitImport'] : '';
- $down = !empty($_GET['down']) ? $_GET['down'] : '';
- $up = !empty($_GET['up']) ? $_GET['up'] : '';
- $catmove = !empty($_GET['catmove']) ? $_GET['catmove'] : '';
- $editlink = !empty($_REQUEST['editlink']) ? $_REQUEST['editlink'] : '';
- $id = !empty($_REQUEST['id']) ? $_REQUEST['id'] : '';
- $urllink = !empty($_REQUEST['urllink']) ? $_REQUEST['urllink'] : '';
- $title = !empty($_REQUEST['title']) ? $_REQUEST['title'] : '';
- $description = !empty($_REQUEST['description']) ? $_REQUEST['description'] : '';
- $selectcategory = !empty($_REQUEST['selectcategory']) ? $_REQUEST['selectcategory'] : '';
- $submit_link = isset($_REQUEST['submitLink']);
- $action = !empty($_REQUEST['action']) ? $_REQUEST['action'] : '';
- $category_title = !empty($_REQUEST['category_title']) ? $_REQUEST['category_title'] : '';
- $submit_category = isset($_POST['submitCategory']);
- $target_link = !empty($_REQUEST['target_link']) ? $_REQUEST['target_link'] : '_self';
- $nameTools = get_lang('Links');
- // Condition for the session
- $session_id = api_get_session_id();
- $condition_session = api_get_session_condition($session_id, true, true);
- if (isset($_GET['action']) && $_GET['action'] == 'addlink') {
- $nameTools = '';
- $interbreadcrumb[] = array('url' => 'link.php', 'name' => get_lang('Links'));
- $interbreadcrumb[] = array('url' => '#', 'name' => get_lang('AddLink'));
- }
- if (isset($_GET['action']) && $_GET['action'] == 'addcategory') {
- $nameTools = '';
- $interbreadcrumb[] = array('url' => 'link.php', 'name' => get_lang('Links'));
- $interbreadcrumb[] = array('url' => '#', 'name' => get_lang('AddCategory'));
- }
- if (isset($_GET['action']) && $_GET['action'] == 'editlink') {
- $nameTools = '';
- $interbreadcrumb[] = array('url' => 'link.php', 'name' => get_lang('Links'));
- $interbreadcrumb[] = array('url' => '#', 'name' => get_lang('EditLink'));
- }
- // Database Table definitions
- $tbl_link = Database::get_course_table(TABLE_LINK);
- $tbl_categories = Database::get_course_table(TABLE_LINK_CATEGORY);
- $course_id = api_get_course_int_id();
- // Statistics
- event_access_tool(TOOL_LINK);
- Display::display_header($nameTools, 'Links');
- ?>
- <script type="text/javascript">
- /* <![CDATA[ */
- function MM_popupMsg(msg) { //v1.0
- confirm(msg);
- }
- /* ]]> */
- </script>
- <?php
- /* Action Handling */
- $nameTools = get_lang('Links');
- if (isset($_GET['action'])) {
- $check_token = Security::check_token('request');
- if ($check_token) {
- switch ($_GET['action']) {
- case 'addlink':
- if ($link_submitted) {
- if (!addlinkcategory("link")) { // Here we add a link
- unset($submit_link);
- }
- }
- break;
- case 'addcategory':
- if ($category_submitted) {
- if (!addlinkcategory('category')) { // Here we add a category
- unset($submit_category);
- }
- }
- break;
- case 'importcsv':
- if ($_POST['submitImport']) {
- import_csvfile();
- }
- break;
- case 'deletelink':
- deletelinkcategory('link'); // Here we delete a link
- break;
- case 'deletecategory':
- deletelinkcategory('category'); // Here we delete a category
- break;
- case 'editlink':
- editlinkcategory('link'); // Here we edit a link
- break;
- case 'editcategory':
- editlinkcategory('category'); // Here we edit a category
- break;
- case 'visible':
- change_visibility($_GET['id'], $_GET['scope']); // Here we edit a category
- break;
- case 'invisible':
- change_visibility($_GET['id'], $_GET['scope']); // Here we edit a category
- break;
- }
- Security::clear_token();
- }
- }
- $token = Security::get_token();
- /* Introduction section */
- Display::display_introduction_section(TOOL_LINK);
- if (api_is_allowed_to_edit(null, true) && isset($_GET['action'])) {
- echo '<div class="actions">';
- if (!empty($_GET['lp_id']) || !empty($_POST['lp_id'])){
- if (!empty($_POST['lp_id'])){
- $lp_id = Security::remove_XSS($_POST['lp_id']);
- } else {
- $lp_id = Security::remove_XSS($_GET['lp_id']);
- }
- echo "<a href=\"../newscorm/lp_controller.php?".api_get_cidreq()."&gradebook=&action=add_item&type=step&lp_id=".$lp_id."#resource_tab-3\">".Display::return_icon('back.png', get_lang("BackTo").' '.get_lang("LearningPaths"),'',ICON_SIZE_MEDIUM)."</a>";
- } else {
- //echo '<a href="link.php?cidReq='.Security::remove_XSS($_GET['cidReq']).'&urlview='.Security::remove_XSS($_GET['urlview']).'">'.Display::return_icon('back.png', get_lang('BackToLinksOverview'),'',ICON_SIZE_MEDIUM).'</a>';
- }
- echo '</div>';
- // Displaying the correct title and the form for adding a category or link. This is only shown when nothing
- // has been submitted yet, hence !isset($submit_link)
- if (($_GET['action'] == 'addlink' || $_GET['action'] == 'editlink') && empty($_POST['submitLink'])) {
- if ($category == '') {
- $category = 0;
- }
- echo '<form class="form-horizontal" method="post" action="'.api_get_self().'?action='.Security::remove_XSS($_GET['action']).'&urlview='.Security::remove_XSS($urlview).'">';
- if ($_GET['action'] == 'addlink') {
- echo '<legend>'.get_lang('LinkAdd').'</legend>';
- } else {
- echo '<legend>'.get_lang('LinkMod').'</legend>';
- }
- echo '<input type="hidden" name="sec_token" value="'.$token.'" />';
- if ($_GET['action'] == 'editlink') {
- $clean_link_id = intval($_GET['id']);
- $link_info = get_link_info($_GET['id']);
- if ($link_info) {
- $urllink = $link_info['url'];
- $title = $link_info['title'];
- $description = $link_info['description'];
- $category = $link_info['category_id'];
- $onhomepage = '';
- if ($link_info['on_homepage'] != 0) {
- $onhomepage = 'checked';
- }
- $target_link = $link_info['target'];
- }
- echo '<input type="hidden" name="id" value="'.$clean_link_id.'" />';
- } else {
- $target_link = "_blank";
- }
- echo ' <div class="control-group url">
- <label class="control-label">
- <span class="form_required">*</span> URL
- </label>
- <div class="controls">
- <input type="text" name="urllink" class="span6" value="' . (empty($urllink) ? 'http://' : Security::remove_XSS($urllink)) . '" />
- </div>
- </div>';
- echo ' <div class="control-group title">
- <label class="control-label">
- '.get_lang('LinkName').'
- </label>
- <div class="controls">
- <input type="text" name="title" class="span6" value="' . Security::remove_XSS($title) . '" />
- </div>
- </div>';
- echo ' <div class="control-group metadata">
- <label class="control-label">
- '.get_lang('Metadata').'
- </label>
- <div class="controls">
- <a href="../metadata/index.php?eid='.urlencode('Link.'.$clean_link_id).'">'.get_lang('AddMetadata').'</a>
- </div>
- </div>';
- echo ' <div class="control-group description">
- <label class="control-label">
- '.get_lang('Description').'
- </label>
- <div class="controls">
- <textarea class="span3" cols="50" name="description">' . Security::remove_XSS($description) . '</textarea>
- </div>
- </div>';
- $sqlcategories = "SELECT * FROM ".$tbl_categories." WHERE c_id = $course_id $condition_session ORDER BY display_order DESC";
- $resultcategories = Database::query($sqlcategories);
- if (Database::num_rows($resultcategories)) {
- echo ' <div class="control-group category">
- <label class="control-label">
- '.get_lang('Category').'
- </label>
- <div class="controls">';
- echo ' <select name="selectcategory">';
- echo ' <option value="0">--</option>';
- while ($myrow = Database::fetch_array($resultcategories)) {
- echo ' <option value="'.$myrow['id'].'"';
- if ($myrow['id'] == $category) {
- echo ' selected';
- }
- echo '>'.$myrow['category_title'].'</option>';
- }
- echo ' </select>';
- echo ' </div>
- </div>';
- }
- echo ' <div class="control-group onhomepage">
- <label class="control-label">
- </label>
- <div class="controls">
- <input class="checkbox" type="checkbox" name="onhomepage" id="onhomepage" value="1"'.$onhomepage.'><label for="onhomepage"> '.get_lang('OnHomepage').'?</label>
- </div>
- </div>';
- echo ' <div class="control-group target" id="div_target">
- <label class="control-label">
- '.get_lang('LinkTarget').'
- </label>
- <div class="controls">
- <select name="target_link" id="target_link">';
- $targets = array('_self'=>get_lang('LinkOpenSelf'),'_blank'=>get_lang('LinkOpenBlank'),'_parent'=>get_lang('LinkOpenParent'),'_top'=>get_lang('LinkOpenTop'));
- foreach ($targets as $target_id => $target) {
- $selected = '';
- if ($target_id == $target_link) {
- $selected = ' selected="selected"';
- }
- echo ' <option value="'.$target_id.'"'.$selected.'>'.$target.'</option> ';
- }
- echo ' </select>
- <span class="help-block">
- '.get_lang('AddTargetOfLinkOnHomepage').'
- </span>
- </div>
- </div>';
- if (api_get_setting('search_enabled') == 'true') {
- require_once api_get_path(LIBRARY_PATH).'specific_fields_manager.lib.php';
- $specific_fields = get_specific_field_list();
- echo ' <div class="control-group index">
- <label class="control-label">
- '.get_lang('SearchFeatureDoIndexLink').'
- </label>
- <div class="controls">
- <label for="index_document">
- <input class="checkbox" type="checkbox" name="index_document" id="index_document" checked="checked">
- '.get_lang('Yes').'
- </label>
- </div>
- </div>';
- foreach ($specific_fields as $specific_field) {
- $default_values = '';
- if ($_GET['action'] == 'editlink') {
- $filter = array('field_id' => $specific_field['id'], 'ref_id' => intval($_GET['id']), 'tool_id' => '\''. TOOL_LINK .'\'');
- $values = get_specific_field_values_list($filter, array('value'));
- if (!empty($values)) {
- $arr_str_values = array();
- foreach ($values as $value) {
- $arr_str_values[] = $value['value'];
- }
- $default_values = implode(', ', $arr_str_values);
- }
- }
- $sf_textbox = '
- <div class="control-group">
- <label class="control-label">%s</label>
- <div class="controls">
- <input name="%s" type="text" value="%s"/>
- </div>
- </div>';
- echo sprintf($sf_textbox, $specific_field['name'], $specific_field['code'], $default_values);
- }
- }
- //echo '<input type="hidden" name="origin" value="' . Security::remove_XSS($_GET['origin']) . '" />';
- echo '<input type="hidden" name="lp_id" value="' . Security::remove_XSS($_GET['lp_id']) . '" />';
- echo '<div class="control-group">
- <label class="control-label">
- </label>
- <div class="controls">
- <button class="btn save" type="submit" name="submitLink" value="OK">'.get_lang('SaveLink').'</button>
- </div>
- </div>';
- echo '</form>';
- } elseif(($_GET['action'] == 'addcategory' || $_GET['action'] == 'editcategory') && !$submit_category) {
- echo '<form class="form-horizontal " method="post" action="'.api_get_self().'?action='.Security::remove_XSS($_GET['action']).'&urlview='.Security::remove_XSS($urlview).'">';
- if ($_GET['action'] == 'addcategory') {
- echo '<legend>'.get_lang('CategoryAdd').'</legend>';
- $my_cat_title = get_lang('CategoryAdd');
- } else {
- echo '<legend>'.get_lang('CategoryMod').'</legend>';
- $my_cat_title = get_lang('CategoryMod');
- }
- echo '<input type="hidden" name="sec_token" value="'.$token.'" />';
- if ($_GET['action'] == 'editcategory') {
- echo '<input type="hidden" name="id" value="'.$id.'" />';
- }
- echo ' <div class="control-group category">
- <label class="control-label">
- <span class="form_required">*</span> '.get_lang('CategoryName').'
- </label>
- <div class="controls">
- <input type="text" name="category_title" size="50" value="'.Security::remove_XSS($category_title).'" />
- </div>
- </div>';
- echo ' <div class="control-group description">
- <label class="control-label">
- '.get_lang('Description').'
- </label>
- <div class="controls">
- <textarea rows="3" cols="50" name="description">'.Security::remove_XSS($description).'</textarea>
- </div>
- </div>';
- echo ' <div class="control-group">
- <label class="control-label">
- </label>
- <div class="controls">
- <button class="btn save" type="submit" name="submitCategory">'.$my_cat_title.' </button>
- </div>
- </div>';
- echo "</form>";
- }
- }
- if (!empty($down)) {
- movecatlink($down);
- }
- if (!empty($up)) {
- movecatlink($up);
- }
- if (empty($_GET['action']) || ($_GET['action'] != 'editlink' && $_GET['action'] != 'addcategory' && $_GET['action'] != 'addlink') || $link_submitted || $category_submitted) {
- /* Action Links */
- echo '<div class="actions">';
- if (api_is_allowed_to_edit(null, true)) {
- $urlview = Security::remove_XSS($urlview);
- echo '<a href="'.api_get_self().'?'.api_get_cidreq().'&action=addlink&category='.(!empty($category) ? $category : '').'&urlview='.$urlview.'">'.Display::return_icon('new_link.png', get_lang('LinkAdd'),'',ICON_SIZE_MEDIUM).'</a>';
- echo '<a href="'.api_get_self().'?'.api_get_cidreq().'&action=addcategory&urlview='.$urlview.'">'.Display::return_icon('new_folder.png', get_lang('CategoryAdd'),'',ICON_SIZE_MEDIUM).'</a>';
- /* "<a href=\"".api_get_self()."?".api_get_cidreq()."&action=importcsv&urlview=".$urlview."\">".get_lang('CsvImport')."</a>\n", // RH*/
- }
- // Making the show none / show all links. Show none means urlview=0000 (number of zeros depending on the
- // number of categories). Show all means urlview=1111 (number of 1 depending on teh number of categories).
- $sqlcategories = "SELECT * FROM ".$tbl_categories." WHERE c_id = $course_id $condition_session ORDER BY display_order DESC";
- $resultcategories = Database::query($sqlcategories);
- $aantalcategories = Database::num_rows($resultcategories);
- if ($aantalcategories > 0) {
- $resultcategories = Database::query($sqlcategories);
- echo '<a href="'.api_get_self().'?'.api_get_cidreq().'&urlview=';
- for ($j = 1; $j <= $aantalcategories; $j++) {
- echo '0';
- }
- echo '">'.Display::return_icon('view_remove.png', $shownone,'',ICON_SIZE_MEDIUM).'</a>';
- echo '<a href="'.api_get_self().'?'.api_get_cidreq().'&urlview=';
- for ($j = 1; $j <= $aantalcategories; $j++) {
- echo '1';
- }
- echo '">'.Display::return_icon('view_tree.png', $showall,'',ICON_SIZE_MEDIUM).'</a>';
- }
- echo '</div>';
- // Displaying the links which have no category (thus category = 0 or NULL), if none present this will not be displayed
- $sqlLinks = "SELECT * FROM ".$tbl_link." WHERE c_id = $course_id AND category_id=0 OR category_id IS NULL";
- $result = Database::query($sqlLinks);
- $numberofzerocategory = Database::num_rows($result);
- if ($numberofzerocategory !== 0) {
- echo '<table class="data_table">';
- echo '<tr><th style="font-weight: bold; text-align:left;padding-left: 10px;">'.get_lang('General').'</th></tr>';
- echo '</table>';
- showlinksofcategory(0);
- }
- $i = 0;
- $catcounter = 1;
- $view = '0';
- while ($myrow = Database::fetch_array($resultcategories)) {
- // Validacion when belongs to a session
- $session_img = api_get_session_image($myrow['session_id'], $_user['status']);
- //if (!isset($urlview)) {
- if ($urlview == '') {
- // No $view set in the url, thus for each category link it should be all zeros except it's own
- makedefaultviewcode($i);
- } else {
- $view = $urlview;
- $view[$i] = '1';
- }
- // If the $urlview has a 1 for this categorie, this means it is expanded and should be desplayed as a
- // - instead of a +, the category is no longer clickable and all the links of this category are displayed
- $myrow['description'] = $myrow['description'];
- if (isset($urlview[$i]) && $urlview[$i] == '1') {
- $newurlview = $urlview;
- $newurlview[$i] = '0';
- echo '<tr>';
- echo '<table class="data_table">';
- echo '<tr>';
- echo '<th width="81%" style="font-weight: bold; text-align:left;padding-left: 5px;">';
- echo '<a href="'.api_get_self().'?'.api_get_cidreq().'&urlview='.Security::remove_XSS($newurlview).'">';
- echo Display::return_icon('view_remove.png').' '.Security::remove_XSS($myrow['category_title']).'</a><br /> '.$myrow['description'];
- echo '</th>';
- if (api_is_allowed_to_edit(null, true)) {
- if ($session_id == $myrow['session_id']) {
- echo '<th>';
- showcategoryadmintools($myrow['id']);
- echo '</th>';
- } else {
- echo '<th>'.get_lang('EditionNotAvailableFromSession');
- }
- }
- echo '</tr>';
- echo '</table>';
- echo showlinksofcategory($myrow['id']);
- echo '</tr>';
- } else {
- echo '<tr>';
- echo '<table class="data_table">';
- echo '<tr>';
- echo '<th width="81%" style="font-weight: bold; text-align:left;padding-left: 5px;"><a href="'.api_get_self().'?'.api_get_cidreq().'&urlview=';
- echo is_array($view) ? implode('', $view) : $view;
- echo '">'.Display::return_icon('view_tree.png').' '.Security::remove_XSS($myrow['category_title']).$session_img;
- echo'</a><br /> ';
- echo $myrow['description'];
- if (api_is_allowed_to_edit(null, true)) {
- echo '<th style="text-align:center;">';
- showcategoryadmintools($myrow['id']);
- echo '</th>';
- }
- echo '</th>';
- echo '</tr>';
- echo '</table>';
- echo '</tr>';
- }
- // Displaying the link of the category
- $i++;
- }
- echo '</table>';
- }
- Display::display_footer();
|