/////////////////////////////////////////////////////////////////////////////
//
// Project ProjectForge Community Edition
// www.projectforge.org
//
// Copyright (C) 2001-2014 Kai Reinhard (k.reinhard@micromata.de)
//
// ProjectForge is dual-licensed.
//
// This community edition 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; version 3 of the License.
//
// This community edition 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 org.projectforge.web.wicket;
import java.util.Date;
import org.apache.wicket.extensions.markup.html.repeater.data.grid.ICellPopulator;
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.repeater.Item;
import org.apache.wicket.model.IModel;
import org.apache.wicket.model.Model;
import org.projectforge.common.BeanHelper;
import org.projectforge.common.DateFormatType;
import org.projectforge.common.DateFormats;
import org.projectforge.web.calendar.DateTimeFormatter;
/**
* Table view property columns representing date or time stamps.
* @author Kai Reinhard (k.reinhard@micromata.de)
*
*/
public class DatePropertyColumn<T> extends CellItemListenerPropertyColumn<T>
{
private static final long serialVersionUID = 4759972917073202845L;
private DateTimeFormatter dateTimeFormatter;
private String datePattern = DateFormats.getFormatString(DateFormatType.DATE_SHORT);
public DatePropertyColumn(final DateTimeFormatter dateTimeFormatter, final String label, final String sortProperty, final String property, CellItemListener<T> cellItemListener)
{
super(new Model<String>(label), sortProperty, property, cellItemListener);
this.dateTimeFormatter = dateTimeFormatter;
}
public DatePropertyColumn(final DateTimeFormatter dateTimeFormatter, final String label, final String sortProperty, final String property)
{
this(dateTimeFormatter, label, sortProperty, property, null);
}
/**
* Default is SHORT_DATE_FORMAT.
* @param datePattern Date pattern to set. Please use DateTimeFormatter constants.
* @see DateTimeFormatter#I18N_KEY_SHORT_DATE_FORMAT
*/
public DatePropertyColumn<T> setDatePattern(final String datePattern) {
this.datePattern = datePattern;
return this;
}
@Override
public void populateItem(final Item<ICellPopulator<T>> item, final String componentId, final IModel<T> rowModel)
{
final Date value = (Date) BeanHelper.getNestedProperty(rowModel.getObject(), getPropertyExpression());
final Label label = new Label(componentId, dateTimeFormatter.getFormattedDate(value, datePattern));
item.add(label);
if (cellItemListener != null) {
cellItemListener.populateItem(item, componentId, rowModel);
}
}
}