X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=FS%2FFS%2FUI%2FWeb%2Fsmall_custview.pm;h=e82e3326f3840432e197f059535f7c584bcc6529;hb=5376c66e2e5c1849763777f9d44ad013405c1d9e;hp=f8e202092e390bdc04f2a610806471fa0fd6b36d;hpb=63a268637b2d51a8766412617724b9436439deb6;p=freeside.git
diff --git a/FS/FS/UI/Web/small_custview.pm b/FS/FS/UI/Web/small_custview.pm
index f8e202092..e82e3326f 100644
--- a/FS/FS/UI/Web/small_custview.pm
+++ b/FS/FS/UI/Web/small_custview.pm
@@ -3,6 +3,7 @@ package FS::UI::Web::small_custview;
use strict;
use vars qw(@EXPORT_OK @ISA);
use Exporter;
+use HTML::Entities;
use FS::Msgcat;
use FS::Record qw(qsearchs);
use FS::cust_main;
@@ -10,42 +11,135 @@ use FS::cust_main;
@ISA = qw(Exporter);
@EXPORT_OK = qw( small_custview );
+=head1 NAME
+
+FS::UI::Web::small_custview
+
+=head1 SYNOPSIS
+
+ use FS::UI::Web::small_custview qw( small_custview );
+
+ #new-style
+ $html = small_custview(
+ { 'cust_main' => $cust_main, #or 'custnum' => $custnum,
+ 'countrydefault' => 'US',
+ 'nobalance' => 1,
+ 'url' => 'http://freeside.machine/freeside/view/cust_main.cgi',
+ 'nopkg' => 1,
+ }
+ );
+
+ #old-style (deprecated)
+ $html = small_custview( $cust_main, $countrydefault, $nobalance, $url );
+
+=head1 DESCRIPTION
+
+A subroutine for displaying customer information.
+
+=head1 SUBROUTINES
+
+=over 4
+
+=item small_custview HASHREF
+
+New-style interface. Keys are:
+
+=over 4
+
+=item cust_main
+
+Customer (as a FS::cust_main object)
+
+=item custnum
+
+Customer number (if cust_main is not provided).
+
+=item countrydefault
+
+=item nobalance
+
+=item url
+
+=back
+
=item small_custview CUSTNUM || CUST_MAIN_OBJECT, COUNTRYDEFAULT, NOBALANCE_FLAG, URL
-Sheesh. I did switch to mason, but this is still hanging around. Figure out
-some better way to sling mason components to self-service & RT.
+Old-style (deprecated) interface.
=cut
sub small_custview {
+ my( $cust_main, $countrydefault, $nobalance, $url, $nopkg );
+ if ( ref($_[0]) eq 'HASH' ) {
+ my $opt = shift;
+ $cust_main = $opt->{cust_main}
+ || qsearchs('cust_main', { 'custnum' => $opt->{custnum} } );
+ $countrydefault = $opt->{countrydefault} || 'US';
+ $nobalance = $opt->{nobalance};
+ $url = $opt->{url};
+ $nopkg = $opt->{nopkg};
+ } else {
+ my $arg = shift;
+ $countrydefault = shift || 'US';
+ $nobalance = shift;
+ $url = shift;
+ $nopkg = 0;
+
+ $cust_main = ref($arg) ? $arg
+ : qsearchs('cust_main', { 'custnum' => $arg } )
+ or die "unknown custnum $arg";
+ }
- my $arg = shift;
- my $countrydefault = shift || 'US';
- my $nobalance = shift;
- my $url = shift;
-
- my $cust_main = ref($arg) ? $arg
- : qsearchs('cust_main', { 'custnum' => $arg } )
- or die "unknown custnum $arg";
-
- my $html;
+ my $html = '
';
- $html = qq!View
'
+ $html = qq!'
if $url;
- $html .= 'Customer #'. $cust_main->display_custnum. ''.
- ' -
'.
- ucfirst($cust_main->status). ''.
+ if ( $FS::CurrentUser::CurrentUser->num_agents ) {
+ $html .= encode_entities($cust_main->agent->agent). ' ';
+ }
+
+ $html .= 'Customer #
'. $cust_main->display_custnum.
+ ':
'. encode_entities($cust_main->name). ''.
+ ' -
'.
+ $cust_main->status_label. '';
+
+ $html .= ' (Balance:
$'. $cust_main->balance. ')'
+ unless $nobalance;
+
+ my @part_tag = $cust_main->part_tag;
+ if ( @part_tag ) {
+ $html .= '
';
+ foreach my $part_tag ( @part_tag ) {
+ $html .= ''.
+ 'tagcolor)
+ ? 'STYLE="background-color:#'.$part_tag->tagcolor.'"'
+ : ''
+ ).
+ '>'.
+ encode_entities($part_tag->tagname.': '. $part_tag->tagdesc).
+ ''.
+ ' |
';
+ }
+ $html .= '
';
+ }
+
+ $html .=
ntable('#e8e8e8'). '
'. ntable("#cccccc",2).
- ' |
Billing Address | '.
- $cust_main->getfield('last'). ', '. $cust_main->first. ' ';
+ ' |
Billing Address | ';
- $html .= $cust_main->company. ' ' if $cust_main->company;
- $html .= $cust_main->address1. ' ';
- $html .= $cust_main->address2. ' ' if $cust_main->address2;
- $html .= $cust_main->city. ', '. $cust_main->state. ' '. $cust_main->zip. ' ';
- $html .= $cust_main->country. ' '
- if $cust_main->country && $cust_main->country ne $countrydefault;
+ if ( $cust_main->bill_locationnum ) {
+
+ $html .= encode_entities($cust_main->address1). ' ';
+ $html .= encode_entities($cust_main->address2). ' '
+ if $cust_main->address2;
+ $html .= encode_entities($cust_main->city) . ', ' if $cust_main->city;
+ $html .= encode_entities($cust_main->state). ' '.
+ encode_entities($cust_main->zip). ' ';
+ $html .= encode_entities($cust_main->country). ' '
+ if $cust_main->country && $cust_main->country ne $countrydefault;
+
+ }
$html .= ' |
| ';
if ( $cust_main->daytime && $cust_main->night ) {
@@ -62,53 +156,51 @@ sub small_custview {
$html .= ' |
';
- if ( defined $cust_main->dbdef_table->column('ship_last') ) {
+ if ( $cust_main->ship_locationnum ) {
- my $pre = $cust_main->ship_last ? 'ship_' : '';
+ my $ship = $cust_main->ship_location;
$html .= '
'. ntable("#cccccc",2).
- ' | Service Address | '.
- $cust_main->get("${pre}last"). ', '.
- $cust_main->get("${pre}first"). ' ';
- $html .= $cust_main->get("${pre}company"). ' '
- if $cust_main->get("${pre}company");
- $html .= $cust_main->get("${pre}address1"). ' ';
- $html .= $cust_main->get("${pre}address2"). ' '
- if $cust_main->get("${pre}address2");
- $html .= $cust_main->get("${pre}city"). ', '.
- $cust_main->get("${pre}state"). ' '.
- $cust_main->get("${pre}zip"). ' ';
- $html .= $cust_main->get("${pre}country"). ' '
- if $cust_main->get("${pre}country")
- && $cust_main->get("${pre}country") ne $countrydefault;
-
- $html .= ' |
| ';
-
- if ( $cust_main->get("${pre}daytime") && $cust_main->get("${pre}night") ) {
- use FS::Msgcat;
- $html .= ( FS::Msgcat::_gettext('daytime') || 'Day' ).
- ' '. $cust_main->get("${pre}daytime").
- ' '. ( FS::Msgcat::_gettext('night') || 'Night' ).
- ' '. $cust_main->get("${pre}night");
- } elsif ( $cust_main->get("${pre}daytime")
- || $cust_main->get("${pre}night") ) {
- $html .= $cust_main->get("${pre}daytime")
- || $cust_main->get("${pre}night");
- }
- if ( $cust_main->get("${pre}fax") ) {
- $html .= ' Fax '. $cust_main->get("${pre}fax");
- }
+ ' |
Service Address | ';
+ $html .= join(' ',
+ map encode_entities($_), grep $_,
+ $cust_main->ship_company,
+ $ship->address1,
+ $ship->address2,
+ (($ship->city ? $ship->city . ', ' : '') . $ship->state . ' ' . $ship->zip),
+ ($ship->country eq $countrydefault ? '' : $ship->country ),
+ );
+
+ # ship phone numbers no longer exist...
$html .= ' |
';
+
}
- $html .= '';
+ $html .= '';
- $html .= '
Balance:
$'. $cust_main->balance. ''
- unless $nobalance;
+ #would be better to use ncancelled_active_pkgs, but that doesn't have an
+ # optimization to just count them yet, so it would be a perf problem on
+ # tons-of-package customers
+ if ( !$nopkg && scalar($cust_main->ncancelled_pkgs) < 20 ) {
+
+ foreach my $cust_pkg ( $cust_main->ncancelled_active_pkgs ) {
+
+ $html .= '
'.
+ ''.
+ ucfirst($cust_pkg->status). ' - '.
+ encode_entities($cust_pkg->part_pkg->pkg_comment_only(nopkgpart=>1)).
+ ' |
';
+ }
+
+ }
+
+ $html .= '';
# last payment might be good here too?
+ $html .= '
';
+
$html;
}
@@ -125,5 +217,22 @@ sub ntable {
}
+=back
+
+=head1 BUGS
+
+Sheesh. I did switch to mason, but this is still hanging around. Figure out
+some better way to sling mason components to self-service & RT.
+
+(Or, is it useful to have this without depending on the regular back-office UI
+and Mason stuff to be in place? So we have something suitable for displaying
+customer information in other external systems, not just RT?)
+
+=head1 SEE ALSO
+
+L