/*******************************************************************************
* 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.descriptor.relational.MWRelationalDescriptor;
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.PropertyAspectAdapter;
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 to the mapping's reference descriptor
*/
final class ManyToManyTargetReferencePanel
extends AbstractTableReferencePanel
{
ManyToManyTargetReferencePanel(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).candidateRelationTableTargetReferences();
}
/**
* override because we want the "target" reference, not the
* "source" reference
*/
protected PropertyValueModel buildTableReferenceHolder() {
return new PropertyAspectAdapter(this.getSubjectHolder(), MWManyToManyMapping.TARGET_REFERENCE_PROPERTY) {
protected Object getValueFromSubject() {
return ((MWManyToManyMapping) this.subject).getTargetReference();
}
protected void setValueOnSubject(Object value) {
((MWManyToManyMapping) this.subject).setTargetReference((MWReference) value);
}
};
}
/**
* override because we want to set the "target" reference, not the
* "source" reference
*/
protected void setReference(MWReference reference) {
MWManyToManyMapping mapping = this.mapping();
mapping.setTargetReference(reference);
if (mapping.getRelationTable() == null) {
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 "reference" descriptor's tables
*/
protected MWTable defaultNewReferenceTargetTable() {
MWRelationalDescriptor descriptor = (MWRelationalDescriptor) this.mapping().getReferenceDescriptor();
if (descriptor == null) {
return null;
}
Iterator candidateTables = descriptor.candidateTables();
return candidateTables.hasNext() ? (MWTable) candidateTables.next() : null;
}
private MWManyToManyMapping mapping() {
return (MWManyToManyMapping) this.subject();
}
}