1 <% include("/elements/header.html",'Agent Listing', menubar(
2 'Agent Types' => $p. 'browse/agent_type.cgi',
3 # 'Add new agent' => '../edit/agent.cgi'
5 Agents are resellers of your service. Agents may be limited to a subset of your
6 full offerings (via their type).<BR><BR>
7 <A HREF="<% $p %>edit/agent.cgi"><I>Add a new agent</I></A><BR><BR>
8 % if ( dbdef->table('agent')->column('disabled') ) {
10 <% $cgi->param('showdisabled')
11 ? do { $cgi->param('showdisabled', 0);
12 '( <a href="'. $cgi->self_url. '">hide disabled agents</a> )'; }
13 : do { $cgi->param('showdisabled', 1);
14 '( <a href="'. $cgi->self_url. '">show disabled agents</a> )'; }
19 <% include('/elements/table-grid.html') %>
20 % my $bgcolor1 = '#eeeeee';
21 % my $bgcolor2 = '#ffffff';
25 <TH CLASS="grid" BGCOLOR="#cccccc" COLSPAN=<% ( $cgi->param('showdisabled') || !dbdef->table('agent')->column('disabled') ) ? 2 : 3 %>>Agent</TH>
26 <TH CLASS="grid" BGCOLOR="#cccccc">Type</TH>
27 <TH CLASS="grid" BGCOLOR="#cccccc">Master Customer</TH>
28 <TH CLASS="grid" BGCOLOR="#cccccc">Commissions</TH>
29 <TH CLASS="grid" BGCOLOR="#cccccc">Access Groups</TH>
30 <TH CLASS="grid" BGCOLOR="#cccccc"><FONT SIZE=-1>Invoice<BR>Template</FONT></TH>
31 <TH CLASS="grid" BGCOLOR="#cccccc">Customers</TH>
32 <TH CLASS="grid" BGCOLOR="#cccccc"><FONT SIZE=-1>Customer<BR>packages</FONT></TH>
33 <TH CLASS="grid" BGCOLOR="#cccccc">Reports</TH>
34 <TH CLASS="grid" BGCOLOR="#cccccc"><FONT SIZE=-1>Registration<BR>codes</FONT></TH>
35 <TH CLASS="grid" BGCOLOR="#cccccc">Prepaid cards</TH>
37 % if ( $conf->config('ticket_system') ) {
38 <TH CLASS="grid" BGCOLOR="#cccccc">Ticketing</TH>
41 <TH CLASS="grid" BGCOLOR="#cccccc"><FONT SIZE=-1>Payment Gateway Overrides</FONT></TH>
42 <TH CLASS="grid" BGCOLOR="#cccccc"><FONT SIZE=-1>Configuration Overrides</FONT></TH>
45 %# <TH><FONT SIZE=-1>Agent #</FONT></TH>
47 %foreach my $agent ( sort {
48 % #$a->getfield('agentnum') <=> $b->getfield('agentnum')
49 % $a->getfield('agent') cmp $b->getfield('agent')
50 %} qsearch('agent', \%search ) ) {
52 % my $cust_main_link = $p. 'search/cust_main.cgi?agentnum_on=1&'.
53 % 'agentnum='. $agent->agentnum;
55 % my $cust_pkg_link = $p. 'search/cust_pkg.cgi?agentnum='. $agent->agentnum;
57 % if ( $bgcolor eq $bgcolor1 ) {
58 % $bgcolor = $bgcolor2;
60 % $bgcolor = $bgcolor1;
68 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
69 <A HREF="<%$p%>edit/agent.cgi?<% $agent->agentnum %>"><% $agent->agentnum %></A>
75 % if ( ! $cgi->param('showdisabled') ) {
76 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>" ALIGN="center">
77 <% $agent->disabled ? '<FONT COLOR="#FF0000"><B>DISABLED</B></FONT>'
78 : '<FONT COLOR="#00CC00"><B>Active</B></FONT>'
86 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
87 <A HREF="<%$p%>edit/agent.cgi?<% $agent->agentnum %>"><% $agent->agent %></A>
93 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
94 <A HREF="<%$p%>edit/agent_type.cgi?<% $agent->typenum %>"><% $agent->agent_type->atype %></A>
100 <TD CLASS="inv" BGCOLOR="<% $bgcolor %>">
101 % if ( $agent->agent_custnum ) {
102 <& /elements/small_custview.html,
103 $agent->agent_custnum,
104 scalar($conf->config('countrydefault')),
106 $p.'view/cust_main.cgi',
115 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
119 % #surprising amount of false laziness w/ edit/process/agent.cgi
120 % my @pkg_class = qsearch('pkg_class', { 'disabled'=>'' });
121 % foreach my $pkg_class ( '', @pkg_class ) {
122 % my %agent_pkg_class = ( 'agentnum' => $agent->agentnum,
123 % 'classnum' => $pkg_class ? $pkg_class->classnum : ''
125 % my $agent_pkg_class =
126 % qsearchs( 'agent_pkg_class', \%agent_pkg_class )
127 % || new FS::agent_pkg_class \%agent_pkg_class;
128 % my $param = 'classnum'. $agent_pkg_class{classnum};
131 <TD><% $agent_pkg_class->commission_percent || 0 %>%</TD>
132 <TD><% $pkg_class ? $pkg_class->classname : mt('(no package class)') |h %>
145 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
146 % foreach my $access_group (
147 % map $_->access_group,
148 % qsearch('access_groupagent', { 'agentnum' => $agent->agentnum })
150 <A HREF="<%$p%>edit/access_group.html?<% $access_group->groupnum %>"><% $access_group->groupname |h %><BR>
157 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
158 <% $agent->invoice_template || '(Default)' %>
165 <TD CLASS="inv" BGCOLOR="<% $bgcolor %>" VALIGN="bottom">
166 <TABLE CLASS="inv" CELLSPACING=0 CELLPADDING=0>
169 % qw( prospect inactive ordered active suspended cancelled );
170 % my %method = ( 'suspended' => 'susp',
171 % 'cancelled' => 'cancel'
173 % my %PL = ( 'prospect' => 'prospects', );
174 % my %link = ( 'cancelled' => 'showcancelledcustomers=1&cancelled' );
175 % my $statuscolor = FS::cust_main->statuscolors;
177 % foreach my $status ( @cust_status ) {
178 % my $meth = exists($method{$status}) ? $method{$status} : $status;
179 % $meth = 'num_'. $meth. '_cust_main';
180 % my $link = exists($link{$status}) ? $link{$status} : $status;
184 % unless ( $disable_counts ) {
185 <TH ALIGN="right" WIDTH="40%">
186 <FONT COLOR="#<% $statuscolor->{$status} %>">
187 <% $num = $agent->$meth() %>
192 % if ( $num || $disable_counts ) {
195 <A HREF="<% $cust_main_link. "&$link=1" %>">
197 <% exists($PL{$status}) ? $PL{$status} : $status %>
198 % if ($num || $disable_counts ) {
211 % # customer packages
214 <TD CLASS="inv" BGCOLOR="<% $bgcolor %>" VALIGN="bottom">
215 <TABLE CLASS="inv" CELLSPACING=0 CELLPADDING=0>
217 % #my @pkg_status = FS::cust_pkg->statuses;
218 % my @pkg_status = ( 'on hold', 'one-time charge', 'not yet billed',
219 % qw( active suspended cancelled ) );
220 % my %method = ( 'one-time charge' => 'inactive',
221 % 'suspended' => 'susp',
222 % 'cancelled' => 'cancel',
224 % my $statuscolor = FS::cust_pkg->statuscolors;
226 % foreach my $status ( @pkg_status ) {
227 % my $magic = exists($method{$status}) ? $method{$status} : $status;
229 % my $meth = 'num_'. $magic. '_cust_pkg';
230 % ( my $label = $status ) =~ s/ / /g;
234 % unless ( $disable_counts ) {
235 <TH ALIGN="right" WIDTH="40%">
236 <FONT COLOR="#<% $statuscolor->{$status} %>">
237 <% $num = $agent->$meth() %>
243 % if ( $num || $disable_counts ) {
245 <A HREF="<% $cust_pkg_link %>&magic=<% $magic %>">
248 % if ( $num || $disable_counts ) {
263 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
264 <A HREF="<% $p %>graph/report_cust_pkg.html?agentnum=<% $agent->agentnum %>">Package Churn</A>
265 <BR><A HREF="<% $p %>search/report_cust_pay.html?agentnum=<% $agent->agentnum %>">Payments</A>
266 <BR><A HREF="<% $p %>search/report_cust_credit.html?agentnum=<% $agent->agentnum %>">Credits</A>
267 <BR><A HREF="<% $p %>search/report_receivables.cgi?agentnum=<% $agent->agentnum %>">A/R Aging</A>
268 <!--<BR><A HREF="<% $p %>search/money_time.cgi?agentnum=<% $agent->agentnum %>">Sales/Credits/Receipts</A>-->
272 % # registration codes
275 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
276 <% my $num_reg_code = $agent->num_reg_code %>
277 % if ( $num_reg_code ) {
279 <A HREF="<%$p%>search/reg_code.html?agentnum=<% $agent->agentnum %>">
282 % if ( $num_reg_code ) {
286 <BR><A HREF="<%$p%>edit/reg_code.cgi?agentnum=<% $agent->agentnum %>">Generate codes</A>
293 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
294 <% my $num_prepay_credit = $agent->num_prepay_credit %>
295 % if ( $num_prepay_credit ) {
297 <A HREF="<%$p%>search/prepay_credit.html?agentnum=<% $agent->agentnum %>">
300 % if ( $num_prepay_credit ) {
304 <BR><A HREF="<%$p%>edit/prepay_credit.cgi?agentnum=<% $agent->agentnum %>">Generate cards</A>
310 % if ( $conf->config('ticket_system') ) {
311 <TD CLASS="grid" BGCOLOR="<% $bgcolor %>">
312 % if ( $agent->ticketing_queueid ) {
313 Queue: <% $agent->ticketing_queueid %>: <% $agent->ticketing_queue %><BR>
320 % # payment gateway overrides
322 <TD CLASS="inv" BGCOLOR="<% $bgcolor %>">
323 <TABLE CLASS="inv" CELLSPACING=0 CELLPADDING=0>
324 % foreach my $override (
325 % # sort { } want taxclass-full stuff first? and default cards (empty cardtype)
326 % qsearch('agent_payment_gateway', { 'agentnum' => $agent->agentnum } )
332 <% $override->cardtype || 'Default' %> to <% $override->payment_gateway->gateway_module %> (<% $override->payment_gateway->gateway_username %>)
333 <% $override->taxclass
334 ? ' for '. $override->taxclass. ' only'
337 <FONT SIZE=-1><A HREF="javascript:areyousure('delete this payment gateway override', '<%$p%>misc/delete-agent_payment_gateway.cgi?<% $override->agentgatewaynum %>')">(delete)</A></FONT>
343 <TD><FONT SIZE=-1><A HREF="<%$p%>edit/agent_payment_gateway.html?agentnum=<% $agent->agentnum %>">(add override)</A></FONT></TD>
349 % # configuration overrides
352 <TD CLASS="inv" BGCOLOR="<% $bgcolor %>">
353 <TABLE CLASS="inv" CELLSPACING=0 CELLPADDING=0>
354 % foreach my $override (
355 % qsearch('conf', { 'agentnum' => $agent->agentnum } )
361 <% $override->name %> <FONT SIZE=-1><A HREF="javascript:areyousure('delete this configuration override', '<%$p%>config/config-delete.cgi?confnum=<% $override->confnum %>')">(delete)</A></FONT>
367 <TD><FONT SIZE=-1><A HREF="<%$p%>config/config-view.cgi?agentnum=<% $agent->agentnum %>">(view/add/edit overrides)</A></FONT></TD>
378 <SCRIPT TYPE="text/javascript">
379 function areyousure(what, href) {
380 if ( confirm("Are you sure you want to " + what + "?") == true )
381 window.location.href = href;
390 unless $FS::CurrentUser::CurrentUser->access_right('Configuration');
393 if ( $cgi->param('showdisabled')
394 || !dbdef->table('agent')->column('disabled') ) {
397 %search = ( 'disabled' => '' );
400 my $conf = new FS::Conf;
401 my $disable_counts = $conf->exists('agent-disable_counts');