/*
* 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.util.template;
import java.io.IOException;
import java.io.InputStream;
import java.nio.charset.Charset;
import java.util.Collections;
import java.util.Locale;
import java.util.Map;
import org.apache.wicket.util.lang.Args;
import org.apache.wicket.util.resource.ResourceStreamNotFoundException;
import org.apache.wicket.util.time.Time;
/**
* Provides the ability to 'decorate' the actual template contents before it is contributed to the
* header. For example, to embed it inside a JavaScript tag pair.
*
* @author Eelco Hillenius
* @since 1.2.6
*/
public abstract class TextTemplateDecorator extends TextTemplate
{
private static final long serialVersionUID = 1L;
/**
* The decorated <code>TextTemplate</code>.
*/
protected final TextTemplate decorated;
/**
* Constructor.
*
* @param textTemplate
* a <code>TextTemplate</code> to decorate
*/
public TextTemplateDecorator(TextTemplate textTemplate)
{
Args.notNull(textTemplate, "textTemplate");
decorated = textTemplate;
}
/**
* Returns the decorated contents as a <code>String</code>.
*
* @return the contents decorated with {@link #getBeforeTemplateContents()} and
* {@link #getAfterTemplateContents()}
* @see org.apache.wicket.util.template.TextTemplate#asString()
*/
@Override
public String asString()
{
return asString(Collections.<String, Object> emptyMap());
}
/**
* Returns the decorated contents as a <code>String</code>.
*
* @return the contents decorated with {@link #getBeforeTemplateContents()} and
* {@link #getAfterTemplateContents()}.
* @see org.apache.wicket.util.template.TextTemplate#asString(java.util.Map)
*/
@Override
public String asString(Map<String, ?> variables)
{
StringBuilder b = new StringBuilder();
b.append(getBeforeTemplateContents());
b.append(decorated.asString(variables));
b.append(getAfterTemplateContents());
return b.toString();
}
/**
* Retrieves the <code>String</code> to put before the actual template contents, for example:
*
* <pre>
* <script type="text/javascript">
* </pre>
*
* @return the <code>String</code> to put before the actual template contents
*/
public abstract String getBeforeTemplateContents();
/**
* Retrieves the <code>String</code> to put after the actual template contents, for example:
*
* <pre>
* </script>
* </pre>
*
* @return the <code>String</code> to put after the actual template contents
*/
public abstract String getAfterTemplateContents();
/**
* @see org.apache.wicket.util.resource.AbstractStringResourceStream#close()
*/
@Override
public void close() throws IOException
{
decorated.close();
}
/**
* @see java.lang.Object#equals(java.lang.Object)
*/
@Override
public boolean equals(Object obj)
{
return decorated.equals(obj);
}
/**
* @see org.apache.wicket.util.resource.AbstractStringResourceStream#getContentType()
*/
@Override
public String getContentType()
{
return decorated.getContentType();
}
/**
* @see org.apache.wicket.util.resource.AbstractStringResourceStream#getInputStream()
*/
@Override
public InputStream getInputStream() throws ResourceStreamNotFoundException
{
return decorated.getInputStream();
}
/**
* @see org.apache.wicket.util.resource.AbstractResourceStream#getLocale()
*/
@Override
public Locale getLocale()
{
return decorated.getLocale();
}
/**
* @see java.lang.Object#hashCode()
*/
@Override
public int hashCode()
{
return decorated.hashCode();
}
/**
* @see org.apache.wicket.util.resource.AbstractStringResourceStream#lastModifiedTime()
*/
@Override
public Time lastModifiedTime()
{
return decorated.lastModifiedTime();
}
/**
* @see org.apache.wicket.util.resource.AbstractResourceStream#setCharset(java.nio.charset.Charset)
*/
@Override
public void setCharset(Charset charset)
{
decorated.setCharset(charset);
}
/**
* @see org.apache.wicket.util.resource.AbstractStringResourceStream#setLastModified(org.apache.wicket.util.time.Time)
*/
@Override
public void setLastModified(Time lastModified)
{
decorated.setLastModified(lastModified);
}
/**
* @see org.apache.wicket.util.resource.AbstractResourceStream#setLocale(java.util.Locale)
*/
@Override
public void setLocale(Locale locale)
{
decorated.setLocale(locale);
}
/**
* @see org.apache.wicket.util.template.TextTemplate#getString()
*/
@Override
public String getString()
{
return decorated.getString();
}
/**
* @see java.lang.Object#toString()
*/
@Override
public String toString()
{
return decorated.toString();
}
}