Diff for /loncom/interface/lonmeta.pm between versions 1.24 and 1.33

version 1.24, 2002/10/25 13:50:48 version 1.33, 2003/07/15 19:04:31
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;
 }  }
   
   # ------------------------------------- Try to make an alt tag if there is none
   
   sub alttag {
       my ($base,$src)=@_;
       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
   
 sub evalgraph {  sub evalgraph {
Line 193  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 200  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 210  $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 228  $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 245  ENDHEAD Line 290  ENDHEAD
   delete($content{'lastrevisiondate'});    delete($content{'lastrevisiondate'});
   delete($content{'owner'});    delete($content{'owner'});
   delete($content{'copyright'});    delete($content{'copyright'});
     delete($content{'customdistributionfile'});
   if ($ENV{'user.adv'}) {    if ($ENV{'user.adv'}) {
 # ------------------------------------------------------------ Dynamic Metadata  # ------------------------------------------------------------ Dynamic Metadata
    $r->print(     $r->print(
Line 254  ENDHEAD Line 300  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 265  ENDHEAD Line 313  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(         $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");
    }     }
      foreach my $cat ('usage','comefrom','goto') {
          $r->print(
   '<tr><td bgcolor="#AAAAAA">'.$items{$cat}.'</td><td bgcolor="#CCCCCC">'.
   $dynmeta{$cat}.'<font size="-1"><ul>'.join("\n",
         map { my $murl=$_; 
    '<li><a href="'.&Apache::lonnet::clutter($murl).'" target="preview">'.
                           &Apache::lonnet::gettitle($murl).' [<tt>'.$murl
                           .'</tt>]</a></li>' }
         split(/\,/,$dynmeta{$cat.'_list'}))."</ul></font></td></tr>\n");
      }
      foreach my $cat ('course') {
          $r->print(
   '<tr><td bgcolor="#AAAAAA">'.$items{$cat}.'</td><td bgcolor="#CCCCCC">'.
   $dynmeta{$cat}.'<font size="-1"><ul>'.join("\n",
         map { my %courseinfo=&Apache::lonnet::coursedescription($_);  
    '<li><a href="/public/'.
     $courseinfo{'domain'}.'/'.$courseinfo{'num'}.'/syllabus" target="preview">'.
     $courseinfo{'description'}.'</a></li>' }
         split(/\,/,$dynmeta{$cat.'_list'}))."</ul></font></td></tr>\n");
      }
        $r->print('</table>');         $r->print('</table>');
    if ($uri=~/\.(problem|exam|quiz|assess|survey|form)\.meta$/) {     if ($uri=~/\.(problem|exam|quiz|assess|survey|form)\.meta$/) {
       $r->print(        $r->print(
Line 303  $dynmeta{$_}."&nbsp;</td></tr>\n"); Line 371  $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 315  $dynmeta{$_}."&nbsp;</td></tr>\n"); Line 383  $dynmeta{$_}."&nbsp;</td></tr>\n");
  '<h3>Additional Metadata (non-standard, parameters, exports)</h3>');   '<h3>Additional Metadata (non-standard, parameters, exports)</h3>');
    foreach (sort keys %content) {     foreach (sort keys %content) {
       my $name=$_;        my $name=$_;
       my $display=&Apache::lonnet::metadata($uri,$name.'.display');        unless ($name=~/\.display$/) {
       unless ($display) { $display=$name; };    my $display=&Apache::lonnet::metadata($uri,$name.'.display');
       my $otherinfo='';    unless ($display) { $display=$name; };
       foreach ('name','part','type','default') {    my $otherinfo='';
           if (defined(&Apache::lonnet::metadata($uri,$name.'.'.$_))) {    foreach ('name','part','type','default') {
              $otherinfo.=' '.$_.'='.        if (defined(&Apache::lonnet::metadata($uri,$name.'.'.$_))) {
  &Apache::lonnet::metadata($uri,$name.'.'.$_).'; ';    $otherinfo.=' '.$_.'='.
           }        &Apache::lonnet::metadata($uri,$name.'.'.$_).'; ';
       }        }
       $r->print('<b>'.$display.':</b> '.$content{$name});    }
       if ($otherinfo) {    $r->print('<b>'.$display.':</b> '.$content{$name});
          $r->print(' ('.$otherinfo.')');    if ($otherinfo) {
         $r->print(' ('.$otherinfo.')');
     }
     $r->print("<br>\n");
       }        }
       $r->print("<br>\n");  
    }     }
   }    }
 # ===================================================== End Resource Space Call  # ===================================================== End Resource Space Call
Line 363  $bodytag Line 433  $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_'.$_};
        }         }
        $r->print(         if (m/copyright/) {
          &Apache::lonpublisher::textfield($_,'new_'.$_,     $r->print(&Apache::lonpublisher::selectbox($_,'new_'.$_,
                                  $Apache::lonpublisher::metadatafields{$_}));         $Apache::lonpublisher::metadatafields{$_},
          \&Apache::loncommon::copyrightdescription,
          (&Apache::loncommon::copyrightids)));
          } elsif (m/language/) {
      $r->print(&Apache::lonpublisher::selectbox($_,'new_'.$_,
         $Apache::lonpublisher::metadatafields{$_},
         \&Apache::loncommon::languagedescription,
         (&Apache::loncommon::languageids)));
          } else {
      $r->print(&Apache::lonpublisher::textfield($_,'new_'.$_,
        $Apache::lonpublisher::metadatafields{$_}));
          }
    }     }
    if ($ENV{'form.store'}) {     if ($ENV{'form.store'}) {
       my $mfh;        my $mfh;

Removed from v.1.24  
changed lines
  Added in v.1.33


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