Skip to content
Kenneth G. Franqueiro edited this page Sep 30, 2013 · 7 revisions

The editor plugin provides the ability to render editor controls within cells for a column. When used in conjunction with a store-backed grid such as an OnDemandGrid, edited fields are directly correlated with the dirty state of the grid; changes can then be saved back to the store based on edits performed in the grid.

require([
    "dojo/_base/declare", "dgrid/OnDemandGrid","dgrid/editor", "dgrid/Keyboard", "dgrid/Selection"
], function(declare, OnDemandGrid, editor, Keyboard, Selection){
    var editGrid = new (declare([OnDemandGrid, Keyboard, Selection]))({
        store: myStore,
        columns: [
            editor({
                label: "Name",
                field: "name",
                editor: "text",
                editOn: "dblclick"
            }),
            // ...
        ]
    }, "editGrid");
});

For more examples of editor in use, see the various editor test pages, as well as the GridFromHtml_editors test page for declarative examples.

Additional Column Definition Properties

The editor plugin supports the following additional column definition properties.

Property Description
editor The type of component to use for editors in this column; either a string specifying a type of standard HTML input to create, or a Dijit widget constructor to instantiate.
editOn A string containing the event (or multiple events, comma-separated) upon which the editor should activate. If unspecified, editors are always displayed in this column's cells.
editorArgs An object containing input attributes or widget arguments. For HTML inputs, the object will have its key/value pairs applied as node attributes via put-selector; for widgets, the object will be passed to the widget constructor.
canEdit(object, value) A function returning a boolean value indicating whether or not the cell for this column should be editable in a particular row. Receives the item for the current row, and the value to be rendered (i.e. the return from the column's get function if any, or the value of the field specified in the column).
autoSave If true, the grid's save method will be called as soon as a change is detected in an editor in this column. Defaults to false. Note: if an error is encountered as a result of a store operation triggered by autoSave, a dgrid-error event will be emitted.
dismissOnEnter By default, pressing enter will store the current value in the grid's dirty data hash. This can be undesirable particularly for textarea editors; setting this property to false will disable the behavior.

For convenience, the editor and editOn properties may also be specified as the second and third arguments to the editor function. For example, both of the following would result in an editor which presents a text field when a cell in the column is double-clicked:

// long version, everything in column def object
editor({
    editor: "text",
    editOn: "dblclick",
    /* rest of column definition here... */
})

// shorthand version, editor and editOn as arguments
editor({ /* rest of column definition here... */ }, "text", "dblclick")

Additional Grid APIs

When the editor plugin is applied to a column in a grid, the grid is augmented with the following method.

Method Description
edit(cell) Activates/focuses the specified cell (which can be a cell object from grid.cell(), or a DOM node or event resolvable to one).

Events

The editor plugin emits a dgrid-datachange event whenever an editor field loses focus after its value is changed. This event includes the following properties:

  • grid: The Grid instance in which the edit occurred
  • cell: The cell object to which the edit applied, as reported by the grid.cell method
  • oldValue: The value before the edit occurred
  • value: The value after the edit occurred

This event bubbles and is cancelable; if the event is canceled, the modification will be reverted.

Editors with editOn set also emit dgrid-editor-show and dgrid-editor-hide events when the editor is shown and hidden, respectively. These events also include grid and cell properties and bubble; however, they are not cancelable. If an editor should not be shown under specific circumstances, include a canEdit function in the column definition.

Recommendations for the editOn property

If attempting to trigger an editor on focus (to accommodate keyboard and mouse), it is highly recommended to use dgrid's custom event, dgrid-cellfocusin instead of focus, to avoid confusion of events. Note that this requires also mixing the Keyboard module into the Grid constructor.

If touch input is a concern for activating editors, the easiest solution is to use the click event, which browsers on touch devices tend to normalize to fire on taps as well. If a different event is desired for desktop browsers, it is possible to do something like the following:

require(
    ["dgrid/OnDemandGrid", "dgrid/editor", "dojo/has" /*, ... */],
    function(OnDemandGrid, editor, has /*, ... */){
        var columns = [
            /* ... more columns here ... */
            editor({ name: "name", label: "Editable Name" }, "text",
                has("touch") ? "click" : "dblclick")
        ];
        /* ... create grid here ... */
    }
);

There are also a couple of useful simple gesture implementations available in the util/touch module, namely tap and dbltap.

Clone this wiki locally