All Versions
39
Latest Version
Avg Release Cycle
51 days
Latest Release
136 days ago

Changelog History
Page 1

  • v1.25.2 Changes

    September 25, 2022

    โž• Added

    • Nothing

    ๐Ÿ”„ Changed

    • Nothing

    ๐Ÿ—„ Deprecated

    • Nothing

    โœ‚ Removed

    • Nothing

    ๐Ÿ›  Fixed

    • Composer dependency clash with ezyang/htmlpurifier
  • v1.25.0 Changes

    September 25, 2022

    โž• Added

    • Implementation of the new TEXTBEFORE(), TEXTAFTER() and TEXTSPLIT() Excel Functions
    • Implementation of the ARRAYTOTEXT() and VALUETOTEXT() Excel Functions
    • ๐Ÿ‘Œ Support for mitoteam/jpgraph implementation of JpGraph library to render charts added.
    • Charts: Add Gradients, Transparency, Hidden Axes, Rounded Corners, Trendlines, Date Axes.

    ๐Ÿ”„ Changed

    • ๐Ÿ‘ Allow variant behaviour when merging cells Issue #3065
      • Merge methods now allow an additional $behaviour argument. Permitted values are:
      • Worksheet::MERGE_CELL_CONTENT_EMPTY - Empty the content of the hidden cells (the default behaviour)
      • Worksheet::MERGE_CELL_CONTENT_HIDE - Keep the content of the hidden cells
      • Worksheet::MERGE_CELL_CONTENT_MERGE - Move the content of the hidden cells into the first cell

    ๐Ÿ—„ Deprecated

    • ๐Ÿ—„ Axis getLineProperty deprecated in favor of getLineColorProperty.
    • ๐Ÿšš Moved majorGridlines and minorGridlines from Chart to Axis. Setting either in Chart constructor or through Chart methods, or getting either using Chart methods is deprecated.
    • Chart::EXCEL_COLOR_TYPE_* copied from Properties to ChartColor; use in Properties is deprecated.
    • ChartColor::EXCEL_COLOR_TYPE_ARGB deprecated in favor of EXCEL_COLOR_TYPE_RGB ("A" component was never allowed).
    • ๐Ÿ’… Misspelled Properties::LINE_STYLE_DASH_SQUERE_DOT deprecated in favor of LINE_STYLE_DASH_SQUARE_DOT.
    • ๐Ÿ‘ฏ Clone not permitted for Spreadsheet. Spreadsheet->copy() can be used instead.

    โœ‚ Removed

    • Nothing

    ๐Ÿ›  Fixed

  • v1.24.1 Changes

    July 18, 2022

    โž• Added

    • ๐Ÿ‘Œ Support for SimpleCache Interface versions 1.0, 2.0 and 3.0
    • โž• Add Chart Axis Option textRotation Issue #2705 PR #2940

    ๐Ÿ”„ Changed

    • Nothing

    ๐Ÿ—„ Deprecated

    • Nothing

    โœ‚ Removed

    • Nothing

    ๐Ÿ›  Fixed

  • v1.24.0 Changes

    July 09, 2022

    ๐Ÿš€ Note that this will be the last 1.x branch release before the 2.x release. We will maintain both branches in parallel for a time; but users are requested to update to version 2.0 once that is fully available.

    โž• Added

    • โž• Added removeComment() method for Worksheet PR #2875
    • โž• Add point size option for scatter charts Issue #2298 PR #2801
    • ๐Ÿ‘ Basic support for Xlsx reading/writing Chart Sheets PR #2830

    Note that a ChartSheet is still only written as a normal Worksheet containing a single chart, not as an actual ChartSheet.

    • โž• Added Worksheet visibility in Ods Reader PR #2851 and Gnumeric Reader PR #2853
    • โž• Added Worksheet visibility in Ods Writer PR #2850
    • ๐Ÿ‘ Allow Csv Reader to treat string as contents of file Issue #1285 PR #2792
    • ๐Ÿ‘ Allow Csv Reader to store null string rather than leave cell empty Issue #2840 PR #2842
    • Provide new Worksheet methods to identify if a row or column is "empty", making allowance for different definitions of "empty":
      • Treat rows/columns containing no cell records as empty (default)
      • Treat cells containing a null value as empty
      • Treat cells containing an empty string as empty

    ๐Ÿ”„ Changed

    • Modify rangeBoundaries(), rangeDimension() and getRangeBoundaries() Coordinate methods to work with row/column ranges as well as with cell ranges and cells PR #2926
    • ๐Ÿ‘ Better enforcement of value modification to match specified datatype when using setValueExplicit()
    • ๐Ÿ”€ Relax validation of merge cells to allow merge for a single cell reference Issue #2776
    • Memory and speed improvements, particularly for the Cell Collection, and the Writers.

    See the Discussion section on github for details of performance across versions

    • ๐Ÿ‘Œ Improved performance for removing rows/columns from a worksheet

    ๐Ÿ—„ Deprecated

    • Nothing

    โœ‚ Removed

    • Nothing

    ๐Ÿ›  Fixed

  • v1.23.0 Changes

    April 24, 2022

    โž• Added

    • ๐Ÿ‘ Ods Writer support for Freeze Pane Issue #2013 PR #2755
    • ๐Ÿ‘ Ods Writer support for setting column width/row height (including the use of AutoSize) Issue #2346 PR #2753
    • Introduced CellAddress, CellRange, RowRange and ColumnRange value objects that can be used as an alternative to a string value (e.g. 'C5', 'B2:D4', '2:2' or 'B:C') in appropriate contexts.
    • Implementation of the FILTER(), SORT(), SORTBY() and UNIQUE() Lookup/Reference (array) functions.
    • Implementation of the ISREF() Information function.
    • โž• Added support for reading "formatted" numeric values from Csv files; although default behaviour of reading these values as strings is preserved.

    (i.e a value of "12,345.67" can be read as numeric 12345.67, not simply as a string "12,345.67", if the castFormattedNumberToNumeric() setting is enabled.

    This functionality is locale-aware, using the server's locale settings to identify the thousands and decimal separators.

    • ๐Ÿ‘Œ Support for two cell anchor drawing of images. #2532 #2674
    • ๐Ÿ‘ Limited support for Xls Reader to handle Conditional Formatting:

    Ranges and Rules are read, but style is currently limited to font size, weight and color; and to fill style and color.

    • โž• Add ability to suppress Mac line ending check for CSV #2623
    • ๐ŸŽ‰ Initial support for creating and writing Tables (Xlsx Writer only) PR #2671

    See /samples/Table for examples of use.

    Note that PreCalculateFormulas needs to be disabled when saving spreadsheets containing tables with formulae (totals or column formulae).

    ๐Ÿ”„ Changed

    • Gnumeric Reader now loads number formatting for cells.
    • Gnumeric Reader now correctly identifies selected worksheet and selected cells in a worksheet.
    • ๐Ÿ”จ Some Refactoring of the Ods Reader, moving all formula and address translation from Ods to Excel into a separate class to eliminate code duplication and ensure consistency.
    • ๐Ÿ‘‰ Make Boolean Conversion in Csv Reader locale-aware when using the String Value Binder.

    This is determined by the Calculation Engine locale setting.

    (i.e. "Vrai" wil be converted to a boolean true if the Locale is set to fr.)

    • ๐Ÿ‘ Allow psr/simple-cache 2.x

    ๐Ÿ—„ Deprecated

    • ๐Ÿ‘€ All Excel Function implementations in Calculation\Functions (including the Error functions) have been moved to dedicated classes for groups of related functions. See the docblocks against all the deprecated methods for details of the new methods to call instead. At some point, these old classes will be deleted.
    • Worksheet methods that reference cells "byColumnandRow". All such methods have an equivalent that references the cell by its address (e.g. 'E3' rather than 5, 3).

    These functions now accept either a cell address string ('E3') or an array with columnId and rowId ([5, 3]) or a new CellAddress object as their cellAddress/coordinate argument. This includes the methods:

    • setCellValueByColumnAndRow() use the equivalent setCellValue()
    • setCellValueExplicitByColumnAndRow() use the equivalent setCellValueExplicit()
    • getCellByColumnAndRow() use the equivalent getCell()
    • cellExistsByColumnAndRow() use the equivalent cellExists()
    • getStyleByColumnAndRow() use the equivalent getStyle()
    • setBreakByColumnAndRow() use the equivalent setBreak()
    • mergeCellsByColumnAndRow() use the equivalent mergeCells()
    • unmergeCellsByColumnAndRow() use the equivalent unmergeCells()
    • protectCellsByColumnAndRow() use the equivalent protectCells()
    • unprotectCellsByColumnAndRow() use the equivalent unprotectCells()
    • setAutoFilterByColumnAndRow() use the equivalent setAutoFilter()
    • freezePaneByColumnAndRow() use the equivalent freezePane()
    • getCommentByColumnAndRow() use the equivalent getComment()
    • setSelectedCellByColumnAndRow() use the equivalent setSelectedCells()

    This change provides more consistency in the methods (not every "by cell address" method has an equivalent "byColumnAndRow" method); and the "by cell address" methods often provide more flexibility, such as allowing a range of cells, or referencing them by passing the defined name of a named range as the argument.

    โœ‚ Removed

    • Nothing

    ๐Ÿ›  Fixed

    • ๐Ÿ‘‰ Make allowance for the AutoFilter dropdown icon in the first row of an Autofilter range when using Autosize columns. Issue #2413 PR #2754
    • ๐Ÿ‘Œ Support for "chained" ranges (e.g. A5:C10:C20:F1) in the Calculation Engine; and also support for using named ranges with the Range operator (e.g. NamedRange1:NamedRange2) Issue #2730 PR #2746
    • โšก๏ธ Update Conditional Formatting ranges and rule conditions when inserting/deleting rows/columns Issue #2678 PR #2689
    • ๐Ÿ‘ Allow INDIRECT() to accept row/column ranges as well as cell ranges PR #2687
    • ๐Ÿ›  Fix bug when deleting cells with hyperlinks, where the hyperlink was then being "inherited" by whatever cell moved to that cell address.
    • ๐Ÿ›  Fix bug in Conditional Formatting in the Xls Writer that resulted in a broken file when there were multiple conditional ranges in a worksheet.
    • ๐Ÿ›  Fix Conditional Formatting in the Xls Writer to work with rules that contain string literals, cell references and formulae.
    • ๐Ÿ›  Fix for setting Active Sheet to the first loaded worksheet when bookViews element isn't defined Issue #2666 PR #2669
    • ๐Ÿ›  Fixed behaviour of XLSX font style vertical align settings PR #2619
    • ๐ŸŒ Resolved formula translations to handle separators (row and column) for array functions as well as for function argument separators; and cleanly handle nesting levels.

    Note that this method is used when translating Excel functions between en_us and other locale languages, as well as when converting formulae between different spreadsheet formats (e.g. Ods to Excel).

    Nor is this a perfect solution, as there may still be issues when function calls have array arguments that themselves contain function calls; but it's still better than the current logic.

    • ๐Ÿ›  Fix for escaping double quotes within a formula Issue #1971 PR #2651
    • ๐Ÿ”„ Change open mode for output from wb+ to wb Issue #2372 PR #2657
    • ๐Ÿ‘‰ Use color palette if supplied Issue #2499 PR #2595
    • Xls reader treat drawing offsets as int rather than float PR #2648
    • ๐Ÿ’… Handle booleans in conditional styles properly PR #2654
    • ๐Ÿ›  Fix for reading files in the root directory of a ZipFile, which should not be prefixed by relative paths ("./") as dirname($filename) does by default.
    • ๐Ÿ›  Fix invalid style of cells in empty columns with columnDimensions and rows with rowDimensions in added external sheet. PR #2739
    • Time Interval Formatting Issue #2768 PR #2772
  • v1.22.0 Changes

    February 18, 2022

    โž• Added

    • ๐Ÿ’… Namespacing phase 2 - styles. PR #2471

    • ๐Ÿ‘Œ Improved support for passing of array arguments to Excel function implementations to return array results (where appropriate). Issue #2551

    This is the first stage in an ongoing process of adding array support to all appropriate function implementations,

    • ๐Ÿ‘Œ Support for the Excel365 Math/Trig SEQUENCE() function PR #2536
    • ๐Ÿ‘Œ Support for the Excel365 Math/Trig RANDARRAY() function PR #2540

    Note that the Spill Operator is not yet supported in the Calculation Engine; but this can still be useful for defining array constants.

    • ๐Ÿ‘Œ Improved support for Conditional Formatting Rules PR #2491

      • Provide support for a wider range of Conditional Formatting Rules for Xlsx Reader/Writer:
      • Cells Containing (cellIs)
      • Specific Text (containing, notContaining, beginsWith, endsWith)
      • Dates Occurring (all supported timePeriods)
      • Blanks/NoBlanks
      • Errors/NoErrors
      • Duplicates/Unique
      • Expression
      • Provision of CF Wizards (for all the above listed rule types) to help create/modify CF Rules without having to manage all the combinations of types/operators, and the complexities of formula expressions, or the text/timePeriod attributes.

      See documentation for details

      • Full support of the above CF Rules for the Xlsx Reader and Writer; even when the file being loaded has CF rules listed in the <extLst><ext><ConditionalFormattings> element for the worksheet rather than the <ConditionalFormatting> element.
      • Provision of a CellMatcher to identify if rules are matched for a cell, and which matching style will be applied.
      • Improved documentation and examples, covering all supported CF rule types.
      • Add support for one digit decimals (FORMAT_NUMBER_0, FORMAT_PERCENTAGE_0). PR #2525
      • Initial work enabling Excel function implementations for handling arrays as arguments when used in "array formulae" #2562
      • Enable most of the Date/Time functions to accept array arguments #2573
      • Array ready functions - Text, Math/Trig, Statistical, Engineering and Logical #2580

    ๐Ÿ”„ Changed

    • โž• Additional Russian translations for Excel Functions (courtesy of aleks-samurai).
    • ๐Ÿ‘Œ Improved code coverage for NumberFormat. PR #2556
    • Extract some methods from the Calculation Engine into dedicated classes #2537
    • Eliminate calls to flattenSingleValue() that are no longer required when we're checking for array values as arguments #2590

    ๐Ÿ—„ Deprecated

    • Nothing

    โœ‚ Removed

    • Nothing

    ๐Ÿ›  Fixed

    • ๐Ÿ›  Fixed [email protected] behavior when removing column before last column with null value PR #2541
    • ๐Ÿ›  Fix bug with DOLLARDE() and DOLLARFR() functions when the dollar value is negative Issue #2578 PR #2579
    • ๐Ÿ›  Fix partial function name matching when translating formulae from Russian to English Issue #2533 PR #2534
    • Various bugs related to Conditional Formatting Rules, and errors in the Xlsx Writer for Conditional Formatting PR #2491
    • ๐Ÿ”€ Xlsx Reader merge range fixes. Issue #2501 PR #2504
    • ๐Ÿ– Handle explicit "date" type for Cell in Xlsx Reader. Issue #2373 PR #2485
    • ๐Ÿšš Recalibrate Row/Column Dimensions after removeRow/Column. Issue #2442 PR #2486
    • Refinement for XIRR. Issue #2469 PR #2487
    • Xlsx Reader handle cell with non-null explicit type but null value. Issue #2488 PR #2489
    • Xlsx Reader fix height and width for oneCellAnchorDrawings. PR #2492
    • Fix rounding error in NumberFormat::NUMBER_PERCENTAGE, NumberFormat::NUMBER_PERCENTAGE_00. PR #2555
    • Don't treat thumbnail file as xml. Issue #2516 PR #2517
    • โš  Eliminating Xlsx Reader warning when no sz tag for RichText. Issue #2542 PR #2550
    • ๐Ÿ›  Fix Xlsx/Xls Writer handling of inline strings. Issue #353 PR #2569
    • Richtext colors were not being read correctly after namespace change #2458
    • ๐Ÿ›  Fix discrepancy between the way markdown tables are rendered in ReadTheDocs and in PHPStorm #2520
    • โšก๏ธ Update Russian Functions Text File #2557
    • ๐Ÿ›  Fix documentation, instantiation example #2564
  • v1.21.0 Changes

    January 06, 2022

    โž• Added

    • ๐Ÿ‘ Ability to add a picture to the background of the comment. Supports four image formats: png, jpeg, gif, bmp. New Comment::setSizeAsBackgroundImage() to change the size of a comment to the size of a background image. Issue #1547 PR #2422
    • 0๏ธโƒฃ Ability to set default paper size and orientation PR #2410
    • Ability to extend AutoFilter to Maximum Row PR #2414

    ๐Ÿ”„ Changed

    • Xlsx Writer will evaluate AutoFilter only if it is as yet unevaluated, or has changed since it was last evaluated PR #2414

    ๐Ÿ—„ Deprecated

    • Nothing

    โœ‚ Removed

    • Nothing

    ๐Ÿ›  Fixed

  • v1.20.0 Changes

    November 23, 2021

    โž• Added

    • ๐Ÿ‘ Xlsx Writer Support for WMF Files #2339
    • ๐Ÿ‘‰ Use standard temporary file for internal use of HTMLPurifier #2383

    ๐Ÿ”„ Changed

    ๐Ÿ—„ Deprecated

    • Nothing

    โœ‚ Removed

    • Nothing

    ๐Ÿ›  Fixed

    • ๐Ÿ›  Fixed null conversation for strToUpper #2292
    • ๐Ÿ›  Fixed Trying to access array offset on value of type null (Xls Reader) #2315
    • Don't corrupt XLSX files containing data validation #2377
    • โšก๏ธ Non-fixed cells were not updated if shared formula has a fixed cell #2354
    • Declare key of generic ArrayObject
    • ๐Ÿ‘ CSV reader better support for boolean values #2374
    • Some ZIP file could not be read #2376
    • ๐Ÿ›  Fix regression were hyperlinks could not be read #2391
    • AutoFilter Improvements #2393
    • Don't corrupt file when using chart with fill color #589
    • โช Restore imperfect array formula values in xlsx writer #2343
    • โช Restore explicit list of changes to PHPExcel migration document #1546
  • v1.19.0 Changes

    October 31, 2021

    โž• Added

    • ๐Ÿ’… Ability to set style on named range, and validate input to setSelectedCells Issue #2279 PR #2280
    • ๐Ÿ–จ Process comments in Sylk file Issue #2276 PR #2277
    • โž• Addition of Custom Properties to Ods Writer, and 32-bit-safe timestamps for Document Properties PR #2113
    • โž• Added callback to CSV reader to set user-specified defaults for various properties (especially for escape which has a poor PHP-inherited default of backslash which does not correspond with Excel) PR #2103
    • ๐Ÿ‘ Phase 1 of better namespace handling for Xlsx, resolving many open issues PR #2173 PR #2204 PR #2303
    • โž• Add ability to extract images if source is a URL Issue #1997 PR #2072
    • ๐Ÿ‘Œ Support for passing flags in the Reader load() and Writer save()methods, and through the IOFactory, to set behaviours PR #2136
    • More flexibility in the StringValueBinder to determine what datatypes should be treated as strings PR #2138
    • Helper class for conversion between css size Units of measure (px, pt, pc, in, cm, mm) PR #2152
    • ๐Ÿ‘ Allow Row height and Column Width to be set using different units of measure (px, pt, pc, in, cm, mm), rather than only in points or MS Excel column width units PR #2152
    • Ability to stream to an Amazon S3 bucket Issue #2249
    • Provided a Size Helper class to validate size values (pt, px, em) PR #1694

    ๐Ÿ”„ Changed

    • Nothing.

    ๐Ÿ—„ Deprecated

    • PHP 8.1 will deprecate auto_detect_line_endings. As a result of this change, Csv Reader using some release after PHP8.1 will no longer be able to handle a Csv with Mac line endings.

    โœ‚ Removed

    • Nothing.

    ๐Ÿ›  Fixed

  • v1.18.0 Changes

    May 31, 2021

    โž• Added

    • โœจ Enhancements to CSV Reader, allowing options to be set when using IOFactory::load() with a callback to set delimiter, enclosure, charset etc. PR #2103 - See documentation for details.
    • Implemented basic AutoFiltering for Ods Reader and Writer PR #2053
    • Implemented basic AutoFiltering for Gnumeric Reader PR #2055
    • ๐Ÿ‘Œ Improved support for Row and Column ranges in formulae Issue #1755 PR #2028
    • ๐ŸŒ Implemented URLENCODE() Web Function
    • โœ… Implemented the CHITEST(), CHISQ.DIST() and CHISQ.INV() and equivalent Statistical functions, for both left- and right-tailed distributions.
    • ๐Ÿ‘Œ Support for ActiveSheet and SelectedCells in the ODS Reader and Writer. PR #1908
    • ๐Ÿ‘Œ Support for notContainsText Conditional Style in xlsx Issue #984

    ๐Ÿ”„ Changed

    • ๐Ÿ‘‰ Use of nb rather than no as the locale code for Norsk Bokmรฅl.

    ๐Ÿ—„ Deprecated

    • ๐Ÿ‘€ All Excel Function implementations in Calculation\Database, Calculation\DateTime, Calculation\Engineering, Calculation\Financial, Calculation\Logical, Calculation\LookupRef, Calculation\MathTrig, Calculation\Statistical, Calculation\TextData and Calculation\Web have been moved to dedicated classes for individual functions or groups of related functions. See the docblocks against all the deprecated methods for details of the new methods to call instead. At some point, these old classes will be deleted.

    โœ‚ Removed

    • ๐Ÿ‘‰ Use of nb rather than no as the locale language code for Norsk Bokmรฅl.

    ๐Ÿ›  Fixed

    • ๐Ÿ›  Fixed error in COUPNCD() calculation for end of month Issue #2116 - PR #2119
    • 0๏ธโƒฃ Resolve default values when a null argument is passed for HLOOKUP(), VLOOKUP() and ADDRESS() functions Issue #2120 - PR #2121
    • ๐Ÿ›  Fixed incorrect R1C1 to A1 subtraction formula conversion (R[-2]C-R[2]C) Issue #2076 PR #2086
    • Correctly handle absolute A1 references when converting to R1C1 format PR #2060
    • ๐Ÿ’… Correct default fill style for conditional without a pattern defined Issue #2035 PR #2050
    • ๐Ÿ›  Fixed issue where array key check for existince before accessing arrays in Xlsx.php. PR #1970
    • ๐Ÿ›  Fixed issue with quoted strings in number format mask rendered with toFormattedString() Issue 1972# PR #1978
    • ๐Ÿ›  Fixed issue with percentage formats in number format mask rendered with toFormattedString() Issue 1929# PR #1928
    • ๐Ÿ›  Fixed issue with _ spacing character in number format mask corrupting output from toFormattedString() Issue 1924# PR #1927
    • ๐Ÿ›  Fix for Issue #1887 - Lose Track of Selected Cells After Save
    • ๐Ÿ›  Fixed issue with [email protected] not returning any data
    • ๐Ÿ›  Fixed invalid arguments triggering mb_substr() error in LEFT(), MID() and RIGHT() text functions. Issue #640
    • ๐Ÿ›  Fix for Issue #1916 - Invalid signature check for XML files
    • ๐Ÿ›  Fix change in Font::setSize() behavior for PHP8. PR #2100