version 1.100, 2004/02/10 22:15:53
|
version 1.104, 2004/02/27 14:59:19
|
Line 42 use Apache::lonlocal;
|
Line 42 use Apache::lonlocal;
|
############################################################### |
############################################################### |
############################################################### |
############################################################### |
sub header { |
sub header { |
my $bodytag=&Apache::loncommon::bodytag('Enrollment Manager'). |
my $bodytag=&Apache::loncommon::bodytag('Enrollment Manager'); |
&Apache::loncommon::help_open_faq(9). |
|
&Apache::loncommon::help_open_bug('Instructor Interface'); |
|
my $title = &mt('LON-CAPA Enrollment Manager'); |
my $title = &mt('LON-CAPA Enrollment Manager'); |
return(<<ENDHEAD); |
return(<<ENDHEAD); |
<html> |
<html> |
Line 1102 sub print_drop_menu {
|
Line 1100 sub print_drop_menu {
|
|
|
# ============================================== view classlist |
# ============================================== view classlist |
sub print_html_classlist { |
sub print_html_classlist { |
my $r=shift; |
my ($r,$mode) = @_; |
if (! exists($ENV{'form.sortby'})) { |
if (! exists($ENV{'form.sortby'})) { |
$ENV{'form.sortby'} = 'username'; |
$ENV{'form.sortby'} = 'username'; |
} |
} |
Line 1110 sub print_html_classlist {
|
Line 1108 sub print_html_classlist {
|
$ENV{'form.Status'} = 'Active'; |
$ENV{'form.Status'} = 'Active'; |
} |
} |
my $status_select = &Apache::lonhtmlcommon::StatusOptions |
my $status_select = &Apache::lonhtmlcommon::StatusOptions |
($ENV{'form.Status'},'studentform'); |
($ENV{'form.Status'}); |
my $cid=$ENV{'request.course.id'}; |
my $cid=$ENV{'request.course.id'}; |
my $cdom=$ENV{'course.'.$cid.'.domain'}; |
my $cdom=$ENV{'course.'.$cid.'.domain'}; |
my $cnum=$ENV{'course.'.$cid.'.num'}; |
my $cnum=$ENV{'course.'.$cid.'.num'}; |
# -------------------------------------------------------- Get course personnel |
# |
|
# List course personnel |
my %coursepersonnel=&Apache::lonnet::get_course_adv_roles($cdom.'/'.$cnum); |
my %coursepersonnel=&Apache::lonnet::get_course_adv_roles($cdom.'/'.$cnum); |
$r->print('<table border="2">'); |
$r->print('<br /><table border="2">'); |
foreach (sort keys %coursepersonnel) { |
foreach (sort keys %coursepersonnel) { |
$r->print('<tr><td>'.$_.'</td><td>'); |
$r->print('<tr><td>'.$_.'</td><td>'); |
foreach (split(/\,/,$coursepersonnel{$_})) { |
foreach (split(/\,/,$coursepersonnel{$_})) { |
Line 1128 sub print_html_classlist {
|
Line 1127 sub print_html_classlist {
|
$r->print('</td></tr>'); |
$r->print('</td></tr>'); |
} |
} |
$r->print('</table>'); |
$r->print('</table>'); |
# --------------------------------------------------------------- Student roles |
# |
|
# Interface output |
my $CCL=&mt('Current Class List'); |
my $CCL=&mt('Current Class List'); |
$r->print(<<END); |
$r->print('<input type="hidden" name="action" value="'. |
<input type="hidden" name="action" value="$ENV{'form.action'}" /> |
$ENV{'form.action'}.'" />'); |
<input type="hidden" name="state" value="" /> |
$r->print("<p>\n"); |
<p> |
|
<font size="+1">$CCL</font> |
|
|
|
END |
|
if ($ENV{'form.action'} ne 'modifystudent') { |
if ($ENV{'form.action'} ne 'modifystudent') { |
my %lt=&Apache::lonlocal::texthash( |
my %lt=&Apache::lonlocal::texthash('csv' => "CSV", |
'ef' => "Excel format", |
'excel' => "Excel", |
'ss' => "Student Status", |
'html' => 'HTML'); |
); |
$r->print('<font size="+1">'); |
$r->print(<<END); |
my $output_selector = '<select size="1" name="state" >'; |
<font size="+1"> |
if ($ENV{'form.state'} !~ /^(csv|excel|html)$/ ) { |
<a href="javascript:document.studentform.state.value='csv';document.studentform.submit();">CSV format</a> |
$ENV{'form.state'} = 'html'; |
|
} |
<a href="javascript:document.studentform.state.value='excel';document.studentform.submit();">$lt{'ef'}</a> |
foreach my $outputformat ('html','csv','excel') { |
</font> |
my $option = '<option value="'.$outputformat.'" '; |
|
if ($outputformat eq $ENV{'form.state'}) { |
$lt{'ss'}: |
$option .= 'selected '; |
END |
} |
|
$option .='>'.$lt{$outputformat}.'</option>'; |
|
$output_selector .= "\n".$option; |
|
} |
|
$output_selector .= '</select>'; |
|
$r->print(&mt('Output Format: [_1]',$output_selector).(' 'x3)); |
} |
} |
$r->print($status_select."</p>\n"); |
$r->print(&mt('Student Status: [_1]',$status_select)."\n"); |
|
$r->print('<input type="submit" value="'.&mt('Refresh Display').'" />'."\n</p>\n"); |
|
|
|
# |
|
# Print the classlist |
|
$r->print('<h2>'.&mt('Current Class List').'</h2>'); |
my ($classlist,$keylist)=&Apache::loncoursedata::get_classlist(); |
my ($classlist,$keylist)=&Apache::loncoursedata::get_classlist(); |
if (! defined($classlist)) { |
if (! defined($classlist)) { |
$r->print(&mt('There are no students currently enrolled.')."\n"); |
$r->print(&mt('There are no students currently enrolled.')."\n"); |
Line 1161 END
|
Line 1167 END
|
if ($ENV{'form.action'} eq 'modifystudent') { |
if ($ENV{'form.action'} eq 'modifystudent') { |
&show_class_list($r,'view','modify','modifystudent', |
&show_class_list($r,'view','modify','modifystudent', |
$ENV{'form.Status'},$classlist,$keylist); |
$ENV{'form.Status'},$classlist,$keylist); |
} else { |
} elsif (! defined($mode) || $mode eq '') { |
&show_class_list($r,'view','aboutme','classlist', |
&show_class_list($r,'view','aboutme','classlist', |
$ENV{'form.Status'},$classlist,$keylist); |
$ENV{'form.Status'},$classlist,$keylist); |
|
} elsif ($mode eq 'csv' || $mode eq 'excel') { |
|
&show_class_list($r,$mode,'nolink','csv', |
|
$ENV{'form.Status'},$classlist,$keylist); |
} |
} |
} |
} |
} |
} |
|
|
# ============================================== view classlist |
|
sub print_formatted_classlist { |
|
my $r=shift; |
|
my $mode = shift; |
|
my $cid=$ENV{'request.course.id'}; |
|
my ($classlist,$keylist)=&Apache::loncoursedata::get_classlist(); |
|
if (! defined($classlist)) { |
|
$r->print(&mt('There are no students currently enrolled.')."\n"); |
|
} else { |
|
&show_class_list($r,$mode,'nolink','csv', |
|
$ENV{'form.Status'},$classlist,$keylist); |
|
} |
|
} |
|
|
|
# =================================================== Show student list to drop |
# =================================================== Show student list to drop |
sub show_class_list { |
sub show_class_list { |
my ($r,$mode,$linkto,$action,$statusmode,$classlist,$keylist)=@_; |
my ($r,$mode,$linkto,$action,$statusmode,$classlist,$keylist)=@_; |
my $cid=$ENV{'request.course.id'}; |
my $cid=$ENV{'request.course.id'}; |
# |
# |
# Variables for excel output |
# Variables for excel output |
my ($excel_workbook, $excel_sheet, $excel_filename,$row); |
my ($excel_workbook, $excel_sheet, $excel_filename,$row,$format); |
|
# |
|
# Variables for csv output |
|
my ($CSVfile,$CSVfilename); |
# |
# |
my $sortby = $ENV{'form.sortby'}; |
my $sortby = $ENV{'form.sortby'}; |
if ($sortby !~ /^(username|domain|section|fullname|id)$/) { |
if ($sortby !~ /^(username|domain|section|fullname|id)$/) { |
$sortby = 'username'; |
$sortby = 'username'; |
} |
} |
# Print out header |
# Print out header |
|
$r->print(<<END); |
|
<input type="hidden" name="sortby" value="$sortby" /> |
|
<input type="hidden" name="sname" value="" /> |
|
<input type="hidden" name="sdom" value="" /> |
|
END |
if ($mode eq 'view') { |
if ($mode eq 'view') { |
if ($linkto eq 'aboutme') { |
if ($linkto eq 'aboutme') { |
$r->print(&mt('Select a user name to view the users personal page.')); |
$r->print(&mt('Select a user name to view the users personal page.')); |
Line 1228 sub show_class_list {
|
Line 1231 sub show_class_list {
|
</tr> |
</tr> |
END |
END |
} elsif ($mode eq 'csv') { |
} elsif ($mode eq 'csv') { |
|
# |
|
# Open a file |
|
$CSVfilename = '/prtspool/'. |
|
$ENV{'user.name'}.'_'.$ENV{'user.domain'}.'_'. |
|
time.'_'.rand(1000000000).'.csv'; |
|
unless ($CSVfile = Apache::File->new('>/home/httpd'.$CSVfilename)) { |
|
$r->log_error("Couldn't open $CSVfilename for output $!"); |
|
$r->print("Problems occured in writing the csv file. ". |
|
"This error has been logged. ". |
|
"Please alert your LON-CAPA administrator."); |
|
$CSVfile = undef; |
|
} |
|
# |
|
# Write headers and data to file |
if($statusmode eq 'Expired') { |
if($statusmode eq 'Expired') { |
$r->print(&mt('Students with expired roles')); |
print $CSVfile '"'.&mt('Students with expired roles').'"'."\n"; |
} |
} |
if ($statusmode eq 'Any') { |
if ($statusmode eq 'Any') { |
$r->print('"'.join('","',(&mt("username"),&mt("domain"),"ID", |
print $CSVfile '"'.join('","',map { |
&mt("student name"),&mt("section"),&mt("status"))). |
&Apache::loncommon::csv_translate(&mt($_)) |
'"'."\n"); |
} ("username","domain","ID","student name", |
|
"section","status")).'"'."\n"; |
} else { |
} else { |
$r->print('"'.join('","',(&mt("username"),&mt("domain"),"ID", |
print $CSVfile '"'.join('","',map { |
&mt("student name"),&mt("section"))).'"'."\n"); |
&Apache::loncommon::csv_translate(&mt($_)) |
|
} ("username","domain","ID","student name", |
|
"section")).'"'."\n"; |
} |
} |
} elsif ($mode eq 'excel') { |
} elsif ($mode eq 'excel') { |
# Create the excel spreadsheet |
# Create the excel spreadsheet |
Line 1247 END
|
Line 1267 END
|
$excel_workbook = Spreadsheet::WriteExcel->new('/home/httpd'. |
$excel_workbook = Spreadsheet::WriteExcel->new('/home/httpd'. |
$excel_filename); |
$excel_filename); |
$excel_workbook->set_tempdir('/home/httpd/perl/tmp'); |
$excel_workbook->set_tempdir('/home/httpd/perl/tmp'); |
|
# |
|
$format = &Apache::loncommon::define_excel_formats($excel_workbook); |
$excel_sheet = $excel_workbook->addworksheet('classlist'); |
$excel_sheet = $excel_workbook->addworksheet('classlist'); |
# |
# |
my $description = 'Class List for '. |
my $description = 'Class List for '. |
$ENV{'course.'.$ENV{'request.course.id'}.'.description'}; |
$ENV{'course.'.$ENV{'request.course.id'}.'.description'}; |
$excel_sheet->write($row++,0,$description); |
$excel_sheet->write($row++,0,$description,$format->{'h1'}); |
# |
# |
$excel_sheet->write($row++,0,["username","domain","ID", |
$excel_sheet->write($row++,0,["username","domain","ID", |
"student name","section","status"]); |
"student name","section","status"],$format->{'bold'}); |
} |
} |
# |
# |
# Sort the students |
# Sort the students |
Line 1307 END
|
Line 1329 END
|
</tr> |
</tr> |
END |
END |
} elsif ($mode eq 'csv') { |
} elsif ($mode eq 'csv') { |
|
next if (! defined($CSVfile)); |
# no need to bother with $linkto |
# no need to bother with $linkto |
my @line = (); |
my @line = (); |
foreach ($username,$domain,$id,$name,$section) { |
foreach ($username,$domain,$id,$name,$section) { |
Line 1315 END
|
Line 1338 END
|
if ($statusmode eq 'Any') { |
if ($statusmode eq 'Any') { |
push @line,&Apache::loncommon::csv_translate($status); |
push @line,&Apache::loncommon::csv_translate($status); |
} |
} |
my $tmp = $"; |
print $CSVfile '"'.join('","',@line).'"'."\n"; |
$" = '","'; |
|
$r->print("\"@line\"\n"); |
|
$" = $tmp; |
|
} elsif ($mode eq 'excel') { |
} elsif ($mode eq 'excel') { |
$excel_sheet->write($row++,0,[$username,$domain,$id, |
$excel_sheet->write($row++,0,[$username,$domain,$id, |
$name,$section,$status]); |
$name,$section,$status]); |
Line 1330 END
|
Line 1350 END
|
$excel_workbook->close(); |
$excel_workbook->close(); |
$r->print('<p><a href="'.$excel_filename.'">'. |
$r->print('<p><a href="'.$excel_filename.'">'. |
&mt('Your Excel spreadsheet').'</a> '.&mt('is ready for download').'.</p>'."\n"); |
&mt('Your Excel spreadsheet').'</a> '.&mt('is ready for download').'.</p>'."\n"); |
|
} elsif ($mode eq 'csv') { |
|
close($CSVfile); |
|
$r->print('<a href="'.$CSVfilename.'">'. |
|
&mt('Your CSV file').'</a> is ready for download.'. |
|
"\n"); |
|
$r->rflush(); |
} |
} |
} |
} |
|
|
Line 1365 sub print_modify_student_form {
|
Line 1391 sub print_modify_student_form {
|
$r->print('<p>'.$starttime.'</p>'); |
$r->print('<p>'.$starttime.'</p>'); |
return; |
return; |
} |
} |
|
# |
# Deal with date forms |
# Deal with date forms |
|
my $current_date_description = ''; |
|
my $textdate = ''; |
|
|
|
if (! defined($starttime) || $starttime == 0) { |
|
$current_date_description = &mt('Current Starting Date: not set'). |
|
'<br />'; |
|
} else { |
|
$current_date_description = |
|
&mt('Current Starting Date: [_1]', |
|
&Apache::lonlocal::locallocaltime($starttime)).'<br />'; |
|
} |
|
if (! defined($endtime) || $endtime == 0) { |
|
$current_date_description.= &mt('Current Ending Date: not set'). |
|
'<br />'; |
|
} else { |
|
$current_date_description.= |
|
&mt('Current Ending Date: [_1]', |
|
&Apache::lonlocal::locallocaltime($endtime)).'<br />'; |
|
|
|
} |
my $date_table = &date_setting_table($starttime,$endtime); |
my $date_table = &date_setting_table($starttime,$endtime); |
# |
# |
if (! exists($ENV{'form.Status'}) || |
if (! exists($ENV{'form.Status'}) || |
Line 1398 $lt{'odcc'}
|
Line 1445 $lt{'odcc'}
|
<input type="hidden" name="state" value="done" /> |
<input type="hidden" name="state" value="done" /> |
<input type="hidden" name="sortby" value="$sortby" /> |
<input type="hidden" name="sortby" value="$sortby" /> |
<input type="hidden" name="Status" value="$ENV{'form.Status'}" /> |
<input type="hidden" name="Status" value="$ENV{'form.Status'}" /> |
|
|
<h2>$lt{'mef'} $info{'firstname'} $info{'middlename'} |
<h2>$lt{'mef'} $info{'firstname'} $info{'middlename'} |
$info{'lastname'} $info{'generation'}, $sname\@$sdom</h2> |
$info{'lastname'} $info{'generation'}, $sname\@$sdom</h2> |
<p> |
<p> |
Line 1417 $info{'lastname'} $info{'generation'}, $
|
Line 1463 $info{'lastname'} $info{'generation'}, $
|
<input type="checkbox" name="forceid" > |
<input type="checkbox" name="forceid" > |
$lt{'disn'} |
$lt{'disn'} |
</p><p> |
</p><p> |
<b>$lt{'sec'}</b>: <input type="text" name="section" value="$section" size="4"/> |
<b>$lt{'sec'}</b>: <input type="text" name="section" value="$section" size="14"/> |
</p> |
</p> |
|
<p>$current_date_description</p> |
<p>$date_table</p> |
<p>$date_table</p> |
<input type="submit" value="$lt{'sm'}" /> |
<input type="submit" value="$lt{'sm'}" /> |
</body></html> |
</body></html> |
Line 2083 sub handler {
|
Line 2130 sub handler {
|
} |
} |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
['action','state']); |
['action','state']); |
|
|
|
&Apache::lonhtmlcommon::clear_breadcrumbs(); |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>"/adm/dropadd", |
|
text=>"Enrollment Manager", |
|
faq=>9,bug=>'Instructor Interface',}); |
# Needs to be in a course |
# Needs to be in a course |
if (! (($ENV{'request.course.fn'}) && |
if (! (($ENV{'request.course.fn'}) && |
(&Apache::lonnet::allowed('cst',$ENV{'request.course.id'})))) { |
(&Apache::lonnet::allowed('cst',$ENV{'request.course.id'})))) { |
Line 2094 sub handler {
|
Line 2147 sub handler {
|
# |
# |
# Only output the header information if they did not request csv format |
# Only output the header information if they did not request csv format |
# |
# |
if (exists($ENV{'form.state'}) && ($ENV{'form.state'} eq 'csv')) { |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
$r->content_type('text/csv'); |
['state','action']); |
} else { |
# Start page |
# Start page |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
$r->print(&header()); |
$r->print(&header()); |
|
} |
|
# |
# |
# Main switch on form.action and form.state, as appropriate |
# Main switch on form.action and form.state, as appropriate |
if (! exists($ENV{'form.action'})) { |
if (! exists($ENV{'form.action'})) { |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs |
|
(undef,'Enrollment Manager')); |
&print_main_menu($r); |
&print_main_menu($r); |
} elsif ($ENV{'form.action'} eq 'upload') { |
} elsif ($ENV{'form.action'} eq 'upload') { |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>'/adm/dropadd?action=upload&state=', |
|
text=>"Upload Classlist", |
|
faq=>9,bug=>'Instructor Interface',}); |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs |
|
(undef,'Upload Classlist')); |
if (! exists($ENV{'form.state'})) { |
if (! exists($ENV{'form.state'})) { |
&print_first_courselist_upload_form($r); |
&print_first_courselist_upload_form($r); |
} elsif ($ENV{'form.state'} eq 'got_file') { |
} elsif ($ENV{'form.state'} eq 'got_file') { |
Line 2121 sub handler {
|
Line 2180 sub handler {
|
&print_first_courselist_upload_form($r); |
&print_first_courselist_upload_form($r); |
} |
} |
} elsif ($ENV{'form.action'} eq 'drop') { |
} elsif ($ENV{'form.action'} eq 'drop') { |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>'/adm/dropadd?action=drop', |
|
text=>"Drop Students", |
|
faq=>9,bug=>'Instructor Interface',}); |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs |
|
(undef,'Drop Students')); |
if (! exists($ENV{'form.state'})) { |
if (! exists($ENV{'form.state'})) { |
&print_drop_menu($r); |
&print_drop_menu($r); |
} elsif ($ENV{'form.state'} eq 'done') { |
} elsif ($ENV{'form.state'} eq 'done') { |
Line 2129 sub handler {
|
Line 2194 sub handler {
|
&print_drop_menu($r); |
&print_drop_menu($r); |
} |
} |
} elsif ($ENV{'form.action'} eq 'enrollstudent') { |
} elsif ($ENV{'form.action'} eq 'enrollstudent') { |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>'/adm/dropadd?action=enrollstudent', |
|
text=>"Enroll Student", |
|
faq=>9,bug=>'Instructor Interface',}); |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs |
|
(undef,'Enroll Student')); |
if (! exists($ENV{'form.state'})) { |
if (! exists($ENV{'form.state'})) { |
&get_student_username_domain_form($r); |
&get_student_username_domain_form($r); |
} elsif ($ENV{'form.state'} eq 'gotusername') { |
} elsif ($ENV{'form.state'} eq 'gotusername') { |
Line 2139 sub handler {
|
Line 2210 sub handler {
|
&get_student_username_domain_form($r); |
&get_student_username_domain_form($r); |
} |
} |
} elsif ($ENV{'form.action'} eq 'classlist') { |
} elsif ($ENV{'form.action'} eq 'classlist') { |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>'/adm/dropadd?action=classlist', |
|
text=>"View Classlist", |
|
faq=>9,bug=>'Instructor Interface',}); |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs |
|
(undef,'View Classlist')); |
if (! exists($ENV{'form.state'})) { |
if (! exists($ENV{'form.state'})) { |
&print_html_classlist($r); |
&print_html_classlist($r,undef); |
} elsif ($ENV{'form.state'} eq 'csv') { |
} elsif ($ENV{'form.state'} eq 'csv') { |
&print_formatted_classlist($r,'csv'); |
&print_html_classlist($r,'csv'); |
} elsif ($ENV{'form.state'} eq 'excel') { |
} elsif ($ENV{'form.state'} eq 'excel') { |
&print_formatted_classlist($r,'excel'); |
&print_html_classlist($r,'excel'); |
} else { |
} else { |
&print_html_classlist($r); |
&print_html_classlist($r,undef); |
} |
} |
} elsif ($ENV{'form.action'} eq 'modifystudent') { |
} elsif ($ENV{'form.action'} eq 'modifystudent') { |
|
&Apache::lonhtmlcommon::add_breadcrumb |
|
({href=>'/adm/dropadd?action=modifystudent', |
|
text=>"Modify Student Data", |
|
faq=>9,bug=>'Instructor Interface',}); |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs |
|
(undef,'Modify Student Data')); |
if (! exists($ENV{'form.state'})) { |
if (! exists($ENV{'form.state'})) { |
&print_html_classlist($r); |
&print_html_classlist($r); |
} elsif ($ENV{'form.state'} eq 'selected') { |
} elsif ($ENV{'form.state'} eq 'selected') { |
Line 2163 sub handler {
|
Line 2246 sub handler {
|
&Apache::lonnet::logthis("Undetermined state in londropadd.pm. ". |
&Apache::lonnet::logthis("Undetermined state in londropadd.pm. ". |
"form.action = ".$ENV{'form.action'}. |
"form.action = ".$ENV{'form.action'}. |
"Someone should fix this."); |
"Someone should fix this."); |
|
$r->print(&Apache::lonhtmlcommon::breadcrumbs |
|
(undef,'Enrollment Manager')); |
&print_main_menu($r); |
&print_main_menu($r); |
} |
} |
# |
# |
# Finish up |
# Finish up |
if (exists($ENV{'form.state'}) && ($ENV{'form.state'} eq 'csv')) { |
$r->print('</form></body></html>'); |
$r->print("\n"); |
|
} else { |
|
$r->print('</form></body></html>'); |
|
} |
|
return OK; |
return OK; |
} |
} |
|
|