X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Fshare%2Fhtml%2FElements%2FEditCustomFieldSelect;h=b343d8266a16d01b8b23683f2a92bc8738dcca10;hb=0ea23112cfa0d82738b0f08d60d90579721b7524;hp=bf2a8289dd229c6ed55e89a70b761fcb340301f7;hpb=fc6209f398899f0211cfcedeb81a3cd65e04a941;p=freeside.git diff --git a/rt/share/html/Elements/EditCustomFieldSelect b/rt/share/html/Elements/EditCustomFieldSelect index bf2a8289d..b343d8266 100644 --- a/rt/share/html/Elements/EditCustomFieldSelect +++ b/rt/share/html/Elements/EditCustomFieldSelect @@ -2,7 +2,7 @@ %# %# COPYRIGHT: %# -%# This software is Copyright (c) 1996-2011 Best Practical Solutions, LLC +%# This software is Copyright (c) 1996-2014 Best Practical Solutions, LLC %# <sales@bestpractical.com> %# %# (Except where explicitly superseded by other copyright notices) @@ -55,7 +55,7 @@ % if (!$HideCategory and @category and not $CustomField->BasedOnObj->id) { <script type="text/javascript" src="<%RT->Config->Get('WebPath')%>/NoAuth/js/cascaded.js"></script> %# XXX - Hide this select from w3m? - <select onchange="filter_cascade('<% $id %>-Values', this.value)" name="<% $id %>-Category" class="CF-<%$CustomField->id%>-Edit"> + <select onchange="filter_cascade(<% "$id-Values" |n,j%>, this.value)" name="<% $id %>-Category" class="CF-<%$CustomField->id%>-Edit"> <option value=""<% !$selected && qq[ selected="selected"] |n %>><&|/l&>-</&></option> % foreach my $cat (@category) { % my ($depth, $name) = @$cat; @@ -65,24 +65,64 @@ % } elsif ($CustomField->BasedOnObj->id) { <script type="text/javascript" src="<%RT->Config->Get('WebPath')%>/NoAuth/js/cascaded.js"></script> <script type="text/javascript"><!-- -doOnLoad( function () { - var basedon = document.getElementById('<% $NamePrefix . $CustomField->BasedOnObj->id %>-Values'); - if (basedon != null) { - var oldchange = basedon.onchange; - basedon.onchange = function () { +jQuery( function () { + var basedon = jQuery('[name^=<% $NamePrefix . $CustomField->BasedOnObj->id %>-Value][type!=hidden]:input:not(.hidden)'); + basedon.each( function() { + var oldchange = jQuery(this).onchange; + jQuery(this).change( function () { + var vals; + if ( jQuery(this).is('select') ) { + vals = basedon.first().val(); + } + else { + vals = []; + jQuery(basedon).each( function() { + if ( jQuery(this).is(':checked') ) { + vals.push(jQuery(this).val()); + } + }); + } filter_cascade( - '<% $id %>-Values', - basedon.value, + <% "$id-Values" |n,j%>, + vals, 1 ); if (oldchange != null) oldchange(); - }; - basedon.onchange(); + }); + }); + + if ( basedon.is('select') ) { + basedon.change(); + } + else { + basedon.first().change(); } }); --></script> % } + +% if ( $RenderType eq 'List' ) { +<fieldset class="cfedit"> +<div data-name="<%$id%>-Values" id="<%$id%>-Values"> +% if ( $checktype eq 'radio' ) { + <div class="none"> + <input class="none" type="<% $checktype %>" name="<% $name %>" id="<% $name %>-none" value="" <% keys %default ? '' : ' checked="checked"' |n%> /> + <label for="<% $name %>-none"><&|/l&>(no value)</&></label><br /> + </div> +% } +% my $CFVs = $CustomField->Values; +% while ( my $value = $CFVs->Next ) { +% my $content = $value->Name; +% my $labelid = "$name-". $value->id; +<div data-name="<% $value->Category || '' %>"> + <input type="<% $checktype %>" name="<% $name %>" id="<% $labelid %>" value="<% $content %>" <% $default{ lc $content }? ' checked="checked"' : '' |n%> /> + <label for="<% $labelid %>"><% $content %></label><br /> +</div> +% } +</div> +</fieldset> +% } else { % if (@category) { %# this hidden select is to supply a full list of values, %# see filter_cascade() in js/cascaded.js @@ -93,22 +133,47 @@ doOnLoad( function () { % } <select name="<%$id%>-Values" id="<%$id%>-Values" class="CF-<%$CustomField->id%>-Edit" -% if ( $Rows && ( $Multiple || !@category ) ) { +% if ( $Rows && ( $Multiple || !@category || $RenderType eq 'Select box') ) { size="<% $Rows %>" % } <% $Multiple && qq[multiple="multiple"] |n %> > <option value=""<% !$selected && qq[ selected="selected"] |n %>><&|/l&>(no value)</&></option> % $m->out($out); </select> +% } +<%init> +# Handle render types +$RenderType ||= $CustomField->RenderType; +if ( $RenderType eq 'Dropdown' ) { + # Turn it into a dropdown + $Rows = 0; +} + +# The following is for rendering checkboxes / radio buttons only +my ($checktype, $name); +if ( $MaxValues == 1 ) { + ($checktype, $name) = ('radio', $NamePrefix . $CustomField->Id . '-Value'); +} else { + ($checktype, $name) = ('checkbox', $NamePrefix . $CustomField->Id . '-Values'); +} + +@Default = grep defined && length, @Default; +if ( !@Default && $Values ) { + @Default = map $_->Content, @{ $Values->ItemsArrayRef }; +} +my %default = map {lc $_ => 1} @Default; +</%init> <%ARGS> $Object => undef $CustomField => undef $NamePrefix => undef -$Default => undef +@Default => () $Values => undef $Multiple => 0 $Rows => undef $HideCategory => 0 +$RenderType => undef +$MaxValues => 1 </%ARGS> <%METHOD options>