| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- <?php
- namespace PhpOffice\PhpSpreadsheetTests;
- use PhpOffice\PhpSpreadsheet\DefinedName;
- use PhpOffice\PhpSpreadsheet\Exception as Except;
- use PhpOffice\PhpSpreadsheet\NamedRange;
- use PhpOffice\PhpSpreadsheet\Spreadsheet;
- use PHPUnit\Framework\TestCase;
- class NamedRange2Test extends TestCase
- {
- /** @var ?Spreadsheet */
- private $spreadsheet;
- protected function setUp(): void
- {
- $spreadsheet = $this->spreadsheet = new Spreadsheet();
- $worksheet1 = $spreadsheet->getActiveSheet();
- $worksheet1->setTitle('SheetOne');
- $spreadsheet->addNamedRange(
- new NamedRange('FirstRel', $worksheet1, '=A1')
- );
- $spreadsheet->addNamedRange(
- new NamedRange('FirstAbs', $worksheet1, '=$B$1')
- );
- $spreadsheet->addNamedRange(
- new NamedRange('FirstRelMult', $worksheet1, '=C1:D2')
- );
- $spreadsheet->addNamedRange(
- new NamedRange('FirstAbsMult', $worksheet1, '$E$3:$F$4')
- );
- $worksheet2 = $spreadsheet->createSheet();
- $worksheet2->setTitle('SheetTwo');
- $spreadsheet->addNamedRange(
- new NamedRange('SecondRel', $worksheet2, '=A1')
- );
- $spreadsheet->addNamedRange(
- new NamedRange('SecondAbs', $worksheet2, '=$B$1')
- );
- $spreadsheet->addNamedRange(
- new NamedRange('SecondRelMult', $worksheet2, '=C1:D2')
- );
- $spreadsheet->addNamedRange(
- new NamedRange('SecondAbsMult', $worksheet2, '$E$3:$F$4')
- );
- $spreadsheet->addDefinedName(DefinedName::createInstance('FirstFormula', $worksheet1, '=TODAY()-1'));
- $spreadsheet->addDefinedName(DefinedName::createInstance('SecondFormula', $worksheet2, '=TODAY()-2'));
- $this->spreadsheet->setActiveSheetIndex(0);
- }
- protected function tearDown(): void
- {
- if ($this->spreadsheet !== null) {
- $this->spreadsheet->disconnectWorksheets();
- $this->spreadsheet = null;
- }
- }
- private function getSpreadsheet(): Spreadsheet
- {
- if ($this->spreadsheet !== null) {
- return $this->spreadsheet;
- }
- $this->spreadsheet = new Spreadsheet();
- return $this->spreadsheet;
- }
- public function testNamedRangeSetStyle(): void
- {
- $spreadsheet = $this->getSpreadsheet();
- $sheet = $spreadsheet->getSheet(0);
- $sheet->getStyle('FirstRel')->getNumberFormat()->setFormatCode('yyyy-mm-dd');
- self::assertSame('yyyy-mm-dd', $sheet->getStyle('A1')->getNumberFormat()->getFormatCode());
- $sheet->getStyle('FirstAbs')->getFont()->setName('Georgia');
- self::assertSame('Georgia', $sheet->getStyle('B1')->getFont()->getName());
- $sheet->getStyle('FirstRelMult')->getFont()->setItalic(true);
- self::assertTrue($sheet->getStyle('D2')->getFont()->getItalic());
- $sheet->getStyle('FirstAbsMult')->getFill()->setFillType('gray125');
- self::assertSame('gray125', $sheet->getStyle('F4')->getFill()->getFillType());
- self::assertSame('none', $sheet->getStyle('A1')->getFill()->getFillType());
- $sheet = $spreadsheet->getSheet(1);
- $sheet->getStyle('SecondAbsMult')->getFill()->setFillType('lightDown');
- self::assertSame('lightDown', $sheet->getStyle('E3')->getFill()->getFillType());
- }
- /**
- * @dataProvider providerRangeOrFormula
- */
- public function testNamedRangeSetStyleBad(string $name): void
- {
- $this->expectException(Except::class);
- $spreadsheet = $this->getSpreadsheet();
- $sheet = $spreadsheet->getSheet(0);
- $sheet->getStyle($name)->getNumberFormat()->setFormatCode('yyyy-mm-dd');
- self::assertSame('yyyy-mm-dd', $sheet->getStyle('A1')->getNumberFormat()->getFormatCode());
- }
- public function providerRangeOrFormula(): array
- {
- return [
- 'wrong sheet rel' => ['SecondRel'],
- 'wrong sheet abs' => ['SecondAbs'],
- 'wrong sheet relmult' => ['SecondRelMult'],
- 'wrong sheet absmult' => ['SecondAbsMult'],
- 'wrong sheet formula' => ['SecondFormula'],
- 'right sheet formula' => ['FirstFormula'],
- 'non-existent name' => ['NonExistentName'],
- 'this sheet name' => ['SheetOne!G7'],
- 'other sheet name' => ['SheetTwo!G7'],
- 'non-existent sheet name' => ['SheetAbc!G7'],
- 'unnamed formula' => ['=2+3'],
- ];
- }
- }
|