micayael/parameterizer-client-bundle

Parameterizer 客户端

1.0.2 2018-07-03 14:39 UTC

This package is auto-updated.

Last update: 2024-09-29 04:37:14 UTC


README

安装 bundle

安装

    composer require micayael/parameterizer-client-bundle:1.0.*

在 AppKernel.php 中激活 bundle

    $bundles = [
        ...
        new Micayael\Parameterizer\ClientBundle\ParameterizerClientBundle(),
        ...
    ];

配置 Guzzle 以查询 authenticator 服务

parameterizer_client:
    host: https://:8000 # host de la aplicación parameterizer
    username: user # usuario de acceso
    password: pass # clave de acceso
    agrupado: true # true|false (opcional, default: true)

"分组" 选项指示服务是否按域名返回分组参数

在控制器中使用它

执行 bin/console cache:clear 后,可以使用以下服务获取参数

    # Para obtener todos los parámetros de la aplicación como un array
    $this->get('parameterizer_client.cache')->getAll()

    # Para obtener todos los parámetros de un dominio específico como un array
    $this->get('parameterizer_client.cache')->get($dominio);

    # Para obtener un parámetro específico
    $this->get('parameterizer_client.cache')->get($dominio, $codigo);

在 twig 中使用它

    # Para obtener todos los parámetros de la aplicación como un array
    {% dump(get_params()) %}

    # Para obtener todos los parámetros de un dominio específico como un array
    {% dump(get_params(dominio)) %}

    # Para obtener un parámetro específico
    {% dump(get_param(dominio, codigo)) %}

在表单中使用它

可以从控制器中通过表单的 options 传递参数

$form = $this->createForm('AppBundle\Form\BuscadorType', null, ['parametros' => $this->get('parameterizer_client.cache')->getAll()]);

必须配置表单以接收此新选项

public function configureOptions(OptionsResolver $resolver)
{
    $resolver->setRequired('parametros');
}

在 buildForm 方法中接收选项作为参数

public function buildForm(FormBuilderInterface $builder, array $options)
{
    $builder
        ->add('estado', ChoiceType::class, [
            'placeholder' => 'Seleccione una opción',
            'empty_data' => null,
            'choices' => array_flip($options['parametros'][$dominio]),
        ])
}