To enable column moving, set the manualColumnMove configuration option to true.
A draggable move handle appears above the selected column header. You can click and drag it to any location in the grid.
import{ HotTable }from'@handsontable/react';import{ registerAllModules }from'handsontable/registry';import'handsontable/dist/handsontable.full.min.css';// register Handsontable's modulesregisterAllModules();// generate an array of arrays with dummy dataconst data =newArray(200)// number of rows.fill().map((_, row)=>newArray(20)// number of columns.fill().map((_, column)=>`${row}, ${column}`));exportconstExampleComponent=()=>{return(<HotTabledata={data}width="100%"height={320}rowHeaders={true}colHeaders={true}colWidths={100}manualColumnMove={true}licenseKey="non-commercial-and-evaluation"/>);};
Move column headers
When you move columns, the default column headers (A, B, C) stay in place.
There are significant differences between the plugin's dragColumns and moveColumns API functions. Both of them change the order of columns, but they rely on different kinds of indexes. The differences between them are shown in the diagrams below.
The dragColumns method has a dropIndex parameter, which points to where the elements are being dropped.
The moveColumns method has a finalIndex parameter, which points to where the elements will be placed after the moving action - finalIndex being the index of the first moved element.
The moveColumns function cannot perform some actions, e.g., more than one element can't be moved to the last position. In this scenario, the move will be cancelled. The Plugin's isMovePossible API method and the movePossible parameters beforeColumnMove and afterColumnMove hooks help in determine such situations.