<% include( 'elements/browse.html', 'title' => ucfirst($classname) . ' Reasons', 'menubar' => [ ucfirst($classname).' Reason Types' => $p."browse/reason_type.html?class=$class" ], 'html_init' => $html_init, 'name' => $classname . ' reasons', 'disableable' => 1, 'disabled_statuspos' => 3, 'query' => { 'table' => 'reason', 'hashref' => {}, 'extra_sql' => $where_clause. ' ORDER BY reason_type', 'addl_from' => 'LEFT JOIN reason_type ON reason_type.typenum = reason.reason_type', }, 'count_query' => $count_query, 'header' => \@header, 'fields' => \@fields, 'links' => \@links, 'align' => $align, 'html_form' => qq!
!, 'html_foot' => $html_foot, ) %> <%init> die "access denied" unless $FS::CurrentUser::CurrentUser->access_right('Configuration'); $cgi->param('class') =~ /^(\w)$/ or die "illegal class"; my $class = $1; my $classname = $FS::reason_type::class_name{$class}; my $classpurpose = $FS::reason_type::class_purpose{$class}; my $html_init = include('/elements/init_overlib.html'). ucfirst($classname). " reasons $classpurpose.

". qq!!. "Add a $classname reason

"; my $where_clause = " WHERE class='$class' "; my $count_query = 'SELECT COUNT(*) FROM reason LEFT JOIN reason_type on ' . 'reason_type.typenum = reason.reason_type ' . $where_clause; my $link = [ $p."edit/reason.html?class=$class&reasonnum=", 'reasonnum' ]; my @header = ( '#', ucfirst($classname) . ' reason type', ucfirst($classname) . ' reason', ); my @fields = ( 'reasonnum', sub { shift->reasontype->type }, 'reason', ); my @links = ( $link, $link, '', ); my $align = 'rll'; if ( $class eq 'S' or $class eq 'C' ) { push @header, 'Credit unused service'; push @fields, sub { my $reason = shift; if ( $reason->unused_credit ) { return 'YES'; } else { return 'NO'; } }; $align .= 'c'; } if ( $class eq 'S' ) { push @header, 'Suspension fee'; push @fields, sub { my $reason = shift; my $feepart = $reason->feepart; my ($href, $text, $detail); if ( $feepart ) { my $part_fee = FS::part_fee->by_key($feepart) or return ''; $text = $part_fee->itemdesc . ': ' . $part_fee->explanation; $detail = $reason->fee_on_unsuspend ? 'unsuspension' : 'suspension'; if ( $reason->fee_hold ) { $detail = "next bill after $detail"; } $detail = "(on $detail)"; $href = $p."edit/part_fee.html?$feepart"; } else { my $pkgpart = $reason->unsuspend_pkgpart; my $part_pkg = FS::part_pkg->by_key($pkgpart) or return ''; $text = $part_pkg->pkg_comment; $href = $p."edit/part_pkg.cgi?$pkgpart"; $detail = $reason->unsuspend_hold ? '(on next bill after unsuspension)' : '(on unsuspension)'; } return '' unless length($text); $text = qq!! . encode_entities($text) . " ". "$detail"; $text .= ''; } ; $align .= 'l'; } # reason merge handling push @header, ''; push @fields, sub { my $reason = shift; my $reasonnum = $reason->reasonnum; qq!!; }; push @links, ''; $align .= 'l'; my $html_foot = include('/search/elements/checkbox-foot.html', onclick => include( '/elements/popup_link_onclick.html', js_action => q!'! . "${p}misc/reason-merge.html?" . q!' + toCGIString()!, actionlabel => 'Merge reasons', ), label => 'merge selected reasons', minboxes => 2, ) . '
';