Proyectos de Subversion Moodle

Rev

| Ultima modificación | Ver Log |

Rev Autor Línea Nro. Línea
1441 ariadna 1
<?php
2
 
3
namespace PhpOffice\PhpSpreadsheet\Worksheet;
4
 
5
use PhpOffice\PhpSpreadsheet\Cell\CellAddress;
6
use PhpOffice\PhpSpreadsheet\Cell\CellRange;
7
use PhpOffice\PhpSpreadsheet\Cell\Coordinate;
8
 
9
class AutoFit
10
{
11
    protected Worksheet $worksheet;
12
 
13
    public function __construct(Worksheet $worksheet)
14
    {
15
        $this->worksheet = $worksheet;
16
    }
17
 
18
    public function getAutoFilterIndentRanges(): array
19
    {
20
        $autoFilterIndentRanges = [];
21
        $autoFilterIndentRanges[] = $this->getAutoFilterIndentRange($this->worksheet->getAutoFilter());
22
 
23
        foreach ($this->worksheet->getTableCollection() as $table) {
24
            /** @var Table $table */
25
            if ($table->getShowHeaderRow() === true && $table->getAllowFilter() === true) {
26
                $autoFilter = $table->getAutoFilter();
27
                $autoFilterIndentRanges[] = $this->getAutoFilterIndentRange($autoFilter);
28
            }
29
        }
30
 
31
        return array_filter($autoFilterIndentRanges);
32
    }
33
 
34
    private function getAutoFilterIndentRange(AutoFilter $autoFilter): ?string
35
    {
36
        $autoFilterRange = $autoFilter->getRange();
37
        $autoFilterIndentRange = null;
38
 
39
        if (!empty($autoFilterRange)) {
40
            $autoFilterRangeBoundaries = Coordinate::rangeBoundaries($autoFilterRange);
41
            $autoFilterIndentRange = (string) new CellRange(
42
                CellAddress::fromColumnAndRow($autoFilterRangeBoundaries[0][0], $autoFilterRangeBoundaries[0][1]),
43
                CellAddress::fromColumnAndRow($autoFilterRangeBoundaries[1][0], $autoFilterRangeBoundaries[0][1])
44
            );
45
        }
46
 
47
        return $autoFilterIndentRange;
48
    }
49
}