/** * Small helper class to make creating {@link Ext.data.Store}s from JSON data easier. * A JsonStore will be automatically configured with a {@link Ext.data.reader.Json}. * * A store configuration would be something like: * * var store = new Ext.data.JsonStore({ * // store configs * storeId: 'myStore', * * proxy: { * type: 'ajax', * url: 'get-images.php', * reader: { * type: 'json', * rootProperty: 'images' * } * }, * * //alternatively, a Model name can be given (see Ext.data.Store for an example) * fields: ['name', 'url', {name:'size', type: 'float'}, {name:'lastmod', type:'date'}] * }); * * This store is configured to consume a returned object of the form: * * { * images: [ * {name: 'Image one', url:'/GetImage.php?id=1', size:46.5, lastmod: new Date(2007, 10, 29)}, * {name: 'Image Two', url:'/GetImage.php?id=2', size:43.2, lastmod: new Date(2007, 10, 30)} * ] * } * * An object literal of this form could also be used as the {@link #cfg-data} config option. */Ext.define('Ext.data.JsonStore', { extend: 'Ext.data.Store', alias: 'store.json', requires: [ 'Ext.data.proxy.Ajax', 'Ext.data.reader.Json', 'Ext.data.writer.Json' ], constructor: function(config) { config = Ext.apply({ proxy: { type : 'ajax', reader: 'json', writer: 'json' } }, config); this.callParent([config]); }});