This commit was generated by cvs2svn to compensate for changes in r12472,
[freeside.git] / httemplate / misc / xmlhttp-cust_main-search.cgi
1 % if ( $sub eq 'custnum_search' ) { 
2 %   my $custnum = $cgi->param('arg');
3 %   my $return = [];
4 %   if ( $custnum =~ /^(\d+)$/ ) {
5 %       $return = findbycustnum($1,0);
6 %       $return = findbycustnum($1,1) if(!scalar(@$return));
7 %   }
8 <% objToJson($return) %>
9 % } elsif ( $sub eq 'smart_search' ) {
10 %
11 %   my $string = $cgi->param('arg');
12 %   my @cust_main = smart_search( 'search' => $string,
13 %                                 'no_fuzzy_on_exact' => 1, #pref?
14 %                               );
15 %   my $return = [ map [ $_->custnum, $_->name, $_->balance, $_->ucfirst_status, $_->statuscolor ], @cust_main ];
16 %     
17 <% objToJson($return) %>
18 % } elsif ( $sub eq 'invnum_search' ) {
19 %
20 %   my $string = $cgi->param('arg');
21 %   my $inv = qsearchs('cust_bill', { 'invnum' => $string });
22 %   my $return = $inv ? findbycustnum($inv->custnum,0) : [];
23 <% objToJson($return) %>
24 % } 
25 <%init>
26
27 my $conf = new FS::Conf;
28
29 my $sub = $cgi->param('sub');
30
31 sub findbycustnum{
32     my $custnum = shift;
33     my $agent = shift;
34     my $hashref = { 'custnum' => $custnum };
35     $hashref = { 'agent_custid' => $custnum } if $agent;
36     my $c = qsearchs({
37         'table'   => 'cust_main',
38         'hashref' => $hashref,
39         'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,
40                 });
41    return [ $c->custnum, $c->name, $c->balance, $c->ucfirst_status, $c->statuscolor ] 
42         if $c;
43    [];
44 }
45 </%init>