phakpoom / settings-bundle
只是一个Symfony设置包。
2.2.5
2024-04-18 09:40 UTC
Requires
- php: >=7.2 || >=8.0
- phakpoom/settings: ^2.2.2
- symfony/form: ^4.4 | ^5.0 | ^6.0 | ^7.0
- symfony/framework-bundle: ^4.4 | ^5.0 | ^6.0 | ^7.0
- symfony/templating: ^4.4 | ^5.0 | ^6.0 | ^7.0
- twig/twig: ^2.0|^3.0
Requires (Dev)
- cache/filesystem-adapter: ^1.0
- phpspec/phpspec: ^7.0
- phpunit/phpunit: ^8.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