phpmob / settings-bundle
仅是一个 Symfony 设置包。
1.2.2
2018-06-09 18:11 UTC
Requires
- php: ^7.1
- phpmob/settings: ^1.2
- symfony/form: ^3.3|^4.0
- symfony/framework-bundle: ^3.3|^4.0
- symfony/templating: ^3.3|^4.0
- twig/twig: ^2.0
Requires (Dev)
- cache/filesystem-adapter: ^1.0
- phpspec/phpspec: ^4.0
- phpunit/phpunit: ^5.6
- sylius-labs/coding-standard: ^1.0
Suggests
- cache/filesystem-adapter: To use built-in \PhpMob\Settings\Manager\CachedManager.
README
仅是一个设置库。
安装
通过 composer 安装。
$ composer require phpmob/settings-bundle
使用缓存
$ composer require cache/filesystem-adapter
现在您可以使用内置的 \PhpMob\Settings\Manager\CachedManager
。
使用内置的 symfony 框架缓存作为替代,请参阅 - 框架/缓存
示例配置
# use with doctrine orm doctrine: orm: mappings: PhpMobSettings: type: xml is_bundle: false prefix: PhpMob\Settings\Model dir: '%kernel.project_dir%/vendor/phpmob/settings-bundle/src/Resources/config/doctrine/model' phpmob_settings: cache: service: cache.flysystem schemas: section1: label: Section1 settings: key1: ~ section2: label: Section2 settings: key1: value: key1Value key2: label: SectionKey2 value: key2value blueprint: options: label: SectionKey2Label constraints: NotBlank: ~ gender: label: Gender value: f blueprint: type: Symfony\Component\Form\Extension\Core\Type\ChoiceType options: required: true choices: Man: m Feman: f birthday: type: date label: Birthday value: "1988-02-10" blueprint: type: Symfony\Component\Form\Extension\Core\Type\BirthdayType datetime: type: datetime label: DateTime value: ~ blueprint: type: Symfony\Component\Form\Extension\Core\Type\DateTimeType
所有者设置
为所有者(用户)感知的设置进行配置。控制器使用 PhpMobSettingsBundle:Update:userUpdate
。
phpmob_settings: schemas: section1: owner_aware: true label: Section1 settings: key1: ~
更新路由
请参阅 src/Resources/config/routing.xml
中的示例路由,或使用以下方式自定义:
your_route_name: path: /settings/{section} defaults: _controller: PhpMobSettingsBundle:Update:globalUpdate _template: @yourtemplate # default @PhpMobSetting/default.html.twig _flash: ~ # flash message after update _redirect: ~ # redirect after update
自定义表单类型以在表单视图中显示 description
设置。
<?php namespace YourBundle\Form\Type; use PhpMob\SettingsBundle\Form\Type\AbstractBlueprintType; use Symfony\Component\Form\Extension\Core\Type\CheckboxType; class YourSettingType extends AbstractBlueprintType { /** * {@inheritdoc} */ public function getParentType(): string { return CheckboxType::class; } }
并在设置配置中。
phpmob_settings: schemas: section1: owner_aware: true label: Section1 settings: key1: type: boolean label: 'Key 1' value: true blueprint: type: YourBundle\Form\Type\YourSettingType
在 twig 中使用
获取设置
{{ settings_get('section.key') }} {# owner aware setting #} {{ settings_get('section.key', app.user) }}
设置设置
{{ settings_set('section.key', 'value') }} {# owner aware setting #} {{ settings_set('section.key', 'value', app.user) }}
示例管理界面
贡献
想要帮助我们并构建开发者友好的 php 代码?请遵循我们的 编码标准 并测试您的代码 — 请参阅 测试,规范。
现在开始分叉和 PR 吧!
编码标准
向 PhpMob 贡献代码时,您必须遵循其编码标准。
PhpMob 遵循在 PSR-0,PSR-1 和 PSR-2 文档中定义的标准。
$ ./bin/ecs check src --fix
测试
$ ./bin/phpunit