1 <& elements/process.html,
3 'viewall_dir' => 'browse',
5 'noerror_callback' => $process_sales_pkg_class,
10 unless $FS::CurrentUser::CurrentUser->access_right('Edit sales people');
12 #false laziness w/process/agent.cgi
13 my $process_sales_pkg_class = sub {
14 my( $cgi, $sales ) = @_;
16 #surprising amount of false laziness w/ edit/agent.cgi
17 my @pkg_class = qsearch('pkg_class', { 'disabled'=>'' });
18 foreach my $pkg_class ( '', @pkg_class ) {
19 my %sales_pkg_class = ( 'salesnum' => $sales->salesnum,
20 'classnum' => $pkg_class ? $pkg_class->classnum : ''
23 qsearchs( 'sales_pkg_class', \%sales_pkg_class )
24 || new FS::sales_pkg_class \%sales_pkg_class;
26 my $param = 'classnum'. $sales_pkg_class{classnum};
28 $sales_pkg_class->commission_percent( $cgi->param($param) );
29 $sales_pkg_class->commission_duration( $cgi->param($param.'_duration') );
31 my $method = $sales_pkg_class->salespkgclassnum ? 'replace' : 'insert';
33 my $error = $sales_pkg_class->$method;
34 die $error if $error; #XXX push this down into sales.pm w/better/transactional error handling