1 <& /elements/header.html,
2 { title => 'Sales Report',
4 <SCRIPT TYPE="text/javascript" SRC="'. $p. 'elements/jquery.js"></SCRIPT>
5 <SCRIPT TYPE="text/javascript" SRC="'. $p. 'elements/spectrum.js"></SCRIPT>
6 <LINK REL="stylesheet" HREF="'. $p. 'elements/spectrum.css" />',
10 <FORM ACTION="cust_bill_pkg.cgi" METHOD="GET">
12 <TABLE BGCOLOR="#cccccc" CELLSPACING=0>
15 <TH CLASS="background" COLSPAN=2 ALIGN="left"><FONT SIZE="+1"><% mt('Search options') |h %></FONT></TH>
18 <% include('/elements/tr-select-from_to.html' ) %>
21 <TD ALIGN="right"><INPUT TYPE="checkbox" NAME="projection" VALUE="1"></TD>
22 <TD>Show projected data for future months</TD>
25 <SCRIPT TYPE="text/javascript">
27 function agent_changed(obj) {
29 if ( obj.value == '' ) { //breakdown, one color list per agent needed
30 document.getElementById('agent0-label').style.display = '';
31 % for ( 1 .. $#agents ) {
32 document.getElementById('agent<% $_ %>-colors').style.display = '';
34 } else { //aggregate, only one color list needed
35 document.getElementById('agent0-label').style.display = 'none';
36 % for ( 1 .. $#agents ) {
37 document.getElementById('agent<% $_ %>-colors').style.display = 'none';
41 enable_agent_totals(obj);
44 function enable_agent_totals(obj) {
45 %# enable it iff we are breaking down by agent AND something else
46 obj.form.agent_totals.disabled = !(
47 obj.form.agentnum.value == '' && (
48 obj.form.refnum.value == '' ||
49 document.getElementById('class_agg_break_breakdown').checked ||
50 obj.form.use_setup.value == 1 ||
51 obj.form.use_usage.value == 1
56 function class_mode_changed() {
57 var options = document.getElementsByName('class_mode');
59 for(var i=0; i < options.length; i++) {
60 if (options[i].checked) {
61 mode = options[i].value;
65 var div_pkg = document.getElementById('pkg_class');
66 var div_report = document.getElementById('report_class');
68 div_pkg.style.display = '';
69 div_report.style.display = 'none';
70 } else if (mode == 'report') {
71 div_pkg.style.display = 'none';
72 div_report.style.display = '';
75 window.onload = class_mode_changed;
78 <& /elements/tr-select-agent.html,
79 'field' => 'agentnum',
82 'pre_options' => [ 'all' => 'all (aggregate)' ],
83 'empty_label' => 'all (breakdown)',
84 'onchange' => 'agent_changed',
87 <& /elements/tr-select-cust_class.html,
88 'field' => 'cust_classnum',
89 'label' => 'Customer class',
93 <& /elements/tr-select-part_referral.html,
95 'label' => 'Advertising source ',
97 'pre_options' => [ 'all' => 'all (aggregate)' ],
98 'empty_label' => 'all (breakdown)',
99 'onchange' => 'enable_agent_totals'
105 <INPUT TYPE="radio" NAME="class_mode" VALUE="pkg" onchange="class_mode_changed('pkg')" CHECKED>
106 <% emt('Package class') %>
108 <INPUT TYPE="radio" NAME="class_mode" VALUE="report" onchange="class_mode_changed('report')">
109 <% emt('Report class') %>
118 <& /elements/select-pkg_class.html,
119 'field' => 'classnum',
122 'pre_options' => [ #'all' => 'all (aggregate)',
123 # '' => 'all (breakdown)',
124 '0' => '(empty class)' ],
125 'disable_empty' => 1,
126 'onchange' => 'enable_agent_totals',
129 <DIV ID="report_class" STYLE="display: none">
130 <& /elements/select-table.html,
131 'field' => 'report_optionnum',
132 'table' => 'part_pkg_report_option',
133 'name_col' => 'name',
134 'value_col' => 'num',
137 'pre_options' => [ #'all' => 'all (aggregate)',
138 # '' => 'all (breakdown)',
139 '0' => '(empty class)' ],
140 'disable_empty' => 1,
141 'onchange' => 'enable_agent_totals',
147 <INPUT TYPE="radio" NAME="class_agg_break" ID="class_agg_break_aggregate" VALUE="aggregate" onchange="enable_agent_totals(this)" CHECKED>
148 <% emt('Aggregate') %>
150 <INPUT TYPE="radio" NAME="class_agg_break" ID="class_agg_break_breakdown" VALUE="breakdown" onchange="enable_agent_totals(this)">
151 <% emt('Breakdown') %>
162 <TH CLASS="background" COLSPAN=2> </TH>
166 <TH CLASS="background" COLSPAN=2 ALIGN="left"><FONT SIZE="+1"><% mt('Display options') |h %></FONT></TH>
171 <TD ALIGN="right"><INPUT TYPE="checkbox" NAME="separate_0freq" VALUE="1"></TD>
172 <TD>Separate one-time vs. recurring sales</TD>
176 % foreach ( qw(Setup Usage) ) {
177 <& /elements/tr-select.html,
178 'label' => "$_ fees",
179 'field' => 'use_'.lc($_),
180 'options' => [ 0, 1, 2 ],
181 'labels' => { 0 => 'Combine', 1 => 'Separate', 2 => 'Do not show' },
182 'onchange'=> 'enable_agent_totals',
187 <TD ALIGN="right">Colors</TD>
191 % #no particular long-term attachment to this, just trying to replicate
192 % # historical behavior so people's graphs don't change color suddenly in 3.x
194 % my $hue_increment = 125;
198 % foreach my $agent ( @agents ) {
199 <TR <% $anum ? 'STYLE="display:none"' : '' %>
200 ID="agent<%$anum%>-colors"
202 <TD <% $anum ? '' :'STYLE="display:none"' %>
203 ID="agent<%$anum%>-label"
205 <% $agent->agent |h %>
208 % my $col_scheme = Color::Scheme->new
209 % ->from_hue($hue) #->from_hex($agent->color)
210 % ->scheme('analogic')
214 % my @colors = ($col_scheme->colors)[ 0,4,8,1,5,9 ];#again some some random historical shite
216 % my $name = "agent$anum-color$cnum";
217 % push @names, $name;
219 <INPUT TYPE = "color"
228 % $hue += $hue_increment;
234 <SCRIPT TYPE="text/javascript">
235 $(document).ready(function() {
236 % foreach my $name (@names) {
237 $("#<% $name %>").spectrum({
238 clickoutFiresChange: true
245 <TD ALIGN="right"><INPUT TYPE="checkbox" NAME="agent_totals" VALUE="1" DISABLED="1"></TD>
246 <TD>Show per-agent subtotals</TD>
250 <TD ALIGN="right"><INPUT TYPE="checkbox" NAME="use_override" VALUE="1"></TD>
251 <TD>Separate sub-packages from parents</TD>
255 <TD ALIGN="right"><INPUT TYPE="checkbox" NAME="average_per_cust_pkg" VALUE="1"></TD>
256 <TD>Average per customer package</TD>
260 <TD ALIGN="right"><INPUT TYPE="checkbox" NAME="distribute" VALUE="1"></TD>
261 <TD>Distribute recurring fees over billing period</TD>
266 <BR><INPUT TYPE="submit" VALUE="Display">
269 <% include('/elements/footer.html') %>
273 unless $FS::CurrentUser::CurrentUser->access_right('Financial reports');
275 my @agents = $FS::CurrentUser::CurrentUser->agents;