/*
* Copyright 2008 Eckhart Arnold (eckhart_arnold@hotmail.com).
*
* 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.eckhartarnold.client;
import com.google.gwt.user.client.ui.HTMLPanel;
import com.google.gwt.user.client.ui.Widget;
/**
* Class <code>HTMLLayout</code> allows to code the layout of the image panel,
* control panel and caption in HTML.
*
* <p>Insances of the class are instantiated with a chunk of HTML code.
* The elements of the slide show, i.e.
* control panel, image panel and caption will be attached by to tags (or
* DOM elements respectively) that have the ids "display", "controlPanel" and
* "caption" of the HTML code.
*
* @author ecki
*
*/
public class HTMLLayout extends Layout {
/** An example HTML chunk that puts the control panel at the top,
* the image panel in the middle and the caption at the bottom. */
public static final String DEFAULT_HTML =
"<table class=\"imageBackground\" style=\"width:100%; height:100%;\">" +
"<tr><td style=\"width:100%\"><hr class=\"tiledSeparator\" /></td>" +
"<td id=\"controlPanel\"></td></tr>" +
"<tr><td id=\"display\" colspan=\"2\" style=\"width:100%; height:100%;\"></td></tr>" +
"<tr><td colspan=\"2\"><hr class=\"tiledSeparator\" /></td></tr>" +
"<tr><td id=\"caption\" colspan=\"2\" align=\"center\" style=\"color:white;\"></td></tr>" +
"</table>";
/** The html panel widget that represents the html chunk. */
protected HTMLPanel htmlPanel;
/**
* The constructor of class <code>HTMLLayout</code>.
*
* @param collection the image collection info object
* @param HTMLChunk a chunk of HTML code that contains tags with
* the id's "display", "controlPanel" and "caption"
* @param configuration the configuration string of the layout
*/
public HTMLLayout(ImageCollectionInfo collection, String HTMLChunk, String configuration) {
super(collection, configuration);
htmlPanel = new HTMLPanel(HTMLChunk);
htmlPanel.add(imagePanel, "display");
if (caption != null) {
htmlPanel.add(caption, "caption");
// caption.setSpacing(true);
}
if (control != null && control instanceof Widget) {
htmlPanel.add((Widget) control, "controlPanel");
}
}
/**
* An alternative constructor that only takes the image collection info
* object and the HTML chunk as parameters.
*
* @param collection the image collection info object
* @param HTMLChunk the HTML chunk defining the layout
*/
public HTMLLayout(ImageCollectionInfo collection, String HTMLChunk) {
this(collection, HTMLChunk, detectConfiguration(HTMLChunk));
}
/**
* An alternative constructor that only takes the image collection info
* as parameter and otherwise uses <code>DEFAULT_HTML</code> for the
* layout.
*
* @param collection the image collection info object
*/
public HTMLLayout(ImageCollectionInfo collection) {
this(collection, DEFAULT_HTML, detectConfiguration(DEFAULT_HTML));
}
/* (non-Javadoc)
* @see de.eckhartarnold.client.Layout#getRootWidget()
*/
@Override
public Widget getRootWidget() {
return htmlPanel;
}
private static String detectConfiguration(String HTMLChunk) {
String cfg = "I";
if (HTMLChunk.indexOf("\"caption\"") >= 0) cfg += "C";
if (HTMLChunk.indexOf("\"controlPanel\"") >= 0) cfg += "P";
return cfg;
}
}