mirror of
https://github.com/alchemy-fr/Phraseanet.git
synced 2025-10-24 02:13:15 +00:00
Use TranslationServiceProvider, fix use of form_div_layout
This commit is contained in:
@@ -128,11 +128,14 @@ use Silex\Application\UrlGeneratorTrait;
|
|||||||
use Silex\Provider\FormServiceProvider;
|
use Silex\Provider\FormServiceProvider;
|
||||||
use Silex\Provider\MonologServiceProvider;
|
use Silex\Provider\MonologServiceProvider;
|
||||||
use Silex\Provider\SessionServiceProvider;
|
use Silex\Provider\SessionServiceProvider;
|
||||||
|
use Silex\Provider\TranslationServiceProvider;
|
||||||
use Silex\Provider\TwigServiceProvider;
|
use Silex\Provider\TwigServiceProvider;
|
||||||
use Silex\Provider\SwiftmailerServiceProvider;
|
use Silex\Provider\SwiftmailerServiceProvider;
|
||||||
use Silex\Provider\UrlGeneratorServiceProvider;
|
use Silex\Provider\UrlGeneratorServiceProvider;
|
||||||
use Silex\Provider\ValidatorServiceProvider;
|
use Silex\Provider\ValidatorServiceProvider;
|
||||||
use Silex\Provider\ServiceControllerServiceProvider;
|
use Silex\Provider\ServiceControllerServiceProvider;
|
||||||
|
use Symfony\Bridge\Twig\Extension\TranslationExtension;
|
||||||
|
use Symfony\Component\Translation\Loader\MoFileLoader;
|
||||||
use Unoconv\UnoconvServiceProvider;
|
use Unoconv\UnoconvServiceProvider;
|
||||||
use XPDF\PdfToText;
|
use XPDF\PdfToText;
|
||||||
use XPDF\XPDFServiceProvider;
|
use XPDF\XPDFServiceProvider;
|
||||||
@@ -299,8 +302,22 @@ class Application extends SilexApplication
|
|||||||
'twig.options' => [
|
'twig.options' => [
|
||||||
'cache' => $this['root.path'] . '/tmp/cache_twig/',
|
'cache' => $this['root.path'] . '/tmp/cache_twig/',
|
||||||
],
|
],
|
||||||
'twig.form.templates' => ['login/common/form_div_layout.html.twig']
|
|
||||||
]);
|
]);
|
||||||
|
|
||||||
|
$this->register(new TranslationServiceProvider(), [
|
||||||
|
'locale_fallbacks' => ['fr_FR'],
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this['translator'] = $this->share($this->extend('translator', function($translator, $app) {
|
||||||
|
$translator->addLoader('mo', new MoFileLoader());
|
||||||
|
$translator->addResource('mo', __DIR__.'/../../../locale/fr_FR/LC_MESSAGES/phraseanet.mo', 'fr_FR');
|
||||||
|
$translator->addResource('mo', __DIR__.'/../../../locale/en_GB/LC_MESSAGES/phraseanet.mo', 'en_GB');
|
||||||
|
$translator->addResource('mo', __DIR__.'/../../../locale/de_DE/LC_MESSAGES/phraseanet.mo', 'de_DE');
|
||||||
|
$translator->addResource('mo', __DIR__.'/../../../locale/nl_NL/LC_MESSAGES/phraseanet.mo', 'nl_NL');
|
||||||
|
|
||||||
|
return $translator;
|
||||||
|
}));
|
||||||
|
|
||||||
$this->register(new FormServiceProvider());
|
$this->register(new FormServiceProvider());
|
||||||
|
|
||||||
$this->setupTwig();
|
$this->setupTwig();
|
||||||
@@ -575,7 +592,7 @@ class Application extends SilexApplication
|
|||||||
$twig->addExtension(new \Twig_Extension_Escaper());
|
$twig->addExtension(new \Twig_Extension_Escaper());
|
||||||
|
|
||||||
// add filter trans
|
// add filter trans
|
||||||
$twig->addExtension(new \Twig_Extensions_Extension_I18n());
|
$twig->addExtension(new TranslationExtension($app['translator']));
|
||||||
// add filter localizeddate
|
// add filter localizeddate
|
||||||
$twig->addExtension(new \Twig_Extensions_Extension_Intl());
|
$twig->addExtension(new \Twig_Extensions_Extension_Intl());
|
||||||
// add filters truncate, wordwrap, nl2br
|
// add filters truncate, wordwrap, nl2br
|
||||||
|
|||||||
@@ -108,7 +108,6 @@ class PhraseaLocaleSubscriber implements EventSubscriberInterface
|
|||||||
});
|
});
|
||||||
|
|
||||||
$this->locale = $this->app['locale'];
|
$this->locale = $this->app['locale'];
|
||||||
\phrasea::use_i18n($this->locale);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public function addLocaleCookie(FilterResponseEvent $event)
|
public function addLocaleCookie(FilterResponseEvent $event)
|
||||||
|
|||||||
@@ -69,23 +69,6 @@ class phrasea
|
|||||||
return self::$_sbas_params;
|
return self::$_sbas_params;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function use_i18n($locale, $textdomain = 'phraseanet')
|
|
||||||
{
|
|
||||||
$codeset = "UTF-8";
|
|
||||||
|
|
||||||
putenv('LANG=' . $locale . '.' . $codeset);
|
|
||||||
putenv('LANGUAGE=' . $locale . '.' . $codeset);
|
|
||||||
bind_textdomain_codeset($textdomain, 'UTF-8');
|
|
||||||
|
|
||||||
bindtextdomain($textdomain, __DIR__ . '/../../locale/');
|
|
||||||
setlocale(LC_ALL
|
|
||||||
, $locale . '.UTF-8'
|
|
||||||
, $locale . '.UTF8'
|
|
||||||
, $locale . '.utf-8'
|
|
||||||
, $locale . '.utf8');
|
|
||||||
textdomain($textdomain);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static function modulesName($array_modules)
|
public static function modulesName($array_modules)
|
||||||
{
|
{
|
||||||
$array = [];
|
$array = [];
|
||||||
|
|||||||
@@ -1,3 +1,5 @@
|
|||||||
|
{% form_theme form 'web/login/common/fields.html.twig' %}
|
||||||
|
|
||||||
{% set jquery_theme = 'dark-hive' %}
|
{% set jquery_theme = 'dark-hive' %}
|
||||||
{% set module = '' %}
|
{% set module = '' %}
|
||||||
|
|
||||||
|
|||||||
@@ -1,334 +0,0 @@
|
|||||||
{# Widgets #}
|
|
||||||
|
|
||||||
{% block form_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if compound %}
|
|
||||||
{{ block('form_widget_compound') }}
|
|
||||||
{% else %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% endif %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_widget %}
|
|
||||||
|
|
||||||
{% block form_widget_simple %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% set type = type|default('text') %}
|
|
||||||
<input type="{{ type }}" {{ block('widget_attributes') }} {% if value is not empty %}value="{{ value }}" {% endif %}/>
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_widget_simple %}
|
|
||||||
|
|
||||||
{% block form_widget_compound %}
|
|
||||||
{% spaceless %}
|
|
||||||
<div {{ block('widget_container_attributes') }}>
|
|
||||||
{% if form.parent is empty %}
|
|
||||||
{{ form_errors(form) }}
|
|
||||||
{% endif %}
|
|
||||||
{{ block('form_rows') }}
|
|
||||||
{{ form_rest(form) }}
|
|
||||||
</div>
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_widget_compound %}
|
|
||||||
|
|
||||||
{% block collection_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if prototype is defined %}
|
|
||||||
{% set attr = attr|merge({'data-prototype': form_row(prototype) }) %}
|
|
||||||
{% endif %}
|
|
||||||
{{ block('form_widget') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock collection_widget %}
|
|
||||||
|
|
||||||
{% block textarea_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
<textarea {{ block('widget_attributes') }}>{{ value }}</textarea>
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock textarea_widget %}
|
|
||||||
|
|
||||||
{% block choice_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if expanded %}
|
|
||||||
{{ block('choice_widget_expanded') }}
|
|
||||||
{% else %}
|
|
||||||
{{ block('choice_widget_collapsed') }}
|
|
||||||
{% endif %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock choice_widget %}
|
|
||||||
|
|
||||||
{% block choice_widget_expanded %}
|
|
||||||
{% spaceless %}
|
|
||||||
<div {{ block('widget_container_attributes') }}>
|
|
||||||
{% for child in form %}
|
|
||||||
{{ form_widget(child) }}
|
|
||||||
{{ form_label(child) }}
|
|
||||||
{% endfor %}
|
|
||||||
</div>
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock choice_widget_expanded %}
|
|
||||||
|
|
||||||
{% block choice_widget_collapsed %}
|
|
||||||
{% spaceless %}
|
|
||||||
<select {{ block('widget_attributes') }}{% if multiple %} multiple="multiple"{% endif %}>
|
|
||||||
{% if empty_value is not none %}
|
|
||||||
<option value="">{{ empty_value }}</option>
|
|
||||||
{% endif %}
|
|
||||||
{% if preferred_choices|length > 0 %}
|
|
||||||
{% set options = preferred_choices %}
|
|
||||||
{{ block('choice_widget_options') }}
|
|
||||||
{% if choices|length > 0 and separator is not none %}
|
|
||||||
<option disabled="disabled">{{ separator }}</option>
|
|
||||||
{% endif %}
|
|
||||||
{% endif %}
|
|
||||||
{% set options = choices %}
|
|
||||||
{{ block('choice_widget_options') }}
|
|
||||||
</select>
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock choice_widget_collapsed %}
|
|
||||||
|
|
||||||
{% block choice_widget_options %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% for group_label, choice in options %}
|
|
||||||
{% if choice is iterable %}
|
|
||||||
<optgroup label="{{ group_label }}">
|
|
||||||
{% set options = choice %}
|
|
||||||
{{ block('choice_widget_options') }}
|
|
||||||
</optgroup>
|
|
||||||
{% else %}
|
|
||||||
<option value="{{ choice.value }}"{% if choice is selectedchoice(value) %} selected="selected"{% endif %}>{{ choice.label }}</option>
|
|
||||||
{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock choice_widget_options %}
|
|
||||||
|
|
||||||
{% block checkbox_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
<input type="checkbox" {{ block('widget_attributes') }}{% if value is defined %} value="{{ value }}"{% endif %}{% if checked %} checked="checked"{% endif %} />
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock checkbox_widget %}
|
|
||||||
|
|
||||||
{% block radio_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
<input type="radio" {{ block('widget_attributes') }}{% if value is defined %} value="{{ value }}"{% endif %}{% if checked %} checked="checked"{% endif %} />
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock radio_widget %}
|
|
||||||
|
|
||||||
{% block datetime_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if widget == 'single_text' %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% else %}
|
|
||||||
<div {{ block('widget_container_attributes') }}>
|
|
||||||
{{ form_errors(form.date) }}
|
|
||||||
{{ form_errors(form.time) }}
|
|
||||||
{{ form_widget(form.date) }}
|
|
||||||
{{ form_widget(form.time) }}
|
|
||||||
</div>
|
|
||||||
{% endif %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock datetime_widget %}
|
|
||||||
|
|
||||||
{% block date_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if widget == 'single_text' %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% else %}
|
|
||||||
<div {{ block('widget_container_attributes') }}>
|
|
||||||
{{ date_pattern|replace({
|
|
||||||
'{{ year }}': form_widget(form.year),
|
|
||||||
'{{ month }}': form_widget(form.month),
|
|
||||||
'{{ day }}': form_widget(form.day),
|
|
||||||
})|raw }}
|
|
||||||
</div>
|
|
||||||
{% endif %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock date_widget %}
|
|
||||||
|
|
||||||
{% block time_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if widget == 'single_text' %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% else %}
|
|
||||||
{% set vars = widget == 'text' ? { 'attr': { 'size': 1 }} : {} %}
|
|
||||||
<div {{ block('widget_container_attributes') }}>
|
|
||||||
{{ form_widget(form.hour, vars) }}:{{ form_widget(form.minute, vars) }}{% if with_seconds %}:{{ form_widget(form.second, vars) }}{% endif %}
|
|
||||||
</div>
|
|
||||||
{% endif %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock time_widget %}
|
|
||||||
|
|
||||||
{% block number_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{# type="number" doesn't work with floats #}
|
|
||||||
{% set type = type|default('text') %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock number_widget %}
|
|
||||||
|
|
||||||
{% block integer_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% set type = type|default('number') %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock integer_widget %}
|
|
||||||
|
|
||||||
{% block money_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{{ money_pattern|replace({ '{{ widget }}': block('form_widget_simple') })|raw }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock money_widget %}
|
|
||||||
|
|
||||||
{% block url_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% set type = type|default('url') %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock url_widget %}
|
|
||||||
|
|
||||||
{% block search_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% set type = type|default('search') %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock search_widget %}
|
|
||||||
|
|
||||||
{% block percent_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% set type = type|default('text') %}
|
|
||||||
{{ block('form_widget_simple') }} %
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock percent_widget %}
|
|
||||||
|
|
||||||
{% block password_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% set type = type|default('password') %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock password_widget %}
|
|
||||||
|
|
||||||
{% block hidden_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% set type = type|default('hidden') %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock hidden_widget %}
|
|
||||||
|
|
||||||
{% block email_widget %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% set type = type|default('email') %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock email_widget %}
|
|
||||||
|
|
||||||
{# Labels #}
|
|
||||||
|
|
||||||
{% block form_label %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if label is not sameas(false) %}
|
|
||||||
{% if not compound %}
|
|
||||||
{% set label_attr = label_attr|merge({'for': id}) %}
|
|
||||||
{% endif %}
|
|
||||||
{% if required %}
|
|
||||||
{% set label_attr = label_attr|merge({'class': (label_attr.class|default('') ~ ' required')|trim}) %}
|
|
||||||
{% endif %}
|
|
||||||
{% if label is empty %}
|
|
||||||
{% set label = name|humanize %}
|
|
||||||
{% endif %}
|
|
||||||
<label{% for attrname, attrvalue in label_attr %} {{ attrname }}="{{ attrvalue }}"{% endfor %}>{{ label }}</label>
|
|
||||||
{% endif %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_label %}
|
|
||||||
|
|
||||||
{# Rows #}
|
|
||||||
|
|
||||||
{% block repeated_row %}
|
|
||||||
{% spaceless %}
|
|
||||||
{#
|
|
||||||
No need to render the errors here, as all errors are mapped
|
|
||||||
to the first child (see RepeatedTypeValidatorExtension).
|
|
||||||
#}
|
|
||||||
{{ block('form_rows') }}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock repeated_row %}
|
|
||||||
|
|
||||||
{% block form_row %}
|
|
||||||
{% spaceless %}
|
|
||||||
<div>
|
|
||||||
{{ form_label(form) }}
|
|
||||||
{{ form_errors(form) }}
|
|
||||||
{{ form_widget(form) }}
|
|
||||||
</div>
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_row %}
|
|
||||||
|
|
||||||
{% block hidden_row %}
|
|
||||||
{{ form_widget(form) }}
|
|
||||||
{% endblock hidden_row %}
|
|
||||||
|
|
||||||
{# Misc #}
|
|
||||||
|
|
||||||
{% block form_enctype %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if multipart %}enctype="multipart/form-data"{% endif %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_enctype %}
|
|
||||||
|
|
||||||
{% block form_errors %}
|
|
||||||
{% import "login/common/macros.html.twig" as auth_macro %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if errors|length > 0 %}
|
|
||||||
{{ auth_macro.fieldError(errors) }}
|
|
||||||
{% endif %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_errors %}
|
|
||||||
|
|
||||||
{% block form_rest %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% for child in form %}
|
|
||||||
{% if not child.rendered %}
|
|
||||||
{{ form_row(child) }}
|
|
||||||
{% endif %}
|
|
||||||
{% endfor %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_rest %}
|
|
||||||
|
|
||||||
{# Support #}
|
|
||||||
|
|
||||||
{% block form_rows %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% for child in form %}
|
|
||||||
{{ form_row(child) }}
|
|
||||||
{% endfor %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock form_rows %}
|
|
||||||
|
|
||||||
{% block widget_attributes %}
|
|
||||||
{% spaceless %}
|
|
||||||
id="{{ id }}" name="{{ full_name }}"{% if read_only %} readonly="readonly"{% endif %}{% if disabled %} disabled="disabled"{% endif %}{% if required %} required="required"{% endif %}{% if max_length %} maxlength="{{ max_length }}"{% endif %}{% if pattern %} pattern="{{ pattern }}"{% endif %}
|
|
||||||
{% for attrname, attrvalue in attr %}{% if attrname in ['placeholder', 'title'] %}{{ attrname }}="{{ attrvalue|trans }}" {% else %}{{ attrname }}="{{ attrvalue }}" {% endif %}{% endfor %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock widget_attributes %}
|
|
||||||
|
|
||||||
{% block widget_container_attributes %}
|
|
||||||
{% spaceless %}
|
|
||||||
{% if id is not empty %}id="{{ id }}" {% endif %}
|
|
||||||
{% for attrname, attrvalue in attr %}{{ attrname }}="{{ attrvalue }}" {% endfor %}
|
|
||||||
{% endspaceless %}
|
|
||||||
{% endblock widget_container_attributes %}
|
|
||||||
|
|
||||||
{# Deprecated in Symfony 2.1, to be removed in 2.3 #}
|
|
||||||
|
|
||||||
{% block generic_label %}{{ block('form_label') }}{% endblock %}
|
|
||||||
{% block widget_choice_options %}{{ block('choice_widget_options') }}{% endblock %}
|
|
||||||
{% block field_widget %}{{ block('form_widget_simple') }}{% endblock %}
|
|
||||||
{% block field_label %}{{ block('form_label') }}{% endblock %}
|
|
||||||
{% block field_row %}{{ block('form_row') }}{% endblock %}
|
|
||||||
{% block field_enctype %}{{ block('form_enctype') }}{% endblock %}
|
|
||||||
{% block field_errors %}{{ block('form_errors') }}{% endblock %}
|
|
||||||
{% block field_rest %}{{ block('form_rest') }}{% endblock %}
|
|
||||||
{% block field_rows %}{{ block('form_rows') }}{% endblock %}
|
|
||||||
|
|
||||||
|
|
||||||
{% block geoname_widget %}
|
|
||||||
{{ block('form_widget_simple') }}
|
|
||||||
|
|
||||||
{# add custom code here #}
|
|
||||||
{% endblock %}
|
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
{% form_theme form 'login/common/fields.html.twig' %}
|
||||||
|
|
||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<!--[if lt IE 7]> <html class="no-js lt-ie9 lt-ie8 lt-ie7"> <![endif]-->
|
<!--[if lt IE 7]> <html class="no-js lt-ie9 lt-ie8 lt-ie7"> <![endif]-->
|
||||||
<!--[if IE 7]> <html class="no-js lt-ie9 lt-ie8"> <![endif]-->
|
<!--[if IE 7]> <html class="no-js lt-ie9 lt-ie8"> <![endif]-->
|
||||||
|
|||||||
Reference in New Issue
Block a user