diff options
| author | ivan <ivan> | 2010-03-30 12:16:00 +0000 | 
|---|---|---|
| committer | ivan <ivan> | 2010-03-30 12:16:00 +0000 | 
| commit | dd2249efe0daa3fc3257029de84d212aa89a4ee9 (patch) | |
| tree | 1908d6b97f240c60baf4246a2d223cd3ae8a508b /FS | |
| parent | fd27587f9cf4c0f1334aaa3ff9eb41e8d10fe4cb (diff) | |
employee commission reporting, RT#6991
Diffstat (limited to 'FS')
| -rw-r--r-- | FS/FS/Schema.pm | 3 | ||||
| -rw-r--r-- | FS/FS/cust_credit.pm | 2 | ||||
| -rw-r--r-- | FS/FS/cust_event.pm | 6 | ||||
| -rw-r--r-- | FS/FS/cust_main.pm | 8 | ||||
| -rw-r--r-- | FS/FS/part_event/Action/pkg_agent_credit.pm | 7 | ||||
| -rw-r--r-- | FS/FS/part_event/Action/pkg_employee_credit.pm | 7 | ||||
| -rw-r--r-- | FS/FS/part_event/Action/pkg_referral_credit.pm | 7 | 
7 files changed, 23 insertions, 17 deletions
| diff --git a/FS/FS/Schema.pm b/FS/FS/Schema.pm index 6756c9c32..660a072b8 100644 --- a/FS/FS/Schema.pm +++ b/FS/FS/Schema.pm @@ -655,10 +655,11 @@ sub tables_hashref {          'addlinfo', 'text', 'NULL', '', '', '',          'closed',    'char', 'NULL', 1, '', '',           'pkgnum', 'int', 'NULL', '', '', '', #desired pkgnum for pkg-balances +        'eventnum', 'int', 'NULL', '', '', '', #triggering event for commission        ],        'primary_key' => 'crednum',        'unique' => [], -      'index' => [ ['custnum'], ['_date'] ], +      'index' => [ ['custnum'], ['_date'], ['eventnum'] ],      },      'cust_credit_bill' => { diff --git a/FS/FS/cust_credit.pm b/FS/FS/cust_credit.pm index 6c3effa13..d0aa3a4b4 100644 --- a/FS/FS/cust_credit.pm +++ b/FS/FS/cust_credit.pm @@ -14,6 +14,7 @@ use FS::cust_credit_bill;  use FS::part_pkg;  use FS::reason_type;  use FS::reason; +use FS::cust_event;  @ISA = qw( FS::cust_main_Mixin FS::Record );  $me = '[ FS::cust_credit ]'; @@ -301,6 +302,7 @@ sub check {      || $self->ut_textn('addlinfo')      || $self->ut_enum('closed', [ '', 'Y' ])      || $self->ut_foreign_keyn('pkgnum', 'cust_pkg', 'pkgnum') +    || $self->ut_foreign_keyn('eventnum', 'cust_event', 'eventnum')    ;    return $error if $error; diff --git a/FS/FS/cust_event.pm b/FS/FS/cust_event.pm index d2fcfc1e2..52b5911dc 100644 --- a/FS/FS/cust_event.pm +++ b/FS/FS/cust_event.pm @@ -1,18 +1,16 @@  package FS::cust_event;  use strict; +use base qw( FS::cust_main_Mixin FS::Record );  use vars qw( @ISA $DEBUG $me );  use Carp qw( croak confess );  use FS::Record qw( qsearch qsearchs dbdef ); -use FS::cust_main_Mixin;  use FS::part_event;  #for cust_X  use FS::cust_main;  use FS::cust_pkg;  use FS::cust_bill; -@ISA = qw(FS::cust_main_Mixin FS::Record); -  $DEBUG = 0;  $me = '[FS::cust_event]'; @@ -230,7 +228,7 @@ sub do_event {    my $error;    {      local $SIG{__DIE__}; # don't want Mason __DIE__ handler active -    $error = eval { $part_event->do_action($object); }; +    $error = eval { $part_event->do_action($object, $self); };    }    my $status = ''; diff --git a/FS/FS/cust_main.pm b/FS/FS/cust_main.pm index 5116049f3..88aceb935 100644 --- a/FS/FS/cust_main.pm +++ b/FS/FS/cust_main.pm @@ -7320,7 +7320,7 @@ sub referral_cust_main_ncancelled {  Like referral_cust_main, except returns a flat list of all unsuspended (and  uncancelled) packages for each customer.  The number of items in this list may -be useful for comission calculations (perhaps after a C<grep { my $pkgpart = $_->pkgpart; grep { $_ == $pkgpart } @commission_worthy_pkgparts> } $cust_main-> ). +be useful for commission calculations (perhaps after a C<grep { my $pkgpart = $_->pkgpart; grep { $_ == $pkgpart } @commission_worthy_pkgparts> } $cust_main-> ).  =cut @@ -7382,8 +7382,10 @@ sub credit {      $cust_credit->set('reason', $reason)    } -  $cust_credit->addlinfo( delete $options{'addlinfo'} ) -    if exists($options{'addlinfo'}); +  for (qw( addlinfo eventnum )) { +    $cust_credit->$_( delete $options{$_} ) +      if exists($options{$_}); +  }    $cust_credit->insert(%options); diff --git a/FS/FS/part_event/Action/pkg_agent_credit.pm b/FS/FS/part_event/Action/pkg_agent_credit.pm index 250273846..4bcee983b 100644 --- a/FS/FS/part_event/Action/pkg_agent_credit.pm +++ b/FS/FS/part_event/Action/pkg_agent_credit.pm @@ -7,7 +7,7 @@ sub description { 'Credit the agent a specific amount'; }  #a little false laziness w/pkg_referral_credit  sub do_action { -  my( $self, $cust_pkg ) = @_; +  my( $self, $cust_pkg, $cust_event ) = @_;    my $cust_main = $self->cust_main($cust_pkg); @@ -26,8 +26,9 @@ sub do_action {    my $error = $agent_cust_main->credit(      $amount,       \$reasonnum, -    'addlinfo' => -      'for customer #'. $cust_main->display_custnum. ': '.$cust_main->name, +    'eventnum' => $cust_event->eventnum, +    'addlinfo' => 'for customer #'. $cust_main->display_custnum. +                               ': '.$cust_main->name,    );    die "Error crediting customer ". $agent_cust_main->custnum.        " for agent commission: $error" diff --git a/FS/FS/part_event/Action/pkg_employee_credit.pm b/FS/FS/part_event/Action/pkg_employee_credit.pm index 94fc5f3b1..e4913a21f 100644 --- a/FS/FS/part_event/Action/pkg_employee_credit.pm +++ b/FS/FS/part_event/Action/pkg_employee_credit.pm @@ -9,7 +9,7 @@ sub description { 'Credit the ordering employee a specific amount'; }  #a little false laziness w/pkg_referral_credit  sub do_action { -  my( $self, $cust_pkg ) = @_; +  my( $self, $cust_pkg, $cust_event ) = @_;    my $cust_main = $self->cust_main($cust_pkg); @@ -31,8 +31,9 @@ sub do_action {    my $error = $employee_cust_main->credit(      $amount,       \$reasonnum, -    'addlinfo' => -      'for customer #'. $cust_main->display_custnum. ': '.$cust_main->name, +    'eventnum' => $cust_event->eventnum, +    'addlinfo' => 'for customer #'. $cust_main->display_custnum. +                               ': '.$cust_main->name,    );    die "Error crediting customer ". $employee_cust_main->custnum.        " for employee commission: $error" diff --git a/FS/FS/part_event/Action/pkg_referral_credit.pm b/FS/FS/part_event/Action/pkg_referral_credit.pm index da872e7ff..e7c92d650 100644 --- a/FS/FS/part_event/Action/pkg_referral_credit.pm +++ b/FS/FS/part_event/Action/pkg_referral_credit.pm @@ -23,7 +23,7 @@ sub option_fields {  }  sub do_action { -  my( $self, $cust_pkg ) = @_; +  my( $self, $cust_pkg, $cust_event ) = @_;    my $cust_main = $self->cust_main($cust_pkg); @@ -43,8 +43,9 @@ sub do_action {    my $error = $referring_cust_main->credit(      $amount,       \$reasonnum, -    'addlinfo' => -      'for customer #'. $cust_main->display_custnum. ': '.$cust_main->name, +    'eventnum' => $cust_event->eventnum, +    'addlinfo' => 'for customer #'. $cust_main->display_custnum. +                               ': '.$cust_main->name,    );    die "Error crediting customer ". $cust_main->referral_custnum.        " for referral: $error" | 
