MDL-8096 - user edit form splitting, refactoring, cleanup and fixing - work in progre...
[moodle.git] / user / tabs.php
1 <?php  // $Id$
2 /// This file to be included so we can assume config.php has already been included.
3 /// We also assume that $user, $course, $currenttab have been set
5     if (!isset($filtertype)) {
6         $filtertype = '';
7     }
8     if (!isset($filterselect)) {
9         $filterselect = '';
10     }
12     //make sure everything is cleaned properly
13     $filtertype   = clean_param($filtertype, PARAM_ALPHA);
14     $filterselect = clean_param($filterselect, PARAM_INT);
16     if (empty($currenttab) or empty($user) or empty($course)) {
17         //error('You cannot call this script in that way');
18     }
20     if (($filtertype == 'site' && $filterselect) || ($filtertype=='user' && $filterselect)) {
21         $user = get_record('user','id',$filterselect);
22     }
24     $inactive = NULL;
25     $activetwo = NULL;
26     $toprow = array();
28     /**************************************
29      * Site Level participation or Blogs  *
30      **************************************/
31     if ($filtertype == 'site') {
33         $site = get_site();
34         print_heading($site->fullname);
35         
36         if ($CFG->bloglevel >= 4) {
37             if (has_capability('moodle/course:viewparticipants', get_context_instance(CONTEXT_SYSTEM, SITEID))) {
38                 $toprow[] = new tabobject('participants', $CFG->wwwroot.'/user/index.php?id='.SITEID,
39                     get_string('participants'));
40             }
42             $toprow[] = new tabobject('blogs', $CFG->wwwroot.'/blog/index.php?filtertype=site&amp;',
43                 get_string('blogs','blog'));
44         }
46     /**************************************
47      * Course Level participation or Blogs  *
48      **************************************/
49     } else if ($filtertype == 'course' && $filterselect) {
51         $course = get_record('course','id',$filterselect);
52         print_heading($course->fullname);
54         if ($CFG->bloglevel >= 3) {
56             $toprow[] = new tabobject('participants', $CFG->wwwroot.'/user/index.php?id='.$filterselect.'&amp;group=0',
57                 get_string('participants'));    //the groupid hack is necessary, otherwise the group in the session willbe used
58         
59             $toprow[] = new tabobject('blogs', $CFG->wwwroot.'/blog/index.php?filtertype=course&amp;filterselect='.$filterselect, get_string('blogs','blog'));
60         }
62     /**************************************
63      * Group Level participation or Blogs  *
64      **************************************/
65     } else if ($filtertype == 'group' && $filterselect) {
67         $group_name = groups_get_group_name($filterselect); //TODO:
68         print_heading($group_name);
70         if ($CFG->bloglevel >= 2) {
72             $toprow[] = new tabobject('participants', $CFG->wwwroot.'/user/index.php?id='.$course->id.'&amp;group='.$filterselect,
73                 get_string('participants'));
75         
76             $toprow[] = new tabobject('blogs', $CFG->wwwroot.'/blog/index.php?filtertype=group&amp;filterselect='.$filterselect, get_string('blogs','blog'));
77         }
79     /**************************************
80      * User Level participation or Blogs  *
81      **************************************/
82     } else {
83         if (isset($userid)) {
84             $user = get_record('user','id', $userid);
85         }
86         print_heading(fullname($user, has_capability('moodle/site:viewfullnames', get_context_instance(CONTEXT_COURSE, $course->id))));
88         $toprow[] = new tabobject('profile', $CFG->wwwroot.'/user/view.php?id='.$user->id.'&amp;course='.$course->id, get_string('profile'));
90         $sitecontext     = get_context_instance(CONTEXT_SYSTEM, SITEID);
91         $coursecontext   = get_context_instance(CONTEXT_COURSE, $course->id);
92         $personalcontext = get_context_instance(CONTEXT_USER, $user->id);
94     /// Can only edit profile if it belongs to user or current user is admin and not editing primary admin
96         $mainadmin = get_admin();
98         if (is_mnet_remote_user($user)) {
99             // cannot edit remote users
100         }
101         else if ((!empty($USER->id) and ($USER->id == $user->id) and !isguest()) or
102             (has_capability('moodle/user:update', $sitecontext) and ($user->id != $mainadmin->id)) ) {
104             if(empty($CFG->loginhttps)) {
105                 $wwwroot = $CFG->wwwroot;
106             } else {
107                 $wwwroot = str_replace('http:','https:',$CFG->wwwroot);
108             }
109             if (has_capability('moodle/user:update', $sitecontext) and ($user->id==$USER->id or $user->id != $mainadmin->id)) {
110                 $toprow[] = new tabobject('editprofile', $wwwroot.'/user/editadvanced.php?id='.$user->id.'&amp;course='.$course->id, get_string('editmyprofile'));
111             } else {
112                 $toprow[] = new tabobject('editprofile', $wwwroot.'/user/edit.php?id='.$user->id.'&amp;course='.$course->id, get_string('editmyprofile'));
113             }
114         }
116     /// Everyone can see posts for this user
117     
118     /// add logic to see course read posts permission
119         if (has_capability('moodle/user:readuserposts', $personalcontext) || has_capability('mod/forum:viewdiscussion', get_context_instance(CONTEXT_COURSE, $course->id))) {
120             $toprow[] = new tabobject('forumposts', $CFG->wwwroot.'/mod/forum/user.php?id='.$user->id.'&amp;course='.$course->id,
121                         get_string('forumposts', 'forum'));
123             if (in_array($currenttab, array('posts', 'discussions'))) {
124                 $inactive = array('forumposts');
125                 $activetwo = array('forumposts');
127                 $secondrow = array();
128                 $secondrow[] = new tabobject('posts', $CFG->wwwroot.'/mod/forum/user.php?course='.$course->id.
129                                       '&amp;id='.$user->id.'&amp;mode=posts', get_string('posts', 'forum'));
130                 $secondrow[] = new tabobject('discussions', $CFG->wwwroot.'/mod/forum/user.php?course='.$course->id.
131                                       '&amp;id='.$user->id.'&amp;mode=discussions', get_string('discussions', 'forum'));
132             }
134         }
136     /// Personal blog entries tab
137         require_once($CFG->dirroot.'/blog/lib.php');
138         if ($CFG->bloglevel >= BLOG_USER_LEVEL and // blogs must be enabled
139             (has_capability('moodle/user:readuserblogs', $personalcontext) // can review posts (parents etc)
140             or has_capability('moodle/blog:manageentries', $sitecontext)     // entry manager can see all posts
141             or ($user->id == $USER->id and has_capability('moodle/blog:create', $sitecontext)) // viewing self
142             or (has_capability('moodle/blog:view', $sitecontext) or has_capability('moodle/blog:view', $coursecontext))
143             ) // able to read blogs in site or course context
144         ) { //end if
146             $toprow[] = new tabobject('blogs', $CFG->wwwroot.'/blog/index.php?userid='.$user->id.'&amp;courseid='.$course->id, get_string('blog', 'blog'));
147         }
149     /// Current user must be teacher of the course or the course allows user to view their reports
150     
151     //print_object($course);
152     //print_object($user);
153     
154         // add in logic to check course read report
155         if (has_capability('moodle/user:viewuseractivitiesreport', $personalcontext) || ($course->showreports and $USER->id == $user->id)) {
157             $toprow[] = new tabobject('reports', $CFG->wwwroot.'/course/user.php?id='.$course->id.
158                                       '&amp;user='.$user->id.'&amp;mode=outline', get_string('activityreports'));
160             if (in_array($currenttab, array('outline', 'complete', 'todaylogs', 'alllogs', 'stats', 'grade'))) {
161                 $inactive = array('reports');
162                 $activetwo = array('reports');
164                 $secondrow = array();
165                 $secondrow[] = new tabobject('outline', $CFG->wwwroot.'/course/user.php?id='.$course->id.
166                                           '&amp;user='.$user->id.'&amp;mode=outline', get_string('outlinereport'));
167                 $secondrow[] = new tabobject('complete', $CFG->wwwroot.'/course/user.php?id='.$course->id.
168                                           '&amp;user='.$user->id.'&amp;mode=complete', get_string('completereport'));
169                 $secondrow[] = new tabobject('todaylogs', $CFG->wwwroot.'/course/user.php?id='.$course->id.
170                                           '&amp;user='.$user->id.'&amp;mode=todaylogs', get_string('todaylogs'));
171                 $secondrow[] = new tabobject('alllogs', $CFG->wwwroot.'/course/user.php?id='.$course->id.
172                                           '&amp;user='.$user->id.'&amp;mode=alllogs', get_string('alllogs'));
173                 if (!empty($CFG->enablestats)) {
174                     $secondrow[] = new tabobject('stats',$CFG->wwwroot.'/course/user.php?id='.$course->id.
175                                                  '&amp;user='.$user->id.'&amp;mode=stats',get_string('stats'));
176                 }
177                 
178                 if ($course->showgrades) {
179                     $secondrow[] = new tabobject('grade', $CFG->wwwroot.'/course/user.php?id='.$course->id.
180                                           '&amp;user='.$user->id.'&amp;mode=grade', get_string('grade'));
181                 }
182                                 
183             }
185         }
187     }    //close last bracket (individual tags)
190     /// this needs permission checkings
192     
193     if (!empty($showroles) and !empty($user)) { // this variable controls whether this roles is showed, or not, so only user/view page should set this flag
194         $usercontext = get_context_instance(CONTEXT_USER, $user->id);
195         if (has_capability('moodle/role:assign',$usercontext)) {
196             $toprow[] = new tabobject('roles', $CFG->wwwroot.'/'.$CFG->admin.'/roles/assign.php?contextid='.$usercontext->id.'&amp;userid='.$user->id.'&amp;courseid='.$course->id
197                                   ,get_string('roles'));
198                                   
199             if (in_array($currenttab, array('assign', 'override'))) {
200                 $inactive = array('roles');
201                 $activetwo = array('roles');
202     
203                 $secondrow = array();
204                 $secondrow[] = new tabobject('assign', $CFG->wwwroot.'/'.$CFG->admin.'/roles/assign.php?contextid='.$usercontext->id.'&amp;userid='.$user->id.'&amp;courseid='.$course->id
205                                   ,get_string('assignroles', 'role'));
206                 $secondrow[] = new tabobject('override', $CFG->wwwroot.'/'.$CFG->admin.'/roles/override.php?contextid='.$usercontext->id.'&amp;userid='.$user->id.'&amp;courseid='.$course->id
207                                   ,get_string('overrideroles', 'role'));
208                                     
209             }
210         }                                                                                                       
211     }
212 /// Add second row to display if there is one
214     if (!empty($secondrow)) {
215         $tabs = array($toprow, $secondrow);
216     } else {
217         $tabs = array($toprow);
218     }
220 /// Print out the tabs and continue!
222     print_tabs($tabs, $currenttab, $inactive, $activetwo);
224 ?>