X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=httemplate%2Fbrowse%2Fpart_svc.cgi;h=4549e44ddf931f0a34a8933d5a687a5e0955298d;hb=b5c4237a34aef94976bc343c8d9e138664fc3984;hp=805bd88b921762e71615e0a2ab4affe9ed4418aa;hpb=9608be1f5c73517fc348f1ab458892b34ed7facb;p=freeside.git diff --git a/httemplate/browse/part_svc.cgi b/httemplate/browse/part_svc.cgi index 805bd88b9..4549e44dd 100755 --- a/httemplate/browse/part_svc.cgi +++ b/httemplate/browse/part_svc.cgi @@ -1,14 +1,214 @@ -<% +<% include('/elements/header.html', 'Service Definition Listing') %> + + + + Service definitions are the templates for items you offer to your customers.

+ +
+Add a new service definition +% if ( @part_svc ) { + or  +% } + +

+ +<% $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 = ''; + + + + # + +% if ( $cgi->param('showdisabled') ) { + Status +% } + + Service + + Table + + Customer
Services
+ + Export + + Field + + Label + + 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 { my $col = $part_svc->part_svc_column($_); +% my $def = FS::part_svc->svc_table_fields($svcdb)->{$_}; +% $svc_x->pvf($_) +% or $_ ne 'svcnum' && ( +% $col->columnflag || ( $col->columnlabel !~ /^\S*$/ +% && $col->columnlabel ne $def->{'label'} +% ) +% ) +% } +% @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; +% } + + + + + CLASS="grid" BGCOLOR="<% $bgcolor %>"> + <% $part_svc->svcpart %> + + +% if ( $cgi->param('showdisabled') ) { + 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 %>:  +% if ($part_export->exportname) { +<% $part_export->exportname %> ( +% } +<% $part_export->exporttype %> to <% $part_export->machine %> +% if ($part_export->exportname) { +) +% } +
+ + +% unless ( @fields ) { +% for ( 1..4 ) { + +% } +% } +% +% my($n1)=''; +% foreach my $field ( @fields ) { +% +% #a few lines of false laziness w/edit/part_svc.cgi +% my $def = FS::part_svc->svc_table_fields($svcdb)->{$field}; +% my $formatter = $def->{format} || sub { shift }; +% +% my $part_svc_column = $part_svc->part_svc_column($field); +% my $label = $part_svc_column->columnlabel || $def->{'label'}; +% my $flag = $part_svc_column->columnflag; + + <% $n1 %> + <% $field %> + <% $label %> + <% $flag{$flag} %> + + +% my $value = &$formatter($part_svc->part_svc_column($field)->columnvalue); +% if ( $flag =~ /^[MAH]$/ ) { +% my $select_table = ($flag eq 'H') ? 'hardware_class' : 'inventory_class'; +% $select_class{$value} ||= +% qsearchs($select_table, { 'classnum' => $value } ); +% + <% $select_class{$value} + ? $select_class{$value}->classname + : "WARNING: $select_table.classnum $value not found" %> +% } else { + + <% $value %> +% } + + +% $n1=""; +% } +% + + +% } + + + + +<%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', + 'H' => 'Selected from hardware class', 'X' => 'Excluded', ); @@ -33,127 +233,6 @@ if ( $cgi->param('orderby') eq 'active' ) { @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) ) %> - - - - Service definitions are the templates for items you offer to your customers.

- -
-Add a new service definition<% if ( @part_svc ) { %> or  -<% } %> -

+my %select_class = (); -<%= $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') ) ); %> -<%= table() %> - - # - <% 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; -%> - - - > - <%= $part_svc->svcpart %> -<% if ( $cgi->param('showdisabled') ) { %> - > - <%= $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=""; - } -%> - -<% } %> - - - +