summaryrefslogtreecommitdiffstats
path: root/client
diff options
context:
space:
mode:
Diffstat (limited to 'client')
-rw-r--r--client/src/com/vaadin/Vaadin.gwt.xml9
-rw-r--r--client/src/com/vaadin/VaadinBrowserSpecificOverrides.gwt.xml10
-rw-r--r--client/src/com/vaadin/client/ApplicationConfiguration.java15
-rw-r--r--client/src/com/vaadin/client/VTooltip.java17
-rw-r--r--client/src/com/vaadin/client/componentlocator/LocatorUtil.java29
-rw-r--r--client/src/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java55
-rwxr-xr-x[-rw-r--r--]client/src/com/vaadin/client/debug/internal/theme/font.eotbin7528 -> 7388 bytes
-rwxr-xr-x[-rw-r--r--]client/src/com/vaadin/client/debug/internal/theme/font.svg60
-rwxr-xr-x[-rw-r--r--]client/src/com/vaadin/client/debug/internal/theme/font.ttfbin7364 -> 7224 bytes
-rwxr-xr-x[-rw-r--r--]client/src/com/vaadin/client/debug/internal/theme/font.woffbin8060 -> 7300 bytes
-rw-r--r--client/src/com/vaadin/client/ui/VCalendar.java2
-rw-r--r--client/src/com/vaadin/client/ui/VContextMenu.java13
-rw-r--r--client/src/com/vaadin/client/ui/VMenuBar.java81
-rw-r--r--client/src/com/vaadin/client/ui/VOverlay.java13
-rw-r--r--client/src/com/vaadin/client/ui/VPopupCalendar.java79
-rw-r--r--client/src/com/vaadin/client/ui/VPopupImpl.java35
-rw-r--r--client/src/com/vaadin/client/ui/VPopupImplMozilla.java35
-rw-r--r--client/src/com/vaadin/client/ui/VPopupView.java11
-rw-r--r--client/src/com/vaadin/client/ui/VScrollTable.java57
-rw-r--r--client/src/com/vaadin/client/ui/VTabsheet.java73
-rw-r--r--client/src/com/vaadin/client/ui/VUpload.java10
-rw-r--r--client/src/com/vaadin/client/ui/calendar/CalendarConnector.java2
-rw-r--r--client/src/com/vaadin/client/ui/calendar/schedule/CalendarDay.java8
-rw-r--r--client/src/com/vaadin/client/ui/calendar/schedule/SimpleDayCell.java68
-rw-r--r--client/src/com/vaadin/client/ui/orderedlayout/AbstractOrderedLayoutConnector.java15
-rw-r--r--client/src/com/vaadin/client/ui/tabsheet/TabsheetConnector.java2
-rw-r--r--client/tests/src/com/vaadin/client/LocatorUtilTest.java73
27 files changed, 519 insertions, 253 deletions
diff --git a/client/src/com/vaadin/Vaadin.gwt.xml b/client/src/com/vaadin/Vaadin.gwt.xml
index aad0563975..5e8f08fe22 100644
--- a/client/src/com/vaadin/Vaadin.gwt.xml
+++ b/client/src/com/vaadin/Vaadin.gwt.xml
@@ -13,11 +13,7 @@
<inherits name="com.google.gwt.json.JSON" />
<inherits name="com.google.gwt.logging.Logging" />
- <!-- Firebug handler is deprecated but for some reason still enabled
- by default -->
- <set-property name="gwt.logging.firebugHandler" value="DISABLED" />
- <!-- Disable popup logging as we have our own popup logger -->
- <set-property name="gwt.logging.popupHandler" value="DISABLED" />
+ <set-property name="gwt.logging.enabled" value="TRUE" />
<inherits name="com.vaadin.VaadinBrowserSpecificOverrides" />
@@ -58,10 +54,9 @@
<!-- Use the new cross site linker to get a nocache.js without document.write -->
<add-linker name="xsiframe" />
- <extend-property name="user.agent" values="opera" />
<!-- Remove IE6/IE7 permutation as they are not supported -->
- <set-property name="user.agent" value="ie8,ie9,ie10,gecko1_8,safari,opera" />
+ <set-property name="user.agent" value="ie8,ie9,ie10,gecko1_8,safari" />
<!-- Pointer event support -->
<define-property name="modernie" values="none,yes" />
diff --git a/client/src/com/vaadin/VaadinBrowserSpecificOverrides.gwt.xml b/client/src/com/vaadin/VaadinBrowserSpecificOverrides.gwt.xml
index 45ede928f5..ceedde50a6 100644
--- a/client/src/com/vaadin/VaadinBrowserSpecificOverrides.gwt.xml
+++ b/client/src/com/vaadin/VaadinBrowserSpecificOverrides.gwt.xml
@@ -44,14 +44,4 @@
</any>
</replace-with>
- <replace-with class="com.vaadin.client.ui.VPopupImpl">
- <when-type-is
- class="com.google.gwt.user.client.ui.impl.PopupImplMozilla" />
- <when-property-is name="user.agent" value="gecko1_8" />
- </replace-with>
-
- <replace-with class="com.vaadin.client.ui.VPopupImpl">
- <when-type-is class="com.google.gwt.user.client.ui.impl.PopupImpl" />
- </replace-with>
-
</module>
diff --git a/client/src/com/vaadin/client/ApplicationConfiguration.java b/client/src/com/vaadin/client/ApplicationConfiguration.java
index 83dd90b6c2..12b1585292 100644
--- a/client/src/com/vaadin/client/ApplicationConfiguration.java
+++ b/client/src/com/vaadin/client/ApplicationConfiguration.java
@@ -32,6 +32,8 @@ import com.google.gwt.core.client.JsArrayString;
import com.google.gwt.core.client.RunAsyncCallback;
import com.google.gwt.core.client.Scheduler;
import com.google.gwt.core.client.Scheduler.ScheduledCommand;
+import com.google.gwt.core.client.ScriptInjector;
+import com.google.gwt.dom.client.Element;
import com.google.gwt.logging.client.LogConfiguration;
import com.google.gwt.user.client.Command;
import com.google.gwt.user.client.Window;
@@ -598,11 +600,20 @@ public class ApplicationConfiguration implements EntryPoint {
}
}
+ private boolean vaadinBootstrapLoaded() {
+ Element window = ScriptInjector.TOP_WINDOW.cast();
+ return window.getPropertyJSO("vaadin") != null;
+ }
+
@Override
public void onModuleLoad() {
- // Don't run twice if the module has been inherited several times.
- if (moduleLoaded) {
+ // Don't run twice if the module has been inherited several times,
+ // and don't continue if vaadinBootstrap was not executed.
+ if (moduleLoaded || !vaadinBootstrapLoaded()) {
+ getLogger()
+ .log(Level.WARNING,
+ "vaadinBootstrap.js was not loaded, skipping vaadin application configuration.");
return;
}
moduleLoaded = true;
diff --git a/client/src/com/vaadin/client/VTooltip.java b/client/src/com/vaadin/client/VTooltip.java
index d61af537a9..edd1273bf5 100644
--- a/client/src/com/vaadin/client/VTooltip.java
+++ b/client/src/com/vaadin/client/VTooltip.java
@@ -132,6 +132,22 @@ public class VTooltip extends VOverlay {
}
if (info.getTitle() != null && !info.getTitle().isEmpty()) {
description.setInnerHTML(info.getTitle());
+ /*
+ * Issue #11871: to correctly update the offsetWidth of description
+ * element we need to clear style width of it's parent DIV from old
+ * value (in some strange cases this width=[tooltip MAX_WIDTH] after
+ * tooltip text has been already updated to new shortly value:
+ *
+ * <div class="popupContent"> <div style="width: 500px;"> <div
+ * class="v-errormessage" aria-hidden="true" style="display: none;">
+ * <div class="gwt-HTML"> </div> </div> <div
+ * class="v-tooltip-text">This is a short tooltip</div> </div>
+ *
+ * and it leads to error during calculation offsetWidth (it is
+ * native GWT method getSubPixelOffsetWidth()) of description
+ * element")
+ */
+ description.getParentElement().getStyle().clearWidth();
description.getStyle().clearDisplay();
} else {
description.setInnerHTML("");
@@ -151,6 +167,7 @@ public class VTooltip extends VOverlay {
// in the right or bottom edge. For this reason the tooltip is moved
// first to 0,0 position so that the calculation goes correctly.
setPopupPosition(0, 0);
+
setPopupPositionAndShow(new PositionCallback() {
@Override
public void setPosition(int offsetWidth, int offsetHeight) {
diff --git a/client/src/com/vaadin/client/componentlocator/LocatorUtil.java b/client/src/com/vaadin/client/componentlocator/LocatorUtil.java
index 1d1c06587b..7de0de3855 100644
--- a/client/src/com/vaadin/client/componentlocator/LocatorUtil.java
+++ b/client/src/com/vaadin/client/componentlocator/LocatorUtil.java
@@ -15,6 +15,8 @@
*/
package com.vaadin.client.componentlocator;
+import com.google.gwt.regexp.shared.RegExp;
+
/**
* Common String manipulator utilities used in VaadinFinderLocatorStrategy and
* SelectorPredicates.
@@ -73,4 +75,31 @@ public class LocatorUtil {
protected static int indexOfIgnoringQuoted(String str, char find) {
return indexOfIgnoringQuoted(str, find, 0);
}
+
+ /**
+ * Checks if path refers to vaadin UI element com.vaadin.ui.UI.
+ *
+ * @param path
+ * to vaadin element
+ * @return true if path refers to UI element, false otherwise
+ */
+ public static boolean isUIElement(String path) {
+ String regex = "^\\/{0,2}(com\\.vaadin\\.ui\\.)?V?UI[\\/\\[]?";
+ RegExp regexp = RegExp.compile(regex);
+ return regexp.test(path);
+ }
+
+ /**
+ * Checks if path refers to vaadin Notification element
+ * com.vaadin.ui.Notification.
+ *
+ * @param path
+ * to vaadin element
+ * @return true if path refers to Notification element, false otherwise
+ */
+ public static boolean isNotificationElement(String path) {
+ String regex = "^\\/{0,2}(com\\.vaadin\\.ui\\.)?V?Notification[\\/\\[]?";
+ RegExp regexp = RegExp.compile(regex);
+ return regexp.test(path);
+ }
}
diff --git a/client/src/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java b/client/src/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java
index a36ea1ac85..44bdeddff3 100644
--- a/client/src/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java
+++ b/client/src/com/vaadin/client/componentlocator/VaadinFinderLocatorStrategy.java
@@ -17,6 +17,7 @@ package com.vaadin.client.componentlocator;
import java.util.ArrayList;
import java.util.Arrays;
+import java.util.LinkedHashSet;
import java.util.List;
import com.google.gwt.dom.client.Document;
@@ -267,32 +268,6 @@ public class VaadinFinderLocatorStrategy implements LocatorStrategy {
return connectorHierarchy;
}
- private boolean isNotificationExpression(String path) {
- String[] starts = { "//", "/" };
-
- String[] frags = { "com.vaadin.ui.Notification.class",
- "com.vaadin.ui.Notification", "VNotification.class",
- "VNotification", "Notification.class", "Notification" };
-
- String[] ends = { "/", "[" };
-
- for (String s : starts) {
- for (String f : frags) {
- if (path.equals(s + f)) {
- return true;
- }
-
- for (String e : ends) {
- if (path.startsWith(s + f + e)) {
- return true;
- }
- }
- }
- }
-
- return false;
- }
-
/**
* {@inheritDoc}
*/
@@ -305,7 +280,7 @@ public class VaadinFinderLocatorStrategy implements LocatorStrategy {
}
List<Element> elements = new ArrayList<Element>();
- if (isNotificationExpression(path)) {
+ if (LocatorUtil.isNotificationElement(path)) {
for (VNotification n : findNotificationsByPath(path)) {
elements.add(n.getElement());
@@ -579,11 +554,19 @@ public class VaadinFinderLocatorStrategy implements LocatorStrategy {
ComponentConnector parent, String pathFragment,
boolean collectRecursively) {
ArrayList<ComponentConnector> potentialMatches = new ArrayList<ComponentConnector>();
+ String widgetName = getWidgetName(pathFragment);
+ // Special case when searching for UIElement.
+ if (LocatorUtil.isUIElement(pathFragment)) {
+ if (connectorMatchesPathFragment(parent, widgetName)) {
+ potentialMatches.add(parent);
+ }
+ }
if (parent instanceof HasComponentsConnector) {
+
List<ComponentConnector> children = ((HasComponentsConnector) parent)
.getChildComponents();
for (ComponentConnector child : children) {
- String widgetName = getWidgetName(pathFragment);
+
if (connectorMatchesPathFragment(child, widgetName)) {
potentialMatches.add(child);
}
@@ -744,19 +727,9 @@ public class VaadinFinderLocatorStrategy implements LocatorStrategy {
*/
private final <T> List<T> eliminateDuplicates(List<T> list) {
- int l = list.size();
- for (int j = 0; j < l; ++j) {
- T ref = list.get(j);
-
- for (int i = j + 1; i < l; ++i) {
- if (list.get(i) == ref) {
- list.remove(i);
- --i;
- --l;
- }
- }
- }
-
+ LinkedHashSet<T> set = new LinkedHashSet<T>(list);
+ list.clear();
+ list.addAll(set);
return list;
}
diff --git a/client/src/com/vaadin/client/debug/internal/theme/font.eot b/client/src/com/vaadin/client/debug/internal/theme/font.eot
index c2a63b3f08..cf38942e0a 100644..100755
--- a/client/src/com/vaadin/client/debug/internal/theme/font.eot
+++ b/client/src/com/vaadin/client/debug/internal/theme/font.eot
Binary files differ
diff --git a/client/src/com/vaadin/client/debug/internal/theme/font.svg b/client/src/com/vaadin/client/debug/internal/theme/font.svg
index 9d00e7b2fc..c5a97a6c8b 100644..100755
--- a/client/src/com/vaadin/client/debug/internal/theme/font.svg
+++ b/client/src/com/vaadin/client/debug/internal/theme/font.svg
@@ -3,34 +3,34 @@
<svg xmlns="http://www.w3.org/2000/svg">
<metadata>Generated by IcoMoon</metadata>
<defs>
-<font id="icomoon" horiz-adv-x="512">
-<font-face units-per-em="512" ascent="480" descent="-32" />
-<missing-glyph horiz-adv-x="512" />
-<glyph unicode="&#x20;" d="" horiz-adv-x="256" />
-<glyph unicode="&#xe600;" d="M381.186 86.878l-19.971 158.833c-5.863 46.622-48.723 84.419-95.716 84.419h-14.532c-47.001 0-89.858-37.817-95.716-84.419l-19.97-158.833c-1.436-11.424 6.727-20.682 18.243-20.682h209.425c11.51 0 19.677 9.259 18.24 20.682zM258.649 282.012c-0.247-0.002-0.88-0.024-1.846-0.089-1.701-0.113-3.619-0.303-5.697-0.592-5.904-0.816-11.787-2.227-17.148-4.329-4.881-1.913-9.060-4.299-12.364-7.148-2.764-2.384-5.232-5.065-7.418-7.995-3.359-4.502-5.904-9.371-7.723-14.231-0.628-1.681-1.117-3.22-1.477-4.573-0.119-0.443-0.212-0.821-0.316-1.281-1.186-6.304-7.257-10.453-13.564-9.268-6.304 1.186-10.453 7.257-9.268 13.564 0.127 0.667 0.355 1.684 0.705 2.995 0.548 2.050 1.262 4.301 2.161 6.703 2.546 6.805 6.097 13.6 10.862 19.983 3.173 4.252 6.786 8.176 10.868 11.697 5.449 4.699 11.878 8.372 19.062 11.185 7.233 2.832 14.846 4.657 22.436 5.708 2.645 0.366 5.115 0.613 7.35 0.759 1.398 0.092 2.451 0.131 3.103 0.139 6.414 0.075 11.675-5.065 11.752-11.479 0.077-6.412-5.062-11.675-11.476-11.75zM240.26 405.353c0-9.469 7.678-17.147 17.147-17.147s17.147 7.678 17.147 17.147v55.31c0 9.469-7.678 17.147-17.147 17.147s-17.147-7.678-17.147-17.147v-55.31zM382.291 357.86c-8.071-4.954-10.599-15.509-5.649-23.581s15.509-10.6 23.581-5.649l47.144 28.922c8.071 4.953 10.599 15.509 5.649 23.581-4.954 8.071-15.509 10.6-23.581 5.649l-47.144-28.921zM109.74 327.524c8.071-4.953 18.629-2.422 23.581 5.649 4.953 8.071 2.422 18.63-5.649 23.581l-47.144 28.921c-8.071 4.954-18.63 2.422-23.581-5.649-4.953-8.071-2.422-18.63 5.649-23.581l47.145-28.921zM146.053 49.625c-11.511 0-20.84-9.339-20.84-20.836v-30.617c0-11.507 9.314-20.836 20.84-20.836h222.163c11.51 0 20.841 9.339 20.841 20.836v30.617c0 11.507-9.313 20.836-20.841 20.836h-222.163z" horiz-adv-x="536" />
-<glyph unicode="&#xf002;" d="M329.143 242.286q0 52.857-37.572 90.428t-90.428 37.572-90.428-37.572-37.572-90.428 37.572-90.428 90.428-37.572 90.428 37.572 37.572 90.428zM475.428 4.572q0-14.857-10.857-25.714t-25.714-10.857q-15.428 0-25.714 10.857l-98 97.714q-51.143-35.428-114-35.428-40.857 0-78.143 15.857t-64.285 42.857-42.857 64.286-15.857 78.143 15.857 78.143 42.857 64.286 64.285 42.857 78.143 15.857 78.143-15.857 64.286-42.857 42.857-64.286 15.857-78.143q0-62.857-35.428-114l98-98q10.572-10.572 10.572-25.714z" horiz-adv-x="476" />
-<glyph unicode="&#xf00c;" d="M477.428 318.286q0-11.428-8-19.428l-245.714-245.714q-8-8-19.428-8t-19.428 8l-142.286 142.286q-8 8-8 19.428t8 19.428l38.857 38.857q8 8 19.428 8t19.428-8l84-84.286 187.429 187.714q8 8 19.428 8t19.428-8l38.857-38.857q8-8 8-19.429z" />
-<glyph unicode="&#xf00d;" d="M370.857 102.286q0-11.428-8-19.428l-38.857-38.857q-8-8-19.428-8t-19.428 8l-84 84-84-84q-8-8-19.428-8t-19.428 8l-38.857 38.857q-8 8-8 19.428t8 19.428l84 84-84 84q-8 8-8 19.428t8 19.428l38.857 38.857q8 8 19.428 8t19.428-8l84-84 84 84q8 8 19.428 8t19.428-8l38.857-38.857q8-8 8-19.428t-8-19.428l-84-84 84-84q8-8 8-19.428z" horiz-adv-x="403" />
-<glyph unicode="&#xf011;" d="M438.857 224q0-44.572-17.428-85.143t-46.857-70-70-46.857-85.143-17.428-85.143 17.428-70 46.857-46.857 70-17.428 85.143q0 52 23 98t64.715 77.143q12.285 9.143 27.285 7.143t23.857-14.286q9.143-12 7-27t-14.143-24.143q-28-21.143-43.285-51.714t-15.285-65.143q0-29.715 11.572-56.715t31.285-46.714 46.715-31.286 56.714-11.572 56.714 11.572 46.714 31.286 31.286 46.714 11.572 56.714q0 34.572-15.286 65.143t-43.286 51.714q-12 9.143-14.143 24.143t7 27q8.857 12.286 24 14.286t27.143-7.143q41.714-31.143 64.714-77.143t23-98zM256 443.428v-182.857q0-14.857-10.857-25.714t-25.715-10.857-25.714 10.857-10.857 25.714v182.857q0 14.857 10.857 25.715t25.714 10.857 25.714-10.857 10.857-25.715z" horiz-adv-x="439" />
-<glyph unicode="&#xf013;" d="M292.572 224q0 30.286-21.428 51.714t-51.714 21.428-51.714-21.428-21.428-51.714 21.428-51.714 51.714-21.428 51.714 21.428 21.428 51.714zM438.857 255.143v-63.429q0-3.428-2.286-6.572t-5.714-3.714l-52.857-8q-5.428-15.428-11.143-26 10-14.286 30.572-39.428 2.857-3.428 2.857-7.143t-2.572-6.572q-7.714-10.572-28.286-30.857t-26.857-20.286q-3.428 0-7.428 2.572l-39.428 30.857q-12.572-6.572-26-10.857-4.572-38.857-8.286-53.143-2-8-10.286-8h-63.428q-4 0-7 2.428t-3.286 6.143l-8 52.572q-14 4.572-25.714 10.572l-40.285-30.572q-2.857-2.572-7.143-2.572-4 0-7.143 3.143-36 32.572-47.143 48-2 2.857-2 6.572 0 3.428 2.285 6.572 4.285 6 14.572 19t15.428 20.143q-7.715 14.286-11.715 28.286l-52.285 7.714q-3.715 0.572-6 3.572t-2.285 6.714v63.428q0 3.429 2.285 6.572t5.428 3.714l53.143 8q4 13.143 11.143 26.286-11.428 16.286-30.572 39.428-2.857 3.429-2.857 6.857 0 2.857 2.572 6.571 7.428 10.286 28.143 30.714t27 20.429q3.715 0 7.428-2.857l39.428-30.572q12.572 6.572 26 10.857 4.572 38.857 8.286 53.143 2 8 10.286 8h63.428q4 0 7-2.428t3.286-6.143l8-52.572q14-4.572 25.714-10.572l40.572 30.572q2.572 2.572 6.857 2.572 3.714 0 7.143-2.857 36.857-34 47.143-48.572 2-2.285 2-6.285 0-3.429-2.286-6.572-4.286-6-14.572-19t-15.428-20.143q7.428-14.285 11.714-28l52.286-8q3.714-0.571 6-3.571t2.286-6.714z" horiz-adv-x="439" />
-<glyph unicode="&#xf014;" d="M146.286 269.714v-164.571q0-4-2.571-6.572t-6.571-2.572h-18.285q-4 0-6.572 2.572t-2.572 6.572v164.572q0 4 2.572 6.571t6.572 2.571h18.285q4 0 6.572-2.571t2.571-6.572zM219.429 269.714v-164.571q0-4-2.571-6.572t-6.572-2.572h-18.286q-4 0-6.572 2.572t-2.571 6.572v164.572q0 4 2.571 6.571t6.572 2.571h18.286q4 0 6.572-2.571t2.571-6.572zM292.572 269.714v-164.571q0-4-2.572-6.572t-6.572-2.572h-18.286q-4 0-6.572 2.572t-2.571 6.572v164.572q0 4 2.571 6.571t6.572 2.571h18.286q4 0 6.572-2.571t2.572-6.572zM329.143 62.857v270.857h-256v-270.857q0-6.286 2-11.572t4.143-7.714 3-2.428h237.715q0.857 0 3 2.428t4.143 7.714 2 11.572zM137.143 370.286h128l-13.714 33.428q-2 2.572-4.857 3.143h-90.571q-2.857-0.571-4.857-3.143zM402.286 361.143v-18.286q0-4-2.572-6.572t-6.572-2.571h-27.428v-270.857q0-23.714-13.428-41t-32.286-17.286h-237.714q-18.857 0-32.285 16.714t-13.428 40.428v272h-27.428q-4 0-6.572 2.572t-2.571 6.571v18.286q0 4 2.571 6.572t6.572 2.571h88.285l20 47.714q4.285 10.572 15.429 18t22.572 7.429h91.428q11.428 0 22.572-7.429t15.428-18l20-47.714h88.286q4 0 6.572-2.571t2.572-6.572z" horiz-adv-x="403" />
-<glyph unicode="&#xf017;" d="M310.857 214.857v-18.286q0-3.714-2.714-6.428t-6.428-2.714h-109.714q-3.714 0-6.428 2.714t-2.714 6.428v128q0 3.714 2.714 6.428t6.428 2.714h18.286q3.714 0 6.428-2.714t2.714-6.428v-100.572h82.286q3.714 0 6.428-2.714t2.714-6.428zM365.714 224q0 29.714-11.572 56.714t-31.286 46.714-46.714 31.286-56.714 11.571-56.714-11.571-46.715-31.286-31.285-46.714-11.572-56.714 11.572-56.714 31.285-46.714 46.715-31.286 56.714-11.572 56.714 11.572 46.714 31.286 31.286 46.714 11.572 56.714zM438.857 224q0-59.714-29.428-110.143t-79.857-79.857-110.143-29.428-110.143 29.428-79.857 79.857-29.428 110.143 29.428 110.143 79.857 79.857 110.143 29.428 110.143-29.428 79.857-79.857 29.428-110.143z" horiz-adv-x="439" />
-<glyph unicode="&#xf021;" d="M431.714 178.286q0-1.428-0.286-2-18.286-76.572-76.572-124.143t-136.571-47.572q-41.715 0-80.715 15.714t-69.572 44.857l-36.857-36.857q-5.428-5.428-12.857-5.428t-12.857 5.428-5.428 12.857v128q0 7.428 5.428 12.857t12.857 5.428h128q7.428 0 12.857-5.428t5.429-12.857-5.428-12.857l-39.143-39.143q20.285-18.857 46-29.143t53.429-10.286q38.286 0 71.428 18.572t53.143 51.143q3.143 4.857 15.143 33.428 2.286 6.572 8.572 6.572h54.857q3.714 0 6.428-2.714t2.714-6.428zM438.857 406.857v-128q0-7.428-5.428-12.857t-12.857-5.428h-128q-7.428 0-12.857 5.428t-5.428 12.857 5.428 12.857l39.428 39.428q-42.286 39.143-99.714 39.143-38.286 0-71.428-18.571t-53.143-51.143q-3.143-4.857-15.143-33.429-2.285-6.572-8.572-6.572h-56.857q-3.715 0-6.428 2.714t-2.715 6.428v2q18.572 76.572 77.143 124.143t137.143 47.571q41.714 0 81.143-15.857t70-44.714l37.143 36.857q5.428 5.428 12.857 5.428t12.857-5.428 5.428-12.857z" horiz-adv-x="439" />
-<glyph unicode="&#xf023;" d="M201.143 187.428q0 15.143-10.714 25.857t-25.857 10.714-25.857-10.714-10.714-25.857q0-10.572 5.429-19.143t14.572-13.428l-19.714-65.428q-1.428-4.286 1.429-8t7.429-3.714h54.857q4.571 0 7.429 3.714t1.429 8l-19.715 65.428q9.143 4.857 14.572 13.428t5.428 19.143zM91.428 260.572h146.286v54.857q0 30.286-21.428 51.714t-51.714 21.429-51.715-21.429-21.428-51.714v-54.857zM329.143 233.143v-164.571q0-11.428-8-19.428t-19.428-8h-274.286q-11.428 0-19.428 8t-8 19.428v164.571q0 11.429 8 19.429t19.428 8h9.143v54.857q0 52.572 37.715 90.286t90.285 37.714 90.285-37.714 37.714-90.286v-54.857h9.143q11.428 0 19.428-8t8-19.428z" horiz-adv-x="329" />
-<glyph unicode="&#xf02e;" d="M332.572 443.428q6.572 0 12.572-2.572 9.428-3.714 15-11.714t5.572-17.714v-368.286q0-9.714-5.572-17.714t-15-11.714q-5.428-2.286-12.572-2.286-13.714 0-23.714 9.143l-126 121.143-126-121.143q-10.285-9.428-23.715-9.428-6.572 0-12.572 2.572-9.428 3.714-15 11.714t-5.572 17.714v368.286q0 9.714 5.572 17.714t15 11.715q6 2.571 12.572 2.571h299.428z" horiz-adv-x="366" />
-<glyph unicode="&#xf05a;" d="M292.572 86.857v18.286q0 4-2.572 6.572t-6.572 2.572h-27.428v137.143q0 4-2.571 6.571t-6.571 2.571h-91.428q-4 0-6.572-2.571t-2.571-6.572v-18.286q0-4 2.571-6.572t6.572-2.571h27.428v-109.715h-27.428q-4 0-6.572-2.572t-2.571-6.572v-18.286q0-4 2.571-6.572t6.572-2.572h128q4 0 6.572 2.572t2.572 6.572zM256 306.286v54.857q0 4-2.571 6.571t-6.571 2.572h-54.857q-4 0-6.571-2.572t-2.571-6.571v-54.857q0-4 2.571-6.572t6.572-2.571h54.857q4 0 6.571 2.571t2.572 6.572zM438.857 224q0-59.714-29.428-110.143t-79.857-79.857-110.143-29.428-110.143 29.428-79.857 79.857-29.428 110.143 29.428 110.143 79.857 79.857 110.143 29.428 110.143-29.428 79.857-79.857 29.428-110.143z" horiz-adv-x="439" />
-<glyph unicode="&#xf05b;" d="M342 187.428h-31.143q-7.428 0-12.857 5.428t-5.428 12.857v36.572q0 7.428 5.428 12.857t12.857 5.429h31.143q-9.143 30.857-32.143 53.857t-53.857 32.143v-31.143q0-7.429-5.429-12.857t-12.857-5.428h-36.571q-7.428 0-12.857 5.428t-5.429 12.857v31.143q-30.857-9.143-53.857-32.143t-32.143-53.857h31.143q7.429 0 12.857-5.428t5.428-12.857v-36.571q0-7.428-5.428-12.857t-12.857-5.428h-31.143q9.143-30.857 32.143-53.857t53.857-32.143v31.143q0 7.428 5.428 12.857t12.857 5.428h36.571q7.428 0 12.857-5.428t5.429-12.857v-31.143q30.857 9.143 53.857 32.143t32.143 53.857zM438.857 242.286v-36.572q0-7.428-5.428-12.857t-12.857-5.428h-40.857q-10.572-46-44.143-79.572t-79.572-44.143v-40.857q0-7.428-5.428-12.857t-12.857-5.428h-36.571q-7.428 0-12.857 5.428t-5.429 12.857v40.857q-46 10.572-79.572 44.143t-44.143 79.572h-40.857q-7.428 0-12.857 5.428t-5.428 12.857v36.572q0 7.428 5.428 12.857t12.857 5.429h40.857q10.572 46 44.143 79.572t79.572 44.143v40.857q0 7.428 5.428 12.857t12.857 5.428h36.571q7.428 0 12.857-5.428t5.429-12.857v-40.857q46-10.571 79.572-44.143t44.143-79.572h40.857q7.428 0 12.857-5.428t5.428-12.857z" horiz-adv-x="439" />
-<glyph unicode="&#xf05e;" d="M365.714 224q0 39.714-20.286 74.286l-200.286-200.286q34.572-20.286 74.286-20.286 29.714 0 56.714 11.572t46.714 31.286 31.286 46.714 11.572 56.714zM93.428 149.714l200.286 200.286q-34.572 20.286-74.286 20.286-29.714 0-56.714-11.572t-46.715-31.286-31.285-46.714-11.572-56.714q0-39.714 20.285-74.286zM438.857 224q0-59.714-29.428-110.143t-79.857-79.857-110.143-29.428-110.143 29.428-79.857 79.857-29.428 110.143 29.428 110.143 79.857 79.857 110.143 29.428 110.143-29.428 79.857-79.857 29.428-110.143z" horiz-adv-x="439" />
-<glyph unicode="&#xf065;" d="M215.714 178.286q0-3.714-2.857-6.572l-94.857-94.857 41.143-41.143q5.429-5.428 5.429-12.857t-5.428-12.857-12.857-5.428h-128q-7.428 0-12.857 5.428t-5.428 12.857v128q0 7.428 5.428 12.857t12.857 5.428 12.857-5.428l41.143-41.143 94.857 94.857q2.857 2.857 6.572 2.857t6.572-2.857l32.572-32.572q2.857-2.857 2.857-6.572zM438.857 425.143v-128q0-7.429-5.428-12.857t-12.857-5.428-12.857 5.428l-41.143 41.143-94.857-94.857q-2.857-2.857-6.572-2.857t-6.572 2.857l-32.572 32.572q-2.857 2.857-2.857 6.572t2.857 6.572l94.857 94.857-41.143 41.143q-5.428 5.428-5.428 12.857t5.428 12.857 12.857 5.428h128q7.428 0 12.857-5.428t5.428-12.857z" horiz-adv-x="439" />
-<glyph unicode="&#xf066;" d="M219.429 205.714v-128q0-7.428-5.429-12.857t-12.857-5.428-12.857 5.428l-41.143 41.143-94.857-94.857q-2.857-2.857-6.572-2.857t-6.572 2.857l-32.572 32.572q-2.857 2.857-2.857 6.572t2.857 6.572l94.857 94.857-41.143 41.143q-5.428 5.428-5.428 12.857t5.428 12.857 12.857 5.428h128q7.428 0 12.857-5.428t5.429-12.857zM435.143 397.714q0-3.714-2.857-6.571l-94.857-94.857 41.143-41.143q5.428-5.429 5.428-12.857t-5.428-12.857-12.857-5.429h-128q-7.428 0-12.857 5.428t-5.429 12.857v128q0 7.429 5.428 12.857t12.857 5.428 12.857-5.428l41.143-41.143 94.857 94.857q2.857 2.857 6.572 2.857t6.572-2.857l32.572-32.572q2.857-2.857 2.857-6.572z" horiz-adv-x="439" />
-<glyph unicode="&#xf06a;" d="M219.429 443.428q59.715 0 110.143-29.428t79.857-79.857 29.428-110.143-29.428-110.143-79.857-79.857-110.143-29.428-110.143 29.428-79.857 79.857-29.428 110.143 29.428 110.143 79.857 79.857 110.143 29.428zM256 87.143v54.286q0 4-2.571 6.714t-6.286 2.714h-54.857q-3.714 0-6.572-2.857t-2.857-6.572v-54.286q0-3.714 2.857-6.572t6.572-2.857h54.857q3.714 0 6.286 2.714t2.571 6.714zM255.429 185.428l5.143 177.428q0 3.429-2.857 5.143-2.857 2.286-6.857 2.286h-62.857q-4 0-6.857-2.286-2.857-1.714-2.857-5.143l4.857-177.428q0-2.857 2.857-5t6.857-2.143h52.857q4 0 6.714 2.143t3 5z" horiz-adv-x="439" />
-<glyph unicode="&#xf071;" d="M292.572 87.143v54.286q0 4-2.714 6.714t-6.428 2.714h-54.857q-3.714 0-6.429-2.714t-2.714-6.714v-54.286q0-4 2.714-6.714t6.428-2.714h54.857q3.714 0 6.428 2.714t2.714 6.714zM292 194l5.143 131.143q0 3.428-2.857 5.428-3.714 3.143-6.857 3.143h-62.857q-3.143 0-6.857-3.143-2.857-2-2.857-6l4.857-130.572q0-2.857 2.857-4.714t6.857-1.857h52.857q4 0 6.714 1.857t3 4.714zM288 460.857l219.428-402.285q10-18-0.572-36-4.857-8.286-13.286-13.143t-18.143-4.857h-438.857q-9.715 0-18.143 4.857t-13.286 13.143q-10.572 18-0.572 36l219.429 402.286q4.857 8.857 13.429 14t18.572 5.143 18.572-5.143 13.428-14z" />
-<glyph unicode="&#xf0c9;" d="M438.857 96v-36.572q0-7.428-5.428-12.857t-12.857-5.428h-402.286q-7.428 0-12.857 5.428t-5.428 12.857v36.572q0 7.428 5.428 12.857t12.857 5.428h402.286q7.428 0 12.857-5.428t5.428-12.857zM438.857 242.286v-36.572q0-7.428-5.428-12.857t-12.857-5.428h-402.286q-7.428 0-12.857 5.428t-5.428 12.857v36.572q0 7.428 5.428 12.857t12.857 5.429h402.286q7.428 0 12.857-5.428t5.428-12.857zM438.857 388.572v-36.572q0-7.428-5.428-12.857t-12.857-5.429h-402.286q-7.428 0-12.857 5.428t-5.428 12.857v36.571q0 7.429 5.428 12.857t12.857 5.428h402.286q7.428 0 12.857-5.428t5.428-12.857z" horiz-adv-x="439" />
-<glyph unicode="&#xf0d0;" d="M340 314l83.714 83.714-30.572 30.572-83.714-83.714zM467.714 397.714q0-7.714-5.143-12.857l-367.428-367.428q-5.143-5.143-12.857-5.143t-12.857 5.143l-56.572 56.572q-5.143 5.143-5.143 12.857t5.143 12.857l367.428 367.428q5.143 5.143 12.857 5.143t12.857-5.143l56.572-56.572q5.143-5.143 5.143-12.857zM81.715 452l28-8.572-28-8.572-8.572-28-8.572 28-28 8.572 28 8.572 8.572 28zM181.714 405.714l56-17.143-56-17.143-17.143-56-17.143 56-56 17.143 56 17.143 17.143 56zM447.428 269.143l28-8.572-28-8.572-8.572-28-8.572 28-28 8.572 28 8.572 8.572 28zM264.572 452l28-8.572-28-8.572-8.572-28-8.572 28-28 8.572 28 8.572 8.572 28z" horiz-adv-x="476" />
-<glyph unicode="&#xf0e8;" d="M512 123.428v-91.428q0-11.428-8-19.428t-19.428-8h-91.428q-11.428 0-19.428 8t-8 19.428v91.428q0 11.428 8 19.428t19.428 8h27.428v54.857h-146.286v-54.857h27.428q11.428 0 19.428-8t8-19.428v-91.428q0-11.428-8-19.428t-19.428-8h-91.428q-11.428 0-19.428 8t-8 19.428v91.428q0 11.428 8 19.428t19.428 8h27.428v54.857h-146.286v-54.857h27.428q11.428 0 19.428-8t8-19.428v-91.428q0-11.428-8-19.428t-19.428-8h-91.428q-11.428 0-19.428 8t-8 19.428v91.428q0 11.428 8 19.428t19.428 8h27.428v54.857q0 14.857 10.857 25.714t25.715 10.857h146.286v54.857h-27.428q-11.428 0-19.428 8t-8 19.428v91.428q0 11.428 8 19.428t19.428 8h91.428q11.428 0 19.428-8t8-19.428v-91.428q0-11.428-8-19.428t-19.428-8h-27.428v-54.857h146.286q14.857 0 25.714-10.857t10.857-25.714v-54.857h27.428q11.428 0 19.428-8t8-19.428z" />
-<glyph unicode="&#xf0ec;" d="M512 141.714v-54.857q0-3.714-2.714-6.428t-6.428-2.714h-393.143v-54.857q0-3.714-2.715-6.428t-6.428-2.714q-3.428 0-6.857 2.857l-91.143 91.428q-2.571 2.572-2.571 6.286 0 4 2.571 6.572l91.428 91.428q2.572 2.572 6.572 2.572 3.715 0 6.428-2.714t2.715-6.428v-54.857h393.143q3.714 0 6.428-2.714t2.714-6.428zM512 297.143q0-4-2.572-6.572l-91.428-91.428q-2.572-2.572-6.572-2.572-3.714 0-6.428 2.714t-2.714 6.428v54.857h-393.143q-3.715 0-6.428 2.714t-2.715 6.429v54.857q0 3.714 2.715 6.428t6.428 2.714h393.143v54.857q0 4 2.572 6.571t6.572 2.572q3.428 0 6.857-2.857l91.143-91.143q2.572-2.571 2.572-6.572z" />
-<glyph unicode="&#xf0f0;" d="M109.715 96q0-7.428-5.428-12.857t-12.857-5.428-12.857 5.428-5.428 12.857 5.428 12.857 12.857 5.428 12.857-5.428 5.428-12.857zM402.286 78.572q0-34.572-20.857-54.286t-55.428-19.714h-249.714q-34.572 0-55.428 19.714t-20.857 54.286q0 19.428 1.571 37.428t6.857 39.428 13.572 37.857 23.143 29.428 34.285 17.286q-6.285-14.857-6.285-34.286v-58q-16.572-5.714-26.572-20t-10-31.714q0-22.857 16-38.857t38.857-16 38.857 16 16 38.857q0 17.428-10.143 31.714t-26.428 20v58q0 17.714 7.143 26.572 37.715-29.714 84.285-29.714t84.285 29.714q7.143-8.857 7.143-26.572v-18.286q-30.286 0-51.714-21.428t-21.428-51.714v-25.428q-9.143-8.286-9.143-20.286 0-11.428 8-19.428t19.429-8 19.428 8 8 19.428q0 12-9.143 20.286v25.428q0 14.857 10.857 25.714t25.714 10.857 25.714-10.857 10.857-25.714v-25.428q-9.143-8.286-9.143-20.286 0-11.428 8-19.428t19.428-8 19.428 8 8 19.428q0 12-9.143 20.286v25.428q0 19.428-9.857 36.428t-26.714 26.714q0 2.857 0.143 12.143t0 13.714-0.714 11.857-2 13.428-3.714 11.428q19.428-4.286 34.286-17.286t23.143-29.428 13.572-37.857 6.857-39.428 1.572-37.428zM310.857 333.714q0-45.428-32.143-77.572t-77.572-32.143-77.572 32.143-32.143 77.571 32.143 77.572 77.572 32.143 77.572-32.143 32.143-77.572z" horiz-adv-x="403" />
-<glyph unicode="&#xf10c;" d="M365.714 224q0 29.714-11.572 56.714t-31.286 46.714-46.714 31.286-56.714 11.571-56.714-11.571-46.715-31.286-31.285-46.714-11.572-56.714 11.572-56.714 31.285-46.714 46.715-31.286 56.714-11.572 56.714 11.572 46.714 31.286 31.286 46.714 11.572 56.714zM438.857 224q0-59.714-29.428-110.143t-79.857-79.857-110.143-29.428-110.143 29.428-79.857 79.857-29.428 110.143 29.428 110.143 79.857 79.857 110.143 29.428 110.143-29.428 79.857-79.857 29.428-110.143z" horiz-adv-x="439" />
-<glyph unicode="&#xf110;" d="M141.714 96q0-17.143-12.143-29.143t-29-12q-17.143 0-29.143 12t-12 29.143 12 29.143 29.143 12q16.857 0 29-12t12.143-29.143zM265.143 41.143q0-15.143-10.714-25.857t-25.857-10.714-25.857 10.714-10.714 25.857 10.714 25.857 25.857 10.714 25.857-10.714 10.714-25.857zM91.428 224q0-18.857-13.428-32.286t-32.285-13.428-32.285 13.428-13.428 32.286 13.428 32.286 32.285 13.428 32.285-13.428 13.428-32.286zM388.572 96q0-13.143-9.428-22.572t-22.572-9.428-22.572 9.428-9.428 22.572 9.428 22.572 22.572 9.428 22.572-9.428 9.428-22.572zM150.857 352q0-20.857-14.714-35.572t-35.572-14.714-35.572 14.714-14.715 35.572 14.715 35.572 35.572 14.714 35.572-14.714 14.714-35.572zM283.428 406.857q0-22.857-16-38.857t-38.857-16-38.857 16-16 38.857 16 38.857 38.857 16 38.857-16 16-38.857zM438.857 224q0-11.428-8-19.428t-19.428-8-19.428 8-8 19.428 8 19.428 19.428 8 19.428-8 8-19.428zM379.428 352q0-9.428-6.714-16.143t-16.143-6.714-16.143 6.714-6.714 16.143 6.714 16.143 16.143 6.714 16.143-6.714 6.714-16.143z" horiz-adv-x="448" />
-<glyph unicode="&#xf111;" d="M438.857 224q0-59.714-29.428-110.143t-79.857-79.857-110.143-29.428-110.143 29.428-79.857 79.857-29.428 110.143 29.428 110.143 79.857 79.857 110.143 29.428 110.143-29.428 79.857-79.857 29.428-110.143z" horiz-adv-x="439" />
+<font id="icomoon" horiz-adv-x="1024">
+<font-face units-per-em="1024" ascent="960" descent="-64" />
+<missing-glyph horiz-adv-x="1024" />
+<glyph unicode="&#x20;" d="" horiz-adv-x="512" />
+<glyph unicode="&#xe600;" d="M887.048 801.673c0 3.001-0.375 30.379-14.251 57.759-19.878 39.755-57.382 61.883-105.39 61.883h-113.641v10.876c0 0 0 26.254-26.254 26.254l-241.159-0.375c0 0-26.254 0-26.254-26.254v-10.876h-113.641c-3.001 0-30.379-0.375-58.134-14.251-39.381-20.628-61.509-58.134-61.134-106.14l1.125-742.979c0-3.001 0.375-30.379 14.251-57.759 19.878-39.755 57.382-61.509 105.39-61.509l520.948 0.75c3.001 0 30.379 0.375 58.134 14.251 39.755 19.878 61.509 57.382 61.509 105.39l-1.5 742.979zM797.787 14.815c-13.503-7.126-28.129-7.876-29.254-7.876l-520.573-0.75c-28.505 0-38.63 13.126-43.881 22.502-7.126 13.503-7.876 28.129-7.876 29.254l-1.5 742.603c0 28.505 12.751 38.63 22.502 43.881 13.503 7.126 28.129 7.876 29.254 7.876h113.266v-11.626c0 0 0-26.254 26.254-26.254l240.783 0.375c0 0 26.254 0 26.254 26.254v11.626h113.641c28.505 0 38.63-12.751 43.881-22.502 7.126-13.503 7.876-28.129 7.876-29.254l1.125-742.603c1.125-28.129-12.001-38.255-21.754-43.506zM706.274 588.269c0 0-20.252 20.252-40.881 0l-192.402-192.777-103.89 103.515c0 0-20.252 20.252-40.881 0l-31.505-31.505c0 0-20.252-20.252 0-40.881l156.022-155.272c0 0 7.876-7.876 19.127-9.002 6.751-0.75 14.251 1.5 21.754 9.002l244.16 244.909c0 0 20.252 20.252 0 40.881l-31.505 31.129z" horiz-adv-x="1072" />
+<glyph unicode="&#xf002;" d="M658.286 484.572q0 105.714-75.144 180.856t-180.856 75.144-180.856-75.144-75.144-180.856 75.144-180.856 180.856-75.144 180.856 75.144 75.144 180.856zM950.856 9.144q0-29.714-21.714-51.428t-51.428-21.714q-30.856 0-51.428 21.714l-196 195.428q-102.286-70.856-228-70.856-81.714 0-156.286 31.714t-128.57 85.714-85.714 128.572-31.714 156.286 31.714 156.286 85.714 128.572 128.57 85.714 156.286 31.714 156.286-31.714 128.572-85.714 85.714-128.572 31.714-156.286q0-125.714-70.856-228l196-196q21.144-21.144 21.144-51.428z" horiz-adv-x="952" />
+<glyph unicode="&#xf00c;" d="M954.856 636.572q0-22.856-16-38.856l-491.428-491.428q-16-16-38.856-16t-38.856 16l-284.572 284.572q-16 16-16 38.856t16 38.856l77.714 77.714q16 16 38.856 16t38.856-16l168-168.572 374.858 375.428q16 16 38.856 16t38.856-16l77.714-77.714q16-16 16-38.858z" />
+<glyph unicode="&#xf00d;" d="M741.714 204.572q0-22.856-16-38.856l-77.714-77.714q-16-16-38.856-16t-38.856 16l-168 168-168-168q-16-16-38.856-16t-38.856 16l-77.714 77.714q-16 16-16 38.856t16 38.856l168 168-168 168q-16 16-16 38.856t16 38.856l77.714 77.714q16 16 38.856 16t38.856-16l168-168 168 168q16 16 38.856 16t38.856-16l77.714-77.714q16-16 16-38.856t-16-38.856l-168-168 168-168q16-16 16-38.856z" horiz-adv-x="806" />
+<glyph unicode="&#xf011;" d="M877.714 448q0-89.144-34.856-170.286t-93.714-140-140-93.714-170.286-34.856-170.286 34.856-140 93.714-93.714 140-34.856 170.286q0 104 46 196t129.43 154.286q24.57 18.286 54.57 14.286t47.714-28.572q18.286-24 14-54t-28.286-48.286q-56-42.286-86.57-103.428t-30.57-130.286q0-59.43 23.144-113.43t62.57-93.428 93.43-62.572 113.428-23.144 113.428 23.144 93.428 62.572 62.572 93.428 23.144 113.428q0 69.144-30.572 130.286t-86.572 103.428q-24 18.286-28.286 48.286t14 54q17.714 24.572 48 28.572t54.286-14.286q83.428-62.286 129.428-154.286t46-196zM512 886.856v-365.714q0-29.714-21.714-51.428t-51.43-21.714-51.428 21.714-21.714 51.428v365.714q0 29.714 21.714 51.43t51.428 21.714 51.428-21.714 21.714-51.43z" horiz-adv-x="878" />
+<glyph unicode="&#xf013;" d="M585.144 448q0 60.572-42.856 103.428t-103.428 42.856-103.428-42.856-42.856-103.428 42.856-103.428 103.428-42.856 103.428 42.856 42.856 103.428zM877.714 510.286v-126.858q0-6.856-4.572-13.144t-11.428-7.428l-105.714-16q-10.856-30.856-22.286-52 20-28.572 61.144-78.856 5.714-6.856 5.714-14.286t-5.144-13.144q-15.428-21.144-56.572-61.714t-53.714-40.572q-6.856 0-14.856 5.144l-78.856 61.714q-25.144-13.144-52-21.714-9.144-77.714-16.572-106.286-4-16-20.572-16h-126.856q-8 0-14 4.856t-6.572 12.286l-16 105.144q-28 9.144-51.428 21.144l-80.57-61.144q-5.714-5.144-14.286-5.144-8 0-14.286 6.286-72 65.144-94.286 96-4 5.714-4 13.144 0 6.856 4.57 13.144 8.57 12 29.144 38t30.856 40.286q-15.43 28.572-23.43 56.572l-104.57 15.428q-7.43 1.144-12 7.144t-4.57 13.428v126.856q0 6.858 4.57 13.144t10.856 7.428l106.286 16q8 26.286 22.286 52.572-22.856 32.572-61.144 78.856-5.714 6.858-5.714 13.714 0 5.714 5.144 13.142 14.856 20.572 56.286 61.428t54 40.858q7.43 0 14.856-5.714l78.856-61.144q25.144 13.144 52 21.714 9.144 77.714 16.572 106.286 4 16 20.572 16h126.856q8 0 14-4.856t6.572-12.286l16-105.144q28-9.144 51.428-21.144l81.144 61.144q5.144 5.144 13.714 5.144 7.428 0 14.286-5.714 73.714-68 94.286-97.144 4-4.57 4-12.57 0-6.858-4.572-13.144-8.572-12-29.144-38t-30.856-40.286q14.856-28.57 23.428-56l104.572-16q7.428-1.142 12-7.142t4.572-13.428z" horiz-adv-x="878" />
+<glyph unicode="&#xf014;" d="M292.572 539.428v-329.142q0-8-5.142-13.144t-13.142-5.144h-36.57q-8 0-13.144 5.144t-5.144 13.144v329.144q0 8 5.144 13.142t13.144 5.142h36.57q8 0 13.144-5.142t5.142-13.144zM438.858 539.428v-329.142q0-8-5.142-13.144t-13.144-5.144h-36.572q-8 0-13.144 5.144t-5.142 13.144v329.144q0 8 5.142 13.142t13.144 5.142h36.572q8 0 13.144-5.142t5.142-13.144zM585.144 539.428v-329.142q0-8-5.144-13.144t-13.144-5.144h-36.572q-8 0-13.144 5.144t-5.142 13.144v329.144q0 8 5.142 13.142t13.144 5.142h36.572q8 0 13.144-5.142t5.144-13.144zM658.286 125.714v541.714h-512v-541.714q0-12.572 4-23.144t8.286-15.428 6-4.856h475.43q1.714 0 6 4.856t8.286 15.428 4 23.144zM274.286 740.572h256l-27.428 66.856q-4 5.144-9.714 6.286h-181.142q-5.714-1.142-9.714-6.286zM804.572 722.286v-36.572q0-8-5.144-13.144t-13.144-5.142h-54.856v-541.714q0-47.428-26.856-82t-64.572-34.572h-475.428q-37.714 0-64.57 33.428t-26.856 80.856v544h-54.856q-8 0-13.144 5.144t-5.142 13.142v36.572q0 8 5.142 13.144t13.144 5.142h176.57l40 95.428q8.57 21.144 30.858 36t45.144 14.858h182.856q22.856 0 45.144-14.858t30.856-36l40-95.428h176.572q8 0 13.144-5.142t5.144-13.144z" horiz-adv-x="806" />
+<glyph unicode="&#xf017;" d="M621.714 429.714v-36.572q0-7.428-5.428-12.856t-12.856-5.428h-219.428q-7.428 0-12.856 5.428t-5.428 12.856v256q0 7.428 5.428 12.856t12.856 5.428h36.572q7.428 0 12.856-5.428t5.428-12.856v-201.144h164.572q7.428 0 12.856-5.428t5.428-12.856zM731.428 448q0 59.428-23.144 113.428t-62.572 93.428-93.428 62.572-113.428 23.142-113.428-23.142-93.43-62.572-62.57-93.428-23.144-113.428 23.144-113.428 62.57-93.428 93.43-62.572 113.428-23.144 113.428 23.144 93.428 62.572 62.572 93.428 23.144 113.428zM877.714 448q0-119.428-58.856-220.286t-159.714-159.714-220.286-58.856-220.286 58.856-159.714 159.714-58.856 220.286 58.856 220.286 159.714 159.714 220.286 58.856 220.286-58.856 159.714-159.714 58.856-220.286z" horiz-adv-x="878" />
+<glyph unicode="&#xf021;" d="M863.428 356.572q0-2.856-0.572-4-36.572-153.144-153.144-248.286t-273.142-95.144q-83.43 0-161.43 31.428t-139.144 89.714l-73.714-73.714q-10.856-10.856-25.714-10.856t-25.714 10.856-10.856 25.714v256q0 14.856 10.856 25.714t25.714 10.856h256q14.856 0 25.714-10.856t10.858-25.714-10.856-25.714l-78.286-78.286q40.57-37.714 92-58.286t106.858-20.572q76.572 0 142.856 37.144t106.286 102.286q6.286 9.714 30.286 66.856 4.572 13.144 17.144 13.144h109.714q7.428 0 12.856-5.428t5.428-12.856zM877.714 813.714v-256q0-14.856-10.856-25.714t-25.714-10.856h-256q-14.856 0-25.714 10.856t-10.856 25.714 10.856 25.714l78.856 78.856q-84.572 78.286-199.428 78.286-76.572 0-142.856-37.142t-106.286-102.286q-6.286-9.714-30.286-66.858-4.57-13.144-17.144-13.144h-113.714q-7.43 0-12.856 5.428t-5.43 12.856v4q37.144 153.144 154.286 248.286t274.286 95.142q83.428 0 162.286-31.714t140-89.428l74.286 73.714q10.856 10.856 25.714 10.856t25.714-10.856 10.856-25.714z" horiz-adv-x="878" />
+<glyph unicode="&#xf023;" d="M402.286 374.856q0 30.286-21.428 51.714t-51.714 21.428-51.714-21.428-21.428-51.714q0-21.144 10.858-38.286t29.144-26.856l-39.428-130.856q-2.856-8.572 2.858-16t14.858-7.428h109.714q9.142 0 14.858 7.428t2.858 16l-39.43 130.856q18.286 9.714 29.144 26.856t10.856 38.286zM182.856 521.144h292.572v109.714q0 60.572-42.856 103.428t-103.428 42.858-103.43-42.858-42.856-103.428v-109.714zM658.286 466.286v-329.142q0-22.856-16-38.856t-38.856-16h-548.572q-22.856 0-38.856 16t-16 38.856v329.142q0 22.858 16 38.858t38.856 16h18.286v109.714q0 105.144 75.43 180.572t180.57 75.428 180.57-75.428 75.428-180.572v-109.714h18.286q22.856 0 38.856-16t16-38.856z" horiz-adv-x="658" />
+<glyph unicode="&#xf02e;" d="M665.144 886.856q13.144 0 25.144-5.144 18.856-7.428 30-23.428t11.144-35.428v-736.572q0-19.428-11.144-35.428t-30-23.428q-10.856-4.572-25.144-4.572-27.428 0-47.428 18.286l-252 242.286-252-242.286q-20.57-18.856-47.43-18.856-13.144 0-25.144 5.144-18.856 7.428-30 23.428t-11.144 35.428v736.572q0 19.428 11.144 35.428t30 23.43q12 5.142 25.144 5.142h598.856z" horiz-adv-x="732" />
+<glyph unicode="&#xf05a;" d="M585.144 173.714v36.572q0 8-5.144 13.144t-13.144 5.144h-54.856v274.286q0 8-5.142 13.142t-13.142 5.142h-182.856q-8 0-13.144-5.142t-5.142-13.144v-36.572q0-8 5.142-13.144t13.144-5.142h54.856v-219.43h-54.856q-8 0-13.144-5.144t-5.142-13.144v-36.572q0-8 5.142-13.144t13.144-5.144h256q8 0 13.144 5.144t5.144 13.144zM512 612.572v109.714q0 8-5.142 13.142t-13.142 5.144h-109.714q-8 0-13.142-5.144t-5.142-13.142v-109.714q0-8 5.142-13.144t13.144-5.142h109.714q8 0 13.142 5.142t5.144 13.144zM877.714 448q0-119.428-58.856-220.286t-159.714-159.714-220.286-58.856-220.286 58.856-159.714 159.714-58.856 220.286 58.856 220.286 159.714 159.714 220.286 58.856 220.286-58.856 159.714-159.714 58.856-220.286z" horiz-adv-x="878" />
+<glyph unicode="&#xf05b;" d="M684 374.856h-62.286q-14.856 0-25.714 10.856t-10.856 25.714v73.144q0 14.856 10.856 25.714t25.714 10.858h62.286q-18.286 61.714-64.286 107.714t-107.714 64.286v-62.286q0-14.858-10.858-25.714t-25.714-10.856h-73.142q-14.856 0-25.714 10.856t-10.858 25.714v62.286q-61.714-18.286-107.714-64.286t-64.286-107.714h62.286q14.858 0 25.714-10.856t10.856-25.714v-73.142q0-14.856-10.856-25.714t-25.714-10.856h-62.286q18.286-61.714 64.286-107.714t107.714-64.286v62.286q0 14.856 10.856 25.714t25.714 10.856h73.142q14.856 0 25.714-10.856t10.858-25.714v-62.286q61.714 18.286 107.714 64.286t64.286 107.714zM877.714 484.572v-73.144q0-14.856-10.856-25.714t-25.714-10.856h-81.714q-21.144-92-88.286-159.144t-159.144-88.286v-81.714q0-14.856-10.856-25.714t-25.714-10.856h-73.142q-14.856 0-25.714 10.856t-10.858 25.714v81.714q-92 21.144-159.144 88.286t-88.286 159.144h-81.714q-14.856 0-25.714 10.856t-10.856 25.714v73.144q0 14.856 10.856 25.714t25.714 10.858h81.714q21.144 92 88.286 159.144t159.144 88.286v81.714q0 14.856 10.856 25.714t25.714 10.856h73.142q14.856 0 25.714-10.856t10.858-25.714v-81.714q92-21.142 159.144-88.286t88.286-159.144h81.714q14.856 0 25.714-10.856t10.856-25.714z" horiz-adv-x="878" />
+<glyph unicode="&#xf05e;" d="M731.428 448q0 79.428-40.572 148.572l-400.572-400.572q69.144-40.572 148.572-40.572 59.428 0 113.428 23.144t93.428 62.572 62.572 93.428 23.144 113.428zM186.856 299.428l400.572 400.572q-69.144 40.572-148.572 40.572-59.428 0-113.428-23.144t-93.43-62.572-62.57-93.428-23.144-113.428q0-79.428 40.57-148.572zM877.714 448q0-119.428-58.856-220.286t-159.714-159.714-220.286-58.856-220.286 58.856-159.714 159.714-58.856 220.286 58.856 220.286 159.714 159.714 220.286 58.856 220.286-58.856 159.714-159.714 58.856-220.286z" horiz-adv-x="878" />
+<glyph unicode="&#xf065;" d="M431.428 356.572q0-7.428-5.714-13.144l-189.714-189.714 82.286-82.286q10.858-10.856 10.858-25.714t-10.856-25.714-25.714-10.856h-256q-14.856 0-25.714 10.856t-10.856 25.714v256q0 14.856 10.856 25.714t25.714 10.856 25.714-10.856l82.286-82.286 189.714 189.714q5.714 5.714 13.144 5.714t13.144-5.714l65.144-65.144q5.714-5.714 5.714-13.144zM877.714 850.286v-256q0-14.858-10.856-25.714t-25.714-10.856-25.714 10.856l-82.286 82.286-189.714-189.714q-5.714-5.714-13.144-5.714t-13.144 5.714l-65.144 65.144q-5.714 5.714-5.714 13.144t5.714 13.144l189.714 189.714-82.286 82.286q-10.856 10.856-10.856 25.714t10.856 25.714 25.714 10.856h256q14.856 0 25.714-10.856t10.856-25.714z" horiz-adv-x="878" />
+<glyph unicode="&#xf066;" d="M438.858 411.428v-256q0-14.856-10.858-25.714t-25.714-10.856-25.714 10.856l-82.286 82.286-189.714-189.714q-5.714-5.714-13.144-5.714t-13.144 5.714l-65.144 65.144q-5.714 5.714-5.714 13.144t5.714 13.144l189.714 189.714-82.286 82.286q-10.856 10.856-10.856 25.714t10.856 25.714 25.714 10.856h256q14.856 0 25.714-10.856t10.858-25.714zM870.286 795.428q0-7.428-5.714-13.142l-189.714-189.714 82.286-82.286q10.856-10.858 10.856-25.714t-10.856-25.714-25.714-10.858h-256q-14.856 0-25.714 10.856t-10.858 25.714v256q0 14.858 10.856 25.714t25.714 10.856 25.714-10.856l82.286-82.286 189.714 189.714q5.714 5.714 13.144 5.714t13.144-5.714l65.144-65.144q5.714-5.714 5.714-13.144z" horiz-adv-x="878" />
+<glyph unicode="&#xf06a;" d="M438.858 886.856q119.43 0 220.286-58.856t159.714-159.714 58.856-220.286-58.856-220.286-159.714-159.714-220.286-58.856-220.286 58.856-159.714 159.714-58.856 220.286 58.856 220.286 159.714 159.714 220.286 58.856zM512 174.286v108.572q0 8-5.142 13.428t-12.572 5.428h-109.714q-7.428 0-13.144-5.714t-5.714-13.144v-108.572q0-7.428 5.714-13.144t13.144-5.714h109.714q7.428 0 12.572 5.428t5.142 13.428zM510.858 370.856l10.286 354.856q0 6.858-5.714 10.286-5.714 4.572-13.714 4.572h-125.714q-8 0-13.714-4.572-5.714-3.428-5.714-10.286l9.714-354.856q0-5.714 5.714-10t13.714-4.286h105.714q8 0 13.428 4.286t6 10z" horiz-adv-x="878" />
+<glyph unicode="&#xf071;" d="M585.144 174.286v108.572q0 8-5.428 13.428t-12.856 5.428h-109.714q-7.428 0-12.858-5.428t-5.428-13.428v-108.572q0-8 5.428-13.428t12.856-5.428h109.714q7.428 0 12.856 5.428t5.428 13.428zM584 388l10.286 262.286q0 6.856-5.714 10.856-7.428 6.286-13.714 6.286h-125.714q-6.286 0-13.714-6.286-5.714-4-5.714-12l9.714-261.144q0-5.714 5.714-9.428t13.714-3.714h105.714q8 0 13.428 3.714t6 9.428zM576 921.714l438.856-804.57q20-36-1.144-72-9.714-16.572-26.572-26.286t-36.286-9.714h-877.714q-19.43 0-36.286 9.714t-26.572 26.286q-21.144 36-1.144 72l438.858 804.572q9.714 17.714 26.858 28t37.144 10.286 37.144-10.286 26.856-28z" />
+<glyph unicode="&#xf0c9;" d="M877.714 192v-73.144q0-14.856-10.856-25.714t-25.714-10.856h-804.572q-14.856 0-25.714 10.856t-10.856 25.714v73.144q0 14.856 10.856 25.714t25.714 10.856h804.572q14.856 0 25.714-10.856t10.856-25.714zM877.714 484.572v-73.144q0-14.856-10.856-25.714t-25.714-10.856h-804.572q-14.856 0-25.714 10.856t-10.856 25.714v73.144q0 14.856 10.856 25.714t25.714 10.858h804.572q14.856 0 25.714-10.856t10.856-25.714zM877.714 777.144v-73.144q0-14.856-10.856-25.714t-25.714-10.858h-804.572q-14.856 0-25.714 10.856t-10.856 25.714v73.142q0 14.858 10.856 25.714t25.714 10.856h804.572q14.856 0 25.714-10.856t10.856-25.714z" horiz-adv-x="878" />
+<glyph unicode="&#xf0d0;" d="M680 628l167.428 167.428-61.144 61.144-167.428-167.428zM935.428 795.428q0-15.428-10.286-25.714l-734.856-734.856q-10.286-10.286-25.714-10.286t-25.714 10.286l-113.144 113.144q-10.286 10.286-10.286 25.714t10.286 25.714l734.856 734.856q10.286 10.286 25.714 10.286t25.714-10.286l113.144-113.144q10.286-10.286 10.286-25.714zM163.43 904l56-17.144-56-17.144-17.144-56-17.144 56-56 17.144 56 17.144 17.144 56zM363.428 811.428l112-34.286-112-34.286-34.286-112-34.286 112-112 34.286 112 34.286 34.286 112zM894.856 538.286l56-17.144-56-17.144-17.144-56-17.144 56-56 17.144 56 17.144 17.144 56zM529.144 904l56-17.144-56-17.144-17.144-56-17.144 56-56 17.144 56 17.144 17.144 56z" horiz-adv-x="952" />
+<glyph unicode="&#xf0e8;" d="M1024 246.856v-182.856q0-22.856-16-38.856t-38.856-16h-182.856q-22.856 0-38.856 16t-16 38.856v182.856q0 22.856 16 38.856t38.856 16h54.856v109.714h-292.572v-109.714h54.856q22.856 0 38.856-16t16-38.856v-182.856q0-22.856-16-38.856t-38.856-16h-182.856q-22.856 0-38.856 16t-16 38.856v182.856q0 22.856 16 38.856t38.856 16h54.856v109.714h-292.572v-109.714h54.856q22.856 0 38.856-16t16-38.856v-182.856q0-22.856-16-38.856t-38.856-16h-182.856q-22.856 0-38.856 16t-16 38.856v182.856q0 22.856 16 38.856t38.856 16h54.856v109.714q0 29.714 21.714 51.428t51.43 21.714h292.572v109.714h-54.856q-22.856 0-38.856 16t-16 38.856v182.856q0 22.856 16 38.856t38.856 16h182.856q22.856 0 38.856-16t16-38.856v-182.856q0-22.856-16-38.856t-38.856-16h-54.856v-109.714h292.572q29.714 0 51.428-21.714t21.714-51.428v-109.714h54.856q22.856 0 38.856-16t16-38.856z" />
+<glyph unicode="&#xf0ec;" d="M1024 283.428v-109.714q0-7.428-5.428-12.856t-12.856-5.428h-786.286v-109.714q0-7.428-5.43-12.856t-12.856-5.428q-6.856 0-13.714 5.714l-182.286 182.856q-5.142 5.144-5.142 12.572 0 8 5.142 13.144l182.856 182.856q5.144 5.144 13.144 5.144 7.43 0 12.856-5.428t5.43-12.856v-109.714h786.286q7.428 0 12.856-5.428t5.428-12.856zM1024 594.286q0-8-5.144-13.144l-182.856-182.856q-5.144-5.144-13.144-5.144-7.428 0-12.856 5.428t-5.428 12.856v109.714h-786.286q-7.43 0-12.856 5.428t-5.43 12.858v109.714q0 7.428 5.43 12.856t12.856 5.428h786.286v109.714q0 8 5.144 13.142t13.144 5.144q6.856 0 13.714-5.714l182.286-182.286q5.144-5.142 5.144-13.144z" />
+<glyph unicode="&#xf0f0;" d="M219.43 192q0-14.856-10.856-25.714t-25.714-10.856-25.714 10.856-10.856 25.714 10.856 25.714 25.714 10.856 25.714-10.856 10.856-25.714zM804.572 157.144q0-69.144-41.714-108.572t-110.856-39.428h-499.428q-69.144 0-110.856 39.428t-41.714 108.572q0 38.856 3.142 74.856t13.714 78.856 27.144 75.714 46.286 58.856 68.57 34.572q-12.57-29.714-12.57-68.572v-116q-33.144-11.428-53.144-40t-20-63.428q0-45.714 32-77.714t77.714-32 77.714 32 32 77.714q0 34.856-20.286 63.428t-52.856 40v116q0 35.428 14.286 53.144 75.43-59.428 168.57-59.428t168.57 59.428q14.286-17.714 14.286-53.144v-36.572q-60.572 0-103.428-42.856t-42.856-103.428v-50.856q-18.286-16.572-18.286-40.572 0-22.856 16-38.856t38.858-16 38.856 16 16 38.856q0 24-18.286 40.572v50.856q0 29.714 21.714 51.428t51.428 21.714 51.428-21.714 21.714-51.428v-50.856q-18.286-16.572-18.286-40.572 0-22.856 16-38.856t38.856-16 38.856 16 16 38.856q0 24-18.286 40.572v50.856q0 38.856-19.714 72.856t-53.428 53.428q0 5.714 0.286 24.286t0 27.428-1.428 23.714-4 26.856-7.428 22.856q38.856-8.572 68.572-34.572t46.286-58.856 27.144-75.714 13.714-78.856 3.144-74.856zM621.714 667.428q0-90.856-64.286-155.144t-155.144-64.286-155.144 64.286-64.286 155.142 64.286 155.144 155.144 64.286 155.144-64.286 64.286-155.144z" horiz-adv-x="806" />
+<glyph unicode="&#xf10c;" d="M731.428 448q0 59.428-23.144 113.428t-62.572 93.428-93.428 62.572-113.428 23.142-113.428-23.142-93.43-62.572-62.57-93.428-23.144-113.428 23.144-113.428 62.57-93.428 93.43-62.572 113.428-23.144 113.428 23.144 93.428 62.572 62.572 93.428 23.144 113.428zM877.714 448q0-119.428-58.856-220.286t-159.714-159.714-220.286-58.856-220.286 58.856-159.714 159.714-58.856 220.286 58.856 220.286 159.714 159.714 220.286 58.856 220.286-58.856 159.714-159.714 58.856-220.286z" horiz-adv-x="878" />
+<glyph unicode="&#xf110;" d="M283.428 192q0-34.286-24.286-58.286t-58-24q-34.286 0-58.286 24t-24 58.286 24 58.286 58.286 24q33.714 0 58-24t24.286-58.286zM530.286 82.286q0-30.286-21.428-51.714t-51.714-21.428-51.714 21.428-21.428 51.714 21.428 51.714 51.714 21.428 51.714-21.428 21.428-51.714zM182.856 448q0-37.714-26.856-64.572t-64.57-26.856-64.57 26.856-26.856 64.572 26.856 64.572 64.57 26.856 64.57-26.856 26.856-64.572zM777.144 192q0-26.286-18.856-45.144t-45.144-18.856-45.144 18.856-18.856 45.144 18.856 45.144 45.144 18.856 45.144-18.856 18.856-45.144zM301.714 704q0-41.714-29.428-71.144t-71.144-29.428-71.144 29.428-29.43 71.144 29.43 71.144 71.144 29.428 71.144-29.428 29.428-71.144zM566.856 813.714q0-45.714-32-77.714t-77.714-32-77.714 32-32 77.714 32 77.714 77.714 32 77.714-32 32-77.714zM877.714 448q0-22.856-16-38.856t-38.856-16-38.856 16-16 38.856 16 38.856 38.856 16 38.856-16 16-38.856zM758.856 704q0-18.856-13.428-32.286t-32.286-13.428-32.286 13.428-13.428 32.286 13.428 32.286 32.286 13.428 32.286-13.428 13.428-32.286z" horiz-adv-x="896" />
+<glyph unicode="&#xf111;" d="M877.714 448q0-119.428-58.856-220.286t-159.714-159.714-220.286-58.856-220.286 58.856-159.714 159.714-58.856 220.286 58.856 220.286 159.714 159.714 220.286 58.856 220.286-58.856 159.714-159.714 58.856-220.286z" horiz-adv-x="878" />
</font></defs></svg> \ No newline at end of file
diff --git a/client/src/com/vaadin/client/debug/internal/theme/font.ttf b/client/src/com/vaadin/client/debug/internal/theme/font.ttf
index eee808e07e..734e69ac3f 100644..100755
--- a/client/src/com/vaadin/client/debug/internal/theme/font.ttf
+++ b/client/src/com/vaadin/client/debug/internal/theme/font.ttf
Binary files differ
diff --git a/client/src/com/vaadin/client/debug/internal/theme/font.woff b/client/src/com/vaadin/client/debug/internal/theme/font.woff
index 2cd069ffdf..a9e6d5576b 100644..100755
--- a/client/src/com/vaadin/client/debug/internal/theme/font.woff
+++ b/client/src/com/vaadin/client/debug/internal/theme/font.woff
Binary files differ
diff --git a/client/src/com/vaadin/client/ui/VCalendar.java b/client/src/com/vaadin/client/ui/VCalendar.java
index f0f1bc89ca..c59a78108c 100644
--- a/client/src/com/vaadin/client/ui/VCalendar.java
+++ b/client/src/com/vaadin/client/ui/VCalendar.java
@@ -588,7 +588,7 @@ public class VCalendar extends Composite implements VHasDropHandler {
int x = pos - (y * columns);
if (x == 0 && daysCount > 7) {
// Add week to weekToolbar for navigation
- weekToolbar.addWeek(week, d.getYear());
+ weekToolbar.addWeek(week, day.getYearOfWeek());
}
final SimpleDayCell cell = new SimpleDayCell(this, y, x);
cell.setMonthGrid(monthGrid);
diff --git a/client/src/com/vaadin/client/ui/VContextMenu.java b/client/src/com/vaadin/client/ui/VContextMenu.java
index 1b0181fb7d..fa6d67fc0c 100644
--- a/client/src/com/vaadin/client/ui/VContextMenu.java
+++ b/client/src/com/vaadin/client/ui/VContextMenu.java
@@ -143,6 +143,9 @@ public class VContextMenu extends VOverlay implements SubPartAware {
// context menu is closed
focusedElement = Util.getFocusedElement();
+ // reset height (if it has been previously set explicitly)
+ setHeight("");
+
setPopupPositionAndShow(new PositionCallback() {
@Override
public void setPosition(int offsetWidth, int offsetHeight) {
@@ -158,12 +161,10 @@ public class VContextMenu extends VOverlay implements SubPartAware {
}
}
if (offsetHeight + top > Window.getClientHeight()) {
- top = top - offsetHeight;
- if (top < 0) {
- top = 0;
-
- setHeight(Window.getClientHeight() + "px");
- }
+ top = Math.max(0, Window.getClientHeight() - offsetHeight);
+ }
+ if (top == 0) {
+ setHeight(Window.getClientHeight() + "px");
}
setPopupPosition(left, top);
diff --git a/client/src/com/vaadin/client/ui/VMenuBar.java b/client/src/com/vaadin/client/ui/VMenuBar.java
index 4a090899f9..5102e6faea 100644
--- a/client/src/com/vaadin/client/ui/VMenuBar.java
+++ b/client/src/com/vaadin/client/ui/VMenuBar.java
@@ -245,7 +245,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* This is called by the items in the menu and it communicates the
* information to the server
- *
+ *
* @param clickedItemId
* id of the item that was clicked
*/
@@ -282,7 +282,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Returns the containing element of the menu
- *
+ *
* @return
*/
@Override
@@ -292,7 +292,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Add a new item to this menu
- *
+ *
* @param html
* items text
* @param cmd
@@ -309,7 +309,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Add a new item to this menu
- *
+ *
* @param item
*/
public void addItem(CustomMenuItem item) {
@@ -334,7 +334,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Remove the given item from this menu
- *
+ *
* @param item
*/
public void removeItem(CustomMenuItem item) {
@@ -431,7 +431,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* When an item is clicked
- *
+ *
* @param item
*/
public void itemClick(CustomMenuItem item) {
@@ -462,7 +462,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* When the user hovers the mouse over the item
- *
+ *
* @param item
*/
public void itemOver(CustomMenuItem item) {
@@ -487,7 +487,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* When the mouse is moved away from an item
- *
+ *
* @param item
*/
public void itemOut(CustomMenuItem item) {
@@ -545,7 +545,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Shows the child menu of an item. The caller must ensure that the item has
* a submenu.
- *
+ *
* @param item
*/
public void showChildMenu(CustomMenuItem item) {
@@ -667,7 +667,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Hides the submenu of an item
- *
+ *
* @param item
*/
public void hideChildMenu(CustomMenuItem item) {
@@ -731,7 +731,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Returns the parent menu of this menu, or null if this is the top-level
* menu
- *
+ *
* @return
*/
public VMenuBar getParentMenu() {
@@ -740,7 +740,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Set the parent menu of this menu
- *
+ *
* @param parent
*/
public void setParentMenu(VMenuBar parent) {
@@ -750,7 +750,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Returns the currently selected item of this menu, or null if nothing is
* selected
- *
+ *
* @return
*/
public CustomMenuItem getSelected() {
@@ -759,7 +759,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Set the currently selected item of this menu
- *
+ *
* @param item
*/
public void setSelected(CustomMenuItem item) {
@@ -776,9 +776,9 @@ public class VMenuBar extends SimpleFocusablePanel implements
}
/**
- *
+ *
* A class to hold information on menu items
- *
+ *
*/
public static class CustomMenuItem extends Widget implements HasHTML {
@@ -797,7 +797,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Default menu item {@link Widget} constructor for GWT.create().
- *
+ *
* Use {@link #setHTML(String)} and {@link #setCommand(Command)} after
* constructing a menu item.
*/
@@ -807,7 +807,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Creates a menu item {@link Widget}.
- *
+ *
* @param html
* @param cmd
* @deprecated use the default constructor and {@link #setHTML(String)}
@@ -1041,7 +1041,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Checks if the item can be selected.
- *
+ *
* @return true if it is possible to select this item, false otherwise
*/
public boolean isSelectable() {
@@ -1200,7 +1200,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
* Get the key that moves the selection upwards. By default it is the up
* arrow key but by overriding this you can change the key to whatever you
* want.
- *
+ *
* @return The keycode of the key
*/
protected int getNavigationUpKey() {
@@ -1211,7 +1211,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
* Get the key that moves the selection downwards. By default it is the down
* arrow key but by overriding this you can change the key to whatever you
* want.
- *
+ *
* @return The keycode of the key
*/
protected int getNavigationDownKey() {
@@ -1222,7 +1222,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
* Get the key that moves the selection left. By default it is the left
* arrow key but by overriding this you can change the key to whatever you
* want.
- *
+ *
* @return The keycode of the key
*/
protected int getNavigationLeftKey() {
@@ -1233,7 +1233,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
* Get the key that moves the selection right. By default it is the right
* arrow key but by overriding this you can change the key to whatever you
* want.
- *
+ *
* @return The keycode of the key
*/
protected int getNavigationRightKey() {
@@ -1243,7 +1243,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Get the key that selects a menu item. By default it is the Enter key but
* by overriding this you can change the key to whatever you want.
- *
+ *
* @deprecated use {@link #isNavigationSelectKey(int)} instead
* @return
*/
@@ -1256,7 +1256,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
* Checks whether key code selects a menu item. By default it is the Enter
* and Space keys but by overriding this you can change the keys to whatever
* you want.
- *
+ *
* @since 7.2
* @param keycode
* @return true if key selects menu item
@@ -1269,7 +1269,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Get the key that closes the menu. By default it is the escape key but by
* overriding this yoy can change the key to whatever you want.
- *
+ *
* @return
*/
protected int getCloseMenuKey() {
@@ -1278,7 +1278,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Handles the keyboard events handled by the MenuBar
- *
+ *
* @param event
* The keyboard event received
* @return true iff the navigation event was handled
@@ -1565,12 +1565,31 @@ public class VMenuBar extends SimpleFocusablePanel implements
private boolean isItemNamed(CustomMenuItem item, String name) {
Element lastChildElement = getLastChildElement(item);
- if (lastChildElement.getInnerText().equals(name)) {
+ if (getText(lastChildElement).equals(name)) {
return true;
}
return false;
}
+ /*
+ * Returns the text content of element without including the text of
+ * possible nested elements. It is assumed that the last child of element
+ * contains the text of interest and that the last child does not itself
+ * have children with text content. This method is used by
+ * getSubPartElement(String) so that possible text icons are not included in
+ * the textual matching (#14879).
+ */
+ private native String getText(Element element)
+ /*-{
+ var n = element.childNodes.length;
+ if(n > 0){
+ return element.childNodes[n - 1].nodeValue;
+ }
+ else{
+ return "";
+ }
+ }-*/;
+
private Element getLastChildElement(CustomMenuItem item) {
Element lastChildElement = item.getElement().getFirstChildElement();
while (lastChildElement.getNextSiblingElement() != null) {
@@ -1604,7 +1623,7 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Get menu item with given DOM element
- *
+ *
* @param element
* Element used in search
* @return Menu item or null if not found
@@ -1633,11 +1652,11 @@ public class VMenuBar extends SimpleFocusablePanel implements
/**
* Get menu item with given DOM element
- *
+ *
* @param element
* Element used in search
* @return Menu item or null if not found
- *
+ *
* @since 7.2
*/
public CustomMenuItem getMenuItemWithElement(Element element) {
diff --git a/client/src/com/vaadin/client/ui/VOverlay.java b/client/src/com/vaadin/client/ui/VOverlay.java
index afa13dc337..dfd81faf94 100644
--- a/client/src/com/vaadin/client/ui/VOverlay.java
+++ b/client/src/com/vaadin/client/ui/VOverlay.java
@@ -79,6 +79,18 @@ import com.vaadin.client.Util;
*/
public class VOverlay extends PopupPanel implements CloseHandler<PopupPanel> {
+ @Override
+ protected void onAttach() {
+ // Move the overlay to the appropriate overlay container
+ final VOverlay overlay = VOverlay.current;
+ if (overlay != null) {
+ final Element e = overlay.getOverlayContainer();
+ e.appendChild(getElement());
+ }
+
+ super.onAttach();
+ }
+
public static class PositionAndSize {
private int left, top, width, height;
@@ -1061,4 +1073,5 @@ public class VOverlay extends PopupPanel implements CloseHandler<PopupPanel> {
}
}
}
+
}
diff --git a/client/src/com/vaadin/client/ui/VPopupCalendar.java b/client/src/com/vaadin/client/ui/VPopupCalendar.java
index 51b2ee22ec..fbd66cff09 100644
--- a/client/src/com/vaadin/client/ui/VPopupCalendar.java
+++ b/client/src/com/vaadin/client/ui/VPopupCalendar.java
@@ -27,6 +27,10 @@ import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.dom.client.DomEvent;
import com.google.gwt.event.dom.client.KeyCodes;
+import com.google.gwt.event.dom.client.MouseOutEvent;
+import com.google.gwt.event.dom.client.MouseOutHandler;
+import com.google.gwt.event.dom.client.MouseOverEvent;
+import com.google.gwt.event.dom.client.MouseOverHandler;
import com.google.gwt.event.logical.shared.CloseEvent;
import com.google.gwt.event.logical.shared.CloseHandler;
import com.google.gwt.i18n.client.DateTimeFormat;
@@ -60,7 +64,8 @@ import com.vaadin.shared.ui.datefield.Resolution;
*
*/
public class VPopupCalendar extends VTextualDate implements Field,
- ClickHandler, CloseHandler<PopupPanel>, SubPartAware {
+ ClickHandler, MouseOverHandler, MouseOutHandler,
+ CloseHandler<PopupPanel>, SubPartAware {
/** For internal use only. May be removed or replaced in the future. */
public final Button calendarToggle = new Button();
@@ -75,6 +80,20 @@ public class VPopupCalendar extends VTextualDate implements Field,
public boolean parsable = true;
private boolean open = false;
+ /*
+ * To resolve #14857. If to click on calendarToggle button when calendar
+ * popup is opened (*1) then we have the following chain of calls:
+ *
+ * 1) onClose() 2) onClick()
+ *
+ * In this case we should prevent calling openCalendarPanel() in onClick.
+ */
+ private boolean preventOpenPopupCalendar = false;
+ /*
+ * To resolve #14857. To determine this situation (*1) we use onMouseOver
+ * and OnMouseOut (for calendarToggle button).
+ */
+ private boolean cursorOverCalendarToggleButton = false;
private boolean textFieldEnabled = true;
@@ -89,6 +108,10 @@ public class VPopupCalendar extends VTextualDate implements Field,
calendarToggle.setText("");
calendarToggle.addClickHandler(this);
+
+ calendarToggle.addMouseOverHandler(this);
+ calendarToggle.addMouseOutHandler(this);
+
// -2 instead of -1 to avoid FocusWidget.onAttach to reset it
calendarToggle.getElement().setTabIndex(-2);
@@ -441,7 +464,10 @@ public class VPopupCalendar extends VTextualDate implements Field,
@Override
public void onClick(ClickEvent event) {
if (event.getSource() == calendarToggle && isEnabled()) {
- openCalendarPanel();
+ if (!preventOpenPopupCalendar) {
+ openCalendarPanel();
+ }
+ preventOpenPopupCalendar = false;
}
}
@@ -464,15 +490,22 @@ public class VPopupCalendar extends VTextualDate implements Field,
focus();
}
- // TODO resolve what the "Sigh." is all about and document it here
- // Sigh.
- Timer t = new Timer() {
- @Override
- public void run() {
- open = false;
- }
- };
- t.schedule(100);
+ open = false;
+
+ if (cursorOverCalendarToggleButton) {
+ preventOpenPopupCalendar = true;
+
+ // To resolve the problem: onMouseOut event not triggered when
+ // moving mouse fast (GWT - all browsers)
+ Timer unPreventClickTimer = new Timer() {
+ @Override
+ public void run() {
+ preventOpenPopupCalendar = false;
+ }
+ };
+
+ unPreventClickTimer.schedule(300);
+ }
}
}
@@ -642,4 +675,28 @@ public class VPopupCalendar extends VTextualDate implements Field,
calendar.setRangeEnd(rangeEnd);
}
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.google.gwt.event.dom.client.MouseOverHandler#onMouseOver(com.google
+ * .gwt.event.dom.client.MouseOverEvent)
+ */
+ @Override
+ public void onMouseOver(MouseOverEvent event) {
+ cursorOverCalendarToggleButton = true;
+ }
+
+ /*
+ * (non-Javadoc)
+ *
+ * @see
+ * com.google.gwt.event.dom.client.MouseOutHandler#onMouseOut(com.google
+ * .gwt.event.dom.client.MouseOutEvent)
+ */
+ @Override
+ public void onMouseOut(MouseOutEvent event) {
+ cursorOverCalendarToggleButton = false;
+ }
+
}
diff --git a/client/src/com/vaadin/client/ui/VPopupImpl.java b/client/src/com/vaadin/client/ui/VPopupImpl.java
deleted file mode 100644
index 5da54b248c..0000000000
--- a/client/src/com/vaadin/client/ui/VPopupImpl.java
+++ /dev/null
@@ -1,35 +0,0 @@
-/*
- * Copyright 2000-2014 Vaadin Ltd.
- *
- * 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.vaadin.client.ui;
-
-import com.google.gwt.dom.client.Element;
-import com.google.gwt.user.client.ui.impl.PopupImpl;
-
-public class VPopupImpl extends PopupImpl {
-
- @Override
- public void onShow(Element popup) {
- // Move the overlay to the appropriate overlay container
- final VOverlay overlay = VOverlay.current;
- if (overlay != null) {
- final Element e = overlay.getOverlayContainer();
- e.appendChild(popup);
- }
-
- super.onShow(popup);
- }
-
-}
diff --git a/client/src/com/vaadin/client/ui/VPopupImplMozilla.java b/client/src/com/vaadin/client/ui/VPopupImplMozilla.java
deleted file mode 100644
index c9ede541ab..0000000000
--- a/client/src/com/vaadin/client/ui/VPopupImplMozilla.java
+++ /dev/null
@@ -1,35 +0,0 @@
-/*
- * Copyright 2000-2014 Vaadin Ltd.
- *
- * 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.vaadin.client.ui;
-
-import com.google.gwt.dom.client.Element;
-import com.google.gwt.user.client.ui.impl.PopupImplMozilla;
-
-public class VPopupImplMozilla extends PopupImplMozilla {
-
- @Override
- public void onShow(Element popup) {
- // Move the overlay to the appropriate overlay container
- final VOverlay overlay = VOverlay.current;
- if (overlay != null) {
- final Element e = overlay.getOverlayContainer();
- e.appendChild(popup);
- }
-
- super.onShow(popup);
- }
-
-}
diff --git a/client/src/com/vaadin/client/ui/VPopupView.java b/client/src/com/vaadin/client/ui/VPopupView.java
index 7d98110446..5b37a90915 100644
--- a/client/src/com/vaadin/client/ui/VPopupView.java
+++ b/client/src/com/vaadin/client/ui/VPopupView.java
@@ -195,6 +195,8 @@ public class VPopupView extends HTML implements HasEnabled, Iterable<Widget>,
/**
* Returns true if the popup is enabled, false if not.
+ *
+ * @since 7.3.4
*/
@Override
public boolean isEnabled() {
@@ -206,6 +208,7 @@ public class VPopupView extends HTML implements HasEnabled, Iterable<Widget>,
*
* @param enabled <code>true</code> to enable the popup, <code>false</code>
* to disable it
+ * @since 7.3.4
*/
@Override
public void setEnabled(boolean enabled) {
@@ -439,6 +442,14 @@ public class VPopupView extends HTML implements HasEnabled, Iterable<Widget>,
return Collections.singleton((Widget) popup).iterator();
}
+ /**
+ * Checks whether there are operations pending for this widget that must be
+ * executed before reaching a steady state.
+ *
+ * @returns <code>true</code> iff there are operations pending which must be
+ * executed before reaching a steady state
+ * @since 7.3.4
+ */
@Override
public boolean isWorkPending() {
return popupShowInProgress;
diff --git a/client/src/com/vaadin/client/ui/VScrollTable.java b/client/src/com/vaadin/client/ui/VScrollTable.java
index 42fef9f0c0..b07d2dc9c0 100644
--- a/client/src/com/vaadin/client/ui/VScrollTable.java
+++ b/client/src/com/vaadin/client/ui/VScrollTable.java
@@ -2600,11 +2600,12 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
@Override
public void run() {
+
if (client.hasActiveRequest() || navKeyDown) {
// if client connection is busy, don't bother loading it more
VConsole.log("Postponed rowfetch");
schedule(250);
- } else if (!updatedReqRows && allRenderedRowsAreNew()) {
+ } else if (allRenderedRowsAreNew() && !updatedReqRows) {
/*
* If all rows are new, there might have been a server-side call
@@ -2625,6 +2626,7 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
setReqRows(last - getReqFirstRow() + 1);
updatedReqRows = true;
schedule(250);
+
} else {
int firstRendered = scrollBody.getFirstRendered();
@@ -2712,6 +2714,7 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
client.updateVariable(paintableId, "firstvisible",
firstRowInViewPort, false);
}
+
client.updateVariable(paintableId, "reqfirstrow", reqFirstRow,
false);
client.updateVariable(paintableId, "reqrows", reqRows, true);
@@ -3138,6 +3141,15 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
&& Util.isTouchEventOrLeftMouseButton(event)) {
dragging = false;
DOM.releaseCapture(getElement());
+
+ if (Util.isTouchEvent(event)) {
+ /*
+ * Prevent using in e.g. scrolling and prevent generated
+ * events.
+ */
+ event.preventDefault();
+ event.stopPropagation();
+ }
if (moved) {
hideFloatingCopy();
tHead.removeSlotFocus();
@@ -3149,14 +3161,8 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
reOrderColumn(cid, closestSlot);
}
}
- }
- if (Util.isTouchEvent(event)) {
- /*
- * Prevent using in e.g. scrolling and prevent generated
- * events.
- */
- event.preventDefault();
- event.stopPropagation();
+ moved = false;
+ break;
}
}
@@ -3630,6 +3636,7 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
c.setWidth(widthWithoutAddedIndent, true);
}
} else if (col.hasAttribute("er")) {
+ c.setUndefinedWidth();
c.setExpandRatio(col.getFloatAttribute("er"));
} else if (recalcWidths) {
@@ -4205,7 +4212,7 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
}
/**
- * Returns the expand ration of the cell
+ * Returns the expand ratio of the cell
*
* @return The expand ratio
*/
@@ -4693,10 +4700,12 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
}
public int getLastRendered() {
+
return lastRendered;
}
public int getFirstRendered() {
+
return firstRendered;
}
@@ -4780,10 +4789,12 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
} else if (firstIndex + rows == firstRendered) {
final VScrollTableRow[] rowArray = new VScrollTableRow[rows];
int i = rows;
+
while (it.hasNext()) {
i--;
rowArray[i] = prepareRow((UIDL) it.next());
}
+
for (i = 0; i < rows; i++) {
addRowBeforeFirstRendered(rowArray[i]);
firstRendered--;
@@ -4808,10 +4819,12 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
setLastRendered(lastRendered + 1);
setContainerHeight();
fixSpacers();
+
while (it.hasNext()) {
addRow(prepareRow((UIDL) it.next()));
setLastRendered(lastRendered + 1);
}
+
fixSpacers();
}
@@ -4826,6 +4839,14 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
* has changed since the last request.
*/
protected void ensureCacheFilled() {
+
+ /**
+ * Fixes cache issue #13576 where unnecessary rows are fetched
+ */
+ if (isLazyScrollerActive()) {
+ return;
+ }
+
int reactFirstRow = (int) (firstRowInViewPort - pageLength
* cache_react_rate);
int reactLastRow = (int) (firstRowInViewPort + pageLength + pageLength
@@ -6133,7 +6154,7 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
touchStart = event;
Touch touch = event.getChangedTouches().get(0);
// save position to fields, touches in events are same
- // isntance during the operation.
+ // instance during the operation.
touchStartX = touch.getClientX();
touchStartY = touch.getClientY();
/*
@@ -6441,8 +6462,7 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
startRow = focusedRow;
selectionRangeStart = focusedRow;
// If start row is null then we have a multipage selection
- // from
- // above
+ // from above
if (startRow == null) {
startRow = (VScrollTableRow) scrollBody.iterator()
.next();
@@ -7277,6 +7297,7 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
}
if (preLimit < firstRendered) {
// need some rows to the beginning of the rendered area
+
rowRequestHandler
.setReqFirstRow((int) (firstRowInViewPort - pageLength
* cache_rate));
@@ -7662,13 +7683,13 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
// viewport
selectLastItemInNextRender = true;
multiselectPending = shift;
- scrollByPagelenght(1);
+ scrollByPagelength(1);
}
}
}
} else {
/* No selections, go page down by scrolling */
- scrollByPagelenght(1);
+ scrollByPagelength(1);
}
return true;
}
@@ -7714,13 +7735,13 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
// viewport
selectFirstItemInNextRender = true;
multiselectPending = shift;
- scrollByPagelenght(-1);
+ scrollByPagelength(-1);
}
}
}
} else {
/* No selections, go page up by scrolling */
- scrollByPagelenght(-1);
+ scrollByPagelength(-1);
}
return true;
@@ -7794,7 +7815,7 @@ public class VScrollTable extends FlowPanel implements HasWidgets,
.getRowHeight());
}
- private void scrollByPagelenght(int i) {
+ private void scrollByPagelength(int i) {
int pixels = i * scrollBodyPanel.getOffsetHeight();
int newPixels = scrollBodyPanel.getScrollPosition() + pixels;
if (newPixels < 0) {
diff --git a/client/src/com/vaadin/client/ui/VTabsheet.java b/client/src/com/vaadin/client/ui/VTabsheet.java
index 9c3af5c568..bcca117395 100644
--- a/client/src/com/vaadin/client/ui/VTabsheet.java
+++ b/client/src/com/vaadin/client/ui/VTabsheet.java
@@ -512,6 +512,18 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
return (Tab) super.getWidget(index);
}
+ private int getTabIndex(String tabId) {
+ if (tabId == null) {
+ return -1;
+ }
+ for (int i = 0; i < getTabCount(); i++) {
+ if (tabId.equals(getTab(i).id)) {
+ return i;
+ }
+ }
+ return -1;
+ }
+
public void selectTab(int index) {
final Tab newSelected = getTab(index);
final Tab oldSelected = selected;
@@ -572,8 +584,40 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
if (tab == selected) {
selected = null;
}
-
// FIXME: Shouldn't something be selected instead?
+
+ int scrollerIndexCandidate = getTabIndex(getTabsheet().scrollerPositionTabId);
+ if (scrollerIndexCandidate < 0) {
+ // The tab with id scrollerPositionTabId has been removed
+ scrollerIndexCandidate = getTabsheet().scrollerIndex;
+ }
+ scrollerIndexCandidate = selectNewShownTab(scrollerIndexCandidate);
+ if (scrollerIndexCandidate >= 0
+ && scrollerIndexCandidate < getTabCount()) {
+ getTabsheet().scrollIntoView(getTab(scrollerIndexCandidate));
+ }
+ }
+
+ private int selectNewShownTab(int oldPosition) {
+ // After removing a tab, find a new scroll position. In most
+ // cases the scroll position does not change, but if the tab
+ // at the scroll position was removed, need to find a nearby
+ // tab that is visible.
+ for (int i = oldPosition; i < getTabCount(); i++) {
+ Tab tab = getTab(i);
+ if (!tab.isHiddenOnServer()) {
+ return i;
+ }
+ }
+
+ for (int i = oldPosition - 1; i >= 0; i--) {
+ Tab tab = getTab(i);
+ if (!tab.isHiddenOnServer()) {
+ return i;
+ }
+ }
+
+ return -1;
}
private boolean isFirstVisibleTab(int index) {
@@ -685,6 +729,14 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
* The index of the first visible tab (when scrolled)
*/
private int scrollerIndex = 0;
+ /**
+ * The id of the tab at position scrollerIndex. This is used for keeping the
+ * scroll position unchanged when a tab is removed from the server side and
+ * the removed tab lies to the left of the current scroll position. For other
+ * cases scrollerIndex alone would be sufficient. Since the tab at the current
+ * scroll position can be removed, scrollerIndex is required in addition to this variable.
+ */
+ private String scrollerPositionTabId;
final TabBar tb = new TabBar(this);
/** For internal use only. May be removed or replaced in the future. */
@@ -694,6 +746,9 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
private final Element deco;
+ /** For internal use only. May be removed or replaced in the future. */
+ public boolean waitingForResponse;
+
private String currentStyle;
/**
@@ -701,7 +756,8 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
*/
private boolean canSelectTab(final int tabIndex) {
Tab tab = tb.getTab(tabIndex);
- if (getApplicationConnection() == null || disabled) {
+ if (getApplicationConnection() == null || disabled
+ || waitingForResponse) {
return false;
}
if (!tab.isEnabledOnServer() || tab.isHiddenOnServer()) {
@@ -735,6 +791,8 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
getRpcProxy().setSelected(tabKeys.get(tabIndex).toString());
+ waitingForResponse = true;
+
tb.getTab(tabIndex).focus(); // move keyboard focus to active tab
return true;
@@ -905,6 +963,7 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
if (newFirstIndex != -1) {
scrollerIndex = newFirstIndex;
+ scrollerPositionTabId = tb.getTab(scrollerIndex).id;
updateTabScroller();
}
@@ -1200,6 +1259,8 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
/** For internal use only. May be removed or replaced in the future. */
public void showAllTabs() {
scrollerIndex = tb.getFirstVisibleTab();
+ scrollerPositionTabId = scrollerIndex < 0 ? null : tb
+ .getTab(scrollerIndex).id;
for (int i = 0; i < tb.getTabCount(); i++) {
Tab t = tb.getTab(i);
if (!t.isHiddenOnServer()) {
@@ -1774,12 +1835,18 @@ public class VTabsheet extends VTabsheetBase implements Focusable, SubPartAware
}
updateTabScroller();
}
+ if (scrollerIndex >= 0 && scrollerIndex < tb.getTabCount()) {
+ scrollerPositionTabId = tb.getTab(scrollerIndex).id;
+ }
+ else{
+ scrollerPositionTabId = null;
+ }
}
}
/**
* Makes tab bar visible.
- *
+ *
* @since 7.2
*/
public void showTabs() {
diff --git a/client/src/com/vaadin/client/ui/VUpload.java b/client/src/com/vaadin/client/ui/VUpload.java
index f234ef6d65..42fb08fb3c 100644
--- a/client/src/com/vaadin/client/ui/VUpload.java
+++ b/client/src/com/vaadin/client/ui/VUpload.java
@@ -184,7 +184,7 @@ public class VUpload extends SimplePanel {
/** For internal use only. May be removed or replaced in the future. */
public void disableUpload() {
- submitButton.setEnabled(false);
+ setEnabledForSubmitButton(false);
if (!submitted) {
// Cannot disable the fileupload while submitting or the file won't
// be submitted at all
@@ -195,7 +195,7 @@ public class VUpload extends SimplePanel {
/** For internal use only. May be removed or replaced in the future. */
public void enableUpload() {
- submitButton.setEnabled(true);
+ setEnabledForSubmitButton(true);
fu.getElement().setPropertyBoolean("disabled", false);
enabled = true;
if (submitted) {
@@ -209,6 +209,12 @@ public class VUpload extends SimplePanel {
}
}
+ private void setEnabledForSubmitButton(boolean enabled) {
+ submitButton.setEnabled(enabled);
+ submitButton.setStyleName(ApplicationConnection.DISABLED_CLASSNAME,
+ !enabled);
+ }
+
/**
* Re-creates file input field and populates panel. This is needed as we
* want to clear existing values from our current file input field.
diff --git a/client/src/com/vaadin/client/ui/calendar/CalendarConnector.java b/client/src/com/vaadin/client/ui/calendar/CalendarConnector.java
index cbf63768a3..8f5e9d9a59 100644
--- a/client/src/com/vaadin/client/ui/calendar/CalendarConnector.java
+++ b/client/src/com/vaadin/client/ui/calendar/CalendarConnector.java
@@ -675,7 +675,7 @@ public class CalendarConnector extends AbstractComponentConnector implements
List<CalendarDay> list = new ArrayList<CalendarDay>(days.size());
for (CalendarState.Day day : days) {
CalendarDay d = new CalendarDay(day.date, day.localizedDateFormat,
- day.dayOfWeek, day.week);
+ day.dayOfWeek, day.week, day.yearOfWeek);
list.add(d);
}
diff --git a/client/src/com/vaadin/client/ui/calendar/schedule/CalendarDay.java b/client/src/com/vaadin/client/ui/calendar/schedule/CalendarDay.java
index 44b82f166f..0fceb6b6f9 100644
--- a/client/src/com/vaadin/client/ui/calendar/schedule/CalendarDay.java
+++ b/client/src/com/vaadin/client/ui/calendar/schedule/CalendarDay.java
@@ -27,14 +27,16 @@ public class CalendarDay {
private String localizedDateFormat;
private int dayOfWeek;
private int week;
+ private int yearOfWeek;
public CalendarDay(String date, String localizedDateFormat, int dayOfWeek,
- int week) {
+ int week, int yearOfWeek) {
super();
this.date = date;
this.localizedDateFormat = localizedDateFormat;
this.dayOfWeek = dayOfWeek;
this.week = week;
+ this.yearOfWeek = yearOfWeek;
}
public String getDate() {
@@ -52,4 +54,8 @@ public class CalendarDay {
public int getWeek() {
return week;
}
+
+ public int getYearOfWeek() {
+ return yearOfWeek;
+ }
}
diff --git a/client/src/com/vaadin/client/ui/calendar/schedule/SimpleDayCell.java b/client/src/com/vaadin/client/ui/calendar/schedule/SimpleDayCell.java
index 8e83dc4e36..db8452af9a 100644
--- a/client/src/com/vaadin/client/ui/calendar/schedule/SimpleDayCell.java
+++ b/client/src/com/vaadin/client/ui/calendar/schedule/SimpleDayCell.java
@@ -74,8 +74,15 @@ public class SimpleDayCell extends FocusableFlowPanel implements
private int startY = -1;
private int startYrelative;
private int startXrelative;
- private Date startDateFrom;
- private Date startDateTo;
+ // "from" date of date which is source of Dnd
+ private Date dndSourceDateFrom;
+ // "to" date of date which is source of Dnd
+ private Date dndSourceDateTo;
+ // "from" time of date which is source of Dnd
+ private Date dndSourceStartDateTime;
+ // "to" time of date which is source of Dnd
+ private Date dndSourceEndDateTime;
+
private int prevDayDiff = 0;
private int prevWeekDiff = 0;
private HandlerRegistration moveRegistration;
@@ -392,8 +399,7 @@ public class SimpleDayCell extends FocusableFlowPanel implements
prevDayDiff = 0;
prevWeekDiff = 0;
- if (!mel.isTimeSpecificEvent()
- && (xDiff < -3 || xDiff > 3 || yDiff < -3 || yDiff > 3)) {
+ if (xDiff < -3 || xDiff > 3 || yDiff < -3 || yDiff > 3) {
eventMoved(moveEvent);
} else if (calendar.getEventClickListener() != null) {
@@ -528,20 +534,47 @@ public class SimpleDayCell extends FocusableFlowPanel implements
Date from = e.getStart();
Date to = e.getEnd();
- long duration = to.getTime() - from.getTime();
long daysMs = dayDiff * DateConstants.DAYINMILLIS;
long weeksMs = weekDiff * DateConstants.WEEKINMILLIS;
- from.setTime(startDateFrom.getTime() + weeksMs + daysMs);
- to.setTime((from.getTime() + duration));
+
+ setDates(e, from, to, weeksMs + daysMs, false);
e.setStart(from);
e.setEnd(to);
- e.setStartTime(new Date(from.getTime()));
- e.setEndTime(new Date(to.getTime()));
+ if (w.isTimeSpecificEvent()) {
+ Date start = new Date();
+ Date end = new Date();
+ setDates(e, start, end, weeksMs + daysMs, true);
+ e.setStartTime(start);
+ e.setEndTime(end);
+ } else {
+ e.setStartTime(new Date(from.getTime()));
+ e.setEndTime(new Date(to.getTime()));
+ }
updateDragPosition(w, dayDiff, weekDiff);
}
+ private void setDates(CalendarEvent e, Date start, Date end, long shift,
+ boolean isDateTime) {
+ Date currentStart;
+ Date currentEnd;
+ if (isDateTime) {
+ currentStart = e.getStartTime();
+ currentEnd = e.getEndTime();
+ } else {
+ currentStart = e.getStart();
+ currentEnd = e.getEnd();
+ }
+ long duration = currentEnd.getTime() - currentStart.getTime();
+ if (isDateTime) {
+ start.setTime(dndSourceStartDateTime.getTime() + shift);
+ } else {
+ start.setTime(dndSourceDateFrom.getTime() + shift);
+ }
+ end.setTime((start.getTime() + duration));
+ }
+
private void eventMoved(CalendarEvent e) {
calendar.updateEventToMonthGrid(e);
if (calendar.getEventMovedListener() != null) {
@@ -551,10 +584,6 @@ public class SimpleDayCell extends FocusableFlowPanel implements
public void startCalendarEventDrag(MouseDownEvent event,
final MonthEventLabel w) {
- if (w.isTimeSpecificEvent()) {
- return;
- }
-
moveRegistration = addMouseMoveHandler(this);
startX = event.getClientX();
startY = event.getClientY();
@@ -564,8 +593,11 @@ public class SimpleDayCell extends FocusableFlowPanel implements
% getWidth();
CalendarEvent e = getEventByWidget(w);
- startDateFrom = (Date) e.getStart().clone();
- startDateTo = (Date) e.getEnd().clone();
+ dndSourceDateFrom = (Date) e.getStart().clone();
+ dndSourceDateTo = (Date) e.getEnd().clone();
+
+ dndSourceStartDateTime = (Date) e.getStartTime().clone();
+ dndSourceEndDateTime = (Date) e.getEndTime().clone();
Event.setCapture(getElement());
keyDownHandler = addKeyDownHandler(new KeyDownHandler() {
@@ -591,8 +623,10 @@ public class SimpleDayCell extends FocusableFlowPanel implements
moveEvent = getEventByWidget(w);
}
- moveEvent.setStart(startDateFrom);
- moveEvent.setEnd(startDateTo);
+ moveEvent.setStart(dndSourceDateFrom);
+ moveEvent.setEnd(dndSourceDateTo);
+ moveEvent.setStartTime(dndSourceStartDateTime);
+ moveEvent.setEndTime(dndSourceEndDateTime);
calendar.updateEventToMonthGrid(moveEvent);
// reset drag-related properties
diff --git a/client/src/com/vaadin/client/ui/orderedlayout/AbstractOrderedLayoutConnector.java b/client/src/com/vaadin/client/ui/orderedlayout/AbstractOrderedLayoutConnector.java
index 0c09ae49c6..aace349392 100644
--- a/client/src/com/vaadin/client/ui/orderedlayout/AbstractOrderedLayoutConnector.java
+++ b/client/src/com/vaadin/client/ui/orderedlayout/AbstractOrderedLayoutConnector.java
@@ -152,7 +152,20 @@ public abstract class AbstractOrderedLayoutConnector extends
public void onElementResize(ElementResizeEvent e) {
updateLayoutHeight();
if (needsExpand()) {
- getWidget().updateExpandCompensation();
+ /*
+ * updateLayoutHeight causes calling of
+ * getLayoutManager().setNeedsMeasure(this) which informs this
+ * LayoutManager that the size of a component might have
+ * changed. Then a new layout phase is scheduled. So
+ * updateExpandCompensation must be delayed until layout phase
+ * will be completed. #12672
+ */
+ Scheduler.get().scheduleFinally(new ScheduledCommand() {
+ @Override
+ public void execute() {
+ getWidget().updateExpandCompensation();
+ }
+ });
}
}
};
diff --git a/client/src/com/vaadin/client/ui/tabsheet/TabsheetConnector.java b/client/src/com/vaadin/client/ui/tabsheet/TabsheetConnector.java
index 94961a6a50..d49581eaad 100644
--- a/client/src/com/vaadin/client/ui/tabsheet/TabsheetConnector.java
+++ b/client/src/com/vaadin/client/ui/tabsheet/TabsheetConnector.java
@@ -41,7 +41,7 @@ public class TabsheetConnector extends TabsheetBaseConnector implements
final String key = getState().tabs.get(i).key;
final boolean selected = key.equals(getState().selected);
if (selected) {
- getWidget().setActiveTabIndex(i);
+ getWidget().waitingForResponse = false;
getWidget().selectTab(i);
break;
}
diff --git a/client/tests/src/com/vaadin/client/LocatorUtilTest.java b/client/tests/src/com/vaadin/client/LocatorUtilTest.java
new file mode 100644
index 0000000000..15536ac6fc
--- /dev/null
+++ b/client/tests/src/com/vaadin/client/LocatorUtilTest.java
@@ -0,0 +1,73 @@
+/*
+ * Copyright 2000-2014 Vaadin Ltd.
+ *
+ * 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.vaadin.client;
+
+import junit.framework.TestCase;
+
+import org.junit.Assert;
+
+import com.vaadin.client.componentlocator.LocatorUtil;
+
+/*
+ * Test LocatorUtil.isUIElement() & isNotificaitonElement methods
+ */
+public class LocatorUtilTest extends TestCase {
+
+ public void testIsUI1() {
+ boolean isUI = LocatorUtil.isUIElement("com.vaadin.ui.UI");
+ Assert.assertTrue(isUI);
+ }
+
+ public void testIsUI2() {
+ boolean isUI = LocatorUtil.isUIElement("/com.vaadin.ui.UI");
+ Assert.assertTrue(isUI);
+ }
+
+ public void testIsUI3() {
+ boolean isUI = LocatorUtil
+ .isUIElement("//com.vaadin.ui.UI[RandomString");
+ Assert.assertTrue(isUI);
+ }
+
+ public void testIsUI4() {
+ boolean isUI = LocatorUtil.isUIElement("//com.vaadin.ui.UI[0]");
+ Assert.assertTrue(isUI);
+ }
+
+ public void testIsNotification1() {
+ boolean isUI = LocatorUtil
+ .isNotificationElement("com.vaadin.ui.VNotification");
+ Assert.assertTrue(isUI);
+ }
+
+ public void testIsNotification2() {
+ boolean isUI = LocatorUtil
+ .isNotificationElement("com.vaadin.ui.Notification");
+ Assert.assertTrue(isUI);
+ }
+
+ public void testIsNotification3() {
+ boolean isUI = LocatorUtil
+ .isNotificationElement("/com.vaadin.ui.VNotification[");
+ Assert.assertTrue(isUI);
+ }
+
+ public void testIsNotification4() {
+ boolean isUI = LocatorUtil
+ .isNotificationElement("//com.vaadin.ui.VNotification[0]");
+ Assert.assertTrue(isUI);
+ }
+}