empathy / yii2-datetime-compare
DateTime comparison validator
Installs: 26 132
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 4
Forks: 6
Open Issues: 1
Type:yii2-extension
Requires
- bower-asset/moment: ^2.11
README
DateTime comparison validator for Yii Framework 2.0. Temporary solution until this enhancement is implemented.
[[Empathy\Validators\DateTimeCompareValidator|compare]]
[ // validates if the value of "birthday" attribute equals to that of "birthday_repeat" ['birthday', DateTimeCompareValidator::className()], // validates if birthday is less than or equal to today ['birthday', DateTimeCompareValidator::className(), 'compareValue' => date('Y-m-d H:i:s'), 'operator' => '<='], // validates if birthday is less than driver's license expiry ['birthday', DateTimeCompareValidator::className(), 'compareAttribute' => 'driver_license_expiry', 'operator' => '<'], ]
This validator compares the specified input datetime with another one and make sure if their relationship
is as specified by the operator
property.
compareAttribute
: the name of the attribute whose value should be compared with. When the validator is being used to validate an attribute, the default value of this property would be the name of the attribute suffixed with_repeat
. For example, if the attribute being validated isbirthday
, then this property will default tobirthday_repeat
.compareValue
: a constant value that the input value should be compared with. When both of this property andcompareAttribute
are specified, this property will take precedence.operator
: the comparison operator. Defaults to==
, meaning checking if the input value is equal to that ofcompareAttribute
orcompareValue
. The following operators are supported:==
: check if two values are equal. The comparison is done is non-strict mode.===
: check if two values are equal. The comparison is done is strict mode.!=
: check if two values are NOT equal. The comparison is done is non-strict mode.!==
: check if two values are NOT equal. The comparison is done is strict mode.>
: check if value being validated is greater than the value being compared with.>=
: check if value being validated is greater than or equal to the value being compared with.<
: check if value being validated is less than the value being compared with.<=
: check if value being validated is less than or equal to the value being compared with.
format
: Date format to parse values with. If blank, PHP Date will try and guess your format.jsFormat
: Date format to parse values with client side. If blank, Moment.js will try and guess your format. Moment.js will not guess all formats correctly, and this feature will be deprecated in future releases of Moment.js. See moment/moment#1407
Installation
The preferred way to install this extension is through composer.
Note: Check the composer.json for this extension's requirements and dependencies.
Run
$ composer require empathy/yii2-datetime-compare