diff options
| author | ivan <ivan> | 2010-08-06 00:45:30 +0000 | 
|---|---|---|
| committer | ivan <ivan> | 2010-08-06 00:45:30 +0000 | 
| commit | 821f08c9d3cbfb67a54a9f2e667d71787bb22a74 (patch) | |
| tree | 8d41c2d9c82442d232818372695c2ff4d16f9c30 /httemplate/edit/process | |
| parent | 082913e7598de8f3ccc832ba5e876bd21517ef16 (diff) | |
communigate account rules: vacation & redirect all, RT#7514
Diffstat (limited to 'httemplate/edit/process')
| -rw-r--r-- | httemplate/edit/process/cgp_rule-redirect_all.html | 24 | ||||
| -rw-r--r-- | httemplate/edit/process/cgp_rule-simplified.html | 53 | ||||
| -rw-r--r-- | httemplate/edit/process/cgp_rule-vacation.html | 29 | 
3 files changed, 106 insertions, 0 deletions
| diff --git a/httemplate/edit/process/cgp_rule-redirect_all.html b/httemplate/edit/process/cgp_rule-redirect_all.html new file mode 100644 index 000000000..162d857c2 --- /dev/null +++ b/httemplate/edit/process/cgp_rule-redirect_all.html @@ -0,0 +1,24 @@ +<% include('cgp_rule-simplified.html', +             'name'       => '#Redirect', +             'priority'   => 1, +             'redirect'   => 'cgp_rule-redirect_all.html', +             'conditions' => [ +               ( $cgi->param('RedirHuman') +                 ? { conditionname => 'Human Generated', } +                 : () +               ), +             ], +             'actions'    => [ +               { action => ( $cgi->param('KeepToAndCc') +                               ? 'Mirror To' +                               : 'Redirect To' +                           ), +                 params => scalar($cgi->param('RedirectText')), +               }, +               ( $cgi->param('RedirKeep') +                 ? () +                 : ( { 'action' => 'Discard' } ) +               ), +             ], +          ) +%> diff --git a/httemplate/edit/process/cgp_rule-simplified.html b/httemplate/edit/process/cgp_rule-simplified.html new file mode 100644 index 000000000..60769d4e6 --- /dev/null +++ b/httemplate/edit/process/cgp_rule-simplified.html @@ -0,0 +1,53 @@ +% if ( $error ) { #redirect back to edit... +%   $cgi->param('error', $error); +<% $cgi->redirect(popurl(3).'edit/'.$opt{'redirect'}.'?'. $cgi->query_string) %> +% } else { #success XXX better msg talking about vacation vs. redirect all +  <% include('/elements/header-popup.html', 'Rule updated') %> +  <SCRIPT TYPE="text/javascript"> +    window.top.location.reload(); +  </SCRIPT> + +  </BODY> +  </HTML> +% } +<%init> + +my %opt = @_; + +my %hash = ( +  'svcnum' => scalar($cgi->param('svcnum')), +  'name'   => $opt{'name'}, +); + +my $cgp_rule = qsearchs('cgp_rule', \%hash); + +my $error = ''; +if ( $cgp_rule ) { #updating +  $error = $cgp_rule->delete; +} + +$cgp_rule = new FS::cgp_rule { %hash, 'priority' => $opt{'priority'} }; +$error ||= $cgp_rule->insert; + +foreach my $condition ( @{ $opt{'conditions'} } ) { +  my $cgp_rule_condition = new FS::cgp_rule_condition { +    %$condition, +    'rulenum' => $cgp_rule->rulenum, +  }; +  $error ||= $cgp_rule_condition->insert; +} + +foreach my $action ( @{ $opt{'actions'} } ) { +  my $cgp_rule_action = new FS::cgp_rule_action { +    %$action, +    'rulenum' => $cgp_rule->rulenum, +  }; +  $error ||= $cgp_rule_action->insert; +} + +unless ( $error ) { +  my $export_error = $cgp_rule->svc_export; +  die $export_error if $export_error; #error handling sucks wrt this... shouldn't happen though +} + +</%init> diff --git a/httemplate/edit/process/cgp_rule-vacation.html b/httemplate/edit/process/cgp_rule-vacation.html new file mode 100644 index 000000000..f10d72b73 --- /dev/null +++ b/httemplate/edit/process/cgp_rule-vacation.html @@ -0,0 +1,29 @@ +<% include('cgp_rule-simplified.html', +             'name'       => '#Vacation', +             'priority'   => 2, +             'redirect'   => 'cgp_rule-vacation.html', +             'conditions' => [ +               { conditionname => 'Human Generated', }, +               { conditionname => 'From', +                 op            => 'not in', +                 params        => '#RepliedAddresses', +               }, +               ( $cgi->param('VacationTill') +                   ? ( { conditionname => 'Current Date', +                         op            => 'less than', #is less? +                         params        => scalar($cgi->param('VacationTill')), +                       } +                     ) +                   : () +               ), +             ], +             'actions'    => [ +               { action => 'Reply with', +                 params => scalar($cgi->param('VacationText')), +               }, +               { action => "Remember 'From' in", +                 params => 'RepliedAddresses', +               }, +             ], +          ) +%> | 
