summaryrefslogtreecommitdiff
path: root/httemplate/misc/did_order_provision.html
blob: 8241121a80f0e5b30a440d427e69c66a1759298a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
<% include('/elements/header-popup.html', 'Bulk DID order - DID provisioning' ) %>

<% include('/elements/error.html') %>

<FORM NAME="did_order_confirm" ACTION="<% popurl(1) %>did_order_confirmed.html" METHOD=POST>
<INPUT TYPE="hidden" NAME="action" VALUE="provision">
<INPUT TYPE="hidden" NAME="ordernum" VALUE="<% $ordernum %>">
<TABLE>
    <TR>    
        <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>

die "access denied"
  unless $FS::CurrentUser::CurrentUser->access_right('Import');

$cgi->param('ordernum') =~ /^(\d+)$/ or die 'illegal ordernum';
my $ordernum = $1;
my $did_order = qsearchs( {
  'table'     => 'did_order',
  'hashref'   => { 'ordernum' => $ordernum },
} );
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>