/* * 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(); } }