fix A/R report
[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
9
10 <TABLE>
11     <TR>
12         <TH COLSPAN="2" ALIGN="LEFT">Order # <% $ordernum %></TH>
13     </TR>
14     <TR>
15         <TH>Customer</TH>
16         <TH>Package/Service</TH>
17     </TR>
18 % my $anyavail = 0;
19 % foreach my $cust_main ( @cust_main ) {
20 %  my($cust_pkg_phone,$cust_pkg_label,$svc_label) = possible_pkgs($cust_main);
21 %  my $avail = keys(%$cust_pkg_phone);
22 %  $anyavail = 1 if $avail;
23     <TR>    
24         <TD><% $cust_main->name |h %></TD>
25         <TD>
26 %           if ( !$avail ) {
27                 No suitable packages exist for this customer.
28 %           } else {
29            <SELECT NAME="custnum<%$cust_main->custnum%>_pkgnum_svcpart">
30 %           foreach my $pkgnum ( keys %$cust_pkg_phone ) {
31 %               my @svcpart = @{$cust_pkg_phone->{$pkgnum}};
32 %               foreach my $svcpart ( @svcpart ) {
33                     <OPTION value="<%"${pkgnum}_$svcpart"%>">
34                         <% $cust_pkg_label->{$pkgnum} %> / <% $svc_label->{$svcpart} %>
35                     </OPTION>
36 %               }
37 %           }
38            </SELECT>
39 %           }
40        </TD>
41     </TR>
42 % }
43 % if ( $anyavail ) {
44     <TR><TD COLSPAN="2"><INPUT TYPE="SUBMIT" value="Provision"></TD></TR>
45 % }
46 </TABLE>
47
48 <%init>
49
50 die "access denied"
51   unless $FS::CurrentUser::CurrentUser->access_right('Import');
52
53 $cgi->param('ordernum') =~ /^(\d+)$/ or die 'illegal ordernum';
54 my $ordernum = $1;
55 my $did_order = qsearchs( {
56   'table'     => 'did_order',
57   'hashref'   => { 'ordernum' => $ordernum },
58 } );
59 die "No order $ordernum" unless $did_order;
60
61 my @cust_main = $did_order->cust_main;
62
63 die "Order is not in received status and/or DIDs not assigned to any customers"
64     unless $did_order->received && scalar(@cust_main);
65
66 my @dids = qsearch( 'phone_avail', { ordernum => $ordernum } );
67 die "no DIDs on order" unless scalar(@dids);
68
69 sub possible_pkgs {
70     my $cust_main = shift;
71     
72     my (%cust_pkg_phone, %cust_pkg_label, %svc_label);
73
74     my @pkgs = $cust_main->ncancelled_pkgs;
75     return (\%cust_pkg_phone,\%cust_pkg_label,\%svc_label) unless scalar(@pkgs);
76
77     foreach my $pkg ( @pkgs ) {
78         my @avail_part_svc = $pkg->available_part_svc;
79         my @svcpart;
80         foreach my $avail_part_svc ( @avail_part_svc ) {
81             if ($avail_part_svc->svcdb eq 'svc_phone'
82                       && $avail_part_svc->num_avail >= scalar(@dids)) {
83                 push @svcpart, $avail_part_svc->svcpart;
84                 $svc_label{$avail_part_svc->svcpart} = $avail_part_svc->svc;
85             }
86         }
87         $cust_pkg_phone{$pkg->pkgnum} = \@svcpart if scalar(@svcpart);
88         $cust_pkg_label{$pkg->pkgnum} = $pkg->part_pkg->pkg;
89     }
90     
91     (\%cust_pkg_phone,\%cust_pkg_label,\%svc_label);
92 }
93
94 </%init>