承接 oh/date-extra-validator-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

oh/date-extra-validator-bundle

Composer 安装命令:

composer require oh/date-extra-validator-bundle

包简介

Symfony2 Date Validator for Minimum and Maximum Constraints

README 文档

README

A minimum and maximum date validator for Symfony2

Installation

Install this bundle as usual by adding to composer.json:

"oh/date-extra-validator-bundle": "dev-master" 

Register the bundle in app/AppKernel.php:

// app/AppKernel.php public function registerBundles() { return array( // ... new Oh\DateExtraValidatorBundle\OhDateExtraValidatorBundle(), ); } 

Usage

Add the constraints to your model

... use Oh\DateExtraValidatorBundle\Validator\Constraints as OhAssert; /** * @ORM\Entity() */ class Event { /** * @ORM\Column(type="datetime") * * @OhAssert\DateExtra(min="-1 year", max="+1 year", intlTimeFormat=\IntlDateFormatter::NONE) */ protected $start_time; } 

Or in your yml (WARNING! untested - I use annotations)

Acme\DemoBundle\Entity\AcmeEntity: properties: start_time: - Oh\DateExtraValidatorBundle\Validator\Constraints\DateExtra: {min="-1 year", max="+1 year", intlTimeFormat=\IntlDateFormatter::NONE} 

Options

Messages

When you validate your model through a form you should see the error messages as defined in Oh\DateExtraValidatorBundle\Validator\Constraints\DateExtra.

public $minMessage = 'You cannot choose a date before {{ min }}.'; public $maxMessage = 'You cannot choose a date after {{ max }}.'; public $invalidMessage = 'The date is invalid'; ... 

Each message can use {{ min }}, {{ max }} and {{ value }} so you can for example put:

/** * @OhAssert\DateExtra(minMessage="The date you supplied, {{ value }}, should be between {{ min }} and {{ max }}", min="-1 year", max="+1 year") */ 

The format of the date in the error messages can be a normal date string or an IntlDateFormatter date.

/** * @OhAssert\DateExtra(format="Y-m-d",min="-1 year", max="+1 year") * or * @OhAssert\DateExtra(intlDateFormat=\IntlDateFormatter::LONG, intlTimeFormat=\IntlDateFormatter::LONG, min="-1 year", max="+1 year") */ 

For the UK timezone Europe/London the 2 examples above would output "You cannot choose a date before 2011-09-04." and "You cannot choose a date before September 4, 2011 8:10:34 PM GMT+01:00."

You can also set the timezone manually by specifying it in the constructor (eg timezone="Europe/London")

Valid values

The class can handle most date formats; \DateTime, array('year'=>2012,'month'=>9,'day'=>4), unix timestamp (eg 1346789811), string (eg 2012-09-04) or an object that returns one of these values in __toString()

Tests

Build Status

Credits

  • Ollie Harridge ollietb as main author.

统计信息

  • 总下载量: 196.05k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 4
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 4
  • Watchers: 2
  • Forks: 2
  • 开发语言: PHP

其他信息

  • 授权协议: Unknown
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固