1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
|
<?php
/**
* TChoiceFormat, I18N choice format component.
*
* @author Wei Zhuo <weizhuo[at]gmail[dot]com>
* @link http://www.pradosoft.com/
* @copyright Copyright © 2005-2014 PradoSoft
* @license http://www.pradosoft.com/license/
* @package Prado\I18N
*/
namespace Prado\I18N;
/**
* Get the ChoiceFormat class.
*/
use Prado\I18N\core\ChoiceFormat;
use Prado\Prado;
Prado::using('System.I18N.core.ChoiceFormat');
Prado::using('System.I18N.TTranslate');
/**
* TChoiceFormat class.
*
* This component performs message/string choice translation. The translation
* source is set in the TGlobalization module. The following example
* demonstrates a simple 2 choice message translation.
* <code>
* <com:TChoiceFormat Value="1">[1] One Apple. |[2] Two Apples</com:TChoiceFormat>
* </code>
*
* The Choice has <b>Value</b> "1" (one), thus the translated string
* is "One Apple". If the <b>Value</b> is "2", then it will show
* "Two Apples".
*
* The message/string choices are separated by the pipe "|" followed
* by a set notation of the form
* # <tt>[1,2]</tt> -- accepts values between 1 and 2, inclusive.
* # <tt>(1,2)</tt> -- accepts values between 1 and 2, excluding 1 and 2.
* # <tt>{1,2,3,4}</tt> -- only values defined in the set are accepted.
* # <tt>[-Inf,0)</tt> -- accepts value greater or equal to negative infinity
* and strictly less than 0
* Any non-empty combinations of the delimiters of square and round brackets
* are acceptable.
*
* The string choosen for display depends on the <b>Value</b> property.
* The <b>Value</b> is evaluated for each set until the Value is found
* to belong to a particular set.
*
* Properties
* - <b>Value</b>, float,
* <br>Gets or sets the Value that determines which string choice to display.
* Since version 3.1.2 the following set notation is also possible.
*
* # <tt>{n: n % 10 > 1 && n % 10 < 5}</tt> -- matches numbers like 2, 3, 4, 22, 23, 24
*
* Where set is defined by the expression after <tt>n:</tt>. In particular, the expression
* accepts the following mathematical/logical operators to form a set of logical conditions
* on the value given by <tt>n</tt>:
* # <tt><</tt> -- less than.
* # <tt><=</tt> -- less than equals.
* # <tt>></tt> -- greater than.
* # <tt>>=</tt> -- greater than equals.
* # <tt>==</tt> -- of equal value.
* # <tt>%</tt> -- modulo, e.g., 1 % 10 equals 1, 11 % 10 equals 1.
* # <tt>-</tt> -- minus, negative.
* # <tt>+</tt> -- addition.
* # <tt>&</tt> -- conditional AND.
* # <tt>&&</tt> -- condition AND with short circuit.
* # <tt>|</tt> -- conditional OR.
* # <tt>||</tt> -- conditional OR with short circuit.
* # <tt>!</tt> -- negation.
*
* Additional round brackets can also be used to perform grouping.
*
* @author Xiang Wei Zhuo <weizhuo[at]gmail[dot]com>
* @package Prado\I18N
*/
class TChoiceFormat extends TTranslate
{
/**
* @return float the numerical value.
*/
public function getValue()
{
return $this->getViewState('Value','');
}
/**
* Sets the numerical choice value
* @param float the choice value
*/
public function setValue($value)
{
$this->setViewState('Value',$value,'');
}
/**
* Display the choosen translated string.
* Overrides the parent method, also calls parent's renderBody to
* translate.
*/
protected function translateText($text, $subs)
{
$text = parent::translateText($text, $subs);
$choice = new ChoiceFormat();
$value = $this->getValue();
$string = $choice->format($text, $value);
if($string)
return strtr($string, array('{Value}'=> $value));
}
}
|