log('Create new Spreadsheet object'); $spreadsheet = new Spreadsheet(); // Set document properties $helper->log('Set document properties'); $spreadsheet->getProperties()->setCreator('Mark Baker') ->setLastModifiedBy('Mark Baker') ->setTitle('PhpSpreadsheet Test Document') ->setSubject('PhpSpreadsheet Test Document') ->setDescription('Test document for PhpSpreadsheet, generated using PHP classes.') ->setKeywords('office PhpSpreadsheet php') ->setCategory('Test result file'); // Create the worksheet $helper->log('Add data'); $spreadsheet->setActiveSheetIndex(0); $spreadsheet->getActiveSheet() ->setCellValue('A1', 'Blank Comparison'); $dataArray = [ ['HELLO', null], [null, 'WORLD'], ]; $spreadsheet->getActiveSheet() ->fromArray($dataArray, null, 'A2', true); // Set title row bold $helper->log('Set title row bold'); $spreadsheet->getActiveSheet()->getStyle('A1:B1')->getFont()->setBold(true); // Define some styles for our Conditionals $helper->log('Define some styles for our Conditionals'); $greenStyle = new Style(false, true); $greenStyle->getFill() ->setFillType(Fill::FILL_SOLID) ->getEndColor()->setARGB(Color::COLOR_GREEN); $greenStyle->getFont()->setColor(new Color(Color::COLOR_DARKRED)); $redStyle = new Style(false, true); $redStyle->getFill() ->setFillType(Fill::FILL_SOLID) ->getEndColor()->setARGB(Color::COLOR_RED); $redStyle->getFont()->setColor(new Color(Color::COLOR_GREEN)); // Set conditional formatting rules and styles $helper->log('Define conditional formatting and set styles'); // Set rules for Blank Comparison $cellRange = 'A2:B3'; $conditionalStyles = []; $wizardFactory = new Wizard($cellRange); /** @var Wizard\Blanks $blanksWizard */ $blanksWizard = $wizardFactory->newRule(Wizard::BLANKS); $blanksWizard->setStyle($redStyle); $conditionalStyles[] = $blanksWizard->getConditional(); $blanksWizard->notBlank() ->setStyle($greenStyle); $conditionalStyles[] = $blanksWizard->getConditional(); $spreadsheet->getActiveSheet() ->getStyle($blanksWizard->getCellRange()) ->setConditionalStyles($conditionalStyles); // Save $helper->write($spreadsheet, __FILE__);