--- loncom/interface/lonmeta.pm 2004/04/14 16:14:29 1.67
+++ loncom/interface/lonmeta.pm 2004/04/19 16:43:53 1.74
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Metadata display handler
#
-# $Id: lonmeta.pm,v 1.67 2004/04/14 16:14:29 matthew Exp $
+# $Id: lonmeta.pm,v 1.74 2004/04/19 16:43:53 matthew Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -114,21 +114,21 @@ sub evalgraph {
return '';
}
my $val=int($value*10.+0.5)-10;
- my $output='
';
+ my $output='
';
if ($val>=20) {
- $output.='
 
';
+ $output.='
 
';
} else {
- $output.='
'.
- '
';
+ $output.='
'.
+ '
';
}
$output.='
';
if ($val>20) {
- $output.='
'.
- '
';
+ $output.='
'.
+ '
';
} else {
- $output.='
 
';
+ $output.='
 
';
}
- $output.='
('.$value.')
';
+ $output.='
('.sprintf("%5.2f",$value).')
';
return $output;
}
@@ -140,15 +140,15 @@ sub diffgraph {
my $val=int(40.0*$value+0.5);
my @colors=('#FF9933','#EEAA33','#DDBB33','#CCCC33',
'#BBDD33','#CCCC33','#DDBB33','#EEAA33');
- my $output='
';
+ my $output='
';
for (my $i=0;$i<8;$i++) {
if ($val>$i*5) {
- $output.='
';
+ $output.='
';
} else {
- $output.='
';
+ $output.='
';
}
}
- $output.='
('.$value.')
';
+ $output.='
('.sprintf("%3.2f",$value).')
';
return $output;
}
@@ -193,7 +193,8 @@ sub fieldnames {
'technical' => 'Resource is technically correct',
'avetries' => 'Average number of tries till solved',
'stdno' => 'Total number of students who have worked on this problem',
- 'difficulty' => 'Degree of difficulty'
+ 'difficulty' => 'Degree of difficulty',
+ 'disc' => 'Degree of discrimination',
);
}
@@ -252,9 +253,26 @@ sub prettyprint {
($type eq 'comefrom_list') ||
($type eq 'sequsage_list')) {
return join(' ',map {
- my $url=&Apache::lonnet::clutter($_);
- ''.&Apache::lonnet::gettitle($url).''.
- &Apache::lonhtmlcommon::crumbs($url,'preview','',undef,'+0');
+ my $url = &Apache::lonnet::clutter($_);
+ my $title = &Apache::lonnet::gettitle($url);
+ if ($title eq '') {
+ $title = 'Untitled';
+ if ($url =~ /\.sequence$/) {
+ $title .= ' Sequence';
+ } elsif ($url =~ /\.page$/) {
+ $title .= ' Page';
+ } elsif ($url =~ /\.problem$/) {
+ $title .= ' Problem';
+ } elsif ($url =~ /\.html$/) {
+ $title .= ' HTML document';
+ } elsif ($url =~ m:/syllabus$:) {
+ $title .= ' Syllabus';
+ }
+ }
+ $_ = ''.$title.' '.
+ ''.
+ ''.$url.''.
+ ''
} split(/\s*\,\s*/,$value));
}
# Evaluations
@@ -266,17 +284,24 @@ sub prettyprint {
return &evalgraph($value);
}
# Difficulty
- if ($type eq 'difficulty') {
+ if ($type eq 'difficulty' || $type eq 'disc') {
return &diffgraph($value);
}
# List of courses
if ($type=~/\_list/) {
- return join(' ',map {
- my %courseinfo=&Apache::lonnet::coursedescription($_);
- ''.
- $courseinfo{'description'}.'';
- } split(/\s*\,\s*/,$value));
+ my @Courses = split(/\s*\,\s*/,$value);
+ my $Str;
+ foreach my $course (@Courses) {
+ my %courseinfo = &Apache::lonnet::coursedescription($course);
+ if (! exists($courseinfo{'num'}) || $courseinfo{'num'} eq '') {
+ next;
+ }
+ if ($Str ne '') { $Str .= ' '; }
+ $Str .= ''.
+ $courseinfo{'description'}.'';
+ }
+ return $Str;
}
# No pretty print found
return $value;
@@ -320,7 +345,7 @@ sub relatedfield {
sub prettyinput {
my ($type,$value,$fieldname,$formname,
- $relatedsearchflag,$relatedsep,$relatedvalue)=@_;
+ $relatedsearchflag,$relatedsep,$relatedvalue,$size)=@_;
# Language
if ($type eq 'language') {
return &selectbox($fieldname,
@@ -378,7 +403,7 @@ sub prettyinput {
$value=~s/\s+/ /gs;
$value=~s/\"/\&quod\;/gs;
return
- ''.
&relatedfield(1,$relatedsearchflag,$relatedsep,$fieldname,
$relatedvalue);
@@ -450,10 +475,10 @@ sub report_bombs {
&Apache::lonmsg::all_url_author_res_msg($author,$domain);
foreach (sort(keys(%brokenurls))) {
if ($_=~/^\Q$uri\E/) {
- $r->print(&Apache::lonhtmlcommon::crumbs
- (&Apache::lonnet::clutter($_)).
- &Apache::lonmsg::retrieve_author_res_msg($_).
- '');
+ $r->print
+ (''.$_.''.
+ &Apache::lonmsg::retrieve_author_res_msg($_).
+ '');
}
}
} else {
@@ -494,8 +519,9 @@ sub present_uneditable_metadata {
} else {
$versiondisplay='Version: '.$currentversion;
}
- # crumbify displayed URL
- $disuri=&Apache::lonhtmlcommon::crumbs($disuri);
+ # crumbify displayed URL uri target prefix form size
+ $disuri=&Apache::lonhtmlcommon::crumbs($disuri,undef, undef, undef,'+1');
+ $disuri =~ s: ::g;
# obsolete
my $obsolete=$content{'obsolete'};
my $obsoletewarning='';
@@ -507,6 +533,10 @@ sub present_uneditable_metadata {
#
my %lt=&fieldnames();
my $table='';
+ my $title = $content{'title'};
+ if (! defined($title)) {
+ $title = 'Untitled Resource';
+ }
foreach ('title',
'author',
'subject',
@@ -532,76 +562,179 @@ sub present_uneditable_metadata {
}
#
$r->print(<$content{'title'}
-
'.&mt('No Access or Usages Statistics are available for this resource.').'
');
}
- $r->print('
');
+ #
+ # Assessment statistics
if ($uri=~/\.(problem|exam|quiz|assess|survey|form)$/) {
- # This is an assessment, print assessment data
- $r->print(
- '
'.&mt('Assessment Statistical Data').'
'.
+ if (exists($dynmeta{'stdno'}) ||
+ exists($dynmeta{'avetries'}) ||
+ exists($dynmeta{'difficulty'}) ||
+ exists($dynmeta{'disc'})) {
+ # This is an assessment, print assessment data
+ $r->print('
'.&mt('Evaluation Comments').' ('.
- &mt('visible to author and co-authors only').
- ')
'.
- '
'.$dynmeta{'comments'}.'
');
- $r->print('
'.&mt('Error Messages').' ('.
- &mt('visible to author and co-authors only').')'.
- '
'.
- &Apache::lonmsg::retrieve_author_res_msg($uri));
+ if (exists($dynmeta{'comments'})) {
+ $r->print('
'.&mt('Evaluation Comments').' ('.
+ &mt('visible to author and co-authors only').
+ ')
'.
+ '
'.$dynmeta{'comments'}.'
');
+ } else {
+ $r->print('
'.&mt('There are no Evaluation Comments on this resource.').'
');
+ }
+ my $bombs = &Apache::lonmsg::retrieve_author_res_msg($uri);
+ if (defined($bombs) && $bombs ne '') {
+ $r->print('
'.&mt('Error Messages').' ('.
+ &mt('visible to author and co-authors only').')'.
+ '
'.$bombs);
+ } else {
+ $r->print('
'.&mt('There are currently no Error Messages for this resource.').'
');
+ }
}
+ #
# All other stuff
$r->print('
'.
&mt('Additional Metadata (non-standard, parameters, exports)').
@@ -747,30 +880,5 @@ ENDEDIT
return;
}
-##############################################################
-##############################################################
-# MySQL table columns
-
-my @columns;
-
-BEGIN {
- # Get columns of MySQL metadata table
- @columns=&Apache::lonmysql::col_order('metadata');
-}
-
-#
-# Turn MySQL row into hash
-# This routine should be moved to lonmetadata
-# a more generic place since it has nothing to do with metadata
-sub metadata_col_to_hash {
- my @cols=@_;
- my %hash=();
- for (my $i=0; $i<=$#columns; $i++) {
- $hash{$columns[$i]}=$cols[$i];
- }
- return %hash;
-}
-
-
1;
__END__