Package com.iizigo.server
Class ServerConfigComposite
java.lang.Object
org.eclipse.swt.widgets.Widget
org.eclipse.swt.widgets.Control
org.eclipse.swt.widgets.Scrollable
org.eclipse.swt.widgets.Composite
com.iizigo.server.ServerConfigComposite
- All Implemented Interfaces:
IDraggingFix
,IPropertyEditorController
,IServerConfigFileListener
,EventListener
,IDisposedPart
,IPropUndoRedo
,ISelectionChangedListener
,Drawable
public class ServerConfigComposite extends Composite implements IPropUndoRedo, ISelectionChangedListener, IDraggingFix, IPropertyEditorController, IServerConfigFileListener, EventListener
The Server Configuration composite displays a tree with the server configuration and a property editor for the properties.
- Author:
- Christopher Mindus
Nested Class Summary
Modifier and TypeClassDescriptionprotected final class
Class used to delegate DragSource events to the listener, making it possible to know when drag-drop is in effect.Field Summary
Constructor Summary
ConstructorDescriptionServerConfigComposite
(IWorkbenchPart part, Composite parent, IMemento restoreMemento, Runnable saveChangedCallback) Creates the Server configuration composite.Method Summary
Modifier and TypeMethodDescriptionvoid
addErrorComposite
(Composite errorComposite) Adds an error composite for presentation of the errors.void
Creates the view part.void
dispose()
Disposes of this composite.void
doSave
(IProgressMonitor monitor) Saves the contents if required.Gets the ModuleModel instance of the project.Gets the multi-property selection provider.Gets the selection enabler instance.Gets the Server Configuration file instance.Gets the settings.Gets the structured viewer (common, tree or table) used for the property operation (add, delete, etc).Gets the undo context.Gets the undo/redo instance.boolean
isDirty()
Gets the dirty state.boolean
Flag for dragging to postpone selection events until drag completes.protected void
Drag started.protected void
Drag finished.void
Called to process an event.void
onServerConfigFileUpdated
(ServerConfigFile serverConfigFile) Called when a change has been made somehow and/or the property tree has been verified for errors.void
removePropertyValue
(GProp<?> property) Removes a property when undefined in the editors.void
Saves the state.void
Notifies that the selection has changed.void
setBlockViewerFocus
(boolean block) Blocks the target viewer from focus.void
setPropertyAttrFlag
(GProp<?> property, int attr, boolean flag) Sets a property attribute flag.void
setPropertyError
(GProp<?> property, String errorID, IPropErrorItem item) Sets a property error.void
setPropertyValue
(PropCnr parent, GProp<?> property, Object value) Sets a property value.void
setServerConfigFile
(ServerConfigFile config, Exception loadException) Sets or clears the Server configuration file to edit.void
setTargetViewer
(Object viewer) Sets the structured viewer (common, tree or table) used for the property operation (add, delete, etc).void
Updates the states of menu items and tool bars.Methods inherited from class org.eclipse.swt.widgets.Composite
changed, checkSubclass, computeSize, drawBackground, getBackgroundMode, getChildren, getLayout, getLayoutDeferred, getTabList, isLayoutDeferred, layout, layout, layout, layout, layout, redraw, setBackgroundMode, setFocus, setLayout, setLayoutDeferred, setTabList, toString
Methods inherited from class org.eclipse.swt.widgets.Scrollable
computeTrim, getClientArea, getHorizontalBar, getScrollbarsMode, getVerticalBar
Methods inherited from class org.eclipse.swt.widgets.Control
addControlListener, addDragDetectListener, addFocusListener, addGestureListener, addHelpListener, addKeyListener, addMenuDetectListener, addMouseListener, addMouseMoveListener, addMouseTrackListener, addMouseWheelListener, addPaintListener, addTouchListener, addTraverseListener, computeSize, dragDetect, dragDetect, forceFocus, getAccessible, getBackground, getBackgroundImage, getBorderWidth, getBounds, getCursor, getDragDetect, getEnabled, getFont, getForeground, getLayoutData, getLocation, getMenu, getMonitor, getOrientation, getParent, getRegion, getShell, getSize, getTextDirection, getToolTipText, getTouchEnabled, getVisible, internal_dispose_GC, internal_new_GC, isEnabled, isFocusControl, isReparentable, isVisible, moveAbove, moveBelow, pack, pack, print, redraw, removeControlListener, removeDragDetectListener, removeFocusListener, removeGestureListener, removeHelpListener, removeKeyListener, removeMenuDetectListener, removeMouseListener, removeMouseMoveListener, removeMouseTrackListener, removeMouseWheelListener, removePaintListener, removeTouchListener, removeTraverseListener, requestLayout, setBackground, setBackgroundImage, setBounds, setBounds, setCapture, setCursor, setDragDetect, setEnabled, setFont, setForeground, setLayoutData, setLocation, setLocation, setMenu, setOrientation, setParent, setRedraw, setRegion, setSize, setSize, setTextDirection, setToolTipText, setTouchEnabled, setVisible, toControl, toControl, toDisplay, toDisplay, traverse, traverse, traverse, update
Methods inherited from class org.eclipse.swt.widgets.Widget
addDisposeListener, addListener, checkWidget, getData, getData, getDisplay, getListeners, getStyle, isAutoDirection, isDisposed, isListening, notifyListeners, removeDisposeListener, removeListener, removeListener, reskin, setData, setData
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
Methods inherited from interface org.eclipse.swt.graphics.Drawable
isAutoScalable
Methods inherited from interface com.iizigo.prop.IPropertyEditorController
isDisposed
Methods inherited from interface com.iizix.prop.IPropUndoRedo
getShell
Constructor Details
ServerConfigComposite
public ServerConfigComposite(IWorkbenchPart part, Composite parent, IMemento restoreMemento, Runnable saveChangedCallback) Creates the Server configuration composite.- Parameters:
part
- The workbench part, or null for none.parent
- The parent composite.restoreMemento
- The restore memento, or null for none.saveChangedCallback
- Callback when dirty changed and save is required.
Method Details
dispose
public void dispose()Disposes of this composite.getServerConfigFile
Gets the Server Configuration file instance.- Returns:
- The current configuration file, or null for none.
getSettings
Gets the settings.- Returns:
- The current Server settings, or null for none.
setServerConfigFile
Sets or clears the Server configuration file to edit.- Parameters:
config
- The configuration, or null for none (loadException
may indicate the error).loadException
- The load exception that occurred, null whenconfig
is non-null.
onServerConfigFileUpdated
Called when a change has been made somehow and/or the property tree has been verified for errors.- Specified by:
onServerConfigFileUpdated
in interfaceIServerConfigFileListener
- Parameters:
serverConfigFile
- The configuration file that was updated, changed or verified.
isDirty
public boolean isDirty()Gets the dirty state.- Returns:
- true if file needs saving, false if not dirty.
saveState
Saves the state.createControls
public void createControls()Creates the view part.updateStates
public void updateStates()Updates the states of menu items and tool bars.- Specified by:
updateStates
in interfaceIPropUndoRedo
selectionChanged
Notifies that the selection has changed.- Specified by:
selectionChanged
in interfaceISelectionChangedListener
- Parameters:
event
- event object describing the change
getSelectionEnabler
Gets the selection enabler instance.getUndoContext
Gets the undo context.- Specified by:
getUndoContext
in interfaceIPropertyEditorController
- Specified by:
getUndoContext
in interfaceIPropUndoRedo
- Returns:
- An object castable to org.eclipse.core.commands.operations.IUndoContext.
setTargetViewer
Sets the structured viewer (common, tree or table) used for the property operation (add, delete, etc).- Specified by:
setTargetViewer
in interfaceIPropUndoRedo
- Parameters:
viewer
- The CommonViewer, TreeViewer or TableViewer, or null for none.
getUndoRedo
Gets the undo/redo instance.- Specified by:
getUndoRedo
in interfaceIPropertyEditorController
onDragBegin
protected void onDragBegin()Drag started.onDragEnd
protected void onDragEnd()Drag finished.isDragging
public boolean isDragging()Flag for dragging to postpone selection events until drag completes.- Specified by:
isDragging
in interfaceIDraggingFix
getModuleModel
Gets the ModuleModel instance of the project.- Specified by:
getModuleModel
in interfaceIPropertyEditorController
getMultiSelectionProvider
Gets the multi-property selection provider.- Specified by:
getMultiSelectionProvider
in interfaceIPropertyEditorController
getTargetViewer
Gets the structured viewer (common, tree or table) used for the property operation (add, delete, etc).- Specified by:
getTargetViewer
in interfaceIPropUndoRedo
- Returns:
- The CommonViewer, TreeViewer or TableViewer, or null for none.
setBlockViewerFocus
public void setBlockViewerFocus(boolean block) Blocks the target viewer from focus.- Specified by:
setBlockViewerFocus
in interfaceIPropertyEditorController
setPropertyError
Sets a property error. The undo/redo functionality will wrap an undo/redo action for this function.- Specified by:
setPropertyError
in interfaceIPropertyEditorController
removePropertyValue
Removes a property when undefined in the editors. The undo/redo functionality will wrap an undo/redo action for this function.- Specified by:
removePropertyValue
in interfaceIPropertyEditorController
setPropertyAttrFlag
Sets a property attribute flag. The undo/redo functionality will wrap an undo/redo action for this function.- Specified by:
setPropertyAttrFlag
in interfaceIPropertyEditorController
setPropertyValue
Sets a property value. The undo/redo functionality will wrap an undo/redo action for this function. This method handles setting a property value that is extended in the parent and the new property is to replace it in the parent.- Specified by:
setPropertyValue
in interfaceIPropertyEditorController
doSave
Saves the contents if required.- Parameters:
monitor
- the progress monitor
addErrorComposite
Adds an error composite for presentation of the errors. The layout is added to the composite. It is also assumed that the error composite has the GridData layout data.onEvent
Called to process an event.- Specified by:
onEvent
in interfaceEventListener
- Parameters:
event
- The event.