This commit was generated by cvs2svn to compensate for changes in r11022,
[freeside.git] / httemplate / misc / did_order_provision.html
1 <% include('/elements/header-popup.html', 'Bulk DID order - DID provisioning' ) %>
2
3 <% include('/elements/error.html') %>
4
5 <FORM NAME="did_order_confirm" ACTION="<% popurl(1) %>did_order_confirmed.html" METHOD=POST>
6 <INPUT TYPE="hidden" NAME="action" VALUE="provision">
7 <INPUT TYPE="hidden" NAME="ordernum" VALUE="<% $ordernum %>">
8 <TABLE>
9     <TR>    
10         <TD>Order #</TD>
11         <TD><% $ordernum %></TD>
12     </TR>
13     <TR>    
14         <TD>Customer</TD>
15         <TD><% $cust_main->name %></TD>
16     <TR>
17         <TD>Package/Service</TD>
18         <TD>
19 %           if ( !$avail ) {
20                 No packages exist for this customer having at least <% scalar(@dids) %>
21                     unprovisioned DIDs, as required for this order.
22 %           } else {
23            <SELECT NAME="pkgnum_svcpart">
24 %           foreach my $pkgnum ( keys %cust_pkg_phone ) {
25 %               my @svcpart = @{$cust_pkg_phone{$pkgnum}};
26 %               foreach my $svcpart ( @svcpart ) {
27                     <OPTION value="<%"${pkgnum}_$svcpart"%>">
28                         <% $cust_pkg_label{$pkgnum} %> / <% $svc_label{$svcpart} %>
29                     </OPTION>
30 %               }
31 %           }
32            </SELECT>
33 %           }
34        </TD>
35     </TR>
36 %   if ( $avail ) {
37     <TR>
38         <TD COLSPAN="2"><INPUT TYPE="SUBMIT" value="Provision"></TD>
39     </TR>
40 %  }
41 </TABLE>
42
43 <%init>
44
45 die "access denied"
46   unless $FS::CurrentUser::CurrentUser->access_right('Import');
47
48 $cgi->param('ordernum') =~ /^(\d+)$/ or die 'illegal ordernum';
49 my $ordernum = $1;
50 my $did_order = qsearchs( {
51   'table'     => 'did_order',
52   'hashref'   => { 'ordernum' => $ordernum },
53 } );
54 die "No order $ordernum" unless $did_order;
55
56 die "Order is not in received status and/or DIDs not assigned to a customer"
57     unless $did_order->received && $did_order->custnum; 
58
59 my $cust_main = qsearchs('cust_main', { custnum => $did_order->custnum } );
60 die "invalid customer" unless $cust_main;
61
62 my @pkgs = $cust_main->ncancelled_pkgs;
63 die "no packages" unless scalar(@pkgs);
64
65 my @dids = qsearch( 'phone_avail', { ordernum => $ordernum } );
66 die "no DIDs on order" unless scalar(@dids);
67
68 my (%cust_pkg_phone, %cust_pkg_label, %svc_label );
69
70 foreach my $pkg ( @pkgs ) {
71     my @avail_part_svc = $pkg->available_part_svc;
72     my @svcpart;
73     foreach my $avail_part_svc ( @avail_part_svc ) {
74         if ($avail_part_svc->svcdb eq 'svc_phone'
75                   && $avail_part_svc->num_avail >= scalar(@dids)) {
76             push @svcpart, $avail_part_svc->svcpart;
77             $svc_label{$avail_part_svc->svcpart} = $avail_part_svc->svc;
78         }
79     }
80     $cust_pkg_phone{$pkg->pkgnum} = \@svcpart if scalar(@svcpart);
81     $cust_pkg_label{$pkg->pkgnum} = $pkg->part_pkg->pkg;
82 }
83
84 my $avail = keys(%cust_pkg_phone);
85
86 </%init>