73 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			73 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?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
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function testConditionalStopIfTrue($format)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $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');
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |