1 <% $exporttext %><%init>
3 #http_header('Content-Type' => 'text/comma-separated-values' ); #IE chokes
4 http_header('Content-Type' => 'text/plain' ); # not necessarily correct...
8 if ( $cgi->param('batchnum') =~ /^(\d+)$/ ) {
11 die "No batch number (bad URL) \n";
15 if ( $cgi->param('gatewaynum') =~ /^(\d+)$/ ) {
16 my $gateway = FS::payment_gateway->by_key($1);
17 die "gatewaynum $1 not found" unless $gateway;
18 $opt{'gateway'} = $gateway;
20 elsif ( $cgi->param('format') =~ /^([\w\- ]+)$/ ) {
24 my $credit_transactions = "EXISTS (SELECT 1 FROM cust_pay_batch WHERE batchnum = $batchnum AND paycode = 'C') AS arecredits";
25 my $pay_batch = qsearchs({ 'select' => "*, $credit_transactions",
26 'table' => 'pay_batch',
27 'hashref' => { batchnum => $batchnum },
29 die "Batch not found: '$batchnum'" if !$pay_batch;
31 if ($pay_batch->{Hash}->{arecredits}) {
32 my $export_format = "FS::pay_batch::".$opt{'format'};
33 die "You are trying to download a credit (batch refund) batch and The format ".$opt{'format'}." can not handle refunds.\n" unless $export_format->can('can_handle_credits');
36 my $exporttext = $pay_batch->export_batch(%opt);
37 unless ($exporttext) {
38 http_header('Content-Type' => 'text/html' );
41 alert('Batch was empty, and has been resolved');
42 window.top.location.href = '${p}search/pay_batch.cgi?magic=_date;open=1;intransit=1;resolved=1';