Provided by: libhtml-formhandler-perl_0.40068-1_all bug

NAME

       HTML::FormHandler::TraitFor::I18N - localization

VERSION

       version 0.40068

       language_handle, _build_language_handle

       Holds a Locale::Maketext (or other duck_type class with a 'maketext' method) language handle. The
       language handle is used to localize the error messages in the field's 'add_error' method. It's also used
       in various places in rendering to localize labels and button values, etc.

       The builder for this attribute gets the Locale::Maketext language handle from the environment variable
       $ENV{LANGUAGE_HANDLE}:

           $ENV{LANGUAGE_HANDLE} = 'en_en';

       ...or creates a default language handler using HTML::FormHandler::I18N.  (Note that earlier versions
       required an actual object reference in ENV, which is a bad practice and no longer supported.)  You can
       pass in an existing Locale::MakeText subclass instance or create one in a builder.

       In a form class:

           sub _build_language_handle { MyApp::I18N::abc_de->new }

       Passed into new or process:

           my $lh = MyApp::I18N::abc_de->new;
           my $form = MyApp::Form->new( language_handle => $lh );

       If you do not set the language_handle, then Locale::Maketext and/or I18N::LangTags may guess, with
       unexpected results.

       You can use non-Locale::Maketext language handles, such as Data::Localize.  There's an example of
       building a Data::Localize language handle in t/xt/locale_data_localize.t in the distribution.

       If you don't want a particular error message to go through localization, you can use 'push_errors' and
       'push_form_errors' instead of 'add_error' and 'add_form_errors'.

       Example of getting the language handle from the Catalyst context (where the Catalyst context is passed in
       with 'ctx'):

           has '+language_handle' => ( builder => 'get_language_handle_from_ctx' );
           sub get_language_handle_from_ctx {
               my $self = shift;
               return MyApp::I18N->get_handle(
                   @{ $self->ctx->languages } );
           }

AUTHOR

       FormHandler Contributors - see HTML::FormHandler

COPYRIGHT AND LICENSE

       This software is copyright (c) 2017 by Gerda Shank.

       This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5
       programming language system itself.