/**
* Copyright (C) 2010 Asterios Raptis
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package de.alpharogroup.wicket.components.labeled.label;
import org.apache.wicket.markup.html.basic.Label;
import org.apache.wicket.markup.html.basic.MultiLineLabel;
import org.apache.wicket.model.IModel;
import org.apache.wicket.model.PropertyModel;
import de.alpharogroup.wicket.base.BasePanel;
import de.alpharogroup.wicket.components.factory.ComponentFactory;
import lombok.Getter;
/**
* Convenience class for labeled MultiLineLabel for form uneditable components.
*
* @param <T>
* the generic type of model object
*/
public class LabeledMultiLineLabelPanel<T> extends BasePanel<T>
{
/** The Constant serialVersionUID. */
private static final long serialVersionUID = 1L;
/** The left side Label component. */
@Getter
private final Label label;
/** The right side label. */
@Getter
private final MultiLineLabel viewableLabel;
/**
* Instantiates a new {@link LabeledMultiLineLabelPanel}.
*
* @param id
* the id
* @param model
* the model
* @param labelModel
* the label model
*/
public LabeledMultiLineLabelPanel(final String id, final IModel<T> model,
final IModel<String> labelModel)
{
super(id, model);
setOutputMarkupId(true);
add(viewableLabel = newMultiLineLabelLabel("viewableLabel", model));
final String markupId = viewableLabel.getMarkupId();
add(label = newLabel("label", markupId, labelModel));
}
/**
* Factory method for create a new {@link Label}. This method is invoked in the constructor from
* the derived classes and can be overridden so users can provide their own version of a new
* {@link Label}.
*
* @param id
* the id
* @param forId
* the for id
* @param model
* the model
* @return the new {@link Label}
*/
protected Label newLabel(final String id, final String forId, final IModel<String> model)
{
return ComponentFactory.newLabel(id, forId, model);
}
/**
* Factory method for create a new {@link MultiLineLabel}. This method is invoked in the
* constructor from the derived classes and can be overridden so users can provide their own
* version of a new {@link MultiLineLabel}.
*
* @param id
* the id
* @param model
* the model
* @return the new {@link MultiLineLabel}
*/
protected MultiLineLabel newMultiLineLabelLabel(final String id, final IModel<T> model)
{
final IModel<T> viewableLabelModel = new PropertyModel<>(model.getObject(), this.getId());
return ComponentFactory.newMultiLineLabel(id, viewableLabelModel);
}
}