bulk svcpart change
[freeside.git] / httemplate / browse / part_svc.cgi
1 <% 
2
3 my %flag = (
4   'D' => 'Default',
5   'F' => 'Fixed',
6   ''  => '',
7 );
8
9 my %search;
10 if ( $cgi->param('showdisabled') ) {
11   %search = ();
12 } else {
13   %search = ( 'disabled' => '' );
14 }
15
16 my @part_svc =
17   sort { $a->getfield('svcpart') <=> $b->getfield('svcpart') }
18     qsearch('part_svc', \%search );
19 my $total = scalar(@part_svc);
20
21 my %num_active_cust_svc = map { $_->svcpart => $_->num_cust_svc } @part_svc;
22
23 if ( $cgi->param('orderby') eq 'active' ) {
24   @part_svc = sort { $num_active_cust_svc{$b->svcpart} <=>
25                      $num_active_cust_svc{$a->svcpart}     } @part_svc;
26 } elsif ( $cgi->param('orderby') eq 'svc' ) { 
27   @part_svc = sort { lc($a->svc) cmp lc($b->svc) } @part_svc;
28 }
29
30 %>
31 <%= header('Service Definition Listing', menubar( 'Main Menu' => $p) ) %>
32
33 <SCRIPT>
34 function part_export_areyousure(href) {
35   if (confirm("Are you sure you want to delete this export?") == true)
36     window.location.href = href;
37 }
38 </SCRIPT>
39
40     Service definitions are the templates for items you offer to your customers.<BR><BR>
41
42 <FORM METHOD="POST" ACTION="<%= $p %>edit/part_svc.cgi">
43 <A HREF="<%= $p %>edit/part_svc.cgi"><I>Add a new service definition</I></A><% if ( @part_svc ) { %>&nbsp;or&nbsp;<SELECT NAME="clone"><OPTION></OPTION>
44 <% foreach my $part_svc ( @part_svc ) { %>
45   <OPTION VALUE="<%= $part_svc->svcpart %>"><%= $part_svc->svc %></OPTION>
46 <% } %>
47 </SELECT><INPUT TYPE="submit" VALUE="Clone existing service">
48 <% } %>
49 </FORM><BR>
50
51 <%= $total %> service definitions
52 <%= $cgi->param('showdisabled')
53       ? do { $cgi->param('showdisabled', 0);
54              '( <a href="'. $cgi->self_url. '">hide disabled services</a> )'; }
55       : do { $cgi->param('showdisabled', 1);
56              '( <a href="'. $cgi->self_url. '">show disabled services</a> )'; }
57 %>
58 <% $cgi->param('showdisabled', ( 1 ^ $cgi->param('showdisabled') ) ); %>
59 <%= table() %>
60   <TR>
61     <TH><A HREF="<%= do { $cgi->param('orderby', 'svcpart'); $cgi->self_url } %>">#</A></TH>
62     <% if ( $cgi->param('showdisabled') ) { %>
63       <TH>Status</TH>
64     <% } %>
65     <TH><A HREF="<%= do { $cgi->param('orderby', 'svc'); $cgi->self_url; } %>">Service</A></TH>
66     <TH>Table</TH>
67     <TH><A HREF="<%= do { $cgi->param('orderby', 'active'); $cgi->self_url; } %>"><FONT SIZE=-1>Customer<BR>Services</FONT></A></TH>
68     <TH>Export</TH>
69     <TH>Field</TH>
70     <TH COLSPAN=2>Modifier</TH>
71   </TR>
72
73 <% foreach my $part_svc ( @part_svc ) {
74      my $svcdb = $part_svc->svcdb;
75      my $svc_x = "FS::$svcdb"->new( { svcpart => $part_svc->svcpart } );
76      my @dfields = $svc_x->fields;
77      push @dfields, 'usergroup' if $svcdb eq 'svc_acct'; #kludge
78      my @fields =
79        grep { $svc_x->pvf($_)
80            or $_ ne 'svcnum' && $part_svc->part_svc_column($_)->columnflag }
81             @dfields ;
82      my $rowspan = scalar(@fields) || 1;
83      my $url = "${p}edit/part_svc.cgi?". $part_svc->svcpart;
84 %>
85
86   <TR>
87     <TD ROWSPAN=<%= $rowspan %>><A HREF="<%= $url %>">
88       <%= $part_svc->svcpart %></A></TD>
89 <% if ( $cgi->param('showdisabled') ) { %>
90     <TD ROWSPAN=<%= $rowspan %>>
91       <%= $part_svc->disabled
92             ? '<FONT COLOR="#FF0000"><B>Disabled</B></FONT>'
93             : '<FONT COLOR="#00CC00"><B>Enabled</B></FONT>'
94       %>
95     </TD>
96 <% } %>
97     <TD ROWSPAN=<%= $rowspan %>><A HREF="<%= $url %>">
98       <%= $part_svc->svc %></A></TD>
99     <TD ROWSPAN=<%= $rowspan %>>
100       <%= $svcdb %></TD>
101     <TD ROWSPAN=<%= $rowspan %>>
102       <FONT COLOR="#00CC00"><B><%= $num_active_cust_svc{$part_svc->svcpart} %></B></FONT>&nbsp;<A HREF="<%=$p%>search/<%= $svcdb %>.cgi?svcpart=<%= $part_svc->svcpart %>">active</A>
103       <% if ( $num_active_cust_svc{$part_svc->svcpart} ) { %>
104         <BR><FONT SIZE="-1">[ <A HREF="<%=$p%>edit/bulk-cust_svc.html?svcpart=<%= $part_svc->svcpart %>">change</A> ]</FONT>
105       <% } %>
106     </TD>
107     <TD ROWSPAN=<%= $rowspan %>><%= itable() %>
108 <%
109 #  my @part_export =
110 map { qsearchs('part_export', { exportnum => $_->exportnum } ) } qsearch('export_svc', { svcpart => $part_svc->svcpart } ) ;
111   foreach my $part_export (
112     map { qsearchs('part_export', { exportnum => $_->exportnum } ) } 
113       qsearch('export_svc', { svcpart => $part_svc->svcpart } )
114   ) {
115 %>
116       <TR>
117         <TD><A HREF="<%= $p %>edit/part_export.cgi?<%= $part_export->exportnum %>"><%= $part_export->exportnum %>:&nbsp;<%= $part_export->exporttype %>&nbsp;to&nbsp;<%= $part_export->machine %></A></TD></TR>
118 <%  } %>
119       </TABLE></TD>
120
121 <%   my($n1)='';
122      foreach my $field ( @fields ) {
123        my $flag = $part_svc->part_svc_column($field)->columnflag;
124 %>
125      <%= $n1 %>
126      <TD><%= $field %></TD>
127      <TD><%= $flag{$flag} %></TD>
128      <TD><%= $part_svc->part_svc_column($field)->columnvalue%></TD>
129
130 <%     $n1="</TR><TR>";
131      }
132 %>
133   </TR>
134 <% } %>
135 </TABLE>
136 </BODY>
137 </HTML>