/*
* Copyright (c) 2012 Data Harmonisation Panel
*
* All rights reserved. This program and the accompanying materials are made
* available 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.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution. If not, see <http://www.gnu.org/licenses/>.
*
* Contributors:
* HUMBOLDT EU Integrated Project #030962
* Data Harmonisation Panel <http://www.dhpanel.eu>
*/
package eu.esdihumboldt.hale.ui.views.tasks.model.impl;
import java.util.HashMap;
import java.util.Map;
import eu.esdihumboldt.hale.ui.views.tasks.model.ServiceProvider;
import eu.esdihumboldt.hale.ui.views.tasks.model.TaskFactory;
import eu.esdihumboldt.hale.ui.views.tasks.model.TaskProvider;
import eu.esdihumboldt.hale.ui.views.tasks.model.TaskRegistry;
import eu.esdihumboldt.hale.ui.views.tasks.service.TaskService;
/**
* Abstract task provider
*
* @author Simon Templer
* @partner 01 / Fraunhofer Institute for Computer Graphics Research
*/
public abstract class AbstractTaskProvider implements TaskProvider {
private boolean active = false;
private final String typePrefix;
/**
* The service provider, it is first set in {@link #activate(TaskService, ServiceProvider)}
*/
protected ServiceProvider serviceProvider;
/**
* The task service
*/
protected TaskService taskService;
private final Map<String, TaskFactory> factories = new HashMap<String, TaskFactory>();
/**
* Create a new task provider
*
* @param typePrefix the type name prefix
*/
public AbstractTaskProvider(String typePrefix) {
super();
this.typePrefix = typePrefix;
}
/**
* Add a task factory. It must be added before {@link #registerTaskTypes(TaskRegistry)}
* is called (e.g in the constructor)
*
* @param factory the factory to add
*/
protected void addFactory(TaskFactory factory) {
factory.setTypeNamePrefix(typePrefix);
factories.put(factory.getTaskType().getName(), factory);
}
/**
* Get the factory for the given type name
*
* @param typeName the type name
*
* @return the task factory or <code>null</code>
*/
protected TaskFactory getFactory(String typeName) {
return factories.get(typeName);
}
/**
* @see TaskProvider#registerTaskTypes(TaskRegistry)
*/
@Override
public void registerTaskTypes(TaskRegistry taskRegistry) {
for (TaskFactory factory : factories.values()) {
taskRegistry.registerType(factory.getTaskType());
}
}
/**
* @see TaskProvider#activate(TaskService, ServiceProvider)
*/
@Override
public void activate(TaskService taskService,
ServiceProvider serviceProvider) {
this.serviceProvider = serviceProvider;
this.taskService = taskService;
if (!active) {
active = true;
doActivate(taskService);
}
}
/**
* Initialize the task provider. This method is called after registering
* the task types
*
* @param taskService the task service
*/
protected abstract void doActivate(TaskService taskService);
/**
* @see TaskProvider#deactivate()
*/
@Override
public void deactivate() {
if (active) {
active = false;
doDeactivate();
// remove tasks that were created by this task provider (by type)
for (String type : factories.keySet()) {
taskService.removeTasks(type);
}
}
}
/**
* Clean up the task provider. This method is called when the task provider
* is deactivated
*/
protected abstract void doDeactivate();
/**
* @see TaskProvider#isActive()
*/
@Override
public boolean isActive() {
return active;
}
}