Upgrade to ExtJS 4.0.0 - Released 04/26/2011
[extjs.git] / examples / form / custom-form.js
diff --git a/examples/form/custom-form.js b/examples/form/custom-form.js
new file mode 100644 (file)
index 0000000..ec2b966
--- /dev/null
@@ -0,0 +1,103 @@
+Ext.Loader.setConfig({enabled: true});
+Ext.Loader.setPath('Ext.ux', '../ux');
+Ext.require([
+    'Ext.data.*',
+    'Ext.panel.Panel',
+    'Ext.view.View',
+    'Ext.layout.container.Fit',
+    'Ext.toolbar.Paging',
+    'Ext.ux.form.SearchField'
+]);
+
+Ext.define('Post', {
+    extend: 'Ext.data.Model',
+    idProperty: 'post_id',
+    fields: [
+        {name: 'postId', mapping: 'post_id'},
+        {name: 'title', mapping: 'topic_title'},
+        {name: 'topicId', mapping: 'topic_id'},
+        {name: 'author', mapping: 'author'},
+        {name: 'lastPost', mapping: 'post_time', type: 'date', dateFormat: 'timestamp'},
+        {name: 'excerpt', mapping: 'post_text'}
+    ]
+});
+
+Ext.onReady(function(){
+    
+    var forumId = 4;
+
+    var store = Ext.create('Ext.data.Store', {
+        model: 'Post',
+        proxy: {
+            type: 'jsonp',
+            url: 'http://sencha.com/forum/topics-remote.php',
+            extraParams: {
+                forumId: forumId
+            },
+            reader: {
+                type: 'json',
+                root: 'topics',
+                totalProperty: 'totalCount'
+            }
+        },
+        listeners: {
+            beforeload: function(){
+                var params = store.getProxy().extraParams;
+                if (params.query) {
+                    delete params.forumId;
+                } else {
+                    params.forumId = forumId;
+                }
+            }
+        }
+    });
+    store.loadPage(1);
+
+    var resultTpl = Ext.create('Ext.XTemplate',
+        '<tpl for=".">',
+        '<div class="search-item">',
+            '<h3><span>{lastPost:this.formatDate}<br />by {author}</span>',
+            '<a href="http://sencha.com/forum/showthread.php?t={topicId}&p={postId}" target="_blank">{title}</a></h3>',
+            '<p>{excerpt}</p>',
+        '</div></tpl>',
+    {
+        formatDate: function(value){
+            return Ext.Date.format(value, 'M j, Y');
+        }
+    });
+
+    var panel = Ext.create('Ext.panel.Panel', {
+        title: 'Forum Search',
+        height: 300,
+        width: 600,
+        renderTo: 'search-panel',
+        id: 'search-results',
+        layout: 'fit',
+        items: {
+            autoScroll: true,
+            xtype: 'dataview',
+            tpl: resultTpl,
+            store: store,
+            itemSelector: 'div.search-item'
+        },
+        dockedItems: [{
+            dock: 'top',
+            xtype: 'toolbar',
+            items: {
+                width: 400,
+                fieldLabel: 'Search',
+                labelWidth: 50,
+                xtype: 'searchfield',
+                store: store
+            }
+        }, {
+            dock: 'bottom',
+            xtype: 'pagingtoolbar',
+            store: store,
+            pageSize: 25,
+            displayInfo: true,
+            displayMsg: 'Topics {0} - {1} of {2}',
+            emptyMsg: 'No topics to display'
+        }]
+    });
+});