Dateien nach "includes/PHPExcel/Classes/PHPExcel/Worksheet" hochladen
This commit is contained in:
		
							
								
								
									
										862
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/AutoFilter.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										862
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/AutoFilter.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,862 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_AutoFilter | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_AutoFilter | ||||
| { | ||||
| 	/** | ||||
| 	 * Autofilter Worksheet | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet | ||||
| 	 */ | ||||
| 	private $_workSheet = NULL; | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * Autofilter Range | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_range = ''; | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * Autofilter Column Ruleset | ||||
| 	 * | ||||
| 	 * @var array of PHPExcel_Worksheet_AutoFilter_Column | ||||
| 	 */ | ||||
| 	private $_columns = array(); | ||||
|  | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_AutoFilter | ||||
| 	 * | ||||
| 	 *	@param	string		$pRange		Cell range (i.e. A1:E10) | ||||
| 	 * @param PHPExcel_Worksheet $pSheet | ||||
|      */ | ||||
|     public function __construct($pRange = '', PHPExcel_Worksheet $pSheet = NULL) | ||||
|     { | ||||
| 		$this->_range = $pRange; | ||||
| 		$this->_workSheet = $pSheet; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get AutoFilter Parent Worksheet | ||||
| 	 * | ||||
| 	 * @return PHPExcel_Worksheet | ||||
| 	 */ | ||||
| 	public function getParent() { | ||||
| 		return $this->_workSheet; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set AutoFilter Parent Worksheet | ||||
| 	 * | ||||
| 	 * @param PHPExcel_Worksheet $pSheet | ||||
| 	 * @return PHPExcel_Worksheet_AutoFilter | ||||
| 	 */ | ||||
| 	public function setParent(PHPExcel_Worksheet $pSheet = NULL) { | ||||
| 		$this->_workSheet = $pSheet; | ||||
|  | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get AutoFilter Range | ||||
| 	 * | ||||
| 	 * @return string | ||||
| 	 */ | ||||
| 	public function getRange() { | ||||
| 		return $this->_range; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Set AutoFilter Range | ||||
| 	 * | ||||
| 	 *	@param	string		$pRange		Cell range (i.e. A1:E10) | ||||
| 	 *	@throws	PHPExcel_Exception | ||||
| 	 *	@return PHPExcel_Worksheet_AutoFilter | ||||
| 	 */ | ||||
| 	public function setRange($pRange = '') { | ||||
| 		// Uppercase coordinate | ||||
| 		$cellAddress = explode('!',strtoupper($pRange)); | ||||
| 		if (count($cellAddress) > 1) { | ||||
| 			list($worksheet,$pRange) = $cellAddress; | ||||
| 		} | ||||
|  | ||||
| 		if (strpos($pRange,':') !== FALSE) { | ||||
| 			$this->_range = $pRange; | ||||
| 		} elseif(empty($pRange)) { | ||||
| 			$this->_range = ''; | ||||
| 		} else { | ||||
| 			throw new PHPExcel_Exception('Autofilter must be set on a range of cells.'); | ||||
| 		} | ||||
|  | ||||
| 		if (empty($pRange)) { | ||||
| 			//	Discard all column rules | ||||
| 			$this->_columns = array(); | ||||
| 		} else { | ||||
| 			//	Discard any column rules that are no longer valid within this range | ||||
| 			list($rangeStart,$rangeEnd) = PHPExcel_Cell::rangeBoundaries($this->_range); | ||||
| 			foreach($this->_columns as $key => $value) { | ||||
| 				$colIndex = PHPExcel_Cell::columnIndexFromString($key); | ||||
| 				if (($rangeStart[0] > $colIndex) || ($rangeEnd[0] < $colIndex)) { | ||||
| 					unset($this->_columns[$key]); | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get all AutoFilter Columns | ||||
| 	 * | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 * @return array of PHPExcel_Worksheet_AutoFilter_Column | ||||
| 	 */ | ||||
| 	public function getColumns() { | ||||
| 		return $this->_columns; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Validate that the specified column is in the AutoFilter range | ||||
| 	 * | ||||
| 	 * @param	string	$column			Column name (e.g. A) | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 * @return	integer	The column offset within the autofilter range | ||||
| 	 */ | ||||
| 	public function testColumnInRange($column) { | ||||
| 		if (empty($this->_range)) { | ||||
| 			throw new PHPExcel_Exception("No autofilter range is defined."); | ||||
| 		} | ||||
|  | ||||
| 		$columnIndex = PHPExcel_Cell::columnIndexFromString($column); | ||||
| 		list($rangeStart,$rangeEnd) = PHPExcel_Cell::rangeBoundaries($this->_range); | ||||
| 		if (($rangeStart[0] > $columnIndex) || ($rangeEnd[0] < $columnIndex)) { | ||||
| 			throw new PHPExcel_Exception("Column is outside of current autofilter range."); | ||||
| 		} | ||||
|  | ||||
| 		return $columnIndex - $rangeStart[0]; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get a specified AutoFilter Column Offset within the defined AutoFilter range | ||||
| 	 * | ||||
| 	 * @param	string	$pColumn		Column name (e.g. A) | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 * @return integer	The offset of the specified column within the autofilter range | ||||
| 	 */ | ||||
| 	public function getColumnOffset($pColumn) { | ||||
| 		return $this->testColumnInRange($pColumn); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get a specified AutoFilter Column | ||||
| 	 * | ||||
| 	 * @param	string	$pColumn		Column name (e.g. A) | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 * @return PHPExcel_Worksheet_AutoFilter_Column | ||||
| 	 */ | ||||
| 	public function getColumn($pColumn) { | ||||
| 		$this->testColumnInRange($pColumn); | ||||
|  | ||||
| 		if (!isset($this->_columns[$pColumn])) { | ||||
| 			$this->_columns[$pColumn] = new PHPExcel_Worksheet_AutoFilter_Column($pColumn, $this); | ||||
| 		} | ||||
|  | ||||
| 		return $this->_columns[$pColumn]; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get a specified AutoFilter Column by it's offset | ||||
| 	 * | ||||
| 	 * @param	integer	$pColumnOffset		Column offset within range (starting from 0) | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 * @return PHPExcel_Worksheet_AutoFilter_Column | ||||
| 	 */ | ||||
| 	public function getColumnByOffset($pColumnOffset = 0) { | ||||
| 		list($rangeStart,$rangeEnd) = PHPExcel_Cell::rangeBoundaries($this->_range); | ||||
| 		$pColumn = PHPExcel_Cell::stringFromColumnIndex($rangeStart[0] + $pColumnOffset - 1); | ||||
|  | ||||
| 		return $this->getColumn($pColumn); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Set AutoFilter | ||||
| 	 * | ||||
| 	 *	@param	PHPExcel_Worksheet_AutoFilter_Column|string		$pColumn | ||||
| 	 *			A simple string containing a Column ID like 'A' is permitted | ||||
| 	 *	@throws	PHPExcel_Exception | ||||
| 	 *	@return PHPExcel_Worksheet_AutoFilter | ||||
| 	 */ | ||||
| 	public function setColumn($pColumn) | ||||
| 	{ | ||||
| 		if ((is_string($pColumn)) && (!empty($pColumn))) { | ||||
| 			$column = $pColumn; | ||||
| 		} elseif(is_object($pColumn) && ($pColumn instanceof PHPExcel_Worksheet_AutoFilter_Column)) { | ||||
| 			$column = $pColumn->getColumnIndex(); | ||||
| 		} else { | ||||
| 			throw new PHPExcel_Exception("Column is not within the autofilter range."); | ||||
| 		} | ||||
| 		$this->testColumnInRange($column); | ||||
|  | ||||
| 		if (is_string($pColumn)) { | ||||
| 			$this->_columns[$pColumn] = new PHPExcel_Worksheet_AutoFilter_Column($pColumn, $this); | ||||
| 		} elseif(is_object($pColumn) && ($pColumn instanceof PHPExcel_Worksheet_AutoFilter_Column)) { | ||||
| 			$pColumn->setParent($this); | ||||
| 			$this->_columns[$column] = $pColumn; | ||||
| 		} | ||||
| 		ksort($this->_columns); | ||||
|  | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Clear a specified AutoFilter Column | ||||
| 	 * | ||||
| 	 * @param	string  $pColumn    Column name (e.g. A) | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 * @return PHPExcel_Worksheet_AutoFilter | ||||
| 	 */ | ||||
| 	public function clearColumn($pColumn) { | ||||
| 		$this->testColumnInRange($pColumn); | ||||
|  | ||||
| 		if (isset($this->_columns[$pColumn])) { | ||||
| 			unset($this->_columns[$pColumn]); | ||||
| 		} | ||||
|  | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Shift an AutoFilter Column Rule to a different column | ||||
| 	 * | ||||
| 	 *	Note: This method bypasses validation of the destination column to ensure it is within this AutoFilter range. | ||||
| 	 *		Nor does it verify whether any column rule already exists at $toColumn, but will simply overrideany existing value. | ||||
| 	 *		Use with caution. | ||||
| 	 * | ||||
| 	 *	@param	string	$fromColumn		Column name (e.g. A) | ||||
| 	 *	@param	string	$toColumn		Column name (e.g. B) | ||||
| 	 *	@return PHPExcel_Worksheet_AutoFilter | ||||
| 	 */ | ||||
| 	public function shiftColumn($fromColumn=NULL,$toColumn=NULL) { | ||||
| 		$fromColumn = strtoupper($fromColumn); | ||||
| 		$toColumn = strtoupper($toColumn); | ||||
|  | ||||
| 		if (($fromColumn !== NULL) && (isset($this->_columns[$fromColumn])) && ($toColumn !== NULL)) { | ||||
| 			$this->_columns[$fromColumn]->setParent(); | ||||
| 			$this->_columns[$fromColumn]->setColumnIndex($toColumn); | ||||
| 			$this->_columns[$toColumn] = $this->_columns[$fromColumn]; | ||||
| 			$this->_columns[$toColumn]->setParent($this); | ||||
| 			unset($this->_columns[$fromColumn]); | ||||
|  | ||||
| 			ksort($this->_columns); | ||||
| 		} | ||||
|  | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 *	Test if cell value is in the defined set of values | ||||
| 	 * | ||||
| 	 *	@param	mixed		$cellValue | ||||
| 	 *	@param	mixed[]		$dataSet | ||||
| 	 *	@return boolean | ||||
| 	 */ | ||||
| 	private static function _filterTestInSimpleDataSet($cellValue,$dataSet) | ||||
| 	{ | ||||
| 		$dataSetValues = $dataSet['filterValues']; | ||||
| 		$blanks = $dataSet['blanks']; | ||||
| 		if (($cellValue == '') || ($cellValue === NULL)) { | ||||
| 			return $blanks; | ||||
| 		} | ||||
| 		return in_array($cellValue,$dataSetValues); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Test if cell value is in the defined set of Excel date values | ||||
| 	 * | ||||
| 	 *	@param	mixed		$cellValue | ||||
| 	 *	@param	mixed[]		$dataSet | ||||
| 	 *	@return boolean | ||||
| 	 */ | ||||
| 	private static function _filterTestInDateGroupSet($cellValue,$dataSet) | ||||
| 	{ | ||||
| 		$dateSet = $dataSet['filterValues']; | ||||
| 		$blanks = $dataSet['blanks']; | ||||
| 		if (($cellValue == '') || ($cellValue === NULL)) { | ||||
| 			return $blanks; | ||||
| 		} | ||||
|  | ||||
| 		if (is_numeric($cellValue)) { | ||||
| 			$dateValue = PHPExcel_Shared_Date::ExcelToPHP($cellValue); | ||||
| 			if ($cellValue < 1) { | ||||
| 				//	Just the time part | ||||
| 				$dtVal = date('His',$dateValue); | ||||
| 				$dateSet = $dateSet['time']; | ||||
| 			} elseif($cellValue == floor($cellValue)) { | ||||
| 				//	Just the date part | ||||
| 				$dtVal = date('Ymd',$dateValue); | ||||
| 				$dateSet = $dateSet['date']; | ||||
| 			} else { | ||||
| 				//	date and time parts | ||||
| 				$dtVal = date('YmdHis',$dateValue); | ||||
| 				$dateSet = $dateSet['dateTime']; | ||||
| 			} | ||||
| 			foreach($dateSet as $dateValue) { | ||||
| 				//	Use of substr to extract value at the appropriate group level | ||||
| 				if (substr($dtVal,0,strlen($dateValue)) == $dateValue) | ||||
| 					return TRUE; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Test if cell value is within a set of values defined by a ruleset | ||||
| 	 * | ||||
| 	 *	@param	mixed		$cellValue | ||||
| 	 *	@param	mixed[]		$ruleSet | ||||
| 	 *	@return boolean | ||||
| 	 */ | ||||
| 	private static function _filterTestInCustomDataSet($cellValue, $ruleSet) | ||||
| 	{ | ||||
| 		$dataSet = $ruleSet['filterRules']; | ||||
| 		$join = $ruleSet['join']; | ||||
| 		$customRuleForBlanks = isset($ruleSet['customRuleForBlanks']) ? $ruleSet['customRuleForBlanks'] : FALSE; | ||||
|  | ||||
| 		if (!$customRuleForBlanks) { | ||||
| 			//	Blank cells are always ignored, so return a FALSE | ||||
| 			if (($cellValue == '') || ($cellValue === NULL)) { | ||||
| 				return FALSE; | ||||
| 			} | ||||
| 		} | ||||
| 		$returnVal = ($join == PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_COLUMN_JOIN_AND); | ||||
| 		foreach($dataSet as $rule) { | ||||
| 			if (is_numeric($rule['value'])) { | ||||
| 				//	Numeric values are tested using the appropriate operator | ||||
| 				switch ($rule['operator']) { | ||||
| 					case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_EQUAL : | ||||
| 						$retVal	= ($cellValue == $rule['value']); | ||||
| 						break; | ||||
| 					case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_NOTEQUAL : | ||||
| 						$retVal	= ($cellValue != $rule['value']); | ||||
| 						break; | ||||
| 					case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_GREATERTHAN : | ||||
| 						$retVal	= ($cellValue > $rule['value']); | ||||
| 						break; | ||||
| 					case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_GREATERTHANOREQUAL : | ||||
| 						$retVal	= ($cellValue >= $rule['value']); | ||||
| 						break; | ||||
| 					case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_LESSTHAN : | ||||
| 						$retVal	= ($cellValue < $rule['value']); | ||||
| 						break; | ||||
| 					case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_LESSTHANOREQUAL : | ||||
| 						$retVal	= ($cellValue <= $rule['value']); | ||||
| 						break; | ||||
| 				} | ||||
| 			} elseif($rule['value'] == '') { | ||||
| 				switch ($rule['operator']) { | ||||
| 					case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_EQUAL : | ||||
| 						$retVal	= (($cellValue == '') || ($cellValue === NULL)); | ||||
| 						break; | ||||
| 					case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_NOTEQUAL : | ||||
| 						$retVal	= (($cellValue != '') && ($cellValue !== NULL)); | ||||
| 						break; | ||||
| 					default : | ||||
| 						$retVal	= TRUE; | ||||
| 						break; | ||||
| 				} | ||||
| 			} else { | ||||
| 				//	String values are always tested for equality, factoring in for wildcards (hence a regexp test) | ||||
| 				$retVal	= preg_match('/^'.$rule['value'].'$/i',$cellValue); | ||||
| 			} | ||||
| 			//	If there are multiple conditions, then we need to test both using the appropriate join operator | ||||
| 			switch ($join) { | ||||
| 				case PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_COLUMN_JOIN_OR : | ||||
| 					$returnVal = $returnVal || $retVal; | ||||
| 					//	Break as soon as we have a TRUE match for OR joins, | ||||
| 					//		to avoid unnecessary additional code execution | ||||
| 					if ($returnVal) | ||||
| 						return $returnVal; | ||||
| 					break; | ||||
| 				case PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_COLUMN_JOIN_AND : | ||||
| 					$returnVal = $returnVal && $retVal; | ||||
| 					break; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return $returnVal; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Test if cell date value is matches a set of values defined by a set of months | ||||
| 	 * | ||||
| 	 *	@param	mixed		$cellValue | ||||
| 	 *	@param	mixed[]		$monthSet | ||||
| 	 *	@return boolean | ||||
| 	 */ | ||||
| 	private static function _filterTestInPeriodDateSet($cellValue, $monthSet) | ||||
| 	{ | ||||
| 		//	Blank cells are always ignored, so return a FALSE | ||||
| 		if (($cellValue == '') || ($cellValue === NULL)) { | ||||
| 			return FALSE; | ||||
| 		} | ||||
|  | ||||
| 		if (is_numeric($cellValue)) { | ||||
| 			$dateValue = date('m',PHPExcel_Shared_Date::ExcelToPHP($cellValue)); | ||||
| 			if (in_array($dateValue,$monthSet)) { | ||||
| 				return TRUE; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return FALSE; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Search/Replace arrays to convert Excel wildcard syntax to a regexp syntax for preg_matching | ||||
| 	 * | ||||
| 	 *	@var	array | ||||
| 	 */ | ||||
| 	private static $_fromReplace = array('\*', '\?', '~~', '~.*', '~.?'); | ||||
| 	private static $_toReplace   = array('.*', '.',  '~',  '\*',  '\?'); | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 *	Convert a dynamic rule daterange to a custom filter range expression for ease of calculation | ||||
| 	 * | ||||
| 	 *	@param	string										$dynamicRuleType | ||||
| 	 *	@param	PHPExcel_Worksheet_AutoFilter_Column		&$filterColumn | ||||
| 	 *	@return mixed[] | ||||
| 	 */ | ||||
| 	private function _dynamicFilterDateRange($dynamicRuleType, &$filterColumn) | ||||
| 	{ | ||||
| 		$rDateType = PHPExcel_Calculation_Functions::getReturnDateType(); | ||||
| 		PHPExcel_Calculation_Functions::setReturnDateType(PHPExcel_Calculation_Functions::RETURNDATE_PHP_NUMERIC); | ||||
| 		$val = $maxVal = NULL; | ||||
|  | ||||
| 		$ruleValues = array(); | ||||
| 		$baseDate = PHPExcel_Calculation_DateTime::DATENOW(); | ||||
| 		//	Calculate start/end dates for the required date range based on current date | ||||
| 		switch ($dynamicRuleType) { | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_LASTWEEK : | ||||
| 				$baseDate = strtotime('-7 days',$baseDate); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_NEXTWEEK : | ||||
| 				$baseDate = strtotime('-7 days',$baseDate); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_LASTMONTH : | ||||
| 				$baseDate = strtotime('-1 month',gmmktime(0,0,0,1,date('m',$baseDate),date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_NEXTMONTH : | ||||
| 				$baseDate = strtotime('+1 month',gmmktime(0,0,0,1,date('m',$baseDate),date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_LASTQUARTER : | ||||
| 				$baseDate = strtotime('-3 month',gmmktime(0,0,0,1,date('m',$baseDate),date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_NEXTQUARTER : | ||||
| 				$baseDate = strtotime('+3 month',gmmktime(0,0,0,1,date('m',$baseDate),date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_LASTYEAR : | ||||
| 				$baseDate = strtotime('-1 year',gmmktime(0,0,0,1,date('m',$baseDate),date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_NEXTYEAR : | ||||
| 				$baseDate = strtotime('+1 year',gmmktime(0,0,0,1,date('m',$baseDate),date('Y',$baseDate))); | ||||
| 				break; | ||||
| 		} | ||||
|  | ||||
| 		switch ($dynamicRuleType) { | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_TODAY : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_YESTERDAY : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_TOMORROW : | ||||
| 				$maxVal = (int) PHPExcel_Shared_Date::PHPtoExcel(strtotime('+1 day',$baseDate)); | ||||
| 				$val = (int) PHPExcel_Shared_Date::PHPToExcel($baseDate); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_YEARTODATE : | ||||
| 				$maxVal = (int) PHPExcel_Shared_Date::PHPtoExcel(strtotime('+1 day',$baseDate)); | ||||
| 				$val = (int) PHPExcel_Shared_Date::PHPToExcel(gmmktime(0,0,0,1,1,date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_THISYEAR : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_LASTYEAR : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_NEXTYEAR : | ||||
| 				$maxVal = (int) PHPExcel_Shared_Date::PHPToExcel(gmmktime(0,0,0,31,12,date('Y',$baseDate))); | ||||
| 				++$maxVal; | ||||
| 				$val = (int) PHPExcel_Shared_Date::PHPToExcel(gmmktime(0,0,0,1,1,date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_THISQUARTER : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_LASTQUARTER : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_NEXTQUARTER : | ||||
| 				$thisMonth = date('m',$baseDate); | ||||
| 				$thisQuarter = floor(--$thisMonth / 3); | ||||
| 				$maxVal = (int) PHPExcel_Shared_Date::PHPtoExcel(gmmktime(0,0,0,date('t',$baseDate),(1+$thisQuarter)*3,date('Y',$baseDate))); | ||||
| 				++$maxVal; | ||||
| 				$val = (int) PHPExcel_Shared_Date::PHPToExcel(gmmktime(0,0,0,1,1+$thisQuarter*3,date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_THISMONTH : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_LASTMONTH : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_NEXTMONTH : | ||||
| 				$maxVal = (int) PHPExcel_Shared_Date::PHPtoExcel(gmmktime(0,0,0,date('t',$baseDate),date('m',$baseDate),date('Y',$baseDate))); | ||||
| 				++$maxVal; | ||||
| 				$val = (int) PHPExcel_Shared_Date::PHPToExcel(gmmktime(0,0,0,1,date('m',$baseDate),date('Y',$baseDate))); | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_THISWEEK : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_LASTWEEK : | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_NEXTWEEK : | ||||
| 				$dayOfWeek = date('w',$baseDate); | ||||
| 				$val = (int) PHPExcel_Shared_Date::PHPToExcel($baseDate) - $dayOfWeek; | ||||
| 				$maxVal = $val + 7; | ||||
| 				break; | ||||
| 		} | ||||
|  | ||||
| 		switch ($dynamicRuleType) { | ||||
| 			//	Adjust Today dates for Yesterday and Tomorrow | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_YESTERDAY : | ||||
| 				--$maxVal; | ||||
| 				--$val; | ||||
| 				break; | ||||
| 			case PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_TOMORROW : | ||||
| 				++$maxVal; | ||||
| 				++$val; | ||||
| 				break; | ||||
| 		} | ||||
|  | ||||
| 		//	Set the filter column rule attributes ready for writing | ||||
| 		$filterColumn->setAttributes(array(	'val' => $val, | ||||
| 											'maxVal' => $maxVal | ||||
| 										  ) | ||||
| 									); | ||||
|  | ||||
| 		//	Set the rules for identifying rows for hide/show | ||||
| 		$ruleValues[] = array( 'operator' => PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_GREATERTHANOREQUAL, | ||||
| 							   'value' => $val | ||||
| 							 ); | ||||
| 		$ruleValues[] = array( 'operator' => PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_LESSTHAN, | ||||
| 							   'value' => $maxVal | ||||
| 							 ); | ||||
| 		PHPExcel_Calculation_Functions::setReturnDateType($rDateType); | ||||
|  | ||||
| 		return array( | ||||
| 			'method' => '_filterTestInCustomDataSet', | ||||
| 			'arguments' => array( 'filterRules' => $ruleValues, | ||||
| 								  'join' => PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_COLUMN_JOIN_AND | ||||
| 								) | ||||
| 		); | ||||
| 	} | ||||
|  | ||||
| 	private function _calculateTopTenValue($columnID,$startRow,$endRow,$ruleType,$ruleValue) { | ||||
| 		$range = $columnID.$startRow.':'.$columnID.$endRow; | ||||
| 		$dataValues = PHPExcel_Calculation_Functions::flattenArray( | ||||
| 			$this->_workSheet->rangeToArray($range,NULL,TRUE,FALSE) | ||||
| 		); | ||||
|  | ||||
| 		$dataValues = array_filter($dataValues); | ||||
| 		if ($ruleType == PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_TOPTEN_TOP) { | ||||
| 			rsort($dataValues); | ||||
| 		} else { | ||||
| 			sort($dataValues); | ||||
| 		} | ||||
|  | ||||
| 		return array_pop(array_slice($dataValues,0,$ruleValue)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Apply the AutoFilter rules to the AutoFilter Range | ||||
| 	 * | ||||
| 	 *	@throws	PHPExcel_Exception | ||||
| 	 *	@return PHPExcel_Worksheet_AutoFilter | ||||
| 	 */ | ||||
| 	public function showHideRows() | ||||
| 	{ | ||||
| 		list($rangeStart,$rangeEnd) = PHPExcel_Cell::rangeBoundaries($this->_range); | ||||
|  | ||||
| 		//	The heading row should always be visible | ||||
| //		echo 'AutoFilter Heading Row ',$rangeStart[1],' is always SHOWN',PHP_EOL; | ||||
| 		$this->_workSheet->getRowDimension($rangeStart[1])->setVisible(TRUE); | ||||
|  | ||||
| 		$columnFilterTests = array(); | ||||
| 		foreach($this->_columns as $columnID => $filterColumn) { | ||||
| 			$rules = $filterColumn->getRules(); | ||||
| 			switch ($filterColumn->getFilterType()) { | ||||
| 				case PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_FILTERTYPE_FILTER : | ||||
| 					$ruleValues = array(); | ||||
| 					//	Build a list of the filter value selections | ||||
| 					foreach($rules as $rule) { | ||||
| 						$ruleType = $rule->getRuleType(); | ||||
| 						$ruleValues[] = $rule->getValue(); | ||||
| 					} | ||||
| 					//	Test if we want to include blanks in our filter criteria | ||||
| 					$blanks = FALSE; | ||||
| 					$ruleDataSet = array_filter($ruleValues); | ||||
| 					if (count($ruleValues) != count($ruleDataSet)) | ||||
| 						$blanks = TRUE; | ||||
| 					if ($ruleType == PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_FILTER) { | ||||
| 						//	Filter on absolute values | ||||
| 						$columnFilterTests[$columnID] = array( | ||||
| 							'method' => '_filterTestInSimpleDataSet', | ||||
| 							'arguments' => array( 'filterValues' => $ruleDataSet, | ||||
| 												  'blanks' => $blanks | ||||
| 												) | ||||
| 						); | ||||
| 					} else { | ||||
| 						//	Filter on date group values | ||||
| 						$arguments = array( | ||||
|                             'date' => array(), | ||||
|                             'time' => array(), | ||||
|                             'dateTime' => array(), | ||||
|                         ); | ||||
| 						foreach($ruleDataSet as $ruleValue) { | ||||
| 							$date = $time = ''; | ||||
| 							if ((isset($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_YEAR])) && | ||||
| 								($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_YEAR] !== '')) | ||||
| 								$date .= sprintf('%04d',$ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_YEAR]); | ||||
| 							if ((isset($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_MONTH])) && | ||||
| 								($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_MONTH] != '')) | ||||
| 								$date .= sprintf('%02d',$ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_MONTH]); | ||||
| 							if ((isset($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_DAY])) && | ||||
| 								($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_DAY] !== '')) | ||||
| 								$date .= sprintf('%02d',$ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_DAY]); | ||||
| 							if ((isset($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_HOUR])) && | ||||
| 								($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_HOUR] !== '')) | ||||
| 								$time .= sprintf('%02d',$ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_HOUR]); | ||||
| 							if ((isset($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_MINUTE])) && | ||||
| 								($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_MINUTE] !== '')) | ||||
| 								$time .= sprintf('%02d',$ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_MINUTE]); | ||||
| 							if ((isset($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_SECOND])) && | ||||
| 								($ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_SECOND] !== '')) | ||||
| 								$time .= sprintf('%02d',$ruleValue[PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DATEGROUP_SECOND]); | ||||
| 							$dateTime = $date . $time; | ||||
| 							$arguments['date'][] = $date; | ||||
| 							$arguments['time'][] = $time; | ||||
| 							$arguments['dateTime'][] = $dateTime; | ||||
| 						} | ||||
| 						//	Remove empty elements | ||||
| 						$arguments['date'] = array_filter($arguments['date']); | ||||
| 						$arguments['time'] = array_filter($arguments['time']); | ||||
| 						$arguments['dateTime'] = array_filter($arguments['dateTime']); | ||||
| 						$columnFilterTests[$columnID] = array( | ||||
| 							'method' => '_filterTestInDateGroupSet', | ||||
| 							'arguments' => array( 'filterValues' => $arguments, | ||||
| 												  'blanks' => $blanks | ||||
| 												) | ||||
| 						); | ||||
| 					} | ||||
| 					break; | ||||
| 				case PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_FILTERTYPE_CUSTOMFILTER : | ||||
| 					$customRuleForBlanks = FALSE; | ||||
| 					$ruleValues = array(); | ||||
| 					//	Build a list of the filter value selections | ||||
| 					foreach($rules as $rule) { | ||||
| 						$ruleType = $rule->getRuleType(); | ||||
| 						$ruleValue = $rule->getValue(); | ||||
| 						if (!is_numeric($ruleValue)) { | ||||
| 							//	Convert to a regexp allowing for regexp reserved characters, wildcards and escaped wildcards | ||||
| 							$ruleValue = preg_quote($ruleValue); | ||||
| 							$ruleValue = str_replace(self::$_fromReplace,self::$_toReplace,$ruleValue); | ||||
| 							if (trim($ruleValue) == '') { | ||||
| 								$customRuleForBlanks = TRUE; | ||||
| 								$ruleValue = trim($ruleValue); | ||||
| 							} | ||||
| 						} | ||||
| 						$ruleValues[] = array( 'operator' => $rule->getOperator(), | ||||
| 											   'value' => $ruleValue | ||||
| 											 ); | ||||
| 					} | ||||
| 					$join = $filterColumn->getJoin(); | ||||
| 					$columnFilterTests[$columnID] = array( | ||||
| 						'method' => '_filterTestInCustomDataSet', | ||||
| 						'arguments' => array( 'filterRules' => $ruleValues, | ||||
| 											  'join' => $join, | ||||
| 											  'customRuleForBlanks' => $customRuleForBlanks | ||||
| 											) | ||||
| 					); | ||||
| 					break; | ||||
| 				case PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_FILTERTYPE_DYNAMICFILTER : | ||||
| 					$ruleValues = array(); | ||||
| 					foreach($rules as $rule) { | ||||
| 						//	We should only ever have one Dynamic Filter Rule anyway | ||||
| 						$dynamicRuleType = $rule->getGrouping(); | ||||
| 						if (($dynamicRuleType == PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_ABOVEAVERAGE) || | ||||
| 							($dynamicRuleType == PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_BELOWAVERAGE)) { | ||||
| 							//	Number (Average) based | ||||
| 							//	Calculate the average | ||||
| 							$averageFormula = '=AVERAGE('.$columnID.($rangeStart[1]+1).':'.$columnID.$rangeEnd[1].')'; | ||||
| 							$average = PHPExcel_Calculation::getInstance()->calculateFormula($averageFormula,NULL,$this->_workSheet->getCell('A1')); | ||||
| 							//	Set above/below rule based on greaterThan or LessTan | ||||
| 							$operator = ($dynamicRuleType === PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_RULETYPE_DYNAMIC_ABOVEAVERAGE) | ||||
| 								? PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_GREATERTHAN | ||||
| 								: PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_LESSTHAN; | ||||
| 							$ruleValues[] = array( 'operator' => $operator, | ||||
| 												   'value' => $average | ||||
| 												 ); | ||||
| 							$columnFilterTests[$columnID] = array( | ||||
| 								'method' => '_filterTestInCustomDataSet', | ||||
| 								'arguments' => array( 'filterRules' => $ruleValues, | ||||
| 													  'join' => PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_COLUMN_JOIN_OR | ||||
| 													) | ||||
| 							); | ||||
| 						} else { | ||||
| 							//	Date based | ||||
| 							if ($dynamicRuleType{0} == 'M' || $dynamicRuleType{0} == 'Q') { | ||||
| 								//	Month or Quarter | ||||
| 								sscanf($dynamicRuleType,'%[A-Z]%d', $periodType, $period); | ||||
| 								if ($periodType == 'M') { | ||||
| 									$ruleValues = array($period); | ||||
| 								} else { | ||||
| 									--$period; | ||||
| 									$periodEnd = (1+$period)*3; | ||||
| 									$periodStart = 1+$period*3; | ||||
| 									$ruleValues = range($periodStart,periodEnd); | ||||
| 								} | ||||
| 								$columnFilterTests[$columnID] = array( | ||||
| 									'method' => '_filterTestInPeriodDateSet', | ||||
| 									'arguments' => $ruleValues | ||||
| 								); | ||||
| 								$filterColumn->setAttributes(array()); | ||||
| 							} else { | ||||
| 								//	Date Range | ||||
| 								$columnFilterTests[$columnID] = $this->_dynamicFilterDateRange($dynamicRuleType, $filterColumn); | ||||
| 								break; | ||||
| 							} | ||||
| 						} | ||||
| 					} | ||||
| 					break; | ||||
| 				case PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_FILTERTYPE_TOPTENFILTER : | ||||
| 					$ruleValues = array(); | ||||
| 					$dataRowCount = $rangeEnd[1] - $rangeStart[1]; | ||||
| 					foreach($rules as $rule) { | ||||
| 						//	We should only ever have one Dynamic Filter Rule anyway | ||||
| 						$toptenRuleType = $rule->getGrouping(); | ||||
| 						$ruleValue = $rule->getValue(); | ||||
| 						$ruleOperator = $rule->getOperator(); | ||||
| 					} | ||||
| 					if ($ruleOperator === PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_TOPTEN_PERCENT) { | ||||
| 						$ruleValue = floor($ruleValue * ($dataRowCount / 100)); | ||||
| 					} | ||||
| 					if ($ruleValue < 1) $ruleValue = 1; | ||||
| 					if ($ruleValue > 500) $ruleValue = 500; | ||||
|  | ||||
| 					$maxVal = $this->_calculateTopTenValue($columnID,$rangeStart[1]+1,$rangeEnd[1],$toptenRuleType,$ruleValue); | ||||
|  | ||||
| 					$operator = ($toptenRuleType == PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_TOPTEN_TOP) | ||||
| 						? PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_GREATERTHANOREQUAL | ||||
| 						: PHPExcel_Worksheet_AutoFilter_Column_Rule::AUTOFILTER_COLUMN_RULE_LESSTHANOREQUAL; | ||||
| 					$ruleValues[] = array( 'operator' => $operator, | ||||
| 										   'value' => $maxVal | ||||
| 										 ); | ||||
| 					$columnFilterTests[$columnID] = array( | ||||
| 						'method' => '_filterTestInCustomDataSet', | ||||
| 						'arguments' => array( 'filterRules' => $ruleValues, | ||||
| 											  'join' => PHPExcel_Worksheet_AutoFilter_Column::AUTOFILTER_COLUMN_JOIN_OR | ||||
| 											) | ||||
| 					); | ||||
| 					$filterColumn->setAttributes( | ||||
| 						array('maxVal' => $maxVal) | ||||
| 					); | ||||
| 					break; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| //		echo 'Column Filter Test CRITERIA',PHP_EOL; | ||||
| //		var_dump($columnFilterTests); | ||||
| // | ||||
| 		//	Execute the column tests for each row in the autoFilter range to determine show/hide, | ||||
| 		for ($row = $rangeStart[1]+1; $row <= $rangeEnd[1]; ++$row) { | ||||
| //			echo 'Testing Row = ',$row,PHP_EOL; | ||||
| 			$result = TRUE; | ||||
| 			foreach($columnFilterTests as $columnID => $columnFilterTest) { | ||||
| //				echo 'Testing cell ',$columnID.$row,PHP_EOL; | ||||
| 				$cellValue = $this->_workSheet->getCell($columnID.$row)->getCalculatedValue(); | ||||
| //				echo 'Value is ',$cellValue,PHP_EOL; | ||||
| 				//	Execute the filter test | ||||
| 				$result = $result && | ||||
| 					call_user_func_array( | ||||
| 						array('PHPExcel_Worksheet_AutoFilter',$columnFilterTest['method']), | ||||
| 						array( | ||||
| 							$cellValue, | ||||
| 							$columnFilterTest['arguments'] | ||||
| 						) | ||||
| 					); | ||||
| //				echo (($result) ? 'VALID' : 'INVALID'),PHP_EOL; | ||||
| 				//	If filter test has resulted in FALSE, exit the loop straightaway rather than running any more tests | ||||
| 				if (!$result) | ||||
| 					break; | ||||
| 			} | ||||
| 			//	Set show/hide for the row based on the result of the autoFilter result | ||||
| //			echo (($result) ? 'SHOW' : 'HIDE'),PHP_EOL; | ||||
| 			$this->_workSheet->getRowDimension($row)->setVisible($result); | ||||
| 		} | ||||
|  | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * 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)) { | ||||
| 				if ($key == '_workSheet') { | ||||
| 					//	Detach from worksheet | ||||
| 					$this->{$key} = NULL; | ||||
| 				} else { | ||||
| 					$this->{$key} = clone $value; | ||||
| 				} | ||||
| 			} elseif ((is_array($value)) && ($key == '_columns')) { | ||||
| 				//	The columns array of PHPExcel_Worksheet_AutoFilter objects | ||||
| 				$this->{$key} = array(); | ||||
| 				foreach ($value as $k => $v) { | ||||
| 					$this->{$key}[$k] = clone $v; | ||||
| 					// attach the new cloned Column to this new cloned Autofilter object | ||||
| 					$this->{$key}[$k]->setParent($this); | ||||
| 				} | ||||
| 			} else { | ||||
| 				$this->{$key} = $value; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * toString method replicates previous behavior by returning the range if object is | ||||
| 	 *    referenced as a property of its parent. | ||||
| 	 */ | ||||
| 	public function __toString() { | ||||
| 		return (string) $this->_range; | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										489
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/BaseDrawing.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										489
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/BaseDrawing.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,489 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_BaseDrawing | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_BaseDrawing implements PHPExcel_IComparable | ||||
| { | ||||
| 	/** | ||||
| 	 * Image counter | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private static $_imageCounter = 0; | ||||
|  | ||||
| 	/** | ||||
| 	 * Image index | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_imageIndex = 0; | ||||
|  | ||||
| 	/** | ||||
| 	 * Name | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	protected $_name; | ||||
|  | ||||
| 	/** | ||||
| 	 * Description | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	protected $_description; | ||||
|  | ||||
| 	/** | ||||
| 	 * Worksheet | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet | ||||
| 	 */ | ||||
| 	protected $_worksheet; | ||||
|  | ||||
| 	/** | ||||
| 	 * Coordinates | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	protected $_coordinates; | ||||
|  | ||||
| 	/** | ||||
| 	 * Offset X | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_offsetX; | ||||
|  | ||||
| 	/** | ||||
| 	 * Offset Y | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_offsetY; | ||||
|  | ||||
| 	/** | ||||
| 	 * Width | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_width; | ||||
|  | ||||
| 	/** | ||||
| 	 * Height | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_height; | ||||
|  | ||||
| 	/** | ||||
| 	 * Proportional resize | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	protected $_resizeProportional; | ||||
|  | ||||
| 	/** | ||||
| 	 * Rotation | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_rotation; | ||||
|  | ||||
| 	/** | ||||
| 	 * Shadow | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet_Drawing_Shadow | ||||
| 	 */ | ||||
| 	protected $_shadow; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     	// Initialise values | ||||
|     	$this->_name				= ''; | ||||
|     	$this->_description			= ''; | ||||
|     	$this->_worksheet			= null; | ||||
|     	$this->_coordinates			= 'A1'; | ||||
|     	$this->_offsetX				= 0; | ||||
|     	$this->_offsetY				= 0; | ||||
|     	$this->_width				= 0; | ||||
|     	$this->_height				= 0; | ||||
|     	$this->_resizeProportional	= true; | ||||
|     	$this->_rotation			= 0; | ||||
|     	$this->_shadow				= new PHPExcel_Worksheet_Drawing_Shadow(); | ||||
|  | ||||
| 		// Set image index | ||||
| 		self::$_imageCounter++; | ||||
| 		$this->_imageIndex 			= self::$_imageCounter; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get image index | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getImageIndex() { | ||||
|     	return $this->_imageIndex; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Name | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getName() { | ||||
|     	return $this->_name; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Name | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setName($pValue = '') { | ||||
|     	$this->_name = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Description | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getDescription() { | ||||
|     	return $this->_description; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Description | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setDescription($pValue = '') { | ||||
|     	$this->_description = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Worksheet | ||||
|      * | ||||
|      * @return PHPExcel_Worksheet | ||||
|      */ | ||||
|     public function getWorksheet() { | ||||
|     	return $this->_worksheet; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Worksheet | ||||
|      * | ||||
|      * @param 	PHPExcel_Worksheet 	$pValue | ||||
|      * @param 	bool				$pOverrideOld	If a Worksheet has already been assigned, overwrite it and remove image from old Worksheet? | ||||
|      * @throws 	PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setWorksheet(PHPExcel_Worksheet $pValue = null, $pOverrideOld = false) { | ||||
|     	if (is_null($this->_worksheet)) { | ||||
|     		// Add drawing to PHPExcel_Worksheet | ||||
| 	    	$this->_worksheet = $pValue; | ||||
| 	    	$this->_worksheet->getCell($this->_coordinates); | ||||
| 	    	$this->_worksheet->getDrawingCollection()->append($this); | ||||
|     	} else { | ||||
|     		if ($pOverrideOld) { | ||||
|     			// Remove drawing from old PHPExcel_Worksheet | ||||
|     			$iterator = $this->_worksheet->getDrawingCollection()->getIterator(); | ||||
|  | ||||
|     			while ($iterator->valid()) { | ||||
|     				if ($iterator->current()->getHashCode() == $this->getHashCode()) { | ||||
|     					$this->_worksheet->getDrawingCollection()->offsetUnset( $iterator->key() ); | ||||
|     					$this->_worksheet = null; | ||||
|     					break; | ||||
|     				} | ||||
|     			} | ||||
|  | ||||
|     			// Set new PHPExcel_Worksheet | ||||
|     			$this->setWorksheet($pValue); | ||||
|     		} else { | ||||
|     			throw new PHPExcel_Exception("A PHPExcel_Worksheet has already been assigned. Drawings can only exist on one PHPExcel_Worksheet."); | ||||
|     		} | ||||
|     	} | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Coordinates | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getCoordinates() { | ||||
|     	return $this->_coordinates; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Coordinates | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setCoordinates($pValue = 'A1') { | ||||
|     	$this->_coordinates = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get OffsetX | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getOffsetX() { | ||||
|     	return $this->_offsetX; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set OffsetX | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setOffsetX($pValue = 0) { | ||||
|     	$this->_offsetX = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get OffsetY | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getOffsetY() { | ||||
|     	return $this->_offsetY; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set OffsetY | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setOffsetY($pValue = 0) { | ||||
|     	$this->_offsetY = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Width | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getWidth() { | ||||
|     	return $this->_width; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Width | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setWidth($pValue = 0) { | ||||
|     	// Resize proportional? | ||||
|     	if ($this->_resizeProportional && $pValue != 0) { | ||||
|     		$ratio = $this->_height / ($this->_width != 0 ? $this->_width : 1); | ||||
|     		$this->_height = round($ratio * $pValue); | ||||
|     	} | ||||
|  | ||||
|     	// Set width | ||||
|     	$this->_width = $pValue; | ||||
|  | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Height | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getHeight() { | ||||
|     	return $this->_height; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Height | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setHeight($pValue = 0) { | ||||
|     	// Resize proportional? | ||||
|     	if ($this->_resizeProportional && $pValue != 0) { | ||||
|     		$ratio = $this->_width / ($this->_height != 0 ? $this->_height : 1); | ||||
|     		$this->_width = round($ratio * $pValue); | ||||
|     	} | ||||
|  | ||||
|     	// Set height | ||||
|     	$this->_height = $pValue; | ||||
|  | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set width and height with proportional resize | ||||
| 	 * Example: | ||||
| 	 * <code> | ||||
| 	 * $objDrawing->setResizeProportional(true); | ||||
| 	 * $objDrawing->setWidthAndHeight(160,120); | ||||
| 	 * </code> | ||||
| 	 * | ||||
|      * @author Vincent@luo MSN:kele_100@hotmail.com | ||||
|      * @param int $width | ||||
|      * @param int $height | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
| 	public function setWidthAndHeight($width = 0, $height = 0) { | ||||
| 		$xratio = $width / ($this->_width != 0 ? $this->_width : 1); | ||||
| 		$yratio = $height / ($this->_height != 0 ? $this->_height : 1); | ||||
| 		if ($this->_resizeProportional && !($width == 0 || $height == 0)) { | ||||
| 			if (($xratio * $this->_height) < $height) { | ||||
| 				$this->_height = ceil($xratio * $this->_height); | ||||
| 				$this->_width  = $width; | ||||
| 			} else { | ||||
| 				$this->_width	= ceil($yratio * $this->_width); | ||||
| 				$this->_height	= $height; | ||||
| 			} | ||||
| 		} else { | ||||
|             $this->_width = $width; | ||||
|             $this->_height = $height; | ||||
|         } | ||||
|  | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
|     /** | ||||
|      * Get ResizeProportional | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     public function getResizeProportional() { | ||||
|     	return $this->_resizeProportional; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set ResizeProportional | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setResizeProportional($pValue = true) { | ||||
|     	$this->_resizeProportional = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Rotation | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getRotation() { | ||||
|     	return $this->_rotation; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Rotation | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setRotation($pValue = 0) { | ||||
|     	$this->_rotation = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Shadow | ||||
|      * | ||||
|      * @return PHPExcel_Worksheet_Drawing_Shadow | ||||
|      */ | ||||
|     public function getShadow() { | ||||
|     	return $this->_shadow; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Shadow | ||||
|      * | ||||
|      * @param 	PHPExcel_Worksheet_Drawing_Shadow $pValue | ||||
|      * @throws 	PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_BaseDrawing | ||||
|      */ | ||||
|     public function setShadow(PHPExcel_Worksheet_Drawing_Shadow $pValue = null) { | ||||
|    		$this->_shadow = $pValue; | ||||
|    		return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get hash code | ||||
| 	 * | ||||
| 	 * @return string	Hash code | ||||
| 	 */ | ||||
| 	public function getHashCode() { | ||||
|     	return md5( | ||||
|     		  $this->_name | ||||
|     		. $this->_description | ||||
|     		. $this->_worksheet->getHashCode() | ||||
|     		. $this->_coordinates | ||||
|     		. $this->_offsetX | ||||
|     		. $this->_offsetY | ||||
|     		. $this->_width | ||||
|     		. $this->_height | ||||
|     		. $this->_rotation | ||||
|     		. $this->_shadow->getHashCode() | ||||
|     		. __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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @@ -0,0 +1,95 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    1.8.0, 2014-03-02 | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_CellIterator | ||||
|  * | ||||
|  * Used to iterate rows in a PHPExcel_Worksheet | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| abstract class PHPExcel_Worksheet_CellIterator | ||||
| { | ||||
| 	/** | ||||
| 	 * PHPExcel_Worksheet to iterate | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet | ||||
| 	 */ | ||||
| 	protected $_subject; | ||||
|  | ||||
| 	/** | ||||
| 	 * Current iterator position | ||||
| 	 * | ||||
| 	 * @var mixed | ||||
| 	 */ | ||||
| 	protected $_position = null; | ||||
|  | ||||
| 	/** | ||||
| 	 * Iterate only existing cells | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	protected $_onlyExistingCells = false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Destructor | ||||
| 	 */ | ||||
| 	public function __destruct() { | ||||
| 		unset($this->_subject); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get loop only existing cells | ||||
| 	 * | ||||
| 	 * @return boolean | ||||
| 	 */ | ||||
|     public function getIterateOnlyExistingCells() { | ||||
|     	return $this->_onlyExistingCells; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Validate start/end values for "IterateOnlyExistingCells" mode, and adjust if necessary | ||||
| 	 * | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
|     abstract protected function adjustForExistingOnlyRange(); | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to loop only existing cells | ||||
| 	 * | ||||
| 	 * @param	boolean		$value | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
|     public function setIterateOnlyExistingCells($value = true) { | ||||
|     	$this->_onlyExistingCells = (boolean) $value; | ||||
|  | ||||
|         $this->adjustForExistingOnlyRange(); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										92
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/Column.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/Column.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_Column | ||||
|  * | ||||
|  * Represents a column in PHPExcel_Worksheet, used by PHPExcel_Worksheet_ColumnIterator | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_Column | ||||
| { | ||||
| 	/** | ||||
| 	 * PHPExcel_Worksheet | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet | ||||
| 	 */ | ||||
| 	private $_parent; | ||||
|  | ||||
| 	/** | ||||
| 	 * Column index | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_columnIndex; | ||||
|  | ||||
| 	/** | ||||
| 	 * Create a new column | ||||
| 	 * | ||||
| 	 * @param PHPExcel_Worksheet 	$parent | ||||
| 	 * @param string				$columnIndex | ||||
| 	 */ | ||||
| 	public function __construct(PHPExcel_Worksheet $parent = null, $columnIndex = 'A') { | ||||
| 		// Set parent and column index | ||||
| 		$this->_parent 		= $parent; | ||||
| 		$this->_columnIndex = $columnIndex; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Destructor | ||||
| 	 */ | ||||
| 	public function __destruct() { | ||||
| 		unset($this->_parent); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get column index | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
| 	public function getColumnIndex() { | ||||
| 		return $this->_columnIndex; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get cell iterator | ||||
| 	 * | ||||
| 	 * @param	integer				$startRow	    The row number at which to start iterating | ||||
| 	 * @param	integer				$endRow	        Optionally, the row number at which to stop iterating | ||||
| 	 * @return PHPExcel_Worksheet_CellIterator | ||||
| 	 */ | ||||
| 	public function getCellIterator($startRow = 1, $endRow = null) { | ||||
| 		return new PHPExcel_Worksheet_ColumnCellIterator($this->_parent, $this->_columnIndex, $startRow, $endRow); | ||||
| 	} | ||||
| } | ||||
| @@ -0,0 +1,215 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license	http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version	##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_ColumnCellIterator | ||||
|  * | ||||
|  * Used to iterate columns in a PHPExcel_Worksheet | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package	PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_ColumnCellIterator extends PHPExcel_Worksheet_CellIterator implements Iterator | ||||
| { | ||||
| 	/** | ||||
| 	 * Column index | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	protected $_columnIndex; | ||||
|  | ||||
|     /** | ||||
| 	 * Start position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_startRow = 1; | ||||
|  | ||||
| 	/** | ||||
| 	 * End position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_endRow = 1; | ||||
|  | ||||
| 	/** | ||||
| 	 * Create a new row iterator | ||||
| 	 * | ||||
| 	 * @param	PHPExcel_Worksheet	$subject	    The worksheet to iterate over | ||||
|      * @param   string              $columnIndex    The column that we want to iterate | ||||
| 	 * @param	integer				$startRow	    The row number at which to start iterating | ||||
| 	 * @param	integer				$endRow	        Optionally, the row number at which to stop iterating | ||||
| 	 */ | ||||
| 	public function __construct(PHPExcel_Worksheet $subject = null, $columnIndex, $startRow = 1, $endRow = null) { | ||||
| 		// Set subject | ||||
| 		$this->_subject = $subject; | ||||
| 		$this->_columnIndex = PHPExcel_Cell::columnIndexFromString($columnIndex) - 1; | ||||
| 		$this->resetEnd($endRow); | ||||
| 		$this->resetStart($startRow); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Destructor | ||||
| 	 */ | ||||
| 	public function __destruct() { | ||||
| 		unset($this->_subject); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * (Re)Set the start row and the current row pointer | ||||
| 	 * | ||||
| 	 * @param integer	$startRow	The row number at which to start iterating | ||||
|      * @return PHPExcel_Worksheet_ColumnCellIterator | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function resetStart($startRow = 1) { | ||||
| 		$this->_startRow = $startRow; | ||||
|         $this->adjustForExistingOnlyRange(); | ||||
| 		$this->seek($startRow); | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * (Re)Set the end row | ||||
| 	 * | ||||
| 	 * @param integer	$endRow	The row number at which to stop iterating | ||||
|      * @return PHPExcel_Worksheet_ColumnCellIterator | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function resetEnd($endRow = null) { | ||||
| 		$this->_endRow = ($endRow) ? $endRow : $this->_subject->getHighestRow(); | ||||
|         $this->adjustForExistingOnlyRange(); | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the row pointer to the selected row | ||||
| 	 * | ||||
| 	 * @param integer	$row	The row number to set the current pointer at | ||||
|      * @return PHPExcel_Worksheet_ColumnCellIterator | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function seek($row = 1) { | ||||
|         if (($row < $this->_startRow) || ($row > $this->_endRow)) { | ||||
|             throw new PHPExcel_Exception("Row $row is out of range ({$this->_startRow} - {$this->_endRow})"); | ||||
|         } elseif ($this->_onlyExistingCells && !($this->_subject->cellExistsByColumnAndRow($this->_columnIndex, $row))) { | ||||
|             throw new PHPExcel_Exception('In "IterateOnlyExistingCells" mode and Cell does not exist'); | ||||
|         } | ||||
| 		$this->_position = $row; | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Rewind the iterator to the starting row | ||||
| 	 */ | ||||
| 	public function rewind() { | ||||
| 		$this->_position = $this->_startRow; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Return the current cell in this worksheet column | ||||
| 	 * | ||||
| 	 * @return PHPExcel_Worksheet_Row | ||||
| 	 */ | ||||
| 	public function current() { | ||||
| 		return $this->_subject->getCellByColumnAndRow($this->_columnIndex, $this->_position); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Return the current iterator key | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
| 	public function key() { | ||||
| 		return $this->_position; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to its next value | ||||
| 	 */ | ||||
| 	public function next() { | ||||
|         do { | ||||
|             ++$this->_position; | ||||
|         } while (($this->_onlyExistingCells) && | ||||
|             (!$this->_subject->cellExistsByColumnAndRow($this->_columnIndex, $this->_position)) && | ||||
|             ($this->_position <= $this->_endRow)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to its previous value | ||||
| 	 */ | ||||
| 	public function prev() { | ||||
|         if ($this->_position <= $this->_startRow) { | ||||
|             throw new PHPExcel_Exception("Row is already at the beginning of range ({$this->_startRow} - {$this->_endRow})"); | ||||
|         } | ||||
|  | ||||
|         do { | ||||
|             --$this->_position; | ||||
|         } while (($this->_onlyExistingCells) && | ||||
|             (!$this->_subject->cellExistsByColumnAndRow($this->_columnIndex, $this->_position)) && | ||||
|             ($this->_position >= $this->_startRow)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Indicate if more rows exist in the worksheet range of rows that we're iterating | ||||
| 	 * | ||||
| 	 * @return boolean | ||||
| 	 */ | ||||
| 	public function valid() { | ||||
| 		return $this->_position <= $this->_endRow; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Validate start/end values for "IterateOnlyExistingCells" mode, and adjust if necessary | ||||
| 	 * | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
|     protected function adjustForExistingOnlyRange() { | ||||
|         if ($this->_onlyExistingCells) { | ||||
|             while ((!$this->_subject->cellExistsByColumnAndRow($this->_columnIndex, $this->_startRow)) && | ||||
|                 ($this->_startRow <= $this->_endRow)) { | ||||
|                 ++$this->_startRow; | ||||
|             } | ||||
|             if ($this->_startRow > $this->_endRow) { | ||||
|                 throw new PHPExcel_Exception('No cells exist within the specified range'); | ||||
|             } | ||||
|             while ((!$this->_subject->cellExistsByColumnAndRow($this->_columnIndex, $this->_endRow)) && | ||||
|                 ($this->_endRow >= $this->_startRow)) { | ||||
|                 --$this->_endRow; | ||||
|             } | ||||
|             if ($this->_endRow < $this->_startRow) { | ||||
|                 throw new PHPExcel_Exception('No cells exist within the specified range'); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										266
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/ColumnDimension.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										266
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/ColumnDimension.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,266 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_ColumnDimension | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_ColumnDimension | ||||
| { | ||||
| 	/** | ||||
| 	 * Column index | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_columnIndex; | ||||
|  | ||||
| 	/** | ||||
| 	 * Column width | ||||
| 	 * | ||||
| 	 * When this is set to a negative value, the column width should be ignored by IWriter | ||||
| 	 * | ||||
| 	 * @var double | ||||
| 	 */ | ||||
| 	private $_width			= -1; | ||||
|  | ||||
| 	/** | ||||
| 	 * Auto size? | ||||
| 	 * | ||||
| 	 * @var bool | ||||
| 	 */ | ||||
| 	private $_autoSize		= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Visible? | ||||
| 	 * | ||||
| 	 * @var bool | ||||
| 	 */ | ||||
| 	private $_visible		= true; | ||||
|  | ||||
| 	/** | ||||
| 	 * Outline level | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_outlineLevel	= 0; | ||||
|  | ||||
| 	/** | ||||
| 	 * Collapsed | ||||
| 	 * | ||||
| 	 * @var bool | ||||
| 	 */ | ||||
| 	private $_collapsed		= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Index to cellXf | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_xfIndex; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_ColumnDimension | ||||
|      * | ||||
|      * @param string $pIndex Character column index | ||||
|      */ | ||||
|     public function __construct($pIndex = 'A') | ||||
|     { | ||||
|     	// Initialise values | ||||
|     	$this->_columnIndex		= $pIndex; | ||||
|  | ||||
| 		// set default index to cellXf | ||||
| 		$this->_xfIndex = 0; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get ColumnIndex | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getColumnIndex() { | ||||
|     	return $this->_columnIndex; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set ColumnIndex | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_ColumnDimension | ||||
|      */ | ||||
|     public function setColumnIndex($pValue) { | ||||
|     	$this->_columnIndex = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Width | ||||
|      * | ||||
|      * @return double | ||||
|      */ | ||||
|     public function getWidth() { | ||||
|     	return $this->_width; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Width | ||||
|      * | ||||
|      * @param double $pValue | ||||
|      * @return PHPExcel_Worksheet_ColumnDimension | ||||
|      */ | ||||
|     public function setWidth($pValue = -1) { | ||||
|     	$this->_width = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Auto Size | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function getAutoSize() { | ||||
|     	return $this->_autoSize; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Auto Size | ||||
|      * | ||||
|      * @param bool $pValue | ||||
|      * @return PHPExcel_Worksheet_ColumnDimension | ||||
|      */ | ||||
|     public function setAutoSize($pValue = false) { | ||||
|     	$this->_autoSize = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Visible | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function getVisible() { | ||||
|     	return $this->_visible; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Visible | ||||
|      * | ||||
|      * @param bool $pValue | ||||
|      * @return PHPExcel_Worksheet_ColumnDimension | ||||
|      */ | ||||
|     public function setVisible($pValue = true) { | ||||
|     	$this->_visible = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Outline Level | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getOutlineLevel() { | ||||
|     	return $this->_outlineLevel; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Outline Level | ||||
|      * | ||||
|      * Value must be between 0 and 7 | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @throws PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_ColumnDimension | ||||
|      */ | ||||
|     public function setOutlineLevel($pValue) { | ||||
|     	if ($pValue < 0 || $pValue > 7) { | ||||
|     		throw new PHPExcel_Exception("Outline level must range between 0 and 7."); | ||||
|     	} | ||||
|  | ||||
|     	$this->_outlineLevel = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Collapsed | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function getCollapsed() { | ||||
|     	return $this->_collapsed; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Collapsed | ||||
|      * | ||||
|      * @param bool $pValue | ||||
|      * @return PHPExcel_Worksheet_ColumnDimension | ||||
|      */ | ||||
|     public function setCollapsed($pValue = true) { | ||||
|     	$this->_collapsed = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get index to cellXf | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
| 	public function getXfIndex() | ||||
| 	{ | ||||
| 		return $this->_xfIndex; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set index to cellXf | ||||
| 	 * | ||||
| 	 * @param int $pValue | ||||
| 	 * @return PHPExcel_Worksheet_ColumnDimension | ||||
| 	 */ | ||||
| 	public function setXfIndex($pValue = 0) | ||||
| 	{ | ||||
| 		$this->_xfIndex = $pValue; | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| } | ||||
							
								
								
									
										192
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/ColumnIterator.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										192
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/ColumnIterator.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,192 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license	http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version	##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_ColumnIterator | ||||
|  * | ||||
|  * Used to iterate columns in a PHPExcel_Worksheet | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package	PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_ColumnIterator implements Iterator | ||||
| { | ||||
| 	/** | ||||
| 	 * PHPExcel_Worksheet to iterate | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet | ||||
| 	 */ | ||||
| 	private $_subject; | ||||
|  | ||||
| 	/** | ||||
| 	 * Current iterator position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_position = 0; | ||||
|  | ||||
| 	/** | ||||
| 	 * Start position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_startColumn = 0; | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * End position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_endColumn = 0; | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * Create a new column iterator | ||||
| 	 * | ||||
| 	 * @param	PHPExcel_Worksheet	$subject	The worksheet to iterate over | ||||
| 	 * @param	string				$startColumn	The column address at which to start iterating | ||||
| 	 * @param	string				$endColumn	    Optionally, the column address at which to stop iterating | ||||
| 	 */ | ||||
| 	public function __construct(PHPExcel_Worksheet $subject = null, $startColumn = 'A', $endColumn = null) { | ||||
| 		// Set subject | ||||
| 		$this->_subject = $subject; | ||||
| 		$this->resetEnd($endColumn); | ||||
| 		$this->resetStart($startColumn); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Destructor | ||||
| 	 */ | ||||
| 	public function __destruct() { | ||||
| 		unset($this->_subject); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * (Re)Set the start column and the current column pointer | ||||
| 	 * | ||||
| 	 * @param integer	$startColumn	The column address at which to start iterating | ||||
|      * @return PHPExcel_Worksheet_ColumnIterator | ||||
| 	 */ | ||||
| 	public function resetStart($startColumn = 'A') { | ||||
|         $startColumnIndex = PHPExcel_Cell::columnIndexFromString($startColumn) - 1; | ||||
| 		$this->_startColumn = $startColumnIndex; | ||||
| 		$this->seek($startColumn); | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * (Re)Set the end column | ||||
| 	 * | ||||
| 	 * @param string	$endColumn	The column address at which to stop iterating | ||||
|      * @return PHPExcel_Worksheet_ColumnIterator | ||||
| 	 */ | ||||
| 	public function resetEnd($endColumn = null) { | ||||
| 		$endColumn = ($endColumn) ? $endColumn : $this->_subject->getHighestColumn(); | ||||
| 		$this->_endColumn = PHPExcel_Cell::columnIndexFromString($endColumn) - 1; | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the column pointer to the selected column | ||||
| 	 * | ||||
| 	 * @param string	$column	The column address to set the current pointer at | ||||
|      * @return PHPExcel_Worksheet_ColumnIterator | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function seek($column = 'A') { | ||||
|         $column = PHPExcel_Cell::columnIndexFromString($column) - 1; | ||||
|         if (($column < $this->_startColumn) || ($column > $this->_endColumn)) { | ||||
|             throw new PHPExcel_Exception("Column $column is out of range ({$this->_startColumn} - {$this->_endColumn})"); | ||||
|         } | ||||
| 		$this->_position = $column; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Rewind the iterator to the starting column | ||||
| 	 */ | ||||
| 	public function rewind() { | ||||
| 		$this->_position = $this->_startColumn; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Return the current column in this worksheet | ||||
| 	 * | ||||
| 	 * @return PHPExcel_Worksheet_Column | ||||
| 	 */ | ||||
| 	public function current() { | ||||
| 		return new PHPExcel_Worksheet_Column($this->_subject, PHPExcel_Cell::stringFromColumnIndex($this->_position)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Return the current iterator key | ||||
| 	 * | ||||
| 	 * @return string | ||||
| 	 */ | ||||
| 	public function key() { | ||||
| 		return PHPExcel_Cell::stringFromColumnIndex($this->_position); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to its next value | ||||
| 	 */ | ||||
| 	public function next() { | ||||
| 		++$this->_position; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to its previous value | ||||
|      * | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function prev() { | ||||
|         if ($this->_position <= $this->_startColumn) { | ||||
|             throw new PHPExcel_Exception( | ||||
|                 "Column is already at the beginning of range (" .  | ||||
|                 PHPExcel_Cell::stringFromColumnIndex($this->_endColumn) . " - " .  | ||||
|                 PHPExcel_Cell::stringFromColumnIndex($this->_endColumn) . ")" | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         --$this->_position; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Indicate if more columns exist in the worksheet range of columns that we're iterating | ||||
| 	 * | ||||
| 	 * @return boolean | ||||
| 	 */ | ||||
| 	public function valid() { | ||||
| 		return $this->_position <= $this->_endColumn; | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										148
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/Drawing.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										148
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/Drawing.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,148 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet_Drawing | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_Drawing | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet_Drawing | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_Drawing extends PHPExcel_Worksheet_BaseDrawing implements PHPExcel_IComparable | ||||
| { | ||||
| 	/** | ||||
| 	 * Path | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_path; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_Drawing | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     	// Initialise values | ||||
|     	$this->_path				= ''; | ||||
|  | ||||
|     	// Initialize parent | ||||
|     	parent::__construct(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Filename | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getFilename() { | ||||
|     	return basename($this->_path); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get indexed filename (using image index) | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getIndexedFilename() { | ||||
|     	$fileName = $this->getFilename(); | ||||
|     	$fileName = str_replace(' ', '_', $fileName); | ||||
|     	return str_replace('.' . $this->getExtension(), '', $fileName) . $this->getImageIndex() . '.' . $this->getExtension(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Extension | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getExtension() { | ||||
|     	$exploded = explode(".", basename($this->_path)); | ||||
|     	return $exploded[count($exploded) - 1]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Path | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getPath() { | ||||
|     	return $this->_path; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Path | ||||
|      * | ||||
|      * @param 	string 		$pValue			File path | ||||
|      * @param 	boolean		$pVerifyFile	Verify file | ||||
|      * @throws 	PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_Drawing | ||||
|      */ | ||||
|     public function setPath($pValue = '', $pVerifyFile = true) { | ||||
|     	if ($pVerifyFile) { | ||||
| 	    	if (file_exists($pValue)) { | ||||
| 	    		$this->_path = $pValue; | ||||
|  | ||||
| 	    		if ($this->_width == 0 && $this->_height == 0) { | ||||
| 	    			// Get width/height | ||||
| 	    			list($this->_width, $this->_height) = getimagesize($pValue); | ||||
| 	    		} | ||||
| 	    	} else { | ||||
| 	    		throw new PHPExcel_Exception("File $pValue not found!"); | ||||
| 	    	} | ||||
|     	} else { | ||||
|     		$this->_path = $pValue; | ||||
|     	} | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get hash code | ||||
| 	 * | ||||
| 	 * @return string	Hash code | ||||
| 	 */ | ||||
| 	public function getHashCode() { | ||||
|     	return md5( | ||||
|     		  $this->_path | ||||
|     		. parent::getHashCode() | ||||
|     		. __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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										465
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/HeaderFooter.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										465
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/HeaderFooter.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,465 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_HeaderFooter | ||||
|  * | ||||
|  * <code> | ||||
|  * Header/Footer Formatting Syntax taken from Office Open XML Part 4 - Markup Language Reference, page 1970: | ||||
|  * | ||||
|  * There are a number of formatting codes that can be written inline with the actual header / footer text, which | ||||
|  * affect the formatting in the header or footer. | ||||
|  * | ||||
|  * Example: This example shows the text "Center Bold Header" on the first line (center section), and the date on | ||||
|  * the second line (center section). | ||||
|  * 		&CCenter &"-,Bold"Bold&"-,Regular"Header_x000A_&D | ||||
|  * | ||||
|  * General Rules: | ||||
|  * There is no required order in which these codes must appear. | ||||
|  * | ||||
|  * The first occurrence of the following codes turns the formatting ON, the second occurrence turns it OFF again: | ||||
|  * - strikethrough | ||||
|  * - superscript | ||||
|  * - subscript | ||||
|  * Superscript and subscript cannot both be ON at same time. Whichever comes first wins and the other is ignored, | ||||
|  * while the first is ON. | ||||
|  * &L - code for "left section" (there are three header / footer locations, "left", "center", and "right"). When | ||||
|  * two or more occurrences of this section marker exist, the contents from all markers are concatenated, in the | ||||
|  * order of appearance, and placed into the left section. | ||||
|  * &P - code for "current page #" | ||||
|  * &N - code for "total pages" | ||||
|  * &font size - code for "text font size", where font size is a font size in points. | ||||
|  * &K - code for "text font color" | ||||
|  * RGB Color is specified as RRGGBB | ||||
|  * Theme Color is specifed as TTSNN where TT is the theme color Id, S is either "+" or "-" of the tint/shade | ||||
|  * value, NN is the tint/shade value. | ||||
|  * &S - code for "text strikethrough" on / off | ||||
|  * &X - code for "text super script" on / off | ||||
|  * &Y - code for "text subscript" on / off | ||||
|  * &C - code for "center section". When two or more occurrences of this section marker exist, the contents | ||||
|  * from all markers are concatenated, in the order of appearance, and placed into the center section. | ||||
|  * | ||||
|  * &D - code for "date" | ||||
|  * &T - code for "time" | ||||
|  * &G - code for "picture as background" | ||||
|  * &U - code for "text single underline" | ||||
|  * &E - code for "double underline" | ||||
|  * &R - code for "right section". When two or more occurrences of this section marker exist, the contents | ||||
|  * from all markers are concatenated, in the order of appearance, and placed into the right section. | ||||
|  * &Z - code for "this workbook's file path" | ||||
|  * &F - code for "this workbook's file name" | ||||
|  * &A - code for "sheet tab name" | ||||
|  * &+ - code for add to page #. | ||||
|  * &- - code for subtract from page #. | ||||
|  * &"font name,font type" - code for "text font name" and "text font type", where font name and font type | ||||
|  * are strings specifying the name and type of the font, separated by a comma. When a hyphen appears in font | ||||
|  * name, it means "none specified". Both of font name and font type can be localized values. | ||||
|  * &"-,Bold" - code for "bold font style" | ||||
|  * &B - also means "bold font style". | ||||
|  * &"-,Regular" - code for "regular font style" | ||||
|  * &"-,Italic" - code for "italic font style" | ||||
|  * &I - also means "italic font style" | ||||
|  * &"-,Bold Italic" code for "bold italic font style" | ||||
|  * &O - code for "outline style" | ||||
|  * &H - code for "shadow style" | ||||
|  * </code> | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_HeaderFooter | ||||
| { | ||||
| 	/* Header/footer image location */ | ||||
| 	const IMAGE_HEADER_LEFT							= 'LH'; | ||||
| 	const IMAGE_HEADER_CENTER						= 'CH'; | ||||
| 	const IMAGE_HEADER_RIGHT						= 'RH'; | ||||
| 	const IMAGE_FOOTER_LEFT							= 'LF'; | ||||
| 	const IMAGE_FOOTER_CENTER						= 'CF'; | ||||
| 	const IMAGE_FOOTER_RIGHT						= 'RF'; | ||||
|  | ||||
| 	/** | ||||
| 	 * OddHeader | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_oddHeader			= ''; | ||||
|  | ||||
| 	/** | ||||
| 	 * OddFooter | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_oddFooter			= ''; | ||||
|  | ||||
| 	/** | ||||
| 	 * EvenHeader | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_evenHeader		= ''; | ||||
|  | ||||
| 	/** | ||||
| 	 * EvenFooter | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_evenFooter		= ''; | ||||
|  | ||||
| 	/** | ||||
| 	 * FirstHeader | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_firstHeader		= ''; | ||||
|  | ||||
| 	/** | ||||
| 	 * FirstFooter | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_firstFooter		= ''; | ||||
|  | ||||
| 	/** | ||||
| 	 * Different header for Odd/Even, defaults to false | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_differentOddEven	= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Different header for first page, defaults to false | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_differentFirst	= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Scale with document, defaults to true | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_scaleWithDocument	= true; | ||||
|  | ||||
| 	/** | ||||
| 	 * Align with margins, defaults to true | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_alignWithMargins	= true; | ||||
|  | ||||
| 	/** | ||||
| 	 * Header/footer images | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet_HeaderFooterDrawing[] | ||||
| 	 */ | ||||
| 	private $_headerFooterImages = array(); | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get OddHeader | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getOddHeader() { | ||||
|     	return $this->_oddHeader; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set OddHeader | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setOddHeader($pValue) { | ||||
|     	$this->_oddHeader = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get OddFooter | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getOddFooter() { | ||||
|     	return $this->_oddFooter; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set OddFooter | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setOddFooter($pValue) { | ||||
|     	$this->_oddFooter = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get EvenHeader | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getEvenHeader() { | ||||
|     	return $this->_evenHeader; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set EvenHeader | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setEvenHeader($pValue) { | ||||
|     	$this->_evenHeader = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get EvenFooter | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getEvenFooter() { | ||||
|     	return $this->_evenFooter; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set EvenFooter | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setEvenFooter($pValue) { | ||||
|     	$this->_evenFooter = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get FirstHeader | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getFirstHeader() { | ||||
|     	return $this->_firstHeader; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set FirstHeader | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setFirstHeader($pValue) { | ||||
|     	$this->_firstHeader = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get FirstFooter | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getFirstFooter() { | ||||
|     	return $this->_firstFooter; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set FirstFooter | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setFirstFooter($pValue) { | ||||
|     	$this->_firstFooter = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get DifferentOddEven | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     public function getDifferentOddEven() { | ||||
|     	return $this->_differentOddEven; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set DifferentOddEven | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setDifferentOddEven($pValue = false) { | ||||
|     	$this->_differentOddEven = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get DifferentFirst | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     public function getDifferentFirst() { | ||||
|     	return $this->_differentFirst; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set DifferentFirst | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setDifferentFirst($pValue = false) { | ||||
|     	$this->_differentFirst = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get ScaleWithDocument | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     public function getScaleWithDocument() { | ||||
|     	return $this->_scaleWithDocument; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set ScaleWithDocument | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setScaleWithDocument($pValue = true) { | ||||
|     	$this->_scaleWithDocument = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get AlignWithMargins | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     public function getAlignWithMargins() { | ||||
|     	return $this->_alignWithMargins; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set AlignWithMargins | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setAlignWithMargins($pValue = true) { | ||||
|     	$this->_alignWithMargins = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Add header/footer image | ||||
|      * | ||||
|      * @param PHPExcel_Worksheet_HeaderFooterDrawing $image | ||||
|      * @param string $location | ||||
|      * @throws PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function addImage(PHPExcel_Worksheet_HeaderFooterDrawing $image = null, $location = self::IMAGE_HEADER_LEFT) { | ||||
|     	$this->_headerFooterImages[$location] = $image; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Remove header/footer image | ||||
|      * | ||||
|      * @param string $location | ||||
|      * @throws PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function removeImage($location = self::IMAGE_HEADER_LEFT) { | ||||
|     	if (isset($this->_headerFooterImages[$location])) { | ||||
|     		unset($this->_headerFooterImages[$location]); | ||||
|     	} | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set header/footer images | ||||
|      * | ||||
|      * @param PHPExcel_Worksheet_HeaderFooterDrawing[] $images | ||||
|      * @throws PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setImages($images) { | ||||
|     	if (!is_array($images)) { | ||||
|     		throw new PHPExcel_Exception('Invalid parameter!'); | ||||
|     	} | ||||
|  | ||||
|     	$this->_headerFooterImages = $images; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get header/footer images | ||||
|      * | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing[] | ||||
|      */ | ||||
|     public function getImages() { | ||||
|     	// Sort array | ||||
|     	$images = array(); | ||||
|     	if (isset($this->_headerFooterImages[self::IMAGE_HEADER_LEFT])) 	$images[self::IMAGE_HEADER_LEFT] = 		$this->_headerFooterImages[self::IMAGE_HEADER_LEFT]; | ||||
|     	if (isset($this->_headerFooterImages[self::IMAGE_HEADER_CENTER])) 	$images[self::IMAGE_HEADER_CENTER] = 	$this->_headerFooterImages[self::IMAGE_HEADER_CENTER]; | ||||
|     	if (isset($this->_headerFooterImages[self::IMAGE_HEADER_RIGHT])) 	$images[self::IMAGE_HEADER_RIGHT] = 	$this->_headerFooterImages[self::IMAGE_HEADER_RIGHT]; | ||||
|     	if (isset($this->_headerFooterImages[self::IMAGE_FOOTER_LEFT])) 	$images[self::IMAGE_FOOTER_LEFT] = 		$this->_headerFooterImages[self::IMAGE_FOOTER_LEFT]; | ||||
|     	if (isset($this->_headerFooterImages[self::IMAGE_FOOTER_CENTER])) 	$images[self::IMAGE_FOOTER_CENTER] = 	$this->_headerFooterImages[self::IMAGE_FOOTER_CENTER]; | ||||
|     	if (isset($this->_headerFooterImages[self::IMAGE_FOOTER_RIGHT])) 	$images[self::IMAGE_FOOTER_RIGHT] = 	$this->_headerFooterImages[self::IMAGE_FOOTER_RIGHT]; | ||||
|     	$this->_headerFooterImages = $images; | ||||
|  | ||||
|     	return $this->_headerFooterImages; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
| @@ -0,0 +1,350 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_HeaderFooterDrawing extends PHPExcel_Worksheet_Drawing implements PHPExcel_IComparable | ||||
| { | ||||
| 	/** | ||||
| 	 * Path | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_path; | ||||
|  | ||||
| 	/** | ||||
| 	 * Name | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	protected $_name; | ||||
|  | ||||
| 	/** | ||||
| 	 * Offset X | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_offsetX; | ||||
|  | ||||
| 	/** | ||||
| 	 * Offset Y | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_offsetY; | ||||
|  | ||||
| 	/** | ||||
| 	 * Width | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_width; | ||||
|  | ||||
| 	/** | ||||
| 	 * Height | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_height; | ||||
|  | ||||
| 	/** | ||||
| 	 * Proportional resize | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	protected $_resizeProportional; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     	// Initialise values | ||||
|     	$this->_path				= ''; | ||||
|     	$this->_name				= ''; | ||||
|     	$this->_offsetX				= 0; | ||||
|     	$this->_offsetY				= 0; | ||||
|     	$this->_width				= 0; | ||||
|     	$this->_height				= 0; | ||||
|     	$this->_resizeProportional	= true; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Name | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getName() { | ||||
|     	return $this->_name; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Name | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
|     public function setName($pValue = '') { | ||||
|     	$this->_name = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get OffsetX | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getOffsetX() { | ||||
|     	return $this->_offsetX; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set OffsetX | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
|     public function setOffsetX($pValue = 0) { | ||||
|     	$this->_offsetX = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get OffsetY | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getOffsetY() { | ||||
|     	return $this->_offsetY; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set OffsetY | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
|     public function setOffsetY($pValue = 0) { | ||||
|     	$this->_offsetY = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Width | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getWidth() { | ||||
|     	return $this->_width; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Width | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
|     public function setWidth($pValue = 0) { | ||||
|     	// Resize proportional? | ||||
|     	if ($this->_resizeProportional && $pValue != 0) { | ||||
|     		$ratio = $this->_width / $this->_height; | ||||
|     		$this->_height = round($ratio * $pValue); | ||||
|     	} | ||||
|  | ||||
|     	// Set width | ||||
|     	$this->_width = $pValue; | ||||
|  | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Height | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getHeight() { | ||||
|     	return $this->_height; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Height | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
|     public function setHeight($pValue = 0) { | ||||
|     	// Resize proportional? | ||||
|     	if ($this->_resizeProportional && $pValue != 0) { | ||||
|     		$ratio = $this->_width / $this->_height; | ||||
|     		$this->_width = round($ratio * $pValue); | ||||
|     	} | ||||
|  | ||||
|     	// Set height | ||||
|     	$this->_height = $pValue; | ||||
|  | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set width and height with proportional resize | ||||
| 	 * Example: | ||||
| 	 * <code> | ||||
|      * $objDrawing->setResizeProportional(true); | ||||
|      * $objDrawing->setWidthAndHeight(160,120); | ||||
| 	 * </code> | ||||
| 	 * | ||||
|      * @author Vincent@luo MSN:kele_100@hotmail.com | ||||
|      * @param int $width | ||||
|      * @param int $height | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
| 	public function setWidthAndHeight($width = 0, $height = 0) { | ||||
| 		$xratio = $width / $this->_width; | ||||
| 		$yratio = $height / $this->_height; | ||||
| 		if ($this->_resizeProportional && !($width == 0 || $height == 0)) { | ||||
| 			if (($xratio * $this->_height) < $height) { | ||||
| 				$this->_height = ceil($xratio * $this->_height); | ||||
| 				$this->_width  = $width; | ||||
| 			} else { | ||||
| 				$this->_width	= ceil($yratio * $this->_width); | ||||
| 				$this->_height	= $height; | ||||
| 			} | ||||
| 		} | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
|     /** | ||||
|      * Get ResizeProportional | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     public function getResizeProportional() { | ||||
|     	return $this->_resizeProportional; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set ResizeProportional | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
|     public function setResizeProportional($pValue = true) { | ||||
|     	$this->_resizeProportional = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Filename | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getFilename() { | ||||
|     	return basename($this->_path); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Extension | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getExtension() { | ||||
|         $parts = explode(".", basename($this->_path)); | ||||
|         return end($parts); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Path | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getPath() { | ||||
|     	return $this->_path; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Path | ||||
|      * | ||||
|      * @param 	string 		$pValue			File path | ||||
|      * @param 	boolean		$pVerifyFile	Verify file | ||||
|      * @throws 	PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_HeaderFooterDrawing | ||||
|      */ | ||||
|     public function setPath($pValue = '', $pVerifyFile = true) { | ||||
|     	if ($pVerifyFile) { | ||||
| 	    	if (file_exists($pValue)) { | ||||
| 	    		$this->_path = $pValue; | ||||
|  | ||||
| 	    		if ($this->_width == 0 && $this->_height == 0) { | ||||
| 	    			// Get width/height | ||||
| 	    			list($this->_width, $this->_height) = getimagesize($pValue); | ||||
| 	    		} | ||||
| 	    	} else { | ||||
| 	    		throw new PHPExcel_Exception("File $pValue not found!"); | ||||
| 	    	} | ||||
|     	} else { | ||||
|     		$this->_path = $pValue; | ||||
|     	} | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get hash code | ||||
| 	 * | ||||
| 	 * @return string	Hash code | ||||
| 	 */ | ||||
| 	public function getHashCode() { | ||||
|     	return md5( | ||||
|     		  $this->_path | ||||
|     		. $this->_name | ||||
|     		. $this->_offsetX | ||||
|     		. $this->_offsetY | ||||
|     		. $this->_width | ||||
|     		. $this->_height | ||||
|     		. __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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										200
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/MemoryDrawing.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										200
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/MemoryDrawing.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,200 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_MemoryDrawing | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_MemoryDrawing extends PHPExcel_Worksheet_BaseDrawing implements PHPExcel_IComparable | ||||
| { | ||||
| 	/* Rendering functions */ | ||||
| 	const RENDERING_DEFAULT					= 'imagepng'; | ||||
| 	const RENDERING_PNG						= 'imagepng'; | ||||
| 	const RENDERING_GIF						= 'imagegif'; | ||||
| 	const RENDERING_JPEG					= 'imagejpeg'; | ||||
|  | ||||
| 	/* MIME types */ | ||||
| 	const MIMETYPE_DEFAULT					= 'image/png'; | ||||
| 	const MIMETYPE_PNG						= 'image/png'; | ||||
| 	const MIMETYPE_GIF						= 'image/gif'; | ||||
| 	const MIMETYPE_JPEG						= 'image/jpeg'; | ||||
|  | ||||
| 	/** | ||||
| 	 * Image resource | ||||
| 	 * | ||||
| 	 * @var resource | ||||
| 	 */ | ||||
| 	private $_imageResource; | ||||
|  | ||||
| 	/** | ||||
| 	 * Rendering function | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_renderingFunction; | ||||
|  | ||||
| 	/** | ||||
| 	 * Mime type | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_mimeType; | ||||
|  | ||||
| 	/** | ||||
| 	 * Unique name | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_uniqueName; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_MemoryDrawing | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     	// Initialise values | ||||
|     	$this->_imageResource		= null; | ||||
|     	$this->_renderingFunction 	= self::RENDERING_DEFAULT; | ||||
|     	$this->_mimeType			= self::MIMETYPE_DEFAULT; | ||||
|     	$this->_uniqueName			= md5(rand(0, 9999). time() . rand(0, 9999)); | ||||
|  | ||||
|     	// Initialize parent | ||||
|     	parent::__construct(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get image resource | ||||
|      * | ||||
|      * @return resource | ||||
|      */ | ||||
|     public function getImageResource() { | ||||
|     	return $this->_imageResource; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set image resource | ||||
|      * | ||||
|      * @param	$value resource | ||||
|      * @return PHPExcel_Worksheet_MemoryDrawing | ||||
|      */ | ||||
|     public function setImageResource($value = null) { | ||||
|     	$this->_imageResource = $value; | ||||
|  | ||||
|     	if (!is_null($this->_imageResource)) { | ||||
| 	    	// Get width/height | ||||
| 	    	$this->_width	= imagesx($this->_imageResource); | ||||
| 	    	$this->_height	= imagesy($this->_imageResource); | ||||
|     	} | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get rendering function | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getRenderingFunction() { | ||||
|     	return $this->_renderingFunction; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set rendering function | ||||
|      * | ||||
|      * @param string $value | ||||
|      * @return PHPExcel_Worksheet_MemoryDrawing | ||||
|      */ | ||||
|     public function setRenderingFunction($value = PHPExcel_Worksheet_MemoryDrawing::RENDERING_DEFAULT) { | ||||
|     	$this->_renderingFunction = $value; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get mime type | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getMimeType() { | ||||
|     	return $this->_mimeType; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set mime type | ||||
|      * | ||||
|      * @param string $value | ||||
|      * @return PHPExcel_Worksheet_MemoryDrawing | ||||
|      */ | ||||
|     public function setMimeType($value = PHPExcel_Worksheet_MemoryDrawing::MIMETYPE_DEFAULT) { | ||||
|     	$this->_mimeType = $value; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get indexed filename (using image index) | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getIndexedFilename() { | ||||
| 		$extension 	= strtolower($this->getMimeType()); | ||||
| 		$extension 	= explode('/', $extension); | ||||
| 		$extension 	= $extension[1]; | ||||
|  | ||||
|     	return $this->_uniqueName . $this->getImageIndex() . '.' . $extension; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get hash code | ||||
| 	 * | ||||
| 	 * @return string	Hash code | ||||
| 	 */ | ||||
| 	public function getHashCode() { | ||||
|     	return md5( | ||||
|     		  $this->_renderingFunction | ||||
|     		. $this->_mimeType | ||||
|     		. $this->_uniqueName | ||||
|     		. parent::getHashCode() | ||||
|     		. __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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										220
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/PageMargins.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										220
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/PageMargins.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,220 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_PageMargins | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_PageMargins | ||||
| { | ||||
| 	/** | ||||
| 	 * Left | ||||
| 	 * | ||||
| 	 * @var double | ||||
| 	 */ | ||||
| 	private $_left		= 0.7; | ||||
|  | ||||
| 	/** | ||||
| 	 * Right | ||||
| 	 * | ||||
| 	 * @var double | ||||
| 	 */ | ||||
| 	private $_right		= 0.7; | ||||
|  | ||||
| 	/** | ||||
| 	 * Top | ||||
| 	 * | ||||
| 	 * @var double | ||||
| 	 */ | ||||
| 	private $_top		= 0.75; | ||||
|  | ||||
| 	/** | ||||
| 	 * Bottom | ||||
| 	 * | ||||
| 	 * @var double | ||||
| 	 */ | ||||
| 	private $_bottom	= 0.75; | ||||
|  | ||||
| 	/** | ||||
| 	 * Header | ||||
| 	 * | ||||
| 	 * @var double | ||||
| 	 */ | ||||
| 	private $_header 	= 0.3; | ||||
|  | ||||
| 	/** | ||||
| 	 * Footer | ||||
| 	 * | ||||
| 	 * @var double | ||||
| 	 */ | ||||
| 	private $_footer 	= 0.3; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_PageMargins | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Left | ||||
|      * | ||||
|      * @return double | ||||
|      */ | ||||
|     public function getLeft() { | ||||
|     	return $this->_left; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Left | ||||
|      * | ||||
|      * @param double $pValue | ||||
|      * @return PHPExcel_Worksheet_PageMargins | ||||
|      */ | ||||
|     public function setLeft($pValue) { | ||||
|     	$this->_left = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Right | ||||
|      * | ||||
|      * @return double | ||||
|      */ | ||||
|     public function getRight() { | ||||
|     	return $this->_right; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Right | ||||
|      * | ||||
|      * @param double $pValue | ||||
|      * @return PHPExcel_Worksheet_PageMargins | ||||
|      */ | ||||
|     public function setRight($pValue) { | ||||
|     	$this->_right = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Top | ||||
|      * | ||||
|      * @return double | ||||
|      */ | ||||
|     public function getTop() { | ||||
|     	return $this->_top; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Top | ||||
|      * | ||||
|      * @param double $pValue | ||||
|      * @return PHPExcel_Worksheet_PageMargins | ||||
|      */ | ||||
|     public function setTop($pValue) { | ||||
|     	$this->_top = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Bottom | ||||
|      * | ||||
|      * @return double | ||||
|      */ | ||||
|     public function getBottom() { | ||||
|     	return $this->_bottom; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Bottom | ||||
|      * | ||||
|      * @param double $pValue | ||||
|      * @return PHPExcel_Worksheet_PageMargins | ||||
|      */ | ||||
|     public function setBottom($pValue) { | ||||
|     	$this->_bottom = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Header | ||||
|      * | ||||
|      * @return double | ||||
|      */ | ||||
|     public function getHeader() { | ||||
|     	return $this->_header; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Header | ||||
|      * | ||||
|      * @param double $pValue | ||||
|      * @return PHPExcel_Worksheet_PageMargins | ||||
|      */ | ||||
|     public function setHeader($pValue) { | ||||
|     	$this->_header = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Footer | ||||
|      * | ||||
|      * @return double | ||||
|      */ | ||||
|     public function getFooter() { | ||||
|     	return $this->_footer; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Footer | ||||
|      * | ||||
|      * @param double $pValue | ||||
|      * @return PHPExcel_Worksheet_PageMargins | ||||
|      */ | ||||
|     public function setFooter($pValue) { | ||||
|     	$this->_footer = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										798
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/PageSetup.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										798
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/PageSetup.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,798 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_PageSetup | ||||
|  * | ||||
|  * <code> | ||||
|  * Paper size taken from Office Open XML Part 4 - Markup Language Reference, page 1988: | ||||
|  * | ||||
|  * 1 = Letter paper (8.5 in. by 11 in.) | ||||
|  * 2 = Letter small paper (8.5 in. by 11 in.) | ||||
|  * 3 = Tabloid paper (11 in. by 17 in.) | ||||
|  * 4 = Ledger paper (17 in. by 11 in.) | ||||
|  * 5 = Legal paper (8.5 in. by 14 in.) | ||||
|  * 6 = Statement paper (5.5 in. by 8.5 in.) | ||||
|  * 7 = Executive paper (7.25 in. by 10.5 in.) | ||||
|  * 8 = A3 paper (297 mm by 420 mm) | ||||
|  * 9 = A4 paper (210 mm by 297 mm) | ||||
|  * 10 = A4 small paper (210 mm by 297 mm) | ||||
|  * 11 = A5 paper (148 mm by 210 mm) | ||||
|  * 12 = B4 paper (250 mm by 353 mm) | ||||
|  * 13 = B5 paper (176 mm by 250 mm) | ||||
|  * 14 = Folio paper (8.5 in. by 13 in.) | ||||
|  * 15 = Quarto paper (215 mm by 275 mm) | ||||
|  * 16 = Standard paper (10 in. by 14 in.) | ||||
|  * 17 = Standard paper (11 in. by 17 in.) | ||||
|  * 18 = Note paper (8.5 in. by 11 in.) | ||||
|  * 19 = #9 envelope (3.875 in. by 8.875 in.) | ||||
|  * 20 = #10 envelope (4.125 in. by 9.5 in.) | ||||
|  * 21 = #11 envelope (4.5 in. by 10.375 in.) | ||||
|  * 22 = #12 envelope (4.75 in. by 11 in.) | ||||
|  * 23 = #14 envelope (5 in. by 11.5 in.) | ||||
|  * 24 = C paper (17 in. by 22 in.) | ||||
|  * 25 = D paper (22 in. by 34 in.) | ||||
|  * 26 = E paper (34 in. by 44 in.) | ||||
|  * 27 = DL envelope (110 mm by 220 mm) | ||||
|  * 28 = C5 envelope (162 mm by 229 mm) | ||||
|  * 29 = C3 envelope (324 mm by 458 mm) | ||||
|  * 30 = C4 envelope (229 mm by 324 mm) | ||||
|  * 31 = C6 envelope (114 mm by 162 mm) | ||||
|  * 32 = C65 envelope (114 mm by 229 mm) | ||||
|  * 33 = B4 envelope (250 mm by 353 mm) | ||||
|  * 34 = B5 envelope (176 mm by 250 mm) | ||||
|  * 35 = B6 envelope (176 mm by 125 mm) | ||||
|  * 36 = Italy envelope (110 mm by 230 mm) | ||||
|  * 37 = Monarch envelope (3.875 in. by 7.5 in.). | ||||
|  * 38 = 6 3/4 envelope (3.625 in. by 6.5 in.) | ||||
|  * 39 = US standard fanfold (14.875 in. by 11 in.) | ||||
|  * 40 = German standard fanfold (8.5 in. by 12 in.) | ||||
|  * 41 = German legal fanfold (8.5 in. by 13 in.) | ||||
|  * 42 = ISO B4 (250 mm by 353 mm) | ||||
|  * 43 = Japanese double postcard (200 mm by 148 mm) | ||||
|  * 44 = Standard paper (9 in. by 11 in.) | ||||
|  * 45 = Standard paper (10 in. by 11 in.) | ||||
|  * 46 = Standard paper (15 in. by 11 in.) | ||||
|  * 47 = Invite envelope (220 mm by 220 mm) | ||||
|  * 50 = Letter extra paper (9.275 in. by 12 in.) | ||||
|  * 51 = Legal extra paper (9.275 in. by 15 in.) | ||||
|  * 52 = Tabloid extra paper (11.69 in. by 18 in.) | ||||
|  * 53 = A4 extra paper (236 mm by 322 mm) | ||||
|  * 54 = Letter transverse paper (8.275 in. by 11 in.) | ||||
|  * 55 = A4 transverse paper (210 mm by 297 mm) | ||||
|  * 56 = Letter extra transverse paper (9.275 in. by 12 in.) | ||||
|  * 57 = SuperA/SuperA/A4 paper (227 mm by 356 mm) | ||||
|  * 58 = SuperB/SuperB/A3 paper (305 mm by 487 mm) | ||||
|  * 59 = Letter plus paper (8.5 in. by 12.69 in.) | ||||
|  * 60 = A4 plus paper (210 mm by 330 mm) | ||||
|  * 61 = A5 transverse paper (148 mm by 210 mm) | ||||
|  * 62 = JIS B5 transverse paper (182 mm by 257 mm) | ||||
|  * 63 = A3 extra paper (322 mm by 445 mm) | ||||
|  * 64 = A5 extra paper (174 mm by 235 mm) | ||||
|  * 65 = ISO B5 extra paper (201 mm by 276 mm) | ||||
|  * 66 = A2 paper (420 mm by 594 mm) | ||||
|  * 67 = A3 transverse paper (297 mm by 420 mm) | ||||
|  * 68 = A3 extra transverse paper (322 mm by 445 mm) | ||||
|  * </code> | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_PageSetup | ||||
| { | ||||
| 	/* Paper size */ | ||||
| 	const PAPERSIZE_LETTER							= 1; | ||||
| 	const PAPERSIZE_LETTER_SMALL					= 2; | ||||
| 	const PAPERSIZE_TABLOID							= 3; | ||||
| 	const PAPERSIZE_LEDGER							= 4; | ||||
| 	const PAPERSIZE_LEGAL							= 5; | ||||
| 	const PAPERSIZE_STATEMENT						= 6; | ||||
| 	const PAPERSIZE_EXECUTIVE						= 7; | ||||
| 	const PAPERSIZE_A3								= 8; | ||||
| 	const PAPERSIZE_A4								= 9; | ||||
| 	const PAPERSIZE_A4_SMALL						= 10; | ||||
| 	const PAPERSIZE_A5								= 11; | ||||
| 	const PAPERSIZE_B4								= 12; | ||||
| 	const PAPERSIZE_B5								= 13; | ||||
| 	const PAPERSIZE_FOLIO							= 14; | ||||
| 	const PAPERSIZE_QUARTO							= 15; | ||||
| 	const PAPERSIZE_STANDARD_1						= 16; | ||||
| 	const PAPERSIZE_STANDARD_2						= 17; | ||||
| 	const PAPERSIZE_NOTE							= 18; | ||||
| 	const PAPERSIZE_NO9_ENVELOPE					= 19; | ||||
| 	const PAPERSIZE_NO10_ENVELOPE					= 20; | ||||
| 	const PAPERSIZE_NO11_ENVELOPE					= 21; | ||||
| 	const PAPERSIZE_NO12_ENVELOPE					= 22; | ||||
| 	const PAPERSIZE_NO14_ENVELOPE					= 23; | ||||
| 	const PAPERSIZE_C								= 24; | ||||
| 	const PAPERSIZE_D								= 25; | ||||
| 	const PAPERSIZE_E								= 26; | ||||
| 	const PAPERSIZE_DL_ENVELOPE						= 27; | ||||
| 	const PAPERSIZE_C5_ENVELOPE						= 28; | ||||
| 	const PAPERSIZE_C3_ENVELOPE						= 29; | ||||
| 	const PAPERSIZE_C4_ENVELOPE						= 30; | ||||
| 	const PAPERSIZE_C6_ENVELOPE						= 31; | ||||
| 	const PAPERSIZE_C65_ENVELOPE					= 32; | ||||
| 	const PAPERSIZE_B4_ENVELOPE						= 33; | ||||
| 	const PAPERSIZE_B5_ENVELOPE						= 34; | ||||
| 	const PAPERSIZE_B6_ENVELOPE						= 35; | ||||
| 	const PAPERSIZE_ITALY_ENVELOPE					= 36; | ||||
| 	const PAPERSIZE_MONARCH_ENVELOPE				= 37; | ||||
| 	const PAPERSIZE_6_3_4_ENVELOPE					= 38; | ||||
| 	const PAPERSIZE_US_STANDARD_FANFOLD				= 39; | ||||
| 	const PAPERSIZE_GERMAN_STANDARD_FANFOLD			= 40; | ||||
| 	const PAPERSIZE_GERMAN_LEGAL_FANFOLD			= 41; | ||||
| 	const PAPERSIZE_ISO_B4							= 42; | ||||
| 	const PAPERSIZE_JAPANESE_DOUBLE_POSTCARD		= 43; | ||||
| 	const PAPERSIZE_STANDARD_PAPER_1				= 44; | ||||
| 	const PAPERSIZE_STANDARD_PAPER_2				= 45; | ||||
| 	const PAPERSIZE_STANDARD_PAPER_3				= 46; | ||||
| 	const PAPERSIZE_INVITE_ENVELOPE					= 47; | ||||
| 	const PAPERSIZE_LETTER_EXTRA_PAPER				= 48; | ||||
| 	const PAPERSIZE_LEGAL_EXTRA_PAPER				= 49; | ||||
| 	const PAPERSIZE_TABLOID_EXTRA_PAPER				= 50; | ||||
| 	const PAPERSIZE_A4_EXTRA_PAPER					= 51; | ||||
| 	const PAPERSIZE_LETTER_TRANSVERSE_PAPER			= 52; | ||||
| 	const PAPERSIZE_A4_TRANSVERSE_PAPER				= 53; | ||||
| 	const PAPERSIZE_LETTER_EXTRA_TRANSVERSE_PAPER	= 54; | ||||
| 	const PAPERSIZE_SUPERA_SUPERA_A4_PAPER			= 55; | ||||
| 	const PAPERSIZE_SUPERB_SUPERB_A3_PAPER			= 56; | ||||
| 	const PAPERSIZE_LETTER_PLUS_PAPER				= 57; | ||||
| 	const PAPERSIZE_A4_PLUS_PAPER					= 58; | ||||
| 	const PAPERSIZE_A5_TRANSVERSE_PAPER				= 59; | ||||
| 	const PAPERSIZE_JIS_B5_TRANSVERSE_PAPER			= 60; | ||||
| 	const PAPERSIZE_A3_EXTRA_PAPER					= 61; | ||||
| 	const PAPERSIZE_A5_EXTRA_PAPER					= 62; | ||||
| 	const PAPERSIZE_ISO_B5_EXTRA_PAPER				= 63; | ||||
| 	const PAPERSIZE_A2_PAPER						= 64; | ||||
| 	const PAPERSIZE_A3_TRANSVERSE_PAPER				= 65; | ||||
| 	const PAPERSIZE_A3_EXTRA_TRANSVERSE_PAPER		= 66; | ||||
|  | ||||
| 	/* Page orientation */ | ||||
| 	const ORIENTATION_DEFAULT	= 'default'; | ||||
| 	const ORIENTATION_LANDSCAPE	= 'landscape'; | ||||
| 	const ORIENTATION_PORTRAIT	= 'portrait'; | ||||
|  | ||||
| 	/* Print Range Set Method */ | ||||
| 	const SETPRINTRANGE_OVERWRITE	= 'O'; | ||||
| 	const SETPRINTRANGE_INSERT		= 'I'; | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * Paper size | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_paperSize		= PHPExcel_Worksheet_PageSetup::PAPERSIZE_LETTER; | ||||
|  | ||||
| 	/** | ||||
| 	 * Orientation | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_orientation	= PHPExcel_Worksheet_PageSetup::ORIENTATION_DEFAULT; | ||||
|  | ||||
| 	/** | ||||
| 	 * Scale (Print Scale) | ||||
| 	 * | ||||
| 	 * Print scaling. Valid values range from 10 to 400 | ||||
| 	 * This setting is overridden when fitToWidth and/or fitToHeight are in use | ||||
| 	 * | ||||
| 	 * @var int? | ||||
| 	 */ | ||||
| 	private $_scale			= 100; | ||||
|  | ||||
| 	/** | ||||
| 	  * Fit To Page | ||||
| 	  * Whether scale or fitToWith / fitToHeight applies | ||||
| 	  * | ||||
| 	  * @var boolean | ||||
| 	  */ | ||||
| 	private $_fitToPage		= FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	  * Fit To Height | ||||
| 	  * Number of vertical pages to fit on | ||||
| 	  * | ||||
| 	  * @var int? | ||||
| 	  */ | ||||
| 	private $_fitToHeight	= 1; | ||||
|  | ||||
| 	/** | ||||
| 	  * Fit To Width | ||||
| 	  * Number of horizontal pages to fit on | ||||
| 	  * | ||||
| 	  * @var int? | ||||
| 	  */ | ||||
| 	private $_fitToWidth	= 1; | ||||
|  | ||||
| 	/** | ||||
| 	 * Columns to repeat at left | ||||
| 	 * | ||||
| 	 * @var array Containing start column and end column, empty array if option unset | ||||
| 	 */ | ||||
| 	private $_columnsToRepeatAtLeft = array('', ''); | ||||
|  | ||||
| 	/** | ||||
| 	 * Rows to repeat at top | ||||
| 	 * | ||||
| 	 * @var array Containing start row number and end row number, empty array if option unset | ||||
| 	 */ | ||||
| 	private $_rowsToRepeatAtTop = array(0, 0); | ||||
|  | ||||
| 	/** | ||||
| 	 * Center page horizontally | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_horizontalCentered = FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * Center page vertically | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_verticalCentered = FALSE; | ||||
|  | ||||
| 	/** | ||||
| 	 * Print area | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_printArea = NULL; | ||||
|  | ||||
| 	/** | ||||
| 	 * First page number | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_firstPageNumber = NULL; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_PageSetup | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Paper Size | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getPaperSize() { | ||||
|     	return $this->_paperSize; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Paper Size | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_PageSetup | ||||
|      */ | ||||
|     public function setPaperSize($pValue = PHPExcel_Worksheet_PageSetup::PAPERSIZE_LETTER) { | ||||
|     	$this->_paperSize = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Orientation | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function getOrientation() { | ||||
|     	return $this->_orientation; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Orientation | ||||
|      * | ||||
|      * @param string $pValue | ||||
|      * @return PHPExcel_Worksheet_PageSetup | ||||
|      */ | ||||
|     public function setOrientation($pValue = PHPExcel_Worksheet_PageSetup::ORIENTATION_DEFAULT) { | ||||
|     	$this->_orientation = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get Scale | ||||
| 	 * | ||||
| 	 * @return int? | ||||
| 	 */ | ||||
| 	public function getScale() { | ||||
| 		return $this->_scale; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set Scale | ||||
| 	 * | ||||
| 	 * Print scaling. Valid values range from 10 to 400 | ||||
| 	 * This setting is overridden when fitToWidth and/or fitToHeight are in use | ||||
| 	 * | ||||
| 	 * @param 	int?	$pValue | ||||
| 	 * @param boolean	$pUpdate	Update fitToPage so scaling applies rather than fitToHeight / fitToWidth | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 * @throws 	PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function setScale($pValue = 100, $pUpdate = true) { | ||||
| 		// Microsoft Office Excel 2007 only allows setting a scale between 10 and 400 via the user interface, | ||||
| 		// but it is apparently still able to handle any scale >= 0, where 0 results in 100 | ||||
| 		if (($pValue >= 0) || is_null($pValue)) { | ||||
| 			$this->_scale = $pValue; | ||||
| 			if ($pUpdate) { | ||||
| 				$this->_fitToPage = false; | ||||
| 			} | ||||
| 		} else { | ||||
| 			throw new PHPExcel_Exception("Scale must not be negative"); | ||||
| 		} | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get Fit To Page | ||||
| 	 * | ||||
| 	 * @return boolean | ||||
| 	 */ | ||||
| 	public function getFitToPage() { | ||||
| 		return $this->_fitToPage; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set Fit To Page | ||||
| 	 * | ||||
| 	 * @param boolean $pValue | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setFitToPage($pValue = TRUE) { | ||||
| 		$this->_fitToPage = $pValue; | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get Fit To Height | ||||
| 	 * | ||||
| 	 * @return int? | ||||
| 	 */ | ||||
| 	public function getFitToHeight() { | ||||
| 		return $this->_fitToHeight; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set Fit To Height | ||||
| 	 * | ||||
| 	 * @param int? $pValue | ||||
| 	 * @param boolean $pUpdate Update fitToPage so it applies rather than scaling | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setFitToHeight($pValue = 1, $pUpdate = TRUE) { | ||||
| 		$this->_fitToHeight = $pValue; | ||||
| 		if ($pUpdate) { | ||||
| 			$this->_fitToPage = TRUE; | ||||
| 		} | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get Fit To Width | ||||
| 	 * | ||||
| 	 * @return int? | ||||
| 	 */ | ||||
| 	public function getFitToWidth() { | ||||
| 		return $this->_fitToWidth; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set Fit To Width | ||||
| 	 * | ||||
| 	 * @param int? $pValue | ||||
| 	 * @param boolean $pUpdate Update fitToPage so it applies rather than scaling | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setFitToWidth($pValue = 1, $pUpdate = TRUE) { | ||||
| 		$this->_fitToWidth = $pValue; | ||||
| 		if ($pUpdate) { | ||||
| 			$this->_fitToPage = TRUE; | ||||
| 		} | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Is Columns to repeat at left set? | ||||
| 	 * | ||||
| 	 * @return boolean | ||||
| 	 */ | ||||
| 	public function isColumnsToRepeatAtLeftSet() { | ||||
| 		if (is_array($this->_columnsToRepeatAtLeft)) { | ||||
| 			if ($this->_columnsToRepeatAtLeft[0] != '' && $this->_columnsToRepeatAtLeft[1] != '') { | ||||
| 				return true; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get Columns to repeat at left | ||||
| 	 * | ||||
| 	 * @return array Containing start column and end column, empty array if option unset | ||||
| 	 */ | ||||
| 	public function getColumnsToRepeatAtLeft() { | ||||
| 		return $this->_columnsToRepeatAtLeft; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set Columns to repeat at left | ||||
| 	 * | ||||
| 	 * @param array $pValue Containing start column and end column, empty array if option unset | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setColumnsToRepeatAtLeft($pValue = null) { | ||||
| 		if (is_array($pValue)) { | ||||
| 			$this->_columnsToRepeatAtLeft = $pValue; | ||||
| 		} | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set Columns to repeat at left by start and end | ||||
| 	 * | ||||
| 	 * @param string $pStart | ||||
| 	 * @param string $pEnd | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setColumnsToRepeatAtLeftByStartAndEnd($pStart = 'A', $pEnd = 'A') { | ||||
| 		$this->_columnsToRepeatAtLeft = array($pStart, $pEnd); | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Is Rows to repeat at top set? | ||||
| 	 * | ||||
| 	 * @return boolean | ||||
| 	 */ | ||||
| 	public function isRowsToRepeatAtTopSet() { | ||||
| 		if (is_array($this->_rowsToRepeatAtTop)) { | ||||
| 			if ($this->_rowsToRepeatAtTop[0] != 0 && $this->_rowsToRepeatAtTop[1] != 0) { | ||||
| 				return true; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return false; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get Rows to repeat at top | ||||
| 	 * | ||||
| 	 * @return array Containing start column and end column, empty array if option unset | ||||
| 	 */ | ||||
| 	public function getRowsToRepeatAtTop() { | ||||
| 		return $this->_rowsToRepeatAtTop; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set Rows to repeat at top | ||||
| 	 * | ||||
| 	 * @param array	$pValue	Containing start column and end column, empty array if option unset | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setRowsToRepeatAtTop($pValue = null) { | ||||
| 		if (is_array($pValue)) { | ||||
| 			$this->_rowsToRepeatAtTop = $pValue; | ||||
| 		} | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set Rows to repeat at top by start and end | ||||
| 	 * | ||||
| 	 * @param int $pStart | ||||
| 	 * @param int $pEnd | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setRowsToRepeatAtTopByStartAndEnd($pStart = 1, $pEnd = 1) { | ||||
| 		$this->_rowsToRepeatAtTop = array($pStart, $pEnd); | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get center page horizontally | ||||
| 	 * | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function getHorizontalCentered() { | ||||
| 		return $this->_horizontalCentered; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set center page horizontally | ||||
| 	 * | ||||
| 	 * @param bool $value | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setHorizontalCentered($value = false) { | ||||
| 		$this->_horizontalCentered = $value; | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get center page vertically | ||||
| 	 * | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function getVerticalCentered() { | ||||
| 		return $this->_verticalCentered; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set center page vertically | ||||
| 	 * | ||||
| 	 * @param bool $value | ||||
| 	 * @return PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function setVerticalCentered($value = false) { | ||||
| 		$this->_verticalCentered = $value; | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 *	Get print area | ||||
| 	 * | ||||
| 	 * @param	int		$index	Identifier for a specific print area range if several ranges have been set | ||||
| 	 *							Default behaviour, or a index value of 0, will return all ranges as a comma-separated string | ||||
| 	 *							Otherwise, the specific range identified by the value of $index will be returned | ||||
| 	 *							Print areas are numbered from 1 | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 * @return	string | ||||
| 	 */ | ||||
| 	public function getPrintArea($index = 0) { | ||||
| 		if ($index == 0) { | ||||
| 			return $this->_printArea; | ||||
| 		} | ||||
| 		$printAreas = explode(',',$this->_printArea); | ||||
| 		if (isset($printAreas[$index-1])) { | ||||
| 			return $printAreas[$index-1]; | ||||
| 		} | ||||
| 		throw new PHPExcel_Exception("Requested Print Area does not exist"); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Is print area set? | ||||
| 	 * | ||||
| 	 * @param	int		$index	Identifier for a specific print area range if several ranges have been set | ||||
| 	 *							Default behaviour, or an index value of 0, will identify whether any print range is set | ||||
| 	 *							Otherwise, existence of the range identified by the value of $index will be returned | ||||
| 	 *							Print areas are numbered from 1 | ||||
| 	 * @return	boolean | ||||
| 	 */ | ||||
| 	public function isPrintAreaSet($index = 0) { | ||||
| 		if ($index == 0) { | ||||
| 			return !is_null($this->_printArea); | ||||
| 		} | ||||
| 		$printAreas = explode(',',$this->_printArea); | ||||
| 		return isset($printAreas[$index-1]); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Clear a print area | ||||
| 	 * | ||||
| 	 * @param	int		$index	Identifier for a specific print area range if several ranges have been set | ||||
| 	 *							Default behaviour, or an index value of 0, will clear all print ranges that are set | ||||
| 	 *							Otherwise, the range identified by the value of $index will be removed from the series | ||||
| 	 *							Print areas are numbered from 1 | ||||
| 	 * @return	PHPExcel_Worksheet_PageSetup | ||||
| 	 */ | ||||
| 	public function clearPrintArea($index = 0) { | ||||
| 		if ($index == 0) { | ||||
| 			$this->_printArea = NULL; | ||||
| 		} else { | ||||
| 			$printAreas = explode(',',$this->_printArea); | ||||
| 			if (isset($printAreas[$index-1])) { | ||||
| 				unset($printAreas[$index-1]); | ||||
| 				$this->_printArea = implode(',',$printAreas); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
|     	return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set print area. e.g. 'A1:D10' or 'A1:D10,G5:M20' | ||||
| 	 * | ||||
| 	 * @param	string	$value | ||||
| 	 * @param	int		$index	Identifier for a specific print area range allowing several ranges to be set | ||||
| 	 *							When the method is "O"verwrite, then a positive integer index will overwrite that indexed | ||||
| 	 *								entry in the print areas list; a negative index value will identify which entry to | ||||
| 	 *								overwrite working bacward through the print area to the list, with the last entry as -1. | ||||
| 	 *								Specifying an index value of 0, will overwrite <b>all</b> existing print ranges. | ||||
| 	 *							When the method is "I"nsert, then a positive index will insert after that indexed entry in | ||||
| 	 *								the print areas list, while a negative index will insert before the indexed entry. | ||||
| 	 *								Specifying an index value of 0, will always append the new print range at the end of the | ||||
| 	 *								list. | ||||
| 	 *							Print areas are numbered from 1 | ||||
| 	 * @param	string	$method	Determines the method used when setting multiple print areas | ||||
| 	 *							Default behaviour, or the "O" method, overwrites existing print area | ||||
| 	 *							The "I" method, inserts the new print area before any specified index, or at the end of the list | ||||
| 	 * @return	PHPExcel_Worksheet_PageSetup | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function setPrintArea($value, $index = 0, $method = self::SETPRINTRANGE_OVERWRITE) { | ||||
| 		if (strpos($value,'!') !== false) { | ||||
| 			throw new PHPExcel_Exception('Cell coordinate must not specify a worksheet.'); | ||||
| 		} elseif (strpos($value,':') === false) { | ||||
| 			throw new PHPExcel_Exception('Cell coordinate must be a range of cells.'); | ||||
| 		} elseif (strpos($value,'$') !== false) { | ||||
| 			throw new PHPExcel_Exception('Cell coordinate must not be absolute.'); | ||||
| 		} | ||||
| 		$value = strtoupper($value); | ||||
|  | ||||
| 		if ($method == self::SETPRINTRANGE_OVERWRITE) { | ||||
| 			if ($index == 0) { | ||||
| 				$this->_printArea = $value; | ||||
| 			} else { | ||||
| 				$printAreas = explode(',',$this->_printArea); | ||||
| 				if($index < 0) { | ||||
| 					$index = count($printAreas) - abs($index) + 1; | ||||
| 				} | ||||
| 				if (($index <= 0) || ($index > count($printAreas))) { | ||||
| 		    		throw new PHPExcel_Exception('Invalid index for setting print range.'); | ||||
| 				} | ||||
| 				$printAreas[$index-1] = $value; | ||||
| 				$this->_printArea = implode(',',$printAreas); | ||||
| 			} | ||||
| 		} elseif($method == self::SETPRINTRANGE_INSERT) { | ||||
| 			if ($index == 0) { | ||||
| 				$this->_printArea .= ($this->_printArea == '') ? $value : ','.$value; | ||||
| 			} else { | ||||
| 				$printAreas = explode(',',$this->_printArea); | ||||
| 				if($index < 0) { | ||||
| 					$index = abs($index) - 1; | ||||
| 				} | ||||
| 				if ($index > count($printAreas)) { | ||||
| 		    		throw new PHPExcel_Exception('Invalid index for setting print range.'); | ||||
| 				} | ||||
| 				$printAreas = array_merge(array_slice($printAreas,0,$index),array($value),array_slice($printAreas,$index)); | ||||
| 				$this->_printArea = implode(',',$printAreas); | ||||
| 			} | ||||
| 		} else { | ||||
|     		throw new PHPExcel_Exception('Invalid method for setting print range.'); | ||||
| 		} | ||||
|  | ||||
|     	return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Add a new print area (e.g. 'A1:D10' or 'A1:D10,G5:M20') to the list of print areas | ||||
| 	 * | ||||
| 	 * @param	string	$value | ||||
| 	 * @param	int		$index	Identifier for a specific print area range allowing several ranges to be set | ||||
| 	 *							A positive index will insert after that indexed entry in the print areas list, while a | ||||
| 	 *								negative index will insert before the indexed entry. | ||||
| 	 *								Specifying an index value of 0, will always append the new print range at the end of the | ||||
| 	 *								list. | ||||
| 	 *							Print areas are numbered from 1 | ||||
| 	 * @return	PHPExcel_Worksheet_PageSetup | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function addPrintArea($value, $index = -1) { | ||||
| 		return $this->setPrintArea($value, $index, self::SETPRINTRANGE_INSERT); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set print area | ||||
| 	 * | ||||
| 	 * @param	int		$column1	Column 1 | ||||
| 	 * @param	int		$row1		Row 1 | ||||
| 	 * @param	int		$column2	Column 2 | ||||
| 	 * @param	int		$row2		Row 2 | ||||
| 	 * @param	int		$index		Identifier for a specific print area range allowing several ranges to be set | ||||
| 	 *								When the method is "O"verwrite, then a positive integer index will overwrite that indexed | ||||
| 	 *									entry in the print areas list; a negative index value will identify which entry to | ||||
| 	 *									overwrite working bacward through the print area to the list, with the last entry as -1. | ||||
| 	 *									Specifying an index value of 0, will overwrite <b>all</b> existing print ranges. | ||||
| 	 *								When the method is "I"nsert, then a positive index will insert after that indexed entry in | ||||
| 	 *									the print areas list, while a negative index will insert before the indexed entry. | ||||
| 	 *									Specifying an index value of 0, will always append the new print range at the end of the | ||||
| 	 *									list. | ||||
| 	 *								Print areas are numbered from 1 | ||||
| 	 * @param	string	$method		Determines the method used when setting multiple print areas | ||||
| 	 *								Default behaviour, or the "O" method, overwrites existing print area | ||||
| 	 *								The "I" method, inserts the new print area before any specified index, or at the end of the list | ||||
| 	 * @return	PHPExcel_Worksheet_PageSetup | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 */ | ||||
|     public function setPrintAreaByColumnAndRow($column1, $row1, $column2, $row2, $index = 0, $method = self::SETPRINTRANGE_OVERWRITE) | ||||
|     { | ||||
|     	return $this->setPrintArea(PHPExcel_Cell::stringFromColumnIndex($column1) . $row1 . ':' . PHPExcel_Cell::stringFromColumnIndex($column2) . $row2, $index, $method); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Add a new print area to the list of print areas | ||||
| 	 * | ||||
| 	 * @param	int		$column1	Start Column for the print area | ||||
| 	 * @param	int		$row1		Start Row for the print area | ||||
| 	 * @param	int		$column2	End Column for the print area | ||||
| 	 * @param	int		$row2		End Row for the print area | ||||
| 	 * @param	int		$index		Identifier for a specific print area range allowing several ranges to be set | ||||
| 	 *								A positive index will insert after that indexed entry in the print areas list, while a | ||||
| 	 *									negative index will insert before the indexed entry. | ||||
| 	 *									Specifying an index value of 0, will always append the new print range at the end of the | ||||
| 	 *									list. | ||||
| 	 *								Print areas are numbered from 1 | ||||
| 	 * @return	PHPExcel_Worksheet_PageSetup | ||||
| 	 * @throws	PHPExcel_Exception | ||||
| 	 */ | ||||
|     public function addPrintAreaByColumnAndRow($column1, $row1, $column2, $row2, $index = -1) | ||||
|     { | ||||
|     	return $this->setPrintArea(PHPExcel_Cell::stringFromColumnIndex($column1) . $row1 . ':' . PHPExcel_Cell::stringFromColumnIndex($column2) . $row2, $index, self::SETPRINTRANGE_INSERT); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get first page number | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
|     public function getFirstPageNumber() { | ||||
| 		return $this->_firstPageNumber; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set first page number | ||||
|      * | ||||
|      * @param int $value | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function setFirstPageNumber($value = null) { | ||||
| 		$this->_firstPageNumber = $value; | ||||
| 		return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Reset first page number | ||||
|      * | ||||
|      * @return PHPExcel_Worksheet_HeaderFooter | ||||
|      */ | ||||
|     public function resetFirstPageNumber() { | ||||
| 		return $this->setFirstPageNumber(null); | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										545
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/Protection.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										545
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/Protection.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,545 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_Protection | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_Protection | ||||
| { | ||||
| 	/** | ||||
| 	 * Sheet | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_sheet					= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Objects | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_objects				= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Scenarios | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_scenarios				= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Format cells | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_formatCells			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Format columns | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_formatColumns			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Format rows | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_formatRows			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert columns | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_insertColumns			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert rows | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_insertRows			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Insert hyperlinks | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_insertHyperlinks		= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete columns | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_deleteColumns			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Delete rows | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_deleteRows			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Select locked cells | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_selectLockedCells		= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Sort | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_sort					= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * AutoFilter | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_autoFilter			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Pivot tables | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_pivotTables			= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Select unlocked cells | ||||
| 	 * | ||||
| 	 * @var boolean | ||||
| 	 */ | ||||
| 	private $_selectUnlockedCells	= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Password | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_password				= ''; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Is some sort of protection enabled? | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function isProtectionEnabled() { | ||||
|     	return 	$this->_sheet || | ||||
| 				$this->_objects || | ||||
| 				$this->_scenarios || | ||||
| 				$this->_formatCells || | ||||
| 				$this->_formatColumns || | ||||
| 				$this->_formatRows || | ||||
| 				$this->_insertColumns || | ||||
| 				$this->_insertRows || | ||||
| 				$this->_insertHyperlinks || | ||||
| 				$this->_deleteColumns || | ||||
| 				$this->_deleteRows || | ||||
| 				$this->_selectLockedCells || | ||||
| 				$this->_sort || | ||||
| 				$this->_autoFilter || | ||||
| 				$this->_pivotTables || | ||||
| 				$this->_selectUnlockedCells; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Sheet | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getSheet() { | ||||
|     	return $this->_sheet; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Sheet | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setSheet($pValue = false) { | ||||
|     	$this->_sheet = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Objects | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getObjects() { | ||||
|     	return $this->_objects; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Objects | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setObjects($pValue = false) { | ||||
|     	$this->_objects = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Scenarios | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getScenarios() { | ||||
|     	return $this->_scenarios; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Scenarios | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setScenarios($pValue = false) { | ||||
|     	$this->_scenarios = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get FormatCells | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getFormatCells() { | ||||
|     	return $this->_formatCells; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set FormatCells | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setFormatCells($pValue = false) { | ||||
|     	$this->_formatCells = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get FormatColumns | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getFormatColumns() { | ||||
|     	return $this->_formatColumns; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set FormatColumns | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setFormatColumns($pValue = false) { | ||||
|     	$this->_formatColumns = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get FormatRows | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getFormatRows() { | ||||
|     	return $this->_formatRows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set FormatRows | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setFormatRows($pValue = false) { | ||||
|     	$this->_formatRows = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get InsertColumns | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getInsertColumns() { | ||||
|     	return $this->_insertColumns; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set InsertColumns | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setInsertColumns($pValue = false) { | ||||
|     	$this->_insertColumns = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get InsertRows | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getInsertRows() { | ||||
|     	return $this->_insertRows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set InsertRows | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setInsertRows($pValue = false) { | ||||
|     	$this->_insertRows = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get InsertHyperlinks | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getInsertHyperlinks() { | ||||
|     	return $this->_insertHyperlinks; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set InsertHyperlinks | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setInsertHyperlinks($pValue = false) { | ||||
|     	$this->_insertHyperlinks = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get DeleteColumns | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getDeleteColumns() { | ||||
|     	return $this->_deleteColumns; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set DeleteColumns | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setDeleteColumns($pValue = false) { | ||||
|     	$this->_deleteColumns = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get DeleteRows | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getDeleteRows() { | ||||
|     	return $this->_deleteRows; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set DeleteRows | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setDeleteRows($pValue = false) { | ||||
|     	$this->_deleteRows = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get SelectLockedCells | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getSelectLockedCells() { | ||||
|     	return $this->_selectLockedCells; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set SelectLockedCells | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setSelectLockedCells($pValue = false) { | ||||
|     	$this->_selectLockedCells = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Sort | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getSort() { | ||||
|     	return $this->_sort; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Sort | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setSort($pValue = false) { | ||||
|     	$this->_sort = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get AutoFilter | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getAutoFilter() { | ||||
|     	return $this->_autoFilter; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set AutoFilter | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setAutoFilter($pValue = false) { | ||||
|     	$this->_autoFilter = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get PivotTables | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getPivotTables() { | ||||
|     	return $this->_pivotTables; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set PivotTables | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setPivotTables($pValue = false) { | ||||
|     	$this->_pivotTables = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get SelectUnlockedCells | ||||
|      * | ||||
|      * @return boolean | ||||
|      */ | ||||
|     function getSelectUnlockedCells() { | ||||
|     	return $this->_selectUnlockedCells; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set SelectUnlockedCells | ||||
|      * | ||||
|      * @param boolean $pValue | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setSelectUnlockedCells($pValue = false) { | ||||
|     	$this->_selectUnlockedCells = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Password (hashed) | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     function getPassword() { | ||||
|     	return $this->_password; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Password | ||||
|      * | ||||
|      * @param string 	$pValue | ||||
|      * @param boolean 	$pAlreadyHashed If the password has already been hashed, set this to true | ||||
|      * @return PHPExcel_Worksheet_Protection | ||||
|      */ | ||||
|     function setPassword($pValue = '', $pAlreadyHashed = false) { | ||||
|     	if (!$pAlreadyHashed) { | ||||
|     		$pValue = PHPExcel_Shared_PasswordHasher::hashPassword($pValue); | ||||
|     	} | ||||
| 		$this->_password = $pValue; | ||||
| 		return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * 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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										92
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/Row.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										92
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/Row.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,92 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_Row | ||||
|  * | ||||
|  * Represents a row in PHPExcel_Worksheet, used by PHPExcel_Worksheet_RowIterator | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_Row | ||||
| { | ||||
| 	/** | ||||
| 	 * PHPExcel_Worksheet | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet | ||||
| 	 */ | ||||
| 	private $_parent; | ||||
|  | ||||
| 	/** | ||||
| 	 * Row index | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_rowIndex = 0; | ||||
|  | ||||
| 	/** | ||||
| 	 * Create a new row | ||||
| 	 * | ||||
| 	 * @param PHPExcel_Worksheet 		$parent | ||||
| 	 * @param int						$rowIndex | ||||
| 	 */ | ||||
| 	public function __construct(PHPExcel_Worksheet $parent = null, $rowIndex = 1) { | ||||
| 		// Set parent and row index | ||||
| 		$this->_parent 		= $parent; | ||||
| 		$this->_rowIndex 	= $rowIndex; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Destructor | ||||
| 	 */ | ||||
| 	public function __destruct() { | ||||
| 		unset($this->_parent); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get row index | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
| 	public function getRowIndex() { | ||||
| 		return $this->_rowIndex; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get cell iterator | ||||
| 	 * | ||||
| 	 * @param	string				$startColumn	The column address at which to start iterating | ||||
| 	 * @param	string				$endColumn	    Optionally, the column address at which to stop iterating | ||||
| 	 * @return PHPExcel_Worksheet_CellIterator | ||||
| 	 */ | ||||
| 	public function getCellIterator($startColumn = 'A', $endColumn = null) { | ||||
| 		return new PHPExcel_Worksheet_RowCellIterator($this->_parent, $this->_rowIndex, $startColumn, $endColumn); | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										224
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/RowCellIterator.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										224
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/RowCellIterator.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,224 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license	http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version	##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_RowCellIterator | ||||
|  * | ||||
|  * Used to iterate columns in a PHPExcel_Worksheet | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package	PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_RowCellIterator extends PHPExcel_Worksheet_CellIterator implements Iterator | ||||
| { | ||||
| 	/** | ||||
| 	 * Row index | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_rowIndex; | ||||
|  | ||||
| 	/** | ||||
| 	 * Start position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_startColumn = 0; | ||||
|  | ||||
| 	/** | ||||
| 	 * End position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	protected $_endColumn = 0; | ||||
|  | ||||
| 	/** | ||||
| 	 * Create a new column iterator | ||||
| 	 * | ||||
| 	 * @param	PHPExcel_Worksheet	$subject	    The worksheet to iterate over | ||||
|      * @param   integer             $rowIndex       The row that we want to iterate | ||||
| 	 * @param	string				$startColumn	The column address at which to start iterating | ||||
| 	 * @param	string				$endColumn	    Optionally, the column address at which to stop iterating | ||||
| 	 */ | ||||
| 	public function __construct(PHPExcel_Worksheet $subject = null, $rowIndex = 1, $startColumn = 'A', $endColumn = null) { | ||||
| 		// Set subject and row index | ||||
| 		$this->_subject = $subject; | ||||
| 		$this->_rowIndex = $rowIndex; | ||||
| 		$this->resetEnd($endColumn); | ||||
| 		$this->resetStart($startColumn); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Destructor | ||||
| 	 */ | ||||
| 	public function __destruct() { | ||||
| 		unset($this->_subject); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * (Re)Set the start column and the current column pointer | ||||
| 	 * | ||||
| 	 * @param integer	$startColumn	The column address at which to start iterating | ||||
|      * @return PHPExcel_Worksheet_RowCellIterator | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function resetStart($startColumn = 'A') { | ||||
|         $startColumnIndex = PHPExcel_Cell::columnIndexFromString($startColumn) - 1; | ||||
| 		$this->_startColumn = $startColumnIndex; | ||||
|         $this->adjustForExistingOnlyRange(); | ||||
| 		$this->seek(PHPExcel_Cell::stringFromColumnIndex($this->_startColumn)); | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * (Re)Set the end column | ||||
| 	 * | ||||
| 	 * @param string	$endColumn	The column address at which to stop iterating | ||||
|      * @return PHPExcel_Worksheet_RowCellIterator | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function resetEnd($endColumn = null) { | ||||
| 		$endColumn = ($endColumn) ? $endColumn : $this->_subject->getHighestColumn(); | ||||
| 		$this->_endColumn = PHPExcel_Cell::columnIndexFromString($endColumn) - 1; | ||||
|         $this->adjustForExistingOnlyRange(); | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the column pointer to the selected column | ||||
| 	 * | ||||
| 	 * @param string	$column	The column address to set the current pointer at | ||||
|      * @return PHPExcel_Worksheet_RowCellIterator | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function seek($column = 'A') { | ||||
|         $column = PHPExcel_Cell::columnIndexFromString($column) - 1; | ||||
|         if (($column < $this->_startColumn) || ($column > $this->_endColumn)) { | ||||
|             throw new PHPExcel_Exception("Column $column is out of range ({$this->_startColumn} - {$this->_endColumn})"); | ||||
|         } elseif ($this->_onlyExistingCells && !($this->_subject->cellExistsByColumnAndRow($column, $this->_rowIndex))) { | ||||
|             throw new PHPExcel_Exception('In "IterateOnlyExistingCells" mode and Cell does not exist'); | ||||
|         } | ||||
| 		$this->_position = $column; | ||||
|  | ||||
|         return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Rewind the iterator to the starting column | ||||
| 	 */ | ||||
| 	public function rewind() { | ||||
| 		$this->_position = $this->_startColumn; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Return the current cell in this worksheet row | ||||
| 	 * | ||||
| 	 * @return PHPExcel_Cell | ||||
| 	 */ | ||||
| 	public function current() { | ||||
| 		return $this->_subject->getCellByColumnAndRow($this->_position, $this->_rowIndex); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Return the current iterator key | ||||
| 	 * | ||||
| 	 * @return string | ||||
| 	 */ | ||||
| 	public function key() { | ||||
| 		return PHPExcel_Cell::stringFromColumnIndex($this->_position); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to its next value | ||||
| 	 */ | ||||
| 	public function next() { | ||||
|         do { | ||||
|             ++$this->_position; | ||||
|         } while (($this->_onlyExistingCells) && | ||||
|             (!$this->_subject->cellExistsByColumnAndRow($this->_position, $this->_rowIndex)) && | ||||
|             ($this->_position <= $this->_endColumn)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to its previous value | ||||
|      * | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function prev() { | ||||
|         if ($this->_position <= $this->_startColumn) { | ||||
|             throw new PHPExcel_Exception( | ||||
|                 "Column is already at the beginning of range (" .  | ||||
|                 PHPExcel_Cell::stringFromColumnIndex($this->_endColumn) . " - " .  | ||||
|                 PHPExcel_Cell::stringFromColumnIndex($this->_endColumn) . ")" | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         do { | ||||
|             --$this->_position; | ||||
|         } while (($this->_onlyExistingCells) && | ||||
|             (!$this->_subject->cellExistsByColumnAndRow($this->_position, $this->_rowIndex)) && | ||||
|             ($this->_position >= $this->_startColumn)); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Indicate if more columns exist in the worksheet range of columns that we're iterating | ||||
| 	 * | ||||
| 	 * @return boolean | ||||
| 	 */ | ||||
| 	public function valid() { | ||||
| 		return $this->_position <= $this->_endColumn; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Validate start/end values for "IterateOnlyExistingCells" mode, and adjust if necessary | ||||
| 	 * | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
|     protected function adjustForExistingOnlyRange() { | ||||
|         if ($this->_onlyExistingCells) { | ||||
|             while ((!$this->_subject->cellExistsByColumnAndRow($this->_startColumn, $this->_rowIndex)) && | ||||
|                 ($this->_startColumn <= $this->_endColumn)) { | ||||
|                 ++$this->_startColumn; | ||||
|             } | ||||
|             if ($this->_startColumn > $this->_endColumn) { | ||||
|                 throw new PHPExcel_Exception('No cells exist within the specified range'); | ||||
|             } | ||||
|             while ((!$this->_subject->cellExistsByColumnAndRow($this->_endColumn, $this->_rowIndex)) && | ||||
|                 ($this->_endColumn >= $this->_startColumn)) { | ||||
|                 --$this->_endColumn; | ||||
|             } | ||||
|             if ($this->_endColumn < $this->_startColumn) { | ||||
|                 throw new PHPExcel_Exception('No cells exist within the specified range'); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
| } | ||||
							
								
								
									
										265
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/RowDimension.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										265
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/RowDimension.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,265 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_RowDimension | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_RowDimension | ||||
| { | ||||
| 	/** | ||||
| 	 * Row index | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_rowIndex; | ||||
|  | ||||
| 	/** | ||||
| 	 * Row height (in pt) | ||||
| 	 * | ||||
| 	 * When this is set to a negative value, the row height should be ignored by IWriter | ||||
| 	 * | ||||
| 	 * @var double | ||||
| 	 */ | ||||
| 	private $_rowHeight		= -1; | ||||
|  | ||||
|  	/** | ||||
| 	 * ZeroHeight for Row? | ||||
| 	 * | ||||
| 	 * @var bool | ||||
| 	 */ | ||||
| 	private $_zeroHeight	= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Visible? | ||||
| 	 * | ||||
| 	 * @var bool | ||||
| 	 */ | ||||
| 	private $_visible		= true; | ||||
|  | ||||
| 	/** | ||||
| 	 * Outline level | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_outlineLevel	= 0; | ||||
|  | ||||
| 	/** | ||||
| 	 * Collapsed | ||||
| 	 * | ||||
| 	 * @var bool | ||||
| 	 */ | ||||
| 	private $_collapsed		= false; | ||||
|  | ||||
| 	/** | ||||
| 	 * Index to cellXf. Null value means row has no explicit cellXf format. | ||||
| 	 * | ||||
| 	 * @var int|null | ||||
| 	 */ | ||||
| 	private $_xfIndex; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_RowDimension | ||||
|      * | ||||
|      * @param int $pIndex Numeric row index | ||||
|      */ | ||||
|     public function __construct($pIndex = 0) | ||||
|     { | ||||
|     	// Initialise values | ||||
|     	$this->_rowIndex		= $pIndex; | ||||
|  | ||||
| 		// set row dimension as unformatted by default | ||||
| 		$this->_xfIndex = null; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Row Index | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getRowIndex() { | ||||
|     	return $this->_rowIndex; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Row Index | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @return PHPExcel_Worksheet_RowDimension | ||||
|      */ | ||||
|     public function setRowIndex($pValue) { | ||||
|     	$this->_rowIndex = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Row Height | ||||
|      * | ||||
|      * @return double | ||||
|      */ | ||||
|     public function getRowHeight() { | ||||
|     	return $this->_rowHeight; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Row Height | ||||
|      * | ||||
|      * @param double $pValue | ||||
|      * @return PHPExcel_Worksheet_RowDimension | ||||
|      */ | ||||
|     public function setRowHeight($pValue = -1) { | ||||
|     	$this->_rowHeight = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get ZeroHeight | ||||
| 	 * | ||||
| 	 * @return bool | ||||
| 	 */ | ||||
| 	public function getZeroHeight() { | ||||
| 		return $this->_zeroHeight; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set ZeroHeight | ||||
| 	 * | ||||
| 	 * @param bool $pValue | ||||
| 	 * @return PHPExcel_Worksheet_RowDimension | ||||
| 	 */ | ||||
| 	public function setZeroHeight($pValue = false) { | ||||
| 		$this->_zeroHeight = $pValue; | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
|     /** | ||||
|      * Get Visible | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function getVisible() { | ||||
|     	return $this->_visible; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Visible | ||||
|      * | ||||
|      * @param bool $pValue | ||||
|      * @return PHPExcel_Worksheet_RowDimension | ||||
|      */ | ||||
|     public function setVisible($pValue = true) { | ||||
|     	$this->_visible = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Outline Level | ||||
|      * | ||||
|      * @return int | ||||
|      */ | ||||
|     public function getOutlineLevel() { | ||||
|     	return $this->_outlineLevel; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Outline Level | ||||
|      * | ||||
|      * Value must be between 0 and 7 | ||||
|      * | ||||
|      * @param int $pValue | ||||
|      * @throws PHPExcel_Exception | ||||
|      * @return PHPExcel_Worksheet_RowDimension | ||||
|      */ | ||||
|     public function setOutlineLevel($pValue) { | ||||
|     	if ($pValue < 0 || $pValue > 7) { | ||||
|     		throw new PHPExcel_Exception("Outline level must range between 0 and 7."); | ||||
|     	} | ||||
|  | ||||
|     	$this->_outlineLevel = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Get Collapsed | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function getCollapsed() { | ||||
|     	return $this->_collapsed; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Set Collapsed | ||||
|      * | ||||
|      * @param bool $pValue | ||||
|      * @return PHPExcel_Worksheet_RowDimension | ||||
|      */ | ||||
|     public function setCollapsed($pValue = true) { | ||||
|     	$this->_collapsed = $pValue; | ||||
|     	return $this; | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get index to cellXf | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
| 	public function getXfIndex() | ||||
| 	{ | ||||
| 		return $this->_xfIndex; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set index to cellXf | ||||
| 	 * | ||||
| 	 * @param int $pValue | ||||
| 	 * @return PHPExcel_Worksheet_RowDimension | ||||
| 	 */ | ||||
| 	public function setXfIndex($pValue = 0) | ||||
| 	{ | ||||
| 		$this->_xfIndex = $pValue; | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										183
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/RowIterator.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										183
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/RowIterator.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,183 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license	http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version	##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_RowIterator | ||||
|  * | ||||
|  * Used to iterate rows in a PHPExcel_Worksheet | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package	PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_RowIterator implements Iterator | ||||
| { | ||||
| 	/** | ||||
| 	 * PHPExcel_Worksheet to iterate | ||||
| 	 * | ||||
| 	 * @var PHPExcel_Worksheet | ||||
| 	 */ | ||||
| 	private $_subject; | ||||
|  | ||||
| 	/** | ||||
| 	 * Current iterator position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_position = 1; | ||||
|  | ||||
| 	/** | ||||
| 	 * Start position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_startRow = 1; | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * End position | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_endRow = 1; | ||||
|  | ||||
|  | ||||
| 	/** | ||||
| 	 * Create a new row iterator | ||||
| 	 * | ||||
| 	 * @param	PHPExcel_Worksheet	$subject	The worksheet to iterate over | ||||
| 	 * @param	integer				$startRow	The row number at which to start iterating | ||||
| 	 * @param	integer				$endRow	    Optionally, the row number at which to stop iterating | ||||
| 	 */ | ||||
| 	public function __construct(PHPExcel_Worksheet $subject = null, $startRow = 1, $endRow = null) { | ||||
| 		// Set subject | ||||
| 		$this->_subject = $subject; | ||||
| 		$this->resetEnd($endRow); | ||||
| 		$this->resetStart($startRow); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Destructor | ||||
| 	 */ | ||||
| 	public function __destruct() { | ||||
| 		unset($this->_subject); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * (Re)Set the start row and the current row pointer | ||||
| 	 * | ||||
| 	 * @param integer	$startRow	The row number at which to start iterating | ||||
|      * @return PHPExcel_Worksheet_RowIterator | ||||
| 	 */ | ||||
| 	public function resetStart($startRow = 1) { | ||||
| 		$this->_startRow = $startRow; | ||||
| 		$this->seek($startRow); | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * (Re)Set the end row | ||||
| 	 * | ||||
| 	 * @param integer	$endRow	The row number at which to stop iterating | ||||
|      * @return PHPExcel_Worksheet_RowIterator | ||||
| 	 */ | ||||
| 	public function resetEnd($endRow = null) { | ||||
| 		$this->_endRow = ($endRow) ? $endRow : $this->_subject->getHighestRow(); | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the row pointer to the selected row | ||||
| 	 * | ||||
| 	 * @param integer	$row	The row number to set the current pointer at | ||||
|      * @return PHPExcel_Worksheet_RowIterator | ||||
|      * @throws PHPExcel_Exception | ||||
| 	 */ | ||||
| 	public function seek($row = 1) { | ||||
|         if (($row < $this->_startRow) || ($row > $this->_endRow)) { | ||||
|             throw new PHPExcel_Exception("Row $row is out of range ({$this->_startRow} - {$this->_endRow})"); | ||||
|         } | ||||
| 		$this->_position = $row; | ||||
|  | ||||
|         return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Rewind the iterator to the starting row | ||||
| 	 */ | ||||
| 	public function rewind() { | ||||
| 		$this->_position = $this->_startRow; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Return the current row in this worksheet | ||||
| 	 * | ||||
| 	 * @return PHPExcel_Worksheet_Row | ||||
| 	 */ | ||||
| 	public function current() { | ||||
| 		return new PHPExcel_Worksheet_Row($this->_subject, $this->_position); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Return the current iterator key | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
| 	public function key() { | ||||
| 		return $this->_position; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to its next value | ||||
| 	 */ | ||||
| 	public function next() { | ||||
| 		++$this->_position; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set the iterator to its previous value | ||||
| 	 */ | ||||
| 	public function prev() { | ||||
|         if ($this->_position <= $this->_startRow) { | ||||
|             throw new PHPExcel_Exception("Row is already at the beginning of range ({$this->_startRow} - {$this->_endRow})"); | ||||
|         } | ||||
|  | ||||
|         --$this->_position; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Indicate if more rows exist in the worksheet range of rows that we're iterating | ||||
| 	 * | ||||
| 	 * @return boolean | ||||
| 	 */ | ||||
| 	public function valid() { | ||||
| 		return $this->_position <= $this->_endRow; | ||||
| 	} | ||||
| } | ||||
							
								
								
									
										188
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/SheetView.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										188
									
								
								includes/PHPExcel/Classes/PHPExcel/Worksheet/SheetView.php
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,188 @@ | ||||
| <?php | ||||
| /** | ||||
|  * PHPExcel | ||||
|  * | ||||
|  * Copyright (c) 2006 - 2014 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_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | ||||
|  * @version    ##VERSION##, ##DATE## | ||||
|  */ | ||||
|  | ||||
|  | ||||
| /** | ||||
|  * PHPExcel_Worksheet_SheetView | ||||
|  * | ||||
|  * @category   PHPExcel | ||||
|  * @package    PHPExcel_Worksheet | ||||
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel) | ||||
|  */ | ||||
| class PHPExcel_Worksheet_SheetView | ||||
| { | ||||
|  | ||||
| 	/* Sheet View types */ | ||||
| 	const SHEETVIEW_NORMAL				= 'normal'; | ||||
| 	const SHEETVIEW_PAGE_LAYOUT			= 'pageLayout'; | ||||
| 	const SHEETVIEW_PAGE_BREAK_PREVIEW	= 'pageBreakPreview'; | ||||
|  | ||||
| 	private static $_sheetViewTypes = array( | ||||
| 		self::SHEETVIEW_NORMAL, | ||||
| 		self::SHEETVIEW_PAGE_LAYOUT, | ||||
| 		self::SHEETVIEW_PAGE_BREAK_PREVIEW, | ||||
| 	); | ||||
|  | ||||
| 	/** | ||||
| 	 * ZoomScale | ||||
| 	 * | ||||
| 	 * Valid values range from 10 to 400. | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_zoomScale			= 100; | ||||
|  | ||||
| 	/** | ||||
| 	 * ZoomScaleNormal | ||||
| 	 * | ||||
| 	 * Valid values range from 10 to 400. | ||||
| 	 * | ||||
| 	 * @var int | ||||
| 	 */ | ||||
| 	private $_zoomScaleNormal	= 100; | ||||
|  | ||||
| 	/** | ||||
| 	 * View | ||||
| 	 * | ||||
| 	 * Valid values range from 10 to 400. | ||||
| 	 * | ||||
| 	 * @var string | ||||
| 	 */ | ||||
| 	private $_sheetviewType		= self::SHEETVIEW_NORMAL; | ||||
|  | ||||
|     /** | ||||
|      * Create a new PHPExcel_Worksheet_SheetView | ||||
|      */ | ||||
|     public function __construct() | ||||
|     { | ||||
|     } | ||||
|  | ||||
| 	/** | ||||
| 	 * Get ZoomScale | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
| 	public function getZoomScale() { | ||||
| 		return $this->_zoomScale; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set ZoomScale | ||||
| 	 * | ||||
| 	 * Valid values range from 10 to 400. | ||||
| 	 * | ||||
| 	 * @param 	int 	$pValue | ||||
| 	 * @throws 	PHPExcel_Exception | ||||
| 	 * @return PHPExcel_Worksheet_SheetView | ||||
| 	 */ | ||||
| 	public function setZoomScale($pValue = 100) { | ||||
| 		// Microsoft Office Excel 2007 only allows setting a scale between 10 and 400 via the user interface, | ||||
| 		// but it is apparently still able to handle any scale >= 1 | ||||
| 		if (($pValue >= 1) || is_null($pValue)) { | ||||
| 			$this->_zoomScale = $pValue; | ||||
| 		} else { | ||||
| 			throw new PHPExcel_Exception("Scale must be greater than or equal to 1."); | ||||
| 		} | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get ZoomScaleNormal | ||||
| 	 * | ||||
| 	 * @return int | ||||
| 	 */ | ||||
| 	public function getZoomScaleNormal() { | ||||
| 		return $this->_zoomScaleNormal; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set ZoomScale | ||||
| 	 * | ||||
| 	 * Valid values range from 10 to 400. | ||||
| 	 * | ||||
| 	 * @param 	int 	$pValue | ||||
| 	 * @throws 	PHPExcel_Exception | ||||
| 	 * @return PHPExcel_Worksheet_SheetView | ||||
| 	 */ | ||||
| 	public function setZoomScaleNormal($pValue = 100) { | ||||
| 		if (($pValue >= 1) || is_null($pValue)) { | ||||
| 			$this->_zoomScaleNormal = $pValue; | ||||
| 		} else { | ||||
| 			throw new PHPExcel_Exception("Scale must be greater than or equal to 1."); | ||||
| 		} | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Get View | ||||
| 	 * | ||||
| 	 * @return string | ||||
| 	 */ | ||||
| 	public function getView() { | ||||
| 		return $this->_sheetviewType; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * Set View | ||||
| 	 * | ||||
| 	 * Valid values are | ||||
| 	 *		'normal'			self::SHEETVIEW_NORMAL | ||||
| 	 *		'pageLayout'		self::SHEETVIEW_PAGE_LAYOUT | ||||
| 	 *		'pageBreakPreview'	self::SHEETVIEW_PAGE_BREAK_PREVIEW | ||||
| 	 * | ||||
| 	 * @param 	string 	$pValue | ||||
| 	 * @throws 	PHPExcel_Exception | ||||
| 	 * @return PHPExcel_Worksheet_SheetView | ||||
| 	 */ | ||||
| 	public function setView($pValue = NULL) { | ||||
| 		//	MS Excel 2007 allows setting the view to 'normal', 'pageLayout' or 'pageBreakPreview' | ||||
| 		//		via the user interface | ||||
| 		if ($pValue === NULL) | ||||
| 			$pValue = self::SHEETVIEW_NORMAL; | ||||
| 		if (in_array($pValue, self::$_sheetViewTypes)) { | ||||
| 			$this->_sheetviewType = $pValue; | ||||
| 		} else { | ||||
| 			throw new PHPExcel_Exception("Invalid sheetview layout type."); | ||||
| 		} | ||||
|  | ||||
| 		return $this; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * 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; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
		Reference in New Issue
	
	Block a user