summaryrefslogtreecommitdiff
path: root/httemplate/edit/process
diff options
context:
space:
mode:
authorIvan Kohler <ivan@freeside.biz>2014-04-05 12:46:30 -0700
committerIvan Kohler <ivan@freeside.biz>2014-04-05 12:46:30 -0700
commit26010ef38cea8b15bc01ede43817ec7e22efbf47 (patch)
treec821d31e2aa3cfb63a623752a02ee601f7738e8d /httemplate/edit/process
parentb04dfa7c78a316b6b00afa17903424d71ba18cc4 (diff)
installers, RT#16584
Diffstat (limited to 'httemplate/edit/process')
-rw-r--r--httemplate/edit/process/access_user.html34
1 files changed, 34 insertions, 0 deletions
diff --git a/httemplate/edit/process/access_user.html b/httemplate/edit/process/access_user.html
index 8e7e70a06..3a5d95198 100644
--- a/httemplate/edit/process/access_user.html
+++ b/httemplate/edit/process/access_user.html
@@ -11,6 +11,7 @@
'target_table' => 'access_group',
},
'precheck_callback'=> \&precheck_callback,
+ 'noerror_callback' => \&noerror_callback,
)
%>
% }
@@ -33,4 +34,37 @@ sub precheck_callback {
}
return '';
}
+
+sub noerror_callback {
+ my( $cgi, $access_user ) = @_;
+
+ #handle installer checkbox
+ my @sched_item = $access_user->sched_item;
+ my $sched_item = $sched_item[0];
+ if ( $cgi->param('sched_item_enabled') ) {
+
+ if ( ! $sched_item ) {
+ my $sched_item = new FS::sched_item {
+ 'usernum' => $access_user->usernum,
+ };
+ my $error = $sched_item->insert;
+ die $error if $error; #wtf? shouldn't happen
+ } elsif ( $sched_item->disabled ) {
+ $sched_item->disabled('');
+ my $error = $sched_item->replace;
+ die $error if $error; #wtf? shouldn't happen
+ }
+
+ } elsif ( ! $cgi->param('sched_item_enabled')
+ && $sched_item
+ && ! $sched_item->disabled
+ )
+ {
+ $sched_item->disabled('Y');
+ my $error = $sched_item->replace;
+ die $error if $error; #wtf? shouldn't happen
+ }
+
+}
+
</%init>