com.google.gwt.uibinder.elementparsers.RenderablePanelParser Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of vaadin-client Show documentation
Show all versions of vaadin-client Show documentation
Vaadin is a web application framework for Rich Internet Applications (RIA).
Vaadin enables easy development and maintenance of fast and
secure rich web
applications with a stunning look and feel and a wide browser support.
It features a server-side architecture with the majority of the logic
running
on the server. Ajax technology is used at the browser-side to ensure a
rich
and interactive user experience.
/*
* Copyright 2011 Google Inc.
*
* 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 com.google.gwt.uibinder.elementparsers;
import com.google.gwt.core.ext.UnableToCompleteException;
import com.google.gwt.core.ext.typeinfo.JClassType;
import com.google.gwt.uibinder.elementparsers.HtmlMessageInterpreter.PlaceholderInterpreterProvider;
import com.google.gwt.uibinder.rebind.UiBinderWriter;
import com.google.gwt.uibinder.rebind.XMLElement;
import com.google.gwt.uibinder.rebind.messages.MessageWriter;
import com.google.gwt.uibinder.rebind.messages.PlaceholderInterpreter;
import com.google.gwt.uibinder.rebind.model.OwnerField;
/**
* Parses {@link com.google.gwt.user.client.ui.RenderablePanel} widgets.
*/
public class RenderablePanelParser implements ElementParser {
public void parse(XMLElement elem, String fieldName, JClassType type,
final UiBinderWriter writer) throws UnableToCompleteException {
assert writer.useLazyWidgetBuilders();
// Make sure that, if there is a UiField for this panel, it isn't
// (provided = true), as that isn't supported.
OwnerField uiField = writer.getOwnerClass().getUiField(fieldName);
if (uiField != null && uiField.isProvided()) {
writer.die("UiField %s for RenderablePanel cannot be provided.", fieldName);
}
/*
* Gathers up elements that indicate nested IsRenderable objects.
*/
IsRenderableInterpreter isRenderableInterpreter = null;
isRenderableInterpreter = new IsRenderableInterpreter(
fieldName, writer);
/*
* Gathers up elements that indicate nested widgets (but only those that are
* not inside msg elements).
*/
WidgetInterpreter widgetInterpreter = new WidgetInterpreter(fieldName,
writer);
/*
* Handles non-widget elements like msg, and dom elements with ui:field
* attributes. There may be widgets inside a msg, which is why the
* construction in makeHtmlInterpreter is so complicated.
*/
HtmlInterpreter htmlInterpreter = makeHtmlInterpreter(fieldName, writer);
writer.beginAttachedSection(fieldName);
final InterpreterPipe interpreters;
interpreters = InterpreterPipe.newPipe(
isRenderableInterpreter, widgetInterpreter, htmlInterpreter);
String html = elem.consumeInnerHtml(interpreters);
writer.endAttachedSection();
/*
* RenderablePanel has no no-arg ctor, so we have to generate our own, using the
* element's innerHTML and perhaps its tag attribute. Do this in a way that
* will not break subclasses if they happen to have the same constructor
* signature (by passing in type).
*/
String customTag = elem.consumeStringAttribute("tag", null);
// TODO(rdcastro): Add support for custom tags in RenderablePanel.
if (customTag != null) {
writer.getLogger().die(elem,
"RenderablePanel does not support custom root elements yet.");
}
writer.setFieldInitializerAsConstructor(fieldName, writer.declareTemplateCall(html,
fieldName));
}
/**
* Creates an HtmlInterpreter with our specialized placeholder interpreter,
* which will allow widget instances to be declared inside of ui:msg elements.
*/
private HtmlInterpreter makeHtmlInterpreter(final String fieldName,
final UiBinderWriter uiWriter) {
final String ancestorExpression = fieldName;
PlaceholderInterpreterProvider placeholderInterpreterProvider =
new PlaceholderInterpreterProvider() {
public PlaceholderInterpreter get(MessageWriter message) {
return new WidgetPlaceholderInterpreter(fieldName, uiWriter, message,
ancestorExpression);
}
};
HtmlInterpreter htmlInterpreter = new HtmlInterpreter(uiWriter,
ancestorExpression, new HtmlMessageInterpreter(uiWriter,
placeholderInterpreterProvider));
return htmlInterpreter;
}
}