diff options
3 files changed, 37 insertions, 23 deletions
diff --git a/src/com/itmill/toolkit/terminal/gwt/client/Client.java b/src/com/itmill/toolkit/terminal/gwt/client/Client.java index 2c1f0b4303..4be56306d3 100755 --- a/src/com/itmill/toolkit/terminal/gwt/client/Client.java +++ b/src/com/itmill/toolkit/terminal/gwt/client/Client.java @@ -104,6 +104,7 @@ public class Client implements EntryPoint { Date start = new Date(); try{ + console.log(response.getText().substring(3) + "}"); JSONValue json = JSONParser .parse(response.getText().substring(3) + "}"); // Process changes @@ -187,6 +188,7 @@ public class Client implements EntryPoint { req.append(pendingVariables.get(i++)); req.append("="); req.append(pendingVariables.get(i)); + req.append("&"); } pendingVariables.clear(); diff --git a/src/com/itmill/toolkit/terminal/gwt/client/ui/TkTextField.java b/src/com/itmill/toolkit/terminal/gwt/client/ui/TkTextField.java index e31f25a437..6dd9f5f4bd 100644 --- a/src/com/itmill/toolkit/terminal/gwt/client/ui/TkTextField.java +++ b/src/com/itmill/toolkit/terminal/gwt/client/ui/TkTextField.java @@ -1,9 +1,11 @@ package com.itmill.toolkit.terminal.gwt.client.ui; +import com.google.gwt.user.client.ui.ChangeListener; import com.google.gwt.user.client.ui.Composite; import com.google.gwt.user.client.ui.Label; import com.google.gwt.user.client.ui.TextArea; import com.google.gwt.user.client.ui.TextBox; +import com.google.gwt.user.client.ui.TextBoxBase; import com.google.gwt.user.client.ui.VerticalPanel; import com.google.gwt.user.client.ui.Widget; import com.itmill.toolkit.terminal.gwt.client.Client; @@ -11,17 +13,21 @@ import com.itmill.toolkit.terminal.gwt.client.Paintable; import com.itmill.toolkit.terminal.gwt.client.UIDL; public class TkTextField extends Composite implements - Paintable { + Paintable, ChangeListener { String id; Client client; - Widget field; + TextBoxBase field; Label caption = new Label(); private VerticalPanel p; + private boolean multiline = false; + + private boolean immediate = false; + public TkTextField() { p = new VerticalPanel(); p.add(caption); @@ -31,31 +37,35 @@ public class TkTextField extends Composite implements public void updateFromUIDL(UIDL uidl, Client client) { this.client = client; id = uidl.getId(); + if(uidl.hasAttribute("immediate") && uidl.getBooleanAttribute("immediate")) + immediate = true; if(uidl.hasAttribute("caption")) caption.setText(uidl.getStringAttribute("caption")); else caption.setVisible(false); - if(uidl.hasAttribute("rows")) { - // TODO textarea - TextArea ta = new TextArea(); - field = ta; - if(uidl.hasAttribute("cols")) - ta.setWidth(uidl.getStringAttribute("cols")+"em"); - ta.setHeight(uidl.getStringAttribute("height")+"em"); - - } else { - // one line text field - TextBox tb = new TextBox(); - field = tb; - if(uidl.hasAttribute("cols")) - tb.setWidth(uidl.getStringAttribute("cols")+"em"); + if(field != null && (uidl.hasAttribute("rows") && !multiline )) { + // field type has changed + p.remove(p.getWidgetIndex(field)); } - p.add(field); + if(field == null) { + if(uidl.hasAttribute("rows")) { + field = new TextArea(); + multiline = true; + } else { + field = new TextBox(); + } + p.add(field); + } + if(multiline) + field.setHeight(uidl.getStringAttribute("height")+"em"); + if(uidl.hasAttribute("cols")) + field.setWidth(uidl.getStringAttribute("cols")+"em"); + + field.addChangeListener(this); + } - public void onClick(Widget sender) { - if (id == null || client == null) - return; - client.updateVariable(id, "state", true, true); + public void onChange(Widget sender) { + client.updateVariable(id, "text", field.getText() , immediate); } } diff --git a/src/com/itmill/toolkit/terminal/web/AjaxJsonPaintTarget.java b/src/com/itmill/toolkit/terminal/web/AjaxJsonPaintTarget.java index 073636d76c..6c7b520f01 100644 --- a/src/com/itmill/toolkit/terminal/web/AjaxJsonPaintTarget.java +++ b/src/com/itmill/toolkit/terminal/web/AjaxJsonPaintTarget.java @@ -164,7 +164,6 @@ public class AjaxJsonPaintTarget implements PaintTarget, AjaxPaintTarget { if(tag != null) { openJsonTags.push(tag); } - // Checks tagName and attributes here mOpenTags.push(tagName); @@ -211,7 +210,10 @@ public class AjaxJsonPaintTarget implements PaintTarget, AjaxPaintTarget { tag = parent; } else { - this.uidlBuffer.print(tag.getJSON()); + changes++; + this.uidlBuffer.print( + ( (changes > 1) ? "," : "") + + tag.getJSON()); tag = null; } } |