/*
* Copyright (C) 2010 Interactive Media Management
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU 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 Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package dk.i2m.converge.jsf.converters;
import dk.i2m.converge.core.content.weather.Situation;
import dk.i2m.converge.ejb.facades.ListingFacadeLocal;
import dk.i2m.converge.core.DataNotFoundException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.faces.component.UIComponent;
import javax.faces.context.FacesContext;
import javax.faces.convert.Converter;
/**
*
* @author Allan Lykke Christensen
*/
public class WeatherSituationConverter implements Converter {
private static final Logger LOG = Logger.getLogger(WeatherSituationConverter.class.getName());
private final ListingFacadeLocal facade;
public WeatherSituationConverter(ListingFacadeLocal facade) {
this.facade = facade;
}
@Override
public Object getAsObject(FacesContext ctx, UIComponent component, String value) {
if (value == null) {
return null;
}
try {
return facade.findWeatherSituationById(Long.valueOf(value));
} catch (DataNotFoundException ex) {
LOG.log(Level.WARNING, "No matching weather situation", ex);
return null;
} catch (NumberFormatException ex) {
LOG.log(Level.SEVERE, "Invalid object passed to Converter. Expected Long object received {0} ({1})", new Object[]{value.getClass(), value});
return null;
}
}
@Override
public String getAsString(FacesContext ctx, UIComponent component, Object value) {
Situation obj = (Situation) value;
if (obj == null) {
return "";
} else {
if (obj.getId() == null) {
LOG.log(Level.SEVERE, "Situation does not exist in database");
return null;
} else {
return String.valueOf(obj.getId());
}
}
}
}