summaryrefslogtreecommitdiffstats
path: root/client
diff options
context:
space:
mode:
authorJohn Ahlroos <john@vaadin.com>2012-12-14 14:14:04 +0000
committerVaadin Code Review <review@vaadin.com>2012-12-14 14:14:04 +0000
commit2a1c1222ec51a4a8979589ffef56f32c2924f617 (patch)
tree860fa22c06976f9e575c4a4ced362651c4f41924 /client
parent5b1bb852142f366df7c70ca6e02edc3ba23bba7c (diff)
parent72943f25d0aa5e936cefabe58f1858ff12c94894 (diff)
downloadvaadin-framework-2a1c1222ec51a4a8979589ffef56f32c2924f617.tar.gz
vaadin-framework-2a1c1222ec51a4a8979589ffef56f32c2924f617.zip
Merge "Colorpicker IE fixes"
Diffstat (limited to 'client')
-rw-r--r--client/src/com/vaadin/client/ui/colorpicker/VColorPickerGradient.java55
1 files changed, 37 insertions, 18 deletions
diff --git a/client/src/com/vaadin/client/ui/colorpicker/VColorPickerGradient.java b/client/src/com/vaadin/client/ui/colorpicker/VColorPickerGradient.java
index 6defc57996..6a3f50cecc 100644
--- a/client/src/com/vaadin/client/ui/colorpicker/VColorPickerGradient.java
+++ b/client/src/com/vaadin/client/ui/colorpicker/VColorPickerGradient.java
@@ -1,15 +1,17 @@
package com.vaadin.client.ui.colorpicker;
+import com.google.gwt.dom.client.Style.Unit;
import com.google.gwt.event.dom.client.MouseDownEvent;
import com.google.gwt.event.dom.client.MouseDownHandler;
import com.google.gwt.event.dom.client.MouseMoveEvent;
import com.google.gwt.event.dom.client.MouseMoveHandler;
import com.google.gwt.event.dom.client.MouseUpEvent;
import com.google.gwt.event.dom.client.MouseUpHandler;
-import com.google.gwt.user.client.DOM;
+import com.google.gwt.user.client.Element;
import com.google.gwt.user.client.ui.AbsolutePanel;
import com.google.gwt.user.client.ui.FocusPanel;
import com.google.gwt.user.client.ui.HTML;
+import com.vaadin.client.ui.SubPartAware;
/**
* Client side implementation for ColorPickerGradient.
@@ -18,7 +20,7 @@ import com.google.gwt.user.client.ui.HTML;
*
*/
public class VColorPickerGradient extends FocusPanel implements
- MouseDownHandler, MouseUpHandler, MouseMoveHandler {
+ MouseDownHandler, MouseUpHandler, MouseMoveHandler, SubPartAware {
/** Set the CSS class name to allow styling. */
public static final String CLASSNAME = "v-colorpicker-gradient";
@@ -28,6 +30,7 @@ public class VColorPickerGradient extends FocusPanel implements
public static final String CLASSNAME_HIGHERBOX = CLASSNAME + "-higherbox";
public static final String CLASSNAME_CONTAINER = CLASSNAME + "-container";
public static final String CLASSNAME_CLICKLAYER = CLASSNAME + "-clicklayer";
+ private static final String CLICKLAYER_ID = "clicklayer";
private final HTML background;
private final HTML foreground;
@@ -41,6 +44,9 @@ public class VColorPickerGradient extends FocusPanel implements
private int cursorX;
private int cursorY;
+ private int width = 220;
+ private int height = 220;
+
/**
* Instantiates the client side component for a color picker gradient.
*/
@@ -49,9 +55,6 @@ public class VColorPickerGradient extends FocusPanel implements
setStyleName(CLASSNAME);
- int width = 220;
- int height = 220;
-
background = new HTML();
background.setStyleName(CLASSNAME_BACKGROUND);
background.setPixelSize(width, height);
@@ -107,7 +110,11 @@ public class VColorPickerGradient extends FocusPanel implements
* @param bgColor
*/
protected void setBGColor(String bgColor) {
- background.getElement().getStyle().setProperty("background", bgColor);
+ if (bgColor == null) {
+ background.getElement().getStyle().clearBackgroundColor();
+ } else {
+ background.getElement().getStyle().setBackgroundColor(bgColor);
+ }
}
@Override
@@ -148,29 +155,41 @@ public class VColorPickerGradient extends FocusPanel implements
cursorX = x;
cursorY = y;
if (x >= 0) {
- DOM.setStyleAttribute(lowercross.getElement(), "width",
- String.valueOf(x) + "px");
+ lowercross.getElement().getStyle().setWidth(x, Unit.PX);
}
if (y >= 0) {
- DOM.setStyleAttribute(lowercross.getElement(), "top",
- String.valueOf(y) + "px");
+ lowercross.getElement().getStyle().setTop(y, Unit.PX);
}
if (y >= 0) {
- DOM.setStyleAttribute(lowercross.getElement(), "height",
- String.valueOf((background.getOffsetHeight() - y)) + "px");
+ lowercross.getElement().getStyle().setHeight(height - y, Unit.PX);
}
if (x >= 0) {
- DOM.setStyleAttribute(highercross.getElement(), "width",
- String.valueOf((background.getOffsetWidth() - x)) + "px");
+ highercross.getElement().getStyle().setWidth(width - x, Unit.PX);
}
if (x >= 0) {
- DOM.setStyleAttribute(highercross.getElement(), "left",
- String.valueOf(x) + "px");
+ highercross.getElement().getStyle().setLeft(x, Unit.PX);
}
if (y >= 0) {
- DOM.setStyleAttribute(highercross.getElement(), "height",
- String.valueOf((y)) + "px");
+ highercross.getElement().getStyle().setHeight(y, Unit.PX);
+ }
+ }
+
+ @Override
+ public Element getSubPartElement(String subPart) {
+ if (subPart.equals(CLICKLAYER_ID)) {
+ return clicklayer.getElement();
}
+
+ return null;
+ }
+
+ @Override
+ public String getSubPartName(Element subElement) {
+ if (clicklayer.getElement().isOrHasChild(subElement)) {
+ return CLICKLAYER_ID;
+ }
+
+ return null;
}
}