Diff for /loncom/interface/groupsort.pm between versions 1.2 and 1.11

version 1.2, 2001/08/13 14:50:53 version 1.11, 2002/05/24 13:53:43
Line 1 Line 1
 # The LearningOnline Network with CAPA  # The LearningOnline Network with CAPA
 #  
 # The LON-CAPA group sort handler  # The LON-CAPA group sort handler
 #  
 # Allows for sorting prior to import into RAT.  # Allows for sorting prior to import into RAT.
 #  #
   # $Id$
   # 
   # Copyright Michigan State University Board of Trustees
   #
   # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
   #
   # LON-CAPA is free software; you can redistribute it and/or modify
   # it under the terms of the GNU General Public License as published by
   # the Free Software Foundation; either version 2 of the License, or
   # (at your option) any later version.
   #
   # LON-CAPA is distributed in the hope that it will be useful,
   # but WITHOUT ANY WARRANTY; without even the implied warranty of
   # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   # GNU General Public License for more details.
   #
   # You should have received a copy of the GNU General Public License
   # along with LON-CAPA; if not, write to the Free Software
   # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
   #
   # /home/httpd/html/adm/gpl.txt
   #
   # http://www.lon-capa.org/
   #
 # YEAR=2001  # YEAR=2001
 # 8/7,8/8 Scott Harrison  # 8/7,8/8,10/14,10/15,12/10 Scott Harrison
   # YEAR=2002
   # 1/17 Scott Harrison
   #
   ###
   
 package Apache::groupsort;  package Apache::groupsort;
   
Line 20  my $iconpath; # variable to be accessibl Line 46  my $iconpath; # variable to be accessibl
 # ---------------------------------------------------------------- Main Handler  # ---------------------------------------------------------------- Main Handler
 sub handler {  sub handler {
     my $r = shift;      my $r = shift;
    
      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
                                              ['acts','catalogmode','mode']);
   
     # color scheme      # color scheme
     my $fileclr = '#ffffe6';      my $fileclr = '#ffffe6';
Line 29  sub handler { Line 58  sub handler {
     $r->send_http_header;      $r->send_http_header;
     return OK if $r->header_only;      return OK if $r->header_only;
   
     # output start of web page  # finish_import looks different for graphical or "simple" RAT
     $r->print(<<END);      my $finishimport='';
 <html>      if ($ENV{'form.mode'} eq 'simple') {
 <head>          $finishimport=(<<ENDSMP);
 <title>The LearningOnline Network With CAPA Group Sorter</title>  function finish_import() {
 <script language='javascript'>      opener.document.forms.simpleedit.importdetail.value='';
 function insertRowInLastRow() {      for (var num=0; num<document.forms.groupsort.fnum.value; num++) {
     opener.insertrow(opener.maxrow);   opener.document.forms.simpleedit.importdetail.value+='&'+
     opener.addobj(opener.maxrow,'e&2');                escape(eval("document.forms.groupsort.title"+num+".value"))+'='+
 }        escape(eval("document.forms.groupsort.filelink"+num+".value"));
 function placeResourceInLastRow (title,url,linkflag) {  
     opener.newresource(opener.maxrow,2,opener.escape(title),  
        opener.escape(url),'false','normal');  
     opener.save();  
     opener.mostrecent=opener.obj.length-1;  
     if (linkflag) {  
  opener.joinres(opener.linkmode,opener.mostrecent,0);  
     }      }
     opener.linkmode=opener.mostrecent;      opener.document.forms.simpleedit.submit();
       self.close();
 }  }
   ENDSMP
       } else {
           $finishimport=(<<ENDADV);
 function finish_import() {  function finish_import() {
     var linkflag=false;      var linkflag=false;
     for (var num=0; num<document.forms.groupsort.fnum.value; num++) {      for (var num=0; num<document.forms.groupsort.fnum.value; num++) {
Line 63  function finish_import() { Line 89  function finish_import() {
     opener.editmode=0;      opener.editmode=0;
     opener.notclear=0;      opener.notclear=0;
     opener.linkmode=0;      opener.linkmode=0;
     opener.infoclear();  
     opener.draw();      opener.draw();
     self.close();      self.close();
 }  }
   ENDADV
       }
   
   # output start of web page
   
       $r->print(<<END);
   <html>
   <head>
   <title>The LearningOnline Network With CAPA Group Sorter</title>
   <script language='javascript'>
   function insertRowInLastRow() {
       opener.insertrow(opener.maxrow);
       opener.addobj(opener.maxrow,'e&2');
   }
   function placeResourceInLastRow (title,url,linkflag) {
       opener.newresource(opener.maxrow,2,opener.escape(title),
          opener.escape(url),'false','normal');
       opener.save();
       opener.mostrecent=opener.obj.length-1;
       if (linkflag) {
    opener.joinres(opener.linkmode,opener.mostrecent,0);
       }
       opener.linkmode=opener.mostrecent;
   }
   $finishimport
 function selectchange(val) {  function selectchange(val) {
     var newval=1+eval("document.forms.groupsort.alt"+val+".selectedIndex");      var newval=0+eval("document.forms.groupsort.alt"+val+".selectedIndex");
     orderchange(val,newval);      orderchange(val,newval);
 }  }
 function move(val,newval) {  function move(val,newval) {
Line 87  END Line 137  END
     # read pertinent machine configuration      # read pertinent machine configuration
     my $domain  = $r->dir_config('lonDefDomain');      my $domain  = $r->dir_config('lonDefDomain');
     $iconpath = $r->dir_config('lonIconsURL') . "/";      $iconpath = $r->dir_config('lonIconsURL') . "/";
     my $diropendb = "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_indexer.db";  
   
     my %shash; # sort order (key is resource location, value is sort order)      my %shash; # sort order (key is resource location, value is sort order)
     my %thash; # title (key is resource location, value is title)      my %thash; # title (key is resource location, value is title)
     map {  
        my ($name, $value) = split(/=/,$_);      my $diropendb;
        $value =~ tr/+/ /;  # ------------------------------ which file do we open? Easy if explictly given
        $value =~ s/%([a-fA-F0-9][a-fA-F0-9])/pack("C",hex($1))/eg;      if ($ENV{'form.catalogmode'} eq 'groupsearch') {
        if ($name eq 'acts') {   $diropendb = 
            $ENV{'form.'.$name}=$value;      "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_searchcat.db";
        }      }
     } (split(/&/,$ENV{'QUERY_STRING'}));      elsif ($ENV{'form.catalogmode'} eq 'groupimport') {
    $diropendb = 
       "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_indexer.db";
       }
       elsif ($ENV{'form.catalogmode'} eq 'groupsec') {
    $diropendb = 
       "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_groupsec.db";
       }
   # --------------------- not explicitly given, choose the one most recently used
       else { # choose last accessed
           my @dbfn;
           my @dbst;
   
    $dbfn[0] =
       "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_searchcat.db";
           $dbst[0]=-1;
    if (-e $dbfn[0]) {
       $dbst[0]=(stat($dbfn[0]))[9];
    }
    $dbfn[1] =
               "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_indexer.db";
           $dbst[1]=-1;
    if (-e $dbfn[1]) {
               $dbst[1]=(stat($dbfn[1]))[9];
           }
    $dbfn[2] =
               "/home/httpd/perl/tmp/$domain\_$ENV{'user.name'}_groupsec.db";
           $dbst[2]=-1;
    if (-e $dbfn[2]) {
               $dbst[2]=(stat($dbfn[2]))[9];
           }
   # Expand here for more modes
   # ....
   
   # Okay, find most recent existing
   
           my $newest=0;
           my $diropendb='';
           for (my $i=0; $i<=$#dbfn; $i++) {
       if ($dbst[$i]>$newest) {
    $newest=$dbst[$i];
                   $diropendb=$dbfn[$i];
               }
           }
   
       }
   # ----------------------------- diropendb is now the filename of the db to open
     if (tie(%hash,'GDBM_File',$diropendb,&GDBM_WRCREAT,0640)) {      if (tie(%hash,'GDBM_File',$diropendb,&GDBM_WRCREAT,0640)) {
  my $acts = $ENV{'form.acts'};   my $acts = $ENV{'form.acts'};
  my @Acts = split(/b/,$acts);   my @Acts = split(/b/,$acts);
  my %ahash;   my %ahash;
  my %achash;   my %achash;
  my $ac = 0;   my $ac = 0;
  map {   foreach (@Acts) {
     my ($state,$ref) = split(/a/);      my ($state,$ref) = split(/a/);
     $ahash{$ref} = $state;      $ahash{$ref} = $state;
     $achash{$ref} = $ac;      $achash{$ref} = $ac;
     $ac++;      $ac++;
  } (@Acts);   }
  map {   foreach (sort {$achash{$a} <=> $achash{$b}} (keys %ahash)) {
     my $key = $_;      my $key = $_;
     if ($ahash{$key} eq '1') {      if ($ahash{$key} eq '1') {
   # my $keyz=join("<br />",keys %hash);
   # print "<br />$key<br />$keyz".$hash{'pre_'.$key.'_link'}."<br />\n";
  $hash{'store_'.$hash{'pre_'.$key.'_link'}} =   $hash{'store_'.$hash{'pre_'.$key.'_link'}} =
     $hash{'pre_'.$key.'_title'};      $hash{'pre_'.$key.'_title'};
  $hash{'storectr_'.$hash{'pre_'.$key.'_link'}} =   $hash{'storectr_'.$hash{'pre_'.$key.'_link'}} =
Line 125  END Line 222  END
     delete $hash{'store_'.$hash{'pre_'.$key.'_link'}};      delete $hash{'store_'.$hash{'pre_'.$key.'_link'}};
  }   }
     }      }
  } sort {$achash{$a} <=> $achash{$b}} (keys %ahash);   }
  map {   foreach (keys %hash) {
     if ($_ =~ /^store_/) {      if ($_ =~ /^store_/) {
  my $key = $_;   my $key = $_;
  $key =~ s/^store_//;   $key =~ s/^store_//;
  $shash{$key} = $hash{'storectr_'.$key};   $shash{$key} = $hash{'storectr_'.$key};
  $thash{$key} = $hash{'store_'.$key};   $thash{$key} = $hash{'store_'.$key};
     }      }
  } keys %hash;   }
  if ($ENV{'form.oldval'}) {   if ($ENV{'form.oldval'}) {
     my $newctr = 0;      my $newctr = 0;
     my %chash;      my %chash;
     map {      foreach (sort {$shash{$a} <=> $shash{$b}} (keys %shash)) {
  my $key = $_;   my $key = $_;
  $newctr++;   $newctr++;
  $shash{$key} = $newctr;   $shash{$key} = $newctr;
  $hash{'storectr_'.$key} = $newctr;   $hash{'storectr_'.$key} = $newctr;
  $chash{$newctr} = $key;   $chash{$newctr} = $key;
     } sort {$shash{$a} <=> $shash{$b}} (keys %shash);      }
     my $oldval = $ENV{'form.oldval'};      my $oldval = $ENV{'form.oldval'};
     my $newval = $ENV{'form.newval'};      my $newval = $ENV{'form.newval'};
     if ($oldval != $newval) {      if ($oldval != $newval) {
  $shash{$chash{$oldval}} = $newval;   # when newval==0, then push down and delete
  $hash{'storectr_'.$chash{$oldval}} = $newval;   if ($newval!=0) {
  if ($oldval < $newval) { # push down      $shash{$chash{$oldval}} = $newval;
       $hash{'storectr_'.$chash{$oldval}} = $newval;
    }
    else {
       $shash{$chash{$oldval}} = $newctr;
       $hash{'storectr_'.$chash{$oldval}} = $newctr;
    }
    if ($newval==0) { # push down
       my $newval2=$newctr;
       for my $idx ($oldval..($newval2-1)) {
    $shash{$chash{$idx+1}} = $idx;
    $hash{'storectr_'.$chash{$idx+1}} = $idx;
       }
       delete $shash{$chash{$oldval}};
       delete $hash{'storectr_'.$chash{$oldval}};
       delete $hash{'store_'.$chash{$oldval}};
    }
    elsif ($oldval < $newval) { # push down
     for my $idx ($oldval..($newval-1)) {      for my $idx ($oldval..($newval-1)) {
  $shash{$chash{$idx+1}} = $idx;   $shash{$chash{$idx+1}} = $idx;
  $hash{'storectr_'.$chash{$idx+1}} = $idx;   $hash{'storectr_'.$chash{$idx+1}} = $idx;
Line 180  END Line 294  END
 <input type="hidden" name="fnum" value="$clen" />  <input type="hidden" name="fnum" value="$clen" />
 <input type="hidden" name="oldval" value="" />  <input type="hidden" name="oldval" value="" />
 <input type="hidden" name="newval" value="" />  <input type="hidden" name="newval" value="" />
   END
   
   # --- Expand here if "GO BACK" button desired
       if ($ENV{'form.catalogmode'} eq 'groupimport') {
    $r->print(<<END);
 <input type="button" name="alter" value="GO BACK"  <input type="button" name="alter" value="GO BACK"
  onClick="window.location='/res/?catalogmode=groupimport'" />&nbsp;   onClick="window.location='/res/?catalogmode=groupimport'" />&nbsp;
   END
       }
       if ($ENV{'form.catalogmode'} eq 'groupsearch') {
    $r->print(<<END);
   <input type="button" name="alter" value="GO BACK"
    onClick="window.location='/adm/searchcat?catalogmode=groupsearch'" />&nbsp;
   END
   }
   # ---
   
       $r->print(<<END);
 <input type="button" name="alter" value="FINISH IMPORT"  <input type="button" name="alter" value="FINISH IMPORT"
  onClick="finish_import()" />&nbsp;   onClick="finish_import()" />&nbsp;
 <input type="button" name="alter" value="CANCEL" onClick="self.close()" />  <input type="button" name="alter" value="CANCEL" onClick="self.close()" />
Line 192  END Line 322  END
       "\n");        "\n");
     $r->print("<td colspan='2' bgcolor='$titleclr'><b>Title</b></td>\n");      $r->print("<td colspan='2' bgcolor='$titleclr'><b>Title</b></td>\n");
     $r->print("<td bgcolor='$titleclr'><b>Path</b></td></tr>\n");      $r->print("<td bgcolor='$titleclr'><b>Path</b></td></tr>\n");
     map {      foreach (sort {$shash{$a}<=>$shash{$b}} (keys %shash)) {
  my $key=$_;   my $key=$_;
  $ctr++;   $ctr++;
  my @file_ext = split(/\./,$key);   my @file_ext = split(/\./,$key);
Line 207  END Line 337  END
  $r->print("</td><td bgcolor='$fileclr'>");   $r->print("</td><td bgcolor='$fileclr'>");
  $r->print("$thash{$key}</td><td bgcolor='$fileclr'>\n");   $r->print("$thash{$key}</td><td bgcolor='$fileclr'>\n");
  $r->print("$key</td></tr>\n");   $r->print("$key</td></tr>\n");
     } sort {$shash{$a}<=>$shash{$b}} (keys %shash);      } 
     $r->print("</table></td></tr></table></form>");      $r->print("</table></td></tr></table></form>");
     $r->print(<<END);      $r->print(<<END);
 </body>  </body>
Line 251  sub select_box { Line 381  sub select_box {
     my $string;      my $string;
     $string = '<select name="alt'.$sel.'"';      $string = '<select name="alt'.$sel.'"';
     $string .= " onChange='selectchange($sel)'>";      $string .= " onChange='selectchange($sel)'>";
       $string .= "<option name='o0' value='0'>remove</option>";
     for my $cur (1..$total) {      for my $cur (1..$total) {
  $string .= "<option name='o$cur' value='$cur'";   $string .= "<option name='o$cur' value='$cur'";
  if ($cur == $sel) {   if ($cur == $sel) {

Removed from v.1.2  
changed lines
  Added in v.1.11


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