diff options
| author | Ivan Kohler <ivan@freeside.biz> | 2015-07-09 22:32:26 -0700 | 
|---|---|---|
| committer | Ivan Kohler <ivan@freeside.biz> | 2015-07-09 22:32:26 -0700 | 
| commit | 026dc7ad72ba972f230b6709e31fa64397d75ad4 (patch) | |
| tree | c5af1a7ac9154744afc3660e9a9405892f2bb50b /FS | |
| parent | 07b4bc84d1078f7390221d766cdb3142513db4b0 (diff) | |
| parent | 1c538bfabc2cd31f27067505f0c3d1a46cba6ef0 (diff) | |
merge RT 4.2.11 and Header changes to disable RT javascript, RT#34237
Diffstat (limited to 'FS')
| -rw-r--r-- | FS/FS/ConfDefaults.pm | 3 | ||||
| -rw-r--r-- | FS/FS/Report/Table.pm | 58 | ||||
| -rw-r--r-- | FS/FS/UI/Web.pm | 1 | ||||
| -rw-r--r-- | FS/FS/cust_main.pm | 2 | 
4 files changed, 26 insertions, 38 deletions
| diff --git a/FS/FS/ConfDefaults.pm b/FS/FS/ConfDefaults.pm index de08f7d68..5b8399af5 100644 --- a/FS/FS/ConfDefaults.pm +++ b/FS/FS/ConfDefaults.pm @@ -71,6 +71,9 @@ sub cust_fields_avail { (    'Cust# | Cust. Status | Name | Company | (bill) Address 1 | (bill) Address 2 | (bill) City | (bill) State | (bill) Zip | (bill) Country | Day phone | Night phone | Mobile phone | Fax number | (service) Address 1 | (service) Address 2 | (service) City | (service) State | (service) Zip | (service) Country | Invoicing email(s) | Payment Type | Current Balance' =>      'custnum | Status | Last, First | Company | (address) | (all phones) | (service address) | Invoicing email(s) | Payment Type | Current Balance', +  'Cust# | Cust. Status | Name | Company | (bill) Address 1 | (bill) Address 2 | (bill) City | (bill) State | (bill) Zip | (bill) Country | Day phone | Night phone | Mobile phone | Fax number | (service) Address 1 | (service) Address 2 | (service) City | (service) State | (service) Zip | (service) Country | Invoicing email(s) | Payment Type | Current Balance | Agent Cust#' => +    'custnum | Status | Last, First | Company | (address) | (all phones) | (service address) | Invoicing email(s) | Payment Type | Current Balance | Agent Cust#', +    'Cust# | Cust. Status | Name | Company | (bill) Address 1 | (bill) Address 2 | (bill) City | (bill) State | (bill) Zip | (bill) Country | (bill) Latitude | (bill) Longitude | Day phone | Night phone | Mobile phone | Fax number | (service) Address 1 | (service) Address 2 | (service) City | (service) State | (service) Zip | (service) Country | (service) Latitude | (service) Longitude | Invoicing email(s) | Payment Type | Current Balance' =>      'custnum | Status | Last, First | Company | (address+coord) | (all phones) | (service address+coord) | Invoicing email(s) | Payment Type | Current Balance', diff --git a/FS/FS/Report/Table.pm b/FS/FS/Report/Table.pm index eef983d68..cba968b43 100644 --- a/FS/FS/Report/Table.pm +++ b/FS/FS/Report/Table.pm @@ -439,8 +439,8 @@ sub cust_pkg_recur_cost {  =item cust_bill_pkg: the total package charges on invoice line items. -'charges': limit the type of charges included (setup, recur, usage). -Should be a string containing one or more of 'S', 'R', or 'U'; if  +'charges': limit the type of charges included (setup, recur, usage, discount). +Should be a string containing one or more of 'S', 'R', 'U', or 'D'; if   unspecified, defaults to all three.  'classnum': limit to this package class. @@ -470,6 +470,7 @@ sub cust_bill_pkg {    $sum += $self->cust_bill_pkg_setup(@_) if $charges{S};    $sum += $self->cust_bill_pkg_recur(@_) if $charges{R};    $sum += $self->cust_bill_pkg_detail(@_) if $charges{U}; +  $sum += $self->cust_bill_pkg_discount(@_) if $charges{D};    if ($opt{'average_per_cust_pkg'}) {      my $count = $self->cust_bill_pkg_count_pkgnum(@_); @@ -656,47 +657,28 @@ sub cust_bill_pkg_detail {  }  sub cust_bill_pkg_discount { -  my( $self, $speriod, $eperiod, $agentnum, %opt ) = @_; - -  #need to do this the new multi-classnum way if it gets re-enabled -  #my $where = ''; -  #my $comparison = ''; -  #if ( $opt{'classnum'} =~ /^(\d+)$/ ) { -  #  if ( $1 == 0 ) { -  #    $comparison = "IS NULL"; -  #  } else { -  #    $comparison = "= $1"; -  #  } -  # -  #  if ( $opt{'use_override'} ) { -  #    $where = "( -  #      part_pkg.classnum $comparison AND pkgpart_override IS NULL OR -  #      override.classnum $comparison AND pkgpart_override IS NOT NULL -  #    )"; -  #  } else { -  #    $where = "part_pkg.classnum $comparison"; -  #  } -  #} +  my $self = shift; +  my ($speriod, $eperiod, $agentnum, %opt) = @_; +  # apply all the same constraints here as for setup/recur    $agentnum ||= $opt{'agentnum'}; -  my $total_sql = -    " SELECT COALESCE( SUM( cust_bill_pkg_discount.amount ), 0 ) "; +  my @where = ( +    '(pkgnum != 0 OR feepart IS NOT NULL)', +    $self->with_classnum($opt{'classnum'}, $opt{'use_override'}), +    $self->with_report_option(%opt), +    $self->in_time_period_and_agent($speriod, $eperiod, $agentnum), +    $self->with_refnum(%opt), +    $self->with_cust_classnum(%opt) +  ); -  $total_sql .= -    " FROM cust_bill_pkg_discount -        LEFT JOIN cust_bill_pkg USING ( billpkgnum ) -        LEFT JOIN cust_bill USING ( invnum ) -        LEFT JOIN cust_main USING ( custnum ) -      WHERE ". $self->in_time_period_and_agent($speriod, $eperiod, $agentnum); -  #      LEFT JOIN cust_pkg_discount USING ( pkgdiscountnum ) -  #      LEFT JOIN discount USING ( discountnum ) -  #      LEFT JOIN cust_pkg USING ( pkgnum ) -  #      LEFT JOIN part_pkg USING ( pkgpart ) -  #      LEFT JOIN part_pkg AS override ON pkgpart_override = override.pkgpart -   -  return $self->scalar_sql($total_sql); +  my $total_sql = "SELECT COALESCE(SUM(cust_bill_pkg_discount.amount), 0) +  FROM cust_bill_pkg_discount +  JOIN cust_bill_pkg USING (billpkgnum) +  $cust_bill_pkg_join +  WHERE " . join(' AND ', grep $_, @where); +  $self->scalar_sql($total_sql);  }  ##### package churn report ##### diff --git a/FS/FS/UI/Web.pm b/FS/FS/UI/Web.pm index ca50b278e..6655f270f 100644 --- a/FS/FS/UI/Web.pm +++ b/FS/FS/UI/Web.pm @@ -273,6 +273,7 @@ sub cust_header {      'Invoicing email(s)'       => 'invoicing_list_emailonly_scalar',      'Payment Type'             => 'payby',      'Current Balance'          => 'current_balance', +    'Agent Cust#'              => 'agent_custid',    );    $header2method{'Cust#'} = 'display_custnum'      if $conf->exists('cust_main-default_agent_custid'); diff --git a/FS/FS/cust_main.pm b/FS/FS/cust_main.pm index c6602c1a0..f55c3493c 100644 --- a/FS/FS/cust_main.pm +++ b/FS/FS/cust_main.pm @@ -4253,6 +4253,8 @@ sub payment_history {        'description' => 'Previous balance',        'amount'      => sprintf("%.2f",$previous),        'balance'     => sprintf("%.2f",$previous), +      'date'        => $$opt{'start_date'}, +      'date_pretty' => $self->time2str_local('short', $$opt{'start_date'} ),      };      #false laziness with above      foreach my $key ( qw(amount balance) ) { | 
