📄 livesearchsample.java
字号:
/*
* GWT-Ext Widget Library
* Copyright 2007 - 2008, GWT-Ext LLC., and individual contributors as indicated
* by the @authors tag. See the copyright.txt in the distribution for a
* full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 3 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package com.gwtext.sample.showcase2.client.combo;
import com.google.gwt.user.client.Window;
import com.gwtext.client.data.*;
import com.gwtext.client.util.Format;
import com.gwtext.client.widgets.Panel;
import com.gwtext.client.widgets.form.ComboBox;
import com.gwtext.client.widgets.form.FormPanel;
import com.gwtext.client.widgets.form.event.ComboBoxListenerAdapter;
import com.gwtext.sample.showcase2.client.ShowcasePanel;
/**
* Styled ComboBox that gets data from a remote Json web service.
*/
public class LiveSearchSample extends ShowcasePanel {
public String getSourceUrl() {
return "source/combo/LiveSearchSample.java.html";
}
public Panel getViewPanel() {
if (panel == null) {
panel = new Panel();
panel.setId("livesearch");
//Use a ScriptTagProxy because you are getting data from a different domain using
//a Json web service. If getting data from your own domain, then should use HttpProxy
DataProxy dataProxy = new ScriptTagProxy("http://extjs.com/forum/topics-remote.php");
RecordDef recordDef = new RecordDef(new FieldDef[]{
new StringFieldDef("title", "topic_title"),
new StringFieldDef("topicId", "topic_id"),
new StringFieldDef("author", "author"),
new DateFieldDef("lastPost", "post_time", "timestamp"),
new StringFieldDef("excerpt", "post_text")
});
JsonReader reader = new JsonReader(recordDef);
reader.setRoot("topics");
reader.setTotalProperty("totalCount");
reader.setId("post_id");
final Store store = new Store(dataProxy, reader);
store.load();
final String resultTpl = "<div class=\"search-item\"><h3><span>{lastPost:date(\"M j, Y\")}<br />" +
"by {author}</span>{title}</h3>{excerpt}</div>";
ComboBox cb = new ComboBox();
cb.setStore(store);
cb.setDisplayField("title");
cb.setTypeAhead(false);
cb.setLoadingText("Searching...");
cb.setWidth(440);
cb.setPageSize(10);
cb.setHideTrigger(true);
cb.setTpl(resultTpl);
cb.setMode(ComboBox.REMOTE);
cb.setTitle("ExtJS Forums");
cb.setHideLabel(true);
cb.setItemSelector("div.search-item");
cb.addListener(new ComboBoxListenerAdapter() {
public void onSelect(ComboBox comboBox, Record record, int index) {
String[] args = new String[]{record.getAsString("topicId"), record.getId()};
String url = Format.format("http://extjs.com/forum/showthread.php?t={0}&p={1}", args);
Window.open(url, "forum", "");
}
});
Panel searchPanel = new Panel();
searchPanel.setWidth(490);
searchPanel.setHeight(150);
searchPanel.setPaddings(20);
searchPanel.setTitle("Search ExtJS Forums");
searchPanel.setFrame(true);
FormPanel form = new FormPanel();
form.setBorder(false);
form.add(cb);
searchPanel.add(form);
Panel instructionPanel = new Panel();
instructionPanel.setBorder(false);
instructionPanel.setPaddings(4,0,0,0);
instructionPanel.setHtml("Live search requires a minimum of 4 characters.");
searchPanel.add(instructionPanel);
panel.add(searchPanel);
}
return panel;
}
public String getIntro() {
return "<p>\n" +
" <b>Combo with Templates & Ajax</b>\n" +
" <p>This is a more advanced example that shows how you can combine paging, Template and a remote data store\n" +
" to create a \"live search\" feature.</p><p>Live search requires a minimum of 4 characters.</p>\n" +
" <p>This examples calls a Json Webservice to retreive data from the ExtJS forums and populate the Store backing the ComboBox.</p>"+
"</p>";
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -