
xdev.ui.ganttchart.action.GanttRelationController Maven / Gradle / Ivy
package xdev.ui.ganttchart.action;
/*-
* #%L
* XDEV BI Suite
* %%
* Copyright (C) 2011 - 2021 XDEV Software
* %%
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Lesser Public License for more details.
*
* You should have received a copy of the GNU General Lesser Public
* License along with this program. If not, see
* .
* #L%
*/
import xdev.ui.ganttchart.UpdateableGanttEntry;
import xdev.ui.ganttchart.template.RelationalGanttTemplate;
import com.jidesoft.gantt.GanttEntry;
import com.jidesoft.gantt.GanttEntryRelation;
import com.jidesoft.gantt.GanttEntryRelationModel;
/**
* Relation controller either for simple connection without logic, or with
* connection compatibility check.
*
*
* @param
* the gantt data type, for example Date
or
* Integer
.
*
* Used for entry scaling via {@link GanttEntry#getRange()}
*
*
*
* @param
* the customized {@link GanttEntry} type.
*
* @author XDEV Software jwill
* @since 4.0
*/
public interface GanttRelationController>
{
/**
* Handles the propper deletion of the given {@link GanttEntry}.
*
* @param entry
* the {@link GanttEntry} to delete.
*/
public void removeEntryRelation(GanttEntryRelation relation);
/**
* Handles the propper insertion of the given {@link GanttEntry}.
*
* @param entry
* the {@link GanttEntry} to insert.
*/
public void insertEntryRelation(GanttEntryRelation relation);
/**
* Set the {@link GanttRelationValidationStrategy} to use for validation
* error notification.
*
* @param strategy
* the strategy to use to notify if the validation of the
* upcoming relation failed.
*/
public void setRelationValidationStrategy(GanttRelationValidationStrategy strategy);
/**
* Returns the {@link GanttRelationValidationStrategy} used for validation
* error notifying.
*
* The default strategy is {@link UIRelationManagementStrategy}.
*
*
* @return the previously set {@link GanttRelationValidationStrategy}.
*/
public GanttRelationValidationStrategy getRelationValidationStrategy();
public class DefaultGanttRelationController> implements
GanttRelationController
{
private final RelationalGanttTemplate template;
/**
*
* @param model
* the {@link GanttEntryRelationModel} to register the
* upcoming relations.
*/
public DefaultGanttRelationController(RelationalGanttTemplate template)
{
this.template = template;
}
@Override
public void setRelationValidationStrategy(
GanttRelationValidationStrategy relationValidationStrategy)
{
}
@Override
public GanttRelationValidationStrategy getRelationValidationStrategy()
{
return null;
}
@Override
public void removeEntryRelation(GanttEntryRelation relation)
{
if(this.template.getGanttRelationPersistence() != null)
{
this.template.getGanttRelationPersistence().removeRelation(relation);
}
}
@Override
public void insertEntryRelation(GanttEntryRelation relation)
{
if(this.template.getGanttRelationPersistence() != null)
{
this.template.getGanttRelationPersistence().addRelation(relation);
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy