--- loncom/interface/lonsearchcat.pm 2024/07/04 17:21:22 1.331.4.17
+++ loncom/interface/lonsearchcat.pm 2014/02/23 22:15:27 1.343
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# Search Catalog
#
-# $Id: lonsearchcat.pm,v 1.331.4.17 2024/07/04 17:21:22 raeburn Exp $
+# $Id: lonsearchcat.pm,v 1.343 2014/02/23 22:15:27 raeburn Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -78,7 +78,6 @@ use Apache::lonnavmaps;
use Apache::lonindexer();
use Apache::lonwishlist();
use LONCAPA;
-use Time::HiRes qw(sleep);
######################################################################
######################################################################
@@ -144,7 +143,7 @@ sub handler {
## this once, so the pause indicator is deleted
##
if (exists($env{'form.pause'})) {
- sleep(0.1);
+ sleep(1);
delete($env{'form.pause'});
}
##
@@ -433,7 +432,7 @@ sub hidden_field {
=pod
=over 4
-
+
=item &print_basic_search_form()
Prints the form for the basic search. Sorry the name is so cryptic.
@@ -479,31 +478,14 @@ sub setup_basic_search {
.&mt('use related words')
.'';
- my $anydom = 1;
- if ($area eq 'res') {
- unless (&Apache::lonnet::allowed('bre','/res/') eq 'F') {
- $anydom = 0;
- }
- }
- my $singledom;
- my ($disabled,$checked);
- if ($anydom) {
- $singledom = $r->dir_config('lonDefDomain');
- if ($env{'form.domains'} eq $singledom) {
- $checked = 1;
- }
- } else {
- $singledom = $env{'user.domain'};
- $disabled = ' disabled="disabled"';
- $checked = 1;
- }
$onlysearchdomain = '';
$adv_search_link = '{'url'});
# Check for priv
- if ($Metadata->{'copyright'} eq 'priv') {
- unless (($env{'user.name'} eq $resname) &&
- ($env{'user.domain'} eq $resdom)) {
- return 0;
- }
+ if (($Metadata->{'copyright'} eq 'priv') &&
+ (($env{'user.name'} ne $resname) &&
+ ($env{'user.domain'} ne $resdom))) {
+ return 0;
}
# Check for domain
if (($Metadata->{'copyright'} eq 'domain') &&
@@ -2099,7 +2064,7 @@ sub print_sort_form {
END
- my $start_page = &Apache::loncommon::start_page('Results');
+ my $start_page = &Apache::loncommon::start_page('Results',$js);
my $breadcrumbs=
&Apache::lonhtmlcommon::breadcrumbs('Searching','Searching',
$env{'form.catalogmode'} ne 'import');
@@ -2263,21 +2228,8 @@ SCRIPT
$r->rflush();
}
-sub reload_result_frame {
- my ($r) = @_;
- my $newloc = '/adm/searchcat?phase=results&persistent_db_id='.
- $env{'form.persistent_db_id'};
- $r->print(<
-SCRIPT
-
- $r->rflush();
-}
-
{
- my $max_time = 60; # seconds for the search to complete
+ my $max_time = 300; # seconds for the search to complete
my $start_time = 0;
my $last_time = 0;
@@ -2458,8 +2410,6 @@ END
##
## Prepare for the big loop.
my $hitcountsum;
- my $oldhitcountsum;
- my $displaycount;
my %matches;
my $server;
my $status;
@@ -2506,7 +2456,7 @@ END
&update_status($r,
&mt('waiting on [_1]',join(' ',keys(%Server_status))));
}
- sleep(0.1);
+ sleep(1);
}
#
# Loop through the servers we have contacted but do not
@@ -2559,8 +2509,8 @@ END
if ($area eq 'portfolio') {
next if (defined($matches{$Fields{'url'}}));
- # Skip unless access control set to public or passphrase-protected
- next unless (($Fields{'scope'} eq 'public') || ($Fields{'scope'} eq 'guest'));
+ # Skip if inaccessible
+ next if (!&Apache::lonnet::portfolio_access($Fields{'url'}));
$matches{$Fields{'url'}} = 1;
}
#
@@ -2582,15 +2532,7 @@ END
delete($Server_status{$server});
}
last if ($connection->aborted());
- if ($oldhitcountsum < $hitcountsum) {
- &update_count_status($r,$hitcountsum);
- if (($hitcountsum <= $env{'form.show'}) ||
- (!$displaycount && $hitcountsum)) {
- reload_result_frame($r);
- $displaycount = $hitcountsum;
- }
- $oldhitcountsum = $hitcountsum;
- }
+ &update_count_status($r,$hitcountsum);
}
last if ($connection->aborted());
&update_seconds($r);
@@ -2684,8 +2626,6 @@ sub display_results {
if ($env{'form.catalogmode'} eq 'import') {
if (! tie(%groupsearch_db,'GDBM_File',$diropendb,
&GDBM_WRCREAT(),0640)) {
- # NOTE: this can happen when a previous request to searchcat?phase=results gets interrupted
- # (%groupsearch_db is not untied)
$r->print(' '.
&mt('Unable to save import results.').
' '.&mt('There are currently no results.').' '.&mt('There are currently no results.').''.' '.
''.$values{'title'}."\n".
+ 'target="preview">'.$values{'title'}."\n".
&display_tools($values{'title'}, $jumpurl).
"
\n".
''.$values{'author'}.','.
@@ -3518,7 +3427,7 @@ sub summary_view {
my $link = '
'.&display_url($jumpurl,1).'
';
$result .=
''.$values{'title'}.''.
+ ' target="preview">'.$values{'title'}.''.
&display_tools($values{'title'}, $jumpurl).<
@@ -3564,7 +3473,7 @@ sub compact_view {
}
$jumpurl = &HTML::Entities::encode($jumpurl,'<>&"');
$result.=' '.
- ''.
+ ''.
&HTML::Entities::encode($values{'title'},'<>&"').' '.
&display_tools($values{'title'}, $jumpurl).
$link.' '.$values{'author'}.' ('.$values{'domain'}.')';
@@ -3580,17 +3489,12 @@ sub display_url {
} elsif ($url=~m{^(http://|/uploaded/)}) {
$link=''.$url.'';
} else {
- # replace the links to open in a new window
- # (because the search opens in a new window, it gets
- # confusing when the links open a tab in the
- # parent window; ideally we should not force windows)
- my $onclick = " onclick=\"window.open(this.href, '_blank', 'toolbar=1,location=1,menubar=0');return false;\"";
$link=&Apache::lonhtmlcommon::crumbs(
$url,
'preview',
'',
- '',
- $skiplast,$onclick).' ';
+ (($env{'form.catalogmode'} eq 'import')?'parent.statusframe.document.forms.statusform':''),
+ $skiplast).' ';
}
return $link;
}
@@ -3896,7 +3800,7 @@ Cleans the global %groupsearch_db by rem
######################################################################
sub start_fresh_session {
delete $groupsearch_db{'mode_catalog'};
- foreach (keys(%groupsearch_db)) {
+ foreach (keys %groupsearch_db) {
if ($_ =~ /^pre_/) {
delete $groupsearch_db{$_};
}