2bdcd741d1c80da91822ca0ed6774401bb6312cb
[freeside.git] / fs_selfservice / FS-SelfService / cgi / ws_list.html
1 <%=
2
3 sub ws_pkglink {
4     my($cat,$count,$link) = (shift,shift,shift);
5     return "0 $cat <BR>" unless $count->{$cat};
6     return qq! <A HREF="${link};filter=$cat">$count->{$cat}</A> $cat <BR> !;
7 }
8
9 sub ws_pkgstatus {
10     my $pkg = shift;
11     $status = "unbilled";
12     $status = "active" if ( $pkg->{setup} && !$pkg->{cancel}
13             && !$pkg->{susp} );
14     $status = "suspended" if ( $pkg->{susp} && !$pkg->{cancel} );
15     $status = "cancelled" if $pkg->{cancel};
16     $status;
17 }
18
19 sub pdate {
20     my($field,$date_format) = (shift,shift);
21     return "<TD>".Date::Format::time2str($date_format,$field)."</TD>" 
22         if $field && $field > 0;
23     '<TD></TD>';
24 }
25
26 if ( $pkgpart ) {
27     $OUT .= qq! <TABLE BORDER="1" style="empty-cells: show"><TR><TH>Package</TH><TH>Status</TH> !;
28     $OUT .= "<TH>Setup</TH><TH>Last Bill</TH><TH>Next Bill</TH><TH>Adjourn</TH>";
29     $OUT .= "<TH>Suspend</TH><TH>Expire</TH><TH>Contract End</TH>";
30     $OUT .= "<TH>Cancel</TH><TH>Services</TH></TR>";
31     foreach my $pkg ( @cust_pkg ) {
32         my $part_pkg = $pkg->{part_pkg}[0];
33         $status = ws_pkgstatus($pkg);
34         if($pkg->{pkgpart} == $pkgpart && 
35                 ( ($filter && $filter eq $status) || !$filter) ) {
36             $OUT .= "<TR><TD>$part_pkg->{pkg}</TD><TD>$status</TD>"; 
37             $OUT .= pdate($pkg->{setup},$date_format);
38             $OUT .= pdate($pkg->{last_bill},$date_format);
39             $OUT .= pdate($pkg->{bill},$date_format);
40             $OUT .= pdate($pkg->{adjourn},$date_format);
41             $OUT .= pdate($pkg->{susp},$date_format);
42             $OUT .= pdate($pkg->{expire},$date_format);
43             $OUT .= pdate($pkg->{contract_end},$date_format);
44             $OUT .= pdate($pkg->{cancel},$date_format);
45
46             $OUT .= "<TD style='font-size: 85%'>";
47             my @cust_svc = @{$pkg->{cust_svc}};
48             foreach my $cust_svc ( @cust_svc ) {
49                 my @label = @{$cust_svc->{'label'}};
50                 $OUT .= qq!$label[0]: $label[1] <BR><BR>!;
51             }
52             my @part_svc = @{$pkg->{part_svc}};
53             foreach my $part_svc ( @part_svc ) {
54                 my $link = qq!<A HREF="${url}provision_svc;!
55                     . qq!pkgnum=$pkg->{'pkgnum'};svcpart=$part_svc->{'svcpart'}!
56                     . qq!;numavail=$part_svc->{'num_avail'}">Setup !
57                     . qq!$part_svc->{'svc'}</A> ($part_svc->{'num_avail'}!
58                     . qq! available)<BR><BR>!;
59                 $OUT .= $link if $part_svc->{'can_get_dids'};
60
61                 if($part_svc->{'svcdb'} eq 'svc_phone' && $lnp) {
62                     $OUT .= qq!<A HREF="${url}provision_svc;lnp=1;!
63                     . qq!pkgnum=$pkg->{'pkgnum'};svcpart=$part_svc->{'svcpart'}!
64                     . qq!">Port-In $part_svc->{'svc'}</A>!;
65                 }
66             }
67
68             $OUT .= "</TD></TR>";
69         }
70     }
71     $OUT .= "</TABLE>";
72 }
73 else {
74     my %pkgparts;
75     foreach my $pkg ( @cust_pkg ) {
76         my $status = ws_pkgstatus($pkg);
77         $pkgparts{$pkg->{pkgpart}}{$status}++;
78         my $part_pkg = $pkg->{part_pkg}[0];
79         $pkgparts{$pkg->{pkgpart}}{pkg} = $part_pkg->{pkg};
80     }
81
82     $OUT .= "<TABLE><TR><TD>";
83
84     $OUT .= qq! <TABLE BORDER="1"><TR><TH>Package</TH><TH>Status</TH></TR> !;
85     my($pkgpart,$counts);
86     while(($pkgpart,$count) = each %pkgparts){
87        my $link = "${url}provision;pkgpart=$pkgpart";
88        $OUT .= qq! <TR><TD><A HREF="$link">$count->{pkg}</A></TD><TD> !;
89        $OUT .= ws_pkglink("unbilled",$count,$link);
90        $OUT .= ws_pkglink("active",$count,$link);
91        $OUT .= ws_pkglink("suspended",$count,$link);
92        $OUT .= ws_pkglink("cancelled",$count,$link);
93        $OUT .= "</TD></TR>";
94     }
95     $OUT .= "</TABLE>";
96
97     $OUT .= qq!</TD><TD VALIGN="TOP" STYLE="padding-left: 11px;">!;
98
99     if ( @login_svcpart ) {
100         $OUT .= "<B>Self-service accounts</B><BR>";
101         foreach my $pkg ( @cust_pkg ) {
102             @cust_svc = @{$pkg->{cust_svc}};
103             @part_svc = @{$pkg->{part_svc}};
104
105             foreach my $cust_svc ( @cust_svc ) {
106                 $svcpart = $cust_svc->{'svcpart'};
107                 next unless grep($_ eq $svcpart, @login_svcpart);
108                 @label = @{$cust_svc->{'label'}};
109                 $OUT .= $label[1] . " &nbsp; ";
110                 unless ( $cust_svc->{'svcnum'} == $svcnum ) {
111                     $OUT .= qq!<A HREF="javascript:areyousure('${url}delete_svc;svcnum=$cust_svc->{svcnum}', 'This will permanently delete the $label[1] $label[0].  Are you sure?')">!.
112                   'Delete</A>';
113                 }
114                 $OUT .= "<BR>";
115             }
116
117             foreach my $part_svc ( @part_svc ) {
118                 $svcpart = $part_svc->{'svcpart'};
119                 next unless grep($_ eq $svcpart, @login_svcpart);
120                 $link = "${url}provision_svc;pkgnum=$pkg->{'pkgnum'};".
121                     "svcpart=$part_svc->{'svcpart'}";
122                 $OUT .= qq!<A HREF="$link">!. 'Setup '. $part_svc->{'svc'}. 
123                     '</A> ('. $part_svc->{'num_avail'}. ' available)' 
124                     if $part_svc->{'svcdb'} eq 'svc_acct';
125             }
126
127         } # foreach cust_pkg
128     } # login_svcpart
129
130     my $hasPhone = 0;
131     foreach my $pkg ( @cust_pkg ) {
132         @cust_svc = @{$pkg->{cust_svc}};
133         foreach my $cust_svc ( @cust_svc ) {
134             @label = @{$cust_svc->{'label'}};
135             $hasPhone = 1 if $label[2] eq 'svc_phone';
136         }
137     }
138     if ( $hasPhone ) {
139         $link = "${url}didreport;type=";
140         $OUT .= "<BR><BR><BR>Download currently allocated DIDs:<BR>";
141         $OUT .= qq! &nbsp; <A HREF="${link}csv">CSV</A> | 
142             <A HREF="${link}xls">Excel</A>!;
143         $OUT .= "<BR><BR>Download recently allocated DIDs:<BR>";
144         $OUT .= qq! &nbsp; <A HREF="${link}csv;recentonly=1">CSV</A> | 
145             <A HREF="${link}xls;recentonly=1">Excel</A>!;
146     }
147     
148     $OUT .= "</TD></TR></TABLE>";
149 }
150 %>