Added support for mergeCells: // mergeCells (B2:G2), you may use CellHelper::getColumnLettersFromColumnIndex() to convert from "B2" to "[1,2]" $writer->mergeCells([1,2], [6, 2]); cell height: $row->setHeight(30); shouldShrinkToFit: $style->setShouldShrinkToFit(); These changes are implemented for XLSX as that's what I need and test spout on.
65 lines
1.7 KiB
PHP
65 lines
1.7 KiB
PHP
<?php
|
|
|
|
namespace Box\Spout\Writer\XLSX\Manager;
|
|
|
|
use Box\Spout\Common\Manager\OptionsManagerAbstract;
|
|
use Box\Spout\Writer\Common\Creator\Style\StyleBuilder;
|
|
use Box\Spout\Writer\Common\Entity\Options;
|
|
|
|
/**
|
|
* Class OptionsManager
|
|
* XLSX Writer options manager
|
|
*/
|
|
class OptionsManager extends OptionsManagerAbstract
|
|
{
|
|
/** Default style font values */
|
|
const DEFAULT_FONT_SIZE = 12;
|
|
const DEFAULT_FONT_NAME = 'Calibri';
|
|
|
|
/** @var StyleBuilder Style builder */
|
|
protected $styleBuilder;
|
|
|
|
/**
|
|
* OptionsManager constructor.
|
|
* @param StyleBuilder $styleBuilder
|
|
*/
|
|
public function __construct(StyleBuilder $styleBuilder)
|
|
{
|
|
$this->styleBuilder = $styleBuilder;
|
|
parent::__construct();
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
protected function getSupportedOptions()
|
|
{
|
|
return [
|
|
Options::TEMP_FOLDER,
|
|
Options::DEFAULT_ROW_STYLE,
|
|
Options::SHOULD_CREATE_NEW_SHEETS_AUTOMATICALLY,
|
|
Options::SHOULD_USE_INLINE_STRINGS,
|
|
Options::COLUMN_WIDTHS,
|
|
Options::MERGE_CELLS,
|
|
];
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
*/
|
|
protected function setDefaultOptions()
|
|
{
|
|
$defaultRowStyle = $this->styleBuilder
|
|
->setFontSize(self::DEFAULT_FONT_SIZE)
|
|
->setFontName(self::DEFAULT_FONT_NAME)
|
|
->build();
|
|
|
|
$this->setOption(Options::TEMP_FOLDER, \sys_get_temp_dir());
|
|
$this->setOption(Options::DEFAULT_ROW_STYLE, $defaultRowStyle);
|
|
$this->setOption(Options::SHOULD_CREATE_NEW_SHEETS_AUTOMATICALLY, true);
|
|
$this->setOption(Options::SHOULD_USE_INLINE_STRINGS, true);
|
|
$this->setOption(Options::COLUMN_WIDTHS, []);
|
|
$this->setOption(Options::MERGE_CELLS, []);
|
|
}
|
|
}
|