2 % $cgi->param('error', $error);
3 <% $cgi->redirect(popurl(3). 'misc/order_pkg.html?'. $cgi->query_string ) %>
5 % my $show = $curuser->default_customer_view =~ /^(jumbo|packages)$/
9 % my $redir_url = popurl(3);
10 % if ( $svcpart ) { # for going straight to service provisining after ordering
11 % $redir_url .= 'edit/'.$part_svc->svcdb.'.cgi?'.
12 % 'pkgnum='.$cust_pkg->pkgnum. ";svcpart=$svcpart";
13 % $redir_url .= ";qualnum=$qualnum" if $qualnum;
14 % } elsif ( $quotationnum ) {
15 % $redir_url .= "view/quotation.html?quotationnum=$quotationnum";
17 % my $custnum = $cust_main->custnum;
18 % my $frag = "cust_pkg". $cust_pkg->pkgnum;
20 % "view/cust_main.cgi?custnum=$custnum$show;fragment=$frag#$frag";
23 <% header('Package ordered') %>
24 <SCRIPT TYPE="text/javascript">
25 // XXX fancy ajax rebuild table at some point, but a page reload will do for now
27 // XXX chop off trailing #target and replace... ?
28 window.top.location = '<% $redir_url %>';
36 my $curuser = $FS::CurrentUser::CurrentUser;
39 unless $curuser->access_right('Order customer package');
42 if ( $cgi->param('custnum') =~ /^(\d+)$/ ) {
44 $cust_main = qsearchs({
45 'table' => 'cust_main',
46 'hashref' => { 'custnum' => $custnum },
47 'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,
52 if ( $cgi->param('prospectnum') =~ /^(\d+)$/ ) {
54 $prospect_main = qsearchs({
55 'table' => 'prospect_main',
56 'hashref' => { 'prospectnum' => $prospectnum },
57 'extra_sql' => ' AND '. $FS::CurrentUser::CurrentUser->agentnums_sql,
61 die 'no custnum or prospectnum' unless $cust_main || $prospect_main;
63 #probably not necessary, taken care of by cust_pkg::check
64 $cgi->param('pkgpart') =~ /^(\d+)$/
65 or die 'illegal pkgpart '. $cgi->param('pkgpart');
67 $cgi->param('quantity') =~ /^(\d*)$/
68 or die 'illegal quantity '. $cgi->param('quantity');
69 my $quantity = $1 || 1;
70 $cgi->param('refnum') =~ /^(\d*)$/
71 or die 'illegal refnum '. $cgi->param('refnum');
73 $cgi->param('salesnum') =~ /^(\d*)$/
74 or die 'illegal salesnum '. $cgi->param('salesnum');
76 $cgi->param('contactnum') =~ /^(\-?\d*)$/
77 or die 'illegal contactnum '. $cgi->param('contactnum');
79 $cgi->param('locationnum') =~ /^(\-?\d*)$/
80 or die 'illegal locationnum '. $cgi->param('locationnum');
83 # for going right to a provision service after ordering a package
84 my( $svcpart, $part_svc ) = ( '', '' );
85 if ( $cgi->param('svcpart') ) {
86 $cgi->param('svcpart') =~ /^(\-?\d*)$/
87 or die 'illegal svcpart '. $cgi->param('svcpart');
89 $part_svc = qsearchs('part_svc', { 'svcpart' => $svcpart } )
90 or die "unknown svcpart $svcpart";
94 if ( $cgi->param('qualnum') =~ /^(\d+)$/ ) {
97 my $quotationnum = '';
98 if ( $cgi->param('quotationnum') =~ /^(\d+)$/ ) {
101 # verify this quotation is visible to this user
104 my $quotation_pkg = '';
108 'pkgpart' => $pkgpart,
109 'quantity' => $quantity,
110 'salesnum' => $salesnum,
112 'contactnum' => $contactnum,
113 'locationnum' => $locationnum,
114 'contract_end' => ( scalar($cgi->param('contract_end'))
115 ? parse_datetime($cgi->param('contract_end'))
120 if ( $cgi->param('setup_discountnum') =~ /^(-?\d+)$/ ) {
122 $hash{waive_setup} = 'Y';
124 $hash{setup_discountnum} = $1;
125 $hash{setup_discountnum_amount} = $cgi->param('setup_discountnum_amount');
126 $hash{setup_discountnum_percent} = $cgi->param('setup_discountnum_percent');
130 if ( $cgi->param('recur_discountnum') =~ /^(-?\d+)$/ ) {
131 $hash{recur_discountnum} = $1;
132 $hash{recur_discountnum_amount} = $cgi->param('recur_discountnum_amount');
133 $hash{recur_discountnum_percent} = $cgi->param('recur_discountnum_percent');
134 $hash{recur_discountnum_months} = $cgi->param('recur_discountnum_months');
137 $hash{'custnum'} = $cust_main->custnum if $cust_main;
139 if ( $cgi->param('start') eq 'on_hold' ) {
140 $hash{'susp'} = 'now';
141 } elsif ( $cgi->param('start') eq 'on_date' ) {
142 $hash{'start_date'} = scalar($cgi->param('start_date'))
143 ? parse_datetime($cgi->param('start_date'))
147 my @cust_pkg_usageprice = ();
148 foreach my $quantity_param ( grep { $cgi->param($_) && $cgi->param($_) > 0 }
149 grep /^usagepricenum(\d+)_quantity$/,
153 $quantity_param =~ /^usagepricenum(\d+)_quantity$/ or die 'unpossible';
155 push @cust_pkg_usageprice, new FS::cust_pkg_usageprice {
156 usagepricepart => scalar($cgi->param("usagepricenum${num}_usagepricepart")),
157 quantity => scalar($cgi->param($quantity_param)),
160 $hash{cust_pkg_usageprice} = \@cust_pkg_usageprice;
162 if ( $quotationnum ) {
164 $quotation_pkg = new FS::quotation_pkg \%hash;
165 $quotation_pkg->quotationnum($quotationnum);
166 $quotation_pkg->prospectnum($prospect_main->prospectnum) if $prospect_main;
168 #XXX handle new location
169 $error = $quotation_pkg->insert;
173 $cust_pkg = new FS::cust_pkg \%hash;
175 $cust_pkg->no_auto( scalar($cgi->param('no_auto')) );
177 my %opt = ( 'cust_pkg' => $cust_pkg );
179 if ( $contactnum == -1 ) {
180 my $contact = FS::contact->new({
181 'custnum' => scalar($cgi->param('custnum')),
182 map { $_ => scalar($cgi->param("contactnum_$_")) } qw( first last )
184 $opt{'contact'} = $contact;
187 if ( $locationnum == -1 ) {
188 my $cust_location = FS::cust_location->new({
189 map { $_ => scalar($cgi->param($_)) }
190 ('custnum', FS::cust_main->location_fields)
192 $opt{'cust_location'} = $cust_location;
194 $opt{'locationnum'} = $locationnum;
197 $error = $cust_main->order_pkg( \%opt );