Annotation of loncom/interface/lonaboutme.pm, revision 1.125

1.1       www         1: # The LearningOnline Network
1.97      weissno     2: # Personal Information Page
1.1       www         3: #
1.125   ! bisitz      4: # $Id: lonaboutme.pm,v 1.124 2009/04/14 15:32:12 neumanie Exp $
1.1       www         5: #
                      6: # Copyright Michigan State University Board of Trustees
                      7: #
                      8: # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
                      9: #
                     10: # LON-CAPA is free software; you can redistribute it and/or modify
                     11: # it under the terms of the GNU General Public License as published by
                     12: # the Free Software Foundation; either version 2 of the License, or
                     13: # (at your option) any later version.
                     14: #
                     15: # LON-CAPA is distributed in the hope that it will be useful,
                     16: # but WITHOUT ANY WARRANTY; without even the implied warranty of
                     17: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
                     18: # GNU General Public License for more details.
                     19: #
                     20: # You should have received a copy of the GNU General Public License
                     21: # along with LON-CAPA; if not, write to the Free Software
                     22: # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
                     23: #
                     24: # /home/httpd/html/adm/gpl.txt
                     25: #
                     26: # http://www.lon-capa.org/
                     27: #
                     28: 
1.74      jms        29: =pod
                     30: 
                     31: =head1 NAME
                     32: 
                     33: pache::lonaboutme
                     34: 
                     35: =head1 SYNOPSIS
                     36: 
                     37: (empty)
                     38: 
                     39: This is part of the LearningOnline Network with CAPA project
                     40: described at http://www.lon-capa.org.
                     41: 
                     42: =head1 OVERVIEW
                     43: 
                     44: (empty)
                     45: 
                     46: 
                     47: =head1 SUBROUTINES
                     48: 
                     49: =over
                     50: 
                     51: =item handler()
                     52: 
                     53: =item in_course()
                     54: 
                     55: =item aboutme_info()
                     56: 
                     57: =item print_portfiles_link()
                     58: 
                     59: =item build_query_string()
                     60: 
                     61: =item display_portfolio_header()
                     62: 
                     63: =item display_portfolio_files()
                     64: 
                     65: =item portfolio_files()
                     66: 
                     67: =item build_hierarchy()
                     68: 
                     69: =item parse_directory()
                     70: 
                     71: =back
                     72: 
                     73: =cut
                     74: 
                     75: 
1.1       www        76: package Apache::lonaboutme;
                     77: 
                     78: use strict;
                     79: use Apache::Constants qw(:common);
                     80: use Apache::loncommon;
                     81: use Apache::lonnet;
1.2       www        82: use Apache::lontexconvert;
1.12      www        83: use Apache::lonfeedback;
1.39      www        84: use Apache::lonrss();
1.17      www        85: use Apache::lonlocal;
1.41      albertel   86: use Apache::lonmsgdisplay();
1.72      amueller   87: use Apache::lontemplate;
1.52      albertel   88: use HTML::Entities();
1.91      neumanie   89: use Image::Magick;
1.1       www        90: 
                     91: sub handler {
                     92:     my $r = shift;
1.17      www        93:     &Apache::loncommon::content_type($r,'text/html');
1.1       www        94:     $r->send_http_header;
                     95:     return OK if $r->header_only;
1.37      albertel   96:     my $target=$env{'form.grade_target'};
1.1       www        97: # ------------------------------------------------------------ Print the screen
1.40      albertel   98:     if ($target eq 'tex') {
1.37      albertel   99: 	$r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));
1.22      sakharuk  100:     }
1.47      albertel  101:     my (undef,undef,$cdom,$cnum,undef,$action)=split(/\//,$r->uri);
1.55      raeburn   102:     my $is_course;
1.2       www       103: # Is this even a user?
                    104:     if (&Apache::lonnet::homeserver($cnum,$cdom) eq 'no_host') {
1.40      albertel  105: 	&Apache::loncommon::simple_error_page($r,'No info',
                    106: 					      'No user information available');
1.2       www       107:         return OK;
1.55      raeburn   108:     } else {
1.59      raeburn   109:         $is_course = &Apache::lonnet::is_course($cdom,$cnum);
1.2       www       110:     }
1.55      raeburn   111: 
1.77      raeburn   112:     my $candisplay = 1;
                    113:     if (!$is_course) {
1.80      raeburn   114:         if ($action ne 'portfolio') {
                    115:             $candisplay = &Apache::lonnet::usertools_access($cnum,$cdom,'aboutme');
                    116:             if ((!$candisplay) && ($env{'request.course.id'})) {
                    117:                 $candisplay = &aboutme_access($cnum,$cdom);
                    118:             }
                    119:             if (!$candisplay) {
                    120:                 if ($target eq 'tex') {
1.110     weissno   121:                     $r->print('\noindent{\large\textbf{'.&mt('No user personal information page available').'}}\\\\\\\\');
1.80      raeburn   122:                 } else {
1.97      weissno   123:                     $r->print(&Apache::loncommon::start_page("Personal Information Page"));
1.110     weissno   124:                     $r->print('<h2>'.&mt('No user personal information page available') .'</h2>'.
1.80      raeburn   125:                               &mt('This is a result of one of the following:').'<ul>'.
1.110     weissno   126:                               '<li>'.&mt('The administrator of this domain has disabled personal information page functionality for this specific user.').'</li>'.
                    127:                               '<li>'.&mt('The domain has been configured to disable, by default, personal information page functionality for all users in the domain.').'</li>'.
1.80      raeburn   128:                               '</ul>');
                    129:                     $r->print(&Apache::loncommon::end_page());
                    130:                 }
                    131:                 return OK;
1.77      raeburn   132:             }
                    133:         }
                    134:     }
                    135: 
1.2       www       136: # --------------------------------------------------------- The syllabus fields
1.17      www       137:     my %syllabusfields=&Apache::lonlocal::texthash(
1.3       www       138:        'aaa_contactinfo'   => 'Contact Information',
1.103     weissno   139:        'bbb_aboutme'       => 'Personal Information',
1.3       www       140:        'ccc_webreferences' => 'Web References');
1.2       www       141: 
1.13      www       142: # ------------------------------------------------------------ Get Query String
1.47      albertel  143:     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
                    144: 					    ['forceedit','forcestudent',
1.69      raeburn   145: 					     'register','popup']);
1.43      raeburn   146: 
1.125   ! bisitz    147: # ----------------------------------------------- Available Portfolio file display
1.47      albertel  148:     if (($target ne 'tex') && ($action eq 'portfolio')) {
1.55      raeburn   149:         &display_portfolio_header($r,$is_course);
1.80      raeburn   150:         if ((!$is_course) && (!&Apache::lonnet::usertools_access($cnum,$cdom,'portfolio'))) {
                    151:             $r->print('<h2>'.&mt('No user portfolio available') .'</h2>'.
                    152:                       &mt('This is a result of one of the following:').'<ul>'.
                    153:                       '<li>'.&mt('The administrator of this domain has disabled portfolio functionality for this specific user.').'</li>'.
                    154:                       '<li>'.&mt('The domain has been configured to disable, by default, portfolio functionality for all users in the domain.').'</li>'.
                    155:                       '</ul>');
1.60      raeburn   156:         } else {
1.125   ! bisitz    157:             my ($blocked,$blocktext) =
1.80      raeburn   158:                 &Apache::loncommon::blocking_status('port',$cnum,$cdom);
                    159:             if (!$blocked) {
                    160:                 &display_portfolio_files($r,$is_course);
                    161:             } else {
                    162:                 $r->print($blocktext);
                    163:             }
1.60      raeburn   164:         }
1.43      raeburn   165:         $r->print(&Apache::loncommon::end_page());
                    166:         return OK;
                    167:     }
                    168: 
1.55      raeburn   169:     if ($is_course) {
                    170:         if ($target ne 'tex') {
1.85      raeburn   171: 	    my $brcrum = [{href=>"/adm/navmaps",text=>"Navigate Course Contents"},
                    172: 			  {href=>"/adm/aboutme",text=>"Course Information"}];
1.55      raeburn   173:             my $start_page =
                    174:                 &Apache::loncommon::start_page(
                    175:                     "Course Information",
                    176:                      undef,
                    177:                      {'function' => $env{'forcestudent'},
                    178:                       'domain'   => $cdom,
1.82      kaisler   179:                       'force_register' => $env{'forceregister'},
1.85      raeburn   180:                       'bread_crumbs' => $brcrum});
1.55      raeburn   181:             $r->print($start_page);
1.111     weissno   182:             $r->print('<h2>'.&mt('Group Portfolio').'</h2>');
1.55      raeburn   183:             &print_portfiles_link($r,$is_course);
                    184:             $r->print(&Apache::loncommon::end_page());
                    185:         }
                    186:         return OK;
                    187:     }
                    188: 
1.2       www       189: # --------------------------------------------------------------- Force Student
                    190:     my $forcestudent='';
1.37      albertel  191:     if ($env{'form.forcestudent'}) { $forcestudent='student'; };
1.43      raeburn   192: 
                    193:     my $forceregister = '';
                    194:     if ($forcestudent eq '') {
                    195:         $forceregister = $env{'form.register'};
                    196:     }
1.105     neumanie  197: 
                    198: #------------Get rights
1.120     amueller  199: 	my %courseenv=&Apache::lonnet::dump('environment',$cdom,$cnum);
                    200:  	my %syllabus=&Apache::lonnet::dump('aboutme',$cdom,$cnum);
1.105     neumanie  201:     my $allowed=0;
1.125   ! bisitz    202:   	my $privleged=$allowed=(($env{'user.name'} eq $cnum) &&
1.105     neumanie  203: 			       ($env{'user.domain'} eq $cdom));
1.125   ! bisitz    204:     if ($forcestudent or $target eq 'tex') { $allowed=0; }
        !           205: 
        !           206: 
1.2       www       207: # --------------------------------------- There is such a user, get environment
1.125   ! bisitz    208: 
1.22      sakharuk  209:     if ($target ne 'tex') {
1.65      albertel  210: 	my $rss_link = &Apache::lonrss::rss_link($cnum,$cdom);
1.69      raeburn   211:         my $args = {'function' => $forcestudent,
                    212:                     'domain'   => $cdom,
                    213:                     'force_register' => $forceregister};
                    214:         if ($env{'form.popup'}) {
                    215:             $args->{'no_nav_bar'} = 1;
                    216:         }
1.98      weissno   217: 	$args->{'bread_crumbs'} = [{href=>"/adm/fhwfdev/$cnum/aboutme",text=>"Personal Information Page"}];
1.125   ! bisitz    218: 	my $start_page =
1.106     schafran  219: 	    &Apache::loncommon::start_page("Personal Data",$rss_link,$args);
1.40      albertel  220: 	$r->print($start_page);
1.125   ! bisitz    221: 
        !           222:     }
1.105     neumanie  223: 
1.115     bisitz    224: #Print Privacy Note
1.125   ! bisitz    225:     if ($allowed) {
1.123     amueller  226:            $r->print('<div class="LC_info">'
1.116     bisitz    227:                     .'<b>'.&mt('Privacy Note:').'</b> '
1.115     bisitz    228:                     .&mt('The information you submit can be viewed by anybody who is logged into LON-CAPA. Do not provide information that you are not ready to share publicly.')
1.123     amueller  229:                     .'</div>'
1.115     bisitz    230:            );
1.120     amueller  231: 	}
1.115     bisitz    232: 
1.123     amueller  233: #Print last modified
                    234: 
                    235: 	my $lastmod;
                    236:     if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) {
                    237:        $lastmod=$syllabus{'uploaded.lastmodified'};
                    238:        $lastmod=($lastmod?&Apache::lonlocal::locallocaltime($lastmod):&mt('never'));
                    239: 	$r->print('<div class="LC_info">');
                    240:  	$r->print(&mt('Last updated').': '.$lastmod . '');
                    241: 	$r->print('</div>');
                    242: }
1.107     neumanie  243: #Print Help Text
1.120     amueller  244: 	if ($target ne 'tex') {
                    245: 		if($allowed){
                    246: 			$r->print(&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')));
1.125   ! bisitz    247: 		}
1.107     neumanie  248: 	}
                    249: 
1.105     neumanie  250: #----------------Print Functions
1.120     amueller  251: 	if ($target ne 'tex'){
1.119     bisitz    252: 		 $r->print(&Apache::lontemplate::start_functionslist());
1.105     neumanie  253:       		if($allowed){
1.125   ! bisitz    254: 			 my $query_string = &build_query_string({'forcestudent' => '1','popup' => $env{'form.popup'}});
1.119     bisitz    255:                         $r->print(&Apache::lontemplate::item_functionslist(
                    256:                             '<a href="'.$r->uri.$query_string.'">'.&mt('Show Public View').'</a>'
                    257:                            .&Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView')));
1.107     neumanie  258:     		}elsif($privleged){
1.105     neumanie  259: 			my $query_string = &build_query_string({'forceedit' => '1','popup' => $env{'form.popup'}});
1.119     bisitz    260:                         $r->print(&Apache::lontemplate::item_functionslist(
                    261:                             '<a href="'.$r->uri.$query_string.'">'. &mt('Edit').'</a>'));
1.105     neumanie  262: 		}
1.119     bisitz    263:                 $r->print(&Apache::lontemplate::item_functionslist(
                    264:                     &Apache::lontemplate::send_message($r,$cnum,$cdom)));
1.105     neumanie  265: 
1.119     bisitz    266: 		if ($env{'request.course.id'} && &Apache::lonnet::allowed('srm',$env{'request.course.id'}) && &in_course($cdom,$cnum)) {
1.105     neumanie  267: 			if (&Apache::lonnet::allowed('vsa', $env{'request.course.id'}) || &Apache::lonnet::allowed('vsa', $env{'request.course.id'}.'/'.
                    268: 					 $env{'request.course.sec'})) {
1.119     bisitz    269:                             $r->print(&Apache::lontemplate::item_functionslist(
                    270:                                 &Apache::loncommon::track_student_link('View recent activity by this student',$cnum,$cdom)));
1.105     neumanie  271: 	    		}
1.125   ! bisitz    272:                         if (&Apache::lonnet::allowed('vgr', $env{'request.course.id'}) ||
1.117     raeburn   273:                             &Apache::lonnet::allowed('vgr', $env{'request.course.id'}.'/'.
                    274:                                                      $env{'request.course.sec'})) {
1.119     bisitz    275:                             $r->print(&Apache::lontemplate::item_functionslist(
                    276:                                 &Apache::loncommon::slot_reservations_link('Slot reservation history',$cnum,$cdom)));
1.117     raeburn   277:                         }
1.119     bisitz    278:                         $r->print(&Apache::lontemplate::item_functionslist(
                    279:                             &Apache::loncommon::noteswrapper(&mt('Add Records'),$cnum,$cdom)));
1.105     neumanie  280: 		}
1.119     bisitz    281:         $r->print(&Apache::lontemplate::end_functionslist());
1.125   ! bisitz    282: 	}
1.105     neumanie  283: #------Print Headtitle
1.120     amueller  284:  	if ($target ne 'tex') {
                    285: 		$r->print('<div class="LC_ContentBoxSpecial">');
                    286: 		$r->print('<h2 class="LC_hcell">'.&Apache::loncommon::plainname($cnum,$cdom).'</h2>');
                    287: 		$r->print('<blockquote>');
                    288: 	 	if ($courseenv{'nickname'}) {
1.105     neumanie  289:       	 	$r->print('<h2>&quot;'.$courseenv{'nickname'}.'&quot;</h2>');
                    290:     	}
1.120     amueller  291: 		$r->print('<h3>'.&Apache::lonnet::domain($cdom,'description').'</h3>');
                    292:  	}
                    293: 	else {
                    294: 		$r->print('\noindent{\large\textbf{'.&Apache::loncommon::plainname($cnum,$cdom).'}}\\\\\\\\');
1.125   ! bisitz    295: 		$r->print('\textbf{'.&Apache::lonnet::domain($cdom,'description').'}\\\\');
1.120     amueller  296: 	}
1.1       www       297: # does this user have privileges to post, etc?
1.2       www       298: 
1.125   ! bisitz    299: 
        !           300: 	my $query_string;
        !           301: 
1.37      albertel  302:       if (($env{'form.uploaddoc.filename'}) &&
                    303:           ($env{'form.storeupl'}) && ($allowed)) {
                    304:  	  if ($env{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/i) {
1.24      albertel  305: 	      if ($syllabus{'uploaded.photourl'}) {
                    306: 		  &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});
                    307: 	      }
                    308: 	      $syllabus{'uploaded.photourl'}=
1.79      amueller  309:                  &Apache::lonnet::userphotoupload('uploaddoc','aboutme');
1.3       www       310:  	  }
                    311:           $syllabus{'uploaded.lastmodified'}=time;
                    312:           &Apache::lonnet::put('aboutme',\%syllabus,$cdom,$cnum);
                    313:        }
1.37      albertel  314:     if ($allowed && $env{'form.delupl'}) {
1.32      albertel  315: 	if ($syllabus{'uploaded.photourl'}) {
                    316: 	    &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});
                    317: 	    delete($syllabus{'uploaded.photourl'});
                    318: 	    &Apache::lonnet::del('aboutme',['uploaded.photourl'],$cdom,$cnum);
                    319: 	}
                    320:     }
1.37      albertel  321:        if (($allowed) && ($env{'form.storesyl'})) {
1.57      albertel  322: 	   foreach my $syl_field (keys(%syllabusfields)) {
                    323:                my $field=$env{'form.'.$syl_field};
1.2       www       324:                $field=~s/\s+$//s;
1.11      www       325:                $field=&Apache::lonfeedback::clear_out_html($field,
1.37      albertel  326:                                                            $env{'user.adv'});
1.57      albertel  327: 	       $syllabus{$syl_field}=$field;
1.2       www       328:            }
                    329:            $syllabus{'uploaded.lastmodified'}=time;
                    330:            &Apache::lonnet::put('aboutme',\%syllabus,$cdom,$cnum);
                    331:        }
                    332: 
1.125   ! bisitz    333: my $image;
1.2       www       334: # ---------------------------------------------------------------- Get syllabus
                    335:     if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) {
1.3       www       336:        if ($syllabus{'uploaded.photourl'}) {
1.24      albertel  337: 	   &Apache::lonnet::allowuploaded('/adm/aboutme',
                    338: 					  $syllabus{'uploaded.photourl'});
1.125   ! bisitz    339: 
1.97      weissno   340:            #This call is to resize all "Personal Information" images in the LonCapa System. When its done, you can remove this line.
1.91      neumanie  341: 	   &Apache::lonnet::resizeImage(&Apache::lonnet::filelocation('',$syllabus{'uploaded.photourl'}));
1.93      neumanie  342: 	   #---End Resize---
1.91      neumanie  343: 
1.94      neumanie  344: 	   $image=qq{<img name="userPhoto" src="$syllabus{'uploaded.photourl'} " class="LC_AboutMe_Image" />};
1.125   ! bisitz    345: 
1.27      albertel  346: 	   if ($target eq 'tex') {
                    347: 	       $image=&Apache::lonxml::xmlparse($r,'tex',$image);
1.26      sakharuk  348: 	   }
1.125   ! bisitz    349: 
1.3       www       350:        }
1.125   ! bisitz    351: 
1.23      sakharuk  352:        if ($allowed) {
1.3       www       353:            $r->print(
                    354: 	 '<form method="post" enctype="multipart/form-data">'.
1.18      www       355:          '<h3>'.&mt('Upload a Photo').'</h3>'.
1.68      raeburn   356:          '<input type="file" name="uploaddoc" size="50" />'.
                    357:          '<input type="submit" name="storeupl" value="'.&mt('Upload').'" />'.
1.69      raeburn   358:          '<input type="hidden" name="popup" value="'.$env{'form.popup'}.'" />'.
1.122     amueller  359: 	 '</form>');
                    360: 	      if ($syllabus{'uploaded.photourl'}) {
                    361:               $r->print('<form method="post"><input type="submit" name="delupl" value="'.&mt('Delete Photo').'" /> </form>')
                    362:           }
                    363:           $r->print('<p>');
1.2       www       364:        }
1.86      schualex  365: 
                    366: 	if($allowed) {
                    367: 		$r->print('<form method="post">');
                    368: 	}
                    369: 
1.93      neumanie  370: 	 if($target ne 'tex') #print Image
1.125   ! bisitz    371:      	 {
        !           372: 		&Apache::lontemplate::start_ContentBox($r);
1.81      ehlerst   373: 		&Apache::lontemplate::end_ContentBox($r);
1.125   ! bisitz    374: 		$r->print($image);
        !           375: 
1.93      neumanie  376: 	}#End Print Image
                    377: 
1.125   ! bisitz    378: 	#Print Content eg. Contactinfo aboutme,...
        !           379: 	&Apache::lontemplate::print_aboutme_content_template($r,$allowed,$target,\%syllabusfields,\%syllabus);
1.93      neumanie  380:         #End Print Content
                    381: 
                    382:        if($target ne 'tex')#Begin Print RSS and portfiles
1.125   ! bisitz    383:        {
1.81      ehlerst   384: 		&print_portfiles_link($r,$is_course);
1.109     neumanie  385: 		if(&Apache::lonrss::advertisefeeds($cnum,$cdom) ne ''){
                    386: 			&Apache::lontemplate::print_start_template($r,'RSS Feeds and Blogs','LC_ContentBoxSpecial');
1.125   ! bisitz    387: 			$r->print(&Apache::lonrss::advertisefeeds($cnum,$cdom));
        !           388: 			&Apache::lontemplate::print_end_template($r);
        !           389: 		}
        !           390: 
1.101     neumanie  391:        } #End  Print RSS and portfiles
1.95      schualex  392: 
1.125   ! bisitz    393: 
1.23      sakharuk  394:        if ($allowed) {
1.69      raeburn   395:            if ($env{'form.popup'}) {
                    396:                $r->print('<input type="hidden" name="popup" value="'.
                    397:                          $env{'form.popup'}.'" />');
                    398:            }
1.2       www       399: 	   $r->print('</form>');
                    400:        }
1.46      albertel  401:        if ($target ne 'tex') {$r->print('<br />');} else {$r->print('\\\\');}
1.2       www       402:     } else {
1.99      neumanie  403: 	# &Apache::lontemplate::send_message($r,$cnum,$cdom);
1.17      www       404:        $r->print('<p>'.&mt('No personal information provided').'.</p>');
1.8       www       405:     }
1.101     neumanie  406:     if($target ne 'tex'){
1.102     schualex  407: 		#$r->print('</blockquote>');
1.125   ! bisitz    408:     		#$r->print('</div>');
1.101     neumanie  409: 	}
1.43      raeburn   410: 
1.63      albertel  411:     if ($env{'request.course.id'}
                    412: 	&& &Apache::lonnet::allowed('srm',$env{'request.course.id'})
                    413: 	&& &in_course($cdom,$cnum)) {
1.125   ! bisitz    414: 	if ($target ne 'tex') {
        !           415: 	   $r->print('<a name="coursecomment" />');
1.112     schualex  416: 	   &Apache::lontemplate::print_start_template($r,&mt('User Notes, Records of Face-To-Face Discussions, and Critical Messages in Course'),'LC_ContentBoxSpecial');
1.114     amueller  417: 	   $r->print('<span class="LC_info">');
1.112     schualex  418: 	   $r->print(&mt('Shared by course faculty and staff').&Apache::loncommon::help_open_topic("Course_Face_To_Face_Records,Course_Critical_Message"));
1.125   ! bisitz    419: 		$r->print('</span> <p>');
1.114     amueller  420: &Apache::lonmsgdisplay::disfacetoface($r,$cnum,$cdom);
1.112     schualex  421: 	   $r->print('</p>');
1.105     neumanie  422: 	   &Apache::lontemplate::print_end_template($r);
1.125   ! bisitz    423: 
1.63      albertel  424: 	} else {
                    425: 	    $r->print('\\\\\textbf{'.&mt('User Notes, Records of Face-To-Face Discussions, and Critical Messages in Course').'}\\\\'.&mt('Shared by course faculty and staff').'\\\\\\\\');
                    426: 	    &Apache::lonmsgdisplay::disfacetoface($r,$cnum,$cdom);
                    427: 	}
1.1       www       428:     }
1.102     schualex  429:     $r->print('</blockquote>');
                    430:     $r->print('</div>');
1.40      albertel  431:     if ($target ne 'tex') {
1.69      raeburn   432:         if ($env{'form.popup'}) {
                    433:             $r->print('<p><a href="javascript:window.close()">'.&mt('Close window').'</a>');
                    434:         }
1.40      albertel  435: 	$r->print(&Apache::loncommon::end_page());
                    436:     } else {
                    437: 	$r->print('\end{document}');
                    438:     }
1.71      amueller  439: 
1.125   ! bisitz    440: 
        !           441: 
1.1       www       442:     return OK;
1.43      raeburn   443: }
                    444: 
1.63      albertel  445: sub in_course {
                    446:     my ($udom,$uname,$cdom,$cnum,$type) = @_;
                    447:     $type ||= 'any';
                    448:     if (!defined($cdom) || !defined($cnum)) {
                    449: 	my $cid  = $env{'request.course.id'};
                    450: 	$cdom = $env{'course.'.$cid.'.domain'};
                    451: 	$cnum = $env{'course.'.$cid.'.num'};
                    452:     }
                    453:     my %roles = &Apache::lonnet::dump('roles',$udom,$uname);
                    454:     my @course_roles = grep(m{^/\Q$cdom\E/\Q$cnum\E[/_]}, keys(%roles));
                    455:     return 0 if (!@course_roles);
                    456:     return 1 if ($type eq 'any');
                    457:     my $now = time();
                    458:     foreach my $role (@course_roles) {
                    459: 	my (undef,$role_end,$role_start)=split(/\_/,$roles{$role});
                    460: 	my $status = 'active';
                    461: 	if ($role_start > 0 && $now < $role_start) {
                    462: 	    $status = 'future';
                    463: 	}
                    464: 	if ($role_end > 0 && $now > $role_end) {
                    465: 	    $status = 'previous';
                    466: 	}
                    467: 	return 1 if ($status eq $type);
                    468:     }
                    469:     return 0;
                    470: }
                    471: 
1.43      raeburn   472: sub aboutme_info {
1.55      raeburn   473:     my ($r,$is_course) = @_;
1.43      raeburn   474:     my (undef,undef,$cdom,$cnum)=split(/\//,$r->uri);
1.55      raeburn   475:     my $name;
                    476:     if (!$is_course) {
                    477:         $name = &Apache::loncommon::plainname($cnum,$cdom);
                    478:     }
1.43      raeburn   479:     return ($cdom,$cnum,$name);
                    480: }
                    481: 
                    482: sub print_portfiles_link {
1.55      raeburn   483:     my ($r,$is_course) = @_;
                    484:     my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
1.64      raeburn   485:     my $filecounts = &portfolio_files($r,'showlink',undef,$is_course,
                    486:                                       $cdom,$cnum,$name);
1.47      albertel  487:     my $query_string = &build_query_string();
1.43      raeburn   488:     my $output;
1.55      raeburn   489:     my %lt = &Apache::lonlocal::texthash(
1.113     bisitz    490:         'vpfi' => 'Viewable portfolio files',
                    491:         'vgpf' => 'Viewable group portfolio files',
                    492:         'difl' => 'Display file listing',
1.125   ! bisitz    493:     );
1.43      raeburn   494:     if ($filecounts->{'both'} > 0) {
1.89      harmsja   495: 	$output = '<div class="LC_ContentBoxSpecial"><h4 class="LC_hcell">';
1.124     neumanie  496: 	$output .= ($is_course?$lt{'vgpf'}:$lt{'vpfi'}).'</h4><div class="LC_BoxPadding">';
1.125   ! bisitz    497: 
1.76      harmsja   498: 	#$output = '<h4>'.($is_course?$lt{'vgpf'}:$lt{'vpfi'}).'</h4>';
1.47      albertel  499:         $output .= '<a href="/adm/'.$cdom.'/'.$cnum.'/aboutme/portfolio'.
1.55      raeburn   500:                    $query_string.'">'.$lt{'difl'}.
1.43      raeburn   501:                    '</a><br /><br />';
1.53      raeburn   502:         if ($filecounts->{'both'} == 1) {
1.55      raeburn   503:             if ($is_course) {
                    504:                 $output .= &mt('One group portfolio file is available.').'<ul>';
                    505:             } else {
1.56      albertel  506:                 $output .= &mt('One portfolio file owned by [_1] is available.',$name).'<ul>';
1.55      raeburn   507:             }
1.53      raeburn   508:         } else {
1.55      raeburn   509:             if ($is_course) {
1.56      albertel  510:                 $output .= &mt('A total of [_1] group portfolio files are available.',$filecounts->{'both'}).'<ul>';
1.55      raeburn   511:             } else {
                    512:                 $output .= &mt('A total of [_1] portfolio files owned by [_2] are available.',$filecounts->{'both'},$name).'<ul>';
                    513:             }
1.53      raeburn   514:         }
1.43      raeburn   515:         if ($filecounts->{'withoutpass'}) {
1.54      albertel  516: 	    $output .= '<li>'.&mt('[quant,_1,file is,files are] publicly accessible.',$filecounts->{'withoutpass'}).'</li>';
1.43      raeburn   517:         }
                    518:         if ($filecounts->{'withpass'}) {
1.54      albertel  519: 	    $output .= '<li>'.&mt('[quant,_1,file requires,files require] a passphrase for access.',$filecounts->{'withpass'}).'</li>';
1.43      raeburn   520:         }
                    521:         $output .= '</ul>';
1.76      harmsja   522: 	$output .='</p>';
1.124     neumanie  523: 	$output .='</div></div>';
1.43      raeburn   524:     }
                    525:     $r->print($output);
                    526:     return;
                    527: }
                    528: 
                    529: sub build_query_string {
                    530:     my ($new_items) = @_;
                    531:     my $query_string;
1.125   ! bisitz    532:     my @formelements = ('register');
1.47      albertel  533:     my $new = 0;
1.43      raeburn   534:     if (ref($new_items) eq 'HASH') {
1.47      albertel  535:         $new = 1;
1.125   ! bisitz    536:         if (!defined($new_items->{'forceedit'}) &&
1.43      raeburn   537:             !defined($new_items->{'forcestudent'})) {
                    538:             push(@formelements,('forceedit','forcestudent'));
                    539:         }
                    540:     } else {
                    541:         push(@formelements,('forceedit','forcestudent'));
                    542:     }
                    543:     foreach my $element (@formelements) {
                    544:         if (exists($env{'form.'.$element})) {
1.47      albertel  545:             if ((!$new) || (!defined($new_items->{$element}))) {
1.43      raeburn   546:                 $query_string .= '&amp;'.$element.'='.$env{'form.'.$element};
                    547:             }
                    548:         }
                    549:     }
1.47      albertel  550:     if ($new) {
1.43      raeburn   551:         foreach my $key (keys(%{$new_items})) {
                    552:             $query_string .= '&amp;'.$key.'='.$new_items->{$key};
                    553:         }
                    554:     }
                    555:     $query_string =~ s/^\&amp;/\?/;
                    556:     return $query_string;
                    557: }
                    558: 
                    559: sub display_portfolio_header {
1.55      raeburn   560:     my ($r,$is_course) = @_;
                    561:     my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
1.43      raeburn   562:     my $query_string = &build_query_string();
                    563:     &Apache::lonhtmlcommon::clear_breadcrumbs();
                    564:     my $forcestudent='';
                    565:     if ($env{'form.forcestudent'}) { $forcestudent='student'; };
1.55      raeburn   566: 
                    567:     my $output;
                    568:     if ($is_course) {
1.125   ! bisitz    569:         $output =
1.55      raeburn   570:             &Apache::loncommon::start_page('Viewable group portfolio files',undef,
                    571:                                             {'function' => $forcestudent,
                    572:                                              'domain'   => $cdom,});
                    573:         $output .= '<h3>'.&mt('Group Portfolio files').'</h3>';
                    574:     } else {
                    575:         $output  =
                    576:             &Apache::loncommon::start_page('Viewable portfolio files',undef,
                    577:                                             {'function' => $forcestudent,
1.43      raeburn   578:                                              'domain'   => $cdom,});
1.55      raeburn   579:         if (!($env{'user.name'} eq 'public' && $env{'user.domain'} eq 'public')) {
                    580:             &Apache::lonhtmlcommon::add_breadcrumb
                    581:                 ({href=>"/adm/$cdom/$cnum/aboutme".$query_string,
1.104     weissno   582:                   text=>&mt('Personal Information Page - [_1]',$name),
1.105     neumanie  583:                   title=>&mt('Go to personal information page for [_1]', $name)},
                    584: 		 {href=>"/adm/$cdom/$cnum/aboutme/portfolio",
                    585:                   text=>&mt('Viewable files - [_1]', $name),
                    586:                   title=>&mt('Viewable portfolio files for [_1]', $name)}
1.55      raeburn   587:             );
                    588:             $output .= &Apache::lonhtmlcommon::breadcrumbs(&mt('Viewable portfolio files.'));
                    589:         }
                    590:         $output .= '<h3>'.&mt('Portfolio files for [_1]',$name).'</h3>';
1.53      raeburn   591:     }
1.43      raeburn   592:     $r->print($output);
                    593:     return;
                    594: }
                    595: 
                    596: sub display_portfolio_files {
1.55      raeburn   597:     my ($r,$is_course) = @_;
                    598:     my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
1.113     bisitz    599:     my %lt = &Apache::lonlocal::texthash(
                    600:         'withoutpass' => 'passphrase not required',
                    601:         'withpass'    => 'passphrase protected',
                    602:         'both'        => 'all access types ',
                    603:     );
1.47      albertel  604: 
1.43      raeburn   605:     my $portaccess = 'withoutpass';
                    606:     if (exists($env{'form.portaccess'})) {
                    607:         $portaccess = $env{'form.portaccess'};
                    608:     }
1.47      albertel  609: 
1.45      albertel  610:     my $output = '<form action="'.&HTML::Entities::encode($r->uri,'<>&"')
                    611: 	.'" name="displaystatus" method="post">'.
                    612: 	&mt('File access type: ').'<select name="portaccess">';
1.43      raeburn   613:     foreach my $type ('withoutpass','withpass','both') {
                    614:         $output .= '<option value="'.$type.'" ';
                    615:         if ($portaccess eq $type) {
                    616:             $output .= 'selected="selected"';
                    617:         }
1.53      raeburn   618:         $output .= '>'.$lt{$type}.'</option>';
1.43      raeburn   619:     }
                    620:     $output .= '</select>'."\n".
                    621:                '<input type="submit" name="portaccessbutton" value="'.
1.47      albertel  622:                &mt('Update display').'" />';
1.43      raeburn   623:     $output .= '</form><br /><br />';
                    624:     $r->print($output);
1.64      raeburn   625:     my $filecounts = &portfolio_files($r,'listfiles',\%lt,$is_course,
                    626:                                       $cdom,$cnum,$name);
1.53      raeburn   627:     if (!($env{'user.name'} eq 'public' && $env{'user.domain'} eq 'public')) {
                    628:         my $query_string = &build_query_string();
                    629:         $r->print('<br /><br /><a href="/adm/'.$cdom.'/'.$cnum.
1.55      raeburn   630:                   '/aboutme'.$query_string.'">');
                    631:         if ($is_course) {
                    632:             $r->print(&mt('Course Information page'));
                    633:         } else {
                    634:             $r->print(&mt('Information about [_1]',$name));
                    635:         }
                    636:         $r->print('</a>');
1.53      raeburn   637:     }
1.43      raeburn   638:     return;
                    639: }
                    640: 
                    641: sub portfolio_files {
1.64      raeburn   642:     my ($r,$mode,$lt,$is_course,$cdom,$cnum,$name) = @_;
1.43      raeburn   643:     my $filecounts = {
                    644:                        withpass    => 0,
                    645:                        withoutpass => 0,
                    646:                        both        => 0,
                    647:                      };
                    648:     my $current_permissions =
1.44      albertel  649: 	&Apache::lonnet::get_portfile_permissions($cdom,$cnum);
1.125   ! bisitz    650:     my %access_controls =
1.44      albertel  651: 	&Apache::lonnet::get_access_controls($current_permissions);
1.43      raeburn   652:     my $portaccess;
                    653:     if ($mode eq 'showlink') {
                    654:         $portaccess = 'both';
                    655:     } else {
                    656:         $portaccess = 'withoutpass';
                    657:         if (exists($env{'form.portaccess'})) {
                    658:             $portaccess = $env{'form.portaccess'};
                    659:         }
                    660:     }
                    661: 
1.55      raeburn   662:     my $diroutput;
                    663:     if ($is_course) {
                    664:         my %files_by_group;
                    665:         foreach my $filename (sort(keys(%access_controls))) {
                    666:             my ($group,$path) = split('/',$filename,2);
1.125   ! bisitz    667:             $files_by_group{$group}{$path} = $access_controls{$filename};
1.55      raeburn   668:         }
                    669:         foreach my $group (sort(keys(%files_by_group))) {
                    670:             my %fileshash;
                    671:             my $grpout .= &build_hierarchy($r,$cdom,$cnum,$portaccess,
                    672:                                            $is_course,$filecounts,$mode,
                    673:                                            $files_by_group{$group},
                    674:                                            \%fileshash,$group);
                    675:             if ($grpout) {
                    676:                 $diroutput .= '<h3>'.$group.'</h3>'.$grpout.'<br />';
                    677:             }
                    678:         }
                    679:     } else {
                    680:         my %allfileshash;
                    681:         $diroutput = &build_hierarchy($r,$cdom,$cnum,$portaccess,$is_course,
                    682:                                       $filecounts,$mode,\%access_controls,
                    683:                                       \%allfileshash);
                    684:     }
                    685:     if ($mode eq 'listfiles') {
                    686:         if ($filecounts->{'both'}) {
                    687:              $r->print($diroutput);
                    688:         } else {
                    689:             my $access_text;
                    690:             if (ref($lt) eq 'HASH') {
1.125   ! bisitz    691:                 $access_text = $lt->{$portaccess};
1.55      raeburn   692:             }
                    693:             $r->print(&mt('There are no available files of the specified access type: [_1]',$access_text));
                    694:         }
                    695:     }
                    696:     return $filecounts;
                    697: }
                    698: 
1.125   ! bisitz    699: {
1.55      raeburn   700:     my $count=0;
                    701:     sub portfolio_table_start {
                    702: 	$count=0;
                    703: 	return '<table class="LC_aboutme_port">';
                    704:     }
                    705:     sub portfolio_row_start {
                    706: 	$count++;
                    707: 	my $class = ($count%2)?'LC_odd_row'
                    708: 	                      :'LC_even_row';
                    709: 	return '<tr class="'.$class.'">';
                    710:     }
                    711: }
                    712: 
                    713: sub build_hierarchy {
                    714:     my ($r,$cdom,$cnum,$portaccess,$is_course,$filecounts,$mode,$access_info,
                    715:         $allfileshash,$group) = @_;
                    716:     foreach my $filename (sort(keys(%{$access_info}))) {
                    717:         my $access_status =
                    718:            &Apache::lonnet::get_portfolio_access($cdom,$cnum,$filename,$group,                                                 $$access_info{$filename});
1.43      raeburn   719:         if ($portaccess eq 'both') {
                    720:             if (($access_status ne 'ok') &&
                    721:                 ($access_status !~  /^[^:]+:guest_/)) {
                    722:                 next;
                    723:             }
                    724:         } elsif ($portaccess eq 'withoutpass') {
                    725:             if ($access_status ne 'ok') {
                    726:                 next;
                    727:             }
                    728:         } elsif ($portaccess eq 'withpass') {
                    729:             if ($access_status !~  /^[^:]+:guest_/) {
                    730:                 next;
                    731:             }
                    732:         }
                    733:         if ($mode eq 'listfiles') {
                    734:             $filename =~ s/^\///;
                    735:             my @pathitems = split('/',$filename);
1.55      raeburn   736:             my $lasthash = $allfileshash;
1.43      raeburn   737:             while (@pathitems > 1) {
                    738:                 my $newlevel = shift(@pathitems);
                    739:                 if (!exists($lasthash->{$newlevel})) {
                    740:                     $lasthash->{$newlevel} = {};
                    741:                 }
                    742:                 $lasthash = $lasthash->{$newlevel};
                    743:             }
                    744:             $lasthash->{$pathitems[0]} = $filename;
                    745:         }
                    746:         if ($access_status eq 'ok') {
                    747:             $filecounts->{'withoutpass'} ++;
                    748:         } elsif ($access_status =~  /^[^:]+:guest_/) {
                    749:             $filecounts->{'withpass'} ++;
                    750:         }
                    751:     }
                    752:     $filecounts->{'both'} =  $filecounts->{'withoutpass'} +
                    753:                               $filecounts->{'withpass'};
1.55      raeburn   754:     my $output;
1.43      raeburn   755:     if ($mode eq 'listfiles') {
1.55      raeburn   756:         if ($filecounts->{'both'} > 0) {
1.45      albertel  757:             $output = &portfolio_table_start();
1.55      raeburn   758:             $output .= &parse_directory($r,0,$allfileshash,'',$is_course,
                    759:                                         $group);
1.43      raeburn   760:             $output .= '</table>';
                    761:         }
1.45      albertel  762:     }
1.55      raeburn   763:     return $output;
1.45      albertel  764: }
                    765: 
1.43      raeburn   766: sub parse_directory {
1.55      raeburn   767:     my ($r,$depth,$currhash,$path,$is_course,$group) = @_;
                    768:     my ($cdom,$cnum,$name) = &aboutme_info($r,$is_course);
1.45      albertel  769:     $depth++;
                    770:     my $output;
1.49      albertel  771: 
1.55      raeburn   772:     my $portfolio_root = &Apache::portfolio::get_portfolio_root($cdom,$cnum,
                    773:                                                                 $group);
1.70      raeburn   774:     my $getpropath = 1;
1.49      albertel  775:     my %dirlist = map {
                    776: 	    ((split('&',$_,2))[0],1)
1.70      raeburn   777: 	} &Apache::lonnet::dirlist($portfolio_root.$path,$cdom,$cnum,$getpropath);
1.43      raeburn   778:     foreach my $item (sort(keys(%{$currhash}))) {
1.45      albertel  779:         $output .= &portfolio_row_start();
                    780:         $output .= '<td style="padding-left: '.($depth*25).'px">';
1.43      raeburn   781:         if (ref($currhash->{$item}) eq 'HASH') {
1.45      albertel  782:             my $title=&HTML::Entities::encode($item,'<>&"');
                    783:             $output .= '<img src="'.&Apache::loncommon::lonhttpdurl("/adm/lonIcons/navmap.folder.open.gif").'" alt="'.&mt('Folder').' '.$title.'" class="LC_icon" />&nbsp;'.$title;
1.47      albertel  784: 	    $output .= '</td><td></td></tr>';
1.49      albertel  785:             $output .= &parse_directory($r,$depth,$currhash->{$item},
1.55      raeburn   786: 					$path.'/'.$item,$is_course,$group);
1.43      raeburn   787:         } else {
1.125   ! bisitz    788: 	    my $file_name;
1.50      albertel  789: 	    if ($currhash->{$item} =~ m|/([^/]+)$|) {
                    790: 		$file_name = $1;
                    791: 	    } else {
                    792: 		$file_name = $currhash->{$item};
                    793: 	    }
                    794: 	    my $have_meta = exists($dirlist{$file_name.'.meta'});
1.55      raeburn   795:             my $url;
                    796:             if ($is_course) {
                    797:                 $url = '/uploaded/'.$cdom.'/'.$cnum.'/groups/'.$group.
                    798:                        '/portfolio/'.$currhash->{$item};
1.125   ! bisitz    799:             } else {
1.55      raeburn   800: 	        $url = '/uploaded/'.$cdom.'/'.$cnum.'/portfolio/'.
                    801: 		       $currhash->{$item};
                    802:             }
1.43      raeburn   803:             my $showname;
1.50      albertel  804: 	    if ($have_meta) {
                    805: 		$showname = &Apache::lonnet::metadata($url,'title');
                    806: 	    }
                    807: 	    if ($showname eq '') {
                    808: 		$showname = $file_name;
                    809: 	    } else {
                    810: 		$showname = $file_name.' ('.$showname.')';
                    811: 	    }
                    812: 
1.45      albertel  813:             $showname=&HTML::Entities::encode($showname,'<>&"');
1.49      albertel  814:             $output .= '<a href="'.$url.'">'.
                    815: 		'<img alt="" src="'.&Apache::loncommon::icon($currhash->{$item}).'" class="LC_icon" />'.
                    816: 		'&nbsp;'.$showname.'</a>';
                    817: 	    $output.='</td><td>';
1.50      albertel  818: 	    if ($have_meta) {
1.92      schafran  819: 		$output.= '<a href="'.$url.'.meta"><img alt="'.&mt('Metadata').'" src="'.
1.47      albertel  820: 		&Apache::loncommon::lonhttpdurl('/res/adm/pages/catalog.gif').
1.49      albertel  821: 		'" class="LC_icon" /></a>';
                    822: 	    }
1.45      albertel  823: 	    $output .= '</td></tr>';
1.43      raeburn   824:         }
                    825:     }
1.45      albertel  826:     return $output;
1.43      raeburn   827: }
1.1       www       828: 
1.77      raeburn   829: sub aboutme_access {
                    830:     my ($uname,$udom) = @_;
                    831:     my $privcheck = $env{'request.course.id'};
                    832:     my $sec;
                    833:     if ($env{'request.course.sec'} ne '') {
                    834:         $sec = $env{'request.course.sec'};
                    835:         $privcheck .= '/'.$sec;
                    836:     }
                    837:     my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'};
                    838:     my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'};
                    839:     if (($cdom eq '') || ($cnum eq '')) {
                    840:         my %coursehash = &coursedescription($env{'request.course.id'});
                    841:         $cdom = $coursehash{'domain'};
                    842:         $cnum = $coursehash{'cnum'};
                    843:     }
1.125   ! bisitz    844:     if ((&Apache::lonnet::allowed('srm',$privcheck)) ||
1.84      raeburn   845:         (&Apache::lonnet::allowed('dff',$privcheck))) {
1.77      raeburn   846:         if (&in_course($uname,$udom,$cnum,$cdom)) {
                    847:             return 1;
                    848:         }
                    849:     }
                    850:     return;
                    851: }
                    852: 
1.1       www       853: 1;
                    854: __END__

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>