/******************************************************************************* * Copyright (c) 1998, 2015 Oracle and/or its affiliates. All rights reserved. * This program and the accompanying materials are made available under the * terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0 * which accompanies this distribution. * The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html * and the Eclipse Distribution License is available at * http://www.eclipse.org/org/documents/edl-v10.php. * * Contributors: * Oracle - initial API and implementation from Oracle TopLink ******************************************************************************/ package org.eclipse.persistence.tools.workbench.mappingsplugin.ui.mapping.relational; import java.util.Collections; import java.util.Iterator; import java.util.List; import org.eclipse.persistence.tools.workbench.framework.context.WorkbenchContextHolder; import org.eclipse.persistence.tools.workbench.mappingsmodel.db.MWReference; import org.eclipse.persistence.tools.workbench.mappingsmodel.db.MWTable; import org.eclipse.persistence.tools.workbench.mappingsmodel.mapping.relational.MWManyToManyMapping; import org.eclipse.persistence.tools.workbench.mappingsmodel.mapping.relational.MWTableReferenceMapping; import org.eclipse.persistence.tools.workbench.uitools.app.PropertyValueModel; /** * this is the panel used to pick (and/or build) the reference from the * "relation" table back to the mapping's "parent" descriptor */ final class ManyToManySourceReferencePanel extends AbstractTableReferencePanel { ManyToManySourceReferencePanel(PropertyValueModel subjectHolder, WorkbenchContextHolder contextHolder) { super(subjectHolder, contextHolder); } /** * override because a many-to-many mapping does not have a single * set of candidate references; it has two, in the relation table: * source and target */ protected Iterator candidateReferences(MWTableReferenceMapping mapping) { return ((MWManyToManyMapping) mapping).candidateRelationTableSourceReferences(); } /** * setting the reference on a many-to-many mapping will set the * mapping's "source" reference */ protected void setReference(MWReference reference) { super.setReference(reference); if (this.mapping().getRelationTable() == null) { this.mapping().setRelationTable(reference.getSourceTable()); } } /** * the reference source is the "relation" table */ protected List candidateNewReferenceSourceTables() { MWTable relationTable = this.mapping().getRelationTable(); if (relationTable == null) { return super.candidateNewReferenceSourceTables(); } return Collections.singletonList(relationTable); } /** * the reference source is the "relation" table */ protected MWTable defaultNewReferenceSourceTable() { return this.mapping().getRelationTable(); } /** * the reference target is one of the "parent" descriptor's tables */ protected MWTable defaultNewReferenceTargetTable() { Iterator candidateTables = this.mapping().getParentRelationalDescriptor().candidateTables(); return candidateTables.hasNext() ? (MWTable) candidateTables.next() : null; } private MWManyToManyMapping mapping() { return (MWManyToManyMapping) this.subject(); } }