RowCopyPaste
Feature
Allow using [Ctrl/CMD + C/X] and [Ctrl/CMD + V] to copy/cut-and-paste rows. Also makes cut, copy and paste actions available via the cell context menu.
You can configure how a newly pasted record is named using generateNewName
This feature is enabled by default
const grid = new Grid({
features : {
rowCopyPaste : true
}
});
targetElement.innerHTML = '<p>Copy/cut and paste rows using keyboard shortcuts or context menu:</p>'; // grid with basic configuration const grid = new Grid({ // makes grid as high as it needs to be to fit rows autoHeight : true, appendTo : targetElement, columns : [ { field : 'name', text : 'Name' }, { field : 'job', text : 'Job', renderer : ({ value }) => value || 'Unemployed' } ], data : [ { id : 1, name : 'Bill', job : 'Retired' }, { id : 2, name : 'Elon', job : 'Visionary' }, { id : 3, name : 'Me' } ] }); This feature will work alongside with CellCopyPaste but there is differences on functionality.
- Context menu actions, and keyboard shortcuts, will be processed by either feature depending on what is selected and where the context menu was triggered. Set rowOptionsOnCellContextMenu to
trueto show two sets of options when context menu is triggered on a selected cell. - They share clipboard, so even when the internal clipboard is used, it is not possible to have rows and cells copied or cut at the same time.
Keyboard shortcuts
The feature has the following default keyboard shortcuts:
| Keys | Action | Weight ¹ | Action description |
|---|---|---|---|
| Ctrl+C | copy | 10 | Calls copyRows which copies selected row(s) into the clipboard. |
| Ctrl+X | cut | 10 | Calls copyRows which cuts out selected row(s) and saves in clipboard. |
| Ctrl+V | paste | 10 | Calls pasteRows which inserts copied or cut row(s) from the clipboard. |
¹ Customization of keyboard shortcuts that has a weight can affect other features that also uses that particular keyboard shortcut. Read more in our guide.
For more information on how to customize keyboard shortcuts, please see our guide.
See also
- CellCopyPaste - Copy/paste individual cells
Configs
Configs are options you supply in a configuration object when creating an instance of this class-
Specifies which column types should be omitted from copying.
-
If
true, this translates copy actions to cut actions and removes the context menuCopyoption. -
The field to use as the name field when updating the name of copied records
-
Adds
Cut (row),Copy (row)andPaste (row)options when opening a context menu on a selected cell when cellSelection and CellCopyPaste is active. Default behaviour will only provide row copy/paste actions on a selected row. -
Configure which sources $name this class allows pasting model data from. Accepts string or array. Unspecified accepts all. If source is not accepted, it will try to use the string value instead.
-
Set this to
trueto use native Clipboard API if it is available -
If
truethis prevents cutting and pasting. Will default totrueif CellEdit feature is disabled. Set tofalseto prevent this behaviour. -
The format a copied date value should have when converted to a string. To learn more about available formats, check out DateHelper docs.
-
Default keyMap configuration: Ctrl/Cmd+c to copy, Ctrl/Cmd+x to cut and Ctrl/Cmd+v to paste. These keyboard shortcuts require a selection to be made.
-
Internal listeners, that cannot be removed by the user.
-
The widget which this plugin is to attach to.
Has a corresponding runtime client property.
-
Set to
falseto disable localization of this object.
Properties
Properties are getters/setters or publicly accessible variables on this class-
Identifies an object as an instance of Clipboardable class, or subclass thereof.
-
Identifies an object as an instance of Events class, or subclass thereof.
-
Identifies an object as an instance of Localizable class, or subclass thereof.
-
Identifies an object as an instance of RowCopyPaste class, or subclass thereof.
-
A class property getter for the default values of internal properties for this class.
-
An empty array that can be used as a default value.
-
An empty object that can be used as a default value.
-
Identifies an object as an instance of CopyPasteBase class, or subclass thereof.
-
Identifies an object as an instance of InstancePlugin class, or subclass thereof.
-
Identifies an object as an instance of RowCopyPaste class, or subclass thereof.
-
Gets the current shared Clipboard instance
-
A method used to generate the name for a copy-pasted record. By defaults appends "- 2", "- 3" as a suffix. Override it to provide your own naming of pasted records.
Has a corresponding generateNewName config.
-
Returns a copy of the full configuration which was used to configure this object.
-
This property is set to
truebefore theconstructorreturns. -
This property is set to
trueon entry to the destroy method. It remains on the objects after returning fromdestroy(). If isDestroyed istrue, this property will also betrue, so there is no need to test for both (for example,comp.isDestroying || comp.isDestroyed). -
The Widget which was passed into the constructor, which is the Widget we are providing extra services for.
Has a corresponding client config.
-
Get the global LocaleHelper
-
Get the global LocaleManager
Functions
Functions are methods available for calling on the class-
This optional class method is called when a class is mixed in using the mixin() method.
-
Registers this class type with its Factory
-
Clears the clipboard data
-
monitorCellCopyPaste( )internal
Listens to CellCopyPaste beforePaste events If user is trying to paste a string representation of a record from RowCopyPaste It will return false and paste the record instead
-
Internal function used to hook destroy() calls when using thisObj
-
Internal function used restore hooked destroy() calls when using thisObj
-
Auto detaches listeners registered from start, if set as detachable
-
Internal function used to run a callback function after an event is triggered
-
Removes all listeners registered to this object by the application.
-
This will merge a feature's (subclass of InstancePlugin) keyMap with it's client's keyMap.