/* AWE - Amanzi Wireless Explorer
* http://awe.amanzi.org
* (C) 2008-2009, AmanziTel AB
*
* This library is provided under the terms of the Eclipse Public License
* as described at http://www.eclipse.org/legal/epl-v10.html. Any use,
* reproduction or distribution of the library constitutes recipient's
* acceptance of this agreement.
*
* This library is distributed WITHOUT ANY WARRANTY; without even the
* implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
*/
package org.amanzi.awe.ui.project;
import org.amanzi.awe.ui.AWEUIPlugin;
import org.amanzi.awe.ui.events.IEvent;
import org.amanzi.awe.ui.events.impl.ProjectNameChangedEvent;
import org.amanzi.awe.ui.listener.IAWEEventListenter;
import org.amanzi.awe.ui.manager.AWEEventManager;
import org.amanzi.neo.models.exceptions.ModelException;
import org.amanzi.neo.models.project.IProjectModel;
import org.amanzi.neo.providers.IProjectModelProvider;
import org.apache.log4j.Logger;
/**
* TODO Purpose of
* <p>
* </p>
*
* @author Nikolay Lagutko (nikolay.lagutko@amanzitel.com)
* @since 1.0.0
*/
public class ProjectChangedListener implements IAWEEventListenter {
private static final Logger LOGGER = Logger.getLogger(ProjectChangedListener.class);
private IProjectModelProvider projectModelProvider;
public ProjectChangedListener() {
}
protected ProjectChangedListener(final IProjectModelProvider projectModelProvider) {
this.projectModelProvider = projectModelProvider;
}
protected IProjectModelProvider getProjectModelProvider() {
if (projectModelProvider == null) {
projectModelProvider = AWEUIPlugin.getDefault().getProjectModelProvider();
}
return projectModelProvider;
}
@Override
public void onEvent(final IEvent event) {
switch (event.getStatus()) {
case PROJECT_CHANGED:
if (event instanceof ProjectNameChangedEvent) {
onProjectChangedEvent((ProjectNameChangedEvent)event);
}
break;
default:
// do nothing
break;
}
}
private void onProjectChangedEvent(final ProjectNameChangedEvent event) {
String name = event.getNewProjectName();
try {
IProjectModel projectModel = getProjectModelProvider().findProjectByName(name);
if (projectModel == null) {
projectModel = getProjectModelProvider().createProjectModel(name);
AWEEventManager.getManager().fireDataUpdatedEvent(this);
}
getProjectModelProvider().setActiveProjectModel(projectModel);
} catch (ModelException e) {
LOGGER.error("Error on switching active UDIG Proejct", e);
}
}
@Override
public Priority getPriority() {
return Priority.HIGH;
}
}