diff --git a/main/wiki/index.php b/main/wiki/index.php
index 5fee16fa0f..36cdbc1a19 100644
--- a/main/wiki/index.php
+++ b/main/wiki/index.php
@@ -905,89 +905,94 @@ if ($_GET['action']=='links')
}
else
{
-
- $sql='SELECT * FROM '.$tbl_wiki.' WHERE reflink="'.html_entity_decode(Database::escape_string(stripslashes(urldecode($page)))).'" AND '.$groupfilter.'';
- $result=api_sql_query($sql,__FILE__,__LINE__); //necessary for pages with compound name. TODO: check if necessay after have fixed wanted pages with _
-
- $row=Database::fetch_array($result);
- echo $LinksPagesFrom.': '.$row['title'].'';
-
- if ($page==get_lang('DefaultTitle'))
- {
- $page='index';
- }
- $sql="SELECT * FROM ".$tbl_wiki." WHERE ".$groupfilter." AND linksto LIKE '%".html_entity_decode(Database::escape_string(stripslashes(urldecode($page))))." %' GROUP BY reflink ORDER BY title ASC"; //add blank space after like '%" " %' to identify each word
+ $sql='SELECT * FROM '.$tbl_wiki.' WHERE reflink="'.html_entity_decode(Database::escape_string(stripslashes(urldecode($page)))).'" AND '.$groupfilter.'';
+ $result=api_sql_query($sql,__FILE__,__LINE__);
+ $row=Database::fetch_array($result);
+ //get type assignment icon
+
+ if($row['assignment']==1)
+ {
+ $ShowAssignment='
';
+ }
+ elseif ($row['assignment']==2)
+ {
+ $ShowAssignment='
';
+ }
+ elseif ($row['assignment']==0)
+ {
+ $ShowAssignment='
';
+ }
- $result=api_sql_query($sql,__LINE__,__FILE__);
-
- //show result
+ //fix index to reflink Main page (see linksto)
+ if ($page=='index')
+ {
+ $page=str_replace(' ','_',get_lang('DefaultTitle'));
+ }
+
+ echo $LinksPagesFrom.': '.$ShowAssignment.''.$row['title'].'';
- echo '
';
-
- while ($row=Database::fetch_array($result))
- {
- $userinfo=Database::get_user_info_from_id($row['user_id']);
+ //table
- //Show page to students if not is hidden, but the author can see. Show page to all teachers if is hidden. Mode assignments: show pages to student only if student is the author
- if($row['visibility']==1 || api_is_allowed_to_edit() || api_is_platform_admin() || ($row['assignment']==2 && $row['visibility']==0 && (api_get_user_id()==$row['user_id'])))
- {
- $year = substr($row['timestamp'], 0, 4);
- $month = substr($row['timestamp'], 5, 2);
- $day = substr($row['timestamp'], 8, 2);
- $hours=substr($row['timestamp'], 11,2);
- $minutes=substr($row['timestamp'], 14,2);
- $seconds=substr($row['timestamp'], 17,2);
+ if(api_is_allowed_to_edit() || api_is_platform_admin()) //only by professors if page is hidden
+ {
+ $sql="SELECT * FROM ".$tbl_wiki." s1 WHERE ".$groupfilter." AND linksto LIKE '%".html_entity_decode(Database::escape_string(stripslashes(urldecode($page))))." %' AND id=(SELECT MAX(s2.id) FROM ".$tbl_wiki." s2 WHERE s1.reflink = s2.reflink)"; //add blank space after like '%" " %' to identify each word.
+ }
+ else
+ {
+ $sql="SELECT * FROM ".$tbl_wiki." s1 WHERE ".$groupfilter." AND visibility=1 AND linksto LIKE '%".html_entity_decode(Database::escape_string(stripslashes(urldecode($page))))." %' AND id=(SELECT MAX(s2.id) FROM ".$tbl_wiki." s2 WHERE s1.reflink = s2.reflink)"; //add blank space after like '%" " %' to identify each word
+ }
+
+ $allpages=api_sql_query($sql,__LINE__,__FILE__);
+
+ //show table
+ if (mysql_num_rows($allpages) > 0)
+ {
+ $row = array ();
+ while ($obj = mysql_fetch_object($allpages))
+ {
+ //get author
+ $userinfo=Database::get_user_info_from_id($obj->user_id);
- //Description assignments visible for all teachers
- if($row['assignment']==1)
- {
- if(api_is_allowed_to_edit() || api_is_platform_admin())
- {
- $ShowAssignment='
';
- echo '- ';
- echo ''.$ShowAssignment.$row['title'].'';
- echo '...'.$userinfo['lastname'].', '.$userinfo['firstname'];
- echo '...'.$day.' '.$MonthsLong[$month-1].' '.$year.' '.$hours.":".$minutes.":".$seconds.'
';
- }
- }
+ //get time
+ $year = substr($obj->timestamp, 0, 4);
+ $month = substr($obj->timestamp, 5, 2);
+ $day = substr($obj->timestamp, 8, 2);
+ $hours = substr($obj->timestamp, 11,2);
+ $minutes = substr($obj->timestamp, 14,2);
+ $seconds = substr($obj->timestamp, 17,2);
- //Work on the assignments visible for each student
- if ($row['assignment']==2)
- {
- if ($row['user_id']==(int)api_get_user_id() || api_is_allowed_to_edit() || api_is_platform_admin())
- {
- $ShowAssignment='
';
- echo '- ';
- echo ''.$ShowAssignment.$row['title'].'';
- echo '...'.$userinfo['lastname'].', '.$userinfo['firstname'];
- echo '...'.$day.' '.$MonthsLong[$month-1].' '.$year.' '.$hours.":".$minutes.":".$seconds.'
';
- }
+ //get type assignment icon
+ if($obj->assignment==1)
+ {
+ $ShowAssignment='
';
}
-
- //show wiki pages standard
- if ($row['assignment']==0)
+ elseif ($obj->assignment==2)
{
- $ShowAssignment='
';
- echo '- ';
- echo ''.$ShowAssignment.$row['title'].'';
-
- if ($row['user_id']<>0)
- {
- echo '...'.$userinfo['lastname'].', '.$userinfo['firstname'];
- }
- else
- {
- echo get_lang('Anonymous').' ('.$row[user_ip].')';
- }
-
- echo '...'.$day.' '.$MonthsLong[$month-1].' '.$year.' '.$hours.":".$minutes.":".$seconds.'
';
- }
- }
- }
-
- echo '
';
+ $ShowAssignment='
';
+ }
+ elseif ($obj->assignment==0)
+ {
+ $ShowAssignment='
';
+ }
+
+ $row = array ();
+ $row[] =$ShowAssignment;
+ $row[] = ''.$obj->title.'';
+ $row[] = $obj->user_id <>0 ? ''.$userinfo['lastname'].', '.$userinfo['firstname'].'' : get_lang('Anonymous').' ('.$obj->user_ip.')';
+ $row[] = $day.' '.$MonthsLong[$month-1].' '.$year.' '.$hours.":".$minutes.":".$seconds;
+ $rows[] = $row;
+ }
+
+ $table = new SortableTableFromArrayConfig($rows,1,10,'AllPages_table','','','ASC');
+ $table->set_additional_parameters(array('cidReq' =>$_GET['cidReq'],'action'=>$_GET['action'],'group_id'=>Security::remove_XSS($_GET['group_id'])));
+ $table->set_header(0,get_lang('Type'), true, array ('style' => 'width:30px;'));
+ $table->set_header(1,get_lang('Title'), true);
+ $table->set_header(2,get_lang('Author'), true);
+ $table->set_header(3,get_lang('Date'), true);
+ $table->display();
+ }
}
}
@@ -1403,7 +1408,6 @@ if ($_GET['action']=='recentchanges')
echo '
';
echo ''.get_lang('RecentChanges').' '.$notify_all.'
';
echo '
';
- echo '';
if(api_is_allowed_to_edit() || api_is_platform_admin()) //only by professors if page is hidden
{
@@ -1481,7 +1485,6 @@ if ($_GET['action']=='allpages')
$_clean['group_id']=(int)$_SESSION['_gid'];
-
if(api_is_allowed_to_edit() || api_is_platform_admin()) //only by professors if page is hidden
{
$sql='SELECT * FROM '.$tbl_wiki.' s1 WHERE '.$groupfilter.' AND id=(SELECT MAX(s2.id) FROM '.$tbl_wiki.' s2 WHERE s1.reflink = s2.reflink)'; // warning don't use group by reflink because don't return the last version