NAME
    Amon2::Plugin::L10N - L10N support for Amon2

DESCRIPTION
    Amon2::Plugin::L10N is L10N support plugin for Amon2.

Implementation L10N for your App
  in YourProj.pm
      __PACKAGE__->load_plugins('L10N' => {
          default_lang => 'en',                                  # default is en
          accept_langs => [qw/ en ja zh-tw zh-cn fr /],          # default is ['en']
          po_dir       => 'po',                                  # default is po
      });

  in your YourProj::Web::ViewFunction
      use Text::Xslate ();
      sub l {
          my $string = shift;
          my @args = map { Text::Xslate::html_escape($_) } @_; # escape arguments
          Text::Xslate::mark_raw( YourProj->context->loc($string, @args) );
      }

  in your tmpl/foo.tt
      [% l('Hello! %1', 'username') %]

  in your some class
      package YourProj::M::Foo;
  
      sub bar {
          YourProj->context->loc('hello! %1', $username);
      }

  hook of before language detection
      __PACKAGE__->load_plugins('L10N' => {
          accept_langs          => [qw/ en ja zh-tw zh-cn fr /],
          before_detection_hook => sub {
              my $c = shift;
              return unless ref($c);
  
              my $accept_re = qr/\A(?:en|ja|zh-tw)\z/;
              my $lang = $c->req->param('lang');
              if ($lang && $lang =~ $accept_re) {
                  $c->session->set( lang => $lang );
                  return $lang;
              } elsif (! defined $lang) {
                  $lang = $c->session->get('lang');
                  if ($lang && $lang =~ $accept_re) {
                      return $lang;
                  }
              }
              $c->session->set( lang => '' );
              return; # through
          },
      });

  hook of after language detection
      __PACKAGE__->load_plugins('L10N' => {
          accept_langs         => [qw/ en ja zh zh-tw zh-cn fr /],
          after_detection_hook => sub {
              my($c, $lang) = shift;
              return 'zh' if $lang =~ /\Azh(?:-.+)\z/;
              return $lang;
          },
      });

  you can customize the po files name
      __PACKAGE__->load_plugins('L10N' => {
          accept_langs         => [qw/ zh-tw zh-cn zh /],
          po_file_langs        => [qw/ zh-tw zh-cn /],    # zh.po is not exists file
          after_detection_hook => sub {
              my($c, $lang) = shift;
              return 'zh-cn' if $lang eq 'zh'; # use zh-cn.po file
              return $lang;
          },
      });

  for your CLI
      __PACKAGE__->load_plugins('L10N' => {
          default_lang          => 'ja',
          accept_langs          => [qw/ en ja /],
          before_detection_hook => sub {
              my $c = shift;
              return unless $NEV{CLI_MODE}; # CLI_MODE is example key
              return 'ja' if $ENV{LANG} =~ /ja/i;
              return 'en' if $ENV{LANG} =~ /en/i;
              return; # use default lang
          },
      });

  you can set Locale::Maketext::Lexicon options
      # in your MyApp.pm
      __PACKAGE__->load_plugins('L10N' => {
          accept_langs   => [qw/ ja /],
          lexicon_options => {
              _auto => 0,
          },
      });

  you can implement L10N class yourself
      package L10N;
      use strict;
      use warnings;
      use parent 'Locale::Maketext';
      use File::Spec;
  
      use Locale::Maketext::Lexicon +{
          'ja'     => [ Gettext => File::Spec->catfile('t', 'po', 'ja.po') ],
          _preload => 1,
          _style   => 'gettext',
          _decode  => 1,
      };
  
      # in your MyApp.pm
      __PACKAGE__->load_plugins('L10N' => {
          accept_langs => [qw/ ja /],
          l10n_class   => 'L10N',
      });

Translation Step
  installing dependent module of amon2-xgettext.pl
      $ cpanm --with-suggests Amon2::Plugin::L10N

    dependnt module list in the cpanfile file.

  write your application
  run amon2-xgettext.pl
      $ cd your_amon2_proj_base_dir
      $ perl amon2-xgettext.pl en ja fr zh-tw

  edit .po files
      $ vim po/ja.po
      $ vim po/zh-tw.po

Add Amon2 Context Method
  $c->l10n_language_detection
    Language that is detected will return.

  $c->loc($message), $c->loc('foo %1 .. %2 ...', @args);
    It will return the text in the appropriate language.

AUTHOR
    Kazuhiro Osawa <yappo {at} shibuya {dot} pl>

COPYRIGHT
    Copyright 2013- Kazuhiro Osawa

LICENSE
    This library is free software; you can redistribute it and/or modify it
    under the same terms as Perl itself.

SEE ALSO
    Amon2, Locale::Maketext::Lexicon, HTTP::AcceptLanguage,
    amon2-xgettext.pl