1 package FS::UI::Web::small_custview;
4 use vars qw(@EXPORT_OK @ISA);
8 use FS::Record qw(qsearchs);
12 @EXPORT_OK = qw( small_custview );
14 =item small_custview CUSTNUM || CUST_MAIN_OBJECT, COUNTRYDEFAULT, NOBALANCE_FLAG, URL
16 Sheesh. I did switch to mason, but this is still hanging around. Figure out
17 some better way to sling mason components to self-service & RT.
24 my $countrydefault = shift || 'US';
25 my $nobalance = shift;
28 my $cust_main = ref($arg) ? $arg
29 : qsearchs('cust_main', { 'custnum' => $arg } )
30 or die "unknown custnum $arg";
34 $html = qq!View <A HREF="$url?! . $cust_main->custnum . '">'
37 $html .= 'Customer #<B>'. $cust_main->display_custnum. '</B></A>'.
38 ' - <B><FONT COLOR="#'. $cust_main->statuscolor. '">'.
39 ucfirst($cust_main->status). '</FONT></B>';
41 my @part_tag = $cust_main->part_tag;
44 foreach my $part_tag ( @part_tag ) {
46 '<FONT '. ( length($part_tag->tagcolor)
47 ? 'STYLE="background-color:#'.$part_tag->tagcolor.'"'
51 encode_entities($part_tag->tagname.': '. $part_tag->tagdesc).
59 ntable('#e8e8e8'). '<TR><TD VALIGN="top">'. ntable("#cccccc",2).
60 '<TR><TD ALIGN="right" VALIGN="top">Billing<BR>Address</TD><TD BGCOLOR="#ffffff">'.
61 $cust_main->getfield('last'). ', '. $cust_main->first. '<BR>';
63 $html .= $cust_main->company. '<BR>' if $cust_main->company;
64 $html .= $cust_main->address1. '<BR>';
65 $html .= $cust_main->address2. '<BR>' if $cust_main->address2;
66 $html .= $cust_main->city. ', '. $cust_main->state. ' '. $cust_main->zip. '<BR>';
67 $html .= $cust_main->country. '<BR>'
68 if $cust_main->country && $cust_main->country ne $countrydefault;
70 $html .= '</TD></TR><TR><TD></TD><TD BGCOLOR="#ffffff">';
71 if ( $cust_main->daytime && $cust_main->night ) {
72 $html .= ( FS::Msgcat::_gettext('daytime') || 'Day' ).
73 ' '. $cust_main->daytime.
74 '<BR>'. ( FS::Msgcat::_gettext('night') || 'Night' ).
75 ' '. $cust_main->night;
76 } elsif ( $cust_main->daytime || $cust_main->night ) {
77 $html .= $cust_main->daytime || $cust_main->night;
79 if ( $cust_main->fax ) {
80 $html .= '<BR>Fax '. $cust_main->fax;
83 $html .= '</TD></TR></TABLE></TD>';
85 if ( defined $cust_main->dbdef_table->column('ship_last') ) {
87 my $pre = $cust_main->ship_last ? 'ship_' : '';
89 $html .= '<TD VALIGN="top">'. ntable("#cccccc",2).
90 '<TR><TD ALIGN="right" VALIGN="top">Service<BR>Address</TD><TD BGCOLOR="#ffffff">'.
91 $cust_main->get("${pre}last"). ', '.
92 $cust_main->get("${pre}first"). '<BR>';
93 $html .= $cust_main->get("${pre}company"). '<BR>'
94 if $cust_main->get("${pre}company");
95 $html .= $cust_main->get("${pre}address1"). '<BR>';
96 $html .= $cust_main->get("${pre}address2"). '<BR>'
97 if $cust_main->get("${pre}address2");
98 $html .= $cust_main->get("${pre}city"). ', '.
99 $cust_main->get("${pre}state"). ' '.
100 $cust_main->get("${pre}zip"). '<BR>';
101 $html .= $cust_main->get("${pre}country"). '<BR>'
102 if $cust_main->get("${pre}country")
103 && $cust_main->get("${pre}country") ne $countrydefault;
105 $html .= '</TD></TR><TR><TD></TD><TD BGCOLOR="#ffffff">';
107 if ( $cust_main->get("${pre}daytime") && $cust_main->get("${pre}night") ) {
109 $html .= ( FS::Msgcat::_gettext('daytime') || 'Day' ).
110 ' '. $cust_main->get("${pre}daytime").
111 '<BR>'. ( FS::Msgcat::_gettext('night') || 'Night' ).
112 ' '. $cust_main->get("${pre}night");
113 } elsif ( $cust_main->get("${pre}daytime")
114 || $cust_main->get("${pre}night") ) {
115 $html .= $cust_main->get("${pre}daytime")
116 || $cust_main->get("${pre}night");
118 if ( $cust_main->get("${pre}fax") ) {
119 $html .= '<BR>Fax '. $cust_main->get("${pre}fax");
122 $html .= '</TD></TR></TABLE></TD>';
125 $html .= '</TR></TABLE>';
127 $html .= '<BR>Balance: <B>$'. $cust_main->balance. '</B><BR>'
130 # last payment might be good here too?
135 #bah. don't want to pull in all of FS::CGI, that's the whole problem in the
139 my $cellspacing = shift || 0;
141 qq!<TABLE BGCOLOR="$col" BORDER=0 CELLSPACING=$cellspacing>!;
143 '<TABLE BORDER CELLSPACING=0 CELLPADDING=2 BORDERCOLOR="#999999">';