version 1.48, 2001/03/20 21:34:34
|
version 1.55, 2001/07/20 02:05:33
|
Line 5
|
Line 5
|
# 12/08,12/09,12/11,12/12,12/15,12/16,12/18,12/19,12/30, |
# 12/08,12/09,12/11,12/12,12/15,12/16,12/18,12/19,12/30, |
# 01/01/01,02/01,03/01,19/01,20/01,22/01, |
# 01/01/01,02/01,03/01,19/01,20/01,22/01, |
# 03/05,03/08,03/10,03/12,03/13,03/15,03/17, |
# 03/05,03/08,03/10,03/12,03/13,03/15,03/17, |
# 03/19,03/20 Gerd Kortemeyer |
# 03/19,03/20,03/21,03/27,04/05,04/09, |
|
# 07/09,07/14 Gerd Kortemeyer |
|
|
package Apache::lonspreadsheet; |
package Apache::lonspreadsheet; |
|
|
Line 77 sub initsheet {
|
Line 78 sub initsheet {
|
# v: output values |
# v: output values |
# c: preloaded constants (A-column) |
# c: preloaded constants (A-column) |
# rl: row label |
# rl: row label |
|
# os: other spreadsheets (for student spreadsheet only) |
|
|
undef %v; |
undef %v; |
undef %t; |
undef %t; |
undef %f; |
undef %f; |
undef %c; |
undef %c; |
undef %rl; |
undef %rl; |
|
undef @os; |
|
|
|
undef $nfield; |
|
undef $nsheet; |
|
|
$maxrow=0; |
$maxrow=0; |
$sheettype=''; |
$sheettype=''; |
Line 397 sub outrowassess {
|
Line 403 sub outrowassess {
|
my $n=shift; |
my $n=shift; |
my @cols=(); |
my @cols=(); |
if ($n) { |
if ($n) { |
$cols[0]=$rl{$f{'A'.$n}}; |
my ($usy,$ufn)=split(/\_\_\&\&\&\_\_/,$f{'A'.$n}); |
|
$cols[0]=$rl{$f{'A'.$n}}.'<br>'. |
|
'<select name="sel_'.$n.'" onChange="changesheet('.$n. |
|
')"><option name="default">Default</option>'; |
|
map { |
|
$cols[0].='<option name="'.$_.'"'; |
|
if ($ufn eq $_) { |
|
$cols[0].=' selected'; |
|
} |
|
$cols[0].='>'.$_.'</option>'; |
|
} @os; |
|
$cols[0].='</select>'; |
} else { |
} else { |
$cols[0]='<b><font size=+1>Export</font></b>'; |
$cols[0]='<b><font size=+1>Export</font></b>'; |
} |
} |
Line 460 sub setconstants {
|
Line 477 sub setconstants {
|
%{$safeeval->varglob('c')}=%c; |
%{$safeeval->varglob('c')}=%c; |
} |
} |
|
|
|
# --------------------------------------------- Set names of other spreadsheets |
|
|
|
sub setothersheets { |
|
my ($safeeval,@os)=@_; |
|
@{$safeeval->varglob('os')}=@os; |
|
} |
|
|
# ------------------------------------------------ Add or change formula values |
# ------------------------------------------------ Add or change formula values |
|
|
sub setrowlabels { |
sub setrowlabels { |
Line 508 sub getmaxrow {
|
Line 532 sub getmaxrow {
|
my $safeeval=shift; |
my $safeeval=shift; |
return $safeeval->reval('$maxrow'); |
return $safeeval->reval('$maxrow'); |
} |
} |
|
# -------------------------------------------- Store which sheet needs changing |
|
|
|
sub changesheet { |
|
my ($safeeval,$nfield,$nsheet)=@_; |
|
$safeeval->reval('$nfield='.$nfield.'; $nsheet='.$nsheet.';'); |
|
} |
|
|
# ---------------------------------------------------------------- Set filename |
# ---------------------------------------------------------------- Set filename |
|
|
Line 600 sub exportdata {
|
Line 630 sub exportdata {
|
return $safeeval->reval('&exportrowa()'); |
return $safeeval->reval('&exportrowa()'); |
} |
} |
|
|
|
|
# ========================================================== End of Spreadsheet |
# ========================================================== End of Spreadsheet |
# ============================================================================= |
# ============================================================================= |
|
|
Line 638 sub rown {
|
Line 669 sub rown {
|
my $showf=0; |
my $showf=0; |
my $proc; |
my $proc; |
my $maxred; |
my $maxred; |
if (&gettype($safeeval) eq 'assesscalc') { |
if (&gettype($safeeval) eq 'studentcalc') { |
$proc='&outrowassess'; |
$proc='&outrowassess'; |
$maxred=1; |
$maxred=26; |
} else { |
} else { |
$proc='&outrow'; |
$proc='&outrow'; |
|
} |
|
if (&gettype($safeeval) eq 'assesscalc') { |
|
$maxred=1; |
|
} else { |
$maxred=26; |
$maxred=26; |
} |
} |
if ($n eq '-') { $proc='&templaterow'; $n=-1; } |
if ($n eq '-') { $proc='&templaterow'; $n=-1; } |
Line 716 sub outsheet {
|
Line 751 sub outsheet {
|
} |
} |
|
|
# |
# |
|
# ----------------------------------------------- Read list of available sheets |
|
# |
|
|
|
sub othersheets { |
|
my ($safeeval,$stype)=@_; |
|
|
|
my $cnum=&getcnum($safeeval); |
|
my $cdom=&getcdom($safeeval); |
|
my $chome=&getchome($safeeval); |
|
|
|
my @alternatives=(); |
|
my $result=&Apache::lonnet::reply('dump:'.$cdom.':'.$cnum.':'. |
|
$stype.'_spreadsheets',$chome); |
|
if ($result!~/^error\:/) { |
|
map { |
|
$alternatives[$#alternatives+1]= |
|
&Apache::lonnet::unescape((split(/\=/,$_))[0]); |
|
} split(/\&/,$result); |
|
} |
|
return @alternatives; |
|
} |
|
|
|
# |
# -------------------------------------- Read spreadsheet formulas for a course |
# -------------------------------------- Read spreadsheet formulas for a course |
# |
# |
|
|
Line 844 sub writesheet {
|
Line 902 sub writesheet {
|
if ($reply eq 'ok') { |
if ($reply eq 'ok') { |
$reply=&Apache::lonnet::reply('put:'.$cdom.':'.$cnum.':'. |
$reply=&Apache::lonnet::reply('put:'.$cdom.':'.$cnum.':'. |
$stype.'_spreadsheets:'. |
$stype.'_spreadsheets:'. |
&Apache::lonnet::escape($fn).'='.$ENV{'user.name'}, |
&Apache::lonnet::escape($fn).'='.$ENV{'user.name'}.'@'. |
|
$ENV{'user.domain'}, |
$chome); |
$chome); |
if ($reply eq 'ok') { |
if ($reply eq 'ok') { |
if ($makedef) { |
if ($makedef) { |
Line 902 sub tmpread {
|
Line 961 sub tmpread {
|
$fo{$name}=$value; |
$fo{$name}=$value; |
} |
} |
} |
} |
if ($nfield) { $fo{$nfield}=$nform; } |
if ($nform eq 'changesheet') { |
|
unless ($ENV{'form.sel_'.$nfield} eq 'Default') { |
|
&changesheet($safeeval,$nfield,$ENV{'form.sel_'.$nfield}); |
|
} |
|
} else { |
|
if ($nfield) { $fo{$nfield}=$nform; } |
|
} |
&setformulas($safeeval,%fo); |
&setformulas($safeeval,%fo); |
} |
} |
|
|
Line 1093 sub updatestudentassesssheet {
|
Line 1158 sub updatestudentassesssheet {
|
&GDBM_READER,0640)) { |
&GDBM_READER,0640)) { |
# --------------------------------------------------------- Get all assessments |
# --------------------------------------------------------- Get all assessments |
|
|
my %allkeys=(); |
my %allkeys=('timestamp' => |
|
'Timestamp of Last Transaction<br>timestamp'); |
my %allassess=(); |
my %allassess=(); |
|
|
|
my $adduserstr=''; |
|
if ((&getuname($safeeval) ne $ENV{'user.name'}) || |
|
(&getudom($safeeval) ne $ENV{'user.domain'})) { |
|
$adduserstr='&uname='.&getuname($safeeval). |
|
'&udom='.&getudom($safeeval); |
|
} |
|
|
map { |
map { |
if ($_=~/^src\_(\d+)\.(\d+)$/) { |
if ($_=~/^src\_(\d+)\.(\d+)$/) { |
my $mapid=$1; |
my $mapid=$1; |
Line 1108 sub updatestudentassesssheet {
|
Line 1181 sub updatestudentassesssheet {
|
'___'.$resid.'___'. |
'___'.$resid.'___'. |
&Apache::lonnet::declutter($srcf); |
&Apache::lonnet::declutter($srcf); |
$allassess{$symb}= |
$allassess{$symb}= |
'<a href="/adm/assesscalc?usymb='.$symb.'">'.$bighash{'title_'.$id}.'</a>'; |
'<a href="/adm/assesscalc?usymb='.$symb.$adduserstr.'">'. |
|
$bighash{'title_'.$id}.'</a>'; |
if ($stype eq 'assesscalc') { |
if ($stype eq 'assesscalc') { |
map { |
map { |
if (($_=~/^stores\_(.*)/) || ($_=~/^parameter\_(.*)/)) { |
if (($_=~/^stores\_(.*)/) || ($_=~/^parameter\_(.*)/)) { |
Line 1214 sub loadstudent {
|
Line 1288 sub loadstudent {
|
if ($_=~/^A(\d+)/) { |
if ($_=~/^A(\d+)/) { |
my $row=$1; |
my $row=$1; |
unless (($f{$_}=~/^\!/) || ($row==0)) { |
unless (($f{$_}=~/^\!/) || ($row==0)) { |
|
my ($usy,$ufn)=split(/\_\_\&\&\&\_\_/,$f{$_}); |
@assessdata=&exportsheet(&getuname($safeeval), |
@assessdata=&exportsheet(&getuname($safeeval), |
&getudom($safeeval), |
&getudom($safeeval), |
'assesscalc',$f{$_}); |
'assesscalc',$usy,$ufn); |
my $index=0; |
my $index=0; |
map { |
map { |
if ($assessdata[$index]) { |
if ($assessdata[$index]) { |
Line 1260 sub loadcourse {
|
Line 1335 sub loadcourse {
|
<script> |
<script> |
popwin=open('','popwin','width=400,height=100'); |
popwin=open('','popwin','width=400,height=100'); |
popwin.document.writeln('<html><body bgcolor="#FFFFFF">'+ |
popwin.document.writeln('<html><body bgcolor="#FFFFFF">'+ |
'<h1>Spreadsheet Calculation Progress</h1>'+ |
'<h3>Spreadsheet Calculation Progress</h3>'+ |
'<form name=popremain>'+ |
'<form name=popremain>'+ |
'<input type=text size=35 name=remaining value=Starting></form>'+ |
'<input type=text size=35 name=remaining value=Starting></form>'+ |
'</body></html>'); |
'</body></html>'); |
Line 1498 sub forcedrecalc {
|
Line 1573 sub forcedrecalc {
|
my ($uname,$udom,$stype,$usymb)=@_; |
my ($uname,$udom,$stype,$usymb)=@_; |
my $key=$uname.':'.$udom.':'.$stype.':'.$usymb; |
my $key=$uname.':'.$udom.':'.$stype.':'.$usymb; |
my $time=$oldsheets{$key.'.time'}; |
my $time=$oldsheets{$key.'.time'}; |
|
if ($ENV{'form.forcerecalc'}) { return 1; } |
unless ($time) { return 1; } |
unless ($time) { return 1; } |
if ($stype eq 'assesscalc') { |
if ($stype eq 'assesscalc') { |
my $map=(split(/\_\_\_/,$usymb))[0]; |
my $map=(split(/\_\_\_/,$usymb))[0]; |
if (&checkthis('::assesscalc:',$time) || |
if (&checkthis('::assesscalc:',$time) || |
&checkthis('::assesscalc:'.$map,$time) || |
&checkthis('::assesscalc:'.$map,$time) || |
&checkthis('::assesscalc:'.$usymb,$time) || |
&checkthis('::assesscalc:'.$usymb,$time) || |
&checkthis($uname.':'.$udom.':assesscalc:',$time)) { |
&checkthis($uname.':'.$udom.':assesscalc:',$time) || |
|
&checkthis($uname.':'.$udom.':assesscalc:'.$map,$time) || |
|
&checkthis($uname.':'.$udom.':assesscalc:'.$usymb,$time)) { |
return 1; |
return 1; |
} |
} |
} else { |
} else { |
if (&checkthis('::studentcalc:',$time) || |
if (&checkthis('::studentcalc:',$time) || |
&checkthis($uname.':'.$udom.':studencalc:',$time)) { |
&checkthis($uname.':'.$udom.':studentcalc:',$time)) { |
return 1; |
return 1; |
} |
} |
} |
} |
Line 1748 $tmpdir=$r->dir_config('lonDaemons').'/t
|
Line 1826 $tmpdir=$r->dir_config('lonDaemons').'/t
|
} |
} |
} (split(/&/,$ENV{'QUERY_STRING'})); |
} (split(/&/,$ENV{'QUERY_STRING'})); |
|
|
|
# -------------------------------------- Interactive loading of specific sheet? |
|
if (($ENV{'form.load'}) && ($ENV{'form.loadthissheet'} ne 'Default')) { |
|
$ENV{'form.ufn'}=$ENV{'form.loadthissheet'}; |
|
} |
# ------------------------------------------- Nothing there? Must be login user |
# ------------------------------------------- Nothing there? Must be login user |
|
|
my $aname; |
my $aname; |
Line 1783 $tmpdir=$r->dir_config('lonDaemons').'/t
|
Line 1865 $tmpdir=$r->dir_config('lonDaemons').'/t
|
} |
} |
} |
} |
|
|
|
function changesheet(cn) { |
|
document.sheet.unewfield.value=cn; |
|
document.sheet.unewformula.value='changesheet'; |
|
document.sheet.submit(); |
|
} |
|
|
</script> |
</script> |
ENDSCRIPT |
ENDSCRIPT |
$r->print('</head><body bgcolor="#FFFFFF">'. |
$r->print('</head><body bgcolor="#FFFFFF">'. |
Line 1799 ENDSCRIPT
|
Line 1887 ENDSCRIPT
|
|
|
$r->rflush(); |
$r->rflush(); |
|
|
|
# ---------------------------------------------------------------- Full recalc? |
|
|
|
|
|
if ($ENV{'form.forcerecalc'}) { |
|
$r->print('<h4>Completely Recalculating Sheet ...</h4>'); |
|
undef %spreadsheets; |
|
undef %courserdatas; |
|
undef %userrdatas; |
|
undef %defaultsheets; |
|
undef %updatedata; |
|
} |
|
|
# ---------------------------------------- Read new sheet or modified worksheet |
# ---------------------------------------- Read new sheet or modified worksheet |
|
|
$r->uri=~/\/(\w+)$/; |
$r->uri=~/\/(\w+)$/; |
Line 1841 ENDSCRIPT
|
Line 1941 ENDSCRIPT
|
$r->print('<h1>'. |
$r->print('<h1>'. |
$ENV{'course.'.$ENV{'request.course.id'}.'.description'}.'</h1>'); |
$ENV{'course.'.$ENV{'request.course.id'}.'.description'}.'</h1>'); |
|
|
|
# ---------------------------------------------------- See if user can see this |
|
|
|
if ((&gettype($asheet) eq 'classcalc') || |
|
(&getuname($asheet) ne $ENV{'user.name'}) || |
|
(&getudom($asheet) ne $ENV{'user.domain'})) { |
|
unless (&Apache::lonnet::allowed('vgr',&getcid($asheet))) { |
|
$r->print( |
|
'<h1>Access Permission Denied</h1></form></body></html>'); |
|
return OK; |
|
} |
|
} |
|
|
# ---------------------------------------------------- See if something to save |
# ---------------------------------------------------- See if something to save |
|
|
Line 1863 ENDSCRIPT
|
Line 1974 ENDSCRIPT
|
|
|
&tmpwrite($asheet); |
&tmpwrite($asheet); |
|
|
|
# ---------------------------------------------------------- Additional options |
|
|
|
$r->print( |
|
'<input type=submit name=forcerecalc value="Completely Recalculate Sheet"><p>' |
|
); |
|
if (&gettype($asheet) eq 'assesscalc') { |
|
$r->print ('<p><font size=+2><a href="/adm/studentcalc?uname='. |
|
&getuname($asheet). |
|
'&udom='.&getudom($asheet). |
|
'">Level up: Student Sheet</a></font><p>'); |
|
} |
|
|
|
if ((&gettype($asheet) eq 'studentcalc') && |
|
(&Apache::lonnet::allowed('vgr',&getcid($asheet)))) { |
|
$r->print ( |
|
'<p><font size=+2><a href="/adm/classcalc">'. |
|
'Level up: Course Sheet</a></font><p>'); |
|
} |
|
|
|
|
# ----------------------------------------------------------------- Save dialog |
# ----------------------------------------------------------------- Save dialog |
|
|
|
|
Line 1877 ENDSCRIPT
|
Line 2008 ENDSCRIPT
|
|
|
$r->print(&hiddenfield('ufn',&getfilename($asheet))); |
$r->print(&hiddenfield('ufn',&getfilename($asheet))); |
|
|
|
# ----------------------------------------------------------------- Load dialog |
|
if (&Apache::lonnet::allowed('opa',$ENV{'request.course.id'})) { |
|
$r->print('<p><input type=submit name=load value="Load ...">'. |
|
'<select name="loadthissheet">'. |
|
'<option name="default">Default</option>'); |
|
map { |
|
$r->print('<option name="'.$_.'"'); |
|
if ($ENV{'form.ufn'} eq $_) { |
|
$r->print(' selected'); |
|
} |
|
$r->print('>'.$_.'</option>'); |
|
} &othersheets($asheet,&gettype($asheet)); |
|
$r->print('</select><p>'); |
|
if (&gettype($asheet) eq 'studentcalc') { |
|
&setothersheets($asheet,&othersheets($asheet,'assesscalc')); |
|
} |
|
} |
|
|
# --------------------------------------------------------------- Cached sheets |
# --------------------------------------------------------------- Cached sheets |
|
|
&expirationdates(); |
&expirationdates(); |