1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
/* ************************************************************************
qooxdoo - the new era of web development
http://qooxdoo.org
Copyright:
2004-2006 by 1&1 Internet AG, Germany, http://www.1and1.org
License:
LGPL 2.1: http://www.gnu.org/licenses/lgpl.html
Authors:
* Sebastian Werner (wpbasti)
* Andreas Ecker (ecker)
************************************************************************ */
/* ************************************************************************
#module(ui_form)
************************************************************************ */
/**
* @event action {qx.event.type.Event} (Fired by {@link qx.ui.form.List})
*/
qx.OO.defineClass("qx.ui.form.ListItem", qx.ui.basic.Atom,
function(vText, vIcon, vValue)
{
qx.ui.basic.Atom.call(this, vText, vIcon);
if (qx.util.Validation.isValid(vValue)) {
this.setValue(vValue);
}
// ************************************************************************
// EVENT LISTENER
// ************************************************************************
this.addEventListener("dblclick", this._ondblclick);
});
qx.OO.changeProperty({ name : "appearance", type : "string", defaultValue : "list-item" });
qx.OO.addProperty({ name : "value" });
/*
---------------------------------------------------------------------------
STATE
---------------------------------------------------------------------------
*/
qx.Proto.handleStateChange = function()
{
if (this.hasState("lead"))
{
this.setStyleProperty("MozOutline", "1px dotted invert");
this.setStyleProperty("outline", "1px dotted invert");
}
else
{
this.removeStyleProperty("MozOutline");
this.setStyleProperty("outline", "0px none");
}
}
// Remove default outline focus border
qx.Proto._applyStateStyleFocus = function(vStates) {};
/*
---------------------------------------------------------------------------
UTILITIES
---------------------------------------------------------------------------
*/
qx.Proto.matchesString = function(vText) {
return vText != "" && this.getLabel().toLowerCase().indexOf(vText.toLowerCase()) == 0;
}
qx.Proto.matchesStringExact = function(vText) {
return vText != "" && this.getLabel().toLowerCase() == String(vText).toLowerCase();
}
qx.Proto.matchesValue = function(vText) {
return vText != "" && this.getValue().toLowerCase().indexOf(vText.toLowerCase()) == 0;
}
qx.Proto.matchesValueExact = function(vText) {
return vText != "" && this.getValue().toLowerCase() == String(vText).toLowerCase();
}
/*
---------------------------------------------------------------------------
EVENT HANDLER
---------------------------------------------------------------------------
*/
qx.Proto._ondblclick = function(e)
{
var vCommand = this.getCommand();
if (vCommand) {
vCommand.execute();
}
}
|