- #end pager
-
- print header('Package Search Results',''),
- "$total matching packages found<BR><BR>$pager", &table(), <<END;
- <TR>
- <TH>Package</TH>
- <TH><FONT SIZE=-1>Setup</FONT></TH>
-END
-
- print '<TH><FONT SIZE=-1>Last<BR>bill</FONT></TH>'
- if defined dbdef->table('cust_pkg')->column('last_bill');
-
- print <<END;
- <TH><FONT SIZE=-1>Next<BR>bill</FONT></TH>
- <TH><FONT SIZE=-1>Susp.</FONT></TH>
- <TH><FONT SIZE=-1>Expire</FONT></TH>
- <TH><FONT SIZE=-1>Cancel</FONT></TH>
- <TH><FONT SIZE=-1>Cust#</FONT></TH>
- <TH>(bill) name</TH>
- <TH>company</TH>
-END
-
- print '<TH>(service) name</TH><TH>company</TH>'
- if defined dbdef->table('cust_main')->column('ship_last');
-
- print '<TH COLSPAN=2>Services</TH></TR>';
-
- my $n1 = '<TR>';
- my(%saw,$cust_pkg);
- foreach $cust_pkg (
- sort $sortby grep(!$saw{$_->pkgnum}++, @cust_pkg)
- ) {
- my($cust_main)=qsearchs('cust_main',{'custnum'=>$cust_pkg->custnum});
- my($pkgnum, $setup, $bill, $susp, $expire, $cancel,
- $custnum, $last, $first, $company ) = (
- $cust_pkg->pkgnum,
- $cust_pkg->getfield('setup')
- ? time2str("%D", $cust_pkg->getfield('setup') )
- : '',
- $cust_pkg->getfield('bill')
- ? time2str("%D", $cust_pkg->getfield('bill') )
- : '',
- $cust_pkg->getfield('susp')
- ? time2str("%D", $cust_pkg->getfield('susp') )
- : '',
- $cust_pkg->getfield('expire')
- ? time2str("%D", $cust_pkg->getfield('expire') )
- : '',
- $cust_pkg->getfield('cancel')
- ? time2str("%D", $cust_pkg->getfield('cancel') )
- : '',
- $cust_pkg->custnum,
- $cust_main ? $cust_main->last : '',
- $cust_main ? $cust_main->first : '',
- $cust_main ? $cust_main->company : '',
- );
-
- my $last_bill = $cust_pkg->getfield('last_bill')
- ? time2str("%D", $cust_pkg->getfield('last_bill') )
- : ''
- if defined dbdef->table('cust_pkg')->column('last_bill');
-
- my($ship_last, $ship_first, $ship_company);
- if ( defined dbdef->table('cust_main')->column('ship_last') ) {
- ($ship_last, $ship_first, $ship_company) = (
- $cust_main
- ? ( $cust_main->ship_last || $cust_main->getfield('last') )
- : '',
- $cust_main
- ? ( $cust_main->ship_last
- ? $cust_main->ship_first
- : $cust_main->first )
- : '',
- $cust_main
- ? ( $cust_main->ship_last
- ? $cust_main->ship_company
- : $cust_main->company )
- : '',
- );
+ return $text;
+};
+
+my $large_pkg_size = $conf->config('cust_pkg-large_pkg_size');
+
+my $process_svc_labels = sub {
+ my $cust_pkg = shift;
+ my @out;
+ foreach my $part_svc ( $cust_pkg->part_svc) {
+ # some false laziness with view/cust_main/packages/services.html
+
+ my $num_cust_svc = $cust_pkg->num_cust_svc( $part_svc->svcpart );
+
+ if ( $large_pkg_size > 0 and $large_pkg_size <= $num_cust_svc ) {
+ my $href = $p.'search/cust_pkg_svc.html?svcpart='.$part_svc->svcpart.
+ ';pkgnum='.$cust_pkg->pkgnum;
+ push @out, [
+ { 'data' => $part_svc->svc . ':',
+ 'align' => 'right',
+ 'rowspan' => 2 },
+ { 'data' => mt('(view all [_1])', $num_cust_svc),
+ 'data_style' => 'b',
+ 'align' => 'left',
+ 'link' => $href, },
+ ],
+ [
+ { 'data' => include('/elements/search-cust_svc.html',
+ 'svcpart' => $part_svc->svcpart,
+ 'pkgnum' => $cust_pkg->pkgnum,
+ ),
+ 'align' => 'left' },
+ ];