summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLeif Åstrand <leif@vaadin.com>2012-06-07 12:07:16 +0000
committerLeif Åstrand <leif@vaadin.com>2012-06-07 12:07:16 +0000
commitcece22a1d1919d8da459b6dab18c19e53c6e7f04 (patch)
treeb64c19a7337a5ddb7a87acb2d94e9e9efa9af801
parentd2c12c2e5ffb9ce8336eac53ef14faaf3499ae82 (diff)
downloadvaadin-framework-cece22a1d1919d8da459b6dab18c19e53c6e7f04.tar.gz
vaadin-framework-cece22a1d1919d8da459b6dab18c19e53c6e7f04.zip
Remove document.write from bootstrap (#8924)
svn changeset:23905/svn branch:6.8
-rw-r--r--src/com/vaadin/terminal/gwt/server/AbstractApplicationPortlet.java70
-rw-r--r--src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java12
2 files changed, 59 insertions, 23 deletions
diff --git a/src/com/vaadin/terminal/gwt/server/AbstractApplicationPortlet.java b/src/com/vaadin/terminal/gwt/server/AbstractApplicationPortlet.java
index 9f1bd4e9ee..26b0d3df1d 100644
--- a/src/com/vaadin/terminal/gwt/server/AbstractApplicationPortlet.java
+++ b/src/com/vaadin/terminal/gwt/server/AbstractApplicationPortlet.java
@@ -882,6 +882,30 @@ public abstract class AbstractApplicationPortlet extends GenericPortlet
/**
* Returns the URL from which the widgetset is served on the portal.
*
+ * @param request
+ * @return
+ */
+ protected String getWidgetsetURL(RenderRequest request) {
+ String requestWidgetset = getApplicationOrSystemProperty(
+ PARAMETER_WIDGETSET, null);
+ String sharedWidgetset = getPortalProperty(
+ PORTAL_PARAMETER_VAADIN_WIDGETSET, request.getPortalContext());
+
+ String widgetset;
+ if (requestWidgetset != null) {
+ widgetset = requestWidgetset;
+ } else if (sharedWidgetset != null) {
+ widgetset = sharedWidgetset;
+ } else {
+ widgetset = DEFAULT_WIDGETSET;
+ }
+ String widgetsetURL = getWidgetsetURL(widgetset, request);
+ return widgetsetURL;
+ }
+
+ /**
+ * Returns the URL from which the widgetset is served on the portal.
+ *
* @param widgetset
* @param request
* @return
@@ -1037,6 +1061,8 @@ public abstract class AbstractApplicationPortlet extends GenericPortlet
writer.write("</script>\n");
+ writeAjaxPageWidgetset(request, writer);
+
writeAjaxPageHtmlTheme(request, writer, themeName, themeURI,
portalTheme);
@@ -1048,32 +1074,40 @@ public abstract class AbstractApplicationPortlet extends GenericPortlet
* the portlet.
*
* @param request
+ * @param writer
+ * @throws IOException
+ */
+ protected void writeAjaxPageWidgetset(RenderRequest request,
+ BufferedWriter writer) throws IOException {
+ String widgetsetURL = getWidgetsetURL(request);
+ writer.write("<iframe tabIndex=\"-1\" id=\"__gwt_historyFrame\" "
+ + "style=\"position:absolute;width:0;height:0;border:0;overflow:"
+ + "hidden;opacity:0;top:-100px;left:-100px;\" src=\"javascript:false\"></iframe>'\n");
+ writer.write("<script language='javascript' src='" + widgetsetURL
+ + "'></script>\n");
+ }
+
+ /**
+ * Writes the script to load the widgetset on the HTML fragment created by
+ * the portlet.
+ *
+ * @param request
* @param response
* @param writer
* @throws IOException
+ *
+ * @Deprecated As of 6.8, use
+ * {@link #writeAjaxPageWidgetset(RenderRequest, BufferedWriter)}
+ * instead to avoid using document.write
*/
+ @Deprecated
protected void writeAjaxPageScriptWidgetset(RenderRequest request,
RenderResponse response, final BufferedWriter writer)
throws IOException {
- String requestWidgetset = getApplicationOrSystemProperty(
- PARAMETER_WIDGETSET, null);
- String sharedWidgetset = getPortalProperty(
- PORTAL_PARAMETER_VAADIN_WIDGETSET, request.getPortalContext());
+ // No longer used as of #8924, but retained to maintain compatibility
- String widgetset;
- if (requestWidgetset != null) {
- widgetset = requestWidgetset;
- } else if (sharedWidgetset != null) {
- widgetset = sharedWidgetset;
- } else {
- widgetset = DEFAULT_WIDGETSET;
- }
- String widgetsetURL = getWidgetsetURL(widgetset, request);
- writer.write("document.write('<iframe tabIndex=\"-1\" id=\"__gwt_historyFrame\" "
- + "style=\"position:absolute;width:0;height:0;border:0;overflow:"
- + "hidden;opacity:0;top:-100px;left:-100px;\" src=\"javascript:false\"></iframe>');\n");
- writer.write("document.write(\"<script language='javascript' src='"
- + widgetsetURL + "'><\\/script>\");\n}\n");
+ // But we still need to close this one block, for compatibility
+ writer.append("\\n}\\n");
}
/**
diff --git a/src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java b/src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java
index c6d286ed03..ffa34b11cd 100644
--- a/src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java
+++ b/src/com/vaadin/terminal/gwt/server/AbstractApplicationServlet.java
@@ -1929,11 +1929,7 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
if (!isProductionMode()) {
page.write("vaadin.debug = true;\n");
}
- page.write("document.write('<iframe tabIndex=\"-1\" id=\"__gwt_historyFrame\" "
- + "style=\"position:absolute;width:0;height:0;border:0;overflow:"
- + "hidden;\" src=\"javascript:false\"></iframe>');\n");
- page.write("document.write(\"<script language='javascript' src='"
- + widgetsetFilePath + "'><\\/script>\");\n}\n");
+ page.write("}\n");
page.write("vaadin.vaadinConfigurations[\"" + appId + "\"] = {");
page.write("appUri:'" + appUrl + "', ");
@@ -1991,6 +1987,12 @@ public abstract class AbstractApplicationServlet extends HttpServlet implements
}
page.write("};\n//]]>\n</script>\n");
+ page.write("<iframe tabIndex='-1' id='__gwt_historyFrame' "
+ + "style='position:absolute;width:0;height:0;border:0;overflow:"
+ + "hidden;' src='javascript:false'></iframe>\n");
+ page.write("<script language='javascript' src='" + widgetsetFilePath
+ + "'></script>\n");
+
if (themeName != null) {
// Custom theme's stylesheet, load only once, in different
// script