diff --git a/api-generator/components/datatable.js b/api-generator/components/datatable.js index c8afa0b41f..9487ac6d69 100644 --- a/api-generator/components/datatable.js +++ b/api-generator/components/datatable.js @@ -506,6 +506,27 @@ const DataTableEvents = [ } ] }, + { + name: "row-dblclick", + description: "Callback to invoke when a row is double clicked.", + arguments: [ + { + name: "event.originalEvent", + type: "object", + description: "Browser event." + }, + { + name: "event.data", + type: "object", + description: "Selected row data." + }, + { + name: "event.index", + type: "number", + description: "Row index" + } + ] + }, { name: "row-contextmenu", description: "Callback to invoke when a row is selected with a ContextMenu", diff --git a/src/components/datatable/DataTable.d.ts b/src/components/datatable/DataTable.d.ts index 8187d6667b..e51cecbfb7 100755 --- a/src/components/datatable/DataTable.d.ts +++ b/src/components/datatable/DataTable.d.ts @@ -62,6 +62,7 @@ declare class DataTable extends Vue { $emit(eventName: 'sort', event: Event): this; $emit(eventName: 'filter', event: Event): this; $emit(eventName: 'row-click', event: Event): this; + $emit(eventName: 'row-dblclick', event: Event): this; $emit(eventName: 'row-contextmenu', event: Event): this; $emit(eventName: 'row-select', event: Event): this; $emit(eventName: 'row-unselect', event: Event): this; diff --git a/src/components/datatable/DataTable.vue b/src/components/datatable/DataTable.vue index c02cb59f40..df7e197177 100755 --- a/src/components/datatable/DataTable.vue +++ b/src/components/datatable/DataTable.vue @@ -28,7 +28,7 @@ :rowGroupMode="rowGroupMode" :groupRowsBy="groupRowsBy" :expandableRowGroups="expandableRowGroups" :rowClass="rowClass" :editMode="editMode" :compareSelectionBy="compareSelectionBy" :expandedRowIcon="expandedRowIcon" :collapsedRowIcon="collapsedRowIcon" :expandedRows="expandedRows" :expandedRowKeys="d_expandedRowKeys" :expandedRowGroups="expandedRowGroups" :editingRows="editingRows" :editingRowKeys="d_editingRowKeys" :templates="$scopedSlots" :loading="loading" - @rowgroup-toggle="toggleRowGroup" @row-click="onRowClick($event)" @row-rightclick="onRowRightClick($event)" @row-touchend="onRowTouchEnd" @row-keydown="onRowKeyDown" + @rowgroup-toggle="toggleRowGroup" @row-click="onRowClick($event)" @row-dblclick="onRowDblClick($event)" @row-rightclick="onRowRightClick($event)" @row-touchend="onRowTouchEnd" @row-keydown="onRowKeyDown" @row-mousedown="onRowMouseDown" @row-dragstart="onRowDragStart($event)" @row-dragover="onRowDragOver($event)" @row-dragleave="onRowDragLeave($event)" @row-dragend="onRowDragEnd($event)" @row-drop="onRowDrop($event)" @row-toggle="toggleRow($event)" @radio-change="toggleRowWithRadio($event)" @checkbox-change="toggleRowWithCheckbox($event)" @cell-edit-init="onCellEditInit($event)" @cell-edit-complete="onCellEditComplete($event)" @cell-edit-cancel="onCellEditCancel($event)" @@ -722,6 +722,13 @@ export default { this.rowTouched = false; }, + onRowDblClick(e) { + const event = e.originalEvent; + if (DomHandler.isClickable(event.target)) { + return; + } + this.$emit('row-dblclick', e); + }, onRowRightClick(event) { DomHandler.clearSelection(); event.originalEvent.target.focus(); diff --git a/src/components/datatable/TableBody.vue b/src/components/datatable/TableBody.vue index d941fba545..86a7391f81 100755 --- a/src/components/datatable/TableBody.vue +++ b/src/components/datatable/TableBody.vue @@ -12,7 +12,8 @@