--- loncom/interface/groupsort.pm 2007/07/12 00:27:13 1.57 +++ loncom/interface/groupsort.pm 2008/12/01 19:12:37 1.63 @@ -2,7 +2,7 @@ # The LON-CAPA group sort handler # Allows for sorting prior to import into RAT. # -# $Id: groupsort.pm,v 1.57 2007/07/12 00:27:13 albertel Exp $ +# $Id: groupsort.pm,v 1.63 2008/12/01 19:12:37 jms Exp $ # # Copyright Michigan State University Board of Trustees # @@ -37,7 +37,7 @@ use GDBM_File; use Apache::loncommon; use Apache::lonlocal; use Apache::lonnet; -use LONCAPA(); +use LONCAPA; my $iconpath; # variable to be accessible to multiple subroutines my %hash; # variable to tie to user specific database @@ -45,14 +45,15 @@ my %hash; # variable to tie to user spec sub update_actions_hash { my ($hash) = @_; + # be careful in here, there is also a global %hash my $acts=$env{'form.acts'}; my @Acts=split(/b/,$acts); my %ahash; my %achash; - my $ac=0; # some initial hashes for working with data + my $ac=0; foreach (@Acts) { - my ($state,$ref)=split(/a/); + my ($state,$ref)=split(/a/); $ahash{$ref}=$state; $achash{$ref}=$ac; $ac++; @@ -60,15 +61,16 @@ sub update_actions_hash { # sorting through the actions and changing the global database hash foreach my $key (sort {$achash{$a}<=>$achash{$b}} (keys %ahash)) { if ($ahash{$key} eq '1') { - $hash->{'store_'.$hash{'pre_'.$key.'_link'}}= + $hash->{'store_'.$hash->{'pre_'.$key.'_link'}}= $hash->{'pre_'.$key.'_title'}; - $hash->{'storectr_'.$hash{'pre_'.$key.'_link'}}= + $hash->{'storectr_'.$hash->{'pre_'.$key.'_link'}}= $hash->{'storectr'}+0; $hash->{'storectr'}++; } if ($ahash{$key} eq '0') { - if ($hash->{'store_'.$hash{'pre_'.$key.'_link'}}) { - delete($hash->{'store_'.$hash{'pre_'.$key.'_link'}}); + if ($hash->{'store_'.$hash->{'pre_'.$key.'_link'}}) { + delete($hash->{'store_'.$hash->{'pre_'.$key.'_link'}}); + delete($hash->{'storectr_'.$hash->{'pre_'.$key.'_link'}}); } } } @@ -160,7 +162,6 @@ sub readfromfile { if ($token->[2]->{'type'} eq 'zombie') { next; } } - my $url=$token->[2]->{'src'}; my $name=$token->[2]->{'title'}; $name=~s/ \[\((\d+)\,($LONCAPA::username_re)\,($LONCAPA::domain_re)\)\]$//; my $note; @@ -170,9 +171,10 @@ sub readfromfile { &Apache::lonlocal::locallocaltime($1); } $name=~s/\&colon\;/\:/g; - push(@{$resources}, {'url' => $url, + push(@{$resources}, {'url' => $token->[2]->{'src'}, 'title' => $name, - 'note' => $note, }); + 'note' => $note, + 'id' => $token->[2]->{'id'},}); } } } @@ -204,9 +206,6 @@ sub handler { &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, ['acts','mode','readfile','recover','bookmarks']); - # color scheme - my $fileclr = '#ffffe6'; - my $titleclr = '#ddffff'; &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; @@ -227,8 +226,9 @@ function finish_import() { for (var num=0; numprint(<$lt{'fin'} +

$lt{'fin'}

+
    +
+
END } - $r->print("
"); - $r->print("\n"); + $r->print(&Apache::loncommon::start_data_table() + .&Apache::loncommon::start_data_table_header_row()); if (($env{'form.readfile'}) || ($env{'form.bookmarks'})) { - $r->print("\n"); + $r->print("\n"); } else { - $r->print("\n"); + $r->print("\n"); } - $r->print("\n"); - $r->print("\n"); + $r->print("\n"); + $r->print(""); + $r->print(&Apache::loncommon::end_data_table_header_row() + ."\n"); } else { $r->print(&Apache::loncommon::start_page(undef,$js, {'only_body' => 1})); @@ -386,30 +392,35 @@ END $ctr++; my $iconname=&Apache::loncommon::icon($resource->{'url'}); if (($clen > 1) || ($env{'form.readfile'}) || ($env{'form.bookmarks'})) { - $r->print(""); unless (($env{'form.readfile'}) || ($env{'form.bookmarks'})) { - $r->print(""); } - $r->print("\n"); + $r->print("" + .&Apache::loncommon::end_data_table_row() + ."\n"); } } if (($clen > 1) || ($env{'form.readfile'}) || ($env{'form.bookmarks'})) { - $r->print("
$lt{'in'}$lt{'in'}$lt{'co'}$lt{'co'}$lt{'ti'}$lt{'pa'}
$lt{'ti'}$lt{'pa'}
"); + $r->print(&Apache::loncommon::start_data_table_row() + .""); if (($env{'form.readfile'}) || ($env{'form.bookmarks'})) { $r->print(&checkbox($ctr-1)); } else { $r->print(&movers($clen,$ctr)); } } - $r->print(&hidden($ctr-1,$resource->{'title'},$resource->{'url'})); + $r->print(&hidden($ctr-1,$resource->{'title'},$resource->{'url'}, + $resource->{'id'})); if (($clen > 1) || ($env{'form.readfile'}) || ($env{'form.bookmarks'})) { $r->print("". + $r->print("". &select_box($clen,$ctr). ""); + $r->print(""); $r->print(""); - $r->print(""); - $r->print($resource->{'title'}.$resource->{'notes'}."\n"); - $r->print($resource->{'url'}."
"); + $r->print($resource->{'title'}.$resource->{'notes'}."\n"); + $r->print($resource->{'url'}."
"); + $r->print(&Apache::loncommon::end_data_table() + .""); } else { $r->print(< @@ -425,12 +436,13 @@ END # --------------------------------------- Hidden values (returns scalar string) sub hidden { - my ($sel,$title,$filelink) = @_; - my $string = ''; + my ($sel,$title,$filelink,$id) = @_; + my $string = ''; $filelink=~s|^/ext/|http://|; $string .= ''; + &escape($filelink).'" />'; + $string .= ''; return $string; } @@ -483,3 +495,30 @@ sub checkbox { 1; __END__ + +=pod + +=head1 NAME + +Apache::groupsort.pm + +=head1 SYNOPSIS + +Implements a second phase of importing +multiple resources into the RAT. Allows for +reordering the sequence of resources + +This is part of the LearningOnline Network with CAPA project +described at http://www.lon-capa.org. + + +=head1 NOTABLE SUBROUTINES + +=over + +=item + +=back + +=cut +