', $thead;
Enter the quantity of each service this package includes.
END
}
my @fixups = ();
my $count = 0;
my $columns = 3;
my @part_svc = qsearch( 'part_svc', { 'disabled' => '' } );
foreach my $part_svc ( @part_svc ) {
my $svcpart = $part_svc->svcpart;
my $pkg_svc = qsearchs( 'pkg_svc', {
'pkgpart' => $cgi->param('clone') || $part_pkg->pkgpart,
'svcpart' => $svcpart,
} ) || new FS::pkg_svc ( {
'pkgpart' => $cgi->param('clone') || $part_pkg->pkgpart,
'svcpart' => $svcpart,
'quantity' => 0,
});
#? #next unless $pkg_svc;
push @fixups, "pkg_svc$svcpart";
unless ( defined ($cgi->param('clone')) && $cgi->param('clone') ) {
print ' | '; # if $count == 0 ;
print qq!quantity || 0,
qq!"> | !, $part_svc->getfield('svc'), " |
";
# print "$thead" if ++$count == int(scalar(@part_svc) / 2);
$count+=1;
foreach ( 1 .. $columns-1 ) {
print " | $thead"
if $count == int( $_ * scalar(@part_svc) / $columns );
}
} else {
print qq!quantity || 0, qq!">\n!;
}
}
unless ( $cgi->param('clone') ) {
print " | ";
#print "";
}
# prolly should be in database
use Tie::IxHash;
tie my %plans, 'Tie::IxHash',
'flat' => {
'name' => 'Flat rate',
'fields' => {
'setup_fee' => { 'name' => 'Setup fee for this package',
'default' => 0,
},
'recur_fee' => { 'name' => 'Recurring fee for this package',
'default' => 0,
},
},
'fieldorder' => [ 'setup_fee', 'recur_fee' ],
'setup' => 'what.setup_fee.value',
'recur' => 'what.recur_fee.value',
},
'flat_comission' => {
'name' => 'Flat rate with recurring referral comission as credit',
'fields' => {
'setup_fee' => { 'name' => 'Setup fee for this package',
'default' => 0,
},
'recur_fee' => { 'name' => 'Recurring fee for this package',
'default' => 0,
},
'comission_amount' => { 'name' => 'Comission amount',
'default' => 0,
},
'comission_depth' => { 'name' => 'Number of layers',
'default' => 1,
},
},
'fieldorder' => [ 'setup_fee', 'recur_fee', 'comission_depth', 'comission_amount' ],
'setup' => 'what.setup_fee.value',
'recur' => '\'my $error = $cust_pkg->cust_main->credit( \' + what.comission_amount.value + \' * scalar($cust_pkg->cust_main->referral_cust_pkg(\' + what.comission_depth.value+ \')), "commission" ); die $error if $error; \' + what.recur_fee.value + \';\'',
},
'sesmon_hour' => {
'name' => 'Base charge plus charge per-hour from the session monitor',
'fields' => {
'setup_fee' => { 'name' => 'Setup fee for this package',
'default' => 0,
},
'recur_flat' => { 'name' => 'Base monthly charge for this package',
'default' => 0,
},
'recur_included_hours' => { 'name' => 'Hours included',
'default' => 0,
},
'recur_hourly_charge' => { 'name' => 'Additional charge per hour',
'default' => 0,
},
},
'fieldorder' => [ 'setup_fee', 'recur_flat', 'recur_included_hours', 'recur_hourly_charge' ],
'setup' => 'what.setup_fee.value',
'recur' => '\'my $hours = $cust_pkg->seconds_since($cust_bkg->bill || 0) / 3600 - \' + what.recur_included_hours.value + \'; $hours = 0 if $hours < 0; \' + what.recur_flat.value + \' + \' + what.recur_hourly_charge.value + \' * $hours;\'',
},
'sesmon_minute' => {
'name' => 'Base charge plus charge per-minute from the session monitor',
'fields' => {
'setup_fee' => { 'name' => 'Setup fee for this package',
'default' => 0,
},
'recur_flat' => { 'name' => 'Base monthly charge for this package',
'default' => 0,
},
'recur_included_min' => { 'name' => 'Minutes included',
'default' => 0,
},
'recur_minly_charge' => { 'name' => 'Additional charge per minute',
'default' => 0,
},
},
'fieldorder' => [ 'setup_fee', 'recur_flat', 'recur_included_min', 'recur_minly_charge' ],
'setup' => 'what.setup_fee.value',
'recur' => '\'my $min = $cust_pkg->seconds_since($cust_bkg->bill || 0) / 60 - \' + what.recur_included_min.value + \'; $min = 0 if $min < 0; \' + what.recur_flat.value + \' + \' + what.recur_minly_charge.value + \' * $min;\'',
},
;
%>
Price plan