| 
									
										
										
										
											2017-12-15 13:28:54 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace PhpOffice\PhpSpreadsheetTests\Functional; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | use PhpOffice\PhpSpreadsheet\Spreadsheet; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class ConditionalStopIfTrueTest extends AbstractFunctional | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     const COLOR_GREEN = 'FF99FF66'; | 
					
						
							|  |  |  |     const COLOR_RED = 'FFFF5050'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     public function providerFormats() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return [ | 
					
						
							|  |  |  |             ['Xlsx'], | 
					
						
							|  |  |  |         ]; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** | 
					
						
							|  |  |  |      * @dataProvider providerFormats | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * @param string $format | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2020-05-18 04:49:57 +00:00
										 |  |  |     public function testConditionalStopIfTrue($format): void | 
					
						
							| 
									
										
										
										
											2017-12-15 13:28:54 +00:00
										 |  |  |     { | 
					
						
							|  |  |  |         $pCoordinate = 'A1:A3'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // if blank cell -> no styling
 | 
					
						
							|  |  |  |         $condition0 = new \PhpOffice\PhpSpreadsheet\Style\Conditional(); | 
					
						
							|  |  |  |         $condition0->setConditionType(\PhpOffice\PhpSpreadsheet\Style\Conditional::CONDITION_EXPRESSION); | 
					
						
							|  |  |  |         $condition0->addCondition('LEN(TRIM(A1))=0'); | 
					
						
							|  |  |  |         $condition0->setStopIfTrue(true); // ! stop here
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // if value below 0.6 (matches also blank cells!) -> red background
 | 
					
						
							|  |  |  |         $condition1 = new \PhpOffice\PhpSpreadsheet\Style\Conditional(); | 
					
						
							|  |  |  |         $condition1->setConditionType(\PhpOffice\PhpSpreadsheet\Style\Conditional::CONDITION_CELLIS); | 
					
						
							|  |  |  |         $condition1->setOperatorType(\PhpOffice\PhpSpreadsheet\Style\Conditional::OPERATOR_LESSTHAN); | 
					
						
							|  |  |  |         $condition1->addCondition(0.6); | 
					
						
							|  |  |  |         $condition1->getStyle()->getFill() | 
					
						
							|  |  |  |             ->setFillType(\PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID) | 
					
						
							|  |  |  |             ->getEndColor()->setARGB(self::COLOR_RED); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // if value above 0.6 -> green background
 | 
					
						
							|  |  |  |         $condition2 = new \PhpOffice\PhpSpreadsheet\Style\Conditional(); | 
					
						
							|  |  |  |         $condition2->setConditionType(\PhpOffice\PhpSpreadsheet\Style\Conditional::CONDITION_CELLIS); | 
					
						
							|  |  |  |         $condition2->setOperatorType(\PhpOffice\PhpSpreadsheet\Style\Conditional::OPERATOR_GREATERTHAN); | 
					
						
							|  |  |  |         $condition2->addCondition(0.6); | 
					
						
							|  |  |  |         $condition2->getStyle()->getFill() | 
					
						
							|  |  |  |             ->setFillType(\PhpOffice\PhpSpreadsheet\Style\Fill::FILL_SOLID) | 
					
						
							|  |  |  |             ->getEndColor()->setARGB(self::COLOR_GREEN); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $spreadsheet = new Spreadsheet(); | 
					
						
							|  |  |  |         $spreadsheet->getActiveSheet()->getCell('A1')->setValue(0.7); | 
					
						
							|  |  |  |         $spreadsheet->getActiveSheet()->getCell('A2')->setValue(''); | 
					
						
							|  |  |  |         $spreadsheet->getActiveSheet()->getCell('A3')->setValue(0.4); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // put all three conditions in sheet
 | 
					
						
							|  |  |  |         $conditionalStyles = []; | 
					
						
							|  |  |  |         array_push($conditionalStyles, $condition0); | 
					
						
							|  |  |  |         array_push($conditionalStyles, $condition1); | 
					
						
							|  |  |  |         array_push($conditionalStyles, $condition2); | 
					
						
							|  |  |  |         $spreadsheet->getActiveSheet()->setConditionalStyles($pCoordinate, $conditionalStyles); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         $reloadedSpreadsheet = $this->writeAndReload($spreadsheet, $format); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // see if we successfully written "StopIfTrue"
 | 
					
						
							|  |  |  |         $newConditionalStyles = $reloadedSpreadsheet->getActiveSheet()->getConditionalStyles($pCoordinate); | 
					
						
							|  |  |  |         self::assertTrue($newConditionalStyles[0]->getStopIfTrue(), 'StopIfTrue should be set (=true) on first condition'); | 
					
						
							|  |  |  |         self::assertFalse($newConditionalStyles[1]->getStopIfTrue(), 'StopIfTrue should not be set (=false) on second condition'); | 
					
						
							|  |  |  |         self::assertFalse($newConditionalStyles[2]->getStopIfTrue(), 'StopIfTrue should not be set (=false) on third condition'); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |