!C99Shell v. 2.5 [PHP 8 Update] [24.05.2025]!

Software: Apache/2.4.41 (Ubuntu). PHP/8.0.30 

uname -a: Linux apirnd 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64 

uid=33(www-data) gid=33(www-data) groups=33(www-data) 

Safe-mode: OFF (not secure)

/uploads/script/vendor/phpoffice/phpspreadsheet/src/PhpSpreadsheet/Writer/Xlsx/   drwxr-xr-x
Free 13.12 GB of 57.97 GB (22.64%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Self remove    Logout    


Viewing file:     Worksheet.php (52.03 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
<?php

namespace PhpOffice\PhpSpreadsheet\Writer\Xlsx;

use 
PhpOffice\PhpSpreadsheet\Cell\Cell;
use 
PhpOffice\PhpSpreadsheet\Cell\Coordinate;
use 
PhpOffice\PhpSpreadsheet\RichText\RichText;
use 
PhpOffice\PhpSpreadsheet\Shared\StringHelper;
use 
PhpOffice\PhpSpreadsheet\Shared\XMLWriter;
use 
PhpOffice\PhpSpreadsheet\Style\Conditional;
use 
PhpOffice\PhpSpreadsheet\Worksheet\AutoFilter\Column;
use 
PhpOffice\PhpSpreadsheet\Worksheet\AutoFilter\Column\Rule;
use 
PhpOffice\PhpSpreadsheet\Worksheet\SheetView;
use 
PhpOffice\PhpSpreadsheet\Worksheet\Worksheet as PhpspreadsheetWorksheet;

class 
Worksheet extends WriterPart
{
    
/**
     * Write worksheet to XML format.
     *
     * @param string[] $pStringTable
     * @param bool $includeCharts Flag indicating if we should write charts
     *
     * @return string XML Output
     */
    
public function writeWorksheet(PhpspreadsheetWorksheet $pSheet$pStringTable null$includeCharts false)
    {
        
// Create XML writer
        
$objWriter null;
        if (
$this->getParentWriter()->getUseDiskCaching()) {
            
$objWriter = new XMLWriter(XMLWriter::STORAGE_DISK$this->getParentWriter()->getDiskCachingDirectory());
        } else {
            
$objWriter = new XMLWriter(XMLWriter::STORAGE_MEMORY);
        }

        
// XML header
        
$objWriter->startDocument('1.0''UTF-8''yes');

        
// Worksheet
        
$objWriter->startElement('worksheet');
        
$objWriter->writeAttribute('xml:space''preserve');
        
$objWriter->writeAttribute('xmlns''http://schemas.openxmlformats.org/spreadsheetml/2006/main');
        
$objWriter->writeAttribute('xmlns:r''http://schemas.openxmlformats.org/officeDocument/2006/relationships');

        
$objWriter->writeAttribute('xmlns:xdr''http://schemas.openxmlformats.org/drawingml/2006/spreadsheetDrawing');
        
$objWriter->writeAttribute('xmlns:x14''http://schemas.microsoft.com/office/spreadsheetml/2009/9/main');
        
$objWriter->writeAttribute('xmlns:mc''http://schemas.openxmlformats.org/markup-compatibility/2006');
        
$objWriter->writeAttribute('mc:Ignorable''x14ac');
        
$objWriter->writeAttribute('xmlns:x14ac''http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac');

        
// sheetPr
        
$this->writeSheetPr($objWriter$pSheet);

        
// Dimension
        
$this->writeDimension($objWriter$pSheet);

        
// sheetViews
        
$this->writeSheetViews($objWriter$pSheet);

        
// sheetFormatPr
        
$this->writeSheetFormatPr($objWriter$pSheet);

        
// cols
        
$this->writeCols($objWriter$pSheet);

        
// sheetData
        
$this->writeSheetData($objWriter$pSheet$pStringTable);

        
// sheetProtection
        
$this->writeSheetProtection($objWriter$pSheet);

        
// protectedRanges
        
$this->writeProtectedRanges($objWriter$pSheet);

        
// autoFilter
        
$this->writeAutoFilter($objWriter$pSheet);

        
// mergeCells
        
$this->writeMergeCells($objWriter$pSheet);

        
// conditionalFormatting
        
$this->writeConditionalFormatting($objWriter$pSheet);

        
// dataValidations
        
$this->writeDataValidations($objWriter$pSheet);

        
// hyperlinks
        
$this->writeHyperlinks($objWriter$pSheet);

        
// Print options
        
$this->writePrintOptions($objWriter$pSheet);

        
// Page margins
        
$this->writePageMargins($objWriter$pSheet);

        
// Page setup
        
$this->writePageSetup($objWriter$pSheet);

        
// Header / footer
        
$this->writeHeaderFooter($objWriter$pSheet);

        
// Breaks
        
$this->writeBreaks($objWriter$pSheet);

        
// Drawings and/or Charts
        
$this->writeDrawings($objWriter$pSheet$includeCharts);

        
// LegacyDrawing
        
$this->writeLegacyDrawing($objWriter$pSheet);

        
// LegacyDrawingHF
        
$this->writeLegacyDrawingHF($objWriter$pSheet);

        
// AlternateContent
        
$this->writeAlternateContent($objWriter$pSheet);

        
$objWriter->endElement();

        
// Return
        
return $objWriter->getData();
    }

    
/**
     * Write SheetPr.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeSheetPr(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// sheetPr
        
$objWriter->startElement('sheetPr');
        if (
$pSheet->getParent()->hasMacros()) {
            
//if the workbook have macros, we need to have codeName for the sheet
            
if (!$pSheet->hasCodeName()) {
                
$pSheet->setCodeName($pSheet->getTitle());
            }
            
$objWriter->writeAttribute('codeName'$pSheet->getCodeName());
        }
        
$autoFilterRange $pSheet->getAutoFilter()->getRange();
        if (!empty(
$autoFilterRange)) {
            
$objWriter->writeAttribute('filterMode'1);
            
$pSheet->getAutoFilter()->showHideRows();
        }

        
// tabColor
        
if ($pSheet->isTabColorSet()) {
            
$objWriter->startElement('tabColor');
            
$objWriter->writeAttribute('rgb'$pSheet->getTabColor()->getARGB());
            
$objWriter->endElement();
        }

        
// outlinePr
        
$objWriter->startElement('outlinePr');
        
$objWriter->writeAttribute('summaryBelow', ($pSheet->getShowSummaryBelow() ? '1' '0'));
        
$objWriter->writeAttribute('summaryRight', ($pSheet->getShowSummaryRight() ? '1' '0'));
        
$objWriter->endElement();

        
// pageSetUpPr
        
if ($pSheet->getPageSetup()->getFitToPage()) {
            
$objWriter->startElement('pageSetUpPr');
            
$objWriter->writeAttribute('fitToPage''1');
            
$objWriter->endElement();
        }

        
$objWriter->endElement();
    }

    
/**
     * Write Dimension.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeDimension(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// dimension
        
$objWriter->startElement('dimension');
        
$objWriter->writeAttribute('ref'$pSheet->calculateWorksheetDimension());
        
$objWriter->endElement();
    }

    
/**
     * Write SheetViews.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeSheetViews(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// sheetViews
        
$objWriter->startElement('sheetViews');

        
// Sheet selected?
        
$sheetSelected false;
        if (
$this->getParentWriter()->getSpreadsheet()->getIndex($pSheet) == $this->getParentWriter()->getSpreadsheet()->getActiveSheetIndex()) {
            
$sheetSelected true;
        }

        
// sheetView
        
$objWriter->startElement('sheetView');
        
$objWriter->writeAttribute('tabSelected'$sheetSelected '1' '0');
        
$objWriter->writeAttribute('workbookViewId''0');

        
// Zoom scales
        
if ($pSheet->getSheetView()->getZoomScale() != 100) {
            
$objWriter->writeAttribute('zoomScale'$pSheet->getSheetView()->getZoomScale());
        }
        if (
$pSheet->getSheetView()->getZoomScaleNormal() != 100) {
            
$objWriter->writeAttribute('zoomScaleNormal'$pSheet->getSheetView()->getZoomScaleNormal());
        }

        
// Show zeros (Excel also writes this attribute only if set to false)
        
if ($pSheet->getSheetView()->getShowZeros() === false) {
            
$objWriter->writeAttribute('showZeros'0);
        }

        
// View Layout Type
        
if ($pSheet->getSheetView()->getView() !== SheetView::SHEETVIEW_NORMAL) {
            
$objWriter->writeAttribute('view'$pSheet->getSheetView()->getView());
        }

        
// Gridlines
        
if ($pSheet->getShowGridlines()) {
            
$objWriter->writeAttribute('showGridLines''true');
        } else {
            
$objWriter->writeAttribute('showGridLines''false');
        }

        
// Row and column headers
        
if ($pSheet->getShowRowColHeaders()) {
            
$objWriter->writeAttribute('showRowColHeaders''1');
        } else {
            
$objWriter->writeAttribute('showRowColHeaders''0');
        }

        
// Right-to-left
        
if ($pSheet->getRightToLeft()) {
            
$objWriter->writeAttribute('rightToLeft''true');
        }

        
$activeCell $pSheet->getActiveCell();
        
$sqref $pSheet->getSelectedCells();

        
// Pane
        
$pane '';
        if (
$pSheet->getFreezePane()) {
            [
$xSplit$ySplit] = Coordinate::coordinateFromString($pSheet->getFreezePane());
            
$xSplit Coordinate::columnIndexFromString($xSplit);
            --
$xSplit;
            --
$ySplit;

            
$topLeftCell $pSheet->getTopLeftCell();

            
// pane
            
$pane 'topRight';
            
$objWriter->startElement('pane');
            if (
$xSplit 0) {
                
$objWriter->writeAttribute('xSplit'$xSplit);
            }
            if (
$ySplit 0) {
                
$objWriter->writeAttribute('ySplit'$ySplit);
                
$pane = ($xSplit 0) ? 'bottomRight' 'bottomLeft';
            }
            
$objWriter->writeAttribute('topLeftCell'$topLeftCell);
            
$objWriter->writeAttribute('activePane'$pane);
            
$objWriter->writeAttribute('state''frozen');
            
$objWriter->endElement();

            if ((
$xSplit 0) && ($ySplit 0)) {
                
//    Write additional selections if more than two panes (ie both an X and a Y split)
                
$objWriter->startElement('selection');
                
$objWriter->writeAttribute('pane''topRight');
                
$objWriter->endElement();
                
$objWriter->startElement('selection');
                
$objWriter->writeAttribute('pane''bottomLeft');
                
$objWriter->endElement();
            }
        }

        
// Selection
        // Only need to write selection element if we have a split pane
        // We cheat a little by over-riding the active cell selection, setting it to the split cell
        
$objWriter->startElement('selection');
        if (
$pane != '') {
            
$objWriter->writeAttribute('pane'$pane);
        }
        
$objWriter->writeAttribute('activeCell'$activeCell);
        
$objWriter->writeAttribute('sqref'$sqref);
        
$objWriter->endElement();

        
$objWriter->endElement();

        
$objWriter->endElement();
    }

    
/**
     * Write SheetFormatPr.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeSheetFormatPr(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// sheetFormatPr
        
$objWriter->startElement('sheetFormatPr');

        
// Default row height
        
if ($pSheet->getDefaultRowDimension()->getRowHeight() >= 0) {
            
$objWriter->writeAttribute('customHeight''true');
            
$objWriter->writeAttribute('defaultRowHeight'StringHelper::formatNumber($pSheet->getDefaultRowDimension()->getRowHeight()));
        } else {
            
$objWriter->writeAttribute('defaultRowHeight''14.4');
        }

        
// Set Zero Height row
        
if (
            (string) 
$pSheet->getDefaultRowDimension()->getZeroHeight() === '1' ||
            
strtolower((string) $pSheet->getDefaultRowDimension()->getZeroHeight()) == 'true'
        
) {
            
$objWriter->writeAttribute('zeroHeight''1');
        }

        
// Default column width
        
if ($pSheet->getDefaultColumnDimension()->getWidth() >= 0) {
            
$objWriter->writeAttribute('defaultColWidth'StringHelper::formatNumber($pSheet->getDefaultColumnDimension()->getWidth()));
        }

        
// Outline level - row
        
$outlineLevelRow 0;
        foreach (
$pSheet->getRowDimensions() as $dimension) {
            if (
$dimension->getOutlineLevel() > $outlineLevelRow) {
                
$outlineLevelRow $dimension->getOutlineLevel();
            }
        }
        
$objWriter->writeAttribute('outlineLevelRow', (int) $outlineLevelRow);

        
// Outline level - column
        
$outlineLevelCol 0;
        foreach (
$pSheet->getColumnDimensions() as $dimension) {
            if (
$dimension->getOutlineLevel() > $outlineLevelCol) {
                
$outlineLevelCol $dimension->getOutlineLevel();
            }
        }
        
$objWriter->writeAttribute('outlineLevelCol', (int) $outlineLevelCol);

        
$objWriter->endElement();
    }

    
/**
     * Write Cols.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeCols(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// cols
        
if (count($pSheet->getColumnDimensions()) > 0) {
            
$objWriter->startElement('cols');

            
$pSheet->calculateColumnWidths();

            
// Loop through column dimensions
            
foreach ($pSheet->getColumnDimensions() as $colDimension) {
                
// col
                
$objWriter->startElement('col');
                
$objWriter->writeAttribute('min'Coordinate::columnIndexFromString($colDimension->getColumnIndex()));
                
$objWriter->writeAttribute('max'Coordinate::columnIndexFromString($colDimension->getColumnIndex()));

                if (
$colDimension->getWidth() < 0) {
                    
// No width set, apply default of 10
                    
$objWriter->writeAttribute('width''9.10');
                } else {
                    
// Width set
                    
$objWriter->writeAttribute('width'StringHelper::formatNumber($colDimension->getWidth()));
                }

                
// Column visibility
                
if ($colDimension->getVisible() === false) {
                    
$objWriter->writeAttribute('hidden''true');
                }

                
// Auto size?
                
if ($colDimension->getAutoSize()) {
                    
$objWriter->writeAttribute('bestFit''true');
                }

                
// Custom width?
                
if ($colDimension->getWidth() != $pSheet->getDefaultColumnDimension()->getWidth()) {
                    
$objWriter->writeAttribute('customWidth''true');
                }

                
// Collapsed
                
if ($colDimension->getCollapsed() === true) {
                    
$objWriter->writeAttribute('collapsed''true');
                }

                
// Outline level
                
if ($colDimension->getOutlineLevel() > 0) {
                    
$objWriter->writeAttribute('outlineLevel'$colDimension->getOutlineLevel());
                }

                
// Style
                
$objWriter->writeAttribute('style'$colDimension->getXfIndex());

                
$objWriter->endElement();
            }

            
$objWriter->endElement();
        }
    }

    
/**
     * Write SheetProtection.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeSheetProtection(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// sheetProtection
        
$objWriter->startElement('sheetProtection');

        
$protection $pSheet->getProtection();

        if (
$protection->getAlgorithm()) {
            
$objWriter->writeAttribute('algorithmName'$protection->getAlgorithm());
            
$objWriter->writeAttribute('hashValue'$protection->getPassword());
            
$objWriter->writeAttribute('saltValue'$protection->getSalt());
            
$objWriter->writeAttribute('spinCount'$protection->getSpinCount());
        } elseif (
$protection->getPassword() !== '') {
            
$objWriter->writeAttribute('password'$protection->getPassword());
        }

        
$objWriter->writeAttribute('sheet', ($protection->getSheet() ? 'true' 'false'));
        
$objWriter->writeAttribute('objects', ($protection->getObjects() ? 'true' 'false'));
        
$objWriter->writeAttribute('scenarios', ($protection->getScenarios() ? 'true' 'false'));
        
$objWriter->writeAttribute('formatCells', ($protection->getFormatCells() ? 'true' 'false'));
        
$objWriter->writeAttribute('formatColumns', ($protection->getFormatColumns() ? 'true' 'false'));
        
$objWriter->writeAttribute('formatRows', ($protection->getFormatRows() ? 'true' 'false'));
        
$objWriter->writeAttribute('insertColumns', ($protection->getInsertColumns() ? 'true' 'false'));
        
$objWriter->writeAttribute('insertRows', ($protection->getInsertRows() ? 'true' 'false'));
        
$objWriter->writeAttribute('insertHyperlinks', ($protection->getInsertHyperlinks() ? 'true' 'false'));
        
$objWriter->writeAttribute('deleteColumns', ($protection->getDeleteColumns() ? 'true' 'false'));
        
$objWriter->writeAttribute('deleteRows', ($protection->getDeleteRows() ? 'true' 'false'));
        
$objWriter->writeAttribute('selectLockedCells', ($protection->getSelectLockedCells() ? 'true' 'false'));
        
$objWriter->writeAttribute('sort', ($protection->getSort() ? 'true' 'false'));
        
$objWriter->writeAttribute('autoFilter', ($protection->getAutoFilter() ? 'true' 'false'));
        
$objWriter->writeAttribute('pivotTables', ($protection->getPivotTables() ? 'true' 'false'));
        
$objWriter->writeAttribute('selectUnlockedCells', ($protection->getSelectUnlockedCells() ? 'true' 'false'));
        
$objWriter->endElement();
    }

    private static function 
writeAttributeIf(XMLWriter $objWriter$conditionstring $attrstring $val): void
    
{
        if (
$condition) {
            
$objWriter->writeAttribute($attr$val);
        }
    }

    private static function 
writeElementIf(XMLWriter $objWriter$conditionstring $attrstring $val): void
    
{
        if (
$condition) {
            
$objWriter->writeElement($attr$val);
        }
    }

    private static function 
writeOtherCondElements(XMLWriter $objWriterConditional $conditionalstring $cellCoordinate): void
    
{
        if (
            
$conditional->getConditionType() == Conditional::CONDITION_CELLIS
            
|| $conditional->getConditionType() == Conditional::CONDITION_CONTAINSTEXT
            
|| $conditional->getConditionType() == Conditional::CONDITION_EXPRESSION
        
) {
            foreach (
$conditional->getConditions() as $formula) {
                
// Formula
                
$objWriter->writeElement('formula'Xlfn::addXlfn($formula));
            }
        } elseif (
$conditional->getConditionType() == Conditional::CONDITION_CONTAINSBLANKS) {
            
// formula copied from ms xlsx xml source file
            
$objWriter->writeElement('formula''LEN(TRIM(' $cellCoordinate '))=0');
        } elseif (
$conditional->getConditionType() == Conditional::CONDITION_NOTCONTAINSBLANKS) {
            
// formula copied from ms xlsx xml source file
            
$objWriter->writeElement('formula''LEN(TRIM(' $cellCoordinate '))>0');
        }
    }

    private static function 
writeTextCondElements(XMLWriter $objWriterConditional $conditionalstring $cellCoordinate): void
    
{
        
$txt $conditional->getText();
        if (
$txt !== null) {
            
$objWriter->writeAttribute('text'$txt);
            if (
$conditional->getOperatorType() == Conditional::OPERATOR_CONTAINSTEXT) {
                
$objWriter->writeElement('formula''NOT(ISERROR(SEARCH("' $txt '",' $cellCoordinate ')))');
            } elseif (
$conditional->getOperatorType() == Conditional::OPERATOR_BEGINSWITH) {
                
$objWriter->writeElement('formula''LEFT(' $cellCoordinate ',' strlen($txt) . ')="' $txt '"');
            } elseif (
$conditional->getOperatorType() == Conditional::OPERATOR_ENDSWITH) {
                
$objWriter->writeElement('formula''RIGHT(' $cellCoordinate ',' strlen($txt) . ')="' $txt '"');
            } elseif (
$conditional->getOperatorType() == Conditional::OPERATOR_NOTCONTAINS) {
                
$objWriter->writeElement('formula''ISERROR(SEARCH("' $txt '",' $cellCoordinate '))');
            }
        }
    }

    
/**
     * Write ConditionalFormatting.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeConditionalFormatting(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// Conditional id
        
$id 1;

        
// Loop through styles in the current worksheet
        
foreach ($pSheet->getConditionalStylesCollection() as $cellCoordinate => $conditionalStyles) {
            foreach (
$conditionalStyles as $conditional) {
                
// WHY was this again?
                // if ($this->getParentWriter()->getStylesConditionalHashTable()->getIndexForHashCode($conditional->getHashCode()) == '') {
                //    continue;
                // }
                
if ($conditional->getConditionType() != Conditional::CONDITION_NONE) {
                    
// conditionalFormatting
                    
$objWriter->startElement('conditionalFormatting');
                    
$objWriter->writeAttribute('sqref'$cellCoordinate);

                    
// cfRule
                    
$objWriter->startElement('cfRule');
                    
$objWriter->writeAttribute('type'$conditional->getConditionType());
                    
$objWriter->writeAttribute('dxfId'$this->getParentWriter()->getStylesConditionalHashTable()->getIndexForHashCode($conditional->getHashCode()));
                    
$objWriter->writeAttribute('priority'$id++);

                    
self::writeAttributeif(
                        
$objWriter,
                        (
$conditional->getConditionType() == Conditional::CONDITION_CELLIS || $conditional->getConditionType() == Conditional::CONDITION_CONTAINSTEXT)
                        && 
$conditional->getOperatorType() != Conditional::OPERATOR_NONE,
                        
'operator',
                        
$conditional->getOperatorType()
                    );

                    
self::writeAttributeIf($objWriter$conditional->getStopIfTrue(), 'stopIfTrue''1');

                    if (
$conditional->getConditionType() == Conditional::CONDITION_CONTAINSTEXT) {
                        
self::writeTextCondElements($objWriter$conditional$cellCoordinate);
                    } else {
                        
self::writeOtherCondElements($objWriter$conditional$cellCoordinate);
                    }

                    
$objWriter->endElement();

                    
$objWriter->endElement();
                }
            }
        }
    }

    
/**
     * Write DataValidations.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeDataValidations(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// Datavalidation collection
        
$dataValidationCollection $pSheet->getDataValidationCollection();

        
// Write data validations?
        
if (!empty($dataValidationCollection)) {
            
$dataValidationCollection Coordinate::mergeRangesInCollection($dataValidationCollection);
            
$objWriter->startElement('dataValidations');
            
$objWriter->writeAttribute('count'count($dataValidationCollection));

            foreach (
$dataValidationCollection as $coordinate => $dv) {
                
$objWriter->startElement('dataValidation');

                if (
$dv->getType() != '') {
                    
$objWriter->writeAttribute('type'$dv->getType());
                }

                if (
$dv->getErrorStyle() != '') {
                    
$objWriter->writeAttribute('errorStyle'$dv->getErrorStyle());
                }

                if (
$dv->getOperator() != '') {
                    
$objWriter->writeAttribute('operator'$dv->getOperator());
                }

                
$objWriter->writeAttribute('allowBlank', ($dv->getAllowBlank() ? '1' '0'));
                
$objWriter->writeAttribute('showDropDown', (!$dv->getShowDropDown() ? '1' '0'));
                
$objWriter->writeAttribute('showInputMessage', ($dv->getShowInputMessage() ? '1' '0'));
                
$objWriter->writeAttribute('showErrorMessage', ($dv->getShowErrorMessage() ? '1' '0'));

                if (
$dv->getErrorTitle() !== '') {
                    
$objWriter->writeAttribute('errorTitle'$dv->getErrorTitle());
                }
                if (
$dv->getError() !== '') {
                    
$objWriter->writeAttribute('error'$dv->getError());
                }
                if (
$dv->getPromptTitle() !== '') {
                    
$objWriter->writeAttribute('promptTitle'$dv->getPromptTitle());
                }
                if (
$dv->getPrompt() !== '') {
                    
$objWriter->writeAttribute('prompt'$dv->getPrompt());
                }

                
$objWriter->writeAttribute('sqref'$coordinate);

                if (
$dv->getFormula1() !== '') {
                    
$objWriter->writeElement('formula1'$dv->getFormula1());
                }
                if (
$dv->getFormula2() !== '') {
                    
$objWriter->writeElement('formula2'$dv->getFormula2());
                }

                
$objWriter->endElement();
            }

            
$objWriter->endElement();
        }
    }

    
/**
     * Write Hyperlinks.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeHyperlinks(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// Hyperlink collection
        
$hyperlinkCollection $pSheet->getHyperlinkCollection();

        
// Relation ID
        
$relationId 1;

        
// Write hyperlinks?
        
if (!empty($hyperlinkCollection)) {
            
$objWriter->startElement('hyperlinks');

            foreach (
$hyperlinkCollection as $coordinate => $hyperlink) {
                
$objWriter->startElement('hyperlink');

                
$objWriter->writeAttribute('ref'$coordinate);
                if (!
$hyperlink->isInternal()) {
                    
$objWriter->writeAttribute('r:id''rId_hyperlink_' $relationId);
                    ++
$relationId;
                } else {
                    
$objWriter->writeAttribute('location'str_replace('sheet://'''$hyperlink->getUrl()));
                }

                if (
$hyperlink->getTooltip() !== '') {
                    
$objWriter->writeAttribute('tooltip'$hyperlink->getTooltip());
                    
$objWriter->writeAttribute('display'$hyperlink->getTooltip());
                }

                
$objWriter->endElement();
            }

            
$objWriter->endElement();
        }
    }

    
/**
     * Write ProtectedRanges.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeProtectedRanges(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        if (
count($pSheet->getProtectedCells()) > 0) {
            
// protectedRanges
            
$objWriter->startElement('protectedRanges');

            
// Loop protectedRanges
            
foreach ($pSheet->getProtectedCells() as $protectedCell => $passwordHash) {
                
// protectedRange
                
$objWriter->startElement('protectedRange');
                
$objWriter->writeAttribute('name''p' md5($protectedCell));
                
$objWriter->writeAttribute('sqref'$protectedCell);
                if (!empty(
$passwordHash)) {
                    
$objWriter->writeAttribute('password'$passwordHash);
                }
                
$objWriter->endElement();
            }

            
$objWriter->endElement();
        }
    }

    
/**
     * Write MergeCells.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeMergeCells(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        if (
count($pSheet->getMergeCells()) > 0) {
            
// mergeCells
            
$objWriter->startElement('mergeCells');

            
// Loop mergeCells
            
foreach ($pSheet->getMergeCells() as $mergeCell) {
                
// mergeCell
                
$objWriter->startElement('mergeCell');
                
$objWriter->writeAttribute('ref'$mergeCell);
                
$objWriter->endElement();
            }

            
$objWriter->endElement();
        }
    }

    
/**
     * Write PrintOptions.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writePrintOptions(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// printOptions
        
$objWriter->startElement('printOptions');

        
$objWriter->writeAttribute('gridLines', ($pSheet->getPrintGridlines() ? 'true' 'false'));
        
$objWriter->writeAttribute('gridLinesSet''true');

        if (
$pSheet->getPageSetup()->getHorizontalCentered()) {
            
$objWriter->writeAttribute('horizontalCentered''true');
        }

        if (
$pSheet->getPageSetup()->getVerticalCentered()) {
            
$objWriter->writeAttribute('verticalCentered''true');
        }

        
$objWriter->endElement();
    }

    
/**
     * Write PageMargins.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writePageMargins(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// pageMargins
        
$objWriter->startElement('pageMargins');
        
$objWriter->writeAttribute('left'StringHelper::formatNumber($pSheet->getPageMargins()->getLeft()));
        
$objWriter->writeAttribute('right'StringHelper::formatNumber($pSheet->getPageMargins()->getRight()));
        
$objWriter->writeAttribute('top'StringHelper::formatNumber($pSheet->getPageMargins()->getTop()));
        
$objWriter->writeAttribute('bottom'StringHelper::formatNumber($pSheet->getPageMargins()->getBottom()));
        
$objWriter->writeAttribute('header'StringHelper::formatNumber($pSheet->getPageMargins()->getHeader()));
        
$objWriter->writeAttribute('footer'StringHelper::formatNumber($pSheet->getPageMargins()->getFooter()));
        
$objWriter->endElement();
    }

    
/**
     * Write AutoFilter.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeAutoFilter(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
$autoFilterRange $pSheet->getAutoFilter()->getRange();
        if (!empty(
$autoFilterRange)) {
            
// autoFilter
            
$objWriter->startElement('autoFilter');

            
// Strip any worksheet reference from the filter coordinates
            
$range Coordinate::splitRange($autoFilterRange);
            
$range $range[0];
            
//    Strip any worksheet ref
            
[$ws$range[0]] = PhpspreadsheetWorksheet::extractSheetTitle($range[0], true);
            
$range implode(':'$range);

            
$objWriter->writeAttribute('ref'str_replace('$'''$range));

            
$columns $pSheet->getAutoFilter()->getColumns();
            if (
count($columns) > 0) {
                foreach (
$columns as $columnID => $column) {
                    
$rules $column->getRules();
                    if (
count($rules) > 0) {
                        
$objWriter->startElement('filterColumn');
                        
$objWriter->writeAttribute('colId'$pSheet->getAutoFilter()->getColumnOffset($columnID));

                        
$objWriter->startElement($column->getFilterType());
                        if (
$column->getJoin() == Column::AUTOFILTER_COLUMN_JOIN_AND) {
                            
$objWriter->writeAttribute('and'1);
                        }

                        foreach (
$rules as $rule) {
                            if (
                                (
$column->getFilterType() === Column::AUTOFILTER_FILTERTYPE_FILTER) &&
                                (
$rule->getOperator() === Rule::AUTOFILTER_COLUMN_RULE_EQUAL) &&
                                (
$rule->getValue() === '')
                            ) {
                                
//    Filter rule for Blanks
                                
$objWriter->writeAttribute('blank'1);
                            } elseif (
$rule->getRuleType() === Rule::AUTOFILTER_RULETYPE_DYNAMICFILTER) {
                                
//    Dynamic Filter Rule
                                
$objWriter->writeAttribute('type'$rule->getGrouping());
                                
$val $column->getAttribute('val');
                                if (
$val !== null) {
                                    
$objWriter->writeAttribute('val'$val);
                                }
                                
$maxVal $column->getAttribute('maxVal');
                                if (
$maxVal !== null) {
                                    
$objWriter->writeAttribute('maxVal'$maxVal);
                                }
                            } elseif (
$rule->getRuleType() === Rule::AUTOFILTER_RULETYPE_TOPTENFILTER) {
                                
//    Top 10 Filter Rule
                                
$objWriter->writeAttribute('val'$rule->getValue());
                                
$objWriter->writeAttribute('percent', (($rule->getOperator() === Rule::AUTOFILTER_COLUMN_RULE_TOPTEN_PERCENT) ? '1' '0'));
                                
$objWriter->writeAttribute('top', (($rule->getGrouping() === Rule::AUTOFILTER_COLUMN_RULE_TOPTEN_TOP) ? '1' '0'));
                            } else {
                                
//    Filter, DateGroupItem or CustomFilter
                                
$objWriter->startElement($rule->getRuleType());

                                if (
$rule->getOperator() !== Rule::AUTOFILTER_COLUMN_RULE_EQUAL) {
                                    
$objWriter->writeAttribute('operator'$rule->getOperator());
                                }
                                if (
$rule->getRuleType() === Rule::AUTOFILTER_RULETYPE_DATEGROUP) {
                                    
// Date Group filters
                                    
foreach ($rule->getValue() as $key => $value) {
                                        if (
$value '') {
                                            
$objWriter->writeAttribute($key$value);
                                        }
                                    }
                                    
$objWriter->writeAttribute('dateTimeGrouping'$rule->getGrouping());
                                } else {
                                    
$objWriter->writeAttribute('val'$rule->getValue());
                                }

                                
$objWriter->endElement();
                            }
                        }

                        
$objWriter->endElement();

                        
$objWriter->endElement();
                    }
                }
            }
            
$objWriter->endElement();
        }
    }

    
/**
     * Write PageSetup.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writePageSetup(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// pageSetup
        
$objWriter->startElement('pageSetup');
        
$objWriter->writeAttribute('paperSize'$pSheet->getPageSetup()->getPaperSize());
        
$objWriter->writeAttribute('orientation'$pSheet->getPageSetup()->getOrientation());

        if (
$pSheet->getPageSetup()->getScale() !== null) {
            
$objWriter->writeAttribute('scale'$pSheet->getPageSetup()->getScale());
        }
        if (
$pSheet->getPageSetup()->getFitToHeight() !== null) {
            
$objWriter->writeAttribute('fitToHeight'$pSheet->getPageSetup()->getFitToHeight());
        } else {
            
$objWriter->writeAttribute('fitToHeight''0');
        }
        if (
$pSheet->getPageSetup()->getFitToWidth() !== null) {
            
$objWriter->writeAttribute('fitToWidth'$pSheet->getPageSetup()->getFitToWidth());
        } else {
            
$objWriter->writeAttribute('fitToWidth''0');
        }
        if (
$pSheet->getPageSetup()->getFirstPageNumber() !== null) {
            
$objWriter->writeAttribute('firstPageNumber'$pSheet->getPageSetup()->getFirstPageNumber());
            
$objWriter->writeAttribute('useFirstPageNumber''1');
        }
        
$objWriter->writeAttribute('pageOrder'$pSheet->getPageSetup()->getPageOrder());

        
$getUnparsedLoadedData $pSheet->getParent()->getUnparsedLoadedData();
        if (isset(
$getUnparsedLoadedData['sheets'][$pSheet->getCodeName()]['pageSetupRelId'])) {
            
$objWriter->writeAttribute('r:id'$getUnparsedLoadedData['sheets'][$pSheet->getCodeName()]['pageSetupRelId']);
        }

        
$objWriter->endElement();
    }

    
/**
     * Write Header / Footer.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeHeaderFooter(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// headerFooter
        
$objWriter->startElement('headerFooter');
        
$objWriter->writeAttribute('differentOddEven', ($pSheet->getHeaderFooter()->getDifferentOddEven() ? 'true' 'false'));
        
$objWriter->writeAttribute('differentFirst', ($pSheet->getHeaderFooter()->getDifferentFirst() ? 'true' 'false'));
        
$objWriter->writeAttribute('scaleWithDoc', ($pSheet->getHeaderFooter()->getScaleWithDocument() ? 'true' 'false'));
        
$objWriter->writeAttribute('alignWithMargins', ($pSheet->getHeaderFooter()->getAlignWithMargins() ? 'true' 'false'));

        
$objWriter->writeElement('oddHeader'$pSheet->getHeaderFooter()->getOddHeader());
        
$objWriter->writeElement('oddFooter'$pSheet->getHeaderFooter()->getOddFooter());
        
$objWriter->writeElement('evenHeader'$pSheet->getHeaderFooter()->getEvenHeader());
        
$objWriter->writeElement('evenFooter'$pSheet->getHeaderFooter()->getEvenFooter());
        
$objWriter->writeElement('firstHeader'$pSheet->getHeaderFooter()->getFirstHeader());
        
$objWriter->writeElement('firstFooter'$pSheet->getHeaderFooter()->getFirstFooter());
        
$objWriter->endElement();
    }

    
/**
     * Write Breaks.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeBreaks(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// Get row and column breaks
        
$aRowBreaks = [];
        
$aColumnBreaks = [];
        foreach (
$pSheet->getBreaks() as $cell => $breakType) {
            if (
$breakType == PhpspreadsheetWorksheet::BREAK_ROW) {
                
$aRowBreaks[] = $cell;
            } elseif (
$breakType == PhpspreadsheetWorksheet::BREAK_COLUMN) {
                
$aColumnBreaks[] = $cell;
            }
        }

        
// rowBreaks
        
if (!empty($aRowBreaks)) {
            
$objWriter->startElement('rowBreaks');
            
$objWriter->writeAttribute('count'count($aRowBreaks));
            
$objWriter->writeAttribute('manualBreakCount'count($aRowBreaks));

            foreach (
$aRowBreaks as $cell) {
                
$coords Coordinate::coordinateFromString($cell);

                
$objWriter->startElement('brk');
                
$objWriter->writeAttribute('id'$coords[1]);
                
$objWriter->writeAttribute('man''1');
                
$objWriter->endElement();
            }

            
$objWriter->endElement();
        }

        
// Second, write column breaks
        
if (!empty($aColumnBreaks)) {
            
$objWriter->startElement('colBreaks');
            
$objWriter->writeAttribute('count'count($aColumnBreaks));
            
$objWriter->writeAttribute('manualBreakCount'count($aColumnBreaks));

            foreach (
$aColumnBreaks as $cell) {
                
$coords Coordinate::coordinateFromString($cell);

                
$objWriter->startElement('brk');
                
$objWriter->writeAttribute('id'Coordinate::columnIndexFromString($coords[0]) - 1);
                
$objWriter->writeAttribute('man''1');
                
$objWriter->endElement();
            }

            
$objWriter->endElement();
        }
    }

    
/**
     * Write SheetData.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     * @param string[] $pStringTable String table
     */
    
private function writeSheetData(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet, array $pStringTable): void
    
{
        
// Flipped stringtable, for faster index searching
        
$aFlippedStringTable $this->getParentWriter()->getWriterPart('stringtable')->flipStringTable($pStringTable);

        
// sheetData
        
$objWriter->startElement('sheetData');

        
// Get column count
        
$colCount Coordinate::columnIndexFromString($pSheet->getHighestColumn());

        
// Highest row number
        
$highestRow $pSheet->getHighestRow();

        
// Loop through cells
        
$cellsByRow = [];
        foreach (
$pSheet->getCoordinates() as $coordinate) {
            
$cellAddress Coordinate::coordinateFromString($coordinate);
            
$cellsByRow[$cellAddress[1]][] = $coordinate;
        }

        
$currentRow 0;
        while (
$currentRow++ < $highestRow) {
            
// Get row dimension
            
$rowDimension $pSheet->getRowDimension($currentRow);

            
// Write current row?
            
$writeCurrentRow = isset($cellsByRow[$currentRow]) || $rowDimension->getRowHeight() >= || $rowDimension->getVisible() == false || $rowDimension->getCollapsed() == true || $rowDimension->getOutlineLevel() > || $rowDimension->getXfIndex() !== null;

            if (
$writeCurrentRow) {
                
// Start a new row
                
$objWriter->startElement('row');
                
$objWriter->writeAttribute('r'$currentRow);
                
$objWriter->writeAttribute('spans''1:' $colCount);

                
// Row dimensions
                
if ($rowDimension->getRowHeight() >= 0) {
                    
$objWriter->writeAttribute('customHeight''1');
                    
$objWriter->writeAttribute('ht'StringHelper::formatNumber($rowDimension->getRowHeight()));
                }

                
// Row visibility
                
if (!$rowDimension->getVisible() === true) {
                    
$objWriter->writeAttribute('hidden''true');
                }

                
// Collapsed
                
if ($rowDimension->getCollapsed() === true) {
                    
$objWriter->writeAttribute('collapsed''true');
                }

                
// Outline level
                
if ($rowDimension->getOutlineLevel() > 0) {
                    
$objWriter->writeAttribute('outlineLevel'$rowDimension->getOutlineLevel());
                }

                
// Style
                
if ($rowDimension->getXfIndex() !== null) {
                    
$objWriter->writeAttribute('s'$rowDimension->getXfIndex());
                    
$objWriter->writeAttribute('customFormat''1');
                }

                
// Write cells
                
if (isset($cellsByRow[$currentRow])) {
                    foreach (
$cellsByRow[$currentRow] as $cellAddress) {
                        
// Write cell
                        
$this->writeCell($objWriter$pSheet$cellAddress$aFlippedStringTable);
                    }
                }

                
// End row
                
$objWriter->endElement();
            }
        }

        
$objWriter->endElement();
    }

    
/**
     * @param RichText|string $cellValue
     */
    
private function writeCellInlineStr(XMLWriter $objWriterstring $mappedType$cellValue): void
    
{
        
$objWriter->writeAttribute('t'$mappedType);
        if (!
$cellValue instanceof RichText) {
            
$objWriter->writeElement('t'StringHelper::controlCharacterPHP2OOXML(htmlspecialchars($cellValue)));
        } elseif (
$cellValue instanceof RichText) {
            
$objWriter->startElement('is');
            
$this->getParentWriter()->getWriterPart('stringtable')->writeRichText($objWriter$cellValue);
            
$objWriter->endElement();
        }
    }

    
/**
     * @param RichText|string $cellValue
     * @param string[] $pFlippedStringTable
     */
    
private function writeCellString(XMLWriter $objWriterstring $mappedType$cellValue, array $pFlippedStringTable): void
    
{
        
$objWriter->writeAttribute('t'$mappedType);
        if (!
$cellValue instanceof RichText) {
            
self::writeElementIf($objWriter, isset($pFlippedStringTable[$cellValue]), 'v'$pFlippedStringTable[$cellValue] ?? '');
        } else {
            
$objWriter->writeElement('v'$pFlippedStringTable[$cellValue->getHashCode()]);
        }
    }

    
/**
     * @param float|int $cellValue
     */
    
private function writeCellNumeric(XMLWriter $objWriter$cellValue): void
    
{
        
//force a decimal to be written if the type is float
        
if (is_float($cellValue)) {
            
// force point as decimal separator in case current locale uses comma
            
$cellValue str_replace(',''.', (string) $cellValue);
            if (
strpos($cellValue'.') === false) {
                
$cellValue $cellValue '.0';
            }
        }
        
$objWriter->writeElement('v'$cellValue);
    }

    private function 
writeCellBoolean(XMLWriter $objWriterstring $mappedTypebool $cellValue): void
    
{
        
$objWriter->writeAttribute('t'$mappedType);
        
$objWriter->writeElement('v'$cellValue '1' '0');
    }

    private function 
writeCellError(XMLWriter $objWriterstring $mappedTypestring $cellValuestring $formulaerr '#NULL!'): void
    
{
        
$objWriter->writeAttribute('t'$mappedType);
        
$cellIsFormula substr($cellValue01) === '=';
        
self::writeElementIf($objWriter$cellIsFormula'f'Xlfn::addXlfnStripEquals($cellValue));
        
$objWriter->writeElement('v'$cellIsFormula $formulaerr $cellValue);
    }

    private function 
writeCellFormula(XMLWriter $objWriterstring $cellValueCell $pCell): void
    
{
        
$calculatedValue $this->getParentWriter()->getPreCalculateFormulas() ? $pCell->getCalculatedValue() : $cellValue;
        if (
is_string($calculatedValue)) {
            if (
\PhpOffice\PhpSpreadsheet\Calculation\Functions::isError($calculatedValue)) {
                
$this->writeCellError($objWriter'e'$cellValue$calculatedValue);

                return;
            }
            
$objWriter->writeAttribute('t''str');
        } elseif (
is_bool($calculatedValue)) {
            
$objWriter->writeAttribute('t''b');
        }
        
// array values are not yet supported
        //$attributes = $pCell->getFormulaAttributes();
        //if (($attributes['t'] ?? null) === 'array') {
        //    $objWriter->startElement('f');
        //    $objWriter->writeAttribute('t', 'array');
        //    $objWriter->writeAttribute('ref', $pCellAddress);
        //    $objWriter->writeAttribute('aca', '1');
        //    $objWriter->writeAttribute('ca', '1');
        //    $objWriter->text(substr($cellValue, 1));
        //    $objWriter->endElement();
        //} else {
        //    $objWriter->writeElement('f', Xlfn::addXlfnStripEquals($cellValue));
        //}
        
$objWriter->writeElement('f'Xlfn::addXlfnStripEquals($cellValue));
        
self::writeElementIf(
            
$objWriter,
            
$this->getParentWriter()->getOffice2003Compatibility() === false,
            
'v',
            (
$this->getParentWriter()->getPreCalculateFormulas() && !is_array($calculatedValue) && substr($calculatedValue01) !== '#')
                ? 
StringHelper::formatNumber($calculatedValue) : '0'
        
);
    }

    
/**
     * Write Cell.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     * @param string $pCellAddress Cell Address
     * @param string[] $pFlippedStringTable String table (flipped), for faster index searching
     */
    
private function writeCell(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheetstring $pCellAddress, array $pFlippedStringTable): void
    
{
        
// Cell
        
$pCell $pSheet->getCell($pCellAddress);
        
$objWriter->startElement('c');
        
$objWriter->writeAttribute('r'$pCellAddress);

        
// Sheet styles
        
$xfi $pCell->getXfIndex();
        
self::writeAttributeIf($objWriter$xfi's'$xfi);

        
// If cell value is supplied, write cell value
        
$cellValue $pCell->getValue();
        if (
is_object($cellValue) || $cellValue !== '') {
            
// Map type
            
$mappedType $pCell->getDataType();

            
// Write data depending on its type
            
switch (strtolower($mappedType)) {
                case 
'inlinestr':    // Inline string
                    
$this->writeCellInlineStr($objWriter$mappedType$cellValue);

                    break;
                case 
's':            // String
                    
$this->writeCellString($objWriter$mappedType$cellValue$pFlippedStringTable);

                    break;
                case 
'f':            // Formula
                    
$this->writeCellFormula($objWriter$cellValue$pCell);

                    break;
                case 
'n':            // Numeric
                    
$this->writeCellNumeric($objWriter$cellValue);

                    break;
                case 
'b':            // Boolean
                    
$this->writeCellBoolean($objWriter$mappedType$cellValue);

                    break;
                case 
'e':            // Error
                    
$this->writeCellError($objWriter$mappedType$cellValue);
            }
        }

        
$objWriter->endElement();
    }

    
/**
     * Write Drawings.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     * @param bool $includeCharts Flag indicating if we should include drawing details for charts
     */
    
private function writeDrawings(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet$includeCharts false): void
    
{
        
$unparsedLoadedData $pSheet->getParent()->getUnparsedLoadedData();
        
$hasUnparsedDrawing = isset($unparsedLoadedData['sheets'][$pSheet->getCodeName()]['drawingOriginalIds']);
        
$chartCount = ($includeCharts) ? $pSheet->getChartCollection()->count() : 0;
        if (
$chartCount == && $pSheet->getDrawingCollection()->count() == && !$hasUnparsedDrawing) {
            return;
        }

        
// If sheet contains drawings, add the relationships
        
$objWriter->startElement('drawing');

        
$rId 'rId1';
        if (isset(
$unparsedLoadedData['sheets'][$pSheet->getCodeName()]['drawingOriginalIds'])) {
            
$drawingOriginalIds $unparsedLoadedData['sheets'][$pSheet->getCodeName()]['drawingOriginalIds'];
            
// take first. In future can be overriten
            // (! synchronize with \PhpOffice\PhpSpreadsheet\Writer\Xlsx\Rels::writeWorksheetRelationships)
            
$rId reset($drawingOriginalIds);
        }

        
$objWriter->writeAttribute('r:id'$rId);
        
$objWriter->endElement();
    }

    
/**
     * Write LegacyDrawing.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeLegacyDrawing(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// If sheet contains comments, add the relationships
        
if (count($pSheet->getComments()) > 0) {
            
$objWriter->startElement('legacyDrawing');
            
$objWriter->writeAttribute('r:id''rId_comments_vml1');
            
$objWriter->endElement();
        }
    }

    
/**
     * Write LegacyDrawingHF.
     *
     * @param XMLWriter $objWriter XML Writer
     * @param PhpspreadsheetWorksheet $pSheet Worksheet
     */
    
private function writeLegacyDrawingHF(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        
// If sheet contains images, add the relationships
        
if (count($pSheet->getHeaderFooter()->getImages()) > 0) {
            
$objWriter->startElement('legacyDrawingHF');
            
$objWriter->writeAttribute('r:id''rId_headerfooter_vml1');
            
$objWriter->endElement();
        }
    }

    private function 
writeAlternateContent(XMLWriter $objWriterPhpspreadsheetWorksheet $pSheet): void
    
{
        if (empty(
$pSheet->getParent()->getUnparsedLoadedData()['sheets'][$pSheet->getCodeName()]['AlternateContents'])) {
            return;
        }

        foreach (
$pSheet->getParent()->getUnparsedLoadedData()['sheets'][$pSheet->getCodeName()]['AlternateContents'] as $alternateContent) {
            
$objWriter->writeRaw($alternateContent);
        }
    }
}

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.5 [PHP 8 Update] [24.05.2025] | Generation time: 0.0192 ]--