summaryrefslogtreecommitdiffstats
path: root/client
diff options
context:
space:
mode:
authorManolo Carrasco <manolo@vaadin.com>2014-09-09 18:11:45 +0200
committerSauli Tähkäpää <sauli@vaadin.com>2014-09-16 10:24:07 +0300
commit1bd717cf668ef777455f29c0bd144a3bc4401f84 (patch)
tree6565b18139f9a4a47434e9851575ae8a6cb34e9f /client
parent3a4e1bb067931f454fa5bb2c1fbddea0402ad97f (diff)
downloadvaadin-framework-1bd717cf668ef777455f29c0bd144a3bc4401f84.tar.gz
vaadin-framework-1bd717cf668ef777455f29c0bd144a3bc4401f84.zip
Use div instead of notice to avoid UI removing it (#14597)7.3.1
Change-Id: I70cf7f310ee8238a6846316d8c85b3ae4abfd67d
Diffstat (limited to 'client')
-rw-r--r--client/src/com/vaadin/client/metadata/ConnectorBundleLoader.java78
1 files changed, 63 insertions, 15 deletions
diff --git a/client/src/com/vaadin/client/metadata/ConnectorBundleLoader.java b/client/src/com/vaadin/client/metadata/ConnectorBundleLoader.java
index 846bfd4671..dca5931640 100644
--- a/client/src/com/vaadin/client/metadata/ConnectorBundleLoader.java
+++ b/client/src/com/vaadin/client/metadata/ConnectorBundleLoader.java
@@ -19,13 +19,21 @@ import java.util.ArrayList;
import java.util.List;
import com.google.gwt.core.shared.GWT;
+import com.google.gwt.dom.client.Style;
+import com.google.gwt.dom.client.Style.Display;
+import com.google.gwt.dom.client.Style.Position;
+import com.google.gwt.dom.client.Style.TextAlign;
+import com.google.gwt.dom.client.Style.Unit;
+import com.google.gwt.dom.client.Style.Visibility;
+import com.google.gwt.dom.client.Style.WhiteSpace;
+import com.google.gwt.event.dom.client.ClickEvent;
+import com.google.gwt.event.dom.client.ClickHandler;
+import com.google.gwt.event.dom.client.TouchStartEvent;
+import com.google.gwt.event.dom.client.TouchStartHandler;
import com.google.gwt.user.client.ui.HTML;
-import com.google.gwt.user.client.ui.Widget;
-import com.vaadin.client.ApplicationConfiguration;
+import com.google.gwt.user.client.ui.RootPanel;
import com.vaadin.client.FastStringMap;
import com.vaadin.client.metadata.AsyncBundleLoader.State;
-import com.vaadin.client.ui.VNotification;
-import com.vaadin.shared.Position;
public abstract class ConnectorBundleLoader {
@@ -139,23 +147,63 @@ public abstract class ConnectorBundleLoader {
public void cval(String typeName) {
if (!cvals.isEmpty()) {
- String msg = "";
for (CValUiInfo c : cvals) {
String ns = c.widgetset.replaceFirst("\\.[^\\.]+$", "");
if (typeName.startsWith(ns)) {
+ notice(c.product + " " + c.version);
cvals.remove(c);
- msg += c.product + " " + c.version + "<br/>";
+ return;
}
}
- if (!msg.isEmpty()) {
- // We need a widget for using VNotification, using the
- // context-menu parent. Is there an easy way?
- Widget w = ApplicationConfiguration.getRunningApplications()
- .get(0).getContextMenu().getParent();
- VNotification n = VNotification.createNotification(0, w);
- n.setWidget(new HTML("Using Evaluation License of:<br/>" + msg));
- n.show(Position.BOTTOM_RIGHT);
- }
}
}
+
+ private HTML notice;
+
+ // Not using Vaadin notifications (#14597)
+ private void notice(String productName) {
+ if (notice == null) {
+ notice = new HTML();
+ notice.addClickHandler(new ClickHandler() {
+ public void onClick(ClickEvent event) {
+ notice.removeFromParent();
+ }
+ });
+ notice.addTouchStartHandler(new TouchStartHandler() {
+ public void onTouchStart(TouchStartEvent event) {
+ notice.removeFromParent();
+ }
+ });
+ }
+ String msg = notice.getText().trim();
+ msg += msg.isEmpty() ? "Using Evaluation License of: " : ", ";
+ notice.setText(msg + productName);
+ RootPanel.get().add(notice);
+
+ notice.getElement().setClassName("");
+ Style s = notice.getElement().getStyle();
+
+ s.setPosition(Position.FIXED);
+ s.setTextAlign(TextAlign.CENTER);
+ s.setRight(0, Unit.PX);
+ s.setLeft(0, Unit.PX);
+ s.setBottom(0, Unit.PX);
+ s.setProperty("padding", "0.5em 1em");
+
+ s.setProperty("font-family", "sans-serif");
+ s.setFontSize(12, Unit.PX);
+ s.setLineHeight(1.1, Unit.EM);
+
+ s.setColor("white");
+ s.setBackgroundColor("black");
+ s.setOpacity(0.7);
+
+ s.setZIndex(2147483646);
+ s.setProperty("top", "auto");
+ s.setProperty("width", "auto");
+ s.setDisplay(Display.BLOCK);
+ s.setWhiteSpace(WhiteSpace.NORMAL);
+ s.setVisibility(Visibility.VISIBLE);
+ s.setMargin(0, Unit.PX);
+ }
}