<?php /** * PHPExcel_Cell_DataValidation * * Copyright (c) 2006 - 2015 PHPExcel * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA * * @category PHPExcel * @package PHPExcel_Cell * @copyright Copyright (c) 2006 - 2015 PHPExcel (http://www.codeplex.com/PHPExcel) * @license http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt LGPL * @version ##VERSION##, ##DATE## */ class PHPExcel_Cell_DataValidation { /* Data validation types */ const TYPE_NONE = 'none'; const TYPE_CUSTOM = 'custom'; const TYPE_DATE = 'date'; const TYPE_DECIMAL = 'decimal'; const TYPE_LIST = 'list'; const TYPE_TEXTLENGTH = 'textLength'; const TYPE_TIME = 'time'; const TYPE_WHOLE = 'whole'; /* Data validation error styles */ const STYLE_STOP = 'stop'; const STYLE_WARNING = 'warning'; const STYLE_INFORMATION = 'information'; /* Data validation operators */ const OPERATOR_BETWEEN = 'between'; const OPERATOR_EQUAL = 'equal'; const OPERATOR_GREATERTHAN = 'greaterThan'; const OPERATOR_GREATERTHANOREQUAL = 'greaterThanOrEqual'; const OPERATOR_LESSTHAN = 'lessThan'; const OPERATOR_LESSTHANOREQUAL = 'lessThanOrEqual'; const OPERATOR_NOTBETWEEN = 'notBetween'; const OPERATOR_NOTEQUAL = 'notEqual'; /** * Formula 1 * * @var string */ private $formula1; /** * Formula 2 * * @var string */ private $formula2; /** * Type * * @var string */ private $type = PHPExcel_Cell_DataValidation::TYPE_NONE; /** * Error style * * @var string */ private $errorStyle = PHPExcel_Cell_DataValidation::STYLE_STOP; /** * Operator * * @var string */ private $operator; /** * Allow Blank * * @var boolean */ private $allowBlank; /** * Show DropDown * * @var boolean */ private $showDropDown; /** * Show InputMessage * * @var boolean */ private $showInputMessage; /** * Show ErrorMessage * * @var boolean */ private $showErrorMessage; /** * Error title * * @var string */ private $errorTitle; /** * Error * * @var string */ private $error; /** * Prompt title * * @var string */ private $promptTitle; /** * Prompt * * @var string */ private $prompt; /** * Create a new PHPExcel_Cell_DataValidation */ public function __construct() { // Initialise member variables $this->formula1 = ''; $this->formula2 = ''; $this->type = PHPExcel_Cell_DataValidation::TYPE_NONE; $this->errorStyle = PHPExcel_Cell_DataValidation::STYLE_STOP; $this->operator = ''; $this->allowBlank = false; $this->showDropDown = false; $this->showInputMessage = false; $this->showErrorMessage = false; $this->errorTitle = ''; $this->error = ''; $this->promptTitle = ''; $this->prompt = ''; } /** * Get Formula 1 * * @return string */ public function getFormula1() { return $this->formula1; } /** * Set Formula 1 * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setFormula1($value = '') { $this->formula1 = $value; return $this; } /** * Get Formula 2 * * @return string */ public function getFormula2() { return $this->formula2; } /** * Set Formula 2 * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setFormula2($value = '') { $this->formula2 = $value; return $this; } /** * Get Type * * @return string */ public function getType() { return $this->type; } /** * Set Type * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setType($value = PHPExcel_Cell_DataValidation::TYPE_NONE) { $this->type = $value; return $this; } /** * Get Error style * * @return string */ public function getErrorStyle() { return $this->errorStyle; } /** * Set Error style * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setErrorStyle($value = PHPExcel_Cell_DataValidation::STYLE_STOP) { $this->errorStyle = $value; return $this; } /** * Get Operator * * @return string */ public function getOperator() { return $this->operator; } /** * Set Operator * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setOperator($value = '') { $this->operator = $value; return $this; } /** * Get Allow Blank * * @return boolean */ public function getAllowBlank() { return $this->allowBlank; } /** * Set Allow Blank * * @param boolean $value * @return PHPExcel_Cell_DataValidation */ public function setAllowBlank($value = false) { $this->allowBlank = $value; return $this; } /** * Get Show DropDown * * @return boolean */ public function getShowDropDown() { return $this->showDropDown; } /** * Set Show DropDown * * @param boolean $value * @return PHPExcel_Cell_DataValidation */ public function setShowDropDown($value = false) { $this->showDropDown = $value; return $this; } /** * Get Show InputMessage * * @return boolean */ public function getShowInputMessage() { return $this->showInputMessage; } /** * Set Show InputMessage * * @param boolean $value * @return PHPExcel_Cell_DataValidation */ public function setShowInputMessage($value = false) { $this->showInputMessage = $value; return $this; } /** * Get Show ErrorMessage * * @return boolean */ public function getShowErrorMessage() { return $this->showErrorMessage; } /** * Set Show ErrorMessage * * @param boolean $value * @return PHPExcel_Cell_DataValidation */ public function setShowErrorMessage($value = false) { $this->showErrorMessage = $value; return $this; } /** * Get Error title * * @return string */ public function getErrorTitle() { return $this->errorTitle; } /** * Set Error title * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setErrorTitle($value = '') { $this->errorTitle = $value; return $this; } /** * Get Error * * @return string */ public function getError() { return $this->error; } /** * Set Error * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setError($value = '') { $this->error = $value; return $this; } /** * Get Prompt title * * @return string */ public function getPromptTitle() { return $this->promptTitle; } /** * Set Prompt title * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setPromptTitle($value = '') { $this->promptTitle = $value; return $this; } /** * Get Prompt * * @return string */ public function getPrompt() { return $this->prompt; } /** * Set Prompt * * @param string $value * @return PHPExcel_Cell_DataValidation */ public function setPrompt($value = '') { $this->prompt = $value; return $this; } /** * Get hash code * * @return string Hash code */ public function getHashCode() { return md5( $this->formula1 . $this->formula2 . $this->type = PHPExcel_Cell_DataValidation::TYPE_NONE . $this->errorStyle = PHPExcel_Cell_DataValidation::STYLE_STOP . $this->operator . ($this->allowBlank ? 't' : 'f') . ($this->showDropDown ? 't' : 'f') . ($this->showInputMessage ? 't' : 'f') . ($this->showErrorMessage ? 't' : 'f') . $this->errorTitle . $this->error . $this->promptTitle . $this->prompt . __CLASS__ ); } /** * Implement PHP __clone to create a deep clone, not just a shallow copy. */ public function __clone() { $vars = get_object_vars($this); foreach ($vars as $key => $value) { if (is_object($value)) { $this->$key = clone $value; } else { $this->$key = $value; } } } }