Main Koha release repository
https://koha-community.org
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
186 lines
4.3 KiB
186 lines
4.3 KiB
package Koha::Template::Plugin::I18N;
|
|
|
|
# Copyright BibLibre 2015
|
|
#
|
|
# This file is part of Koha.
|
|
#
|
|
# Koha is free software; you can redistribute it and/or modify it
|
|
# under the terms of the GNU General Public License as published by
|
|
# the Free Software Foundation; either version 3 of the License, or
|
|
# (at your option) any later version.
|
|
#
|
|
# Koha 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 Koha; if not, see <http://www.gnu.org/licenses>.
|
|
|
|
use Modern::Perl;
|
|
|
|
use base qw( Template::Plugin );
|
|
|
|
use C4::Context;
|
|
use Koha::I18N;
|
|
|
|
=head1 NAME
|
|
|
|
Koha::Template::Plugin::I18N - Translate strings in templates
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
[% PROCESS 'i18n.inc' %]
|
|
|
|
. . .
|
|
|
|
[% I18N.t("Hello!") %]
|
|
[% I18N.tx("Hello {name}", { name = name }) %]
|
|
[% I18N.tn("Hello friend", "Hello friends", count) %]
|
|
[% I18N.tnx("Hello my {count} friend", "Hello my {count} friends", count, { count = count }) %]
|
|
[% I18N.tp('verb', 'Item') # to order %]
|
|
[% I18N.tnp('bibliographic material', "item", "items", count) %]
|
|
[% I18N.tnpx('bibliographic material', "{count} item", "{count} items", count, { count = count }) %]
|
|
|
|
Do not use this plugin directly. Add the following directive
|
|
|
|
[% PROCESS 'i18n.inc' %]
|
|
|
|
and use the macros defined.
|
|
|
|
See: https://wiki.koha-community.org/wiki/Internationalization,_plural_forms,_context,_and_more_(RFC)
|
|
for further context.
|
|
|
|
=head1 METHODS
|
|
|
|
=head2 t
|
|
|
|
[% I18N.t("hello") %]
|
|
|
|
Translate - The simplest type of translatable string where
|
|
there are no variables and not pluralisations to consider.
|
|
|
|
=cut
|
|
|
|
sub t {
|
|
my ($self, $msgid) = @_;
|
|
return __($msgid);
|
|
}
|
|
|
|
=head2 tx
|
|
|
|
[% I18N.tx("hello {name}", { name = name }) %]
|
|
|
|
Translate with variable - A translatable string that
|
|
includes a variable
|
|
|
|
=cut
|
|
|
|
sub tx {
|
|
my ($self, $msgid, $vars) = @_;
|
|
return __x($msgid, %$vars);
|
|
}
|
|
|
|
=head2 tn
|
|
|
|
[% I18N.tn("item", "items", count) %]
|
|
|
|
Translate with plural - A translatable string that needs
|
|
singular and plural forms
|
|
|
|
=cut
|
|
|
|
sub tn {
|
|
my ($self, $msgid, $msgid_plural, $count) = @_;
|
|
return __n($msgid, $msgid_plural, $count);
|
|
}
|
|
|
|
=head2 tnx
|
|
|
|
[% I18N.tnx("{count} item", "{count} items", count, { count = count }) %]
|
|
|
|
Translate with plural and variable - A translatable string
|
|
that needs singular and plural forms and includes a variable
|
|
|
|
=cut
|
|
|
|
sub tnx {
|
|
my ($self, $msgid, $msgid_plural, $count, $vars) = @_;
|
|
return __nx($msgid, $msgid_plural, $count, %$vars);
|
|
}
|
|
|
|
=head2 txn
|
|
|
|
Alias of tnx
|
|
|
|
=cut
|
|
|
|
sub txn {
|
|
my ($self, $msgid, $msgid_plural, $count, $vars) = @_;
|
|
return __xn($msgid, $msgid_plural, $count, %$vars);
|
|
}
|
|
|
|
=head2 tp
|
|
|
|
[% I18N.tp("context", "hello") %]
|
|
|
|
Translate with context - A translatable string where a
|
|
context hint would be helpful to translators.
|
|
|
|
An example would be where in english a single word may be
|
|
be used as both a verb and a noun. You may want to add a
|
|
note to distinguish this particular use case so translators
|
|
can understand the context correctly.
|
|
|
|
=cut
|
|
|
|
sub tp {
|
|
my ($self, $msgctxt, $msgid) = @_;
|
|
return __p($msgctxt, $msgid);
|
|
}
|
|
|
|
=head2 tpx
|
|
|
|
[% I18N.tpx("context", "hello {name}", { name = name }) %]
|
|
|
|
Translate with context and variable - A translatable string
|
|
that needs both a contextual hint and includes a variable.
|
|
|
|
=cut
|
|
|
|
sub tpx {
|
|
my ($self, $msgctxt, $msgid, $vars) = @_;
|
|
return __px($msgctxt, $msgid, %$vars);
|
|
}
|
|
|
|
=head2 tnp
|
|
|
|
[% I18N.tnp("context", "item", "items", count) %]
|
|
|
|
Translate with context and plural - A translatable string
|
|
that needs both a contextual hints and singular and plural
|
|
forms.
|
|
|
|
=cut
|
|
|
|
sub tnp {
|
|
my ($self, $msgctxt, $msgid, $msgid_plural, $count) = @_;
|
|
return __np($msgctxt, $msgid, $msgid_plural, $count);
|
|
}
|
|
|
|
=head2 tnpx
|
|
|
|
[% I18N.tnpx("context", "{count} item", "{count} items", count, { count = count }) %]
|
|
|
|
Translate with context, plural and variables - A translatable
|
|
string that needs contextual hints, singular and plural forms
|
|
and also includes variables.
|
|
|
|
=cut
|
|
|
|
sub tnpx {
|
|
my ($self, $msgctxt, $msgid, $msgid_plural, $count, $vars) = @_;
|
|
return __npx($msgctxt, $msgid, $msgid_plural, $count, %$vars);
|
|
}
|
|
|
|
1;
|
|
|