From 265d7e4bb7a6fc958728ac20c737180d0a54550a Mon Sep 17 00:00:00 2001 From: mertsincan Date: Wed, 25 May 2022 03:25:58 +0100 Subject: [PATCH] Fixed #2923 - Frozen columns and non-frozen columns can be reordered with each other in DataTable --- components/lib/datatable/DataTable.js | 6 +++--- components/lib/datatable/HeaderCell.js | 5 +++-- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/components/lib/datatable/DataTable.js b/components/lib/datatable/DataTable.js index 417370e8e2..3222bd4d7e 100644 --- a/components/lib/datatable/DataTable.js +++ b/components/lib/datatable/DataTable.js @@ -562,7 +562,7 @@ export const DataTable = React.forwardRef((props, ref) => { const { originalEvent: event, column } = e; - if (props.reorderableColumns && getColumnProp(column, 'reorderable') !== false) { + if (props.reorderableColumns && getColumnProp(column, 'reorderable') !== false && !getColumnProp(column, 'frozen')) { if (event.target.nodeName === 'INPUT' || event.target.nodeName === 'TEXTAREA' || DomHandler.hasClass(event.target, 'p-column-resizer')) event.currentTarget.draggable = false; else @@ -616,9 +616,9 @@ export const DataTable = React.forwardRef((props, ref) => { } const onColumnHeaderDragOver = (e) => { - const { originalEvent: event } = e; + const { originalEvent: event, column } = e; const dropHeader = findParentHeader(event.currentTarget); - if (props.reorderableColumns && draggedColumnElement.current && dropHeader) { + if (props.reorderableColumns && draggedColumnElement.current && dropHeader && !getColumnProp(column, 'frozen')) { event.preventDefault(); if (draggedColumnElement.current !== dropHeader) { diff --git a/components/lib/datatable/HeaderCell.js b/components/lib/datatable/HeaderCell.js index f14e76a44d..3f7ce9d512 100644 --- a/components/lib/datatable/HeaderCell.js +++ b/components/lib/datatable/HeaderCell.js @@ -269,14 +269,15 @@ export const HeaderCell = React.memo((props) => { const sortMeta = getSortMeta(); const style = getStyle(); const align = getColumnProp('alignHeader') || getColumnProp('align'); + const frozen = getColumnProp('frozen'); const className = classNames(getColumnProp('headerClassName'), getColumnProp('className'), { 'p-sortable-column': getColumnProp('sortable'), 'p-resizable-column': props.resizableColumns && getColumnProp('resizeable'), 'p-highlight': sortMeta.sorted, - 'p-frozen-column': getColumnProp('frozen'), + 'p-frozen-column': frozen, 'p-selection-column': getColumnProp('selectionMode'), 'p-sortable-disabled': getColumnProp('sortable') && _isSortableDisabled, - 'p-reorderable-column': props.reorderableColumns && getColumnProp('reorderable'), + 'p-reorderable-column': props.reorderableColumns && getColumnProp('reorderable') && !frozen, [`p-align-${align}`]: !!align }); const tabIndex = getColumnProp('sortable') && !_isSortableDisabled ? props.tabIndex : null;