X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fbrowse%2Fpart_svc.cgi;h=0113263fb51c793a09f0685a0772199bdb291995;hb=c8cccb4a92adceb943c635fe62dad0d034462ce0;hp=07f197982c802f257928a3551a05e3069f134b63;hpb=6caffaefb96e25c68866825e2211816355a656aa;p=freeside.git
diff --git a/httemplate/browse/part_svc.cgi b/httemplate/browse/part_svc.cgi
index 07f197982..0113263fb 100755
--- a/httemplate/browse/part_svc.cgi
+++ b/httemplate/browse/part_svc.cgi
@@ -1,80 +1,177 @@
-
-<%
-
-my %search;
-if ( $cgi->param('showdisabled') ) {
- %search = ();
-} else {
- %search = ( 'disabled' => '' );
+%
+%
+%#code duplication w/ edit/part_svc.cgi, should move this hash to part_svc.pm
+%my %flag = (
+% '' => '',
+% 'D' => 'Default',
+% 'F' => 'Fixed (unchangeable)',
+% #'M' => 'Manual selection from inventory',
+% 'M' => 'Manual selected from inventory',
+% #'A' => 'Automatically fill in from inventory',
+% 'A' => 'Automatically filled in from inventory',
+% 'X' => 'Excluded',
+%);
+%
+%my %search;
+%if ( $cgi->param('showdisabled') ) {
+% %search = ();
+%} else {
+% %search = ( 'disabled' => '' );
+%}
+%
+%my @part_svc =
+% sort { $a->getfield('svcpart') <=> $b->getfield('svcpart') }
+% qsearch('part_svc', \%search );
+%my $total = scalar(@part_svc);
+%
+%my %num_active_cust_svc = map { $_->svcpart => $_->num_cust_svc } @part_svc;
+%
+%if ( $cgi->param('orderby') eq 'active' ) {
+% @part_svc = sort { $num_active_cust_svc{$b->svcpart} <=>
+% $num_active_cust_svc{$a->svcpart} } @part_svc;
+%} elsif ( $cgi->param('orderby') eq 'svc' ) {
+% @part_svc = sort { lc($a->svc) cmp lc($b->svc) } @part_svc;
+%}
+%
+%my %inventory_class = ();
+%
+%
+
+<% include("/elements/header.html",'Service Definition Listing', menubar( 'Main Menu' => $p) ) %>
+
+
-my @part_svc = qsearch('part_svc', \%search );
-my $total = scalar(@part_svc);
+ Service definitions are the templates for items you offer to your customers.
-%>
-<%= header('Service Definition Listing', menubar( 'Main Menu' => $p) ) %>
+
+
+<% $total %> service definitions
+<% $cgi->param('showdisabled')
? do { $cgi->param('showdisabled', 0);
'( hide disabled services )'; }
: do { $cgi->param('showdisabled', 1);
'( show disabled services )'; }
%>
-<%= table() %>
+% $cgi->param('showdisabled', ( 1 ^ $cgi->param('showdisabled') ) );
+
+<% table() %>
- param('showdisabled') ? 2 : 3 %>>Service |
+ # |
+% if ( $cgi->param('showdisabled') ) {
+
+ Status |
+% }
+
+ Service |
Table |
+ Customer Services |
+ Export |
Field |
Modifier |
+% foreach my $part_svc ( @part_svc ) {
+% my $svcdb = $part_svc->svcdb;
+% my $svc_x = "FS::$svcdb"->new( { svcpart => $part_svc->svcpart } );
+% my @dfields = $svc_x->fields;
+% push @dfields, 'usergroup' if $svcdb eq 'svc_acct'; #kludge
+% my @fields =
+% grep { $svc_x->pvf($_)
+% or $_ ne 'svcnum' && $part_svc->part_svc_column($_)->columnflag }
+% @dfields ;
+% my $rowspan = scalar(@fields) || 1;
+% my $url = "${p}edit/part_svc.cgi?". $part_svc->svcpart;
+%
-<% foreach my $part_svc ( sort {
- $a->getfield('svcpart') <=> $b->getfield('svcpart')
- } @part_svc ) {
- my($hashref)=$part_svc->hashref;
- my($svcdb)=$hashref->{svcdb};
- my @fields =
- grep { $_ ne 'svcnum' && $part_svc->part_svc_column($_)->columnflag }
- fields($svcdb);
-
- my($rowspan)=scalar(@fields) || 1;
- my $url = "${p}edit/part_svc.cgi?$hashref->{svcpart}";
-%>
- >
- <%= $hashref->{svcpart} %> |
-<% unless ( $cgi->param('showdisabled') ) { %>
- >
- <%= $hashref->{disabled} ? 'DISABLED' : '' %> |
-<% } %>
- >
- <%= $hashref->{svc} %> |
- >
- <%= $hashref->{svcdb} %> |
-
-<% my($n1)='';
- foreach my $field ( @fields ) {
- my $flag = $part_svc->part_svc_column($field)->columnflag;
-%>
- <%= $n1 %><%= $field %> |
+ | >
+ <% $part_svc->svcpart %> |
+% if ( $cgi->param('showdisabled') ) {
-<% if ( $flag eq "D" ) { print "Default"; }
- elsif ( $flag eq "F" ) { print "Fixed"; }
- else { print "(Unknown!)"; }
-%>
- <%= $part_svc->part_svc_column($field)->columnvalue%> |
-<% $n1="
";
- }
-%>
-
-<% } %>
+ >
+ <% $part_svc->disabled
+ ? 'Disabled'
+ : 'Enabled'
+ %>
+ |
+% }
+
+ >
+ <% $part_svc->svc %> |
+ >
+ <% $svcdb %> |
+ >
+ <% $num_active_cust_svc{$part_svc->svcpart} %> active
+% if ( $num_active_cust_svc{$part_svc->svcpart} ) {
+
+ [ change ]
+% }
+
+ |
+ ><% itable() %>
+%
+%# my @part_export =
+%map { qsearchs('part_export', { exportnum => $_->exportnum } ) } qsearch('export_svc', { svcpart => $part_svc->svcpart } ) ;
+% foreach my $part_export (
+% map { qsearchs('part_export', { exportnum => $_->exportnum } ) }
+% qsearch('export_svc', { svcpart => $part_svc->svcpart } )
+% ) {
+%
+
+ |
+ <% $part_export->exportnum %>: <% $part_export->exporttype %> to <% $part_export->machine %> |
+% }
+
+
+% my($n1)='';
+% foreach my $field ( @fields ) {
+% my $flag = $part_svc->part_svc_column($field)->columnflag;
+%
+
+ <% $n1 %>
+ <% $field %> |
+ <% $flag{$flag} %> |
+
+
+% my $value = $part_svc->part_svc_column($field)->columnvalue;
+% if ( $flag =~ /^[MA]$/ ) {
+% $inventory_class{$value}
+% ||= qsearchs('inventory_class', { 'classnum' => $value } );
+%
+
+ <% $inventory_class{$value}
+ ? $inventory_class{$value}->classname
+ : "WARNING: inventory_class.classnum $value not found" %>
+% } else {
+
+ <% $value %>
+% }
+
+ |
+% $n1="";
+% }
+%
-
- param('showdisabled') ? 6 : 7 %>>Add a new service definition |
+% }
+