芝麻web文件管理V1.00
编辑当前文件:/home2/sdektunc/xmintal-back/vendor/yiisoft/yii2/validators/ImageValidator.php
* @since 2.0 */ class ImageValidator extends FileValidator { /** * @var string the error message used when the uploaded file is not an image. * You may use the following tokens in the message: * * - {attribute}: the attribute name * - {file}: the uploaded file name */ public $notImage; /** * @var int|null the minimum width in pixels. * Defaults to null, meaning no limit. * @see underWidth for the customized message used when image width is too small. */ public $minWidth; /** * @var int|null the maximum width in pixels. * Defaults to null, meaning no limit. * @see overWidth for the customized message used when image width is too big. */ public $maxWidth; /** * @var int|null the minimum height in pixels. * Defaults to null, meaning no limit. * @see underHeight for the customized message used when image height is too small. */ public $minHeight; /** * @var int|null the maximum width in pixels. * Defaults to null, meaning no limit. * @see overHeight for the customized message used when image height is too big. */ public $maxHeight; /** * @var string the error message used when the image is under [[minWidth]]. * You may use the following tokens in the message: * * - {attribute}: the attribute name * - {file}: the uploaded file name * - {limit}: the value of [[minWidth]] */ public $underWidth; /** * @var string the error message used when the image is over [[maxWidth]]. * You may use the following tokens in the message: * * - {attribute}: the attribute name * - {file}: the uploaded file name * - {limit}: the value of [[maxWidth]] */ public $overWidth; /** * @var string the error message used when the image is under [[minHeight]]. * You may use the following tokens in the message: * * - {attribute}: the attribute name * - {file}: the uploaded file name * - {limit}: the value of [[minHeight]] */ public $underHeight; /** * @var string the error message used when the image is over [[maxHeight]]. * You may use the following tokens in the message: * * - {attribute}: the attribute name * - {file}: the uploaded file name * - {limit}: the value of [[maxHeight]] */ public $overHeight; /** * {@inheritdoc} */ public function init() { parent::init(); if ($this->notImage === null) { $this->notImage = Yii::t('yii', 'The file "{file}" is not an image.'); } if ($this->underWidth === null) { $this->underWidth = Yii::t('yii', 'The image "{file}" is too small. The width cannot be smaller than {limit, number} {limit, plural, one{pixel} other{pixels}}.'); } if ($this->underHeight === null) { $this->underHeight = Yii::t('yii', 'The image "{file}" is too small. The height cannot be smaller than {limit, number} {limit, plural, one{pixel} other{pixels}}.'); } if ($this->overWidth === null) { $this->overWidth = Yii::t('yii', 'The image "{file}" is too large. The width cannot be larger than {limit, number} {limit, plural, one{pixel} other{pixels}}.'); } if ($this->overHeight === null) { $this->overHeight = Yii::t('yii', 'The image "{file}" is too large. The height cannot be larger than {limit, number} {limit, plural, one{pixel} other{pixels}}.'); } } /** * {@inheritdoc} */ protected function validateValue($value) { $result = parent::validateValue($value); return empty($result) ? $this->validateImage($value) : $result; } /** * Validates an image file. * @param UploadedFile $image uploaded file passed to check against a set of rules * @return array|null the error message and the parameters to be inserted into the error message. * Null should be returned if the data is valid. */ protected function validateImage($image) { if (false === ($imageInfo = getimagesize($image->tempName))) { return [$this->notImage, ['file' => $image->name]]; } list($width, $height) = $imageInfo; if ($width == 0 || $height == 0) { return [$this->notImage, ['file' => $image->name]]; } if ($this->minWidth !== null && $width < $this->minWidth) { return [$this->underWidth, ['file' => $image->name, 'limit' => $this->minWidth]]; } if ($this->minHeight !== null && $height < $this->minHeight) { return [$this->underHeight, ['file' => $image->name, 'limit' => $this->minHeight]]; } if ($this->maxWidth !== null && $width > $this->maxWidth) { return [$this->overWidth, ['file' => $image->name, 'limit' => $this->maxWidth]]; } if ($this->maxHeight !== null && $height > $this->maxHeight) { return [$this->overHeight, ['file' => $image->name, 'limit' => $this->maxHeight]]; } return null; } /** * {@inheritdoc} */ public function clientValidateAttribute($model, $attribute, $view) { ValidationAsset::register($view); $options = $this->getClientOptions($model, $attribute); return 'yii.validation.image(attribute, messages, ' . Json::htmlEncode($options) . ', deferred);'; } /** * {@inheritdoc} */ public function getClientOptions($model, $attribute) { $options = parent::getClientOptions($model, $attribute); $label = $model->getAttributeLabel($attribute); if ($this->notImage !== null) { $options['notImage'] = $this->formatMessage($this->notImage, [ 'attribute' => $label, ]); } if ($this->minWidth !== null) { $options['minWidth'] = $this->minWidth; $options['underWidth'] = $this->formatMessage($this->underWidth, [ 'attribute' => $label, 'limit' => $this->minWidth, ]); } if ($this->maxWidth !== null) { $options['maxWidth'] = $this->maxWidth; $options['overWidth'] = $this->formatMessage($this->overWidth, [ 'attribute' => $label, 'limit' => $this->maxWidth, ]); } if ($this->minHeight !== null) { $options['minHeight'] = $this->minHeight; $options['underHeight'] = $this->formatMessage($this->underHeight, [ 'attribute' => $label, 'limit' => $this->minHeight, ]); } if ($this->maxHeight !== null) { $options['maxHeight'] = $this->maxHeight; $options['overHeight'] = $this->formatMessage($this->overHeight, [ 'attribute' => $label, 'limit' => $this->maxHeight, ]); } return $options; } }