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

version 1.29, 2003/04/12 15:57:30 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',                     'goto'         => 'add',
Line 69  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 96  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 284  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 293  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 304  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 354  $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(' ('.$otherinfo.')');
     }
     $r->print("<br>\n");
       }        }
       $r->print('<b>'.$display.':</b> '.$content{$name});  
       if ($otherinfo) {  
          $r->print(' ('.$otherinfo.')');  
       }  
       $r->print("<br>\n");  
    }     }
   }    }
 # ===================================================== End Resource Space Call  # ===================================================== End Resource Space Call
Line 406  ENDEDIT Line 437  ENDEDIT
        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.29  
changed lines
  Added in v.1.33


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