React Data Grid Release notes
See the full history of changes made to Handsontable in each major, minor, and patch release.
12.4.0
Released on May 23, 2023.
For more information on this release, see:
Added
- Added two new Handsontable hooks,
afterColumnSequenceChange
andafterRowSequenceChange
, which are fired after changing the order of columns or rows, respectively. #10215 (opens new window)
Fixed
- Fixed numerous issues related to syncing Handsontable with HyperFormula. Now, formulas work properly with all the Handsontable features. #10215 (opens new window)
- Fixed na issue where formulas didn't recalculate after rows or columns were moved. #4668 (opens new window)
- Fixed an issue where Handsontable's dates didn't sync correctly with HyperFormula's dates. #10085 (opens new window)
- Fixed an issue where calling
updateSettings()
would reset HyperFormula's undo/redo actions stack. #10326 (opens new window) - Fixed an issue where the
Autofill
,TrimRows
andFormulas
plugins didn't work properly together. #10200 (opens new window) - Fixed an issue where the
modifySourceData
hook used the wrong type of indexes. #10215 (opens new window) - Fixed an issue where text copied from Handsontable to Excel included wrong types of spaces. #10017 (opens new window)
- Fixed an issue where mousing over the same cell twice didn't trigger the
beforeOnCellMouseOver
andafterOnCellMouseOver
hooks. #10321 (opens new window) - Updated TypeScript definition files related to the
CustomBorders
plugin. #10360 (opens new window) - Fixed an issue where moving rows manually to the bottom was difficult due the misalignment between the backlight and guideline elements. #9556 (opens new window)
12.3.3
Released on March 28, 2023.
For more information on this release, see:
Added
- Added a Chinese (zh-CN) translation of the "Copy with headers" feature. #10273 (opens new window)
- Added a new guide: Rows sorting. #10183 (opens new window)
Fixed
- Fixed an issue where column-filter checkboxes got reset when the table was scrolled out of view. We solved this by preventing the table from triggering a complete render each time it leaves the viewport. #10206 (opens new window)
- Fixed an issue where clicking on a cell scrolled the table sideways in certain RTL configurations. #10206 (opens new window)
- Fixed an issue where calling
getDataAtCol()
(opens new window) orgetDataAtProp()
(opens new window) caused an error when the data set had more than 125 000 rows. #10226 (opens new window) - React: Fixed React 18 warnings about deprecated lifecycle methods. We removed
componentWillMount()
andcomponentWillUpdate()
from Handsontable's codebase and recreated their functionality by using React's portals. #10263 (opens new window)
12.3.2
Released on March 23, 2023.
Handsontable 12.3.2 may not work properly with React's functional components. If you're using React, you should upgrade to 12.3.3.
12.3.1
Released on February 6, 2023.
For more information on this release, see:
Added
- Added a Japanese translation of the "Copy with headers" feature. #10201 (opens new window)
Removed
- Removed the two-week delay in showing the console warning about license expiration. #10175 (opens new window)
Fixed
- Fixed an issue where
updateData()
didn't work with nested data structures (NestedRows
). #10178 (opens new window) - Fixed an issue of unwanted pixels in the "Filter by condition" menu by removing a superfluous overlay. #10174 (opens new window)
- Fixed an issue where merged cells could lack right and bottom borders due to a Chrome bug. #10212 (opens new window)
- Fixed an issue where using some browser and system shortcuts could cause Handsontable to behave as if Cmd/Ctrl was being held down. #10210 (opens new window)
12.3.0
Released on December 14, 2022.
For more information on this release, see:
Added
- Added a new feature that lets you copy the contents of column headers by using 3 new context menu options: "Copy with headers", "Copy with group headers", and "Copy headers only". #2288 (opens new window)
- Added 4 new API methods for copying column headers programmatically:
copyCellsOnly()
,copyWithColumnHeaders()
,copyWithAllColumnHeaders()
, andcopyColumnHeadersOnly()
. #2288 (opens new window) - Added missing TypeScript definitions of the
CellCoords
andCellRange
classes, which are used in the arguments of some of the APIs. #9755 (opens new window) - Added missing TypeScript definitions for the following Handsontable hooks:
beforeColumnFreeze
,afterColumnFreeze
,beforeColumnUnfreeze
, andafterColumnUnfreeze
. #9859 (opens new window)
Fixed
- Fixed an issue where the
UndoRedo
plugin didn't work properly with preconfigured columns. #10108 (opens new window) - Fixed an issue where formulas inserted programmatically by using
updateData()
were not evaluated. #10011 (opens new window) - Fixed a regression where setting a column's
type
could overwrite other custom-defined settings. #10128 (opens new window) - Fixed an issue where Handsontable didn't render properly when initialized inside of a hidden container. #5322 (opens new window)
- Fixed an issue of desynchronization between configuration options (cell meta) and Handsontable's
data. The issue occurred when Handsontable's options were modified through the following hooks:
beforeCreateRow
,afterCreateRow
,beforeCreateCol
, andafterCreateCol
. #10136 (opens new window) - Fixed an issue where comments added to fixed columns didn't display properly after scrolling. #9645 (opens new window)
- Fixed an issue where typing in a
dropdown
editor caused the IME to disappear, resulting in wrong characters being typed. #9672 (opens new window) - React: Fixed an issue where
dropdown
cells weren't validated properly when using theHotColumn
component. #10065 (opens new window)
12.2.0
Released on October 25, 2022.
For more information on this release, see:
Added
- Added a new feature that lets you add rows and columns at a specified position. Now, the
alter()
method takes 4 new parameter values:insert_row_above
,insert_row_below
,insert_col_start
, andinsert_col_end
. Theinsert_row
andinsert_col
parameters are marked as deprecated. #9471 (opens new window)
Deprecated
- Deprecated the
insert_row
parameter of thealter()
method. Instead, useinsert_row_above
orinsert_row_below
. #9471 (opens new window) - Deprecated the
insert_col
parameter of thealter()
method. Instead, useinsert_col_start
orinsert_col_end
. #9471 (opens new window)
Removed
- Removed a type definition for a non-existing method,
translateRowsToColumns()
. #9919 (opens new window)
Fixed
- Fixed an issue where the width of the cell editor was calculated incorrectly. #3815 (opens new window)
- Fixed an issue where formulas surrounded by merged cells were converted to values by mistake. #6359 (opens new window)
- Fixed an issue where Handsontable could disappear on Firefox 93 (and later) in a specific use case. #9545 (opens new window)
- Fixed an issue where changing a cell's
type
throughsetCellMeta()
didn't properly set the cell'seditor
andrenderer
. #9734 (opens new window) - Fixed an issue where the dropdown menu didn't display when the
NestedHeaders
plugin was enabled and all rows were trimmed out. #9753 (opens new window)
12.1.3
Released on September 22, 2022.
For more information on this release, see:
Removed
- Removed a custom stable sorting implementation in favor of the stable sorting algorithm guaranteed by ECMAScript 2019. #6091 (opens new window)
- Removed type definitions for non-existing methods
rowOffset
andcolOffset
and a non-existing hookmodifyRowSourceData
. #8659 (opens new window), #7317 (opens new window)
Fixed
- Fixed incorrect date format conversion on input in the date editor. #9681 (opens new window)
- Fixed an error when adding a large number of rows using the
alter
method. #7840 (opens new window) - Fixed IME text input in the editors. #9586 (opens new window)
- Fixed an issue where the editor did not open on key events when the cell was outside the viewport. #9022 (opens new window)
- Fixed an issue with "0" values being ignored by the Column Summary plugin. #6385 (opens new window)
- Fixed an error when opening the column dropdown menu with the Filters plugin enabled. #9561 (opens new window)
- Fixed an issue where the
trimWhitespace
option could not be used in the column and cell levels of the cascading configuration. #7387 (opens new window) - Fixed the flickering of the selection area at the edge of the table while scrolling. #8317 (opens new window)
- Fixed misalignment on mobile devices when the edge cells were selected. #9621 (opens new window)
- Fixed type definitions for the method
setSourceDataAtCell
. #8599 (opens new window)
12.1.2
Released on July 8, 2022.
For more information on this release, see:
Changed
- Changed the version of the Moment.js dependency from 2.29.3 to 2.29.4, in reaction to a recently-found Moment.js security vulnerability. The vulnerability did not affect a correct configuration of Handsontable. #9638 (opens new window)
- Vue: Freezed the version of the Vue framework that is used in our build chain to ~2.6. This shouldn't affect apps that use Vue 2.7+. #9624 (opens new window)
12.1.1
Released on July 5, 2022.
For more information on this release, see:
Fixed
- Angular: Fixed an issue where the installation of
@handsontable/angular
package failed for versions of Angular other than 9 #9622 (opens new window)
12.1.0
Released on June 28, 2022.
For more information on this release, see:
Added
- Added smoother row and column moving when some row or columns are hidden. #7613 (opens new window)
- Added
getNearestNotHiddenIndex()
, a new method that finds the visual index of the nearest not-hidden row or column and works even with large numbers of hidden rows or columns. The previous method,getFirstNotHiddenIndex()
, still works, but is marked as deprecated. #9064 (opens new window) - Added a Czech translation. #9343 (opens new window)
- Added a Serbian translation. #9469 (opens new window)
- Added new hooks:
beforeColumnFreeze
,afterColumnFreeze
,beforeColumnUnfreeze
, andafterColumnUnfreeze
. #9248 (opens new window)
Changed
- Replaced HTML entities appearing in Handsontable's license texts with canonical counterparts. #9487 (opens new window)
- Updated the Pikaday optional dependency to 1.8.2, to let Handsontable work with Parcel 2 without errors. #9410 (opens new window)
- React: Changed the wrapper's lifecycle methods, to let Handsontable work with React 17+ without warnings. #8748 (opens new window)
- Angular: Moved the
@angular/core
dependency to peer dependencies. #9574 (opens new window)
Deprecated
- Deprecated the
getFirstNotHiddenIndex()
method. UsegetNearestNotHiddenIndex()
instead. #9064 (opens new window)
Fixed
- Fixed an issue where dropdown and autocomplete cell editors rendered incorrectly if the
preventOverflow
option was set to'horizontal'
. #3828 (opens new window) - Fixed an issue where frozen rows were getting duplicated. #4454 (opens new window)
- Fixed an issue where comments rendered outside the viewport. #4785 (opens new window)
- Fixed an issue where comments got positioned incorrectly when Handsontable ran within a scrollable element. #6744 (opens new window)
- Fixed an issue that occurred when Handsontable ran within an HTML
<form>
: pressing Enter inside another form's<input>
could open Handsontable's dropdown menu. #9295 (opens new window) - Fixed an issue where it was impossible to unmerge cells in the RTL layout direction. #9362 (opens new window)
- Fixed an issue where columns wider than the viewport's width and rows higher than the viewport's height didn't render correctly. #9473 (opens new window)
- Fixed an issue where dragging-to-scroll on mobile didn't work properly in the RTL layout direction. #9475 (opens new window)
- Fixed an issue where hiding columns with nested headers caused incorrect column width calculation
(for the
stretchH: 'all'
option). #9496 (opens new window) - Fixed an issue where
ShortcutManager
unnecessarily handledkeyup
events with nokey
defined. #9562 (opens new window)
12.0.1
Released on May 16, 2022.
For more information on this release, see:
Fixed
- Fixed an issue where checking or unchecking a checkbox in a row with
autoRowSize: true
and multi-line cell values caused rows to align incorrectly. #7102 (opens new window) - Fixed an issue where checking or unchecking a checkbox changed the cell width. #8211 (opens new window)
- Fixed an issue where using a single Handsontable instance with multiple HyperFormula sheets could
lead to an uncaught
TypeError
. #8268 (opens new window) - Fixed an issue where nested column headers didn't expand properly. #9099 (opens new window)
- Fixed an issue where updating custom borders could lead to uncaught error exceptions. #9455 (opens new window)
12.0.0
Released on April 28, 2022.
For more information on this release, see:
Added
- Added
ShortcutManager
, a new API for customizing keyboard shortcuts. #8942 (opens new window) - Added support for right-to-left (RTL) languages, by introducing a new configuration option:
layoutDirection
. #8760 (opens new window) - Added an Arabic translation. #9208 (opens new window)
- Added a new configuration option:
fixedColumnsStart
. #8760 (opens new window) - Added a new keyboard shortcut (Ctrl/Cmd + Enter) for filling the selected range of cells with the value of the active cell. #9366 (opens new window)
- Added support for the Home and End keys inside cell editors, for moving the cursor to the beginning or end of the text. #9367 (opens new window)
- Added support for the latest Node LTS version. #9149 (opens new window)
Changed
- Breaking change: Changed how
updateSettings()
handles data updates, to improve performance and the consistency of user experience. Now, when provided with a new data object,updateSettings()
updates the data without resetting any states. #7263 (opens new window) [migration guide] - Breaking change (React, Angular, Vue 2, Vue 3): Updating your data through a component property no longer resets your index mapper information and configuration options. #7263 (opens new window) [migration guide]
- Breaking change: Changed how
updatePlugin()
reacts toupdateSettings()
calls, to improve performance and the consistency of user experience. Now, calls toupdateSettings()
update a plugin's state only when the options object contains a configuration option that's relevant to that particular plugin. #9021 (opens new window) [migration guide] - Breaking change: Changed the order of execution for two hooks: now,
beforeKeyDown
is properly fired beforeafterDocumentKeyDown
. #6236 (opens new window) [migration guide] - Breaking change: Changed how default keyboard shortcuts are defined, to improve keyboard navigation consistency. Most of the shortcuts did not change and are now properly documented in the keyboard shortcuts guide. However, some shortcuts that were not defined explicitly, and were not listed in the documentation, don't work anymore (e.g., Enter opens a cell's editor, but Ctrl + Enter doesn't). This change doesn't affect custom keyboard shortcuts. #8942 (opens new window) [migration guide]
- Breaking change: Split a cross-platform modifier key (Ctrl/Cmd) into two separate keys, to improve keyboard navigation consistency. Now, the Cmd key triggers actions on macOS where the Ctrl key triggers actions on Windows. For example, on macOS, Ctrl + A doesn't work anymore: Cmd + A is used instead. #9369 (opens new window) [migration guide]
- Breaking change: Changed the actions of the following keyboard shortcuts, to match the usual spreadsheet software behavior, and provide a more intuitive user experience: Ctrl/Cmd + ↑, Ctrl/Cmd + Shift + ↑, Ctrl/Cmd + ↓, Ctrl/Cmd + Shift + ↓, Ctrl/Cmd + ←, Ctrl/Cmd + Shift + ←, Ctrl/Cmd + →, Ctrl/Cmd + Shift + →, Home, Ctrl/Cmd + Home, End, Ctrl/Cmd + End, Shift + Page Up, and Shift + Page Down. #9363 (opens new window) #9364 (opens new window) #9365 (opens new window) [migration guide]
- Changed two scripts of the main Handsontable workspace (
/
), to speed up the build process: now, thenpm run build
andnpm run test
scripts don't build or test the Handsontable examples (/examples
). #9412 (opens new window) - Changed the version of the Moment.js dependency from 2.24.0 to 2.29.3, in reaction to a recently-found Moment.js security vulnerability that did not directly affect Handsontable. #9381 (opens new window)
- Changed the version of the HyperFormula optional dependency from ^1.2.0 to ^2.0.0. #9411 (opens new window)
- Changed an internal property name, from
handsontableInstance.view.wt
tohandsontableInstance.view._wt
, to make it clear that Walkontable (Handsontable's rendering engine) is not a part of Handsontable's public API. #8760 (opens new window)
Removed
- Breaking change: Removed the Cmd + M keyboard shortcut (used for cell merging), as it conflicted with window minimizing on macOS. The Ctrl + M keyboard shortcut works the same as before. #9368 (opens new window) [migration guide]
- Breaking change: Removed the Shift + Page Up/Page Down keyboard shortcuts from the cell editing context. #9401 (opens new window) [migration guide]
- Dropped support for Internet Explorer 11 and Edge Legacy (the non-Chromium version of Edge). Handsontable 11.x becomes the long-term support (LTS) version for Internet Explorer 11 and Edge Legacy, until the end of 2023. #7026 (opens new window)
- React: Removed the
enzyme
dependency from the React wrapper. #9151 (opens new window)
Fixed
- React, Angular, Vue 2, Vue 3: Fixed an issue where using
updateSettings()
caused problems for state managers. #8372 (opens new window) - Fixed an issue where using
updateSettings()
caused hidden columns to reappear. #7165 (opens new window) - Fixed an issue where using
updateSettings()
caused merged cells to unmerge. #3315 (opens new window) - Fixed an issue where using
updateSettings()
caused the state of nested rows to reset. #8838 (opens new window) - Fixed an issue where using
updateSettings()
caused problems with column sorting. #7688 (opens new window) - React: Fixed an issue where using React's
setState()
within theafterFilter
hook broke filtering. #7567 (opens new window) - Vue 2: Fixed an issue where repeatedly changing Handsontable's height through
updateSettings()
caused Handsontable to crash. #7546 (opens new window) - Vue 2: Fixed an issue where the
failed
validation status got erased when editing a new row. #7541 (opens new window) - Fixed an issue where cell filtering did not use formula results. #5455 (opens new window)
- Fixed a wrong TypeScript definition in the
BasePlugin
class. #9175 (opens new window) - Fixed an issue where the Ctrl/Cmd + Z and Ctrl/Cmd + Shift + Z keyboard shortcuts didn't behave properly inside cell editors. #9367 (opens new window)
- Fixed an issue where the dropdown menu contained unwanted rectangle elements. #9240 (opens new window)
- React, Vue 2, Vue 3: Fixed an issue with registering modules for the React, Vue 2, and Vue 3
wrappers, by adding an
"exports"
field to theirpackage.json
files. #9140 (opens new window)
11.1.0
Released on January 13, 2022
For more information on this release, see:
Added
- Added
updateData()
, a new method that lets you replace Handsontable'sdata
without resetting the states of cells, rows and columns. #7263 (opens new window) - Vue: Added Vue 3 (opens new window) support, by introducing a new wrapper. #7545 (opens new window)
Changed
- Updated the TypeScript definition of the
setDataAtCell()
method. #8601 (opens new window) - Extended the
Code Examples Deployment
GitHub Actions workflow (opens new window), to allow for deploying code examples to GitHub Pages (opens new window)). #9058 (opens new window)
Fixed
- Fixed an issue where the
autocomplete
editor's suggestion list didn't update properly. #7570 (opens new window) - Fixed an issue where nested headers didn't render when
data
wasn't defined. #8589 (opens new window) - Fixed some end-to-end tests that failed on mobile devices. #8749 (opens new window)
- Fixed an issue where the rendered selection could get shifted by 1px. #8756 (opens new window)
- Fixed an issue where the first column's border didn't display properly. #8767 (opens new window)
- Fixed an issue where the
CollapsibleColumns
plugin'sexpandAll()
method didn't expand collapsed columns. #8900 (opens new window) - Fixed end-to-end test scripts that occasionally crashed. #8961 (opens new window)
- Fixed a typo in the
valueAccordingPercent()
helper. #9006 (opens new window) - Fixed an issue where the
NestedRows
plugin could throw a type error after calling theupdateSettings()
method. #9018 (opens new window) - Fixed an issue where performance was affected by removing events. #9044 (opens new window)
- Fixed a wrong TypeScript definition of the
MultiColumnSorting
plugin'ssort()
method. #9067 (opens new window) - Fixed an issue where the
Comments
plugin's editor disappeared after adding a comment. #9075 (opens new window) #6661 (opens new window) - React: Fixed a wrong return type. #9000 (opens new window)
11.0.1
Released on November 17, 2021.
For more information on this release, see:
Fixed
- Fixed the UMD build of
@handsontable/angular
, which was not working properly in11.0.0
. #8946 (opens new window)
11.0.0
Released on November 17, 2021.
For more information on this release, see:
Added
- Breaking change: Added TypeScript definition files for Handsontable's modularized version. #7489 (opens new window)
- Breaking change (Vue): Added support for modularization to the Vue wrapper. #8820 (opens new window)
- Breaking change (React): Added support for modularization to the React wrapper. #8819 (opens new window)
- Breaking change (Angular): Added support for modularization to the Angular wrapper. #8818 (opens new window)
- Added a new package entry point that allows importing built-in modules in one function call:
import { registerAllEditors, registerAllRenderers, registerAllValidators, registerAllCellTypes, registerAllPlugins } from 'handsontable/registry'
. #8816 (opens new window) - Added a new
locale
option, to properly handle locale-based data. #8897 (opens new window) - Added a GitHub Actions workflow that covers testing Handsontable and the wrappers. #8652 (opens new window)
- Added new direction helpers (internal API) that lay ground for future RTL support. #8868 (opens new window)
Changed
- Breaking change: Changed how the
populateFromArray()
method works with itsmethod
argument set toshift_down
orshift_right
. #888 (opens new window) - Moved the entire Handsontable package to its own, new subdirectory:
/handsontable
. #8759 (opens new window) - Replaced the license files with updated versions. #8877 (opens new window)
Fixed
- Fixed an issue with incorrect filtering of locale-based data while using search input from a dropdown menu. #6095 (opens new window)
- Fixed an error thrown when using the
populateFromArray()
method with itsmethod
argument set toshift_right
. #6929 (opens new window) - Fixed an issue with the
beforeOnCellMouseDown
andafterOnCellMouseDown
hooks using wrong coordinates. #8498 (opens new window) - Fixed a
TypeError
thrown when calling theupdateSettings()
method in Handsontable's modularized version. #8830 (opens new window) - Fixed two issues with the documentation's
canonicalUrl
entries. #8886 (opens new window) - Fixed an error thrown when autofill's source is a
date
cell. #8894 (opens new window) - React: Fixed a React wrapper issue where it's impossible to use different sets of props in editor components reused across multiple columns. #8527 (opens new window)
10.0.0
Released on September 29, 2021.
For more information on this release, see:
Changed
- Breaking change: Unified the naming and description of the fourth argument,
controller
, for selection manipulation in thebeforeOnCellMouseDown
andbeforeOnCellMouseOver
hooks. #4996 (opens new window) - Breaking change: Changed what the
beforeRender
andafterRender
hooks are, and when they are triggered. Added two new hooks:beforeViewRender
andafterViewRender
. #6303 (opens new window) - Breaking change: Changed the optional
HyperFormula (opens new window) dependency from
0.6.2
to^1.1.0
, which introduces breaking changes for theFormulas
plugin users. #8502 (opens new window) - Breaking change: Changed the default values for the
rowsLimit
andcolumnsLimit
options of theCopyPaste
plugin. #8660 (opens new window) - Breaking change: Added a default font family, size, weight and color. #8661 (opens new window)
- Breaking change: Changed the
autoWrapRow
andautoWrapCol
options` default values fromtrue
tofalse
. #8662 (opens new window) - Improved the performance of the
getCellMeta()
method. #6303 (opens new window) - Improved the documentation and TypeScript definition of the
selectOptions
option. #8488 (opens new window) - Improved the arguments forwarding in the hooks #8668 (opens new window)
- Added a Github Actions workflow covering the testing of Handsontable and all of the wrappers. #8652 (opens new window)
Fixed
- Fixed an issue of not resetting the date picker's configuration #6636 (opens new window)
- An error won't be thrown while inserting a new row for nested rows in a specific case #7137 (opens new window)
- Fixed a few problems with the
NestedRows
plugin, occurring with theFormulas
plugin enabled. #8048 (opens new window) - Fixed errors being thrown in the
Formulas
plugin if a provided sheet name contained a dash character #8057 (opens new window) - Fixed multiple bugs related to undo/redo actions while using the
Formulas
plugin #8078 (opens new window) - Fixed an issue where autofill was not able to be blocked/changed with the
beforeChange
hook when theFormulas
plugin was enabled #8107 (opens new window) - Data stored by the
NestedRows
plugin won't be corrupted by some actions #8180 (opens new window) - Collapsed parents won't be expanded after inserting rows #8181 (opens new window)
- Fixed the cooperation of the dropdown menu and column sorting (menu closing on click) #8232 (opens new window)
- Data won't be corrupted anymore when some alterations are performed #8614 (opens new window)
- Adjusted directories and files related to
dataMap
(opens new window), to prevent potential circular references. #8704 (opens new window) - Improved the performance of the regular expression used to detect numeric values, and fixed major code smells. #8752 (opens new window)
9.0.2
Released on July 28, 2021.
For more information on this release, see:
Fixed
- Fixed an issue with an error being thrown when lazy loading columns on a setup with Nested Headers + Hidden Columns. #7160 (opens new window)
- Fixed column header sizes not being updated on
updateSettings
calls containingcolumns
. #7689 (opens new window) - Fixed functional keys' behavior to prevent unexpected editing. #7838 (opens new window)
- Fixed missing collapsible indicator on IE. #8028 (opens new window)
- Fixed support for row and column headers in the
parseTable
utility. #8041 (opens new window) - Fixed a bug where not providing a data object with the
NestedRows
plugin enabled crashed the table. #8171 (opens new window) - Vue: Fixed an issue where adding rows to a Handsontable instance wrapped for Vue resulted in additional rows being inserted at the end of the table. #8148 (opens new window)
- Vue: Fixed a problem in the Vue wrapper, where destroying the underlying Handsontable instance caused it to throw errors and crash. #8311 (opens new window)
- React: Fixed a problem in the React wrapper, where destroying the underlying Handsontable instance caused it to throw errors and crash. #8311 (opens new window)
- Angular: Fixed a problem in the Angular wrapper, where destroying the underlying Handsontable instance caused it to throw errors and crash. #8311 (opens new window)
Added
- Added new documentation engine #7624 (opens new window)
9.0.1
Released on June 17, 2021.
For more information on this release, see:
Removed
- Removed the redundant internal
jsonpatch
library from the source code. (#8140 (opens new window))
Fixed
- Fixed an issue where the validator function was called twice when the
Formulas
plugin was enabled. (#8138 (opens new window)) - Introduced a new CSS style for cells of the
checkbox
type to restore previous behaviour. (#8196 (opens new window))
9.0.0
Released on June 1, 2021.
For more information on this release, see:
Changed
- Breaking change: New
Formulas
plugin, with an entirely different API. See the migration guide for a full list of changes. Removed the requiredhot-formula-parser
dependency for the sake of an optional one,hyperformula
. (#6466 (opens new window)) - Breaking change: Changed the
afterAutofill
andbeforeAutofill
hooks' signatures. (#7987 (opens new window)) - Upgraded
eslint
and eslint-related modules. (#7531 (opens new window)) - Added
fit
&fdescribe
to restricted globals in test files. (#8088 (opens new window))
Deprecated
- Deprecated the
beforeAutofillInsidePopulate
hook. It will be removed in the next major release. (#8095 (opens new window))
Removed
- Breaking change: Removed the deprecated plugins - Header Tooltips and Observe Changes. (#8083 (opens new window))
Fixed
- Fixed a problem with the column indicator of the
CollapsibleColumns
plugin not being displayed properly on styled headers. (#7970 (opens new window)) - Fixed a problem with duplicated
afterCreateCol
hooks being triggered after undoing a removal of a column. (#8076 (opens new window)) - Fixed a problem with formulas not being calculated in certain conditions. (#4430 (opens new window))
- Fixed a bug with formulas displaying incorrect values after inserting new rows. (#4654 (opens new window))
- Fixed a problem with the
AVARAGE
formula being updated incorrectly. (#4675 (opens new window)) - Fixed a problem with the
IF
formulas not working properly. (#5870 (opens new window)) - Fixed a bug with using the
clear
method broke the formulas in the table. (#6248 (opens new window))
8.4.0
Released on May 11, 2021.
For more information on this release, see:
Added
- Introduced a
separated
attribute for the label options (thelabel
DOM element may wrapinput
or be placed next to it). (#3172 (opens new window)) - Introduced the
modifyAutoColumnSizeSeed
hook to let developers overwrite the default behaviour of the AutoColumnSize sampling. (#3339 (opens new window)) - Added support for hiding columns for the
NestedHeaders
plugin. (#6879 (opens new window)) - Added ability to skip stacking actions by the
UndoRedo
plugin and introduced new hooks. (#6948 (opens new window)) - Added 2 new hooks,
beforeHighlightingColumnHeader
andbeforeHighlightingRowHeader
. Use them to retrieve a header element (<th>
) before it gets highlighted. (#7528 (opens new window)) - Added a new method,
indexMapper.unregisterAll()
. Use it to unregister all collected index maps from all map collections types. (#7528 (opens new window)) - Added a new method,
indexMapper.createChangesObserver()
. Use it to listen to any changes made to indexes while Handsontable is running. (#7528 (opens new window)) - Added a new method,
indexMapper.createAndRegisterIndexMap()
. Use it to create and register a new index map. (#7528 (opens new window))
Fixed
- Fixed a problem with sorting the
checkbox
-typed cells and an issue with empty cells not being displayed properly. (#4047 (opens new window)) - Fixed a problem where undoing the removal of row with
readOnly
cells was not performed properly. (#4754 (opens new window)) - Fixed state-change resolving for externally added checkboxes. (#5934 (opens new window))
- Fixed a problem with the native selection being removed with the
fragmentSelection
option enabled. (#6083 (opens new window)) - Fixed a bug where number of columns rendered in the viewport was not correct. (#6115 (opens new window))
- Fixed a bug with the Dropdown Menu not opening on Android devices. (#6212 (opens new window))
- Fixed the double-tap issue on iOS. (#6961 (opens new window))
- Fixed a problem with the Comments editor being destroyed after destroying another Handsontable instance. (#7091 (opens new window))
- Fixed incorrect
numericFormat
's type definition. (#7420 (opens new window)) - Fixed the
trimWhitespace
tests on Firefox. (#7593 (opens new window)) - Fixed the [NPM Audit] Github Action job to report found vulnerabilities. (#7621 (opens new window))
- Fixed some minor iOS problems. (#7659 (opens new window))
- Fixed the TypeScript definition for the suspended rendering feature. (#7666 (opens new window))
- Fixed the
postbuild
andexamples:install
scripts on Windows. (#7680 (opens new window)) - Fixed the contents of the production
package.json
. (#7723 (opens new window)) - Fixed an issue, where the callbacks for the
UndoRedo
plugin were called twice. (#7825 (opens new window)) - Vue: Fixed a problem with displaying and removing rows in the
NestedRows
plugin. (#7548 (opens new window)) - React: Fixed an incompatibility in the property type definitions for the HotColumn component. (#7612 (opens new window))
Changed
- Enhanced the ESLint config file by adding a rule that checks if there are new lines missing before some keywords or statements. (#7691 (opens new window))
8.3.2
Released on March 16, 2021.
For more information on this release, see:
Added
- Introduced the monorepo to this repository. From now
on,
handsontable
,@handsontable/angular
,@handsontable/react
, and@handsontable/vue
will all be developed in the same repo -handsontable
. (#7380 (opens new window)) - Added a custom ESLint rule which allows restricting specified modules from loading by
import
or re-exporting. (#7473 (opens new window))
Fixed
- Fixed a bug where it was impossible to enable
disableVisualSelection
for cells/columns. (#5082 (opens new window)) - Fixed wrong paddings for multi-level headers. (#5086 (opens new window))
- Fixed problems with the
current
option of thedisableVisualSelection
setting. (#5869 (opens new window)) - Fixed problems with the
header
option of thedisableVisualSelection
setting. (#6025 (opens new window)) - Fixed a bug where the "double-tap-to-zoom" gesture prevented the editor from opening properly on some mobile devices. (#7142 (opens new window))
- Fixed a bug where calling the
updateSettings
method in the body of some callbacks would break the table. (#7231 (opens new window)) - Fixed an issue where the
maxRows
andmaxCols
options interfered with hidden index calculations. (#7350 (opens new window)) - Fixed problems with doubled borders being displayed when
window
was a scrollable container. (#7356 (opens new window)) - Fixed a bug where value population from an edited cell would result in a console error. (#7382 (opens new window))
- Fixed a bug where the dropdown cell type would not work on Safari 14+. (#7413 (opens new window))
- Fixed a bug where the
AutoRowSize
plugin would break the table when placed in an iframe. (#7424 (opens new window)) - Fixed bugs in navigation by
HOME
andEND
keys with hidden rows/columns enabled. (#7454 (opens new window)) - Fixed a bug with the
trimWhitespace
option not working properly. (#7458 (opens new window)) - Fixed an issue with inconsistent documentation and TypeScript definitions
for
colWidths
androwHeights
options. (#7507 (opens new window)) - Fixed the incorrect
cellTypes
module paths in theexports
entry of thepackage.json
file. (#7597 (opens new window)) - Vue: Fixed Remote Code Execution vulnerability in the dev dependencies. (#7620 (opens new window))
8.3.1
Released on February 10, 2021.
For more information on this release, see:
Fixed
- Fixed an issue where the CSS files could be eliminated during tree-shaking. (#7516 (opens new window))
8.3.0
Released on January 28, 2021.
For more information on this release, see:
Added
- Introduced a new feature that allows postponing the table render and internal data cache update.
The table rendering time can be reduced several-fold times by batching (using the
batch
method), multi-line API calls, or manually suspending rendering using thesuspendRender
andresumeRender
methods. (#7274 (opens new window)) - Introduced a possibility to import:
- plugins
- cell types
- editors
- renderers
- validators as separate modules, along with the Handsontable base. This change allows utilizing only the parts of Handsontable the end application is actually using, without the overhead of the full bundle. (#7403 (opens new window))
- Added a new workflow for managing and generating changelogs. (#7405 (opens new window))
Fixed
- Fixed a bug with auto-execution of the first item in the
ContextMenu
plugin. (#7364 (opens new window)) - Fixed a bug where column sorting with multi column sorting crashed the table. (#7415 (opens new window))
- Added a missing entry for the
skipRowOnPaste
option in the TypeScript definition file. (#7394 (opens new window)) - Added missing tests to prevent issue #7377 from resurfacing. (#7396 (opens new window))
- Fixed an issue where altering columns did not update filters attached to columns. (#6830 (opens new window))
- Fixed typos and wrong return types in the TypeScript definition file. (#7399 (opens new window))
- Updated the dependencies causing potential security issues, as well as Babel configuration needed after the update. (#7463 (opens new window))
Changed
- Corrected a typo in a helper method from the
ColumnSorting
plugin. (#7375 (opens new window)) - Optimized the performance of rendering the table with numerous spare rows (for
minSpareRows
,minSpareCols
,minRows
, andminCols
options). (#7439 (opens new window))
8.2.0
Released on November 12, 2020.
For more information on this release, see:
Added
- Added a new type of an Index Map named
LinkedPhysicalIndexToValueMap
. (#7276 (opens new window)) - Added an external dependency,
DOMPurify
, to add HTML sanitization that should minimize the risk of inserting insecure code using Handsontable built-in functionalities. (#7292 (opens new window))
Fixed
- Fixed an issue where the container was not updated after trimming rows. (#7241 (opens new window))
- Fixed an issue where the
htmlToGridSettings
helper threw an error if a<table>
with no rows was passed. (#7311 (opens new window)) - Fixed an issue where the sorting indicator moved incorrectly when a column was added. (#6397 (opens new window))
- Fixed an issue where untrimming previously trimmed rows would sometimes result in the table instance not refreshing its height, leaving the row headers improperly rendered. (#6276 (opens new window))
- Fixed an issue where the hidden columns plugin caused unintended scrolling when some cells were hidden. (#7322 (opens new window))
- Fixed an issue where an error was thrown while hovering over row/column headers. (#6926 (opens new window))
- Fixed an issue where table validation caused incorrect data rendering if the hidden rows/column plugin was enabled. (#7301 (opens new window))
- Fixed an issue where adding 0 rows to the table ended with doubled entries in index mappers' collections. (#7326 (opens new window))
- Fixed a problem with the inconsistent behavior of the Context Menu's "Clear column" disabled status. (#7003 (opens new window))
- Fixed an issue with parsing multiline cells on pasting
text/html
mime-type. (#7369 (opens new window))
8.1.0
Released on October 1, 2020.
For more information on this release, see:
Added
- Added support for resizing non-adjacent selected rows and columns. (#7162 (opens new window))
- Added e2e tests and reorganized already existing ones. (#6491 (opens new window))
Changed
- Updated dependencies to meet security requirements. (#7222 (opens new window))
- Improved performance for
TrimRows
,HiddenRows
andHiddenColumns
plugins for big datasets with many trimmed/hidden indexes. (#7223 (opens new window))
Fixed
- Fixed an issue where the value did not show if the first part of the merged area was hidden. (#6871 (opens new window))
- Fixed an issue where after selecting the top-left element, resizing the row range was not possible. (#7162 (opens new window))
- Fixed a bug introduced within (#6871 (opens new window))
- Fixed an issue where column headers were cut off after hiding and revealing the columns with the
HiddenColumns
plugin. (#6395 (opens new window)) - Fixed an issue where a redundant row was added during copy/paste operations in some cases. (#5961 (opens new window))
- Fixed an issue where too many values were pasted after a column was hidden. (#6743 (opens new window))
- Fixed a bug where an attempt to move collapsed parent rows, with the
NestedRows
plugin enabled, resulted in an error. (#7132 (opens new window)) - Fixed an issue where, after column or row alteration, Handsontable threw an error if
ColumnSummary
was enabled without defined row ranges. (#7174 (opens new window)) - Fixed an issue where using
updateSettings
was breaking column sorting in specific cases. (#7228 (opens new window)) - Fixed an issue where, if
fixedColumnsLeft
was defined, rows had their left borders missing after disabling the row headers usingupdateSettings
. (#5735 (opens new window)) - Fixed an issue where the Handsontable instance could fall into an infinite loop during vertical
scrolling. It only happened when the scrollable element was the
window
object. (#7260 (opens new window)) - Fixed an issue with moving rows to the last row of the table when the
NestedRows
plugin was enabled. Repaired some other minor moving-related bugs as well. (#6067 (opens new window)) - Fixed an issue with adding an unnecessary extra empty line in cells on Safari. (#7262 (opens new window))
- Fixed an issue with clipped column headers when they were changed before or within usage of
updateSettings
. (#6004 (opens new window))
8.0.0
Released on August 5, 2020.
For more information on this release, see:
Major changes
This version introduces a completely new architecture for row and column management - index mapper, which is responsible for the storage and management of index values. In prior versions, the calculation between physical and visual indexes was based on callbacks between hooks. That solution slowly led to inconsistencies and the calculation was imperfect in some cases. To fix that there was a major change in the whole system of mapping the indexes. The current solution offers an easier and more straightforward way to perform CRUD and move operations on rows and columns. It keeps all data in one place so getting and managing information is easier and less prone to bugs.
The existing features were adapted to benefit from the new architecture. Apart from that, extra methods and hooks were added and there are few depreciations and removals, too.
Breaking changes
- Modifying the table's data by reference and calling
render()
will not work properly anymore. From this point onward, all the data-related operations need to be performed using the API methods, such aspopulateFromArray
orsetDataAtCell
. - The
modifyRow
,modifyCol
,unmodifyRow
,unmodifyCol
hooks are no longer needed and were removed. Their functionality can be achived by using API. More information in the 8.0.0 migration guide (opens new window). skipLengthCache
hook was removed,indexMapper
is now responsible for the cache and length.- The
ManualColumnFreeze
plugin doesn't use theManualColumnMove
plugin anymore. - The
CollapsibleColumns
plugin doesn't use theHiddenColumns
plugin anymore. - The
NestedRows
andFilters
plugins don't use theTrimRows
plugin anymore. - The
minSpareRows
andminRows
options will ensure that the number of visible rows corresponds to the value provided to them (for example, theTrimRows
plugin won't have an impact on the number of displayed rows). toPhysicalRow
andtoVisualColumn
now returnnull
for non-existant rows/columns. #5945 (opens new window)).- The
afterLoadData
hook receives a different set of arguments. It used to be just the initialLoad flag, now the first argument issourceData
, followed byinitialLoad
. - The
ManualColumnFreeze
plugin will now put the unfrozen columns right next to the last frozen one. - The
RecordTranslator
object and thet
property available in the plugins were removed. - After-prefixed hooks (
afterLoadData
,afterFilter
, etc.) are now called just before therender
call. - Newly created rows and columns are now placed in the source data in the place calculated from its position in the visual context (they "stick" to their adjacent rows/columns). It also applies to moved rows and columns.
- When the
NestedRows
plugin isenabled
, moving rows will be possible only using the UI or by calling thedragRows
method of theManualRowMove
plugin. - The
beforeRowResize
,afterRowResize
,beforeColumnResize
,afterColumnResize
hooks have the order of their arguments rearranged for the sake of consistency with other hooks and to fix an issue where multiple hooks didn't get the modified value in the pipeline: #3328 (opens new window). - Changed the argument structure in
collapsibleColumns
'toggleCollapsibleSection
method: #6193 (opens new window). - The following sublist shows changes related to the refactor of
HiddenColumns
andCollapsibleColumns
. They will be compatible with upcomingIndexMappers
#5945 (opens new window) along with other adjustments #6547 (opens new window):- Hidden indexes aren’t rendered. As a consequence hooks
beforeValueRender
,beforeRenderer
,afterRenderer
,modifyColWidth
,beforeStretchingColumnWidth
etc. will be executed just for some of the columns (just the rendered ones). - The
getColWidth
for hidden index will return 0 – it used to return 0.1. Also, it will no longer be called internally, the need can be now achieved by managers of rows and columns. - The
modifyColWidth
hook will not be called internally. However, it will be executed when the user will call thegetColWidth
. - Hidden indexes aren't rendered. As a consequence hooks
beforeValueRender
,beforeRenderer
,afterRenderer
,modifyColWidth
,beforeStretchingColumnWidth
etc. will be executed just for some of the columns (just the rendered ones). listen
function from the core API used to acceptmodifyDocumentFocus
as optional parameter, this parameter was removed.CustomBorders
plugin was adapted to work withHiddenColumns
properly. From now on hiding cells at the start or the end of the range will also hide their borders. Hiding a single cell with borders will hide all of its borders. #7083 (opens new window).CollapsibleColumns
will no longer useHiddenColumns
plugin to work. #6204 (opens new window).- Adjusted
HiddenColumns
to be compatible with upcomingIndexMappers
. #6547 (opens new window). hiddenRow
andhiddenColumn
hooks were removed. They were used to check if a given index is hidden in theHiddenColumns
andHiddenRows
plugins. Since now there may be more sources of hiding indexes they have been replaced byIndexMapper
with the newisHidden
method. It keeps the broad information about hidden indexes and their sources.rowOffset
andcolOffset
were removed since they aliased the methods from Walkontable. #6547 (opens new window).
- Hidden indexes aren’t rendered. As a consequence hooks
- Changes related to adjusting
HiddenRows
to newIndexMapper
architecture are #6177 (opens new window):- Adjusted
HiddenRows
to newIndexMapper
architecture. #6177 (opens new window).
- Adjusted
- Developed a unified way to identify HOT "input" elements. All input elements owned by HOT got an attribute "data-hot-input" which are identified by that key. #6383 (opens new window).
NestedHeaders
plugin was rewritten, from now on, only a tree-like structure will be allowed, meaning, there will be no possibility to place nested headers in-between layers. #6716 (opens new window)- The right mouse button (
RMB
) click on the corner when there is no data will show all options disabled. #6547 (opens new window). - Left mouse button (
LMB
) click on the top left corner will now select all cells along with their headers. #6547 (opens new window). - Removed the experimental
GanttChart
plugin. #7022 (opens new window). - Adding properties which were not defined on initialization or by
updateSettings
to the source data is possible only by the usage ofsetSourceDataAtCell
. #6664 (opens new window). - Passing
columns
ordata
inside thesettings
object when calling theupdateSettings
method will result in resetting states corresponding to rows and columns (ie. row/column sequence, column width, row height, freezed columns etc.). The same behavior can be seen when usingloadData
. In such cases, it is assumed that a new dataset is introduced upon callingupdateSettings
orloadData
.#6547 (opens new window).
New features
- Added the Index Mapper architecture and its API. #5112 (opens new window) (more information available in the PRs #5945 (opens new window) with additional changes in #6547 (opens new window))
- Added a new
batch
method. #5945 (opens new window) along with other adjustments (#7068 (opens new window))
Deprecations
- The
ObserveChanges
plugin is no longer enabled bycolumnSorting
and became deprecated. #5945 (opens new window) HeaderTooltips
plugin becomes deprecated and will be removed in the next major version. #7023 (opens new window)- IE support is deprecated and will be removed by the end of the year. #7026 (opens new window)
Changelog
- Added
modifySourceData
hook andsetSourceDataAtCell
method. #6664 (opens new window) - Added new argument to
scrollViewportTo
method: optionalconsiderHiddenIndexes
which is aboolean
. #6547 (opens new window) - Added additional information available in the cell meta object - the language. #6254 (opens new window).
- Added a possibility to allow cancelling of
autofill
in thebeforeAutofill
hook. #4441 (opens new window) - Added support for newer versions of moment, numbro and pikaday. #5159 (opens new window)
- Added
afterAutoFill
hook. #6135 (opens new window) - Added deprecated warning messages mechanism for plugin hooks. #6613 (opens new window)
- Added missing types for `instance.undoRedo`. #6346 (opens new window)
- Added
countRenderableColumns
method to theTableView
. #6177 (opens new window) - Added missing "hide" property in
CustomBorders
typings. #6788 (opens new window) - Added
beforeSetCellMeta
hook with an ability to cancel the changes. #5388 (opens new window) - Added additional test for autofill plugin. #6756 (opens new window)
- Changed how
ManualRowMove
andManualColumnMove
plugins work #5945 (opens new window) - Click on a row header will select all cells (also hidden). #2391 (opens new window)
- Extracted Cell-Meta logic from Core to separate module. #6254 (opens new window)
- The
CellMeta
manager was refactored for future features and improvements. #6233 (opens new window) - Rows can be resized to less than
rowHeights
. #6149 (opens new window) - Left mouse button (LMB) click on the corner will now select all cells. #6547 (opens new window)
- Passing
columns
ordata
inside thesettings
object when calling theupdateSettings
method will result in resetting states corresponding to rows and columns (ie. row/column sequence, column width, row height, freezed columns etc.). The same behavior can be seen when usingloadData
. In such cases, it is assumed that a new dataset is introduced upon callingupdateSettings
orloadData
.#6547 (opens new window). - The right mouse button (
RMB
) click on the corner, column and row headers will show just some options, defined by newly created specification #7082 (opens new window) - Hidden indexes will no longer be rendered, as a consequence
afterRenderer
,modifyColWidth
,beforeStretchingColumnWidth
will be executable only on visible (meaning, rendered) rows and columns. #6547 (opens new window) - The
getColWidth
for hidden index will return 0 - it used to return 0.1 #6547 (opens new window) - The
modifyColWidth
hook isn't called internally. However, it will be executed when the user will call thegetColWidth
. #6547 (opens new window) - Hidden rows/columns won't rendered anymore. As a consequence hooks
beforeValueRender
,beforeRenderer
,afterRenderer
,modifyColWidth
,beforeStretchingColumnWidth
etc. will be executed just for some of the columns (just the renderable ones). #6547 (opens new window) - Selection behavior changed when hiding cells from the
ContextMenu
, now it is selecting a column on the right when there is space on right to the last selected column, selecting a column on the left otherwise. #6547 (opens new window) - Developed a unified way to identify HOT "input" elements. All input elements owned by HOT got an attribute "data-hot-input" which are identified by that key. #6383 (opens new window)
NestedHeaders
plugin was rewritten, from now on, only a tree-like structure will be allowed, meaning, there will be no possibility to place nested headers in-between layers. #6716 (opens new window)CustomBorders
plugin was adapted to work withHiddenColumns
properly, from now on hiding cells at the start or at the end of a range will also hide their borders. Also, hiding a single cell with borders will hide all of its borders. #7083 (opens new window)CollapsibleColumns
will no longer useHiddenColumns
plugin to work. #6204 (opens new window)- Modifying the table's data by reference and calling `render()` will not work properly anymore.
From this point onward, all the data-related operations need to be performed using the API
methods, such as
populateFromArray
orsetDataAtCell
. #5945 (opens new window) - Removed dependencies between plugins: the
ManualColumnFreeze
plugin doesn't use theManualColumnMove
, theCollapsibleColumns
plugin doesn't use theHiddenColumns
plugin,NestedRows
plugin doesn't use theTrimRows
plugin,Filters
plugin doesn't use theTrimRows
plugin anymore. #5945 (opens new window) along with other adjustments [#6547](https:// github.com/handsontable/handsontable/pull/6547): - The
minSpareRows
andminRows
options will ensure that the number of visible rows corresponds to the value provided to them (for example, theTrimRows
plugin won't have an impact on the number of displayed rows). #5945 (opens new window) toPhysicalRow
andtoVisualColumn
now returnnull
for non-existant rows/columns. #5945 (opens new window)- The
afterLoadData
hook receives a different set of arguments. It used to be just the initialLoad flag, now the first argument issourceData
, followed byinitialLoad
. #5945 (opens new window) - The
ManualColumnFreeze
plugin unfreezes the column just after the "line of freeze". #5945 (opens new window) - The
RecordTranslator
object and thet
property available in the plugins were removed. #5945 (opens new window) - After-prefixed hooks (
afterLoadData
,afterFilter
, etc.) are now called just before therender
call. #5945 (opens new window) - Newly created rows and columns are now placed in the source data in the place calculated from its position in the visual context (they "stick" to their adjacent rows/columns). It also applies to moved rows and columns. #5945 (opens new window)
- When the
NestedRows
plugin isenabled
, moving rows will be possible only using the UI or by calling thedragRows
method of themanualRowMove
plugin. #5945 (opens new window) - The
beforeRowResize
,afterRowResize
,beforeColumnResize
,afterColumnResize
hooks have the order of their arguments rearranged for the sake of consistency with other hooks. #3328 (opens new window) - Changed the argument structure in
collapsibleColumns
'toggleCollapsibleSection
method. #6193 (opens new window) - Updated the
moment
,numbro
andpikaday
dependencies to their latest versions. #6610 (opens new window) - Standardize the `z-index` properties between the overlays. #6269 (opens new window)
HeaderTooltips
plugin becomes deprecated and will be removed in the next major version. #7023 (opens new window)- IE support is depreacated and will removed by the end of the year. #7026 (opens new window)
- Removed
firstVisibleColumn
CSS class as no longer needed. #6547 (opens new window) - Removed helpers that covered IE8 support or are not needed anymore. #6525 (opens new window)
- Removed old unnecessary warning about
beforeChange
callback. #6792 (opens new window) - Removed
debug
key (key, css, docs). #6672 (opens new window) - Removed
hiddenRow
andhiddenColumn
hooks. #6547 (opens new window) - Removed optional argument
modifyDocumentFocus
from thelisten
function. #6547 (opens new window) - Removed
rowOffset
andcolOffset
public API methods since they aliased the methods from Walkontable. #6547 (opens new window) - Removed the experimental
GanttChart
plugin. #7022 (opens new window) - Removed post-install warning from package.json file #6608 (opens new window)
- The
modifyRow
,modifyCol
,unmodifyRow
,unmodifyCol
andskipLengthCache
hooks are no longer needed and were removed. #5945 (opens new window) - Fixed a problem with data not being added to the table properly with the
columnSorting
option enabled. #2685 (opens new window) - Fixed a problem with
loadData
not resetting the row order changed by theManualRowMove
plugin. #3568 (opens new window) - Fixed a bug, where using
alter
'sinsert_row
after using theloadData
method and sorting the data would add unintentional additional rows to the table. #3809 (opens new window) - Fixed a bug, where blank rows appeared in the middle of the table after using
loadData
along with theminSpareRows
option. #3937 (opens new window) - Fixed a problem with the
ColumnSummary
plugin not working properly after adding new rows using the Context Menu and sorting the data. #3924 (opens new window) - Fixed a bug, where calling
loadData
with an object-based data source would not work properly. #4204 (opens new window) - Fixed a problem with the Hidden Columns settings being reset after calling
updateSettings
. #4121 (opens new window) - Fixed a bug with the
Filters
plugin using incorrect indexes after moving and/or sorting the table. #4442 (opens new window) - Fixed a bug that caused a column to contain improper data after moving it to index
0
. #4470 (opens new window) - Fixed a bug with the
afterRowMove
hook receiving an impropertarget
argument. #4501 (opens new window) - Fixed a problem with the
ManualColumnFreeze
plugin enablingManualColumnMove
, even if it was declared asfalse
. #4553 (opens new window) - Fixed a problem with plugins using
arrayMappers
not working properly after updating the dataset. #4567 (opens new window) - Fixed a bug, where calling
loadData
withminSpareRows
andmanualRowMove
enabled caused the table to improperly load the data. #4576 (opens new window) - Fixed a bug, where enabling
columnSorting
caused themanualColumnFreeze
to be unusable. #4601 (opens new window) - Fixed a problem, where the columns were assigned improper widths after inserting additional columns or removing any of them. #4666 (opens new window)
- Fixed a bug, where moving rows was impossible while
persistentState
was enabled. #4713 (opens new window) - Fixed a bug, where
manualColumnMove
didn't work if the dataset was empty. #4926 (opens new window) - Fixed a bug with the
collapseAll
method from thecollapsibleColumns
plugin did not work properly ifcolumnSorting
was enabled. #4999 (opens new window) - Fixed a bug, where calling
loadData
withminSpareRows
enabled would cause unwanted blank rows to appear. #5707 (opens new window) - Fixed a bug with the
afterColumnMove
hook receiving an impropertarget
argument. #5173 (opens new window) - Fixed a problem, where filtering data after moving rows would not work properly. #5178 (opens new window)
- Fixed a bug, where calling
loadData
madeNaN
appear in the column headers. #5369 (opens new window) - Fixed a bug with the
skipColumnOnPaste
option not working properly when usingcolumnSorting
andhiddenColumns
. #5824 (opens new window) - Fixed a bug with the
TrimRows
plugin did not work properly after moving rows. #5860 (opens new window) - Fixed a problem with
minSpareRows
not working properly with thetrimRows
plugin being used. #5862 (opens new window) - Fixed a problem, where it was impossible to filter the data declared in the
NestedRows
plugin . #5889 (opens new window) - Fixed a bug, where filtering and sorting data would cause the
toVisualRow
method to return the wrong results. #5890 (opens new window) - Fixed a bug with the
filters
andtrimRows
plugins not working properly alongside each other. #5915 (opens new window) - Fixed a bug, where
manualColumnMove
would not work properly when the data object properties count would be lower than the table column count. #5931 (opens new window) - Fixed a bug with the
TrimRows
plugin did not work properly with thestartRows
option. #5953 (opens new window) - Fixed a problem, where using
loadData
after sorting would not work as expected. #5956 (opens new window) - Fixed a problem with the
beforeColumnMove
andafterColumnMove
hooks not containing information about their destination indexes. #6005 (opens new window) - Fixed a problem where using
filters
andminSpareRows
would make the table add an empty row at the beginning of the table. #6278 (opens new window) - Fixed a bug with the
manualRowMove
plugin would duplicate data in the moved rows, when used with a row index greater than the table row count. #6088 (opens new window) - Fixed a bug, where the
toVisualRow
method returnednull
when using thetrimRows
andcolumnSorting
plugins together. #6310 (opens new window) - Fixed a problem, where calling
updateSettings
in theafterColumnMove
hook callback would have no effect. #4480 (opens new window) - Fixed a bug, where calling
loadData
would make thefilters
plugin to not behave as expected. #5244 (opens new window) - Fixed a bug, where detaching a child from a parent in the
NestedRows
plugin would cause a `+/-` button misalignment. #5900 (opens new window) - Fixed a problem with the
ColumnSummary
plugin creating a doubled summary row. #5794 (opens new window) - Fixed a bug, where moving children between parents using the
NestedRows
plugin would throw an error. #6066 (opens new window) - Fixed a bug, where adding rows by modifying the data by reference while using the
NestedRows
plugin would throw an error. #3914 (opens new window) - Fixed a bug, where merging cells would conflict with the
columnSorting
plugin. #6086 (opens new window) - Fixed a bug, where the row headers would stay visible after removing all the table columns. #6412 (opens new window)
- Fixed an issue where Hidden columns become visible when the user ran
updateSettings
. #4121 (opens new window) - Fixed an issue where using
hiddenColumns
andstretchH
showed a redundant horizontal scrollbar. #4181 (opens new window) - Fixed an issue in which if the last column was a hidden column and
stretchH
was enabled, the last column was displayed. #4370 (opens new window) - Fixed an issue where
updateSettings
performance was very low because ofhiddenColumns
being rendered. #4381 (opens new window) - Fixed an issue where collapse was not working correctly with custom cell renderers. #4716 (opens new window)
- Fixed an incorrect header name when user defined more columns in the
NestedHeaders
plugin. #4716 (opens new window) - Fixed an issue where
HiddenColumns
did not work properly withColumnSorting
. #5571 (opens new window) - Fixed an issue where
ManualColumnMove
should work withHiddenColumns
. #5598 (opens new window) - Fixed an issue where
hiddenColumns
option interfered with the keyboard movement. #5704 (opens new window) - Fixed an issue where after hiding the first two rows, the row headers became de-synchronized by 1px. #5817 (opens new window)
- Fixed an issue where hiding columns affected selection of hidden columns. #5871 (opens new window)
- Fixed an issue where if
collapsibleColumns
were set totrue
it was impossible to exit selection mode. #5875 (opens new window) - Fixed an issue where
hiddenColumns
did not work properly with `autoWrapRow/autoWrapCol`. #5877 (opens new window) - Fixed an issue on IE where hiding the first column caused a display of double border for top left corner. #5881 (opens new window)
- Fixed an issue where
nestedHeaders
duplicated a header name if more columns are added. #5882 (opens new window) - Fixed an issue where
HiddenColumns
plugin unset cell'srenderer
. #5883 (opens new window) - Fixed an issue where
hiddenColumns
had stored visual indexes and should have used physical indexes. #5909 (opens new window) - Fixed an issue where hidden columns should be unrecoverable. #6113 (opens new window)
- Fixed an issue where row selection ignored columns that are hidden at the end. #6181 (opens new window)
- Fixed an issue where defining data with more data than used in
columns
caused an issue with showing column once it was hidden. #6426 (opens new window) - Fixed an issue where hiding rows, while there was a merged area, involved caused data shifting and unexpected merged area coordinates. #6376 (opens new window)
- Fixed an issue where
colHeader
was truncated after movinghiddenColumn
. #6463 (opens new window) - Fixed an issue where the last hidden column was visible upon column resizing. #6557 (opens new window)
- Fixed an issue where with hiding columns after moved them manually. #6668 (opens new window)
- Fixed an issue where expanding a collapsed column caused expanding of a child columns except for the first one. #5792 (opens new window)
- Fixed an issue where setting
columnSorting
totrue
(on initialization or viaupdateSettings
) made headers non-collapsible programmatically viacollapseAll
method. #4999 (opens new window) - Fixed an issue where
CustomBorders
plugin was missing in the definition file. #6477 (opens new window) - Fixed incorrect size of
wtHider
andwtHolder
in overlays. #3873 (opens new window) - Fixed an issue where
updateSettings
could not updatetableClassName
. #6295 (opens new window) - Fixed an issue where JSON data with empty value was losing some double quotes when pasted into a cell. #6167 (opens new window)
- Fixed an issue where some classes for the table were missing if one of them was empty. #6371 (opens new window)
- Fixed an issue where clicking in a contextmenu's border opened the native context menu. #6218 (opens new window)
- Fixed the error that ocurred during loading of E2E test runner in Edge and IE. #6713 (opens new window)
- Fixed the inconsistency and problems with adding rows from the corner when all rows are trimmed. #7061 (opens new window)
- Fixed an issue where using read-only and alignment from the context menu was disabled when all columns were selected. #7114 (opens new window)
- Fixed an issue where setting focus to a column to open context menu after applying a filter was impossible. #7005 (opens new window)
- Fixed an issue where
minSpareCols
withundo
added too many columns. #6363 (opens new window) - Fixed the inconsistency in selection when using the right mouse button for first row/column. #6334 (opens new window)
- Fixed an issue where undoing column removal caused column headers to lack a header. #6992 (opens new window)
- Fixed an issue where
readOnly
for column was erased (did not apply) if filters were used. #6559 (opens new window) - Fixed an issue where readonly property was lost after declining confirmation in
beforeRemoveCol
orbeforeRemoverow
. #6332 (opens new window) - Fixed an issue where
readOnly
state for some cells was lost when rows withtrimRows
turned on were removed. #6990 (opens new window) - Fixed incorrect column header highlight when merged cells were unmerged and
hiddenColumns
were used. #6978 (opens new window) - Fixed an issue where after hiding the first row, the second row top border disappeared. #6977 (opens new window)
- Fixed an issue with incorrect selection after hiding the first row. #6831 (opens new window)
- Fixed an issue where hiding the first row caused blue highlight in column headers selection to disappear. #6976 (opens new window)
- Fixed wrong selection area after sorting with hidden rows. #6386 (opens new window)
- Fixed an issue where it was not possible to use
selectAll
when the first row was hidden. #6975 (opens new window) - Fixed an issue where it was possible to select hidden row or column. #6974 (opens new window)
- Fixed an issue where row indexes changed if the first row was hiding after moving row from bottom to top. #6965 (opens new window)
- Fixed an issue where selection skipped the highest parent. #6770 (opens new window)
- Fixed an iisue where
nestedRows
blocked table from loading if data was not provided. #6928 (opens new window) - Fixed an isse where it was impossible to go back to the original cell after dragging down. #4233 (opens new window)
- Fixed an issue where keyboard navigation did not work on merged cells with hidden rows/columns. #6973 (opens new window)
- Fixed an issue where
trimRows
andhiddenRows
with specific settings broke borders. #6904 (opens new window) - Fixed wrong union type for
startPosition
. #6840 (opens new window) - Fixed type mismatch for `Handsontable.plugins.ContextMenu`. #6347 (opens new window)
- Fixed an issue where
manualColumnMove
did not modify thecolumns
inupdateSettings
. #5200 (opens new window) - Fixed rendering issue on column udpate with
updateSettings
. #3770 (opens new window) - Fixed an issue where expanding a collapsed column was also expanding 'child' collapsed columns, except the first child. #5792 (opens new window)
- Fixed an issue with inproper selection for headers when the first column was hidden. #5999 (opens new window)
- Fixed an issue where it was not possible to align cells if the selection was made upward. #6600 (opens new window)
- Fixed an issue where
currentColClassName
did not work properly withnestedHeaders
. #5861 (opens new window) - Fixed an issue with scrollbar and dimension calculation in Firefox for toggling column visibility
with fixed columns and
stretchH
. #6186 (opens new window) - Fixed an issue with undoing the nested row removal. #6433 (opens new window)
- Fixed an isse where
getSourceData
functions returned wrong data for nested rows. #5771 (opens new window) - Fixed na issue where the
Formulas
plugin did not work withnestedRows
. #4154 (opens new window) - Fixed an issue where nested headers and hidden columns highlighted ad additional column when used together. #6881 (opens new window)
- Fixed an issue where
getByRange
for sourceData did not work properly with nested object data. #6548 (opens new window) - Fixed an issue where `window.frameElement` threw errors in MSEdge, IE and Safari. #6478 (opens new window)
- Fixed an issue where `DataSource.countColumns` returned invalid number of columns for nested objects. #3958 (opens new window)
- Fixed an issue where
mergedCells
with hidden cells caused problems with rendering. #7020 (opens new window) - Fixed an issue where it was not possible to move column when all columns were selected by `ctrl + a`. #6355 (opens new window)
- Fixed an issue where double click on the column resize handle did not adjust size correctly. #6755 (opens new window)
- Fixed an issue where the cell meta was retrieved using the wrong coordinates. #6703 (opens new window)
- Fixed nested rows incorrect state after changing data. #5753 (opens new window)
- Fixed an issue in EDGE where the dropdown menu
onMouseOut
event caused critical errors when hovering over vertical scrollbar. #6699 (opens new window) - Fixed an issue with too many layers of highlight with noncontinuous selection on merged cells. #7028 (opens new window)
- Fixed an issue where
NestedHeaders
did not allow to define header level as an empty array. #7035 (opens new window) - Fixed an issue where passing
nestedHeaders
as a single empty array stoped the table from rendering. #7036 (opens new window) - Fixed an issue where opening a context menu for a column when its hidden data was selected did not block adding of rows by the menu. #7050 (opens new window)
- Fixed an issue where it was not possible to navigate past hidden column using keyboard if`
hot.updateSettings` was called in
afterSelection
. #3726 (opens new window) - Fixed an issue where headers did not export with
exportToFile
in the specific case. #4176 (opens new window) - Fixed an issue with types mismatch. #6035 (opens new window)
- Fixed an issue where manual row resize handler threw an error when bottom rows overlay was enabled. #6435 (opens new window)
- Fixed an issue where the
afterRowResize
hook shared incorrect results in the second parameter. #6430 (opens new window) - Fixed an issue where the row/column resize hooks should not have returned
null
. #7074 (opens new window) - Fixed the loss of selection after merging from headers. #7076 (opens new window)
- Fixed an issue where calling
updateSettings
changed the index of frozen columns viafreezeColumn
method. #6843 (opens new window) - Fixed an issue where deleting the last column via
updateSettings
which was part of the selection caused scroll to the bottom. #5849 (opens new window) - Fixed an issue where it was not possible to hide rows and merge cells at the same time. #6224 (opens new window)
- Fixed the wrong data in merge cells after the hidden column and additionally an error occurs. #6888 (opens new window)
- Fixed an issue where it was not possible to change cell type via
setCellMeta
. #4793 (opens new window) - Fixed an issue where cell editor did not dynamically changed while changing the cell type. #4360 (opens new window)
- Fixed an issue where it was not possible to unmerge cells if part of them was hidden. #7095 (opens new window)
- Fixed an issue where calling
clear
method removed the focus from the table. #7099 (opens new window) - Fixed an issue where
clear
method did not work for hidden data. #7097 (opens new window) - Fixed an issue where the editor was moved by 1px when the first row / column was hidden. #6982 (opens new window)
- Fixed an issue where headers were deselected after undoing removal. #6670 (opens new window)
- Fixed an issue with improper selection after insert column/row when mergeCells was enabled. #4897 (opens new window)
- Fixed an issue where wrong cell meta was removed when deleting rows. #6051 (opens new window)
- Fixed wrong types of
beforeRowMove
arguments. #6539 (opens new window) - Fixed an issue where selection of a whole row did not happen consequently after selecting a row header. #5906 (opens new window)
- Fixed an issue where it was not possible to use physical row index instead of visual one. #6309 (opens new window)
- Fixed an issue where incorrect data was returned after undoing the remove column option. #5000 (opens new window)
- Fixed - Copy and paste works properly also when selecting hidden columns when: all columns within a selected range are hidden and when just some columns within a selected range are hidden. #7043 (opens new window).
- Fixed an issue where it was impossible to add new row in the
nestedRows
. #5133 (opens new window) - Fixed an issue where
afterOnCellMouseDown
returned (0,0) coords after clicking on the topleft corner. #3978 (opens new window) - Fixed an issue where persisted
manualColumnMove
was not restored when usingloadData
. #5207 (opens new window) - Fixed issues with filtering results in blank rows. #5208 (opens new window)
- Fixed an issue where changing data on collapsed rows resulted in error. #5328 (opens new window)
- Fixed an issue where the
manualColumnMove
operation affected the column order of data loaded byloadData
. #5591 (opens new window) - Fixed an issue where
nestedRows
did not allow to keeprowHeaders
after collapsing. #5874 (opens new window) - Fixed performance and CPU issue caused by using some handsontable properties. #6058 (opens new window)
- Fixed an error with the
ColumnSummary
plugin when trying to create a row. #6300 (opens new window) - Fixed an error where `walkontable.css` and `handsontable.css` stylesheets were out of sync. #6381 (opens new window)
- Fixed an issue where
colHeaders
order was not updated after manual move with empty object data source. #6413 (opens new window) - Fixed "detach from parent" option. #6432 (opens new window)
- Fixed an issue where
PreventOverflow
feature did not work ifMultiColumnSorting
plugin was enabled. #6514 (opens new window) - Fixed an issue where old CSS classes were not removed after
updateSettings
. #6575 (opens new window) - Fixed an issue where
columnSummary
,Filters
and spare rows were causing 'RangeError: Maximum call stack size exceeded'. #6695 (opens new window) - Fixed an issue where
afterSelectionEnd
returned incorrect data when clicking on a column when all rows were hidden. #7045 (opens new window) - Fixed an issue where wrapping was not applied after setting
trimWhitespace
tofalse
. #6232 (opens new window) - Fixed an issue with additional selection border in iOS. #7103 (opens new window)
- Fixed an issue with rendering different borders. #6955 (opens new window)
- Fixed an issue with
BACKSPACE
not working properly in the filter by value input. #6842 (opens new window) - Fixed an issue with Undo/Redo not working with fixing columns. #6869 (opens new window)
- Added a missing argument in the
deepObjectSize
function. #6821 (opens new window) - Fixed an issue where the table threw errors while clicking the cells if the Handsontable was
initialized with
fixedRowsTop
andfixedRowsBottom
higher than rows length. #6718 (opens new window) - Fixed an issue where it was not possible to change the state of checkbox-type, non-adjacent cells
using
SPACE
. #4882 (opens new window) - Fixed an issue where resizing made rows shorter than expected and caused row misalignment. #6429 (opens new window)
- Fixed an issue where Handsontable was missing rows when
preventOverflow
withupdateSettings
were used. #4303 (opens new window) - Adding properties which were not defined on initialization or by
updateSettings
to the source data is possible only by the usage ofsetSourceDataAtCell
. #6664 (opens new window).
7.4.2
Released on February 19, 2020.
For more information on this release, see:
- Blog post (opens new window)
- Documentation (7.4.2) (opens new window)
- GitHub release tag (opens new window)
Changes
- Fixed an issue where the cell value could not be edited on mobile devices. (#6707 (opens new window))
- Fixed an issue where white lines appeared at the bottom of cell headers. (#6459 (opens new window))
- Fixed a bug, where resizing the window (while using Angular) would result in Handsontable not stretching properly and throwing an error. (#6710 (opens new window))
7.4.1
Released on February 19, 2020.
Due to technical issues, version 7.4.2 patch needed to be released.
All the changes from 7.4.1 are included in the 7.4.2 release.
7.4.0
Released on February 12, 2020.
For more information on this release, see:
- Blog post (opens new window)
- Documentation (7.4.0) (opens new window)
- GitHub release tag (opens new window)
Changes
- Fixed the problem, where the
onCellMouseUp
hook was fired for all mouse buttons exceptRMB
, which was not consistent with theonCellMouseDown
hook. To make the changes more consistent with the nativedblclick
event (which is triggered only for theLMB
button), theonCellDblClick
andonCellCornerDblClick
hooks were modified to also fire only forLMB
. (#6507 (opens new window)) - Updated
moment
,pikaday
andnumbro
to their latest versions. (#6610 (opens new window)) - Fixed a bug with numbers not being presented properly with the
pt_BR
culture setting. (#5569 (opens new window)) - Extended the Babel config with the possibility to use private methods, optional chaining and nullish coalescing operator. (#6308 (opens new window))
- Updated some of the internal configs, updated dev-dependencies, housekeeping etc. (#6560 (opens new window), #6609 (opens new window), #6612 (opens new window), #6629 (opens new window), #6574 (opens new window), #6565 (opens new window))
Older versions
The release notes about older versions of Handsontable are available on GitHub (opens new window).