X-Git-Url: http://git.freeside.biz/gitweb/?a=blobdiff_plain;f=rt%2Fshare%2Fhtml%2FElements%2FEditCustomFieldSelect;h=363477f11cb6621b78cd7176732d4767643f32cc;hb=de9d037528895f7151a9aead6724ce2df95f9586;hp=bf2a8289dd229c6ed55e89a70b761fcb340301f7;hpb=fc6209f398899f0211cfcedeb81a3cd65e04a941;p=freeside.git diff --git a/rt/share/html/Elements/EditCustomFieldSelect b/rt/share/html/Elements/EditCustomFieldSelect index bf2a8289d..363477f11 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-2017 Best Practical Solutions, LLC %# %# %# (Except where explicitly superseded by other copyright notices) @@ -50,12 +50,10 @@ %# (perhaps by tweaking the .display style?) % my $selected = 0; % my @category; -% my $id = $NamePrefix . $CustomField->Id; % my $out = $m->scomp('SELF:options', %ARGS, SelectedRef => \$selected, CategoryRef => \@category); % if (!$HideCategory and @category and not $CustomField->BasedOnObj->id) { - %# XXX - Hide this select from w3m? - % foreach my $cat (@category) { % my ($depth, $name) = @$cat; @@ -63,52 +61,118 @@ % }
% } elsif ($CustomField->BasedOnObj->id) { - + % } + +% if ( $RenderType eq 'List' ) { +
+
+% if ( $checktype eq 'radio' ) { +
+ /> +
+
+% } +% my $CFVs = $CustomField->Values; +% while ( my $value = $CFVs->Next ) { +% my $content = $value->Name; +% my $labelid = "$name-". $value->id; +
+ /> +
+
+% } +
+
+% } else { % if (@category) { %# this hidden select is to supply a full list of values, -%# see filter_cascade() in js/cascaded.js - % $m->out($out); % } +% } +<%init> +# Handle render types +$RenderType ||= $CustomField->RenderType; +if ( $RenderType eq 'Dropdown' ) { + # Turn it into a dropdown + $Rows = 0; +} + +my ($checktype, $name); +if ( $MaxValues == 1 and $RenderType eq 'List' ) { + ($checktype, $name) = ('radio', $Name || $NamePrefix . $CustomField->Id . '-Value'); +} else { + ($checktype, $name) = ('checkbox', $Name || $NamePrefix . $CustomField->Id . '-Values'); +} + +@Default = grep defined && length, @Default; +if ( !@Default && $Values ) { + @Default = map $_->Content, @{ $Values->ItemsArrayRef }; +} +my %default = map {lc $_ => 1} @Default; + <%ARGS> $Object => undef $CustomField => undef $NamePrefix => undef -$Default => undef +$Name => undef +$BasedOnName => undef +@Default => () $Values => undef $Multiple => 0 $Rows => undef $HideCategory => 0 +$RenderType => undef +$MaxValues => 1 <%METHOD options>