File:  [LON-CAPA] / loncom / homework / outputtags.pm
Revision 1.40: download - view: text, annotated - select for diffs
Wed Nov 2 20:31:55 2005 UTC (18 years, 6 months ago) by albertel
Branches: MAIN
CVS tags: HEAD
- need lonlocal

    1: # The LearningOnline Network with CAPA 
    2: # tags that create controlled output
    3: #
    4: # $Id: outputtags.pm,v 1.40 2005/11/02 20:31:55 albertel Exp $
    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: 
   29: package Apache::outputtags; 
   30: 
   31: use strict;
   32: use Apache::lonlocal;
   33: use Apache::lonnet;
   34: use POSIX qw(strftime);
   35: 
   36: BEGIN {
   37:     &Apache::lonxml::register('Apache::outputtags',('displayduedate','displaytitle','displayweight','displaystudentphoto'));
   38: }
   39: 
   40: sub initialize_outputtags {
   41:     %Apache::outputtags::showonce=();
   42: }
   43: 
   44: 
   45: sub start_displayduedate {
   46:     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
   47:     my $result;
   48: 
   49:     # Different parts can have different due dates... so we keep a list
   50:     # of the parts for which we've displayed the duedate:
   51: 
   52:     if (exists($Apache::outputtags::showonce{'displayduedate'})) {
   53: 	if (grep(/^\Q$Apache::inputtags::part\E$/,
   54: 		 @{$Apache::outputtags::showonce{'displayduedate'}})) {
   55: 	    return '';
   56: 	}
   57:     }
   58:     push (@{$Apache::outputtags::showonce{'displayduedate'}},
   59: 	  $Apache::inputtags::part);
   60: 
   61:     my $status=$Apache::inputtags::status['-1'];
   62:     &Apache::lonxml::debug("got a $status in duedatebox");
   63:     my $style = &Apache::lonxml::get_param('style',$parstack,$safeeval);
   64:     if (($status =~ /CAN.*_ANSWER/) && ($target eq 'web')) {
   65: 	my $id = $Apache::inputtags::part;
   66: 	my $date = &Apache::lonnet::EXT("resource.$id.duedate");
   67: 	&Apache::lonxml::debug("duedatebox found $date for $id");
   68: 
   69: 	# Only show the due date if the current date is 
   70: 	# different from due date of the previous part.  I think
   71: 	# this is probably the best way to avoid due date clutter.
   72: 
   73:        	my $showduedate = 1;
   74: 	my $part_count  = scalar(@{$Apache::outputtags::showonce{'displayduedate'}});
   75: 	if ($part_count > 1) {
   76: 	    my $prev_part_id = $Apache::outputtags::showonce{'displayduedate'}->[$part_count-2];
   77: 	    my $prev_due_date = &Apache::lonnet::EXT("resource.$prev_part_id.duedate");
   78: 	    if ($prev_due_date == $date) {
   79: 		$showduedate = 0;
   80: 	    }
   81: 	}
   82: 
   83: 	if ($showduedate) {
   84: 	    if (lc($style) !~ 'plain') { 
   85: 		$result ='<table border="on"><tr><td>Due '.
   86: 		    &Apache::lonnavmaps::timeToHumanString($date).
   87: 		    '</td></tr></table>';
   88: 	    } else {
   89: 		$result=&mt('Due').' '.&Apache::lonnavmaps::timeToHumanString($date);
   90: 	    }
   91: 	}
   92:     } elsif ( $target eq 'edit' ) {
   93: 	$result=&Apache::edit::tag_start($target,$token);
   94: 	$result.='</td></tr>';
   95: 	$result.=&Apache::edit::end_table();
   96:     }
   97:     return $result;
   98: }
   99: 
  100: sub end_displayduedate {
  101:     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
  102:     my @result;
  103:     if ($target eq 'edit') { $result[1]='no'; }
  104:     return @result;
  105: }
  106: 
  107: sub start_displaytitle {
  108:     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
  109:     my $result='';
  110:     if (exists($Apache::outputtags::showonce{'displayduetitle'})) {
  111: 	return '';
  112:     } else {
  113: 	$Apache::outputtags::showonce{'displayduetitle'}=1;
  114:     }
  115:     my $name=&Apache::structuretags::get_resource_name();
  116:     my $style = &Apache::lonxml::get_param('style',$parstack,$safeeval);
  117:     if ($target eq 'web') {
  118: 	$result=$name;
  119: 	if (lc($style) !~ 'plain') { $result="<h1>$name</h1>"; }
  120:     } elsif ($target eq 'edit') {
  121: 	$result=&Apache::edit::tag_start($target,$token);
  122: 	$result.='</td></tr>';
  123: 	$result.=&Apache::edit::end_table();
  124:     } elsif ($target eq 'tex' and $Apache::lonhomework::type ne 'exam') {
  125: 	$name=&Apache::lonxml::latex_special_symbols($name);
  126: 	if (lc($style) !~ 'plain') { 
  127: 	    $result='\vskip 0 mm\noindent\textbf{'.$name.'}\vskip 0 mm';
  128: 	} else {
  129: 	    $result=$name;
  130: 	}
  131:     }
  132:     return $result;
  133: }
  134: 
  135: sub end_displaytitle {
  136:     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
  137:     my @result;
  138:     if ($target eq 'edit') { $result[1]='no'; }
  139:     return @result;
  140: }
  141: 
  142: sub multipart {
  143:     my ($uri)=@_;
  144:     if (!defined($uri)) { $uri=$env{'request.uri'}; }
  145:     my @parts;
  146:     my $metadata = &Apache::lonnet::metadata($uri,'packages');
  147:     foreach (split(/\,/,$metadata)) {
  148: 	if ($_ =~ /^part_(.*)$/) {
  149: 	    my $part = $1;
  150: 	    if ($part ne '0') { push(@parts,$part); }
  151: 	}
  152:     }
  153:     return @parts;
  154: }
  155: 
  156: sub start_displayweight {
  157:     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
  158:     my $result;
  159:     if (exists($Apache::outputtags::showonce{'displayweight'})) {
  160: 	if(grep(/^\Q$Apache::inputtags::part\E$/,
  161: 		@{$Apache::outputtags::showonce{'displayweight'}})) {
  162: 	    return '';
  163: 	}
  164:     }
  165:     push(@{$Apache::outputtags::showonce{'displayweight'}},
  166: 	 $Apache::inputtags::part);
  167:     if ($target eq 'web' || $target eq 'tex') {
  168: 	my $id = $Apache::inputtags::part;
  169: 	if ($id ne '0') {
  170: 	    my $weight = &Apache::lonnet::EXT("resource.$id.weight");
  171: 	    if (!defined($weight) || ($weight eq '')) { $weight=1; }
  172: 	    $result.=$weight;
  173: 	} else {
  174: 	    my @parts=&multipart($env{'request.uri'});
  175: 	    my $weight;
  176: 	    if (@parts) {
  177: 	        foreach my $part (@parts) {
  178: 		    my $pweight=&Apache::lonnet::EXT("resource.$part.weight");
  179: 		    if (!defined($pweight) || ($pweight eq '')) { $pweight=1; }
  180: 		    $weight+=$pweight;
  181: 	        }
  182: 	    } else {
  183: 		$weight = &Apache::lonnet::EXT("resource.$id.weight");
  184:                 if (!defined($weight) || ($weight eq '')) { $weight=1; }
  185: 	    }
  186: 	    $result=$weight;
  187: 	}
  188:     } elsif ( $target eq 'edit' ) {
  189: 	$result=&Apache::edit::tag_start($target,$token);
  190: 	$result.='</td></tr>';
  191: 	$result.=&Apache::edit::end_table();
  192:     }
  193:     return $result;
  194: }
  195: 
  196: sub end_displayweight {
  197:     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
  198:     my @result;
  199:     if ($target eq 'edit') { $result[1]='no'; }
  200:     return @result;
  201: }
  202: 
  203: sub start_displaystudentphoto {
  204:     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
  205:     my $result;
  206:     my (undef,undef,$domain,$user) = &Apache::lonxml::whichuser();
  207:     if ($target eq 'web' && $user eq $env{'user.name'}) {
  208: 	my $url=&Apache::lonnet::studentphoto($domain,$user,"gif");
  209: 	my $args;
  210: 	my $width=&Apache::lonxml::get_param('width',$parstack,$safeeval);
  211: 	if ($width) { $args.=" width=\"$width\" "; }
  212: 	my $height=&Apache::lonxml::get_param('heigth',$parstack,$safeeval);
  213: 	if ($height) { $args.=" height=\"$height\" "; }
  214: 	my $align=&Apache::lonxml::get_param('align',$parstack,$safeeval);
  215: 	if ($align) { $args.=" align=\"$align\" "; }
  216: 	$result.=" <img $args src=\"$url\" alt=\"$user\@$domain\" />";
  217:     }
  218:     if ($target eq 'tex' && $env{'request.role'} =~ /^cc/) {
  219: 	my $url=&Apache::lonnet::studentphoto($domain,$user,"eps");
  220: 	my $ua=new LWP::UserAgent;
  221: 	my $request=new HTTP::Request('GET',$url);
  222: 	my $response=$ua->request($request);
  223: 	if ($response->is_success) {
  224: 	    my $file=$user."_".$domain."_studentphoto.eps";
  225: 	    open(FILE,">".$Apache::lonnet::perlvar{'lonPrtDir'}."/$file");
  226: 	    print FILE $response->content;
  227: 	    close(FILE);
  228: 	    my $width_param=&Apache::londefdef::image_size($Apache::lonnet::perlvar{'lonPrtDir'}."/$file",'0.3',$parstack,$safeeval);
  229: 	    $result.=' \graphicspath{{'.$Apache::lonnet::perlvar{'lonPrtDir'}.
  230: 		'}}\includegraphics[width='.$width_param.' mm]{'.$file.'} ';
  231: 	} else {
  232: 	    $result="$user\@$domain";
  233: 	}
  234:     }
  235:     return $result;
  236: }
  237: 
  238: sub end_displaystudentphoto {
  239:     my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_;
  240:     my @result;
  241:     if ($target eq 'edit') { $result[1]='no'; }
  242:     return @result;
  243: }
  244: 
  245: 1;
  246: __END__

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