Charts32DsvLabelsTest.php 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. <?php
  2. namespace PhpOffice\PhpSpreadsheetTests\Chart;
  3. use PhpOffice\PhpSpreadsheet\Reader\Xlsx as XlsxReader;
  4. use PhpOffice\PhpSpreadsheet\Writer\Xlsx as XlsxWriter;
  5. use PhpOffice\PhpSpreadsheetTests\Functional\AbstractFunctional;
  6. class Charts32DsvLabelsTest extends AbstractFunctional
  7. {
  8. private const DIRECTORY = 'samples' . DIRECTORY_SEPARATOR . 'templates' . DIRECTORY_SEPARATOR;
  9. public function readCharts(XlsxReader $reader): void
  10. {
  11. $reader->setIncludeCharts(true);
  12. }
  13. public function writeCharts(XlsxWriter $writer): void
  14. {
  15. $writer->setIncludeCharts(true);
  16. }
  17. public function testBar4(): void
  18. {
  19. $file = self::DIRECTORY . '32readwriteBarChart4.xlsx';
  20. $reader = new XlsxReader();
  21. $reader->setIncludeCharts(true);
  22. $spreadsheet = $reader->load($file);
  23. $sheet = $spreadsheet->getActiveSheet();
  24. self::assertSame(1, $sheet->getChartCount());
  25. /** @var callable */
  26. $callableReader = [$this, 'readCharts'];
  27. /** @var callable */
  28. $callableWriter = [$this, 'writeCharts'];
  29. $reloadedSpreadsheet = $this->writeAndReload($spreadsheet, 'Xlsx', $callableReader, $callableWriter);
  30. $spreadsheet->disconnectWorksheets();
  31. $sheet = $reloadedSpreadsheet->getActiveSheet();
  32. $charts = $sheet->getChartCollection();
  33. self::assertCount(1, $charts);
  34. $chart = $charts[0];
  35. self::assertNotNull($chart);
  36. $plotArea = $chart->getPlotArea();
  37. self::assertNotNull($plotArea);
  38. $dataSeriesArray = $plotArea->getPlotGroup();
  39. self::assertCount(1, $dataSeriesArray);
  40. $dataSeries = $dataSeriesArray[0];
  41. $dataSeriesValuesArray = $dataSeries->getPlotValues();
  42. self::assertCount(1, $dataSeriesValuesArray);
  43. $dataSeriesValues = $dataSeriesValuesArray[0];
  44. $layout = $dataSeriesValues->getLabelLayout();
  45. self::assertNotNull($layout);
  46. self::assertTrue($layout->getShowVal());
  47. $fillColor = $layout->getLabelFillColor();
  48. self::assertNotNull($fillColor);
  49. self::assertSame('schemeClr', $fillColor->getType());
  50. self::assertSame('accent1', $fillColor->getValue());
  51. $borderColor = $layout->getLabelBorderColor();
  52. self::assertNotNull($borderColor);
  53. self::assertSame('srgbClr', $borderColor->getType());
  54. self::assertSame('FFC000', $borderColor->getValue());
  55. $fontColor = $layout->getLabelFontColor();
  56. self::assertNotNull($fontColor);
  57. self::assertSame('srgbClr', $fontColor->getType());
  58. self::assertSame('FFFF00', $fontColor->getValue());
  59. self::assertEquals(
  60. [15, 73, 61, 32],
  61. $dataSeriesValues->getDataValues()
  62. );
  63. $reloadedSpreadsheet->disconnectWorksheets();
  64. }
  65. }