From 42132c9a86d36d7fefa7ba5f058f764ba6e7ad5b Mon Sep 17 00:00:00 2001 From: jeff Date: Thu, 28 Aug 2008 21:32:26 +0000 Subject: taxproduct selection for one time charges --- httemplate/edit/part_pkg_taxoverride.html | 9 +++++++-- httemplate/edit/process/quick-charge.cgi | 13 ++++++++++++- httemplate/edit/quick-charge.html | 8 ++++++-- 3 files changed, 25 insertions(+), 5 deletions(-) (limited to 'httemplate/edit') diff --git a/httemplate/edit/part_pkg_taxoverride.html b/httemplate/edit/part_pkg_taxoverride.html index 5f191b373..61dfa2ac5 100644 --- a/httemplate/edit/part_pkg_taxoverride.html +++ b/httemplate/edit/part_pkg_taxoverride.html @@ -10,8 +10,8 @@
- ').value=s.toString(); parent.cClick();"> - + ').value=s.toString(); parent.<% $onclick %>();"> +
@@ -124,4 +124,9 @@ my $selected = $1 my $element_name = $1 if $cgi->param('element_name') =~/^(\w+)$/; +my $onclick = $1 + if $cgi->param('onclick') =~/^(\w+)$/; + +$onclick = 'cClick' unless $onclick; + diff --git a/httemplate/edit/process/quick-charge.cgi b/httemplate/edit/process/quick-charge.cgi index 4c4927f4d..839a4e911 100644 --- a/httemplate/edit/process/quick-charge.cgi +++ b/httemplate/edit/process/quick-charge.cgi @@ -14,6 +14,7 @@ die "access denied" unless $FS::CurrentUser::CurrentUser->access_right('One-time charge'); my $error = ''; +my $conf = new FS::conf; my $param = $cgi->Vars; my @description = (); @@ -35,8 +36,16 @@ if ( $cgi->param('quantity') =~ /^\s*(\d+)\s*$/ ) { $quantity = $1; } +$param->{'tax_override'} =~ /^\s*([,\d]*)\s*$/ + or $error .= "Illegal tax override " . $param->{"tax_override"} . " "; +my $override = $1; + if ( $param->{'taxclass'} eq '(select)' ) { - $error .= "Must select a tax class. "; + $error .= "Must select a tax class. " + unless ($conf->exists('enable_taxproducts') && + ( $override || $param->{taxproductnum} ) + ); + $cgi->param('taxclass', ''); } unless ( $error ) { @@ -48,6 +57,8 @@ unless ( $error ) { 'quantity' => $quantity, 'pkg' => scalar($cgi->param('pkg')), 'taxclass' => scalar($cgi->param('taxclass')), + 'taxproductnum' => scalar($cgi->param('taxproductnum')), + 'tax_override' => $override, 'classnum' => scalar($cgi->param('classnum')), 'additional' => \@description, } ); diff --git a/httemplate/edit/quick-charge.html b/httemplate/edit/quick-charge.html index d51015054..bf4c44571 100644 --- a/httemplate/edit/quick-charge.html +++ b/httemplate/edit/quick-charge.html @@ -71,7 +71,7 @@ function validate_quick_charge () { -
+ @@ -97,6 +97,10 @@ function validate_quick_charge () { <% include('/elements/tr-select-taxclass.html', 'curr_value' => $cgi->param('taxclass') ) %> +<% include('/elements/tr-select-taxproduct.html', 'label' => 'Tax product', 'onclick' => 'parent.taxproductmagic(this);', 'curr_value' => $cgi->param('taxproductnum') ) %> + +<% include('/elements/tr-select-taxoverride.html', 'onclick' => 'parent.taxoverridemagic(this);', 'curr_value' => $cgi->param('tax_override') ) %> + Description: @@ -110,7 +114,7 @@ function validate_quick_charge () { % my $row = 0; -% if ( $cgi->param('error') ) { +% if ( $cgi->param('error') || $cgi->param('magic') ) { % my $param = $cgi->Vars; % % for ( $row = 0; exists($param->{"description$row"}); $row++ ) { -- cgit v1.2.1