1 <% include("/elements/header-popup.html", 'One-time charge entry', '',
2 ( $cgi->param('error') ? '' : 'onload="addRow()"' ),
6 <% include('/elements/error.html') %>
8 <SCRIPT TYPE="text/javascript">
10 function enable_quick_charge () {
11 if ( document.QuickChargeForm.amount.value
12 && document.QuickChargeForm.pkg.value ) {
13 document.QuickChargeForm.submit.disabled = false;
15 document.QuickChargeForm.submit.disabled = true;
19 function enable_quick_charge_desc () {
20 if ( document.QuickChargeForm.amount.value && document.QuickChargeForm.pkg.value ) {
21 document.QuickChargeForm.submit.disabled = false;
23 document.QuickChargeForm.submit.disabled = true;
27 function enable_quick_charge_amount () {
28 if ( document.QuickChargeForm.amount.value && document.QuickChargeForm.pkg.value ) {
29 document.QuickChargeForm.submit.disabled = false;
31 document.QuickChargeForm.submit.disabled = true;
35 function validate_quick_charge () {
36 var pkg = document.QuickChargeForm.pkg.value;
37 var pkg_regex = /^([\w \!\@\#\$\%\&\(\)\-\+\;\:\'\"\,\.\?\/\=\[\]]*)$/ ;
38 var amount = document.QuickChargeForm.amount.value;
39 var amount_regex = /^\s*\$?\s*(\d+(\.\d{1,2})?)\s*$/ ;
42 if ( ! amount_regex.test(amount) ) {
43 alert('Illegal amount - enter an amount to charge, for example, "5" or "43" or "21.46".');
46 if ( String(pkg).length < 1 ) {
49 if ( ! pkg_regex.test(pkg) ) {
53 for (i=0; i < rownum; i++) {
54 if (! eval('pkg_regex.test(document.QuickChargeForm.description' + i + '.value)')){
64 alert('Enter a description for the one-time charge');
68 alert('Illegal description - spaces, letters, numbers, and the following punctuation characters are allowed: . , ! ? @ # $ % & ( ) - + ; : ' + "'" + ' " = [ ]' );
74 <FORM ACTION="process/quick-charge.cgi" NAME="QuickChargeForm" METHOD="POST" onsubmit="document.QuickChargeForm.submit.disabled=true;return validate_quick_charge();">
76 <INPUT TYPE="hidden" NAME="custnum" VALUE="<% $custnum %>">
78 <TABLE ID="QuickChargeTable" BGCOLOR="#cccccc" BORDER=0 CELLSPACING=0 STYLE="background-color: #cccccc">
81 <TD ALIGN="right">Amount: </TD>
83 $<INPUT TYPE="text" NAME="amount" SIZE=6 VALUE="<% $amount %>" onChange="enable_quick_charge()" onKeyPress="enable_quick_charge_amount()">
87 % if ( $conf->exists('invoice-unitprice') ) {
89 <TD ALIGN="right">Quantity: </TD>
91 <INPUT TYPE="text" NAME="quantity" SIZE=4 VALUE="<% $quantity %>">
96 <% include('/elements/tr-select-pkg_class.html', 'curr_value' => $cgi->param('classnum') ) %>
98 <% include('/elements/tr-select-taxclass.html', 'curr_value' => $cgi->param('taxclass') ) %>
101 <TD>Description:</TD>
103 <INPUT TYPE="text" NAME="pkg" SIZE="60" MAXLENGTH="65" VALUE="<% $pkg %>" onChange="enable_quick_charge()" onKeyPress="enable_quick_charge_desc()">
109 <TD><FONT SIZE="-1">Optional additional description: </FONT></TD>
113 % if ( $cgi->param('error') ) {
114 % my $param = $cgi->Vars;
116 % for ( $row = 0; exists($param->{"description$row"}); $row++ ) {
121 <INPUT TYPE="text" NAME="description<% $row %>" SIZE="60" MAXLENGTH="65" VALUE="<% $param->{"description$row"} |h %>" rownum="<% $row %>" onkeyup = "possiblyAddRow;" >
131 <INPUT TYPE="submit" ID="submit" NAME="submit" VALUE="Add one-time charge" <% $cgi->param('error') ? '' :' DISABLED' %>>
136 <SCRIPT TYPE="text/javascript">
138 var rownum = <% $row %>;
140 function possiblyAddRow() {
141 if ( ( rownum - this.getAttribute('rownum') ) == 1 ) {
148 var table = document.getElementById('QuickChargeTable');
149 var tablebody = table.getElementsByTagName('tbody').item(0);
151 var row = document.createElement('TR');
153 var empty_cell = document.createElement('TD');
154 row.appendChild(empty_cell);
156 var description_cell = document.createElement('TD');
158 var description_input = document.createElement('INPUT');
159 description_input.setAttribute('name', 'description'+rownum);
160 description_input.setAttribute('id', 'description'+rownum);
161 description_input.setAttribute('size', 60);
162 description_input.setAttribute('maxLength', 65);
163 description_input.setAttribute('rownum', rownum);
164 description_input.onkeyup = possiblyAddRow;
165 description_cell.appendChild(description_input);
167 row.appendChild(description_cell);
169 tablebody.appendChild(row);
182 unless $FS::CurrentUser::CurrentUser->access_right('One-time charge');
184 my $conf = new FS::Conf;
186 $cgi->param('custnum') =~ /^(\d+)$/ or die 'illegal custnum';
190 if ( $cgi->param('amount') =~ /^\s*\$?\s*(\d+(\.\d{1,2})?)\s*$/ ) {
195 if ( $cgi->param('quantity') =~ /^\s*(\d+)\s*$/ ) {
199 $cgi->param('pkg') =~ /^([\w \!\@\#\$\%\&\(\)\-\+\;\:\'\"\,\.\?\/\=\[\]]*)$/
200 or die 'illegal description';