Suggested case list:
Using timer to refresh a grid
383guest172.69.33.12125nk0uiMay 7, 2020 7:23:47 AMlinkuser model to move item to another listbox
120guest162.158.193.148d0n3krApr 2, 2020 5:28:28 AMlinkDisabled list item row passed to VM-1981
296fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:44 PMlinkDisabled list item row passed to VM-1981
295fatih123160.83.36.13025nk0uiFeb 13, 2018 4:25:16 PMlinkDisabled list item row passed to VM-1981
294fatih123160.83.36.13225nk0uiFeb 13, 2018 3:30:44 PMlinkgrid sample with ListModel/RowRenderer
816guest80.82.2.1312vah9ajFeb 21, 2017 11:42:21 AMlinkgrid sample with ListModel/RowRenderer
809guest175.98.113.1622vah9ajJan 26, 2017 9:19:33 AMlinkgrid sample with ListModel/RowRenderer
196guest79.185.142.402vah9ajApr 26, 2014 10:53:57 PMlinkgrid sample with ListModel/RowRenderer
195guest79.185.142.402vah9ajApr 26, 2014 10:53:54 PMlinkgrid sample with ListModel/RowRenderer
194guest79.185.142.402vah9ajApr 26, 2014 10:53:51 PMlinkgrid sample with ListModel/RowRenderer
193guest79.185.142.402vah9ajApr 26, 2014 10:53:48 PMlinkgrid sample with ListModel/RowRenderer
192guest79.185.142.402vah9ajApr 26, 2014 10:53:44 PMlinkgrid sample with ListModel/RowRenderer
191guest79.185.142.402vah9ajApr 26, 2014 10:53:40 PMlinkHierarchy table without using ZK PE/EE
1aaknai151.28.135.2131s871daJul 29, 2013 11:02:46 PMlinkgrid sample with ListModel/RowRenderer
128aaknai151.28.135.2132vah9ajJul 29, 2013 7:20:00 PMlinkuser model to move item to another listbox
1TonyQ114.25.109.94d0n3krApr 21, 2012 10:43:27 AMlinkUsing timer to refresh a grid
1TonyQ220.133.44.3725nk0uiFeb 17, 2012 3:17:34 AMlinkFire a event from child iframe
1TonyQ220.133.44.372eupjotFeb 3, 2012 5:04:52 AMlinkTextbox input restriction sample
1TonyQ72.21.245.2431b3nlr0Dec 20, 2011 10:09:10 AMlinkTest web core taglib in ZUL
1TonyQ198.203.175.175ofqkemDec 17, 2011 3:36:08 AMlinkLatest 10 Fiddles :
constraint binding textbox
3guest172.68.151.16220peldaDec 5, 2025 5:08:19 PMlinkAnother new ZK fiddle
2guest172.68.151.16320peldaDec 5, 2025 5:07:51 PMlinkAnother new ZK fiddle
1guest172.68.151.16220peldaDec 5, 2025 5:07:32 PMlinkAnother new ZK fiddle
1peggypeng172.71.154.99364f4neDec 5, 2025 9:24:31 AMlinktooltip example
2guest104.22.23.13rc1ntoDec 4, 2025 2:23:45 PMlinkAnother new ZK fiddle
1guest172.69.134.2277t7602Dec 4, 2025 1:40:46 PMlinkAnother new ZK fiddle
1peggypeng104.22.17.1802df6e3oDec 4, 2025 8:41:29 AMlinkonClose
1peggypeng172.68.87.248j8kd8aDec 3, 2025 4:10:26 AMlinkAnother new ZK fiddle
1peggypeng172.69.134.2271rm7f4eNov 26, 2025 3:31:24 AMlinkZK-5912-Suggestion
2rebeccalai104.22.20.1442qrmiiuNov 26, 2025 2:07:15 AMlinkMake fisheye handle onfocus/onblur
2guest92.231.74.1031an1r8gJun 7, 2012 11:14:22 AMlinkresources
index.zulzul<zk>
<zscript>
import org.zkoss.zk.ui.event.Event;
import org.zkoss.zk.ui.event.Events;
public class CustomFisheye extends org.zkoss.zkex.zul.Fisheye {
public CustomFisheye () {
addClientEvent(CustomFisheye.class, Events.ON_FOCUS, CE_IMPORTANT|CE_REPEAT_IGNORE);
addClientEvent(CustomFisheye.class, Events.ON_BLUR, CE_IMPORTANT|CE_REPEAT_IGNORE);
}
public void service(org.zkoss.zk.au.AuRequest request, boolean everError) {
final String cmd = request.getCommand();
if ("onFocus".equals(cmd)) {
Events.postEvent(new Event("onFocus", this));
}
super.service(request, everError);
}
}
</zscript>
<script type="text/javascript">
/**
* make a component focusable and can handle onCtrlKey event
* by the given component's uuid
*/
function makeFocusable (uuid) {
var wgt = zk.Widget.$('#'+uuid);
overrideFunctions(wgt);
}
/**
* Override several functions to handle the focus/blur event
* and handle the onCtrlKey event
*/
function overrideFunctions (wgt) {
if (wgt) {
var oldClick = wgt.doClick_,
oldFocus = wgt.doFocus_,
oldBlur = wgt.doBlur_,
oldMouseDown = wgt.doMouseDown_;
wgt.doClick_ = function (evt) {
// the focusable anchor not exist, create it
if (!wgt.$n('custom-anchor')) {
createFocusableAnchor(wgt);
// rebind to enable added events
wgt.unbind().bind();
}
// focus the anchor if click on self to trigger the onFocus event
if (jq.isAncestor(wgt.$n(), evt.domTarget))
jq(wgt.$n('custom-anchor')).focus();
// do original function
oldClick.apply(wgt, arguments);
}
wgt.doFocus_ = function (evt) {
if (wgt._isFocused) return;
wgt._isFocused = true;
// do original function
oldFocus.apply(wgt, arguments);
// mantain focus status
if (evt.domTarget == wgt.$n('custom-anchor'))
wgt._focused = true;
wgt.fire('onFocus', {});
}
wgt.doBlur_ = function (evt) {
if (zkex.menu.Fisheye._preventBlur)
return;
wgt._isFocused = null;
// do original function
oldBlur.apply(wgt, arguments);
// mantain focus status
if (evt.domTarget == wgt.$n('custom-anchor'))
wgt._focused = false;
}
wgt.doMouseDown_ = function (evt) {
oldMouseDown.apply(wgt, arguments);
zkex.menu.Fisheye._preventBlur = true;
setTimeout (function () {
zkex.menu.Fisheye._preventBlur = null;
}, 0);
}
}
}
/**
* Create a focusable anchor to make the widget focusable
* and can handle the onCtrlKey event
*/
function createFocusableAnchor (wgt) {
if (wgt) {
// create an anchor that can receive the focus
var anchor = zk.ie || zk.gecko ? document.createElement("a") : document.createElement("button");
// make it focusable
anchor.href = 'javascript:;';
// make it catchable
anchor.id = wgt.uuid + '-custom-anchor';
// make it out of the screen
anchor.style.position = 'absolute';
anchor.style.left = '-3000px';
anchor.style.top = '-3000px';
// make it as a part of the div component
wgt.$n().appendChild(anchor);
// listen to event focus, blur and keydown
wgt.domListen_(anchor, 'onFocus', 'doFocus_')
.domListen_(anchor, 'onKeyDown', 'doKeyDown_')
.domListen_(anchor, 'onBlur', 'doBlur_');
}
}
</script>
<label id="lb" value=" Fish eye focused !" visible="false" />
<div height="500px">
<fisheyebar id="fsb" style="position:absolute;margin:80px 150px;"
attachEdge="bottom" itemWidth="80" itemHeight="80" itemMaxHeight="160" itemMaxWidth="160">
<fisheye onFocus="lb.setVisible(true);" onBlur="lb.setVisible(false);" use="CustomFisheye"
image="http://www.zkoss.org/zksandbox/img/Centigrade-Widget-Icons/Briefcase-128x128.png" label="Folder">
<attribute name="onCreate">
<!-- make this component focusable and can handle onCtrlKey event -->
Clients.evalJavaScript("makeFocusable('"+self.getUuid()+"')");
</attribute>
</fisheye>
<fisheye onFocus="lb.setVisible(true);" onBlur="lb.setVisible(false);" use="CustomFisheye"
image="http://www.zkoss.org/zksandbox/img/Centigrade-Widget-Icons/ReadingGlass-128x128.png" label="Reading Glasses">
<attribute name="onCreate">
<!-- make this component focusable and can handle onCtrlKey event -->
Clients.evalJavaScript("makeFocusable('"+self.getUuid()+"')");
</attribute>
</fisheye>
</fisheyebar>
</div>
</zk>