<%
#<!-- $Id: cust_pay.cgi,v 1.7 2001-12-26 02:33:30 ivan Exp $ -->

use strict;
use vars qw( $cgi $link $linknum $p1 $_date $payby $payinfo $paid );
use Date::Format;
use CGI;
use CGI::Carp qw(fatalsToBrowser);
use FS::Conf;
use FS::UID qw(cgisuidsetup);
use FS::CGI qw(header popurl ntable);

my $conf = new FS::Conf;

my $countrydefault = $conf->config('countrydefault') || 'US';

$cgi = new CGI;
cgisuidsetup($cgi);

if ( $cgi->param('error') ) {
  $link = $cgi->param('link');
  $linknum = $cgi->param('linknum');
  $paid = $cgi->param('paid');
  $payby = $cgi->param('payby');
  $payinfo = $cgi->param('payinfo');
} elsif ($cgi->keywords) {
  my($query) = $cgi->keywords;
  $query =~ /^(\d+)$/;
  $link = 'invnum';
  $linknum = $1;
  $paid = '';
  $payby = 'BILL';
  $payinfo = "";
} elsif ( $cgi->param('custnum')  =~ /^(\d+)$/ ) {
  $link = 'custnum';
  $linknum = $1;
  $paid = '';
  $payby = 'BILL';
  $payinfo = '';
} else {
  die "illegal query ". $cgi->keywords;
}
$_date = time;

$p1 = popurl(1);
print header("Enter payment", '');

print qq!<FONT SIZE="+1" COLOR="#ff0000">Error: !, $cgi->param('error'),
      "</FONT>"
  if $cgi->param('error');

print <<END, ntable("#cccccc",2);
    <FORM ACTION="${p1}process/cust_pay.cgi" METHOD=POST>
    <INPUT TYPE="hidden" NAME="link" VALUE="$link">
    <INPUT TYPE="hidden" NAME="linknum" VALUE="$linknum">
END

my $custnum;
if ( $link eq 'invnum' ) {

  my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
    or die "unknown invnum $linknum";
  print "Invoice #<B>$linknum</B>". ntable("#cccccc",2).
        '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
        time2str("%D", $cust_bill->_date). '</TD></TR>'.
        '<TR><TD ALIGN="right" VALIGN="top">Items</TD><TD BGCOLOR="#ffffff">';
  foreach ( $cust_bill->cust_bill_pkg ) { #false laziness with FS::cust_bill
    if ( $_->pkgnum ) {

      my($cust_pkg)=qsearchs('cust_pkg', { 'pkgnum', $_->pkgnum } );
      my($part_pkg)=qsearchs('part_pkg',{'pkgpart'=>$cust_pkg->pkgpart});
      my($pkg)=$part_pkg->pkg;

      if ( $_->setup != 0 ) {
        print "$pkg Setup<BR>"; # $money_char. sprintf("%10.2f",$_->setup);
        print join('<BR>',
          map { "  ". $_->[0]. ": ". $_->[1] } $cust_pkg->labels
        ). '<BR>';
      }

      if ( $_->recur != 0 ) {
        print
          "$pkg (" . time2str("%x",$_->sdate) . " - " .
                                time2str("%x",$_->edate) . ")<BR>";
          #$money_char. sprintf("%10.2f",$_->recur)
        print join('<BR>',
          map { '--->'. $_->[0]. ": ". $_->[1] } $cust_pkg->labels
        ). '<BR>';
      }

    } else { #pkgnum Tax
      print "Tax<BR>" # $money_char. sprintf("%10.2f",$_->setup)
        if $_->setup != 0;
    }

  }
  print '</TD></TR></TABLE>';

  $custnum = $cust_bill->custnum;

} elsif ( $link eq 'custnum' ) {
  $custnum = $linknum;
}

print "<BR><BR>Customer #<B>$custnum</B>". ntable('#e8e8e8');
my $cust_main = qsearchs('cust_main', { 'custnum' => $custnum } )
  or die "unknown custnum $custnum";

print '<TR><TD>'. ntable("#cccccc",2).
      '<TR><TD ALIGN="right" VALIGN="top">Billing</TD><TD BGCOLOR="#ffffff">'.
      $cust_main->getfield('last'). ', '. $cust_main->first. '<BR>';
print $cust_main->company. '<BR>' if $cust_main->company;
print $cust_main->address1. '<BR>';
print $cust_main->address2. '<BR>' if $cust_main->address2;
print $cust_main->city. ', '. $cust_main->state. '  '. $cust_main->zip. '<BR>';
print $cust_main->country. '<BR>' if $cust_main->country
                                     && $cust_main->country ne $countrydefault;

print '</TD>'.
      '</TR></TABLE></TD>';

if ( defined $cust_main->dbdef_table->column('ship_last') ) {

  my $pre = $cust_main->ship_last ? 'ship_' : '';

  print '<TD>'. ntable("#cccccc",2).
        '<TR><TD ALIGN="right" VALIGN="top">Service</TD><TD BGCOLOR="#ffffff">'.
        $cust_main->get("${pre}last"). ', '.
        $cust_main->get("${pre}first"). '<BR>';
  print $cust_main->get("${pre}company"). '<BR>'
    if $cust_main->get("${pre}company");
  print $cust_main->get("${pre}address1"). '<BR>';
  print $cust_main->get("${pre}address2"). '<BR>'
    if $cust_main->get("${pre}address2");
  print $cust_main->get("${pre}city"). ', '.
        $cust_main->get("${pre}state"). '  '.
        $cust_main->get("${pre}ship_zip"). '<BR>';
  print $cust_main->get("${pre}country"). '<BR>'
    if $cust_main->get("${pre}country")
       && $cust_main->get("${pre}country") ne $countrydefault;

  print '</TD>'.
        '</TR></TABLE></TD>';
}

print '</TR></TABLE>';


print '<BR><BR>Payment'. ntable("#cccccc", 2).
      '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
      time2str("%D",$_date).  '</TD></TR>'.
      qq!<INPUT TYPE="hidden" NAME="_date" VALUE="$_date">!;

print qq!<TR><TD ALIGN="right">Amount</TD><TD BGCOLOR="#ffffff">\$<INPUT TYPE="text" NAME="paid" VALUE="$paid" SIZE=8 MAXLENGTH=8></TD></TR>!;

print qq!<TR><TD ALIGN="right">Payby</TD><TD BGCOLOR="#ffffff">$payby</TD></TR><INPUT TYPE="hidden" NAME="payby" VALUE="$payby">!;

#payinfo (check # now as payby="BILL" hardcoded.. what to do later?)
print qq!<TR><TD ALIGN="right">Check #</TD><TD BGCOLOR="#ffffff"><INPUT TYPE="text" NAME="payinfo" VALUE="$payinfo"></TD></TR>!;

#paybatch
print qq!<INPUT TYPE="hidden" NAME="paybatch" VALUE="">!;

print <<END;
</TABLE>
<BR>
<INPUT TYPE="submit" VALUE="Post payment">
END

print <<END;

    </FORM>
  </BODY>
</HTML>
END

%>