diff options
author | levinse <levinse> | 2011-04-17 03:28:12 +0000 |
---|---|---|
committer | levinse <levinse> | 2011-04-17 03:28:12 +0000 |
commit | fe54b392480244e9486603b162902acd2144bbc6 (patch) | |
tree | f91678656f227d65035c5d539c00f7d7c3dc8f32 /httemplate/misc | |
parent | ac2a516d126ab23b46138a6b930545fecc633943 (diff) |
bulk DID orders/inventory enhancements, RT11291
Diffstat (limited to 'httemplate/misc')
-rw-r--r-- | httemplate/misc/did_order_confirmed.html | 21 | ||||
-rw-r--r-- | httemplate/misc/did_order_provision.html | 51 |
2 files changed, 71 insertions, 1 deletions
diff --git a/httemplate/misc/did_order_confirmed.html b/httemplate/misc/did_order_confirmed.html index aaded9f58..c0c4795a6 100644 --- a/httemplate/misc/did_order_confirmed.html +++ b/httemplate/misc/did_order_confirmed.html @@ -8,7 +8,7 @@ die "access denied" unless $FS::CurrentUser::CurrentUser->access_right('Import'); -$cgi->param('action') =~ /^(confirm|cancel)$/ or die 'illegal action'; +$cgi->param('action') =~ /^(confirm|cancel|provision)$/ or die 'illegal action'; my $action = $1; my $success_msg = ''; my $error = ''; @@ -45,4 +45,23 @@ elsif ( $action eq 'cancel' ) { $error = $did_order->delete; $js = "window.location.href = '${p}browse/did_order.html'"; } +elsif ( $action eq 'provision' ) { + my $sucess_msg = 'DID order provisioned'; + $cgi->param('pkgnum_svcpart') =~ /^(\d+)_(\d+)$/ or die 'illegal pkgnum_svcpart'; + my $pkgnum = $1; + my $svcpart = $2; + my @dids = qsearch( 'phone_avail', { ordernum => $ordernum } ); + die "no DIDs on order" unless scalar(@dids); + foreach my $did ( @dids ) { + my $svc_phone = new FS::svc_phone({ + pkgnum => $pkgnum, + svcpart => $svcpart, + countrycode => 1, + phonenum => $did->npa.$did->nxx.$did->station, + }); + $error = $svc_phone->insert; + last if $error; + } +} + </%init> diff --git a/httemplate/misc/did_order_provision.html b/httemplate/misc/did_order_provision.html index b0c7210b7..8241121a8 100644 --- a/httemplate/misc/did_order_provision.html +++ b/httemplate/misc/did_order_provision.html @@ -10,9 +10,34 @@ <TD>Order #</TD> <TD><% $ordernum %></TD> </TR> + <TR> + <TD>Customer</TD> + <TD><% $cust_main->name %></TD> + <TR> + <TD>Package/Service</TD> + <TD> +% if ( !$avail ) { + No packages exist for this customer having at least <% scalar(@dids) %> + unprovisioned DIDs, as required for this order. +% } else { + <SELECT NAME="pkgnum_svcpart"> +% foreach my $pkgnum ( keys %cust_pkg_phone ) { +% my @svcpart = @{$cust_pkg_phone{$pkgnum}}; +% foreach my $svcpart ( @svcpart ) { + <OPTION value="<%"${pkgnum}_$svcpart"%>"> + <% $cust_pkg_label{$pkgnum} %> / <% $svc_label{$svcpart} %> + </OPTION> +% } +% } + </SELECT> +% } + </TD> + </TR> +% if ( $avail ) { <TR> <TD COLSPAN="2"><INPUT TYPE="SUBMIT" value="Provision"></TD> </TR> +% } </TABLE> <%init> @@ -31,5 +56,31 @@ die "No order $ordernum" unless $did_order; die "Order is not in received status and/or DIDs not assigned to a customer" unless $did_order->received && $did_order->custnum; +my $cust_main = qsearchs('cust_main', { custnum => $did_order->custnum } ); +die "invalid customer" unless $cust_main; + +my @pkgs = $cust_main->ncancelled_pkgs; +die "no packages" unless scalar(@pkgs); + +my @dids = qsearch( 'phone_avail', { ordernum => $ordernum } ); +die "no DIDs on order" unless scalar(@dids); + +my (%cust_pkg_phone, %cust_pkg_label, %svc_label ); + +foreach my $pkg ( @pkgs ) { + my @avail_part_svc = $pkg->available_part_svc; + my @svcpart; + foreach my $avail_part_svc ( @avail_part_svc ) { + if ($avail_part_svc->svcdb eq 'svc_phone' + && $avail_part_svc->num_avail >= scalar(@dids)) { + push @svcpart, $avail_part_svc->svcpart; + $svc_label{$avail_part_svc->svcpart} = $avail_part_svc->svc; + } + } + $cust_pkg_phone{$pkg->pkgnum} = \@svcpart if scalar(@svcpart); + $cust_pkg_label{$pkg->pkgnum} = $pkg->part_pkg->pkg; +} + +my $avail = keys(%cust_pkg_phone); </%init> |