so Search.tsf and Search.rdf work
[freeside.git] / httemplate / edit / cust_pay.cgi
1 <!-- mason kludge -->
2 <%
3
4 my $conf = new FS::Conf;
5
6 my($link, $linknum, $paid, $payby, $payinfo, $quickpay, $_date); 
7 if ( $cgi->param('error') ) {
8   $link     = $cgi->param('link');
9   $linknum  = $cgi->param('linknum');
10   $paid     = $cgi->param('paid');
11   $payby    = $cgi->param('payby');
12   $payinfo  = $cgi->param('payinfo');
13   $quickpay = $cgi->param('quickpay');
14   $_date    = $cgi->param('_date') ? str2time($cgi->param('_date')) : time;
15 } elsif ($cgi->keywords) {
16   my($query) = $cgi->keywords;
17   $query =~ /^(\d+)$/;
18   $link     = 'invnum';
19   $linknum  = $1;
20   $paid     = '';
21   $payby    = 'BILL';
22   $payinfo  = "";
23   $quickpay = '';
24   $_date    = time;
25 } elsif ( $cgi->param('custnum')  =~ /^(\d+)$/ ) {
26   $link     = 'custnum';
27   $linknum  = $1;
28   $paid     = '';
29   $payby    = 'BILL';
30   $payinfo  = '';
31   $quickpay = $cgi->param('quickpay');
32   $_date    = time;
33 } else {
34   die "illegal query ". $cgi->keywords;
35 }
36
37 my $paybatch = "webui-$_date-$$-". rand() * 2**32;
38
39 %>
40
41 <%=  header("Post payment", '') %>
42
43 <% if ( $cgi->param('error') ) { %>
44 <FONT SIZE="+1" COLOR="#ff0000">Error: <%= $cgi->param('error') %></FONT>
45 <BR><BR>
46 <% } %>
47
48 <%= ntable("#cccccc",2) %>
49
50 <LINK REL="stylesheet" TYPE="text/css" HREF="../elements/calendar-win2k-2.css" TITLE="win2k-2">
51 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar_stripped.js"></SCRIPT>
52 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar-en.js"></SCRIPT>
53 <SCRIPT TYPE="text/javascript" SRC="../elements/calendar-setup.js"></SCRIPT>
54
55 <FORM ACTION="<%= popurl(1) %>process/cust_pay.cgi" METHOD=POST>
56 <INPUT TYPE="hidden" NAME="link" VALUE="<%= $link %>">
57 <INPUT TYPE="hidden" NAME="linknum" VALUE="<%= $linknum %>">
58 <INPUT TYPE="hidden" NAME="quickpay" VALUE="<%= $quickpay %>">
59
60 <% 
61 my $money_char = $conf->config('money_char') || '$';
62 my $custnum;
63 if ( $link eq 'invnum' ) {
64
65   my $cust_bill = qsearchs('cust_bill', { 'invnum' => $linknum } )
66     or die "unknown invnum $linknum";
67   print "Invoice #<B>$linknum</B>". ntable("#cccccc",2).
68         '<TR><TD ALIGN="right">Date</TD><TD BGCOLOR="#ffffff">'.
69         time2str("%D", $cust_bill->_date). '</TD></TR>'.
70         '<TR><TD ALIGN="right" VALIGN="top">Items</TD><TD BGCOLOR="#ffffff">';
71   foreach ( $cust_bill->cust_bill_pkg ) { #false laziness with FS::cust_bill
72     if ( $_->pkgnum ) {
73
74       my($cust_pkg)=qsearchs('cust_pkg', { 'pkgnum', $_->pkgnum } );
75       my($part_pkg)=qsearchs('part_pkg',{'pkgpart'=>$cust_pkg->pkgpart});
76       my($pkg)=$part_pkg->pkg;
77
78       if ( $_->setup != 0 ) {
79         print "$pkg Setup<BR>"; # $money_char. sprintf("%10.2f",$_->setup);
80         print join('<BR>',
81           map { "  ". $_->[0]. ": ". $_->[1] } $cust_pkg->labels
82         ). '<BR>';
83       }
84
85       if ( $_->recur != 0 ) {
86         print
87           "$pkg (" . time2str("%x",$_->sdate) . " - " .
88                                 time2str("%x",$_->edate) . ")<BR>";
89           #$money_char. sprintf("%10.2f",$_->recur)
90         print join('<BR>',
91           map { '--->'. $_->[0]. ": ". $_->[1] } $cust_pkg->labels
92         ). '<BR>';
93       }
94
95     } else { #pkgnum Tax
96       print "Tax<BR>" # $money_char. sprintf("%10.2f",$_->setup)
97         if $_->setup != 0;
98     }
99
100   }
101   print '</TD></TR></TABLE><BR><BR>';
102
103   $custnum = $cust_bill->custnum;
104
105 } elsif ( $link eq 'custnum' ) {
106   $custnum = $linknum;
107 }
108 %>
109
110 <%= small_custview($custnum, $conf->config('countrydefault')) %>
111
112 <INPUT TYPE="hidden" NAME="payby" VALUE="<%= $payby %>">
113
114 <BR><BR>
115 Payment
116 <%= ntable("#cccccc", 2) %>
117 <TR>
118   <TD ALIGN="right">Date</TD>
119   <TD COLSPAN=2>
120     <INPUT TYPE="text" NAME="_date" ID="_date_text" VALUE="<%= time2str("%m/%d/%Y %r",$_date) %>">
121     <IMG SRC="../images/calendar.png" ID="_date_button" STYLE="cursor: pointer" TITLE="Select date">
122   </TD>
123 </TR>
124 <SCRIPT TYPE="text/javascript">
125   Calendar.setup({
126     inputField: "_date_text",
127     ifFormat:   "%m/%d/%Y",
128     button:     "_date_button",
129     align:      "BR"
130   });
131 </SCRIPT>
132 <TR>
133   <TD ALIGN="right">Amount</TD>
134   <TD BGCOLOR="#ffffff" ALIGN="right"><%= $money_char %></TD>
135   <TD><INPUT TYPE="text" NAME="paid" VALUE="<%= $paid %>" SIZE=8 MAXLENGTH=8></TD>
136 </TR>
137 <TR>
138   <TD ALIGN="right">Check #</TD>
139   <TD COLSPAN=2><INPUT TYPE="text" NAME="payinfo" VALUE="<%= $payinfo %>" SIZE=10></TD>
140 </TR>
141 <TR>
142   <TD ALIGN="right">Auto-apply<BR>to invoices</TD>
143   <TD COLSPAN=2><SELECT NAME="apply"><OPTION VALUE="yes" SELECTED>yes<OPTION>no</SELECT></TD>
144 </TR>
145
146 </TABLE>
147
148 <INPUT TYPE="hidden" NAME="paybatch" VALUE="<%= $paybatch %>">
149
150 <BR>
151 <INPUT TYPE="submit" VALUE="Post payment">
152     </FORM>
153   </BODY>
154 </HTML>