--- loncom/interface/lonaboutme.pm 2002/08/27 21:05:04 1.3
+++ loncom/interface/lonaboutme.pm 2006/08/02 19:29:35 1.44
@@ -1,7 +1,7 @@
# The LearningOnline Network
# "About Me" Personal Information
#
-# $Id: lonaboutme.pm,v 1.3 2002/08/27 21:05:04 www Exp $
+# $Id: lonaboutme.pm,v 1.44 2006/08/02 19:29:35 albertel Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -33,77 +33,132 @@ use Apache::Constants qw(:common);
use Apache::loncommon;
use Apache::lonnet;
use Apache::lontexconvert;
+use Apache::lonfeedback;
+use Apache::lonrss();
+use Apache::lonlocal;
+use Apache::lonmsgdisplay();
sub handler {
my $r = shift;
- $r->content_type('text/html');
+ &Apache::loncommon::content_type($r,'text/html');
$r->send_http_header;
return OK if $r->header_only;
-
+ my $target=$env{'form.grade_target'};
# ------------------------------------------------------------ Print the screen
- $r->print(<
-
-The LearningOnline Network with CAPA
-
-ENDDOCUMENT
+ if ($target eq 'tex') {
+ $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));
+ }
my (undef,undef,$cdom,$cnum)=split(/\//,$r->uri);
# Is this even a user?
if (&Apache::lonnet::homeserver($cnum,$cdom) eq 'no_host') {
- $r->print('No user information available');
+ &Apache::loncommon::simple_error_page($r,'No info',
+ 'No user information available');
return OK;
}
# --------------------------------------------------------- The syllabus fields
- my %syllabusfields=(
+ my %syllabusfields=&Apache::lonlocal::texthash(
'aaa_contactinfo' => 'Contact Information',
'bbb_aboutme' => 'About Me',
'ccc_webreferences' => 'Web References');
-# --------------------------------------------------------------- Force Student
+# ------------------------------------------------------------ Get Query String
&Apache::loncommon::get_unprocessed_cgi
- ($ENV{'QUERY_STRING'},['forcestudent']);
+ ($ENV{'QUERY_STRING'},['forceedit','forcestudent','register','action']);
+
+# ----------------------------------------------- Available Portfolio file display
+ if (($target ne 'tex') && ($env{'form.action'} eq 'portfolio')) {
+ my %lt = &Apache::lonlocal::texthash (
+ withoutpass => 'passphrase not required',
+ withpass => 'passphrase protected',
+ both => 'all access types ',
+ );
+ &display_portfolio_header($r);
+ &display_portfolio_files($r,\%lt);
+ $r->print(&Apache::loncommon::end_page());
+ return OK;
+ }
+
+# --------------------------------------------------------------- Force Student
my $forcestudent='';
- if ($ENV{'form.forcestudent'}) { $forcestudent='student'; };
+ if ($env{'form.forcestudent'}) { $forcestudent='student'; };
+
+ my $forceregister = '';
+ if ($forcestudent eq '') {
+ $forceregister = $env{'form.register'};
+ }
# --------------------------------------- There is such a user, get environment
my %courseenv=&Apache::lonnet::dump('environment',$cdom,$cnum);
- $r->print(&Apache::loncommon::bodytag
- ("Personal Information",$forcestudent,'','',$cdom));
- $r->print(''.&Apache::loncommon::plainname($cnum,$cdom).'
'.
- $Apache::lonnet::domaindescription{$cdom}.'
');
+ if ($target ne 'tex') {
+ my $start_page =
+ &Apache::loncommon::start_page("Personal Information",undef,
+ {'function' => $forcestudent,
+ 'domain' => $cdom,
+ 'force_register' =>
+ $forceregister,});
+ $r->print($start_page);
+ $r->print(''.&Apache::loncommon::plainname($cnum,$cdom).'
');
+ } else {
+ $r->print('\noindent{\large\textbf{'.&Apache::loncommon::plainname($cnum,$cdom).'}}\\\\\\\\');
+ }
+ if ($courseenv{'nickname'}) {
+ $r->print(
+ '"'.$courseenv{'nickname'}.
+ '"
');
+ }
+ if ($target ne 'tex') {
+ $r->print(''.$Apache::lonnet::domaindescription{$cdom}.'
'.
+ ''.&Apache::loncommon::messagewrapper('Send me a message',$cnum,$cdom).'
'.&Apache::lonrss::advertisefeeds($cnum,$cdom));
+ } else {
+ $r->print('\textbf{'.$Apache::lonnet::domaindescription{$cdom}.'}\\\\');
+ }
my %syllabus=&Apache::lonnet::dump('aboutme',$cdom,$cnum);
my $allowed=0;
# does this user have privileges to post, etc?
- $allowed=(($ENV{'user.name'} eq $cnum) &&
- ($ENV{'user.domain'} eq $cdom));
- if ($forcestudent) { $allowed=0; }
+ my $privleged=$allowed=(($env{'user.name'} eq $cnum) &&
+ ($env{'user.domain'} eq $cdom));
+ if ($forcestudent or $target eq 'tex') { $allowed=0; }
if ($allowed) {
- $r->print(
- 'Show Student View
');
- }
- if (($ENV{'form.uploaddoc.filename'}) &&
- ($ENV{'form.storeupl'}) && ($allowed)) {
- if ($ENV{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/) {
- $syllabus{'uploaded.photourl'}=
- &Apache::lonnet::userfileupload('uploaddoc');
+ my $query_string = &build_query_string({'forcestudent' => '1',});
+ $r->print(''.&mt('Privacy Note').': '.
+ &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.').
+ '
'.
+ &Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes','Help with filling in text boxes').'
Show Public View'.
+ &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView').'
');
+ } elsif ($privleged && $target ne 'tex') {
+ my $query_string = &build_query_string({'forceedit' => '1',});
+ $r->print(''.
+ &mt('Edit').'
');
+ }
+ if (($env{'form.uploaddoc.filename'}) &&
+ ($env{'form.storeupl'}) && ($allowed)) {
+ if ($env{'form.uploaddoc.filename'}=~/\.(gif|jpg|png|jpeg)$/i) {
+ if ($syllabus{'uploaded.photourl'}) {
+ &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});
+ }
+ $syllabus{'uploaded.photourl'}=
+ &Apache::lonnet::userfileupload('uploaddoc',undef,'aboutme');
}
$syllabus{'uploaded.lastmodified'}=time;
&Apache::lonnet::put('aboutme',\%syllabus,$cdom,$cnum);
}
- if (($allowed) && ($ENV{'form.storesyl'})) {
+ if ($allowed && $env{'form.delupl'}) {
+ if ($syllabus{'uploaded.photourl'}) {
+ &Apache::lonnet::removeuploadedurl($syllabus{'uploaded.photourl'});
+ delete($syllabus{'uploaded.photourl'});
+ &Apache::lonnet::del('aboutme',['uploaded.photourl'],$cdom,$cnum);
+ }
+ }
+ if (($allowed) && ($env{'form.storesyl'})) {
foreach (keys %syllabusfields) {
- my $field=$ENV{'form.'.$_};
+ my $field=$env{'form.'.$_};
$field=~s/\s+$//s;
- $field=~s/\\<\;/g;
- $field=~s/\>/\>\;/g;
- if ($field) {
- $syllabus{$_}=$field;
- } else {
- delete $syllabus{$_};
- }
+ $field=&Apache::lonfeedback::clear_out_html($field,
+ $env{'user.adv'});
+ $syllabus{$_}=$field;
}
$syllabus{'uploaded.lastmodified'}=time;
&Apache::lonnet::put('aboutme',\%syllabus,$cdom,$cnum);
@@ -111,47 +166,337 @@ ENDDOCUMENT
# ---------------------------------------------------------------- Get syllabus
if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) {
- $r->print('Last updated:'.
- localtime($syllabus{'uploaded.lastmodified'}));
+ my $lastmod=$syllabus{'uploaded.lastmodified'};
+ $lastmod=($lastmod?&Apache::lonlocal::locallocaltime($lastmod):&mt('never'));
+ $r->print(&mt('Last updated').': '.$lastmod);
if ($syllabus{'uploaded.photourl'}) {
- $r->print('
');
+ &Apache::lonnet::allowuploaded('/adm/aboutme',
+ $syllabus{'uploaded.photourl'});
+ my $image=
+ qq{
};
+ if ($target eq 'tex') {
+ $image=&Apache::lonxml::xmlparse($r,'tex',$image);
+ }
+ $r->print($image);
}
if ($allowed) {
$r->print(
+ ''.
'');
}
- $r->print('');
+ if ($target ne 'tex') {$r->print('');} else {$r->print('\\\\');}
} else {
- $r->print('No personal information provided.
');
+ $r->print(''.&mt('No personal information provided').'.
');
+ }
+
+ if ($target ne 'tex') {
+ &print_portfiles_link($r);
+ }
+
+ if ($env{'request.course.id'}) {
+ if (&Apache::lonnet::allowed('srm',$env{'request.course.id'})) {
+ if ($target ne 'tex') {
+ $r->print('');
+ $r->print('
'.
+ &mt('User Notes, Records of Face-To-Face Discussions, and Critical Messages in Course').'
'.
+ &mt('Shared by course faculty and staff').
+ &Apache::loncommon::help_open_topic("Course_Face_To_Face_Records,Course_Critical_Message").
+'
');
+ &Apache::lonmsgdisplay::disfacetoface($r,$cnum,$cdom);
+ $r->print('
');
+ if (&Apache::lonnet::allowed('vsa',
+ $env{'request.course.id'}) ||
+ &Apache::lonnet::allowed('vsa',
+ $env{'request.course.id'}.'/'.
+ $env{'request.course.sec'})) {
+ $r->print(&Apache::loncommon::track_student_link
+ ('View recent activity by this student',
+ $cnum,$cdom).(' 'x2));
+ }
+ $r->print(&Apache::loncommon::noteswrapper('Add Records',$cnum,$cdom));
+ } else {
+ $r->print('\\\\\textbf{'.&mt('User Notes, Records of Face-To-Face Discussions, and Critical Messages in Course').'}\\\\'.&mt('Shared by course faculty and staff').'\\\\\\\\');
+ &Apache::lonmsgdisplay::disfacetoface($r,$cnum,$cdom);
+ }
+ }
+ }
+ if ($target ne 'tex') {
+ $r->print(&Apache::loncommon::end_page());
+ } else {
+ $r->print('\end{document}');
}
- $r->print('