95 lines
2.8 KiB
PHP
95 lines
2.8 KiB
PHP
<?php
|
|
|
|
namespace PhpOffice\PhpSpreadsheetTests\Writer\Html;
|
|
|
|
use PhpOffice\PhpSpreadsheet\Spreadsheet;
|
|
use PhpOffice\PhpSpreadsheet\Worksheet\Drawing;
|
|
use PhpOffice\PhpSpreadsheet\Writer\Html;
|
|
use PhpOffice\PhpSpreadsheetTests\Functional;
|
|
|
|
class ExtendForChartsAndImagesTest extends Functional\AbstractFunctional
|
|
{
|
|
public function testEmptySheet(): void
|
|
{
|
|
$spreadsheet = new Spreadsheet();
|
|
|
|
$this->assertMaxColumnAndMaxRow($spreadsheet, 1, 1);
|
|
}
|
|
|
|
public function testSimpleSheet(): void
|
|
{
|
|
$spreadsheet = new Spreadsheet();
|
|
$sheet = $spreadsheet->getActiveSheet();
|
|
$sheet->setCellValue('B3', 'foo');
|
|
|
|
$this->assertMaxColumnAndMaxRow($spreadsheet, 2, 3);
|
|
}
|
|
|
|
public function testSheetWithExtraColumnDimensions(): void
|
|
{
|
|
$spreadsheet = new Spreadsheet();
|
|
$sheet = $spreadsheet->getActiveSheet();
|
|
$sheet->setCellValue('B3', 'foo');
|
|
|
|
// Artificially expend the sheet column count without any real cells
|
|
$sheet->getColumnDimension('E');
|
|
|
|
$this->assertMaxColumnAndMaxRow($spreadsheet, 2, 3);
|
|
}
|
|
|
|
public function testSheetWithExtraRowDimensions(): void
|
|
{
|
|
$spreadsheet = new Spreadsheet();
|
|
$sheet = $spreadsheet->getActiveSheet();
|
|
$sheet->setCellValue('B3', 'foo');
|
|
|
|
// Artificially expend the sheet row count without any real cells
|
|
$sheet->getRowDimension(5);
|
|
|
|
$this->assertMaxColumnAndMaxRow($spreadsheet, 2, 3);
|
|
}
|
|
|
|
public function testSheetWithImageBelowData(): void
|
|
{
|
|
$spreadsheet = new Spreadsheet();
|
|
$sheet = $spreadsheet->getActiveSheet();
|
|
$sheet->setCellValue('B3', 'foo');
|
|
|
|
// Add a drawing to the worksheet
|
|
$drawing = new Drawing();
|
|
$drawing->setPath('foo.png', false);
|
|
$drawing->setCoordinates('A5');
|
|
$drawing->setWorksheet($sheet);
|
|
|
|
$this->assertMaxColumnAndMaxRow($spreadsheet, 2, 5);
|
|
}
|
|
|
|
public function testSheetWithImageRightOfData(): void
|
|
{
|
|
$spreadsheet = new Spreadsheet();
|
|
$sheet = $spreadsheet->getActiveSheet();
|
|
$sheet->setCellValue('B3', 'foo');
|
|
|
|
// Add a drawing to the worksheet
|
|
$drawing = new Drawing();
|
|
$drawing->setPath('foo.png', false);
|
|
$drawing->setCoordinates('E1');
|
|
$drawing->setWorksheet($sheet);
|
|
|
|
$this->assertMaxColumnAndMaxRow($spreadsheet, 5, 3);
|
|
}
|
|
|
|
private function assertMaxColumnAndMaxRow(Spreadsheet $spreadsheet, int $expectedColumnCount, int $expectedRowCount): void
|
|
{
|
|
$writer = new Html($spreadsheet);
|
|
$html = $writer->generateHtmlAll();
|
|
|
|
$rowCount = substr_count($html, '<tr ');
|
|
self::assertSame($expectedRowCount, $rowCount);
|
|
|
|
$columnCount = substr_count($html, '<td ') / $rowCount;
|
|
|
|
self::assertSame($expectedColumnCount, $columnCount);
|
|
}
|
|
}
|