Commit 426e6c9f by Carsten Brandt

reword/structure of the i18n and formatter guide

parent 6c0dde6f
Data Formatter Data Formatter
============== ==============
For formatting of outputs Yii provides a formatter class to make date more readable for users. For formatting of outputs Yii provides a formatter class to make data more readable for users.
[[yii\i18n\Formatter]] is a helper class that is registered as an [application component](concept-components.md) name `formatter` by default. [[yii\i18n\Formatter]] is a helper class that is registered as an [application component](concept-components.md) named `formatter` by default.
It provides a set of methods for data formatting purpose such as date/time values, numbers and other commonly used formats in a localized way. It provides a set of methods for data formatting purpose such as date/time values, numbers and other commonly used formats in a localized way.
The formatter can be used in two different ways. The formatter can be used in two different ways.
1. Using the formatting methods(all formatter methods prefixed with `as`) directly: 1. Using the formatting methods (all formatter methods prefixed with `as`) directly:
```php ```php
echo Yii::$app->formatter->asDate('2014-01-01', 'long'); // output: January 1, 2014 echo Yii::$app->formatter->asDate('2014-01-01', 'long'); // output: January 1, 2014
...@@ -18,9 +18,9 @@ The formatter can be used in two different ways. ...@@ -18,9 +18,9 @@ The formatter can be used in two different ways.
echo Yii::$app->formatter->asDate(null); // output: (Not set) echo Yii::$app->formatter->asDate(null); // output: (Not set)
``` ```
2. Using the [[yii\i18n\Formatter::format()|format()]] method using the format name. 2. Using the [[yii\i18n\Formatter::format()|format()]] method and the format name.
This method is used by classes like GridView and DetailView where you can specify the data format of a column in the This method is also used by widgets like [[yii\grid\GridView]] and [[yii\widgets\DetailView]] where you can specify
widget config. the data format of a column in the widget configuration.
```php ```php
echo Yii::$app->formatter->format('2014-01-01', 'date'); // output: January 1, 2014 echo Yii::$app->formatter->format('2014-01-01', 'date'); // output: January 1, 2014
...@@ -32,9 +32,9 @@ The formatter can be used in two different ways. ...@@ -32,9 +32,9 @@ The formatter can be used in two different ways.
All output of the formatter is localized when the [PHP intl extension](http://php.net/manual/en/book.intl.php) is installed. All output of the formatter is localized when the [PHP intl extension](http://php.net/manual/en/book.intl.php) is installed.
You can configure the [[yii\i18n\Formatter::locale|locale]] property of the formatter for this. If not configured, the You can configure the [[yii\i18n\Formatter::locale|locale]] property of the formatter for this. If not configured, the
application [[yii\base\Application::language|language]] is used as the locale. See the [Section on internationaization](tutorial-i18n.md) for more details. application [[yii\base\Application::language|language]] is used as the locale. See the [Section on internationaization](tutorial-i18n.md) for more details.
The Formatter will then choose the correct format for dates and number according to the locale including names of month and The Formatter will then choose the correct format for dates and numbers according to the locale including names of month and
week days translated to the current language. Date formats are also affected by the [[yii\i18n\Formatter::timeZone|timeZone]] week days translated to the current language. Date formats are also affected by the [[yii\i18n\Formatter::timeZone|timeZone]]
which will also be taken [[yii\base\Application::timeZone|from the application]] by default. which will also be taken [[yii\base\Application::timeZone|from the application]] if not configured explicitly.
For example the date format call will output different results for different locales: For example the date format call will output different results for different locales:
...@@ -50,16 +50,16 @@ echo Yii::$app->formatter->asDate('2014-01-01'); // output: 1 января 2014 ...@@ -50,16 +50,16 @@ echo Yii::$app->formatter->asDate('2014-01-01'); // output: 1 января 2014
> Note that formatting may differ between different versions of the ICU library compiled with PHP and also based on the fact whether the > Note that formatting may differ between different versions of the ICU library compiled with PHP and also based on the fact whether the
> [PHP intl extension](http://php.net/manual/en/book.intl.php) is installed or not. So to ensure your website works with the same output > [PHP intl extension](http://php.net/manual/en/book.intl.php) is installed or not. So to ensure your website works with the same output
> in all environments it is recommended to install the PHP intl extension in all environments and verify that the version of the ICU library > in all environments it is recommended to install the PHP intl extension in all environments and verify that the version of the ICU library
> is the same. > is the same. See also: [Setting up your PHP environment for internationalization](tutorial-i18n.md#setup-environment).
Configuring the format Configuring the format
---------------------- ----------------------
The default format of the Formatter class can be adjusted using the properties of the formatter class. The default format of the Formatter class can be adjusted using the properties of the formatter class.
You can adjust these values application wide by configuring the `formatter` component in your [application config](concept-configurations.md#application-configurations) You can adjust these values application wide by configuring the `formatter` component in your [application config](concept-configurations.md#application-configurations).
an example configuration is shown in the following. An example configuration is shown in the following.
For more details about certain properties check out the [[yii\i18n\Formatter|API documentation of the Formatter class]]. For more details about the available properties check out the [[yii\i18n\Formatter|API documentation of the Formatter class]].
```php ```php
'components' => [ 'components' => [
...@@ -74,6 +74,8 @@ For more details about certain properties check out the [[yii\i18n\Formatter|API ...@@ -74,6 +74,8 @@ For more details about certain properties check out the [[yii\i18n\Formatter|API
Formatting Dates Formatting Dates
---------------- ----------------
> Note: This section is under development.
TDB TDB
See http://site.icu-project.org/ for the format. See http://site.icu-project.org/ for the format.
...@@ -89,6 +91,8 @@ See http://site.icu-project.org/ for the format. ...@@ -89,6 +91,8 @@ See http://site.icu-project.org/ for the format.
Formatting Numbers Formatting Numbers
------------------ ------------------
> Note: This section is under development.
TDB TDB
See http://site.icu-project.org/ for the format. See http://site.icu-project.org/ for the format.
...@@ -105,6 +109,8 @@ See http://site.icu-project.org/ for the format. ...@@ -105,6 +109,8 @@ See http://site.icu-project.org/ for the format.
Other formatters Other formatters
---------------- ----------------
> Note: This section is under development.
TDB TDB
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment