diff options
author | ivan <ivan> | 2005-06-09 22:40:10 +0000 |
---|---|---|
committer | ivan <ivan> | 2005-06-09 22:40:10 +0000 |
commit | 0402f78ff052d950bc9fd4e4845b7d81d2196c47 (patch) | |
tree | 19bc13239867838c92548dfce076063f66cd7dd5 /FS | |
parent | 9788b10d423bb3e4c16989b08bcce6f1a78f3d89 (diff) |
advanced invoice serach, groundwork to add reprint/fax/email links to invoice search results
Diffstat (limited to 'FS')
-rw-r--r-- | FS/FS/cust_bill.pm | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/FS/FS/cust_bill.pm b/FS/FS/cust_bill.pm index 7d104117f..0a00de701 100644 --- a/FS/FS/cust_bill.pm +++ b/FS/FS/cust_bill.pm @@ -2114,6 +2114,98 @@ sub _items_payments { =back +=head1 SUBROUTINES + +=over 4 + +=item reprint + +=cut + +sub process_reprint { + process_re_X('print', @_); +} + +=item reemail + +=cut + +sub process_reemail { + process_re_X('email', @_); +} + +=item refax + +=cut + +sub process_refax { + process_re_X('fax', @_); +} + +use Storable qw(thaw); +use Data::Dumper; +use MIME::Base64; +sub process_re_X { + my( $method, $job ) = ( shift, shift ); + + my $param = thaw(decode_base64(shift)); + warn Dumper($param) if $DEBUG; + + re_X( + $method, + $param->{'beginning'}, + $param->{'ending'}, + $param->{'failed'}, + $job, + ); + +} + +sub re_X { + my($method, $beginning, $ending, $failed, $job) = @_; + + my $where = " WHERE plan LIKE 'send%'". + " AND cust_bill_event._date >= $beginning". + " AND cust_bill_event._date <= $ending"; + $where .= " AND statustext != '' AND statustext IS NOT NULL" + if $failed; + + my $from = 'LEFT JOIN part_bill_event USING ( eventpart )'; + + my @cust_bill_event = qsearch( 'cust_bill_event', {}, '', $where, '', $from ); + + my( $num, $last, $min_sec ) = (0, time, 5); #progresbar foo + foreach my $cust_bill_event ( @cust_bill_event ) { + + $cust_bill_event->cust_bill->$method( + $cust_bill_event->part_bill_event->templatename + ); + + if ( $job ) { #progressbar foo + $num++; + if ( time - $min_sec > $last ) { + my $error = $job->update_statustext( + int( 100 * $num / scalar(@cust_bill_event) ) + ); + die $error if $error; + $last = time; + } + } + + } + + #this doesn't work, but it would be nice + #if ( $job ) { #progressbar foo + # my $error = $job->update_statustext( + # scalar(@cust_bill_event). " invoices re-${method}ed" + # ); + # die $error if $error; + #} + +} + +=back + =head1 BUGS The delete method. |