X-Git-Url: http://git.freeside.biz/gitweb/?p=freeside.git;a=blobdiff_plain;f=httemplate%2Fbrowse%2Fpart_svc.cgi;h=cce6af822b20f2905c4f0c1c33a0ce0293d4f953;hp=84d8a356644f71318a0f60b0b8c49aad07d42f89;hb=db4034e2019cb6c7f455640b89e8d5fedeb28932;hpb=51984ac3d3da3006809c6866fdecd4ad83610731 diff --git a/httemplate/browse/part_svc.cgi b/httemplate/browse/part_svc.cgi index 84d8a3566..cce6af822 100755 --- a/httemplate/browse/part_svc.cgi +++ b/httemplate/browse/part_svc.cgi @@ -1,60 +1,215 @@ - -<%= header('Service Part Listing', menubar( 'Main Menu' => $p) ) %> +<% include("/elements/header.html",'Service Definition Listing', menubar( 'Main Menu' => $p) ) %> - Services are items you offer to your customers.

- - - - - - - + + + Service definitions are the templates for items you offer to your customers.

+ + +Add a new service definition +% if ( @part_svc ) { + or  +% } -<% foreach my $part_svc ( sort { - $a->getfield('svcpart') <=> $b->getfield('svcpart') - } qsearch('part_svc',{}) ) { - my($hashref)=$part_svc->hashref; - my($svcdb)=$hashref->{svcdb}; - my(@rows)= - grep $hashref->{${svcdb}.'__'.$_.'_flag'}, - map { /^${svcdb}__(.*)$/; $1 } - grep ! /_flag$/, - grep /^${svcdb}__/, - fields('part_svc') - ; - my($rowspan)=scalar(@rows) || 1; - my $url = "${p}edit/part_svc.cgi?$hashref->{svcpart}"; +
+ +<% $total %> service definitions +<% $cgi->param('showdisabled') + ? do { $cgi->param('showdisabled', 0); + '( hide disabled services )'; } + : do { $cgi->param('showdisabled', 1); + '( show disabled services )'; } %> +% $cgi->param('showdisabled', ( 1 ^ $cgi->param('showdisabled') ) ); + +<% include('/elements/table-grid.html') %> +% my $bgcolor1 = '#eeeeee'; +% my $bgcolor2 = '#ffffff'; +% my $bgcolor = ''; - - - - -<% my($n1)=''; - my($row); - foreach $row ( @rows ) { - my($flag)=$part_svc->getfield($svcdb.'__'.$row.'_flag'); -%> - <%= $n1 %> -<% $n1=""; - } -%> + + +% if ( $cgi->param('showdisabled') ) { + +% } + + + + + + + + + + + + + -<% } %> + +% 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; +% +% if ( $bgcolor eq $bgcolor1 ) { +% $bgcolor = $bgcolor2; +% } else { +% $bgcolor = $bgcolor1; +% } + - + + + +% if ( $cgi->param('showdisabled') ) { + +% } + + + + + + + + + +% unless ( @fields ) { +% for ( 1..3 ) { + + + + +% $n1=""; +% } +% + +% } +
ServiceTableFieldModifier
> - <%= $hashref->{svcpart} %>> - <%= $hashref->{svc} %>> - <%= $hashref->{svcdb} %>$row -<% if ( $flag eq "D" ) { print "Default"; } - elsif ( $flag eq "F" ) { print "Fixed"; } - else { print "(Unknown!)"; } -%> - <%= $part_svc->getfield($svcdb."__".$row) %>
#StatusServiceTableCustomer
Services
ExportFieldModifier
Add new service CLASS="grid" BGCOLOR="<% $bgcolor %>"> + <% $part_svc->svcpart %> + CLASS="grid" BGCOLOR="<% $bgcolor %>"> + <% $part_svc->disabled + ? 'Disabled' + : 'Enabled' + %> + CLASS="grid" BGCOLOR="<% $bgcolor %>"> + <% $part_svc->svc %> CLASS="grid" BGCOLOR="<% $bgcolor %>"> + <% $svcdb %> CLASS="grid" BGCOLOR="<% $bgcolor %>"> + <% $num_active_cust_svc{$part_svc->svcpart} %> <% $num_active_cust_svc{$part_svc->svcpart} ? svc_url( 'ahref' => 1, 'm' => $m, 'action' => 'search', 'part_svc' => $part_svc, 'query' => "svcpart=". $part_svc->svcpart ) : '' %>active + +% if ( $num_active_cust_svc{$part_svc->svcpart} ) { +
[ change ] +% } + +
CLASS="inv" BGCOLOR="<% $bgcolor %>"> + +% +%# 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 $formatter = +% FS::part_svc->svc_table_fields($svcdb)->{$field}->{format} +% || sub { shift }; +% my $flag = $part_svc->part_svc_column($field)->columnflag; +% + + <% $n1 %> + <% $field %><% $flag{$flag} %> +% my $value = &$formatter($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 %> +% } + +
+<%init> + +die "access denied" + unless $FS::CurrentUser::CurrentUser->access_right('Configuration'); + +#code duplication w/ edit/part_svc.cgi, should move this hash to part_svc.pm +my %flag = ( + '' => '', + 'D' => 'Default', + 'F' => 'Fixed (unchangeable)', + 'S' => 'Selectable choice', + #'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 = (); + +