Ext.require([
'Ext.data.*',
'Ext.grid.*',
'Ext.tree.*'
]);
var ptag = false;
var ptag2=0;
var partyName;
var companyNumber;
Ext.onReady(function() {
Ext.define('Task', {
extend: 'Ext.data.Model',
fields: [
{name:'totalCount', type:'string'},
{name: 'groupName', type: 'string'}, //集团名称
{name: 'company_Leader', type: 'string'},//公司领导 5
{name: 'info_Tech', type: 'string'},//信息技术 0
{name: 'core_Business', type: 'string'},//核心业务 1
{name: 'finance_Purchase', type: 'string'}, //财务采购 2
{name: 'administrative_Department', type: 'string'},//行政部门 3
{name: 'regulatory_Department', type: 'string'},// 纪检部门 4
{name: 'other', type: 'string'}, //其它
{name: 'province', type: 'string'}, //所在省
{name: 'partyid', type:'string'} //parytId
],
idProperty:"partyid"
});
//treegird 的store
var store = Ext.create('Ext.data.TreeStore', {
model: 'Task',
proxy: {
type: 'ajax',
url: 'memberTreeODS.do', //memberTreeGrid JSON
reader: {
type: 'json',
root: 'children',
totalProperty:'totalCount'
}
},
autoLoad:false
});
var itemsPerPage = 1; // set the number of items you want per page
var storePage = Ext.create('Ext.data.Store', {
id:'simpsonsStore',
autoLoad: false,
fields:[],
pageSize: itemsPerPage, // items per page
proxy: {
type: 'ajax',
url: 'memberTreeODS.do', // url that will load data with respect to start and limit params
reader: {
type: 'json',
root: 'children',
totalProperty: 'totalCount'
}
}
});
if(ptag2==0){
alert(1);
storePage.load({
params:{
start:0,
limit: itemsPerPage,
partyName1:'Test'
}
});}else{
alert(2);
storePage.load({
params:{
start:0,
limit: itemsPerPage,
partyName:Ext.getCmp('party').getValue(),
companyNumber:Ext.getCmp('companyCode').getValue()
}
});
};
var bbarModel=new Ext.PagingToolbar({
id:'pageTool',
pageSize:pageSize,
store:storePage , //分页的STORE
displayInfo:true,
displayMsg:'显示{0}---{1}条,共{2}条',
emptyMsg:"没有记录",
listeners:{
change:function(obj,pdata,options){
//store3.removeAll( ) ;
if(pdata.currentPage==1){
if(ptag2 ==0){
return;
}
}
ptag2++;
partyName=Ext.getCmp('party').getValue();
companeyNumber=Ext.getCmp('companyCode').getValue();
store.on('beforeload',function(){ // =======翻页时 查询条件
store.baseParams={
partyName:Ext.getCmp('party').getValue(),companyNumber:Ext.getCmp('companyCode').getValue()
}
});
store.load({
params:{
start:pdata.fromRecord,
page:pdata.currentPage,
limit: itemsPerPage
}
});
//var x=pdata;
}
}
}
)
var companyOptions = new Ext.data.Store({
fields: ['id','name'],
proxy: new Ext.data.HttpProxy({
url: rootPath + '/vip/getCompany.do'
}),
reader: new Ext.data.JsonReader({
type: "json"
}),
autoLoad:true
});
var combo = Ext.create('Ext.form.ComboBox',{
id:"companyCode",
store:companyOptions,
valueField:'id',
displayField:'name',
fieldLabel:'所属省份',
labelAlign:'right',
emptyText: '请选择...',
editable: false,
multiSelect:false
});
var pageSize=1;
//Ext.ux.tree.TreeGrid is no longer a Ux. You can simply use a tree.TreePanel
var tree = Ext.create('Ext.tree.Panel', {
id:'trPanel',
title: '重要成员信息',
// width: 1000,
height: 400,
// renderTo: treegrid,
collapsible: true,
border:'1 1 1 1',
useArrows: true,
rootVisible: false,
store: store,
multiSelect: false,
singleExpand: true,
align: 'center',
bbar: new Ext.PagingToolbar({
partyName:partyName,
companyNumber:companyNumber,
id:'pageTool',
pageSize:pageSize,
store:storePage , //分页的STORE
displayInfo:true,
displayMsg:'显示{0}---{1}条,共{2}条',
emptyMsg:"没有记录",
listeners:{
change:function(obj,pdata,options){
//store3.removeAll( ) ;
if(pdata.currentPage==1){
if(ptag2 ==0){
return;
}
}
ptag2++;
store.load({
params:{
partyName:Ext.getCmp('party').getValue(),
companyNumber:Ext.getCmp('companyCode').getValue(),
start:pdata.fromRecord,
page:pdata.currentPage,
limit: itemsPerPage
}
});
}
}
}
),
columns: [{
xtype: 'treecolumn', //this is so we know which column will show the tree
text: '集团名称',
flex: 1,
sortable: false,
align: 'center',
dataIndex: 'groupName' //??????????
},{
text: '公司领导',
flex: 1,
dataIndex: 'company_Leader',
align: 'center',
renderer:function(v,v2,rec){
return '<span style="color:blue;" onclick="openItems(\'5\',\''+rec.data.partyid+'\')">'+v+'</span>';
},
sortable: false
},{
text: '信息技术',
flex: 1,
dataIndex: 'info_Tech',
align: 'center',
renderer:function(v,v2,rec){
return '<span style="color:blue;" onclick="openItems(\'0\',\''+rec.data.partyid+'\')">'+v+'</span>';
},
sortable: false
},{
text: '核心业务',
flex: 1,
dataIndex: 'core_Business',
align: 'center',
renderer:function(v,v2,rec){
return '<span style="color:blue;" onclick="openItems(\'1\',\''+rec.data.partyid+'\')">'+v+'</span>';
},
sortable: false
},{
text: '财务采购',
flex: 1,
dataIndex: 'finance_Purchase',
align: 'center',
renderer:function(v,v2,rec){
return '<span style="color:blue;" onclick="openItems(\'2\',\''+rec.data.partyid+'\')">'+v+'</span>';
},
sortable: false
},{
text: '行政部门',
flex: 1,
dataIndex: 'administrative_Department',
align: 'center',
renderer:function(v,v2,rec){
return '<span style="color:blue;" onclick="openItems(\'3\',\''+rec.data.partyid+'\')">'+v+'</span>';
},
sortable: false
},{
text: '纪检剖门',
flex: 1,
dataIndex: 'regulatory_Department',
align: 'center',
renderer:function(v,v2,rec){
return '<span style="color:blue;" onclick="openItems(\'4\',\''+rec.data.partyid+'\')">'+v+'</span>';
},
sortable: false
},{
text: '其它',
flex: 1,
dataIndex: 'other',
align: 'center',
renderer:function(v,v2,rec){
return '<span style="color:blue;" onclick="openItems(\'9\',\''+rec.data.partyid+'\')">'+v+'</span>';
},
sortable: false
},{
text: '所在省',
flex: 1,
dataIndex: 'province',
align: 'center',
sortable: false
}
]
});
var layout=Ext.create('Ext.panel.Panel',
{
bodyStyle:{
style:'border-left: 0 solid #8db2e3;'
},
items:[
{
xtype:'panel',
layout:{
type:'table',
columns:3
},
defaults:{labelAlign:'right',fieldWidth:100,margin:'10px 5px 10px 10px'},
items:[
combo,
{
xtype:'textfield',
fieldLabel:'集团客户',
id:'party'
},{
xtype:'button',
text:'查询',
handler:function(){
ptag = false;
ptag2=0;
var obj=Ext.getCmp("pageTool");
//var objTP=Ext.getCmp("trPanel");
//objTP.bbar=bbarModel;
store.load({
params:{
start:0,
page:1,
limit: itemsPerPage,
partyName:Ext.getCmp('party').getValue(),
companyNumber:Ext.getCmp('companyCode').getValue()
},
callback:function(r,options,success){
var r=r;
var options=options;
var storePageObj=Ext.getCmp('simpsonsStore');
storePage.load({
params:{
start:0,
page:1,
limit: itemsPerPage,
partyName:Ext.getCmp('party').getValue(),
companyNumber:Ext.getCmp('companyCode').getValue()
}
});
obj.moveFirst();
}
});
/*storePage.load({
params:{
start:0,
page:1,
limit: itemsPerPage,
partyName:Ext.getCmp('party').getValue(),
companyNumber:Ext.getCmp('companyCode').getValue()
},
callback:function(r,options,success){
var r=r;
var options=options;
var storePageObj=Ext.getCmp('simpsonsStore');
}
});
*/
//还是没执行,分页还是没到初始化
/*
storePage.on('beforeload',function(){ // =======翻页时 查询条件
storePage.baseParams={
partyName:Ext.getCmp('party').getValue(),companyNumber:Ext.getCmp('companyCode').getValue()
};
}); */
}
}
]
},
tree
]
});
layout.render(document.body);
});
function openItems(six,partyid,countno){
countno=1;
window.open('../memberInfo/memberListView.do?partyId='+partyid+'&vipDepartmentId='+six, '详细信息', 'height=600, width=800, top=100, status=no') ;
}
这是JS
这里你会发现有两个Store,但他们引用了同一个JSON数据源.一个treestroe,一个是store,由于我不能把treestroe 直接变成Stroer所有用了两个.如果有高人的话不妨指点一下.