diff options
Diffstat (limited to 'jpa/plugins/org.eclipse.jpt.eclipselink.ui/src/org/eclipse/jpt/eclipselink/ui/internal/v1_1/orm/details/OrmEclipseLinkManyToManyMapping1_1Composite.java')
-rw-r--r-- | jpa/plugins/org.eclipse.jpt.eclipselink.ui/src/org/eclipse/jpt/eclipselink/ui/internal/v1_1/orm/details/OrmEclipseLinkManyToManyMapping1_1Composite.java | 106 |
1 files changed, 106 insertions, 0 deletions
diff --git a/jpa/plugins/org.eclipse.jpt.eclipselink.ui/src/org/eclipse/jpt/eclipselink/ui/internal/v1_1/orm/details/OrmEclipseLinkManyToManyMapping1_1Composite.java b/jpa/plugins/org.eclipse.jpt.eclipselink.ui/src/org/eclipse/jpt/eclipselink/ui/internal/v1_1/orm/details/OrmEclipseLinkManyToManyMapping1_1Composite.java new file mode 100644 index 0000000000..b3a69b05d2 --- /dev/null +++ b/jpa/plugins/org.eclipse.jpt.eclipselink.ui/src/org/eclipse/jpt/eclipselink/ui/internal/v1_1/orm/details/OrmEclipseLinkManyToManyMapping1_1Composite.java @@ -0,0 +1,106 @@ +/******************************************************************************* + * Copyright (c) 2009 Oracle. All rights reserved. + * This program and the accompanying materials are made available under the + * terms of the Eclipse Public License v1.0, which accompanies this distribution + * and is available at http://www.eclipse.org/legal/epl-v10.html. + * + * Contributors: + * Oracle - initial API and implementation + ******************************************************************************/ +package org.eclipse.jpt.eclipselink.ui.internal.v1_1.orm.details; + +import org.eclipse.jpt.core.context.AccessHolder; +import org.eclipse.jpt.core.context.ManyToManyMapping; +import org.eclipse.jpt.eclipselink.ui.internal.mappings.details.EclipseLinkManyToManyMappingComposite; +import org.eclipse.jpt.eclipselink.ui.internal.mappings.details.EclipseLinkJoinFetchComposite; +import org.eclipse.jpt.ui.WidgetFactory; +import org.eclipse.jpt.ui.internal.details.AccessTypeComposite; +import org.eclipse.jpt.ui.internal.mappings.details.CascadeComposite; +import org.eclipse.jpt.ui.internal.mappings.details.FetchTypeComposite; +import org.eclipse.jpt.ui.internal.mappings.details.ManyToManyJoiningStrategyPane; +import org.eclipse.jpt.ui.internal.mappings.details.OrderingComposite; +import org.eclipse.jpt.ui.internal.mappings.details.TargetEntityComposite; +import org.eclipse.jpt.utility.internal.model.value.PropertyAspectAdapter; +import org.eclipse.jpt.utility.model.value.PropertyValueModel; +import org.eclipse.swt.widgets.Composite; + +/** + * Here the layout of this pane: + * <pre> + * ----------------------------------------------------------------------------- + * | ------------------------------------------------------------------------- | + * | | | | + * | | TargetEntityComposite | | + * | | | | + * | ------------------------------------------------------------------------- | + * | ------------------------------------------------------------------------- | + * | | | | + * | | JoiningStrategyComposite | | + * | | | | + * | ------------------------------------------------------------------------- | + * | ------------------------------------------------------------------------- | + * | | | | + * | | FetchTypeComposite | | + * | | | | + * | ------------------------------------------------------------------------- | + * | ------------------------------------------------------------------------- | + * | | | | + * | | CascadeComposite | | + * | | | | + * | ------------------------------------------------------------------------- | + * | ------------------------------------------------------------------------- | + * | | | | + * | | OrderingComposite | | + * | | | | + * | ------------------------------------------------------------------------- | + * -----------------------------------------------------------------------------</pre> + * + * @see {@link ManyToManyMapping} + * @see {@link BaseJpaUiFactory} - The factory creating this pane + * @see {@link TargetEntityComposite} + * @see {@link ManyToManyJoiningStrategyPane} + * @see {@link FetchTypeComposite} + * @see {@link CascadeComposite} + * @see {@link OrderingComposite} + * + * @version 2.2 + * @since 2.2 + */ +public class OrmEclipseLinkManyToManyMapping1_1Composite extends EclipseLinkManyToManyMappingComposite +{ + /** + * Creates a new <code>ManyToManyMappingComposite</code>. + * + * @param subjectHolder The holder of the subject <code>IManyToManyMapping</code> + * @param parent The parent container + * @param widgetFactory The factory used to create various common widgets + */ + public OrmEclipseLinkManyToManyMapping1_1Composite(PropertyValueModel<? extends ManyToManyMapping> subjectHolder, + Composite parent, + WidgetFactory widgetFactory) { + + super(subjectHolder, parent, widgetFactory); + } + + @Override + protected void initializeLayout(Composite container) { + int groupBoxMargin = getGroupBoxMargin(); + + new TargetEntityComposite(this, addPane(container, groupBoxMargin)); + new ManyToManyJoiningStrategyPane(this, buildJoiningHolder(), container); + new AccessTypeComposite(this, buildAccessHolderHolder(), addPane(container, groupBoxMargin)); + new FetchTypeComposite(this, addPane(container, groupBoxMargin)); + new EclipseLinkJoinFetchComposite(this, buildJoinFetchableHolder(), addPane(container, groupBoxMargin)); + new CascadeComposite(this, buildCascadeHolder(), addSubPane(container, 5)); + new OrderingComposite(this, container); + } + + protected PropertyValueModel<AccessHolder> buildAccessHolderHolder() { + return new PropertyAspectAdapter<ManyToManyMapping, AccessHolder>(getSubjectHolder()) { + @Override + protected AccessHolder buildValue_() { + return this.subject.getPersistentAttribute(); + } + }; + } +}
\ No newline at end of file |