Skip to main content


Eclipse Community Forums
Forum Search:

Search      Help    Register    Login    Home
Home » Eclipse Projects » Remote Application Platform (RAP) » AutoTab to next field when field is full(How to achieve Auto-Tab on completion of a field)
AutoTab to next field when field is full [message #1772647] Wed, 13 September 2017 14:36 Go to next message
John Gymer is currently offline John GymerFriend
Messages: 279
Registered: November 2012
Location: UK
Senior Member
We would like to support an auto-tab feature for fields so that a field defined as auto-tab will jump the focus to the next field in the tab sequence when it is 'full' i.e. reached its' text limit (Text#setTextLimit method).

We currently do this with a thin SWT.Modify listener on the field, which in principle works OK... but... because of the network latency lag, it takes a moment for the event to be triggered, and the user may have started typing in more input which is then lost because setTextLimit is limiting any more characters from being entered... but I'd like them to go to the next field.

What I'm looking for (I think) is a client-side feature that does the tabbing, so it is immediate.

Is this possible?

Thanks, John


---
Just because you can doesn't mean you should
Re: AutoTab to next field when field is full [message #1772667 is a reply to message #1772647] Wed, 13 September 2017 16:48 Go to previous messageGo to next message
Cole Markham is currently offline Cole MarkhamFriend
Messages: 150
Registered: July 2009
Location: College Station, TX
Senior Member

The Client Scripting API should be what you're looking for. You can write javascript that will run on the client to interact with widgets:

http://www.eclipse.org/rap/developers-guide/devguide.php?topic=scripting.html&version=3.2

Hope that helps,

Cole Markham
CCM Computing
Re: AutoTab to next field when field is full [message #1772727 is a reply to message #1772667] Thu, 14 September 2017 12:11 Go to previous messageGo to next message
John Gymer is currently offline John GymerFriend
Messages: 279
Registered: November 2012
Location: UK
Senior Member
Thanks Cole, seems like a good place to start. I've implemented part of this and it is detecting the limit being reached OK, but how (in JS) do I trigger the TAB to move to the next field?

For info, here's what I've done so far:

In Java, server-side:
	public static void addAutoTabBehavior(Text text, int limitLen) {
		ClientListener listener = MyRWTScriptListenerAutoTab.getInstance();
		text.addListener(SWT.Modify, listener);
		WidgetUtil.registerDataKeys("myFieldLengthLimit");
		text.setData("myFieldLengthLimit", limitLen);
	}


My ScriptListener is pretty simple:
import org.eclipse.rap.rwt.SingletonUtil;
import org.eclipse.rap.rwt.scripting.ClientListener;

@SuppressWarnings("serial")
public class MyRWTScriptListenerAutoTab extends ClientListener {
	public static MyRWTScriptListenerAutoTab getInstance() {
		return SingletonUtil.getSessionInstance(MyRWTScriptListenerAutoTab.class);
	}
	
	private MyRWTScriptListenerAutoTab() {
		super(getText());
	}
	
	private static String getText() {
	    String scriptCode = ResourceLoaderUtil.readTextContent(CustomBehaviors.RESOURCES_PREFIX + "AutoTab.js");
	    return(scriptCode);
	}
}


On the JS client-side:
var handleEvent = function(event) {
	switch(event.type) {
	case SWT.Modify:
		var limitLen = event.widget.getData("myFieldLengthLimit");
		handleModifyEvent(event, limitLen);
		break;
	}
};

var handleModifyEvent = function(event, limitLen) {
	var text = event.widget.getText();
	var lenNow = text.length;
	if (limitLen == lenNow) {
		console.log("text limitLen=" + limitLen + " vs lenNow=" + lenNow + " - needs to trigger AUTOTAB");
	}
};


This works in as far as I get the message on the console saying that the AUTOTAB needs to be done, but how?

Is there some way to send a TAB keypress to the browser, or is there a better way to do this with the RAP JS?

Thanks, John


---
Just because you can doesn't mean you should
Re: AutoTab to next field when field is full [message #1772730 is a reply to message #1772727] Thu, 14 September 2017 12:43 Go to previous messageGo to next message
John Gymer is currently offline John GymerFriend
Messages: 279
Registered: November 2012
Location: UK
Senior Member
I can see to use something like this on the client-script side:
rap.getObject( text.getData( "next" ) ).forceFocus();

...but how do I set the 'next' data on the Java side? What should it be set to?


---
Just because you can doesn't mean you should
Re: AutoTab to next field when field is full [message #1772740 is a reply to message #1772730] Thu, 14 September 2017 14:11 Go to previous messageGo to next message
John Gymer is currently offline John GymerFriend
Messages: 279
Registered: November 2012
Location: UK
Senior Member
Well, this sort of works, but still need some help...
When I configure my tab sequence in Java, I ensure that any field with AutoTab required has the clientscripting listener as shown above, and I set another attribute to the RAP Id of the next widget in sequence:
		WidgetUtil.registerDataKeys("myNextFocusControl");
...
		String rapId = WidgetUtil.getId(nextControl);
		text.setData("myNextFocusControl", rapId);


Then on the JS side:
...
		var nextControl = event.widget.getData("myNextFocusControl");
		if (nextControl != null) {
			var ctl = rap.getObject(nextControl);
			if (ctl != null) {
				ctl.forceFocus();
			}
		}
...


Fine, and this works for a simple application.

However, we have constant changes to which controls are enabled/disabled through the life of the UI, so this technique would require me to recalculate the tab sequence and send appropriate nextControl data to the client each time enabling changes.

Yes, this is possible, but seems highly inefficient and potentially client-server slow!

It would be better to have JS logic that validated that the nextControl for focus was not read-only (disabled input) and if so, find that control's nextControl instead (repeating until it finds a control that is not disabled).

This would then all be client-side, so fast.

I'm just not sure how to do this, as I'm no JS expert. I would guess I'd want something like this below, but it doesn't return anything whether the control is disabled or not:
if (ctl.$input.disabled) ...


Hopefully that all makes sense - just trying to avoid unnecessary c/s comms and UI changes when there really is no need, and performance is important here.

Thanks in advance for useful ideas...
John


---
Just because you can doesn't mean you should
Re: AutoTab to next field when field is full [message #1772763 is a reply to message #1772740] Thu, 14 September 2017 21:44 Go to previous messageGo to next message
Chris Fairhall is currently offline Chris FairhallFriend
Messages: 221
Registered: February 2011
Senior Member
You could use some internal undocumented API:
rwt.remote.ObjectRegistry.getObject('w1650').getFocusRoot()._onfocuskeyevent({getKeyIdentifier : function() {return "Tab"}, stopPropagation : function() {}, preventDefault : function() {}, isShiftPressed : function() {return false}})

That gets the widget with the ID w1650, finds it's focus root (in this case it's the Shell that contains the Text widget) and sends fake Tab event to its FocusManager with a minimal set of methods so the code doesn't throw errors

It should be pretty easy to expand this to a function that takes a widget ID as a parameter.

You could do it without the fake event by calling the same methods as in FocusManager#_onkeyevent
Something like (untested):
var w = rwt.remote.ObjectRegistry.getObject(rapId);
var root = w.getFocusRoot();
var fh = root.getFocusHandler();

var vCurrent = root.getFocusedChild();
var vNext  = vCurrent ? fh.getWidgetAfter(root, vCurrent) : fh.getFirstWidget(root);
if (vNext) {
  vNext.setFocused(true);
  vNext._ontabfocus();
}
Re: AutoTab to next field when field is full [message #1772785 is a reply to message #1772763] Fri, 15 September 2017 08:36 Go to previous message
John Gymer is currently offline John GymerFriend
Messages: 279
Registered: November 2012
Location: UK
Senior Member
Hi Chris,

Looks interesting, but I'd rather not use unsupported/undocumented features as it could break in the future, and I won't remember what or why we did it!

I've found a different approach instead, since the forceFocus method returns whether it was successful or not (seems reliable), I can traverse my way through the controls using the same technique until I reach one that will take the forceFocus successfully... this approach seems to work well:

		var nextControl = event.widget.getData("myNextFocusControl");
		while (nextControl != null) {
			var ctl = rap.getObject(nextControl);
			if (ctl != null) {
				var suc = ctl.forceFocus();
				if (suc) {
					return;
				}
				// move onto the next control in the list
				// to see if we can focus that one instead
				// (prev might be disabled)
				nextControl = ctl.getData("myNextFocusControl");
			}
		}


John


---
Just because you can doesn't mean you should
Previous Topic:Unable to Install RAP Target
Next Topic:Shell-DisplayOverlay cursor
Goto Forum:
  


Current Time: Fri Apr 19 10:48:04 GMT 2024

Powered by FUDForum. Page generated in 0.02780 seconds
.:: Contact :: Home ::.

Powered by: FUDforum 3.0.2.
Copyright ©2001-2010 FUDforum Bulletin Board Software

Back to the top