X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;ds=sidebyside;f=httemplate%2Felements%2Fselect-cgp_rule_condition.html;h=eaf7211fa20df92aa7330d5b844ba30dfc2203dc;hb=fa6176ab2df85c4b66026e9fe2a7242293d20ce5;hp=1ce85bdb63c117edd28da2c00d514d14d7c6ace5;hpb=6874a21f3cb26a167e49cc1324df30119c6ed75d;p=freeside.git diff --git a/httemplate/elements/select-cgp_rule_condition.html b/httemplate/elements/select-cgp_rule_condition.html index 1ce85bdb6..eaf7211fa 100644 --- a/httemplate/elements/select-cgp_rule_condition.html +++ b/httemplate/elements/select-cgp_rule_condition.html @@ -1,26 +1,106 @@ -<% include( 'select.html', - %opt, - 'options' => \@conditions, #reverse order if we ever need to spec - 'labels' => { '' => 'Select Condition' }, - ) -%> -<% include( 'select.html', - 'name' => $opt{'field'}.'_op', - 'id' => ($opt{'field'}||$opt{'id'}).'_op', - 'options' => \@myop, - ) -%> -<% include( 'input-text.html', - 'name' => $opt{'field'}.'_params', - #XXX curr value... anything else? - ) -%> -<%init> +% unless ( $opt{'js_only'} ) { + <% include( 'select.html', + %opt, + 'options' => \@conditions, + 'labels' => { '' => 'Select Condition' }, + 'onchange' => $key.'_changed', + ) + %> + <% include( 'select.html', + 'name' => $opt{'field'}.'_op', + 'id' => $key.'_op', + 'options' => \@op, + #XXX curr op + ) + %> + <% include( 'input-text.html', + 'name' => $opt{'field'}.'_params', + 'id' => $key.'_params', + #XXX curr value... anything else? + ) + %> +% # could add more UI sugar for date/time ranges, string #lists, etc. +% } +% unless ( $opt{'html_only'} || $opt{'js_only'} ) { + +% } +<%once> my @conditions = ( '', + + #generic http://www.communigate.com/CommunigatePro/Rules.html#Conditions + 'Submit Address', + 'Time of Day', + 'Current Date', + 'Current Day', + 'Preference', + 'FreeBusy', + 'Existing Mailbox', + + #email http://www.communigate.com/CommunigatePro/QueueRules.html#Conditions 'From', 'Sender', 'To', @@ -43,21 +123,41 @@ my @conditions = ( 'Each Route' ); -my %bool = ( +my %bool = ( #hide the op and valud dropdowns entirely + '' => 1, #XXX hide _op and _params on "Select Condition" 'Human Generated' => 1, ); -my %number = ( +my %no_in = ( #hide in/not in 'Message Size' => 1, + 'Current Date' => 1, + 'Existing Mailbox' => 1, ); -#XXX curr value -> hidden op / param / param selects depending +my %lt_gt = ( #add less than/greater than + 'Message Size' => 1, + 'Time of Day', => 1, + 'Current Date', => 1, +); -my @op = ( 'is', 'is not', 'in', 'not in' ); -my @op_number = ( 'is', 'is_not', 'less than', 'greater than' ); +my $cond2op = sub { + my $cond = shift; + return () if $bool{$cond}; + my @op = ( 'is', 'is not' ); + push @op, 'less than', 'greater than' if $lt_gt{$cond}; + push @op, 'in', 'not in' unless $no_in{$cond}; + @op; +}; -my @myop = @op; #XXX $number{$curr_value} ? @op_number : @op; -#XXX and a fancy onchange handler... yes. -#XXX (and for total hiding of the %bool one) + +<%init> + +my %opt = @_; + +my $key = $opt{'field'} || $opt{'id'}; + +#XXX curr value -> hidden op / param / param selects depending +#my @op = &$cond2op($curr_value); +my @op = &$cond2op();