-
Bug
-
Resolution: Unresolved
-
Normal
-
None
-
7.0.5
-
An application that has non-displayed / lazy initialized and displayed comboboxes
-
None
Hi,
i've tracked down an issue with a wired behaviour on comboboxes. The comboboxes are loaded with ListSubModel's that are initially empty and filled with results as soon as the user starts typing.
Here we boserved that the dropdown always keeps on a sub-line hight even if we had many results.
After some investigation we found out this only happened if there are also hidden, lazy initialized comboboxes on the same desktop (e.g. in a listbox with disabled columns).
Detailed description what happens:
For the 'hidden / lazy initialized combobx' it seems that ComboWidget.js:getPopupNode_() returns null because the popup is not initialized yet. But this 'hidden' combobox is already registered to zWatch.listen('onResponse'...) and receives onResponse updates, but trows an TypeError in ComboWidget.js:_checkPopupPosition() with these exception details:
TypeError: this.jq[0] is undefined - Stacktrace: zjq.prototype.dimension@https://localhost:8443/zkau/web/ab032470/js/zk.wpd:11878:7
zul.inp.ComboWidget<._checkPopupPosition@https://localhost:8443/zkau/web/_zv2015032410/js/zul.inp.wpd:1881:12
zul.inp.Combobox<.onResponse@https://localhost:8443/zkau/web/_zv2015032410/js/zul.inp.wpd:2201:4
_invoke@https://localhost:8443/zkau/web/ab032470/js/zk.wpd:12628:5
_Gun<.fire@https://localhost:8443/zkau/web/ab032470/js/zk.wpd:12608:8
_fire/<@https://localhost:8443/zkau/web/ab032470/js/zk.wpd:12749:6
The TypeError is a result of pp being null in https://github.com/zkoss/zk/blob/7.0-Stable/zul/src/archive/web/js/zul/inp/ComboWidget.js#L222.
I added the attached patch that checks if pp is null and returns false if so to prevent the exception from be thrown and so any further event processing been stopped. The Jira-Entry ZK-2733 is also related to this issue, because the exception was dropped silently there...
Hope the details are clear and the patch is OK to integrate, because i was not able to prepare a testcase easily.
Thanks & Bye,
Chris