All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.wicket.model.ResourceModel Maven / Gradle / Ivy

/*
 * Licensed to the Apache Software Foundation (ASF) under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * The ASF licenses this file to You 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 org.apache.wicket.model;

import org.apache.wicket.Application;
import org.apache.wicket.Component;

/**
 * A model that represents a localized resource string. This is a lightweight version of the
 * {@link StringResourceModel}. It lacks parameter substitutions, but is generally easier to use.
 * 

* If you don't use this model as primary component model (you don't specify it in component * constructor and don't assign it to component using {@link Component#setDefaultModel(IModel)}), * you will need to connect the model with a component using {@link #wrapOnAssignment(Component)}. * * @author Igor Vaynberg (ivaynberg) * */ public class ResourceModel extends AbstractReadOnlyModel implements IComponentAssignedModel { private static final long serialVersionUID = 1L; private final String resourceKey; private final String defaultValue; /** * Constructor * * @param resourceKey * key of the resource this model represents */ public ResourceModel(String resourceKey) { this(resourceKey, null); } /** * Constructor * * @param resourceKey * key of the resource this model represents * @param defaultValue * value that will be returned if resource does not exist * */ public ResourceModel(String resourceKey, String defaultValue) { this.resourceKey = resourceKey; this.defaultValue = defaultValue; } /** * @see org.apache.wicket.model.AbstractReadOnlyModel#getObject() */ @Override public String getObject() { // this shouldn't be called always wrapped! return Application.get().getResourceSettings().getLocalizer().getString(resourceKey, null, defaultValue); } /** * @see org.apache.wicket.model.IComponentAssignedModel#wrapOnAssignment(org.apache.wicket.Component) */ public IWrapModel wrapOnAssignment(final Component component) { return new AssignmentWrapper(resourceKey, defaultValue, component); } /** * */ private class AssignmentWrapper extends ResourceModel implements IWrapModel { private static final long serialVersionUID = 1L; private final Component component; /** * Construct. * * @param resourceKey * @param defaultValue * @param component */ public AssignmentWrapper(String resourceKey, String defaultValue, Component component) { super(resourceKey, defaultValue); this.component = component; } /** * @see org.apache.wicket.model.IWrapModel#getWrappedModel() */ public IModel getWrappedModel() { return ResourceModel.this; } /** * @see org.apache.wicket.model.AbstractReadOnlyModel#getObject() */ @Override public String getObject() { return Application.get().getResourceSettings().getLocalizer().getString(resourceKey, component, defaultValue); } @Override public void detach() { super.detach(); ResourceModel.this.detach(); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy