Ext.Loader.setConfig({enabled: true}); Ext.Loader.setPath('Ext.ux.DataView', '../ux/DataView/'); Ext.require([ 'Ext.data.*', 'Ext.util.*', 'Ext.view.View', 'Ext.ux.DataView.DragSelector', 'Ext.ux.DataView.LabelEditor' ]); Ext.onReady(function(){ ImageModel = Ext.define('ImageModel', { extend: 'Ext.data.Model', fields: [ {name: 'name'}, {name: 'url'}, {name: 'size', type: 'float'}, {name:'lastmod', type:'date', dateFormat:'timestamp'} ] }); var store = Ext.create('Ext.data.Store', { model: 'ImageModel', proxy: { type: 'ajax', url: 'get-images.php', reader: { type: 'json', root: 'images' } } }); store.load(); Ext.create('Ext.Panel', { id: 'images-view', frame: true, collapsible: true, width: 535, renderTo: 'dataview-example', title: 'Simple DataView (0 items selected)', items: Ext.create('Ext.view.View', { store: store, tpl: [ '', '
', '
', '{shortName}
', '
', '
' ], multiSelect: true, height: 310, trackOver: true, overItemCls: 'x-item-over', itemSelector: 'div.thumb-wrap', emptyText: 'No images to display', plugins: [ Ext.create('Ext.ux.DataView.DragSelector', {}), Ext.create('Ext.ux.DataView.LabelEditor', {dataIndex: 'name'}) ], prepareData: function(data) { Ext.apply(data, { shortName: Ext.util.Format.ellipsis(data.name, 15), sizeString: Ext.util.Format.fileSize(data.size), dateString: Ext.util.Format.date(data.lastmod, "m/d/Y g:i a") }); return data; }, listeners: { selectionchange: function(dv, nodes ){ var l = nodes.length, s = l !== 1 ? 's' : ''; this.up('panel').setTitle('Simple DataView (' + l + ' item' + s + ' selected)'); } } }) }); });