2 |
aperonnet |
1 |
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
|
|
|
2 |
<html>
|
|
|
3 |
<head>
|
|
|
4 |
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
|
|
|
5 |
<title>Combo Boxes</title>
|
|
|
6 |
<link rel="stylesheet" type="text/css" href="../../resources/css/ext-all.css" />
|
|
|
7 |
<link rel="stylesheet" type="text/css" href="../../resources/css/xtheme-gray.css" />
|
|
|
8 |
|
|
|
9 |
<!-- GC -->
|
|
|
10 |
<!-- LIBS -->
|
|
|
11 |
<script type="text/javascript" src="../../adapter/ext/ext-base.js"></script>
|
|
|
12 |
<!-- ENDLIBS -->
|
|
|
13 |
|
|
|
14 |
<script type="text/javascript" src="../../ext-all.js"></script>
|
|
|
15 |
|
|
|
16 |
<script type="text/javascript" src="states.js"></script>
|
|
|
17 |
<script type="text/javascript" src="combos.js"></script>
|
|
|
18 |
<link rel="stylesheet" type="text/css" href="combos.css" />
|
|
|
19 |
|
|
|
20 |
<!-- Common Styles for the examples -->
|
|
|
21 |
<link rel="stylesheet" type="text/css" href="../examples.css" />
|
|
|
22 |
<style type="text/css">
|
|
|
23 |
p { width:650px; }
|
|
|
24 |
</style>
|
|
|
25 |
</head>
|
|
|
26 |
<body>
|
|
|
27 |
<script type="text/javascript" src="../examples.js"></script><!-- EXAMPLES -->
|
|
|
28 |
<h1>Combo Boxes</h1>
|
|
|
29 |
<p>The js is not minified so it is readable. See <a href="combos.js">combos.js</a>.</p>
|
|
|
30 |
|
|
|
31 |
<p>
|
|
|
32 |
<b>Data Sources</b><br />
|
|
|
33 |
The combo box can use any type of Ext.data.Store as it's data source.
|
|
|
34 |
This means your data can be XML, JSON, arrays or any other supported format. It can be loaded using Ajax, script tags or be local.
|
|
|
35 |
This combo uses local data from a JS array:<p>
|
|
|
36 |
<div>
|
|
|
37 |
<input type="text" id="local-states" size="20"/>
|
|
|
38 |
</div>
|
|
|
39 |
<div id="state-combo-code-panel" style="margin-top:10px">
|
|
|
40 |
<pre id="state-combo-code" class="code"><code>// simple array store
|
|
|
41 |
var store = new Ext.data.SimpleStore({
|
|
|
42 |
fields: ['abbr', 'state'],
|
|
|
43 |
data : exampleData
|
|
|
44 |
});
|
|
|
45 |
var combo = new Ext.form.ComboBox({
|
|
|
46 |
store: store,
|
|
|
47 |
displayField:'state',
|
|
|
48 |
typeAhead: true,
|
|
|
49 |
mode: 'local',
|
|
|
50 |
triggerAction: 'all',
|
|
|
51 |
emptyText:'Select a state...',
|
|
|
52 |
selectOnFocus:true,
|
|
|
53 |
applyTo: 'local-states'
|
|
|
54 |
});
|
|
|
55 |
</code></pre></div>
|
|
|
56 |
<br />
|
|
|
57 |
</p>
|
|
|
58 |
<p>
|
|
|
59 |
The combo below uses the same data, but also illustrates how to use an optional
|
|
|
60 |
custom template to create custom UI renditions for list items. In this case,
|
|
|
61 |
each item has a popup QuickTip which displays the state's nickname when hovered over.
|
|
|
62 |
</p>
|
|
|
63 |
<div>
|
|
|
64 |
<input type="text" id="local-states-with-qtip" size="20"/>
|
|
|
65 |
</div>
|
|
|
66 |
<div id="state-combo-qtip-code-panel" style="margin-top:10px">
|
|
|
67 |
<pre id="state-combo-qtip-code" class="code"><code>// simple array store
|
|
|
68 |
var store = new Ext.data.SimpleStore({
|
|
|
69 |
fields: ['abbr', 'state', 'nick'],
|
|
|
70 |
data : exampleData
|
|
|
71 |
});
|
|
|
72 |
var comboWithTooltip = new Ext.form.ComboBox({
|
|
|
73 |
tpl: '<tpl for="."><div ext:qtip="{state}. {nick}" class="x-combo-list-item">{state}</div></tpl>',
|
|
|
74 |
store: store,
|
|
|
75 |
displayField:'state',
|
|
|
76 |
typeAhead: true,
|
|
|
77 |
mode: 'local',
|
|
|
78 |
triggerAction: 'all',
|
|
|
79 |
emptyText:'Select a state...',
|
|
|
80 |
selectOnFocus:true,
|
|
|
81 |
applyTo: 'local-states-with-qtip'
|
|
|
82 |
});
|
|
|
83 |
</code></pre></div>
|
|
|
84 |
<br />
|
|
|
85 |
<p>
|
|
|
86 |
<b>Unobtrusive</b><br />
|
|
|
87 |
The combo box can very easily be used to convert existing select elements into auto-completing, filtering combos.
|
|
|
88 |
</p>
|
|
|
89 |
<div>
|
|
|
90 |
Transformed select:<br/> <select name="state" id="state">
|
|
|
91 |
<option value="AL">Alabama</option>
|
|
|
92 |
<option value="AK">Alaska</option>
|
|
|
93 |
<option value="AZ">Arizona</option>
|
|
|
94 |
<option value="AR">Arkansas</option>
|
|
|
95 |
<option value="CA">California</option>
|
|
|
96 |
<option value="CO">Colorado</option>
|
|
|
97 |
<option value="CT">Connecticut</option>
|
|
|
98 |
<option value="DE">Delaware</option>
|
|
|
99 |
<option value="FL">Florida</option>
|
|
|
100 |
<option value="GA">Georgia</option>
|
|
|
101 |
<option value="HI">Hawaii</option>
|
|
|
102 |
<option value="ID">Idaho</option>
|
|
|
103 |
<option value="IL">Illinois</option>
|
|
|
104 |
<option value="IN">Indiana</option>
|
|
|
105 |
<option value="IA">Iowa</option>
|
|
|
106 |
<option value="KS">Kansas</option>
|
|
|
107 |
<option value="KY">Kentucky</option>
|
|
|
108 |
<option value="LA">Louisiana</option>
|
|
|
109 |
<option value="ME">Maine</option>
|
|
|
110 |
<option value="MD">Maryland</option>
|
|
|
111 |
<option value="MA">Massachusetts</option>
|
|
|
112 |
<option value="MI">Michigan</option>
|
|
|
113 |
<option value="MN">Minnesota</option>
|
|
|
114 |
<option value="MS">Mississippi</option>
|
|
|
115 |
<option value="MO">Missouri</option>
|
|
|
116 |
<option value="MT">Montana</option>
|
|
|
117 |
<option value="NE">Nebraska</option>
|
|
|
118 |
<option value="NV">Nevada</option>
|
|
|
119 |
<option value="NH">New Hampshire</option>
|
|
|
120 |
<option value="NJ">New Jersey</option>
|
|
|
121 |
<option value="NM">New Mexico</option>
|
|
|
122 |
<option value="NY">New York</option>
|
|
|
123 |
<option value="NC">North Carolina</option>
|
|
|
124 |
<option value="ND">North Dakota</option>
|
|
|
125 |
<option value="OH" selected>Ohio</option>
|
|
|
126 |
<option value="OK">Oklahoma</option>
|
|
|
127 |
<option value="OR">Oregon</option>
|
|
|
128 |
<option value="PA">Pennsylvania</option>
|
|
|
129 |
<option value="RI">Rhode Island</option>
|
|
|
130 |
<option value="SC">South Carolina</option>
|
|
|
131 |
<option value="SD">South Dakota</option>
|
|
|
132 |
<option value="TN">Tennessee</option>
|
|
|
133 |
<option value="TX">Texas</option>
|
|
|
134 |
<option value="UT">Utah</option>
|
|
|
135 |
<option value="VT">Vermont</option>
|
|
|
136 |
<option value="VA">Virginia</option>
|
|
|
137 |
<option value="WA">Washington</option>
|
|
|
138 |
<option value="WV">West Virginia</option>
|
|
|
139 |
<option value="WI">Wisconsin</option>
|
|
|
140 |
<option value="WY">Wyoming</option>
|
|
|
141 |
</select>
|
|
|
142 |
</div><br />
|
|
|
143 |
<p>
|
|
|
144 |
Originally looked like:<br/> <select name="state-orig">
|
|
|
145 |
<option value="AL">Alabama</option>
|
|
|
146 |
<option value="AK">Alaska</option>
|
|
|
147 |
<option value="AZ">Arizona</option>
|
|
|
148 |
<option value="AR">Arkansas</option>
|
|
|
149 |
<option value="CA">California</option>
|
|
|
150 |
<option value="CO">Colorado</option>
|
|
|
151 |
<option value="CT">Connecticut</option>
|
|
|
152 |
<option value="DE">Delaware</option>
|
|
|
153 |
<option value="FL">Florida</option>
|
|
|
154 |
<option value="GA">Georgia</option>
|
|
|
155 |
<option value="HI">Hawaii</option>
|
|
|
156 |
<option value="ID">Idaho</option>
|
|
|
157 |
<option value="IL">Illinois</option>
|
|
|
158 |
<option value="IN">Indiana</option>
|
|
|
159 |
<option value="IA">Iowa</option>
|
|
|
160 |
<option value="KS">Kansas</option>
|
|
|
161 |
<option value="KY">Kentucky</option>
|
|
|
162 |
<option value="LA">Louisiana</option>
|
|
|
163 |
<option value="ME">Maine</option>
|
|
|
164 |
<option value="MD">Maryland</option>
|
|
|
165 |
<option value="MA">Massachusetts</option>
|
|
|
166 |
<option value="MI">Michigan</option>
|
|
|
167 |
<option value="MN">Minnesota</option>
|
|
|
168 |
<option value="MS">Mississippi</option>
|
|
|
169 |
<option value="MO">Missouri</option>
|
|
|
170 |
<option value="MT">Montana</option>
|
|
|
171 |
<option value="NE">Nebraska</option>
|
|
|
172 |
<option value="NV">Nevada</option>
|
|
|
173 |
<option value="NH">New Hampshire</option>
|
|
|
174 |
<option value="NJ">New Jersey</option>
|
|
|
175 |
<option value="NM">New Mexico</option>
|
|
|
176 |
<option value="NY">New York</option>
|
|
|
177 |
<option value="NC">North Carolina</option>
|
|
|
178 |
<option value="ND">North Dakota</option>
|
|
|
179 |
<option value="OH" selected>Ohio</option>
|
|
|
180 |
<option value="OK">Oklahoma</option>
|
|
|
181 |
<option value="OR">Oregon</option>
|
|
|
182 |
<option value="PA">Pennsylvania</option>
|
|
|
183 |
<option value="RI">Rhode Island</option>
|
|
|
184 |
<option value="SC">South Carolina</option>
|
|
|
185 |
<option value="SD">South Dakota</option>
|
|
|
186 |
<option value="TN">Tennessee</option>
|
|
|
187 |
<option value="TX">Texas</option>
|
|
|
188 |
<option value="UT">Utah</option>
|
|
|
189 |
<option value="VT">Vermont</option>
|
|
|
190 |
<option value="VA">Virginia</option>
|
|
|
191 |
<option value="WA">Washington</option>
|
|
|
192 |
<option value="WV">West Virginia</option>
|
|
|
193 |
<option value="WI">Wisconsin</option>
|
|
|
194 |
<option value="WY">Wyoming</option>
|
|
|
195 |
</select>
|
|
|
196 |
</p>
|
|
|
197 |
<div id="transformed-combo-code-panel" style="margin-top:10px">
|
|
|
198 |
<pre id="transformed-combo-code" class="code"><code>var converted = new Ext.form.ComboBox({
|
|
|
199 |
typeAhead: true,
|
|
|
200 |
triggerAction: 'all',
|
|
|
201 |
transform:'state',
|
|
|
202 |
width:135,
|
|
|
203 |
forceSelection:true
|
|
|
204 |
});
|
|
|
205 |
</code></pre></div>
|
|
|
206 |
<br />
|
|
|
207 |
<p>
|
|
|
208 |
<b>Grid Editor</b><br />
|
|
|
209 |
<a href="../grid/edit-grid.html">Click here</a> to see the combo as a grid editor.
|
|
|
210 |
</p>
|
|
|
211 |
<br />
|
|
|
212 |
<p>
|
|
|
213 |
<b>Templates and Ajax</b><br />
|
|
|
214 |
<a href="forum-search.html">Click here</a> for a more advanced example.
|
|
|
215 |
</p>
|
|
|
216 |
<br /><br /><br /><br />
|
|
|
217 |
</body>
|
|
|
218 |
</html>
|