Diff for /loncom/interface/lonmeta.pm between versions 1.25 and 1.30

version 1.25, 2003/02/18 21:17:00 version 1.30, 2003/04/14 13:46:53
Line 51  sub dynamicmeta { Line 51  sub dynamicmeta {
     $regexp='___'.$regexp.'___';      $regexp='___'.$regexp.'___';
     my %evaldata=&Apache::lonnet::dump('nohist_resevaldata',$adomain,      my %evaldata=&Apache::lonnet::dump('nohist_resevaldata',$adomain,
        $aauthor,$regexp);         $aauthor,$regexp);
     my %sum;      my %sum=();
     my %cnt;      my %cnt=();
       my %concat=();
     my %listitems=('count'        => 'add',      my %listitems=('count'        => 'add',
                    'course'       => 'add',                     'course'       => 'add',
                      'goto'         => 'add',
                      'comefrom'     => 'add',
                    'avetries'     => 'avg',                     'avetries'     => 'avg',
                    'stdno'        => 'add',                     'stdno'        => 'add',
                    'difficulty'   => 'avg',                     'difficulty'   => 'avg',
Line 67  sub dynamicmeta { Line 70  sub dynamicmeta {
                    'usage'        => 'cnt'                     'usage'        => 'cnt'
                    );                     );
     foreach (keys %evaldata) {      foreach (keys %evaldata) {
  $_=~/___(\w+)$/;   my ($item,$purl,$cat)=split(/\_\_\_/,$_);
         if (defined($cnt{$1})) { $cnt{$1}++; } else { $cnt{$1}=1; }  ### print "\n".$_.' - '.$item.'<br />';
         unless ($listitems{$1} eq 'app') {          if (defined($cnt{$cat})) { $cnt{$cat}++; } else { $cnt{$cat}=1; }
             if (defined($sum{$1})) {          unless ($listitems{$cat} eq 'app') {
                $sum{$1}+=$evaldata{$_};              if (defined($sum{$cat})) {
                  $sum{$cat}+=$evaldata{$_};
                  $concat{$cat}.=','.$item;
     } else {      } else {
                $sum{$1}=$evaldata{$_};                 $sum{$cat}=$evaldata{$_};
                  $concat{$cat}=$item;
     }      }
         } else {          } else {
             if (defined($sum{$1})) {              if (defined($sum{$cat})) {
                if ($evaldata{$_}) {                 if ($evaldata{$_}) {
                   $sum{$1}.='<hr>'.$evaldata{$_};                    $sum{$cat}.='<hr>'.$evaldata{$_};
        }         }
      } else {       } else {
        $sum{$1}=''.$evaldata{$_};         $sum{$cat}=''.$evaldata{$_};
     }      }
  }   }
     }      }
Line 94  sub dynamicmeta { Line 100  sub dynamicmeta {
        } else {         } else {
            $returnhash{$_}=$sum{$_};             $returnhash{$_}=$sum{$_};
        }         }
          $returnhash{$_.'_list'}=$concat{$_};
   ### print "\n<hr />".$_.': '.$returnhash{$_}.'<br />'.$returnhash{$_.'_list'};
     }      }
     return %returnhash;      return %returnhash;
 }  }
Line 101  sub dynamicmeta { Line 109  sub dynamicmeta {
 # ------------------------------------- Try to make an alt tag if there is none  # ------------------------------------- Try to make an alt tag if there is none
   
 sub alttag {  sub alttag {
     my $src=shift;      my ($base,$src)=@_;
     return 'None';      my $fullpath=&Apache::lonnet::hreflocation($base,$src);
       my $alttag=&Apache::lonnet::metadata($fullpath,'title').' '.
                  &Apache::lonnet::metadata($fullpath,'subject').' '.
                  &Apache::lonnet::metadata($fullpath,'abstract');
       $alttag=~s/\s+/ /gs;
       $alttag=~s/\"//gs;
       $alttag=~s/\'//gs;
       $alttag=~s/\s+$//gs;
       $alttag=~s/^\s+//gs;
       if ($alttag) { return $alttag; } else 
                    { return 'No information available'; }
   }
   
   # -------------------------------------------------------------- Author display
   
   sub authordisplay {
       my ($aname,$adom)=@_;
       return &Apache::loncommon::aboutmewrapper(
                   &Apache::loncommon::plainname($aname,$adom),
                       $aname,$adom).' <tt>['.$aname.'@'.$adom.']</tt>';
 }  }
   
 # -------------------------------------------------------------- Pretty display  # -------------------------------------------------------------- Pretty display
Line 200  my $mime=&Apache::loncommon::filedescrip Line 227  my $mime=&Apache::loncommon::filedescrip
 my $disuri=&Apache::lonnet::declutter($uri);  my $disuri=&Apache::lonnet::declutter($uri);
   $disuri=~s/\.meta$//;    $disuri=~s/\.meta$//;
 my $currentversion=&Apache::lonnet::getversion($disuri);  my $currentversion=&Apache::lonnet::getversion($disuri);
   my $author=$content{'author'};
   $author=~s/(\w+)(\:|\@)(\w+)/&authordisplay($1,$3)/gse;
   my $owner=$content{'owner'};
   $owner=~s/(\w+)(\:|\@)(\w+)/&authordisplay($1,$3)/gse;
 my $versiondisplay='';  my $versiondisplay='';
 if ($thisversion) {  if ($thisversion) {
     $versiondisplay='Version: '.$thisversion.      $versiondisplay='Version: '.$thisversion.
Line 207  if ($thisversion) { Line 238  if ($thisversion) {
 } else {  } else {
     $versiondisplay='Version: '.$currentversion;      $versiondisplay='Version: '.$currentversion;
 }  }
   my $customdistributionfile='';
   if ($content{'customdistributionfile'}) {
      $customdistributionfile='<a href="'.$content{'customdistributionfile'}.
        '"><tt>'.$content{'customdistributionfile'}.'</tt></a>';
   }
 my $bodytag=&Apache::loncommon::bodytag  my $bodytag=&Apache::loncommon::bodytag
             ('Catalog Information','','','',$resdomain);              ('Catalog Information','','','',$resdomain);
   $r->print(<<ENDHEAD);    $r->print(<<ENDHEAD);
Line 217  $bodytag Line 253  $bodytag
 $versiondisplay<br />  $versiondisplay<br />
 <table cellspacing=2 border=0>  <table cellspacing=2 border=0>
 <tr><td bgcolor='#AAAAAA'>Author(s)</td>  <tr><td bgcolor='#AAAAAA'>Author(s)</td>
 <td bgcolor="#CCCCCC">$content{'author'}&nbsp;</td></tr>  <td bgcolor="#CCCCCC">$author&nbsp;</td></tr>
 <tr><td bgcolor='#AAAAAA'>Subject</td>  <tr><td bgcolor='#AAAAAA'>Subject</td>
 <td bgcolor="#CCCCCC">$content{'subject'}&nbsp;</td></tr>  <td bgcolor="#CCCCCC">$content{'subject'}&nbsp;</td></tr>
 <tr><td bgcolor='#AAAAAA'>Keyword(s)</td>  <tr><td bgcolor='#AAAAAA'>Keyword(s)</td>
Line 235  $versiondisplay<br /> Line 271  $versiondisplay<br />
 <tr><td bgcolor='#AAAAAA'>  <tr><td bgcolor='#AAAAAA'>
 Last Revision Date</td><td bgcolor="#CCCCCC">$lastrevisiondate&nbsp;</td></tr>  Last Revision Date</td><td bgcolor="#CCCCCC">$lastrevisiondate&nbsp;</td></tr>
 <tr><td bgcolor='#AAAAAA'>Publisher/Owner</td>  <tr><td bgcolor='#AAAAAA'>Publisher/Owner</td>
 <td bgcolor="#CCCCCC">$content{'owner'}&nbsp;</td></tr>  <td bgcolor="#CCCCCC">$owner&nbsp;</td></tr>
 <tr><td bgcolor='#AAAAAA'>Copyright/Distribution</td>  <tr><td bgcolor='#AAAAAA'>Copyright/Distribution</td>
 <td bgcolor="#CCCCCC">$content{'copyright'}  <td bgcolor="#CCCCCC">$content{'copyright'}&nbsp;</td></tr>
   <tr><td bgcolor='#AAAAAA'>Custom Distribution File</td>
   <td bgcolor="#CCCCCC">$customdistributionfile&nbsp;</td></tr>
 </table>  </table>
 ENDHEAD  ENDHEAD
   delete($content{'title'});    delete($content{'title'});
Line 261  ENDHEAD Line 299  ENDHEAD
  'count'      => 'Network-wide number of accesses (hits)',   'count'      => 'Network-wide number of accesses (hits)',
  'course'     => 'Network-wide number of courses using resource',   'course'     => 'Network-wide number of courses using resource',
  'usage'      => 'Number of resources using or importing resource',   'usage'      => 'Number of resources using or importing resource',
    'goto'       => 'Number of resources that follow this resource in maps',
    'comefrom'   => 'Number of resources that lead up to this resource in maps',
  'clear'      => 'Material presented in clear way',   'clear'      => 'Material presented in clear way',
  'depth'      => 'Material covered with sufficient depth',   'depth'      => 'Material covered with sufficient depth',
  'helpful'    => 'Material is helpful',   'helpful'    => 'Material is helpful',
Line 272  ENDHEAD Line 312  ENDHEAD
    my %dynmeta=&dynamicmeta($uri);     my %dynmeta=&dynamicmeta($uri);
    $r->print(     $r->print(
 '</table><h4>Access and Usage Statistics</h4><table cellspacing=2 border=0>');  '</table><h4>Access and Usage Statistics</h4><table cellspacing=2 border=0>');
    foreach ('count','usage','course') {     foreach ('count') {
          $r->print(
   '<tr><td bgcolor="#AAAAAA">'.$items{$_}.'</td><td bgcolor="#CCCCCC">'.
   $dynmeta{$_}."&nbsp;</td></tr>\n");
      }
      foreach my $cat ('usage','comefrom','goto') {
          $r->print(
   '<tr><td bgcolor="#AAAAAA">'.$items{$cat}.'</td><td bgcolor="#CCCCCC">'.
   $dynmeta{$_}.'<br />'.join('<br /><font size="-1">',
         map { '<a href="'.&Apache::lonnet::clutter($_).'">'.
                           &Apache::lonnet::gettitle($_).' <tt>['.
    $_.']</tt></a>' }
         split(/\,/,$dynmeta{$cat.'_list'}))."</font></td></tr>\n");
      }
      foreach ('course') {
        $r->print(         $r->print(
 '<tr><td bgcolor="#AAAAAA">'.$items{$_}.'</td><td bgcolor="#CCCCCC">'.  '<tr><td bgcolor="#AAAAAA">'.$items{$_}.'</td><td bgcolor="#CCCCCC">'.
 $dynmeta{$_}."&nbsp;</td></tr>\n");  $dynmeta{$_}."&nbsp;</td></tr>\n");
Line 310  $dynmeta{$_}."&nbsp;</td></tr>\n"); Line 364  $dynmeta{$_}."&nbsp;</td></tr>\n");
    '<h4>Error Messages (visible to author and co-authors only)</h4>');     '<h4>Error Messages (visible to author and co-authors only)</h4>');
       my %errormsgs=&Apache::lonnet::dump('nohist_res_msgs',$1,$2);        my %errormsgs=&Apache::lonnet::dump('nohist_res_msgs',$1,$2);
       foreach (keys %errormsgs) {        foreach (keys %errormsgs) {
  if ($_=~/^$disuri\_\d+$/) {   if ($_=~/^\Q$disuri\E\_\d+$/) {
           my %content=&Apache::lonmsg::unpackagemsg($errormsgs{$_});            my %content=&Apache::lonmsg::unpackagemsg($errormsgs{$_});
   $r->print('<b>'.$content{'time'}.'</b>: '.$content{'message'}.    $r->print('<b>'.$content{'time'}.'</b>: '.$content{'message'}.
                     '<br />');                      '<br />');
Line 370  $bodytag Line 424  $bodytag
 <form method="post">  <form method="post">
 ENDEDIT  ENDEDIT
    foreach ('author','title','subject','keywords','abstract','notes',     foreach ('author','title','subject','keywords','abstract','notes',
             'copyright','language') {              'copyright','customdistributionfile','language') {
        if ($ENV{'form.new_'.$_}) {         if ($ENV{'form.new_'.$_}) {
    $Apache::lonpublisher::metadatafields{$_}=$ENV{'form.new_'.$_};     $Apache::lonpublisher::metadatafields{$_}=$ENV{'form.new_'.$_};
        }         }

Removed from v.1.25  
changed lines
  Added in v.1.30


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