RequiredValidator.php 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\validators;
  8. use Yii;
  9. use yii\helpers\Json;
  10. /**
  11. * RequiredValidator validates that the specified attribute does not have null or empty value.
  12. *
  13. * @author Qiang Xue <qiang.xue@gmail.com>
  14. * @since 2.0
  15. */
  16. class RequiredValidator extends Validator
  17. {
  18. /**
  19. * @var bool whether to skip this validator if the value being validated is empty.
  20. */
  21. public $skipOnEmpty = false;
  22. /**
  23. * @var mixed the desired value that the attribute must have.
  24. * If this is null, the validator will validate that the specified attribute is not empty.
  25. * If this is set as a value that is not null, the validator will validate that
  26. * the attribute has a value that is the same as this property value.
  27. * Defaults to null.
  28. * @see strict
  29. */
  30. public $requiredValue;
  31. /**
  32. * @var bool whether the comparison between the attribute value and [[requiredValue]] is strict.
  33. * When this is true, both the values and types must match.
  34. * Defaults to false, meaning only the values need to match.
  35. *
  36. * Note that behavior for when [[requiredValue]] is null is the following:
  37. *
  38. * - In strict mode, the validator will check if the attribute value is null
  39. * - In non-strict mode validation will fail
  40. */
  41. public $strict = false;
  42. /**
  43. * @var string the user-defined error message. It may contain the following placeholders which
  44. * will be replaced accordingly by the validator:
  45. *
  46. * - `{attribute}`: the label of the attribute being validated
  47. * - `{value}`: the value of the attribute being validated
  48. * - `{requiredValue}`: the value of [[requiredValue]]
  49. */
  50. public $message;
  51. /**
  52. * {@inheritdoc}
  53. */
  54. public function init()
  55. {
  56. parent::init();
  57. if ($this->message === null) {
  58. $this->message = $this->requiredValue === null ? Yii::t('yii', '{attribute} cannot be blank.')
  59. : Yii::t('yii', '{attribute} must be "{requiredValue}".');
  60. }
  61. }
  62. /**
  63. * {@inheritdoc}
  64. */
  65. protected function validateValue($value)
  66. {
  67. if ($this->requiredValue === null) {
  68. if ($this->strict && $value !== null || !$this->strict && !$this->isEmpty(is_string($value) ? trim($value) : $value)) {
  69. return null;
  70. }
  71. } elseif (!$this->strict && $value == $this->requiredValue || $this->strict && $value === $this->requiredValue) {
  72. return null;
  73. }
  74. if ($this->requiredValue === null) {
  75. return [$this->message, []];
  76. }
  77. return [$this->message, [
  78. 'requiredValue' => $this->requiredValue,
  79. ]];
  80. }
  81. /**
  82. * {@inheritdoc}
  83. */
  84. public function clientValidateAttribute($model, $attribute, $view)
  85. {
  86. ValidationAsset::register($view);
  87. $options = $this->getClientOptions($model, $attribute);
  88. return 'yii.validation.required(value, messages, ' . Json::htmlEncode($options) . ');';
  89. }
  90. /**
  91. * {@inheritdoc}
  92. */
  93. public function getClientOptions($model, $attribute)
  94. {
  95. $options = [];
  96. if ($this->requiredValue !== null) {
  97. $options['message'] = $this->formatMessage($this->message, [
  98. 'requiredValue' => $this->requiredValue,
  99. ]);
  100. $options['requiredValue'] = $this->requiredValue;
  101. } else {
  102. $options['message'] = $this->message;
  103. }
  104. if ($this->strict) {
  105. $options['strict'] = 1;
  106. }
  107. $options['message'] = $this->formatMessage($options['message'], [
  108. 'attribute' => $model->getAttributeLabel($attribute),
  109. ]);
  110. return $options;
  111. }
  112. }