projects
/
freeside.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
::1 becomes 127.0.0.1 in IP checks
[freeside.git]
/
FS
/
FS
/
part_pkg
/
flat_comission_cust.pm
diff --git
a/FS/FS/part_pkg/flat_comission_cust.pm
b/FS/FS/part_pkg/flat_comission_cust.pm
index
4abe66a
..
e2034cd
100644
(file)
--- a/
FS/FS/part_pkg/flat_comission_cust.pm
+++ b/
FS/FS/part_pkg/flat_comission_cust.pm
@@
-9,6
+9,7
@@
use FS::part_pkg::flat;
%info = (
'name' => 'Flat rate with recurring commission per active customer',
%info = (
'name' => 'Flat rate with recurring commission per active customer',
+ 'shortname' => 'Commission per active customer',
'fields' => {
'setup_fee' => { 'name' => 'Setup fee for this package',
'default' => 0,
'fields' => {
'setup_fee' => { 'name' => 'Setup fee for this package',
'default' => 0,
@@
-26,8
+27,15
@@
use FS::part_pkg::flat;
'comission_depth' => { 'name' => 'Number of layers',
'default' => 1,
},
'comission_depth' => { 'name' => 'Number of layers',
'default' => 1,
},
+ 'reason_type' => { 'name' => 'Reason type for commission credits',
+ 'type' => 'select_table',
+ 'select_table' => 'reason_type',
+ 'select_hash' => { 'class' => 'R' },
+ 'select_key' => 'typenum',
+ 'select_label' => 'type',
+ },
},
},
- 'fieldorder' => [ 'setup_fee', 'recur_fee', 'unused_credit', 'comission_depth', 'comission_amount' ],
+ 'fieldorder' => [ 'setup_fee', 'recur_fee', 'unused_credit', 'comission_depth', 'comission_amount'
, 'reason_type'
],
#'setup' => 'what.setup_fee.value',
#'recur' => '\'my $error = $cust_pkg->cust_main->credit( \' + what.comission_amount.value + \' * scalar($cust_pkg->cust_main->referral_cust_main_ncancelled(\' + what.comission_depth.value+ \')), "commission" ); die $error if $error; \' + what.recur_fee.value + \';\'',
'weight' => '60',
#'setup' => 'what.setup_fee.value',
#'recur' => '\'my $error = $cust_pkg->cust_main->credit( \' + what.comission_amount.value + \' * scalar($cust_pkg->cust_main->referral_cust_main_ncancelled(\' + what.comission_depth.value+ \')), "commission" ); die $error if $error; \' + what.recur_fee.value + \';\'',
'weight' => '60',
@@
-45,7
+53,9
@@
sub calc_recur {
if ( $amount && $num_active ) {
my $error =
if ( $amount && $num_active ) {
my $error =
- $cust_pkg->cust_main->credit( $amount*$num_active, "commission" );
+ $cust_pkg->cust_main->credit( $amount*$num_active, "commission",
+ 'reason_type'=>$self->option('reason_type'),
+ );
die $error if $error;
}
die $error if $error;
}