v7.3.0
SupportExamplesFree Trial

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 true to 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.

Please note that Ctrl is the equivalent to Command and Alt is the equivalent to Option for Mac users

For more information on how to customize keyboard shortcuts, please see our guide.

See also

No results

Configs

Configs are options you supply in a configuration object when creating an instance of this class
  • columnTypesToIgnore : String[]["rownumber","sequenceNumber"]
    internal

    Specifies which column types should be omitted from copying.

  • If true, this translates copy actions to cut actions and removes the context menu Copy option.

  • The field to use as the name field when updating the name of copied records

  • Adds Cut (row), Copy (row) and Paste (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 true to use native Clipboard API if it is available

  • If true this prevents cutting and pasting. Will default to true if CellEdit feature is disabled. Set to false to 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 false to disable localization of this object.

Properties

Properties are getters/setters or publicly accessible variables on this class
  • isClipboardable : Booleantrue
    READONLY
    static
    ADVANCED
    Clipboardable
    Identifies an object as an instance of Clipboardable class, or subclass thereof.
  • isEvents : Booleantrue
    READONLY
    static
    ADVANCED
    Events
    Identifies an object as an instance of Events class, or subclass thereof.
  • isLocalizable : Booleantrue
    READONLY
    static
    ADVANCED
    Localizable
    Identifies an object as an instance of Localizable class, or subclass thereof.
  • isRowCopyPaste : Booleantrue
    READONLY
    static
    ADVANCED
    Identifies an object as an instance of RowCopyPaste class, or subclass thereof.
  • properties : Object
    internal
    static
    CopyPasteBase

    A class property getter for the default values of internal properties for this class.

  • emptyArray : Array
    internal
    READONLY
    CopyPasteBase

    An empty array that can be used as a default value.

  • emptyObject : Object
    internal
    READONLY
    CopyPasteBase

    An empty object that can be used as a default value.

  • isCopyPasteBase : Booleantrue
    READONLY
    ADVANCED
    CopyPasteBase
    Identifies an object as an instance of CopyPasteBase class, or subclass thereof.
  • isInstancePlugin : Booleantrue
    READONLY
    ADVANCED
    CopyPasteBase
    Identifies an object as an instance of InstancePlugin class, or subclass thereof.
  • isRowCopyPaste : Booleantrue
    READONLY
    ADVANCED
    Identifies an object as an instance of RowCopyPaste class, or subclass thereof.
  • clipboard : Object
    private
    READONLY
    Clipboardable

    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.

  • config : Object
    READONLY
    ADVANCED
    CopyPasteBase

    Returns a copy of the full configuration which was used to configure this object.

  • This property is set to true before the constructor returns.

  • isDestroying : Boolean
    READONLY
    ADVANCED
    CopyPasteBase

    This property is set to true on entry to the destroy method. It remains on the objects after returning from destroy(). If isDestroyed is true, this property will also be true, so there is no need to test for both (for example, comp.isDestroying || comp.isDestroyed).

  • client : Widget
    READONLY
    ADVANCED
    CopyPasteBase

    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
  • onClassMixedIn( )
    internal
    static
    CopyPasteBase

    This optional class method is called when a class is mixed in using the mixin() method.

  • initClass( )
    static
    ADVANCED
    CopyPasteBase

    Registers this class type with its Factory

  • Clears the clipboard data

  • 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

  • doDestroy( )
    internal
    Events

    Auto detaches listeners registered from start, if set as detachable

  • once( )
    private
    Events

    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.

Events

Events are triggered for certain actions in this class and can be listened for to react to those actions in your code

Event handlers

Event handlers are callbacks called as a result of certain actions in this class
id: rowCopyPaste

Source path

Grid/feature/RowCopyPaste.js

Contents