/* * Copyright (C) 2001-2004 Red Hat Inc. All Rights Reserved. * * This library 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 2.1 of * the License, or (at your option) any later version. * * This library 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA * */ package com.arsdigita.cms; import com.arsdigita.bebop.PageState; import com.arsdigita.bebop.SingleSelectionModel; import com.arsdigita.bebop.parameters.LongParameter; import com.arsdigita.ui.CcmObjectSelectionModel; import org.libreccm.cdi.utils.CdiUtil; import org.librecms.contentsection.ContentItem; import org.librecms.contentsection.ContentType; import org.librecms.contentsection.ContentTypeRepository; import org.librecms.contenttypes.ContentTypeInfo; import java.math.BigDecimal; /** *
* Loads a subclass of a {@link com.arsdigita.cms.ContentItem} from the * database. This model should be used as a parameter to the constructor of * authoring kit components.
* ** It is possible to instantiate this model with a {@link * com.arsdigita.cms.ContentType} as a constructor parameter. In this case, the * model will only instantiate items that are of the specified content type, or * one of it subclasses.
* * @author Stanislav Freidin (stas@arsdigita.com) * @author Jens Pelzetter * * @see com.arsdigita.kernel.ui.ACSObjectSelectionModel * @see com.arsdigita.bebop.SingleSelectionModel */ public class ItemSelectionModel extends CcmObjectSelectionModelItemSelectionModel
*
* @param type The content type for the items this model will
* generate
*
* @param parameterName The name of the state parameter which will be used
* to store the item.
*/
public ItemSelectionModel(final ContentType type,
final String parameterName) {
this(type, new LongParameter(parameterName));
}
/**
* Construct a new ItemSelectionModel
*
* @param type The content type for the items this model will generate
*
* @param parameter The state parameter which should be used by this item
*
*/
public ItemSelectionModel(final ContentType type,
final LongParameter parameter) {
super(type.getContentItemClass(), parameter);
typeId = type.getObjectId();
}
/**
* Construct a new ItemSelectionModel
*
* @param type The content type for the items this model will generate
*
* @param model The {@link SingleSelectionModel} which will supply a
* {@link BigDecimal} id of the currently selected object
*
*/
public ItemSelectionModel(final ContentType type,
final SingleSelectionModelContentItem
*
* @param state the current page state
*
* @return the currently selected ContentItem, or null if no
* item was selected.
*/
public final ContentItem getSelectedItem(final PageState state) {
return getSelectedObject(state);
}
/**
*
* @return The content type of the items which are produced by this model,
* or null if the content type has not been specified in the
* constructor.
*/
public ContentType getContentType() {
ContentType type = null;
if (typeId != null) {
type = CdiUtil.createCdiUtil().findBean(ContentTypeRepository.class)
.findById(typeId);
}
return type;
}
}