service refactor!
[freeside.git] / httemplate / browse / part_svc.cgi
1
2 %
3 %#code duplication w/ edit/part_svc.cgi, should move this hash to part_svc.pm
4 %my %flag = (
5 %  ''  => '',
6 %  'D' => 'Default',
7 %  'F' => 'Fixed (unchangeable)',
8 %  'S' => 'Selectable choice',
9 %  #'M' => 'Manual selection from inventory',
10 %  'M' => 'Manual selected from inventory',
11 %  #'A' => 'Automatically fill in from inventory',
12 %  'A' => 'Automatically filled in from inventory',
13 %  'X' => 'Excluded',
14 %);
15 %
16 %my %search;
17 %if ( $cgi->param('showdisabled') ) {
18 %  %search = ();
19 %} else {
20 %  %search = ( 'disabled' => '' );
21 %}
22 %
23 %my @part_svc =
24 %  sort { $a->getfield('svcpart') <=> $b->getfield('svcpart') }
25 %    qsearch('part_svc', \%search );
26 %my $total = scalar(@part_svc);
27 %
28 %my %num_active_cust_svc = map { $_->svcpart => $_->num_cust_svc } @part_svc;
29 %
30 %if ( $cgi->param('orderby') eq 'active' ) {
31 %  @part_svc = sort { $num_active_cust_svc{$b->svcpart} <=>
32 %                     $num_active_cust_svc{$a->svcpart}     } @part_svc;
33 %} elsif ( $cgi->param('orderby') eq 'svc' ) { 
34 %  @part_svc = sort { lc($a->svc) cmp lc($b->svc) } @part_svc;
35 %}
36 %
37 %my %inventory_class = ();
38 %
39 %
40
41 <% include("/elements/header.html",'Service Definition Listing', menubar( 'Main Menu' => $p) ) %>
42
43 <SCRIPT>
44 function part_export_areyousure(href) {
45   if (confirm("Are you sure you want to delete this export?") == true)
46     window.location.href = href;
47 }
48 </SCRIPT>
49
50     Service definitions are the templates for items you offer to your customers.<BR><BR>
51
52 <FORM METHOD="POST" ACTION="<% $p %>edit/part_svc.cgi">
53 <A HREF="<% $p %>edit/part_svc.cgi"><I>Add a new service definition</I></A>
54 % if ( @part_svc ) { 
55 &nbsp;or&nbsp;<SELECT NAME="clone"><OPTION></OPTION>
56 % foreach my $part_svc ( @part_svc ) { 
57
58   <OPTION VALUE="<% $part_svc->svcpart %>"><% $part_svc->svc %></OPTION>
59 % } 
60
61 </SELECT><INPUT TYPE="submit" VALUE="Clone existing service">
62 % } 
63
64 </FORM><BR>
65
66 <% $total %> service definitions
67 <% $cgi->param('showdisabled')
68       ? do { $cgi->param('showdisabled', 0);
69              '( <a href="'. $cgi->self_url. '">hide disabled services</a> )'; }
70       : do { $cgi->param('showdisabled', 1);
71              '( <a href="'. $cgi->self_url. '">show disabled services</a> )'; }
72 %>
73 % $cgi->param('showdisabled', ( 1 ^ $cgi->param('showdisabled') ) ); 
74
75 <% include('/elements/table-grid.html') %>
76 % my $bgcolor1 = '#eeeeee';
77 %   my $bgcolor2 = '#ffffff';
78 %   my $bgcolor = '';
79
80   <TR>
81
82     <TH CLASS="grid" BGCOLOR="#cccccc"><A HREF="<% do { $cgi->param('orderby', 'svcpart'); $cgi->self_url } %>">#</A></TH>
83
84 % if ( $cgi->param('showdisabled') ) { 
85       <TH CLASS="grid" BGCOLOR="#cccccc">Status</TH>
86 % } 
87
88     <TH CLASS="grid" BGCOLOR="#cccccc"><A HREF="<% do { $cgi->param('orderby', 'svc'); $cgi->self_url; } %>">Service</A></TH>
89
90     <TH CLASS="grid" BGCOLOR="#cccccc">Table</TH>
91
92     <TH CLASS="grid" BGCOLOR="#cccccc"><A HREF="<% do { $cgi->param('orderby', 'active'); $cgi->self_url; } %>"><FONT SIZE=-1>Customer<BR>Services</FONT></A></TH>
93
94     <TH CLASS="grid" BGCOLOR="#cccccc">Export</TH>
95
96     <TH CLASS="grid" BGCOLOR="#cccccc">Field</TH>
97
98     <TH COLSPAN=2 CLASS="grid" BGCOLOR="#cccccc">Modifier</TH>
99
100   </TR>
101
102 % foreach my $part_svc ( @part_svc ) {
103 %     my $svcdb = $part_svc->svcdb;
104 %     my $svc_x = "FS::$svcdb"->new( { svcpart => $part_svc->svcpart } );
105 %     my @dfields = $svc_x->fields;
106 %     push @dfields, 'usergroup' if $svcdb eq 'svc_acct'; #kludge
107 %     my @fields =
108 %       grep { $svc_x->pvf($_)
109 %           or $_ ne 'svcnum' && $part_svc->part_svc_column($_)->columnflag }
110 %            @dfields ;
111 %     my $rowspan = scalar(@fields) || 1;
112 %     my $url = "${p}edit/part_svc.cgi?". $part_svc->svcpart;
113 %
114 %     if ( $bgcolor eq $bgcolor1 ) {
115 %       $bgcolor = $bgcolor2;
116 %     } else {
117 %       $bgcolor = $bgcolor1;
118 %     }
119
120
121   <TR>
122
123     <TD ROWSPAN=<% $rowspan %> CLASS="grid" BGCOLOR="<% $bgcolor %>">
124       <A HREF="<% $url %>"><% $part_svc->svcpart %></A>
125     </TD>
126
127 % if ( $cgi->param('showdisabled') ) { 
128     <TD ROWSPAN=<% $rowspan %> CLASS="grid" BGCOLOR="<% $bgcolor %>">
129       <% $part_svc->disabled
130             ? '<FONT COLOR="#FF0000"><B>Disabled</B></FONT>'
131             : '<FONT COLOR="#00CC00"><B>Enabled</B></FONT>'
132       %>
133     </TD>
134 % } 
135
136     <TD ROWSPAN=<% $rowspan %> CLASS="grid" BGCOLOR="<% $bgcolor %>"><A HREF="<% $url %>">
137       <% $part_svc->svc %></A></TD>
138
139     <TD ROWSPAN=<% $rowspan %> CLASS="grid" BGCOLOR="<% $bgcolor %>">
140       <% $svcdb %></TD>
141
142     <TD ROWSPAN=<% $rowspan %> CLASS="grid" BGCOLOR="<% $bgcolor %>">
143       <FONT COLOR="#00CC00"><B><% $num_active_cust_svc{$part_svc->svcpart} %></B></FONT>&nbsp;<% $num_active_cust_svc{$part_svc->svcpart} ? FS::UI::Web::svc_url( 'ahref' => 1, 'm' => $m, 'action' => 'search', 'part_svc' => $part_svc, 'query' => "svcpart=". $part_svc->svcpart ) : '<A NAME="zero">' %>active</A>
144
145 % if ( $num_active_cust_svc{$part_svc->svcpart} ) { 
146         <BR><FONT SIZE="-1">[ <A HREF="<%$p%>edit/bulk-cust_svc.html?svcpart=<% $part_svc->svcpart %>">change</A> ]</FONT>
147 % } 
148
149     </TD>
150
151     <TD ROWSPAN=<% $rowspan %> CLASS="inv" BGCOLOR="<% $bgcolor %>">
152       <TABLE CLASS="inv">
153 %
154 %#  my @part_export =
155 %map { qsearchs('part_export', { exportnum => $_->exportnum } ) } qsearch('export_svc', { svcpart => $part_svc->svcpart } ) ;
156 %  foreach my $part_export (
157 %    map { qsearchs('part_export', { exportnum => $_->exportnum } ) } 
158 %      qsearch('export_svc', { svcpart => $part_svc->svcpart } )
159 %  ) {
160 %
161
162         <TR>
163           <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>
164         </TR>
165 %  } 
166
167       </TABLE>
168     </TD>
169
170 %     unless ( @fields ) {
171 %       for ( 1..3 ) {  
172           <TD CLASS="grid" BGCOLOR="<% $bgcolor %>"</TD>
173 %       }
174 %     }
175 %   
176 %     my($n1)='';
177 %     foreach my $field ( @fields ) {
178 %       my $flag = $part_svc->part_svc_column($field)->columnflag;
179 %
180
181      <% $n1 %>
182      <TD CLASS="grid" BGCOLOR="<% $bgcolor %>"><% $field %></TD>
183      <TD CLASS="grid" BGCOLOR="<% $bgcolor %>"><% $flag{$flag} %></TD>
184
185      <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
186 % my $value = $part_svc->part_svc_column($field)->columnvalue;
187 %          if ( $flag =~ /^[MA]$/ ) { 
188 %            $inventory_class{$value}
189 %              ||= qsearchs('inventory_class', { 'classnum' => $value } );
190 %       
191
192             <% $inventory_class{$value}
193                   ? $inventory_class{$value}->classname
194                   : "WARNING: inventory_class.classnum $value not found" %>
195 % } else { 
196
197             <% $value %>
198 % } 
199
200      </TD>
201 %     $n1="</TR><TR>";
202 %     }
203 %
204
205   </TR>
206 % } 
207
208 </TABLE>
209 </BODY>
210 </HTML>