getbogged
9 Apr 2012, 10:54 AM
I am creating multiple grids inside of a panel and have them being able to be dragged and dropped to each other. For my base grids with my data i am using this
var store = Ext.create('Ext.data.Store', {
model: 'DataObject',
data: adata
});
var rround = "panel-game-"+round;
var ss = Ext.create('Ext.grid.Panel', {
stateful: true,
id: "panel-game-"+round,
stateId: 'stateGrid',
autoScroll: false,
store: store,
columns: [
{
text : 'Teams',
flex : 1,
sortable : true,
dataIndex: 'team_name'
}
],
height: 100,
width: 150,
title: 'Game ' + round,
viewConfig: {
stripeRows: true,
plugins: {
ptype: 'gridviewdragdrop',
dragGroup: ["draggroup","dropgroup"],
dropGroup: ["draggroup","dropgroup"]
},
listeners: {
drop: function(node, data, dropRec, dropPosition,record,store) {
var dropOn = dropRec ? ' ' + dropPosition + ' ' + dropRec.get('name') : ' on empty view';
var data = this.store.data.items;
var sdata = new Array();
data.each(function(e){
var bleh = {team_id: e.data.team_id, team_name:e.data.team_name};
sdata.push(bleh);
})
console.log(sdata);
removeDupe(sdata,this.store); } } }
});
This is used to create blank grids
var rCellStore = Ext.create('Ext.data.Store', {
model: 'DataObject'
});
var rCell = Ext.create('Ext.grid.Panel', {
stateful: true,
id: "panel-game-"+i+'-'+a,
stateId: 'stateGrid',
autoScroll: false,
store: rCellStore,
columns: [
{
text : 'Teams',
flex : 1,
sortable : true,
dataIndex: 'team_name'
}
],
viewConfig: {
plugins: {
ptype: 'gridviewdragdrop',
dragGroup: ["draggroup","dropgroup"],
dropGroup: ["draggroup","dropgroup"]
},
listeners: {
drop: function(node, data, dropRec, dropPosition, record) {
var dropOn = dropRec ? ' ' + dropPosition + ' ' + dropRec.get('title') : ' on empty view';
var f = node.id.replace('-body','');
var newval = data.records[0].data;
if(f != undefined && f != ''){
var fstore = Ext.getCmp(f).getStore();
fstore.add(newval);
}
var data = this.store.data.items;
var sdata = new Array();
data.each(function(e){
var bleh = {team_id: e.data.team_id, team_name:e.data.team_name};
sdata.push(bleh);
})
// console.log(sdata);
removeDupe(sdata,this.store);
}
}
},
height: 100,
width: 150,
title: 'Game ',
viewConfig: {
stripeRows: true
}
});
items.push({html: '<id="'+i+'-'+a+'"></id> ', items: [rCell]});
This works perfectly in chrome as i can drag and drop to anywhere form anywhere. When using IE, Safari, or FF they will only drag within the original grids that already have data in them.
var store = Ext.create('Ext.data.Store', {
model: 'DataObject',
data: adata
});
var rround = "panel-game-"+round;
var ss = Ext.create('Ext.grid.Panel', {
stateful: true,
id: "panel-game-"+round,
stateId: 'stateGrid',
autoScroll: false,
store: store,
columns: [
{
text : 'Teams',
flex : 1,
sortable : true,
dataIndex: 'team_name'
}
],
height: 100,
width: 150,
title: 'Game ' + round,
viewConfig: {
stripeRows: true,
plugins: {
ptype: 'gridviewdragdrop',
dragGroup: ["draggroup","dropgroup"],
dropGroup: ["draggroup","dropgroup"]
},
listeners: {
drop: function(node, data, dropRec, dropPosition,record,store) {
var dropOn = dropRec ? ' ' + dropPosition + ' ' + dropRec.get('name') : ' on empty view';
var data = this.store.data.items;
var sdata = new Array();
data.each(function(e){
var bleh = {team_id: e.data.team_id, team_name:e.data.team_name};
sdata.push(bleh);
})
console.log(sdata);
removeDupe(sdata,this.store); } } }
});
This is used to create blank grids
var rCellStore = Ext.create('Ext.data.Store', {
model: 'DataObject'
});
var rCell = Ext.create('Ext.grid.Panel', {
stateful: true,
id: "panel-game-"+i+'-'+a,
stateId: 'stateGrid',
autoScroll: false,
store: rCellStore,
columns: [
{
text : 'Teams',
flex : 1,
sortable : true,
dataIndex: 'team_name'
}
],
viewConfig: {
plugins: {
ptype: 'gridviewdragdrop',
dragGroup: ["draggroup","dropgroup"],
dropGroup: ["draggroup","dropgroup"]
},
listeners: {
drop: function(node, data, dropRec, dropPosition, record) {
var dropOn = dropRec ? ' ' + dropPosition + ' ' + dropRec.get('title') : ' on empty view';
var f = node.id.replace('-body','');
var newval = data.records[0].data;
if(f != undefined && f != ''){
var fstore = Ext.getCmp(f).getStore();
fstore.add(newval);
}
var data = this.store.data.items;
var sdata = new Array();
data.each(function(e){
var bleh = {team_id: e.data.team_id, team_name:e.data.team_name};
sdata.push(bleh);
})
// console.log(sdata);
removeDupe(sdata,this.store);
}
}
},
height: 100,
width: 150,
title: 'Game ',
viewConfig: {
stripeRows: true
}
});
items.push({html: '<id="'+i+'-'+a+'"></id> ', items: [rCell]});
This works perfectly in chrome as i can drag and drop to anywhere form anywhere. When using IE, Safari, or FF they will only drag within the original grids that already have data in them.