import java.beans.PropertyChangeListener;\r
\r
import org.apache.log4j.Logger;\r
-import org.eclipse.core.commands.ExecutionException;\r
-import org.eclipse.core.commands.operations.IOperationHistory;\r
import org.eclipse.core.commands.operations.IUndoContext;\r
import org.eclipse.core.commands.operations.IUndoableOperation;\r
import org.eclipse.core.runtime.Assert;\r
-import org.eclipse.core.runtime.IStatus;\r
import org.eclipse.jface.action.Action;\r
+import org.eclipse.swt.SWT;\r
+import org.eclipse.swt.custom.StyledText;\r
import org.eclipse.swt.events.FocusAdapter;\r
import org.eclipse.swt.events.FocusEvent;\r
+import org.eclipse.swt.events.KeyAdapter;\r
+import org.eclipse.swt.events.KeyEvent;\r
+import org.eclipse.swt.graphics.Color;\r
import org.eclipse.swt.graphics.Font;\r
import org.eclipse.swt.graphics.Image;\r
import org.eclipse.swt.widgets.Composite;\r
+import org.eclipse.swt.widgets.Label;\r
import org.eclipse.ui.forms.IManagedForm;\r
+import org.eclipse.ui.forms.widgets.TableWrapData;\r
+import org.eclipse.ui.forms.widgets.TableWrapLayout;\r
import org.eclipse.ui.views.properties.IPropertySource;\r
\r
import eu.etaxonomy.cdm.model.name.BotanicalName;\r
import eu.etaxonomy.cdm.model.taxon.TaxonBase;\r
import eu.etaxonomy.taxeditor.ITaxEditorConstants;\r
import eu.etaxonomy.taxeditor.TaxEditorPlugin;\r
-import eu.etaxonomy.taxeditor.UiUtil;\r
-import eu.etaxonomy.taxeditor.actions.ui.CreateNewHeterotypicCompositeAction;\r
-import eu.etaxonomy.taxeditor.editor.EditorGroupedComposite;\r
+import eu.etaxonomy.taxeditor.controller.EditorController;\r
+import eu.etaxonomy.taxeditor.controller.GlobalController;\r
+import eu.etaxonomy.taxeditor.editor.ContextMenu;\r
+import eu.etaxonomy.taxeditor.editor.GroupedComposite;\r
import eu.etaxonomy.taxeditor.editor.LineBreakListener;\r
import eu.etaxonomy.taxeditor.editor.ParseListener;\r
import eu.etaxonomy.taxeditor.model.CdmUtil;\r
-import eu.etaxonomy.taxeditor.operations.name.ChangeHomotypicGroupOperation;\r
import eu.etaxonomy.taxeditor.operations.name.CreateSynonymInNewGroupOperation;\r
import eu.etaxonomy.taxeditor.propertysheet.name.BotanicalNamePropertySource;\r
import eu.etaxonomy.taxeditor.propertysheet.name.NonViralNamePropertySource;\r
-import eu.etaxonomy.taxeditor.propertysheet.name.TaxonBasePropertySource;\r
import eu.etaxonomy.taxeditor.propertysheet.name.ZoologicalNamePropertySource;\r
\r
/**\r
- * Formats an <code>EditorGroupedComposite</code> to display <code>TaxonNameBase</code> elements\r
+ * Formats an <code>GroupedComposite</code> to display <code>TaxonNameBase</code> elements\r
* in a <code>NameViewer</code>.\r
* \r
- * <code>Composite.getData()</code> returns <code>TaxonBase</code>. Therefore, the method \r
- * <code>setSelection()</code> is overriden to send the property sheet <code>TaxonBase.getName()</code>. \r
- * \r
* @author p.ciardelli\r
* @created 02.06.2008\r
* @version 1.0\r
*/\r
-public class NameComposite extends EditorGroupedComposite {\r
+public abstract class NameComposite extends GroupedComposite {\r
private static final Logger logger = Logger.getLogger(NameComposite.class);\r
\r
/**\r
public static final String HOMOTYPIC_SYNONYM = "homotypic_name_composite";\r
public static final String HETEROTYPIC_SYNONYM = "heterotypic_name_composite";\r
public static final String MISAPPLIED_NAME = "misappliedname_name_composite";\r
+ public static final String CONCEPTRELATION = "concept_name_comcposite";\r
\r
/**\r
* ************ INDENTATIONS ************\r
public static final int ACCEPTED_INDENT = 0;\r
public static final int SYNONYM_INDENT = 15;\r
public static final int MISAPPLIEDNAME_INDENT = 15;\r
+ public static final int CONCEPT_INDENT = 15;\r
\r
/**\r
* ************ FONTS ************\r
.getFont(ITaxEditorConstants.SYNONYM_FONT);\r
public static final Font MISAPPLIEDNAME_FONT = TaxEditorPlugin.getDefault()\r
.getFont(ITaxEditorConstants.MISAPPLIEDNAME_FONT);\r
+ public static final Font CONCEPT_FONT = TaxEditorPlugin.getDefault()\r
+ .getFont(ITaxEditorConstants.CONCEPT_FONT);\r
\r
/**\r
* ************ ICONS ************\r
ITaxEditorConstants.HETEROTYPIC_SYN_ORIGINAL_ICON);\r
public static final Image MISAPPLIEDNAME_ICON = TaxEditorPlugin\r
.getDefault().getImage(ITaxEditorConstants.MISAPPLIED_NAME_ICON);\r
+ public static final Image CONCEPT_ICON = TaxEditorPlugin\r
+ .getDefault().getImage(ITaxEditorConstants.CONCEPT_ICON);\r
public static final Image AUTONYM_ICON = TaxEditorPlugin.getDefault()\r
.getImage(ITaxEditorConstants.AUTONYM_ICON);\r
public static final Image BASIONYM_ICON = TaxEditorPlugin.getDefault()\r
\r
protected boolean isParsing;\r
\r
- private NameViewer nameViewer;\r
+ protected NameViewer nameViewer;\r
\r
/**\r
* The constructor for a DescriptionElementComposite. Takes a parent Composite on which to\r
* @param managedForm\r
*/\r
public NameComposite(Composite parent, IManagedForm managedForm, \r
- String compositeType, TaxonBase data) {\r
+ String compositeType, TaxonBase taxonBase) {\r
super(parent, managedForm);\r
\r
createNameViewer();\r
createBorderSupport();\r
createLineWrapSupport();\r
\r
- setData(data);\r
-// if (compositeType != null) {\r
-// transform(compositeType);\r
-// }\r
-\r
- createParser(); \r
+ setDraggableControl(nameViewer.getRulerControl());\r
+ \r
+ createParser();\r
createEmptyViewerPrompt(EMPTY_NAME_PROMPT);\r
-\r
setFocus();\r
\r
- // NOTE: placing this after setFocus() solved a strange bug where if the first action\r
+ // NOTE: placing this after setFocus() inexplicably solved a strange bug where if the first action\r
// during a session was to open a new taxon, the empty name prompt didn't work\r
- createNameListener(data);\r
+ createNameListener(taxonBase.getName());\r
}\r
\r
+ protected void createContent() {\r
+ setLayoutData(new TableWrapData(TableWrapData.FILL_GRAB));\r
+ TableWrapLayout layout = new TableWrapLayout();\r
+ layout.leftMargin = 0;\r
+ layout.topMargin = 0;\r
+ layout.bottomMargin = 0;\r
+ layout.verticalSpacing = 0;\r
+ setLayout(layout);\r
+ \r
+ Color groupBackgroundColor = TaxEditorPlugin.getDefault().\r
+ getColor(ITaxEditorConstants.GROUP_GRAY_BKG_COLOR);\r
+ setBackground(groupBackgroundColor);\r
+ }\r
+ \r
+ protected String getEmptyTextPrompt() {\r
+ return EMPTY_NAME_PROMPT;\r
+ }\r
+ \r
/**\r
* Listens for changes to this name's <code>fullTitleCache</code>.\r
* \r
* @param data\r
*/\r
- private void createNameListener(TaxonBase taxonBase) {\r
- if (taxonBase.getName() == null) {\r
+ private void createNameListener(final TaxonNameBase name) {\r
+ \r
+ if (name == null) {\r
return;\r
}\r
\r
- final TaxonNameBase name = taxonBase.getName();\r
- \r
final PropertyChangeListener listener = new PropertyChangeListener() {\r
public void propertyChange(PropertyChangeEvent evt) {\r
\r
return;\r
}\r
\r
- if (UiUtil.getIsSaving()) {\r
+ if (EditorController.isSaving()) {\r
return;\r
}\r
\r
reference.addPropertyChangeListener("titleCache", listener);\r
}\r
}\r
-\r
- /**\r
- * Override of Composite.setData() which passes data along to\r
- * <code>NameComposite</code>'s <code>TextViewer</code> where appropriate.\r
- * \r
- * @see org.eclipse.swt.widgets.Widget#setData(java.lang.Object)\r
- */\r
- public void setData(Object data) {\r
- super.setData(data);\r
- \r
- Assert.isTrue((data instanceof TaxonBase), \r
- "NameComposite's data field must contain a TaxonBase object");\r
- \r
- String text = CdmUtil.getDisplayNameAndRef((TaxonBase) data);\r
- getTextViewer().getTextWidget().setText(text);\r
-\r
- if (getTextViewer() instanceof NameViewer) {\r
- ((NameViewer) getTextViewer()).setCursorToEOL();\r
-\r
- TaxonNameBase name = ((TaxonBase) data).getName();\r
- if (name != null) {\r
+ \r
+ protected void initNameViewer(TaxonBase taxonBase) {\r
+ String text = CdmUtil.getDisplayNameWithRef(taxonBase);\r
+ if (text.length() == 0) {\r
+ initEmptyText();\r
+ } else {\r
+ getTextViewer().getTextWidget().setText(text);\r
+\r
+ if (getTextViewer() instanceof NameViewer) {\r
\r
- boolean hasProblem = name.getHasProblem();\r
- ((NameViewer) getTextViewer()).setShowError(name);\r
+ ((NameViewer) getTextViewer()).setCursorToEOL();\r
+\r
+ TaxonNameBase name = taxonBase.getName();\r
+ if (name != null) { \r
+ calculateErrors();\r
+ }\r
}\r
}\r
- \r
+ activateParser();\r
}\r
-\r
+ \r
private void createParser() {\r
- ((NameViewer) getTextViewer()).setParseListener(new ParseListener() {\r
+ ((NameViewer) getTextViewer()).addParseListener(new ParseListener() {\r
\r
@Override\r
public void parse(String text) {\r
\r
// Let others know the parser is active\r
isParsing = true;\r
- \r
- // Get the name from the composite's data field\r
- TaxonBase taxonBase = (TaxonBase) getData();\r
- NonViralName nonViralName = (NonViralName) taxonBase.getName();\r
- \r
+ \r
// Parse the name and paint the text field w any errors\r
- if (nonViralName != null) {\r
- CdmParserController.parseFullReference(nonViralName, text);\r
- ((NameViewer) getTextViewer()).setShowError(nonViralName);\r
+ if (getName() != null) {\r
+ CdmParserController.parseFullReference((NonViralName) getName(), text);\r
}\r
\r
// Any entry of text means the taxon has been changed\r
\r
// The parser is no longer active\r
isParsing = false;\r
-\r
+ \r
// Manually refresh the property sheet to reflect changes\r
- UiUtil.getPropertySheetPage().refresh();\r
+ setSelection();\r
+ \r
+ // Show any errors in the name viewer\r
+ calculateErrors();\r
}\r
});\r
- activateParser();\r
}\r
\r
public void activateParser() {\r
isUseParser = false;\r
}\r
\r
+ protected abstract TaxonNameBase getName();\r
+ \r
+ protected void calculateErrors() {\r
+ \r
+ nameViewer.clearErrors();\r
+ \r
+ nameViewer.setShowParsingError(getName());\r
+ \r
+ }\r
+ \r
private NameViewer createNameViewer() {\r
-// nameViewer = new NameViewer(this);\r
+ \r
+ nameViewer = new NameViewer(this);\r
+ \r
+ StyledText styledText = nameViewer.getTextWidget();\r
// nameViewer.setLineBreakListener(new LineBreakListener() {\r
\r
- setTextViewer(new NameViewer(this));\r
- getTextViewer().setLineBreakListener(new LineBreakListener() {\r
+ setTextViewer(nameViewer);\r
+ \r
+ nameViewer.addLineBreakListener(new LineBreakListener() {\r
\r
@Override\r
public void handleSplitText(String text) {\r
-\r
- Composite parent = getParent();\r
- final Composite grandParent = parent.getParent();\r
-\r
-// new CreateNewHeterotypicCompositeAction(text, managedForm)\r
-// .run();\r
\r
- IOperationHistory operationHistory = UiUtil.getOperationHistory();\r
- IUndoContext undoContext = UiUtil.getTaxonNameEditorUndoContext(taxon);\r
+ // Create a synonym in a new homotypic group using text as name\r
+ IUndoContext undoContext = EditorController.getUndoContext(taxon);\r
IUndoableOperation operation = new CreateSynonymInNewGroupOperation\r
("new heterotypic synonym", undoContext, taxon, text); //$NON-NLS-1$\r
+// setOperation(new CreateSynonymInNewGroupOperation\r
\r
- try {\r
- IStatus status = operationHistory.execute(operation, null, null);\r
- } catch (ExecutionException e) {\r
- // TODO Auto-generated catch block\r
- e.printStackTrace();\r
- }\r
-\r
- // setDirty(true);\r
+ GlobalController.executeOperation(operation);\r
+// getTextViewer().removeLineBreakListener(this);\r
}\r
\r
});\r
\r
- getTextViewer().getTextWidget().addFocusListener(new FocusAdapter() {\r
+// styledText.addKeyListener(new KeyAdapter(){\r
+//\r
+// @Override\r
+// public void keyReleased(KeyEvent e) {\r
+// if (operation != null) {\r
+// GlobalController.executeOperation(operation);\r
+// operation = null;\r
+// }\r
+// }\r
+// \r
+// });\r
+ \r
+ styledText.addFocusListener(new FocusAdapter() {\r
public void focusGained(FocusEvent e) {\r
setFocus();\r
}\r
});\r
-\r
+ \r
// createLineWrapSupport(nameViewer);\r
-\r
- getTextViewer().getTextWidget().setBackground(TaxEditorPlugin.getDefault().\r
- getColor(ITaxEditorConstants.GROUP_GRAY_BKG_COLOR)); \r
+ \r
\r
- return (NameViewer) getTextViewer();\r
+ return nameViewer;\r
}\r
\r
+// IUndoableOperation operation;\r
+\r
+ private Label nonEditableInfo;\r
+ \r
+// protected void setOperation(IUndoableOperation operation) {\r
+// this.operation = operation;\r
+// }\r
+\r
public void setText(String text) {\r
Assert.isNotNull(getTextViewer(), \r
"Cannot set text for a TextViewer that has not yet been initialized.");\r
getTextViewer().getDocument().set(text);\r
}\r
\r
+ public void setNonEditableInfo(String info) {\r
+ if (nonEditableInfo == null) {\r
+ nonEditableInfo = new Label(this, SWT.WRAP);\r
+ nonEditableInfo.setLayoutData(new TableWrapData(TableWrapData.FILL_GRAB, TableWrapData.TOP));\r
+ } else {\r
+ info = nonEditableInfo.getText() + ", " + info;\r
+ }\r
+ nonEditableInfo.setText(info.toUpperCase());\r
+ }\r
+ \r
public NameViewer getTextViewer() {\r
return this.nameViewer;\r
}\r
public void setTextViewer(NameViewer textViewer) {\r
this.nameViewer = textViewer;\r
}\r
-\r
- public IPropertySource getPropertySource() {\r
- \r
- // Property source for misapplied name\r
- if (MISAPPLIED_NAME.equals(compositeType)) {\r
- return new TaxonBasePropertySource((TaxonBase) getData());\r
+ \r
+ public void createBorderSupport() {\r
+ super.createBorderSupport();\r
+ if (nameViewer != null) {\r
+ borderDecorator.setBorderedComposite(nameViewer.getTextWidget());\r
}\r
- \r
- // Get name info out of composite data\r
- TaxonBase taxon = (TaxonBase) getData();\r
- if (taxon == null) {\r
- return null;\r
+ }\r
+ \r
+ public void setIcon(Image icon) {\r
+ if (nameViewer != null) {\r
+ nameViewer.setIcon(icon);\r
}\r
- TaxonNameBase name = taxon.getName();\r
+ }\r
+ \r
+ protected IPropertySource getPropertySourceByName(TaxonNameBase name) {\r
if (name == null) {\r
return null;\r
}\r
\r
- // Property sources for names\r
if (name.getClass() == BotanicalName.class) {\r
return new BotanicalNamePropertySource((BotanicalName) name);\r
}\r
\r
return null;\r
}\r
+ \r
+ protected ContextMenu createContextMenu() {\r
+ if (nameViewer != null) {\r
+ ContextMenu contextMenu = new ContextMenu(nameViewer.getRulerControl());\r
+ nameViewer.getTextWidget().setMenu(contextMenu.getMenu());\r
+ return contextMenu;\r
+ } else {\r
+ logger.warn("Can't create menu because nameViewer has not been initalized.");\r
+ return null;\r
+ }\r
+ }\r
}
\ No newline at end of file