Skip to main content
summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/parts/MultiInputPort2EditPart.java')
-rw-r--r--org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/parts/MultiInputPort2EditPart.java408
1 files changed, 408 insertions, 0 deletions
diff --git a/org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/parts/MultiInputPort2EditPart.java b/org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/parts/MultiInputPort2EditPart.java
new file mode 100644
index 0000000..8e0f651
--- /dev/null
+++ b/org.eclipse.emf.refactor.comrel.diagram/src/comrel/diagram/edit/parts/MultiInputPort2EditPart.java
@@ -0,0 +1,408 @@
+/*
+ *
+ */
+package comrel.diagram.edit.parts;
+
+import java.util.ArrayList;
+import java.util.Collections;
+import java.util.LinkedList;
+import java.util.List;
+
+import org.eclipse.draw2d.IFigure;
+import org.eclipse.draw2d.MarginBorder;
+import org.eclipse.draw2d.PositionConstants;
+import org.eclipse.draw2d.RectangleFigure;
+import org.eclipse.draw2d.Shape;
+import org.eclipse.draw2d.StackLayout;
+import org.eclipse.draw2d.geometry.Dimension;
+import org.eclipse.gef.EditPart;
+import org.eclipse.gef.EditPolicy;
+import org.eclipse.gef.GraphicalEditPart;
+import org.eclipse.gef.Request;
+import org.eclipse.gef.commands.Command;
+import org.eclipse.gef.editpolicies.LayoutEditPolicy;
+import org.eclipse.gef.editpolicies.NonResizableEditPolicy;
+import org.eclipse.gef.handles.MoveHandle;
+import org.eclipse.gef.requests.CreateRequest;
+import org.eclipse.gmf.runtime.diagram.ui.editparts.BorderedBorderItemEditPart;
+import org.eclipse.gmf.runtime.diagram.ui.editparts.IBorderItemEditPart;
+import org.eclipse.gmf.runtime.diagram.ui.editparts.IGraphicalEditPart;
+import org.eclipse.gmf.runtime.diagram.ui.editpolicies.BorderItemSelectionEditPolicy;
+import org.eclipse.gmf.runtime.diagram.ui.editpolicies.EditPolicyRoles;
+import org.eclipse.gmf.runtime.diagram.ui.figures.BorderItemLocator;
+import org.eclipse.gmf.runtime.draw2d.ui.figures.WrappingLabel;
+import org.eclipse.gmf.runtime.emf.type.core.IElementType;
+import org.eclipse.gmf.runtime.gef.ui.figures.DefaultSizeNodeFigure;
+import org.eclipse.gmf.runtime.gef.ui.figures.NodeFigure;
+import org.eclipse.gmf.runtime.notation.View;
+import org.eclipse.swt.graphics.Color;
+
+import comrel.InputPort;
+import comrel.diagram.edit.parts.MultiInputPort8EditPart.MultiInputPortFigure;
+import comrel.diagram.edit.policies.MultiInputPort2ItemSemanticEditPolicy;
+import comrel.diagram.part.ComrelVisualIDRegistry;
+import comrel.diagram.providers.ComrelElementTypes;
+import comrel.figures.InputPortFigure;
+
+/**
+ * @generated
+ */
+public class MultiInputPort2EditPart extends BorderedBorderItemEditPart {
+
+ /**
+ * @generated
+ */
+ public static final int VISUAL_ID = 3006;
+
+ /**
+ * @generated
+ */
+ protected IFigure contentPane;
+
+ /**
+ * @generated
+ */
+ protected IFigure primaryShape;
+
+ /**
+ * @generated
+ */
+ public MultiInputPort2EditPart(View view) {
+ super(view);
+ }
+
+ /**
+ * @generated
+ */
+ protected void createDefaultEditPolicies() {
+ super.createDefaultEditPolicies();
+ installEditPolicy(EditPolicy.PRIMARY_DRAG_ROLE,
+ getPrimaryDragEditPolicy());
+ installEditPolicy(EditPolicyRoles.SEMANTIC_ROLE,
+ new MultiInputPort2ItemSemanticEditPolicy());
+ installEditPolicy(EditPolicy.LAYOUT_ROLE, createLayoutEditPolicy());
+ // XXX need an SCR to runtime to have another abstract superclass that would let children add reasonable editpolicies
+ // removeEditPolicy(org.eclipse.gmf.runtime.diagram.ui.editpolicies.EditPolicyRoles.CONNECTION_HANDLES_ROLE);
+ }
+
+ /**
+ * @generated
+ */
+ protected LayoutEditPolicy createLayoutEditPolicy() {
+ org.eclipse.gmf.runtime.diagram.ui.editpolicies.LayoutEditPolicy lep = new org.eclipse.gmf.runtime.diagram.ui.editpolicies.LayoutEditPolicy() {
+
+ protected EditPolicy createChildEditPolicy(EditPart child) {
+ View childView = (View) child.getModel();
+ switch (ComrelVisualIDRegistry.getVisualID(childView)) {
+ case MultiInputPortNameType2EditPart.VISUAL_ID:
+ return new BorderItemSelectionEditPolicy() {
+
+ protected List createSelectionHandles() {
+ MoveHandle mh = new MoveHandle(
+ (GraphicalEditPart) getHost());
+ mh.setBorder(null);
+ return Collections.singletonList(mh);
+ }
+ };
+ }
+ EditPolicy result = child
+ .getEditPolicy(EditPolicy.PRIMARY_DRAG_ROLE);
+ if (result == null) {
+ result = new NonResizableEditPolicy();
+ }
+ return result;
+ }
+
+ protected Command getMoveChildrenCommand(Request request) {
+ return null;
+ }
+
+ protected Command getCreateCommand(CreateRequest request) {
+ return null;
+ }
+ };
+ return lep;
+ }
+
+ /**
+ * @generated NOT
+ */
+ protected IFigure createNodeShape() {
+ MultiInputPortFigure figure = new MultiInputPortFigure();
+ InputPort port = (InputPort) this.resolveSemanticElement();
+ figure.setPort(port);
+ return primaryShape = figure;
+ }
+
+ /**
+ * @generated
+ */
+ public MultiInputPortFigure getPrimaryShape() {
+ return (MultiInputPortFigure) primaryShape;
+ }
+
+ /**
+ * @generated
+ */
+ protected void addBorderItem(IFigure borderItemContainer,
+ IBorderItemEditPart borderItemEditPart) {
+ if (borderItemEditPart instanceof MultiInputPortNameType2EditPart) {
+ BorderItemLocator locator = new BorderItemLocator(getMainFigure(),
+ PositionConstants.SOUTH);
+ locator.setBorderItemOffset(new Dimension(-20, -20));
+ borderItemContainer.add(borderItemEditPart.getFigure(), locator);
+ } else {
+ super.addBorderItem(borderItemContainer, borderItemEditPart);
+ }
+ }
+
+ /**
+ * @generated
+ */
+ protected NodeFigure createNodePlate() {
+ DefaultSizeNodeFigure result = new DefaultSizeNodeFigure(20, 20);
+
+ //FIXME: workaround for #154536
+ result.getBounds().setSize(result.getPreferredSize());
+ return result;
+ }
+
+ /**
+ * Creates figure for this edit part.
+ *
+ * Body of this method does not depend on settings in generation model
+ * so you may safely remove <i>generated</i> tag and modify it.
+ *
+ * @generated
+ */
+ protected NodeFigure createMainFigure() {
+ NodeFigure figure = createNodePlate();
+ figure.setLayoutManager(new StackLayout());
+ IFigure shape = createNodeShape();
+ figure.add(shape);
+ contentPane = setupContentPane(shape);
+ return figure;
+ }
+
+ /**
+ * Default implementation treats passed figure as content pane.
+ * Respects layout one may have set for generated figure.
+ * @param nodeShape instance of generated figure class
+ * @generated
+ */
+ protected IFigure setupContentPane(IFigure nodeShape) {
+ return nodeShape; // use nodeShape itself as contentPane
+ }
+
+ /**
+ * @generated
+ */
+ public IFigure getContentPane() {
+ if (contentPane != null) {
+ return contentPane;
+ }
+ return super.getContentPane();
+ }
+
+ /**
+ * @generated
+ */
+ protected void setForegroundColor(Color color) {
+ if (primaryShape != null) {
+ primaryShape.setForegroundColor(color);
+ }
+ }
+
+ /**
+ * @generated
+ */
+ protected void setBackgroundColor(Color color) {
+ if (primaryShape != null) {
+ primaryShape.setBackgroundColor(color);
+ }
+ }
+
+ /**
+ * @generated
+ */
+ protected void setLineWidth(int width) {
+ if (primaryShape instanceof Shape) {
+ ((Shape) primaryShape).setLineWidth(width);
+ }
+ }
+
+ /**
+ * @generated
+ */
+ protected void setLineType(int style) {
+ if (primaryShape instanceof Shape) {
+ ((Shape) primaryShape).setLineStyle(style);
+ }
+ }
+
+ /**
+ * @generated
+ */
+ public EditPart getPrimaryChildEditPart() {
+ return getChildBySemanticHint(ComrelVisualIDRegistry
+ .getType(MultiInputPortNameType2EditPart.VISUAL_ID));
+ }
+
+ /**
+ * @generated
+ */
+ public List<IElementType> getMARelTypesOnSource() {
+ ArrayList<IElementType> types = new ArrayList<IElementType>(2);
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ return types;
+ }
+
+ /**
+ * @generated
+ */
+ public List<IElementType> getMARelTypesOnSourceAndTarget(
+ IGraphicalEditPart targetEditPart) {
+ LinkedList<IElementType> types = new LinkedList<IElementType>();
+ if (targetEditPart instanceof MultiInputPortEditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof comrel.diagram.edit.parts.MultiInputPort2EditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof MultiInputPort3EditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof MultiInputPort4EditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof MultiInputPort5EditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof MultiInputPort6EditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof MultiInputPort7EditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof MultiInputPort8EditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof MultiInputPort9EditPart) {
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ }
+ if (targetEditPart instanceof SingleInputPortEditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ if (targetEditPart instanceof SingleInputPort2EditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ if (targetEditPart instanceof SingleInputPort3EditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ if (targetEditPart instanceof SingleInputPort4EditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ if (targetEditPart instanceof SingleInputPort5EditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ if (targetEditPart instanceof SingleInputPort6EditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ if (targetEditPart instanceof SingleInputPort7EditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ if (targetEditPart instanceof SingleInputPort8EditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ if (targetEditPart instanceof SingleInputPort9EditPart) {
+ types.add(ComrelElementTypes.MultiSinglePortMapping_4003);
+ }
+ return types;
+ }
+
+ /**
+ * @generated
+ */
+ public List<IElementType> getMATypesForTarget(IElementType relationshipType) {
+ LinkedList<IElementType> types = new LinkedList<IElementType>();
+ if (relationshipType == ComrelElementTypes.MultiPortMapping_4002) {
+ types.add(ComrelElementTypes.MultiInputPort_3002);
+ types.add(ComrelElementTypes.MultiInputPort_3006);
+ types.add(ComrelElementTypes.MultiInputPort_3010);
+ types.add(ComrelElementTypes.MultiInputPort_3014);
+ types.add(ComrelElementTypes.MultiInputPort_3017);
+ types.add(ComrelElementTypes.MultiInputPort_3020);
+ types.add(ComrelElementTypes.MultiInputPort_3024);
+ types.add(ComrelElementTypes.MultiInputPort_3028);
+ types.add(ComrelElementTypes.MultiInputPort_3032);
+ } else if (relationshipType == ComrelElementTypes.MultiSinglePortMapping_4003) {
+ types.add(ComrelElementTypes.SingleInputPort_2001);
+ types.add(ComrelElementTypes.SingleInputPort_3001);
+ types.add(ComrelElementTypes.SingleInputPort_3005);
+ types.add(ComrelElementTypes.SingleInputPort_3009);
+ types.add(ComrelElementTypes.SingleInputPort_3013);
+ types.add(ComrelElementTypes.SingleInputPort_3023);
+ types.add(ComrelElementTypes.SingleInputPort_3027);
+ types.add(ComrelElementTypes.SingleInputPort_3031);
+ types.add(ComrelElementTypes.SingleInputPort_3035);
+ }
+ return types;
+ }
+
+ /**
+ * @generated
+ */
+ public List<IElementType> getMARelTypesOnTarget() {
+ ArrayList<IElementType> types = new ArrayList<IElementType>(1);
+ types.add(ComrelElementTypes.MultiPortMapping_4002);
+ return types;
+ }
+
+ /**
+ * @generated
+ */
+ public List<IElementType> getMATypesForSource(IElementType relationshipType) {
+ LinkedList<IElementType> types = new LinkedList<IElementType>();
+ if (relationshipType == ComrelElementTypes.MultiPortMapping_4002) {
+ types.add(ComrelElementTypes.MultiInputPort_3002);
+ types.add(ComrelElementTypes.MultiInputPort_3006);
+ types.add(ComrelElementTypes.MultiInputPort_3010);
+ types.add(ComrelElementTypes.MultiInputPort_3014);
+ types.add(ComrelElementTypes.MultiOutputPort_3015);
+ types.add(ComrelElementTypes.MultiInputPort_3017);
+ types.add(ComrelElementTypes.MultiInputPort_3020);
+ types.add(ComrelElementTypes.MultiOutputPort_3021);
+ types.add(ComrelElementTypes.MultiInputPort_3024);
+ types.add(ComrelElementTypes.MultiInputPort_3028);
+ types.add(ComrelElementTypes.MultiInputPort_3032);
+ }
+ return types;
+ }
+
+ /**
+ * @generated NOT
+ */
+ public class MultiInputPortFigure extends InputPortFigure {
+
+ /**
+ * @generated
+ */
+ public MultiInputPortFigure() {
+ this.setLineWidth(10);
+ this.setForegroundColor(THIS_FORE);
+ this.setPreferredSize(new Dimension(getMapMode().DPtoLP(20),
+ getMapMode().DPtoLP(20)));
+ this.setBorder(new MarginBorder(getMapMode().DPtoLP(5),
+ getMapMode().DPtoLP(5), getMapMode().DPtoLP(5),
+ getMapMode().DPtoLP(5)));
+ }
+
+ }
+
+ /**
+ * @generated
+ */
+ static final Color THIS_FORE = new Color(null, 255, 0, 0);
+
+}

Back to the top