%# BEGIN BPS TAGGED BLOCK {{{
%#
%# COPYRIGHT:
%#
%# This software is Copyright (c) 1996-2023 Best Practical Solutions, LLC
%#                                          <sales@bestpractical.com>
%#
%# (Except where explicitly superseded by other copyright notices)
%#
%#
%# LICENSE:
%#
%# This work is made available to you under the terms of Version 2 of
%# the GNU General Public License. A copy of that license should have
%# been provided with this software, but in any event can be snarfed
%# from www.gnu.org.
%#
%# This work is distributed in the hope that it will be useful, but
%# WITHOUT ANY WARRANTY; without even the implied warranty of
%# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
%# General Public License for more details.
%#
%# You should have received a copy of the GNU General Public License
%# along with this program; if not, write to the Free Software
%# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
%# 02110-1301 or visit their web page on the internet at
%# http://www.gnu.org/licenses/old-licenses/gpl-2.0.html.
%#
%#
%# CONTRIBUTION SUBMISSION POLICY:
%#
%# (The following paragraph is not intended to limit the rights granted
%# to you to modify and distribute this software under the terms of
%# the GNU General Public License and is only of importance to you if
%# you choose to contribute your changes and enhancements to the
%# community by submitting them to Best Practical Solutions, LLC.)
%#
%# By intentionally submitting any modifications, corrections or
%# derivatives to this work, or any other work intended for use with
%# Request Tracker, to Best Practical Solutions, LLC, you confirm that
%# you are the copyright holder for those contributions and you grant
%# Best Practical Solutions,  LLC a nonexclusive, worldwide, irrevocable,
%# royalty-free, perpetual, license to use, copy, create derivative
%# works based on those contributions, and sublicense and distribute
%# those contributions and any derivatives thereof.
%#
%# END BPS TAGGED BLOCK }}}
<& /Elements/ListActions, actions => \@results &>


<form method="post" action="CustomField.html">
<input type="hidden" class="hidden" name="CustomField" value="<%$id %>" />
<input type="hidden" class="hidden" name="Queue" value="<%$Queue%>" />

<&| /Elements/LabeledValue, Label => loc("Name") &>
  <input class="form-control" type="text" name="Name" value="<%$CustomFieldObj->Name%>" size="20" />
</&>

<&| /Elements/LabeledValue, Label => loc("Description") &>
  <input class="form-control" type="text" name="Description" value="<%$CustomFieldObj->Description%>" size="80" />
</&>

<&| /Elements/LabeledValue, Label => loc("Type") &>
  <& /Admin/Elements/SelectCustomFieldType, Name => "Type", Default => $CustomFieldObj->Type &>
</&>

<input type="hidden" class="hidden" name="SetEnabled" value="1" />
<div class="custom-control custom-checkbox">
  <input type="checkbox" class="custom-control-input checkbox" id="Enabled" name="Enabled" value="1" <%$EnabledChecked%> />
  <label class="custom-control-label" for="Enabled"><&|/l&>Enabled (Unchecking this box disables this custom field)</&></label>
</div>

<p>
% if ($CustomFieldObj->Id and $CustomFieldObj->Type =~ /Select/) {
<h2><&|/l&>Values</&></h2>
<font size="-1">
  <& /Admin/Elements/EditCustomFieldValues, CustomField => $CustomFieldObj &>
  <& /Admin/Elements/AddCustomFieldValue, CustomField => $CustomFieldObj &>
</font>
% }
<&/Elements/Submit, Label => loc('Create') &>
</form>
<%INIT>

my $CustomFieldObj = RT::CustomField->new($session{'CurrentUser'});
my $EnabledChecked = 'checked="checked"';
my (@results);

if (! $CustomField ) { 
  $title = loc("Create a CustomField");
  $id = 'new';
} else {

    if ($CustomField eq 'new') {
      my ($val, $msg) =  $CustomFieldObj->Create(Queue => $Queue,
                                                 Name => $Name,
                                                 Type => $Type,
                                                 Description => $Description,
                                             );

      # if there is an error, then abort.  But since at this point there's
      # stuff already printed, clear it out.
      # (This only works in conjunction with temporarily turning autoflush
      #  off in the files that use this component.)
      unless ($val) {
          $m->clear_buffer;
          Abort(loc("Could not create CustomField: [_1]", $msg), SuppressHeader => 1);
      }
      push @results, $msg;
      $CustomFieldObj->SetSortOrder($CustomFieldObj->id);
      $title = loc('Created CustomField [_1]', $CustomFieldObj->Name()); 
    } else {
      $CustomFieldObj->Load($CustomField) || Abort(loc('No CustomField'), SuppressHeader => 1);
      $title = loc('Editing CustomField [_1]', $CustomFieldObj->Name()); 

      my @aresults = ProcessCustomFieldUpdates ( 
                        CustomFieldObj => $CustomFieldObj,
                        ARGSRef => \%ARGS );
      push @results, @aresults;
    }


$id = $CustomFieldObj->id;

  #we're asking about enabled on the web page but really care about disabled.
  my $Disabled = ($Enabled ? 0 : 1);

  if  ( ($SetEnabled) and ( $Disabled != $CustomFieldObj->Disabled) ) { 
      my  ($code, $msg) = $CustomFieldObj->SetDisabled($Disabled);
      push @results, loc('Enabled status [_1]', loc_fuzzy($msg));
  }
  
  if ($CustomFieldObj->Disabled()) {
      $EnabledChecked ="";
  }

}


</%INIT>
<%ARGS>
$id => undef
$title => undef
$Queue => undef
$CustomField => undef
$Type => undef
$Description => undef
$Name => undef
$SetEnabled => undef
$Enabled => undef
</%ARGS>
