summaryrefslogtreecommitdiff
path: root/httemplate/search/elements/search.html
diff options
context:
space:
mode:
authorivan <ivan>2007-08-01 22:26:52 +0000
committerivan <ivan>2007-08-01 22:26:52 +0000
commiteb4ff7f73c5d4bdf74a3472448b5a195598ff4cd (patch)
treebb38241e8c865c3bca861da7749071feeadd2b5b /httemplate/search/elements/search.html
parent32b5d3a31f112a381f0a15ac5e3a2204242f3405 (diff)
event refactor, landing on HEAD!
Diffstat (limited to 'httemplate/search/elements/search.html')
-rw-r--r--httemplate/search/elements/search.html225
1 files changed, 136 insertions, 89 deletions
diff --git a/httemplate/search/elements/search.html b/httemplate/search/elements/search.html
index 7d5e58a3b..5afc3dc20 100644
--- a/httemplate/search/elements/search.html
+++ b/httemplate/search/elements/search.html
@@ -34,7 +34,7 @@
% # 'select' => '*',
% # 'addl_from' => '', #'LEFT JOIN othertable USING ( key )',
% # 'extra_sql' => '', #'AND otherstuff', #'WHERE onlystuff',
-% #
+% # 'order_by' => 'ORDER BY something',
% #
% # },
% # # "select * from tablename";
@@ -54,6 +54,20 @@
% # 'disable_nonefound' => '', # set true to disable the "No matching Xs found"
% # # message
% #
+% # 'disableable' => 1, # set true if this table has a "disabled" field, to
+% # # hide disabled records & have "show disabled" links
+% # 'disabled_statuspos' => 3, #optional position (starting from 0) to insert
+% # #a Status column when showing disabled records
+% # #(query needs to be a qsearch hashref and
+% # # header & fields need to be defined)
+
+% # 'agent_virt' => 1, # set true if this search should be agent-virtualized
+% # 'agent_null_right' => 'Access Right', #opt. right to view global records
+% # 'agent_pos' => 3, #optional position (starting from 0) to insert
+% # #an Agent column
+% # #(query needs to be a qsearch hashref and
+% # # header & fields need to be defined)
+% #
% # #listref - each item is a literal column name (or method) or coderef
% # #if not specified all columns will be shown
% # 'fields' => [
@@ -88,11 +102,11 @@
% # #(can't be used with a literal query)
% # 'disableable' => 1,
%
-% my $DEBUG = 0;
-%
% my(%opt) = @_;
% #warn join(' / ', map { "$_ => $opt{$_}" } keys %opt ). "\n";
%
+% my $curuser = $FS::CurrentUser::CurrentUser;
+%
% my %align = (
% 'l' => 'left',
% 'r' => 'right',
@@ -103,6 +117,90 @@
% $opt{align} = [ map $align{$_}, split(//, $opt{align}) ],
% unless !$opt{align} || ref($opt{align});
%
+% if ( $opt{'agent_virt'} ) {
+%
+% my $agentnums_sql = $curuser->agentnums_sql(
+% 'null_right' => $opt{'agent_null_right'}
+% );
+%
+% $opt{'query'}{'extra_sql'} .=
+% ( $opt{'query'} =~ /WHERE/i ? ' AND ' : ' WHERE ' ).
+% $agentnums_sql;
+% $opt{'count_query'} .=
+% ( $opt{'count_query'} =~ /WHERE/i ? ' AND ' : ' WHERE ' ).
+% $agentnums_sql;
+%
+% if ( $opt{'agent_pos'} || $opt{'agent_pos'} eq '0'
+% and scalar($curuser->agentnums) > 1 ) {
+% #false laziness w/statuspos above
+% my $pos = $opt{'agent_pos'};
+%
+% foreach my $att (qw( align style color size )) {
+% $opt{$att} ||= [ map '', @{ $opt{'fields'} } ];
+% }
+%
+% splice @{ $opt{'header'} }, $pos, 0, 'Agent';
+% splice @{ $opt{'align'} }, $pos, 0, 'c';
+% splice @{ $opt{'style'} }, $pos, 0, '';
+% splice @{ $opt{'size'} }, $pos, 0, '';
+% splice @{ $opt{'fields'} }, $pos, 0,
+% sub { $_[0]->agentnum ? $_[0]->agent->agent : '(global)'; };
+% splice @{ $opt{'color'} }, $pos, 0, '';
+% splice @{ $opt{'links'} }, $pos, 0, '' #[ 'agent link?', 'agentnum' ]
+% if $opt{'links'};
+%
+% }
+%
+% }
+%
+% if ( $opt{'disableable'} ) {
+%
+% unless ( $cgi->param('showdisabled') ) { #modify searches
+%
+% $opt{'query'}{'hashref'}{'disabled'} = '';
+% $opt{'query'}{'extra_sql'} =~ s/^\s*WHERE/ AND/i;
+%
+% $opt{'count_query'} .=
+% ( $opt{'count_query'} =~ /WHERE/i ? ' AND ' : ' WHERE ' ).
+% "( disabled = '' OR disabled IS NULL )";
+%
+% } elsif ( $opt{'disabled_statuspos'}
+% || $opt{'disabled_statuspos'} eq '0' ) { #add status column
+%
+% my $pos = $opt{'disabled_statuspos'};
+%
+% foreach my $att (qw( align style color size )) {
+% $opt{$att} ||= [ map '', @{ $opt{'fields'} } ];
+% }
+%
+% splice @{ $opt{'header'} }, $pos, 0, 'Status';
+% splice @{ $opt{'align'} }, $pos, 0, 'c';
+% splice @{ $opt{'style'} }, $pos, 0, 'b';
+% splice @{ $opt{'size'} }, $pos, 0, '';
+% splice @{ $opt{'fields'} }, $pos, 0,
+% sub { shift->disabled ? 'DISABLED' : 'Active'; };
+% splice @{ $opt{'color'} }, $pos, 0,
+% sub { shift->disabled ? 'FF0000' : '00CC00'; };
+% splice @{ $opt{'links'} }, $pos, 0, ''
+% if $opt{'links'};
+% }
+%
+% #add show/hide disabled links
+% my $items = $opt{'name'} || PL($opt{'name_singular'});
+% if ( $cgi->param('showdisabled') ) {
+% $cgi->param('showdisabled', 0);
+% $opt{'html_posttotal'} .=
+% '( <a href="'. $cgi->self_url. qq!">hide disabled $items</a> )!;
+% $cgi->param('showdisabled', 1);
+% } else {
+% $cgi->param('showdisabled', 1);
+% $opt{'html_posttotal'} .=
+% '( <a href="'. $cgi->self_url. qq!">show disabled $items</a> )!;
+% $cgi->param('showdisabled', 0);
+% }
+%
+% }
+%
% my $type = '';
% my $limit = '';
% my($confmax, $maxrecords, $total, $offset, $count_arrayref);
@@ -146,61 +244,6 @@
%
% }
%
-% #disableable handling
-% my $posttotal = '';
-% if ( $opt{disableable} ) {
-%
-% my $name= $opt{'name_singular'} ? PL($opt{'name_singular'}) : $opt{'name'};
-%
-% if ( $cgi->param('showdisabled') ) {
-% $cgi->param('showdisabled', 0);
-% $posttotal= '( <a href="'. $cgi->self_url. '">'.
-% "hide disabled $name</a> )";
-% $cgi->param('showdisabled', 1);
-% } else {
-% $cgi->param('showdisabled', 1);
-% $posttotal= '( <a href="'. $cgi->self_url. '">'.
-% "show disabled $name</a> )";
-% $cgi->param('showdisabled', 0);
-% }
-%
-% if ( $cgi->param('showdisabled') ) {
-%
-% my $offset = $opt{disableable};
-%
-% splice @{ $opt{header} }, $offset, 0, 'Status';
-%
-% splice @{ $opt{fields} }, $offset, 0,
-% sub { shift->disabled ? 'DISABLED' : 'Active' };
-%
-% if ( $opt{links} && scalar( @{ $opt{links} } ) ) {
-% splice @{ $opt{links} }, $offset, 0, '';
-% }
-%
-% if ( $opt{align} && scalar( @{ $opt{align} } ) ) {
-% splice @{ $opt{align} }, $offset, 0, 'center';
-% }
-%
-% unless ( $opt{color} && scalar( @{ $opt{color} } ) ) {
-% #$opt{color} = [ map { '000000'; } @{$opt{header}} ];
-% $opt{color} = [ map { ''; } @{$opt{header}} ];
-% }
-% splice @{ $opt{color} }, $offset, 0,
-% sub { shift->disabled ? 'FF0000' : '00CC00'; };
-%
-% if ( $opt{size} && scalar( @{ $opt{size} } ) ) {
-% splice @{ $opt{size} }, $offset, 0, '';
-% }
-%
-% unless ( $opt{style} && scalar( @{ $opt{style} } ) ) {
-% $opt{style} = [ map { ''; } @{$opt{header}} ];
-% }
-% splice @{ $opt{style} }, $offset, 0, 'b';
-%
-% }
-%
-% }
-%
% # run the query
%
% my $header = $opt{header};
@@ -214,17 +257,15 @@
% }
%
% #eval "use FS::$opt{'query'};";
-% $rows = [ qsearch(
-% $opt{'query'}->{'table'},
-% $opt{'query'}->{'hashref'} || {},
-% $opt{'query'}->{'select'},
-% $opt{'query'}->{'extra_sql'}. " $limit",
-% '',
-% (exists($opt{'query'}->{'addl_from'}) ? $opt{'query'}->{'addl_from'} : '')
-% ) ];
-%
+% $rows = [ qsearch({
+% 'select' => $opt{'query'}->{'select'},
+% 'table' => $opt{'query'}->{'table'},
+% 'addl_from' => (exists($opt{'query'}->{'addl_from'}) ? $opt{'query'}->{'addl_from'} : ''),
+% 'hashref' => $opt{'query'}->{'hashref'} || {},
+% 'extra_sql' => $opt{'query'}->{'extra_sql'},
+% 'order_by' => $opt{'query'}->{'order_by'}. " $limit",
+% }) ];
% } else {
-%
% my $sth = dbh->prepare("$opt{'query'} $limit")
% or die "Error preparing $opt{'query'}: ". dbh->errstr;
% $sth->execute
@@ -234,15 +275,8 @@
% $rows = $sth->fetchall_arrayref;
%
% $header ||= $sth->{NAME};
-%
% }
%
-% warn scalar(@$rows). ' rows returned from '.
-% ( ref($opt{'query'}) ? 'qsearch query' : 'literal SQL query' )
-% if $DEBUG || $opt{'debug'};
-%
-% # display the results - csv, xls or html
-%
% if ( $type eq 'csv' ) {
%
% #http_header('Content-Type' => 'text/comma-separated-values' ); #IE chokes
@@ -430,8 +464,6 @@
% $cgi->param('maxrecords', $maxrecords);
% }
- <% $posttotal %>
-
<% defined($opt{'html_posttotal'})
? ( ref($opt{'html_posttotal'})
? &{$opt{'html_posttotal'}}()
@@ -522,7 +554,7 @@
%
% my $tableref = $_;
%
-% '<TABLE CLASS="inv" CELLSPACING=0 CELLPADDING=0>'.
+% '<TABLE CLASS="inv" CELLSPACING=0 CELLPADDING=0 WIDTH="100%">'.
%
% join('', map {
%
@@ -532,22 +564,37 @@
%
% join('', map {
%
-% my $element = $_;
+% my $e = $_;
+%
+% '<TD '.
+% join(' ', map {
+% uc($_).'="'. $e->{$_}. '"';
+% }
+% grep exists($e->{$_}),
+% qw( align bgcolor colspan rowspan
+% style valign width )
+% ).
+% '>'.
%
-% '<TD'.
-% ( $element->{'align'}
-% ? ' ALIGN="'. $element->{'align'}. '"'
+% ( $e->{'link'}
+% ? '<A HREF="'. $e->{'link'}. '">'
% : ''
-% ). '>'.
-% ( $element->{'link'}
-% ? '<A HREF="'. $element->{'link'}.'">'
+% ).
+% ( $e->{'size'}
+% ? '<FONT SIZE="'.uc($e->{'size'}).'">'
+% : ''
+% ).
+% ( $e->{'data_style'}
+% ? '<'. uc($e->{'data_style'}). '>'
% : ''
% ).
-% $element->{'data'}.
-% ( $element->{'link'}
-% ? '</A>'
+% $e->{'data'}.
+% ( $e->{'data_style'}
+% ? '</'. uc($e->{'data_style'}). '>'
% : ''
% ).
+% ( $e->{'size'} ? '</FONT>' : '' ).
+% ( $e->{'link'} ? '</A>' : '' ).
% '</td>';
%
% } @$rowref ).
@@ -620,7 +667,7 @@
% } else {
% foreach ( @$row ) {
- <TD CLASS="grid" BGCOLOR="<% $bgcolor %>"><% $_ %></TD>
+ <TD CLASS="grid" BGCOLOR="$bgcolor"><% $_ %></TD>
% }
% }