summaryrefslogtreecommitdiffstats
path: root/client
diff options
context:
space:
mode:
authorAnna Koskinen <Ansku@users.noreply.github.com>2019-10-23 14:24:19 +0300
committerTatu Lund <tatu@vaadin.com>2019-10-23 14:24:19 +0300
commitf1dc01ec76840d995d562ba04d6ef6553c19b749 (patch)
treede091138fd0759473ca8a9a0ee43b94944318de3 /client
parent3980e35b71f9f20bf812123de8f017398927ff46 (diff)
downloadvaadin-framework-f1dc01ec76840d995d562ba04d6ef6553c19b749.tar.gz
vaadin-framework-f1dc01ec76840d995d562ba04d6ef6553c19b749.zip
When ComboBox popup opens to the left accommodate margin/border/padding. (#11755)
Fixes #11718
Diffstat (limited to 'client')
-rw-r--r--client/src/main/java/com/vaadin/client/ui/VComboBox.java18
1 files changed, 10 insertions, 8 deletions
diff --git a/client/src/main/java/com/vaadin/client/ui/VComboBox.java b/client/src/main/java/com/vaadin/client/ui/VComboBox.java
index 587710e612..81453bfade 100644
--- a/client/src/main/java/com/vaadin/client/ui/VComboBox.java
+++ b/client/src/main/java/com/vaadin/client/ui/VComboBox.java
@@ -791,6 +791,8 @@ public class VComboBox extends Composite implements Field, KeyDownHandler,
updateMenuWidth(desiredWidth, naturalMenuWidth);
+ double menuMarginBorderPaddingWidth = getMarginBorderPaddingWidth(
+ menu.getElement());
if (BrowserInfo.get().isIE()
&& BrowserInfo.get().getBrowserMajorVersion() < 11) {
// Must take margin,border,padding manually into account for
@@ -805,15 +807,13 @@ public class VComboBox extends Composite implements Field, KeyDownHandler,
.getStyle().getVisibility();
menu.getElement().getParentElement().getStyle()
.setVisibility(Visibility.VISIBLE);
- naturalMenuOuterWidth = WidgetUtil
- .getRequiredWidthDouble(menuFirstChild)
- + getMarginBorderPaddingWidth(menu.getElement());
+ naturalMenuOuterWidth = WidgetUtil.getRequiredWidthDouble(
+ menuFirstChild) + menuMarginBorderPaddingWidth;
menu.getElement().getParentElement().getStyle()
.setProperty("visibility", before);
} else {
- naturalMenuOuterWidth = WidgetUtil
- .getRequiredWidthDouble(menuFirstChild)
- + getMarginBorderPaddingWidth(menu.getElement());
+ naturalMenuOuterWidth = WidgetUtil.getRequiredWidthDouble(
+ menuFirstChild) + menuMarginBorderPaddingWidth;
}
/*
@@ -893,9 +893,11 @@ public class VComboBox extends Composite implements Field, KeyDownHandler,
}
}
- if (offsetWidth + left > Window.getClientWidth()) {
+ if (offsetWidth + menuMarginBorderPaddingWidth + left > Window
+ .getClientWidth()) {
left = VComboBox.this.getAbsoluteLeft()
- + VComboBox.this.getOffsetWidth() - offsetWidth;
+ + VComboBox.this.getOffsetWidth() - offsetWidth
+ - (int) menuMarginBorderPaddingWidth;
if (left < 0) {
left = 0;
menu.setWidth(Window.getClientWidth() + "px");