Class EditContext
- All Implemented Interfaces:
- HasHandlers,- HasEditMaskClickedHandlers,- HasEditNodeUpdatedHandlers,- HasNodeAddedHandlers,- HasSelectedEditNodesUpdatedHandlers
 An EditContext is typically populated by
 adding a series of EditNodes created via a Palette, either via drag and drop creation, or when loading from a saved version, via addFromPaletteNode() or  addPaletteNodesFromXML(). 
An EditContext then provides interfaces for further editing of the components represented by EditNodes.
 Developers may explicitly define an edit
 context and initialize it with a rootComponent - the root
 of the user interface being created. The EditContext itself is not visible to the user, but the root component's  liveObject may be.
 As child editNodes are added to the
 rootComponent node or its descendants, liveObjects in the user will update to reflect these changes. The live objects
 for the edit nodes will be nested using the appropriate parent-child relationships, for  the types of node in question.
 For example Canvases will be added as members of layouts
 and FormItems will be added as  fields of DynamicForms.
 
 To enable drag and drop creation of widgets from a Palette, a developer can use
 Canvas.setEditMode() to enable editing behaviors on the live
 object of the desired drop target (typically the root component).
 To enable editNode creation via double-click on a
 Palette, developers can set the Palette.defaultEditContext. 
 Developers can also make use of
 EditPane or EditTree classes which provide a visual
 interface for managing an EditContext.
- See Also:
- 
Field SummaryFields inherited from class com.smartgwt.client.core.BaseClassconfig, configOnly, factoryCreated, factoryProperties, id, scClassName
- 
Constructor SummaryConstructors
- 
Method SummaryModifier and TypeMethodDescriptionAdd a editMaskClicked handler.Add a editNodeUpdated handler.addFromPaletteNode(PaletteNode paletteNode) Creates a new EditNode from a PaletteNode, using thedefaultPalette.addFromPaletteNode(PaletteNode paletteNode, EditNode parentNode) Creates a new EditNode from a PaletteNode, using thedefaultPalette.EditNode[]addFromPaletteNodes(PaletteNode[] paletteNodes) Add the suppliedPaletteNodesto the parentNode, preserving internal references from one supplied PaletteNode to another.EditNode[]addFromPaletteNodes(PaletteNode[] paletteNodes, EditNode parentNode) Add the suppliedPaletteNodesto the parentNode, preserving internal references from one supplied PaletteNode to another.EditNode[]addFromPaletteNodeTree(Tree paletteNodeTree) Add the suppliedPaletteNodetree to the parentNode, preserving internal references from one supplied PaletteNode to another.EditNode[]addFromPaletteNodeTree(Tree paletteNodeTree, EditNode parentNode) Add the suppliedPaletteNodetree to the parentNode, preserving internal references from one supplied PaletteNode to another.Add a newEditNodeto the EditContext, under the specified parent.addNode(EditNode newNode, EditNode parentNode, Integer index, String parentProperty, Boolean skipParentComponentAdd) addNode(EditNode newNode, EditNode parentNode, Integer index, String parentProperty, Boolean skipParentComponentAdd, Boolean forceSingularFieldReplace) Add a newEditNodeto the EditContext, under the specified parent.addNodeAddedHandler(NodeAddedHandler handler) Add a nodeAdded handler.voidaddPaletteNodeFormItemConstructors(Tree nodeTree) AddPaletteNodeconstructors for the specific type ofFormItemthat will be created to the paletteNodes in the specified tree created bycreatePaletteNodeTree().voidaddPaletteNodesFromJS(String jsCode) AddPaletteNodesfrom a JavaScript source representation.voidaddPaletteNodesFromJS(String jsCode, EditNode parentNode) voidaddPaletteNodesFromJS(String jsCode, EditNode parentNode, String[] globals) AddPaletteNodesfrom a JavaScript source representation.voidaddPaletteNodesFromJSON(String jsonString) RecreateEditNodesfrom a JSON representation ofPaletteNodes(possibly created by callingserializeAllEditNodesAsJSON()orserializeEditNodesAsJSON().voidaddPaletteNodesFromJSON(String jsonString, EditNode parentNode) voidaddPaletteNodesFromJSON(String jsonString, EditNode parentNode, String[] globals) voidaddPaletteNodesFromJSON(String jsonString, EditNode parentNode, String[] globals, Function callback) RecreateEditNodesfrom a JSON representation ofPaletteNodes(possibly created by callingserializeAllEditNodesAsJSON()orserializeEditNodesAsJSON().voidaddPaletteNodesFromXML(String xmlString) RecreateEditNodesfrom an XML representation ofPaletteNodes(possibly created by callingserializeAllEditNodes()orserializeEditNodes().voidaddPaletteNodesFromXML(String xmlString, EditNode parentNode) voidaddPaletteNodesFromXML(String xmlString, EditNode parentNode, String[] globals) voidaddPaletteNodesFromXML(String xmlString, EditNode parentNode, String[] globals, Function callback) RecreateEditNodesfrom an XML representation ofPaletteNodes(possibly created by callingserializeAllEditNodes()orserializeEditNodes().Add a selectedEditNodesUpdated handler.voidconvertedNode(EditNode origNode, EditNode newNode, EditNode parentNode) Notification fired when anEditNodeis converted to a different type when moved from one container to another.voidcopyEditNodes(EditNode editNode) Copies the passed editNode or editNodes to an internal "clipboard" space, for later application viapasteEditNodes().voidcopyEditNodes(EditNode... editNode) Copies the passed editNode or editNodes to an internal "clipboard" space, for later application viapasteEditNodes().create()createPaletteNodeTree(PaletteNode... paletteNodes) Creates aTreefrom the suppliedPaletteNodespreserving internal references from one supplied PaletteNode to another.voidDeselect all EditNodes.voiddeselectEditNodes(List editNodes) Deselect a list of EditNodes.voideditNodeHasDataSource(EditNode editNode) Does theeditNodehave a DataSource assigned?editNodeHasFields(EditNode editNode) Does theeditNodehave at least one field assigned?voidenableEditing(EditNode editNode) Enable edit mode for anEditNode.Returns all global component IDs as a map of ID toEditNode.Dropping a component near the edge of another component allows the component to be dropped through an ancestor component.Controls whether components can be dropped into other components which support child components.New nodes added to the editContext are automatically placed into edit mode if the new node's parent is in edit mode.Should the group selection box shown whencanGroupSelectis true allow dragging the group as a whole?Should a group selection outline covering the outermost bounding boxes of all selected components be shown in this container?Should editNodes added to this EditContext be selectable? Whentrue, eachEditProxy.canSelectChildrenproperty is enabled unless explicitly set tofalse.Paletteto use when anEditNodeis being created directly by this EditContext, instead of being created due to a user interaction with a palette (eg dragging from aTreePalette, or clicking onMenuPalette).The default parentEditNodeto be used when a new EditNode is added to the EditContext without a specified parent.Properties to apply to allEditProxy.editMasks created for components in edit mode.EditNode[]getEditNodesByType(String types) ReturnsEditNodesas an array that match the specified type or types.EditNode[]getEditNodesByType(String... types) ReturnsEditNodesas an array that match the specified type or types.EditNode[]getEditNodesByType(String[] types, boolean strict) ReturnsEditNodesas an array that match the specified type or types.Gets the tree of editNodes being edited by this editContext.Whether inline editing should be enabled for any components that are added and are placed into editMode.Palette[]AdditionalPalettesto consult for metadata when deserializingEdit Nodes.Should the group selection box shown whencanGroupSelectis true be hidden during drag?Defines the mode of inclusion for components encountered during hoop selection which is enabled whenselectionTypeismultiple.Properties to apply toEditProxy.hoopSelector.getJsObj()voidgetNodeProperty(EditNode editNode, String name) Returns the specified property from the editNode's serializable "defaults".static EditContextgetOrCreateRef(JavaScriptObject jsObj) voidgetPaletteNodesFromJS(String jsCode, PaletteNodeCallback callback) ObtainPaletteNodesfrom a JavaScript source representation.voidgetPaletteNodesFromJS(String jsCode, PaletteNodeCallback callback, String[] globals) ObtainPaletteNodesfrom a JavaScript source representation.voidgetPaletteNodesFromXML(String xmlString, PaletteNodeCallback callback) ObtainPaletteNodesfrom an XML representation, but do not add them to the EditContext.When enabled, changes to aliveObject's position and size will be persisted to theirEditNodesby default.Root of data to edit.Returns the rootEditNodeof the EditContext typically created fromrootComponent.Appearance that is applied to selected component.Set the CSS border to be applied to the selection outline of the selected components.Returns selected EditNode or first selected EditNode if multiple nodes are selected.EditNode[]Returns all selected EditNodes as an Array.The background color for the selection outline label.Mask color applied toeditMaskof selected component whenEditProxy.selectedAppearanceis "tintMask".intOpacity applied toeditMaskof selected component whenEditProxy.selectedAppearanceis "tintMask".Defines selection behavior when in edit mode.Should the selection outline show a label for selected components? A component may also be highlighted with the selection outline and label to indicate the target of a drop.Should the selection outline show a label when the component is selected? This property is similar toshowSelectedLabel.voidinlineEditorShowing(FormItem field, String type) Notification method fired when an inline title or value editor is shown or closed for a component in the designer pane.booleanbooleanReturns true if the editNode is selected.booleanisNodeEditingOn(EditNode editNode) Returns true ifeditNodeis in edit mode.makeEditNode(PaletteNode paletteNode) Creates and returns an EditNode using thedefaultPalette.makePaletteNode(EditNode editNode) makePaletteNodeTree(EditNode editNode, Boolean removeAutoIDs) Creates aTreeofPaletteNodesfrom anEditNodein this context'seditNodeTree, by usingmakePaletteNode()on the passedEditNodeand its descendents within theeditNodeTree.voidnodeMoved(EditNode oldNode, EditNode oldParentNode, EditNode newNode, EditNode newParentNode, EditNode rootNode) Notification fired when anEditNodehas been moved to a new position in the component tree.voidnodeRemoved(EditNode removedNode, EditNode parentNode, EditNode rootNode) Notification fired when anEditNodehas been removed from the EditContextvoid"Pastes"editNodespreviously captured viacopyEditNodes().voidpasteEditNodes(EditNode targetEditNode) "Pastes"editNodespreviously captured viacopyEditNodes().voidRemoves allEditNodesfrom the EditContext, but does not destroy theliveObjects.voidremoveNode(EditNode editNode) RemovesEditNodefrom the EditContext.voidremoveNodeProperties(EditNode editNode, String[] properties) Removes the specified properties from an editNode's serializable "defaults".voidreorderNode(EditNode parentNode, Integer index, Integer moveToIndex) Moves anEditNodefrom one child index to another in the EditContext under the specified parent.voidSelect all EditNodes.voidselectEditNode(EditNode editNode) Select an EditNode.voidselectSingleEditNode(EditNode editNode) Select a single EditNode and deselect everything else.Serialize the tree ofEditNodesto an XML representation ofPaletteNodes.serializeAllEditNodes(SerializationSettings settings) Serialize the tree ofEditNodesto an XML representation ofPaletteNodes.Encode the tree ofEditNodesto a JSON representation ofPaletteNodes.Encode the tree ofEditNodesto a JSON representation ofPaletteNodes.serializeEditNodes(EditNode[] nodes) Serialize the providedEditNodesto an XML representation ofPaletteNodes.serializeEditNodes(EditNode[] nodes, SerializationSettings settings) Serialize the providedEditNodesto an XML representation ofPaletteNodes.serializeEditNodesAsJSON(EditNode[] nodes) Serialize the providedEditNodesto a JSON representation ofPaletteNodes.serializeEditNodesAsJSON(EditNode[] nodes, SerializationSettings settings) Serialize the providedEditNodesto a JSON representation ofPaletteNodes.setAllowDropThrough(Boolean allowDropThrough) Dropping a component near the edge of another component allows the component to be dropped through an ancestor component.setAllowNestedDrops(Boolean allowNestedDrops) Controls whether components can be dropped into other components which support child components.setAutoEditNewNodes(Boolean autoEditNewNodes) New nodes added to the editContext are automatically placed into edit mode if the new node's parent is in edit mode.setCanDragGroup(Boolean canDragGroup) Should the group selection box shown whencanGroupSelectis true allow dragging the group as a whole?setCanGroupSelect(Boolean canGroupSelect) Should a group selection outline covering the outermost bounding boxes of all selected components be shown in this container?setCanSelectEditNodes(Boolean canSelectEditNodes) Should editNodes added to this EditContext be selectable? Whentrue, eachEditProxy.canSelectChildrenproperty is enabled unless explicitly set tofalse.setDefaultPalette(Palette defaultPalette) Paletteto use when anEditNodeis being created directly by this EditContext, instead of being created due to a user interaction with a palette (eg dragging from aTreePalette, or clicking onMenuPalette).setDefaultParent(EditNode defaultParent) The default parentEditNodeto be used when a new EditNode is added to the EditContext without a specified parent.setEditMaskProperties(Map editMaskProperties) Properties to apply to allEditProxy.editMasks created for components in edit mode.voidsetEditProxyProperties(EditNode editNode, EditProxy properties) Update an editNode'sEditProxyproperties.setEnableInlineEdit(Boolean enableInlineEdit) Whether inline editing should be enabled for any components that are added and are placed into editMode.setExtraPalettes(Palette... extraPalettes) AdditionalPalettesto consult for metadata when deserializingEdit Nodes.setHideGroupBorderOnDrag(Boolean hideGroupBorderOnDrag) Should the group selection box shown whencanGroupSelectis true be hidden during drag?setHoopSelectionMode(HoopSelectionStyle hoopSelectionMode) Defines the mode of inclusion for components encountered during hoop selection which is enabled whenselectionTypeismultiple.setHoopSelectorProperties(Map hoopSelectorProperties) Properties to apply toEditProxy.hoopSelector.voidprotected voidsetNodeProperties(EditNode editNode, JavaScriptObject properties) protected voidsetNodeProperties(EditNode editNode, JavaScriptObject properties, Boolean skipLiveObjectUpdate) voidsetNodeProperties(EditNode editNode, Canvas properties) Update an editNode's serializable "defaults" with the supplied properties.voidsetNodeProperties(EditNode editNode, Canvas properties, Boolean skipLiveObjectUpdate) Update an editNode's serializable "defaults" with the supplied properties.voidsetNodeProperties(EditNode editNode, DrawItem properties) Update an editNode's serializable "defaults" with the supplied properties.voidsetNodeProperties(EditNode editNode, DrawItem properties, Boolean skipLiveObjectUpdate) Update an editNode's serializable "defaults" with the supplied properties.setPersistCoordinates(Boolean persistCoordinates) When enabled, changes to aliveObject's position and size will be persisted to theirEditNodesby default.setRootComponent(PaletteNode rootComponent) Root of data to edit.setSelectedAppearance(SelectedAppearance selectedAppearance) Appearance that is applied to selected component.setSelectedBorder(String selectedBorder) Set the CSS border to be applied to the selection outline of the selected components.setSelectedLabelBackgroundColor(String selectedLabelBackgroundColor) The background color for the selection outline label.setSelectedTintColor(String selectedTintColor) Mask color applied toeditMaskof selected component whenEditProxy.selectedAppearanceis "tintMask".setSelectedTintOpacity(int selectedTintOpacity) Opacity applied toeditMaskof selected component whenEditProxy.selectedAppearanceis "tintMask".setSelectionType(SelectionStyle selectionType) Defines selection behavior when in edit mode.setShowSelectedLabel(Boolean showSelectedLabel) Should the selection outline show a label for selected components? A component may also be highlighted with the selection outline and label to indicate the target of a drop.setShowSelectedLabelOnSelect(Boolean showSelectedLabelOnSelect) Should the selection outline show a label when the component is selected? This property is similar toshowSelectedLabel.setUseCopyPasteShortcuts(Boolean useCopyPasteShortcuts) voidsubstitutedNode(PaletteNode origNode, PaletteNode newNode, EditNode parentNode) Notification fired when a differentPaletteNodeis substituted for one being dropped into a container.Methods inherited from class com.smartgwt.client.core.BaseClassaddDynamicProperty, addDynamicProperty, addDynamicProperty, addDynamicProperty, applyFactoryProperties, asSGWTComponent, clearDynamicProperty, createJsObj, destroy, doAddHandler, doInit, error, error, errorIfNotCreated, fireEvent, getAttribute, getAttributeAsBoolean, getAttributeAsDate, getAttributeAsDouble, getAttributeAsElement, getAttributeAsFloat, getAttributeAsInt, getAttributeAsJavaScriptObject, getAttributeAsMap, getAttributeAsString, getAttributeAsStringArray, getClassName, getConfig, getHandlerCount, getID, getRef, getRuleScope, getScClassName, getTestInstance, hasAutoAssignedID, hasDynamicProperty, internalSetID, internalSetID, isConfigOnly, isFactoryCreated, onBind, onInit, registerID, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setAttribute, setConfig, setConfigOnly, setFactoryCreated, setID, setProperty, setProperty, setProperty, setProperty, setRuleScope, setScClassNameMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, waitMethods inherited from interface com.google.gwt.event.shared.HasHandlersfireEvent
- 
Constructor Details- 
EditContextpublic EditContext()
- 
EditContext
 
- 
- 
Method Details- 
getOrCreateRef
- 
setJavaScriptObject- Overrides:
- setJavaScriptObjectin class- BaseClass
 
- 
create
- 
isCreatedpublic boolean isCreated()
- 
getJsObj
- 
getOrCreateJsObj- Overrides:
- getOrCreateJsObjin class- BaseClass
 
- 
setAllowDropThroughDropping a component near the edge of another component allows the component to be dropped through an ancestor component. To suppress this action setallowDropThroughto false.- Parameters:
- allowDropThrough- New allowDropThrough value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
 
- 
getAllowDropThroughDropping a component near the edge of another component allows the component to be dropped through an ancestor component. To suppress this action setallowDropThroughto false.- Returns:
- Current allowDropThrough value. Default value is null
 
- 
setAllowNestedDropsControls whether components can be dropped into other components which support child components.When enabled, during a drop interaction in which a PaletteNodeorEditNodeis the drop data, theComponent Schemaof the current candidate drop target is inspected to see whether that parent allows children of the type being dropped. If it does, the drop will result in a call toaddNode()for a paletteNode or for an existingEditNodein the same tree.Specific components can disable nested drops by explicitly setting EditProxy.allowNestedDropsto false.This mode is enabled by default unless explicitly disabled by setting this property to false. - Parameters:
- allowNestedDrops- New allowNestedDrops value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getAllowNestedDropsControls whether components can be dropped into other components which support child components.When enabled, during a drop interaction in which a PaletteNodeorEditNodeis the drop data, theComponent Schemaof the current candidate drop target is inspected to see whether that parent allows children of the type being dropped. If it does, the drop will result in a call toaddNode()for a paletteNode or for an existingEditNodein the same tree.Specific components can disable nested drops by explicitly setting EditProxy.allowNestedDropsto false.This mode is enabled by default unless explicitly disabled by setting this property to false. - Returns:
- Current allowNestedDrops value. Default value is null
 
- 
setAutoEditNewNodesNew nodes added to the editContext are automatically placed into edit mode if the new node's parent is in edit mode. To suppress this action setautoEditNewNodesto false.- Parameters:
- autoEditNewNodes- New autoEditNewNodes value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
 
- 
getAutoEditNewNodesNew nodes added to the editContext are automatically placed into edit mode if the new node's parent is in edit mode. To suppress this action setautoEditNewNodesto false.- Returns:
- Current autoEditNewNodes value. Default value is null
 
- 
setCanDragGroupShould the group selection box shown whencanGroupSelectis true allow dragging the group as a whole?Treated as trueif not set andcanGroupSelectis true.- Parameters:
- canDragGroup- New canDragGroup value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getCanDragGroupShould the group selection box shown whencanGroupSelectis true allow dragging the group as a whole?Treated as trueif not set andcanGroupSelectis true.- Returns:
- Current canDragGroup value. Default value is null
 
- 
setCanGroupSelectShould a group selection outline covering the outermost bounding boxes of all selected components be shown in this container?Treated as trueif not set and hoop selection is enabled (seeEditProxy.canSelectChildrenandselectionType.- Parameters:
- canGroupSelect- New canGroupSelect value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getCanGroupSelectShould a group selection outline covering the outermost bounding boxes of all selected components be shown in this container?Treated as trueif not set and hoop selection is enabled (seeEditProxy.canSelectChildrenandselectionType.- Returns:
- Current canGroupSelect value. Default value is null
 
- 
setCanSelectEditNodesShould editNodes added to this EditContext be selectable? Whentrue, eachEditProxy.canSelectChildrenproperty is enabled unless explicitly set tofalse. This allows an individual component to override this setting.- Parameters:
- canSelectEditNodes- New canSelectEditNodes value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getCanSelectEditNodesShould editNodes added to this EditContext be selectable? Whentrue, eachEditProxy.canSelectChildrenproperty is enabled unless explicitly set tofalse. This allows an individual component to override this setting.- Returns:
- Current canSelectEditNodes value. Default value is null
 
- 
setDefaultPalettePaletteto use when anEditNodeis being created directly by this EditContext, instead of being created due to a user interaction with a palette (eg dragging from aTreePalette, or clicking onMenuPalette).If no defaultPalette is provided, the EditContext uses an automatically created HiddenPalette.
 If this method is called after the component has been drawn/initialized:Paletteto use when anEditNodeis being created directly by this EditContext, instead of being created due to a user interaction with a palette (eg dragging from aTreePalette, or clicking onMenuPalette).If no defaultPalette is provided, the EditContext uses an automatically created HiddenPalette.- Parameters:
- defaultPalette- the default Palette. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
 
- 
getDefaultPalettePaletteto use when anEditNodeis being created directly by this EditContext, instead of being created due to a user interaction with a palette (eg dragging from aTreePalette, or clicking onMenuPalette).If no defaultPalette is provided, the EditContext uses an automatically created HiddenPalette.- Returns:
- Paletteto use when an- EditNodeis being created directly by this EditContext, instead of being created due to a user interaction with a palette (eg dragging from a- TreePalette, or clicking on- MenuPalette).- If no defaultPalette is provided, the EditContext uses an automatically created - HiddenPalette. Default value is null
 
- 
setDefaultParentThe default parentEditNodeto be used when a new EditNode is added to the EditContext without a specified parent. This commonly occurs when a paletteNode is double-clicked in a palette.If not specified, the root editNode (see getRootEditNode()) is used.Note: this property is automatically cleared if node is removed from the editTree such as on calls to destroyAll()orremoveNode().- Parameters:
- defaultParent- New defaultParent value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
 
- 
getDefaultParentThe default parentEditNodeto be used when a new EditNode is added to the EditContext without a specified parent. This commonly occurs when a paletteNode is double-clicked in a palette.If not specified, the root editNode (see getRootEditNode()) is used.Note: this property is automatically cleared if node is removed from the editTree such as on calls to destroyAll()orremoveNode().- Returns:
- Current defaultParent value. Default value is null
 
- 
setEditMaskPropertiesProperties to apply to allEditProxy.editMasks created for components in edit mode. This mask can be modified when the node is selected byselectedBorder,selectedTintColorandselectedTintOpacitydepending on theselectedAppearancesetting.- Parameters:
- editMaskProperties- New editMaskProperties value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getEditMaskPropertiesProperties to apply to allEditProxy.editMasks created for components in edit mode. This mask can be modified when the node is selected byselectedBorder,selectedTintColorandselectedTintOpacitydepending on theselectedAppearancesetting.- Returns:
- Current editMaskProperties value. Default value is null
 
- 
setEnableInlineEditWhether inline editing should be enabled for any components that are added and are placed into editMode. Enabling this will turn on inline edit for any EditProxy whereEditProxy.supportsInlineEditis true.- Parameters:
- enableInlineEdit- New enableInlineEdit value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getEnableInlineEditWhether inline editing should be enabled for any components that are added and are placed into editMode. Enabling this will turn on inline edit for any EditProxy whereEditProxy.supportsInlineEditis true.- Returns:
- Current enableInlineEdit value. Default value is null
 
- 
setExtraPalettesAdditionalPalettesto consult for metadata when deserializingEdit Nodes. Note that thedefaultPaletteis always consulted and need not be provided again here.- Parameters:
- extraPalettes- New extraPalettes value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
 
- 
getExtraPalettesAdditionalPalettesto consult for metadata when deserializingEdit Nodes. Note that thedefaultPaletteis always consulted and need not be provided again here.- Returns:
- Current extraPalettes value. Default value is null
 
- 
setHideGroupBorderOnDragpublic EditContext setHideGroupBorderOnDrag(Boolean hideGroupBorderOnDrag) throws IllegalStateException Should the group selection box shown whencanGroupSelectis true be hidden during drag?Treated as trueif not explicitly set to false.- Parameters:
- hideGroupBorderOnDrag- New hideGroupBorderOnDrag value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getHideGroupBorderOnDragShould the group selection box shown whencanGroupSelectis true be hidden during drag?Treated as trueif not explicitly set to false.- Returns:
- Current hideGroupBorderOnDrag value. Default value is null
 
- 
setHoopSelectionModepublic EditContext setHoopSelectionMode(HoopSelectionStyle hoopSelectionMode) throws IllegalStateException Defines the mode of inclusion for components encountered during hoop selection which is enabled whenselectionTypeismultiple.enclosesmode causes selection of components that are completely enclosed by the hoop.intersectsmode selects components that come into contact with the hoop.- Parameters:
- hoopSelectionMode- New hoopSelectionMode value. Default value is "encloses"
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
- See Also:
 
- 
getHoopSelectionModeDefines the mode of inclusion for components encountered during hoop selection which is enabled whenselectionTypeismultiple.enclosesmode causes selection of components that are completely enclosed by the hoop.intersectsmode selects components that come into contact with the hoop.- Returns:
- Current hoopSelectionMode value. Default value is "encloses"
- See Also:
 
- 
setHoopSelectorPropertiespublic EditContext setHoopSelectorProperties(Map hoopSelectorProperties) throws IllegalStateException Properties to apply toEditProxy.hoopSelector.- Parameters:
- hoopSelectorProperties- New hoopSelectorProperties value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getHoopSelectorPropertiesProperties to apply toEditProxy.hoopSelector.- Returns:
- Current hoopSelectorProperties value. Default value is null
 
- 
setPersistCoordinatesWhen enabled, changes to aliveObject's position and size will be persisted to theirEditNodesby default. This applies to both programmatic calls and user interaction (drag reposition or drag resize).This feature can be disabled by either setting this property or EditProxy.persistCoordinatestofalse. This property affects all nodes within the EditContext whereas the latter property affects children of a single node.In some use-cases, like Reify, coordinates should not be persisted except when a component explicitly enables this feature. By setting this property to nullno component will persist coordinates of children unlessEditProxy.persistCoordinatesis explicitly set totrue.- Parameters:
- persistCoordinates- New persistCoordinates value. Default value is true
- Returns:
- EditContextinstance, for chaining setter calls
 
- 
getPersistCoordinatesWhen enabled, changes to aliveObject's position and size will be persisted to theirEditNodesby default. This applies to both programmatic calls and user interaction (drag reposition or drag resize).This feature can be disabled by either setting this property or EditProxy.persistCoordinatestofalse. This property affects all nodes within the EditContext whereas the latter property affects children of a single node.In some use-cases, like Reify, coordinates should not be persisted except when a component explicitly enables this feature. By setting this property to nullno component will persist coordinates of children unlessEditProxy.persistCoordinatesis explicitly set totrue.- Returns:
- Current persistCoordinates value. Default value is true
 
- 
setRootComponentRoot of data to edit. Must contain the "type" property, with the name of a validschemaor nothing will be able to be dropped on this EditContext. A "liveObject" property representing the rootComponent is also suggested. Otherwise, a live object will be created from the palette node.Can be retrieved at any time. Use getRootEditNode()to retrieve theEditNodecreated from the rootComponent.- Parameters:
- rootComponent- New rootComponent value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
- See Also:
 
- 
getRootComponentRoot of data to edit. Must contain the "type" property, with the name of a validschemaor nothing will be able to be dropped on this EditContext. A "liveObject" property representing the rootComponent is also suggested. Otherwise, a live object will be created from the palette node.Can be retrieved at any time. Use getRootEditNode()to retrieve theEditNodecreated from the rootComponent.- Returns:
- Current rootComponent value. Default value is null
- See Also:
 
- 
setSelectedAppearancepublic EditContext setSelectedAppearance(SelectedAppearance selectedAppearance) throws IllegalStateException Appearance that is applied to selected component.This value is applied as a default to EditProxy.selectedAppearance.- Parameters:
- selectedAppearance- New selectedAppearance value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
- See Also:
 
- 
getSelectedAppearanceAppearance that is applied to selected component.This value is applied as a default to EditProxy.selectedAppearance.- Returns:
- Current selectedAppearance value. Default value is null
- See Also:
 
- 
setSelectedBorderSet the CSS border to be applied to the selection outline of the selected components. This property is used whenEditProxy.selectedAppearanceisoutlineMaskoroutlineEdges.This value is applied as a default to EditProxy.selectedBorder.- Parameters:
- selectedBorder- New selectedBorder value. Default value is "1px dashed #44ff44"
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getSelectedBorderSet the CSS border to be applied to the selection outline of the selected components. This property is used whenEditProxy.selectedAppearanceisoutlineMaskoroutlineEdges.This value is applied as a default to EditProxy.selectedBorder.- Returns:
- Current selectedBorder value. Default value is "1px dashed #44ff44"
 
- 
setSelectedLabelBackgroundColorpublic EditContext setSelectedLabelBackgroundColor(String selectedLabelBackgroundColor) throws IllegalStateException The background color for the selection outline label. The default is defined onSelectionOutline.This value is applied as a default to EditProxy.selectedLabelBackgroundColor.NOTE: A selected component label is only supported when EditProxy.selectedAppearanceis "outlineEdges".- Parameters:
- selectedLabelBackgroundColor- New selectedLabelBackgroundColor value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
- See Also:
 
- 
getSelectedLabelBackgroundColorThe background color for the selection outline label. The default is defined onSelectionOutline.This value is applied as a default to EditProxy.selectedLabelBackgroundColor.NOTE: A selected component label is only supported when EditProxy.selectedAppearanceis "outlineEdges".- Returns:
- Current selectedLabelBackgroundColor value. Default value is null
- See Also:
 
- 
setSelectedTintColorMask color applied toeditMaskof selected component whenEditProxy.selectedAppearanceis "tintMask".This value is applied as a default to EditProxy.selectedTintColor.- Parameters:
- selectedTintColor- New selectedTintColor value. Default value is "#cccccc"
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
- See Also:
 
- 
getSelectedTintColorMask color applied toeditMaskof selected component whenEditProxy.selectedAppearanceis "tintMask".This value is applied as a default to EditProxy.selectedTintColor.- Returns:
- Current selectedTintColor value. Default value is "#cccccc"
- See Also:
 
- 
setSelectedTintOpacityOpacity applied toeditMaskof selected component whenEditProxy.selectedAppearanceis "tintMask".This value is applied as a default to EditProxy.selectedTintOpacity.- Parameters:
- selectedTintOpacity- New selectedTintOpacity value. Default value is 25
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
- See Also:
 
- 
getSelectedTintOpacitypublic int getSelectedTintOpacity()Opacity applied toeditMaskof selected component whenEditProxy.selectedAppearanceis "tintMask".This value is applied as a default to EditProxy.selectedTintOpacity.- Returns:
- Current selectedTintOpacity value. Default value is 25
- See Also:
 
- 
setSelectionTypeDefines selection behavior when in edit mode. Only two styles are supported: "single" and "multiple". Multiple enables hoop selection.- Parameters:
- selectionType- New selectionType value. Default value is "multiple"
- Returns:
- EditContextinstance, for chaining setter calls
- See Also:
 
- 
getSelectionTypeDefines selection behavior when in edit mode. Only two styles are supported: "single" and "multiple". Multiple enables hoop selection.- Returns:
- Current selectionType value. Default value is "multiple"
- See Also:
 
- 
setShowSelectedLabelShould the selection outline show a label for selected components? A component may also be highlighted with the selection outline and label to indicate the target of a drop. To suppress showing a label at any time set this property tofalse.To suppress labels during selection but still show them when targeted for a drop, see showSelectedLabelOnSelect.NOTE: A selected component label is only supported when EditProxy.selectedAppearanceis "outlineEdges".- Parameters:
- showSelectedLabel- New showSelectedLabel value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getShowSelectedLabelShould the selection outline show a label for selected components? A component may also be highlighted with the selection outline and label to indicate the target of a drop. To suppress showing a label at any time set this property tofalse.To suppress labels during selection but still show them when targeted for a drop, see showSelectedLabelOnSelect.NOTE: A selected component label is only supported when EditProxy.selectedAppearanceis "outlineEdges".- Returns:
- Current showSelectedLabel value. Default value is null
 
- 
setShowSelectedLabelOnSelectpublic EditContext setShowSelectedLabelOnSelect(Boolean showSelectedLabelOnSelect) throws IllegalStateException Should the selection outline show a label when the component is selected? This property is similar toshowSelectedLabel. WhereasshowSelectedLabelcontrols whether a label is shown at any time, this property allows normal selection to suppress the label but still show a label during the drop process on the target. LeaveshowSelectedLabelunset and set this property tofalse.NOTE: A selected component label is only supported when EditProxy.selectedAppearanceis "outlineEdges".- Parameters:
- showSelectedLabelOnSelect- New showSelectedLabelOnSelect value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getShowSelectedLabelOnSelectShould the selection outline show a label when the component is selected? This property is similar toshowSelectedLabel. WhereasshowSelectedLabelcontrols whether a label is shown at any time, this property allows normal selection to suppress the label but still show a label during the drop process on the target. LeaveshowSelectedLabelunset and set this property tofalse.NOTE: A selected component label is only supported when EditProxy.selectedAppearanceis "outlineEdges".- Returns:
- Current showSelectedLabelOnSelect value. Default value is null
 
- 
setUseCopyPasteShortcutspublic EditContext setUseCopyPasteShortcuts(Boolean useCopyPasteShortcuts) throws IllegalStateException If set, auto-enablesEditProxy.useCopyPasteShortcutson theEditProxyfor theroot editNode. This works whether there is currently a root editNode or one is added later.- Parameters:
- useCopyPasteShortcuts- New useCopyPasteShortcuts value. Default value is null
- Returns:
- EditContextinstance, for chaining setter calls
- Throws:
- IllegalStateException- this property cannot be changed after the underlying component has been created
 
- 
getUseCopyPasteShortcutsIf set, auto-enablesEditProxy.useCopyPasteShortcutson theEditProxyfor theroot editNode. This works whether there is currently a root editNode or one is added later.- Returns:
- Current useCopyPasteShortcuts value. Default value is null
 
- 
addFromPaletteNodeCreates a new EditNode from a PaletteNode, using thedefaultPalette. If you have an array of possibly inter-related PaletteNodes, then you should useaddFromPaletteNodes()on the array instead, in order to preserve the relationships.- Parameters:
- paletteNode- the palette node to use to create the new node
- Returns:
- the EditNode created from the paletteNode
- See Also:
 
- 
addFromPaletteNodeCreates a new EditNode from a PaletteNode, using thedefaultPalette. If you have an array of possibly inter-related PaletteNodes, then you should useaddFromPaletteNodes()on the array instead, in order to preserve the relationships.- Parameters:
- paletteNode- the palette node to use to create the new node
- parentNode- optional the parent node if the new node should appear under a specific parent
- Returns:
- the EditNode created from the paletteNode
- See Also:
 
- 
addFromPaletteNodesAdd the suppliedPaletteNodesto the parentNode, preserving internal references from one supplied PaletteNode to another. This method should be used with an array of possibly inter-related PaletteNodes (for instance, those produced as a result of serialization viaserializeAllEditNodes()) rather than callingaddFromPaletteNode()on each individual PaletteNode.- Parameters:
- paletteNodes- array of PaletteNodes
- Returns:
- an array of the EditNodes added to the parentNode
- See Also:
 
- 
addFromPaletteNodesAdd the suppliedPaletteNodesto the parentNode, preserving internal references from one supplied PaletteNode to another. This method should be used with an array of possibly inter-related PaletteNodes (for instance, those produced as a result of serialization viaserializeAllEditNodes()) rather than callingaddFromPaletteNode()on each individual PaletteNode.- Parameters:
- paletteNodes- array of PaletteNodes
- parentNode- parent to add to (defaults to the root)
- Returns:
- an array of the EditNodes added to the parentNode
- See Also:
 
- 
addFromPaletteNodeTreeAdd the suppliedPaletteNodetree to the parentNode, preserving internal references from one supplied PaletteNode to another.- Parameters:
- paletteNodeTree- tree of PaletteNodes
- Returns:
- an array of the EditNodes added to the parentNode
- See Also:
 
- 
addFromPaletteNodeTreeAdd the suppliedPaletteNodetree to the parentNode, preserving internal references from one supplied PaletteNode to another.- Parameters:
- paletteNodeTree- tree of PaletteNodes
- parentNode- parent to add to (defaults to the root)
- Returns:
- an array of the EditNodes added to the parentNode
- See Also:
 
- 
addNodeAdd a newEditNodeto the EditContext, under the specified parent. If the parentNode is not provided it will be determined fromdefaultParent.The EditContext will interrogate the parent and new nodes to determine what field within the parent allows a child of this type, and to find a method to add the newNode's liveObject to the parentNode's liveObject. The new relationship will then be stored in the tree of EditNodes. For example, when a Tab is dropped on a TabSet, the field TabSet.tabs is discovered as the correct target field via naming conventions, and the method TabSet.addTab() is likewise discovered as the correct method to add a Tab to a TabSet. - Parameters:
- newNode- new node to be added
- Returns:
- newNodenode added
 
- 
addNode
- 
addNode
- 
addNode
- 
addNode
- 
addNodepublic EditNode addNode(EditNode newNode, EditNode parentNode, Integer index, String parentProperty, Boolean skipParentComponentAdd, Boolean forceSingularFieldReplace) Add a newEditNodeto the EditContext, under the specified parent. If the parentNode is not provided it will be determined fromdefaultParent.The EditContext will interrogate the parent and new nodes to determine what field within the parent allows a child of this type, and to find a method to add the newNode's liveObject to the parentNode's liveObject. The new relationship will then be stored in the tree of EditNodes. For example, when a Tab is dropped on a TabSet, the field TabSet.tabs is discovered as the correct target field via naming conventions, and the method TabSet.addTab() is likewise discovered as the correct method to add a Tab to a TabSet. - Parameters:
- newNode- new node to be added
- parentNode- parent to add the new node under.
- index- index within the parent's children array
- parentProperty- the property of the liveParent to which the new node should be added, if not auto-discoverable from the schema
- skipParentComponentAdd- whether to skip adding the liveObject to the liveParent (default false)
- forceSingularFieldReplace- whether to replace existing single field node if newNode liveObject is the same (default false)
- Returns:
- newNodenode added
 
- 
addPaletteNodeFormItemConstructorsAddPaletteNodeconstructors for the specific type ofFormItemthat will be created to the paletteNodes in the specified tree created bycreatePaletteNodeTree().Normally, the specific FormItem is applied from the DataSource and DataBoundComponent at time of use but there are times when having the explicit constructor on the paletteNodes is helpful such as for validation or serialization. Note that the paletteNodes are updated in place. - Parameters:
- nodeTree- tree of PaletteNodes
 
- 
addPaletteNodesFromJSAddPaletteNodesfrom a JavaScript source representation.By default, components that have global IDswill not actually be allowed to take those global IDs - instead, only widgets that have one of the global IDs passed as theglobalsparameter will actually receive their global IDs. To override this behavior, pass the special valueALL_GLOBALSfor theglobalsparameter.- Parameters:
- jsCode- JavaScript code to eval.
 
- 
addPaletteNodesFromJS- See Also:
 
- 
addPaletteNodesFromJSAddPaletteNodesfrom a JavaScript source representation.By default, components that have global IDswill not actually be allowed to take those global IDs - instead, only widgets that have one of the global IDs passed as theglobalsparameter will actually receive their global IDs. To override this behavior, pass the special valueALL_GLOBALSfor theglobalsparameter.- Parameters:
- jsCode- JavaScript code to eval.
- parentNode- parent node (defaults to the root)
- globals- widgets to allow to take their global IDs
 
- 
addPaletteNodesFromJSONRecreateEditNodesfrom a JSON representation ofPaletteNodes(possibly created by callingserializeAllEditNodesAsJSON()orserializeEditNodesAsJSON().By default, components that have global IDswill not actually be allowed to take those global IDs - instead, only widgets that have one of the global IDs passed as theglobalsparameter will actually receive their global IDs. To override this behavior, pass the special valueALL_GLOBALSfor theglobalsparameter.- Parameters:
- jsonString- JSON string representing an array of PaletteNodes
- See Also:
 
- 
addPaletteNodesFromJSON
- 
addPaletteNodesFromJSON
- 
addPaletteNodesFromJSONpublic void addPaletteNodesFromJSON(String jsonString, EditNode parentNode, String[] globals, Function callback) RecreateEditNodesfrom a JSON representation ofPaletteNodes(possibly created by callingserializeAllEditNodesAsJSON()orserializeEditNodesAsJSON().By default, components that have global IDswill not actually be allowed to take those global IDs - instead, only widgets that have one of the global IDs passed as theglobalsparameter will actually receive their global IDs. To override this behavior, pass the special valueALL_GLOBALSfor theglobalsparameter.- Parameters:
- jsonString- JSON string representing an array of PaletteNodes
- parentNode- parent to add to (defaults to the root)
- globals- widgets to allow to take their global IDs
- callback- Callback to fire after nodes have been added
- See Also:
 
- 
addPaletteNodesFromXMLRecreateEditNodesfrom an XML representation ofPaletteNodes(possibly created by callingserializeAllEditNodes()orserializeEditNodes().By default, components that have global IDswill not actually be allowed to take those global IDs - instead, only widgets that have one of the global IDs passed as theglobalsparameter will actually receive their global IDs. To override this behavior, pass the special valueALL_GLOBALSfor theglobalsparameter.- Parameters:
- xmlString- XML string
- See Also:
 
- 
addPaletteNodesFromXML- See Also:
 
- 
addPaletteNodesFromXML- See Also:
 
- 
addPaletteNodesFromXMLpublic void addPaletteNodesFromXML(String xmlString, EditNode parentNode, String[] globals, Function callback) RecreateEditNodesfrom an XML representation ofPaletteNodes(possibly created by callingserializeAllEditNodes()orserializeEditNodes().By default, components that have global IDswill not actually be allowed to take those global IDs - instead, only widgets that have one of the global IDs passed as theglobalsparameter will actually receive their global IDs. To override this behavior, pass the special valueALL_GLOBALSfor theglobalsparameter.- Parameters:
- xmlString- XML string
- parentNode- parent node (defaults to the root)
- globals- widgets to allow to take their global IDs
- callback- Callback to fire after nodes have been added
- See Also:
 
- 
convertedNodeNotification fired when anEditNodeis converted to a different type when moved from one container to another.- Parameters:
- origNode- node that was being moved
- newNode- node that was placed into new container
- parentNode- parent node of the drop
 
- 
copyEditNodesCopies the passed editNode or editNodes to an internal "clipboard" space, for later application viapasteEditNodes().- Parameters:
- editNode-
 
- 
copyEditNodesCopies the passed editNode or editNodes to an internal "clipboard" space, for later application viapasteEditNodes().- Parameters:
- editNode-
 
- 
createPaletteNodeTreeCreates aTreefrom the suppliedPaletteNodespreserving internal references from one supplied PaletteNode to another. This method should be used with an array of possibly inter-related PaletteNodes (for instance, those produced as a result of serialization viaserializeAllEditNodes()) rather than callingaddFromPaletteNode()on each individual PaletteNode.- Parameters:
- paletteNodes- array of PaletteNodes
- Returns:
- a tree of the PaletteNodes
- See Also:
 
- 
deselectAllEditNodespublic void deselectAllEditNodes()Deselect all EditNodes.
- 
deselectEditNodesDeselect a list of EditNodes.- Parameters:
- editNodes- editNodes to deselect
 
- 
destroyAllpublic void destroyAll()
- 
addEditMaskClickedHandlerAdd a editMaskClicked handler.Executed when the left mouse is clicked (pressed and then released) on any selectable component with EditProxy.editMaskenabled. implementation.- Specified by:
- addEditMaskClickedHandlerin interface- HasEditMaskClickedHandlers
- Parameters:
- handler- the editMaskClicked handler
- Returns:
- HandlerRegistrationused to remove this handler
 
- 
editNodeHasDataSourceDoes theeditNodehave a DataSource assigned?- Parameters:
- editNode- editNode to check for a DataSource
- Returns:
- true if the editNode has a DataSource assigned
 
- 
editNodeHasFieldsDoes theeditNodehave at least one field assigned?Note that if this method is called for a component editNode that could have child components rather than fields, it will return trueif there are any child nodes other than a DataSource.- Parameters:
- editNode- editNode to check for fields
- Returns:
- true if the editNode has fields or child nodes other than a DataSource
 
- 
addEditNodeUpdatedHandlerAdd a editNodeUpdated handler.Fires whenever editNode.defaults are modified by setNodeProperties() and/or editProxy features - Specified by:
- addEditNodeUpdatedHandlerin interface- HasEditNodeUpdatedHandlers
- Parameters:
- handler- the editNodeUpdated handler
- Returns:
- HandlerRegistrationused to remove this handler
 
- 
enableEditingEnable edit mode for anEditNode. This is a shortcut for callingCanvas.setEditMode().- Parameters:
- editNode- the EditNode on which to enable editing
- See Also:
 
- 
getAllEditNodeGlobalsReturns all global component IDs as a map of ID toEditNode.- Returns:
- Map of global ID to EditNode for all components in the edit tree
 
- 
getEditNodesByTypeReturnsEditNodesas an array that match the specified type or types. By default thetypesare matched against theEditNode.typeor the general type of the component. By settingstricttotruethe match is made against the editNode type exactly.For example, searching for "Canvas" nodes will return nodes for any component that derives from Canvas unless strictis set. In the strict case, the search will only return nodes for explict Canvas nodes.- Parameters:
- types- type or types of nodes to find
- Returns:
- the filtered list of EditNodes
 
- 
getEditNodesByTypeReturnsEditNodesas an array that match the specified type or types. By default thetypesare matched against theEditNode.typeor the general type of the component. By settingstricttotruethe match is made against the editNode type exactly.For example, searching for "Canvas" nodes will return nodes for any component that derives from Canvas unless strictis set. In the strict case, the search will only return nodes for explict Canvas nodes.- Parameters:
- types- type or types of nodes to find
- Returns:
- the filtered list of EditNodes
 
- 
getEditNodesByTypeReturnsEditNodesas an array that match the specified type or types. By default thetypesare matched against theEditNode.typeor the general type of the component. By settingstricttotruethe match is made against the editNode type exactly.For example, searching for "Canvas" nodes will return nodes for any component that derives from Canvas unless strictis set. In the strict case, the search will only return nodes for explict Canvas nodes.- Parameters:
- types- type or types of nodes to find
- strict- true to match the- EditNode.typeexactly
- Returns:
- the filtered list of EditNodes
 
- 
getEditNodeTreeGets the tree of editNodes being edited by this editContext. Standard tree traversal methods can then be used to locate desired editNodes for interaction.Note: the returned tree is read-only and must only be modified by calling methods on EditContext like addNode()orsetNodeProperties().- Returns:
- the tree of EditNodes
 
- 
getNodePropertyReturns the specified property from the editNode's serializable "defaults".- Parameters:
- editNode- the editNode to query
- name- the property name to query
- See Also:
 
- 
getPaletteNodesFromJSObtainPaletteNodesfrom a JavaScript source representation.By default, components that have global IDswill not actually be allowed to take those global IDs - instead, only widgets that have one of the global IDs passed as theglobalsparameter will actually receive their global IDs. To override this behavior, pass the special valueALL_GLOBALSfor theglobalsparameter.- Parameters:
- jsCode- JavaScript code to eval.
- callback- Callback used to return the PaletteNodes
 
- 
getPaletteNodesFromJSObtainPaletteNodesfrom a JavaScript source representation.By default, components that have global IDswill not actually be allowed to take those global IDs - instead, only widgets that have one of the global IDs passed as theglobalsparameter will actually receive their global IDs. To override this behavior, pass the special valueALL_GLOBALSfor theglobalsparameter.- Parameters:
- jsCode- JavaScript code to eval.
- callback- Callback used to return the PaletteNodes
- globals- widgets to allow to take their global IDs
 
- 
getPaletteNodesFromXMLObtainPaletteNodesfrom an XML representation, but do not add them to the EditContext.- Parameters:
- xmlString- XML string
- callback- Callback used to return the PaletteNodes
- See Also:
 
- 
getRootEditNodeReturns the rootEditNodeof the EditContext typically created fromrootComponent.- Returns:
- the root EditNode
 
- 
getSelectedEditNodeReturns selected EditNode or first selected EditNode if multiple nodes are selected.- Returns:
- the selected or first edit node
 
- 
getSelectedEditNodesReturns all selected EditNodes as an Array.- Returns:
- the selected edit nodes
 
- 
inlineEditorShowingNotification method fired when an inline title or value editor is shown or closed for a component in the designer pane.- Parameters:
- field- the field within the inline editor when showing. null if the editor is closed.
- type- the type of editor showing: "title" or "value"
 
- 
isEditNodeSelectedpublic boolean isEditNodeSelected()Returns true if the editNode is selected.- Returns:
- true if editNode is selected; false otherwise
 
- 
isNodeEditingOnReturns true ifeditNodeis in edit mode.- Parameters:
- editNode- the EditNode
- Returns:
- true if node is in edit mode
 
- 
makeEditNodeCreates and returns an EditNode using thedefaultPalette. Does not add the newly created EditNode to an EditContext.- Parameters:
- paletteNode- the palette node to use to create the new node
- Returns:
- the EditNode created from the paletteNode
 
- 
makePaletteNodeCreates aPaletteNodefrom anEditNodein this context'seditNodeTree.This essentially creates a new PaletteNodewith theEditNode.defaultsfrom the passededitNode. The returnedpaletteNodecould then be used withaddFromPaletteNode()to effectively create a copy of the original editNode - specifically a new editNode with a newEditNode.liveObjectcreated from the same defaults.However note that makePaletteNode()does not copy descendant nodes - usemakePaletteNodeTree()for that.May return null if the passed editNode cannot validly by transformed into a paletteNode, for example if EditNode.canDuplicatewas set false.- Parameters:
- editNode- the editNode to use to make a paletteNode
- Returns:
- paletteNode derived from the editNode or null
 
- 
makePaletteNodeTreeCreates aTreeofPaletteNodesfrom anEditNodein this context'seditNodeTree, by usingmakePaletteNode()on the passedEditNodeand its descendents within theeditNodeTree.The root node of the returned Treewill be a PaletteNode derived from the passedEditNode.- Parameters:
- editNode- root editNode to make Tree of PaletteNodes from
- removeAutoIDs- should ID and autoID defaults be removed?
- Returns:
- a Tree of paletteNodes or null
 
- 
addNodeAddedHandlerAdd a nodeAdded handler.Notification fired when an EditNodehas been added to the EditContext- Specified by:
- addNodeAddedHandlerin interface- HasNodeAddedHandlers
- Parameters:
- handler- the nodeAdded handler
- Returns:
- HandlerRegistrationused to remove this handler
 
- 
nodeMovedpublic void nodeMoved(EditNode oldNode, EditNode oldParentNode, EditNode newNode, EditNode newParentNode, EditNode rootNode) Notification fired when anEditNodehas been moved to a new position in the component tree.- Parameters:
- oldNode- node that was removed
- oldParentNode- parent node of the node that was removed
- newNode- node that was added
- newParentNode- parent node of the node that was added
- rootNode- root node of the edit context
 
- 
nodeRemovedNotification fired when anEditNodehas been removed from the EditContext- Parameters:
- removedNode- node that was removed
- parentNode- parent node of the node that was removed
- rootNode- root node of the edit context
 
- 
pasteEditNodespublic void pasteEditNodes()"Pastes"editNodespreviously captured viacopyEditNodes().New editNodes will be added as root-level nodes of the editNodeTreeunless atargetEditNodeis passed.
- 
pasteEditNodes"Pastes"editNodespreviously captured viacopyEditNodes().New editNodes will be added as root-level nodes of the editNodeTreeunless atargetEditNodeis passed.- Parameters:
- targetEditNode-
 
- 
removeAllpublic void removeAll()Removes allEditNodesfrom the EditContext, but does not destroy theliveObjects.
- 
removeNodeRemovesEditNodefrom the EditContext. The editNode liveObject is not destroyed.- Parameters:
- editNode- node to be removed
 
- 
removeNodePropertiesRemoves the specified properties from an editNode's serializable "defaults". Note that theliveObjectis not updated by this method. To set a property to null (rather than removing it), usesetNodeProperties()instead.- Parameters:
- editNode- the editNode to update
- properties- an array of property names to remove
- See Also:
 
- 
reorderNodeMoves anEditNodefrom one child index to another in the EditContext under the specified parent.No changes are made to the live objects. - Parameters:
- parentNode- parent to reorder child nodes
- index- index within the parent's children array to be moved
- moveToIndex- index within the parent's children array at which to place moved node
 
- 
selectAllEditNodespublic void selectAllEditNodes()Select all EditNodes.
- 
addSelectedEditNodesUpdatedHandlerpublic HandlerRegistration addSelectedEditNodesUpdatedHandler(SelectedEditNodesUpdatedHandler handler) Add a selectedEditNodesUpdated handler.Called when editMode selection changes. Note this method fires exactly once for any given change. This event is fired once after selection/deselection has completed. The result is one event per mouse-down event. For a drag selection there will be one event fired when the range is completed. - Specified by:
- addSelectedEditNodesUpdatedHandlerin interface- HasSelectedEditNodesUpdatedHandlers
- Parameters:
- handler- the selectedEditNodesUpdated handler
- Returns:
- HandlerRegistrationused to remove this handler
 
- 
selectEditNodeSelect an EditNode.- Parameters:
- editNode- editNode to select
 
- 
selectSingleEditNodeSelect a single EditNode and deselect everything else.- Parameters:
- editNode- editNode to select
 
- 
serializeAllEditNodesSerialize the tree ofEditNodesto an XML representation ofPaletteNodes. The result can be supplied toaddPaletteNodesFromXML()to recreate the EditNodes.- Returns:
- an XML representation of PaletteNodes which can be used to recreate the tree of EditNodes.
- See Also:
 
- 
serializeAllEditNodesSerialize the tree ofEditNodesto an XML representation ofPaletteNodes. The result can be supplied toaddPaletteNodesFromXML()to recreate the EditNodes.- Parameters:
- settings- Additional serialization settings
- Returns:
- an XML representation of PaletteNodes which can be used to recreate the tree of EditNodes.
- See Also:
 
- 
serializeAllEditNodesAsJSONEncode the tree ofEditNodesto a JSON representation ofPaletteNodes. The result can be supplied toaddPaletteNodesFromJSON()to recreate the EditNodes.- Returns:
- a JSON representation of PaletteNodes which can be used to recreate the tree of EditNodes.
- See Also:
 
- 
serializeAllEditNodesAsJSONEncode the tree ofEditNodesto a JSON representation ofPaletteNodes. The result can be supplied toaddPaletteNodesFromJSON()to recreate the EditNodes.- Parameters:
- settings- Additional serialization settings
- Returns:
- a JSON representation of PaletteNodes which can be used to recreate the tree of EditNodes.
- See Also:
 
- 
serializeEditNodesSerialize the providedEditNodesto an XML representation ofPaletteNodes. Note that the EditNodes must have been added to this EditContext. The result can be supplied toaddPaletteNodesFromXML()to recreate the EditNodes.- Parameters:
- nodes- EditNodes to be serialized
- Returns:
- an XML representtion of the provided EditNodes
 
- 
serializeEditNodesSerialize the providedEditNodesto an XML representation ofPaletteNodes. Note that the EditNodes must have been added to this EditContext. The result can be supplied toaddPaletteNodesFromXML()to recreate the EditNodes.- Parameters:
- nodes- EditNodes to be serialized
- settings- Additional serialization settings
- Returns:
- an XML representtion of the provided EditNodes
 
- 
serializeEditNodesAsJSONSerialize the providedEditNodesto a JSON representation ofPaletteNodes. Note that the EditNodes must have been added to this EditContext. The result can be supplied toaddPaletteNodesFromJSON()to recreate the EditNodes.- Parameters:
- nodes- EditNodes to be serialized
- Returns:
- a JSON representtion of the provided EditNodes
 
- 
serializeEditNodesAsJSONSerialize the providedEditNodesto a JSON representation ofPaletteNodes. Note that the EditNodes must have been added to this EditContext. The result can be supplied toaddPaletteNodesFromJSON()to recreate the EditNodes.- Parameters:
- nodes- EditNodes to be serialized
- settings- Additional serialization settings
- Returns:
- a JSON representtion of the provided EditNodes
 
- 
setEditProxyPropertiesUpdate an editNode'sEditProxyproperties. If editProxy has not yet been created,editProxyPropertiesis updated or created instead.- Parameters:
- editNode- the editNode to update
- properties- the properties to apply
 
- 
setNodePropertiesUpdate an editNode's serializable "defaults" with the supplied properties. If you wish to remove a property from the defaults (rather than setting it to null), then useremoveNodeProperties()instead.- Parameters:
- editNode- the editNode to update
- properties- the properties to apply
- See Also:
 
- 
setNodePropertiesUpdate an editNode's serializable "defaults" with the supplied properties. If you wish to remove a property from the defaults (rather than setting it to null), then useremoveNodeProperties()instead.- Parameters:
- editNode- the editNode to update
- properties- the properties to apply
- skipLiveObjectUpdate- whether to skip updating the- liveObject, e.g. if you have already updated the liveObject
- See Also:
 
- 
substitutedNodeNotification fired when a differentPaletteNodeis substituted for one being dropped into a container.- Parameters:
- origNode- node that was originally dropped
- newNode- node that was substituted
- parentNode- parent node of the drop
 
- 
setNodePropertiesUpdate an editNode's serializable "defaults" with the supplied properties. If you wish to remove a property from the defaults (rather than setting it to null), then useremoveNodeProperties()instead.- Parameters:
- editNode- the editNode to update
- properties- the properties to apply
- Throws:
- IllegalStateException
- See Also:
 
- 
setNodePropertiespublic void setNodeProperties(EditNode editNode, DrawItem properties, Boolean skipLiveObjectUpdate) throws IllegalStateException Update an editNode's serializable "defaults" with the supplied properties. If you wish to remove a property from the defaults (rather than setting it to null), then useremoveNodeProperties()instead.- Parameters:
- editNode- the editNode to update
- properties- the properties to apply
- skipLiveObjectUpdate- whether to skip updating the- liveObject, e.g. if you have already updated the liveObject
- Throws:
- IllegalStateException
- See Also:
 
- 
setNodeProperties
- 
setNodePropertiesprotected void setNodeProperties(EditNode editNode, JavaScriptObject properties, Boolean skipLiveObjectUpdate) 
 
-