Контекстные операции с Sencha Touch2
Мое требование - иметь панель с вкладками и сегментированные контекстные кнопки (подоперации) на одной из панелей вкладок. При нажатии на кнопку мы должны скрыть текущий список и показать новый список.
Я могу показать сегментированные кнопки, но не списки ниже, а также не могу добавить новый список на основе нажатия кнопки.
Представление списка визуализируется и отображается при проверке в отладчике Chrome, однако оно не отображается на странице.
Ext.define('myApp.view.Main', {
extend: 'Ext.tab.Panel',
xtype: 'main',
requires: [
'Ext.TitleBar',
'Ext.Video',
'Ext.data.TreeStore',
'myApp.view.cont',
'myApp.view.listview'
],
config: {
tabBarPosition: 'bottom',
items: [{
alias : 'widget.myPagesViewPanel',
title: 'container',
iconCls: 'user',
xtype: 'container',
layout: 'vbox',
items:[{
docked: 'top',
xtype: 'toolbar',
items: [{
id:'myPageControls',
xtype: 'segmentedbutton',
allowDepress: false,
items: [{
text: 'show list1', pressed: true
},
{
text: 'show list2'
}]
}]
},
{
xtype:'listdata',
layout:'fit'
}]
},
{
title: 'Contact',
iconCls: 'user',
xtype: 'formpanel',
url: 'contact.php',
layout: 'vbox',
items: [{
xtype: 'fieldset',
title: 'Contact Us',
instructions: '(email address is optional)',
height: 285,
items: [{
xtype: 'textfield',
label: 'Name'
},
{
xtype: 'emailfield',
label: 'Email'
},
{
xtype: 'textareafield',
label: 'Message'
}]
},
{
xtype: 'button',
text: 'Send',
ui: 'confirm',
handler: function() {
this.up('formpanel').submit();
}
}]
}]
}
});
Ext.define('myApp.view.centerlistview', {
extend: 'Ext.List',
xtype: 'centerlistdata',
config: {
onItemDisclosure: false, // by true this will add a arrow mark
emptyText: 'No data found!',
store: {
fields: ['name'],
data: [
{name: 'list2-1'},
{name: 'list2-1'},
{name: 'list3-1'}
]
},
itemTpl: '{name}'
}
});
Ext.define('myApp.view.listview', {
extend: 'Ext.List',
xtype: 'listdata',
config: {
onItemDisclosure: false, // by true this will add a arrow mark
emptyText: 'No data found!',
store: {
fields: ['name'],
data: [
{name: 'list1-1'},
{name: 'list1-2'},
{name: 'list1-3'}
]
},
itemTpl: '{name}'
}
});
Ext.define('myApp.controller.MyAppController', {extend : 'Ext.app.Controller',
requires:['myApp.view.centerlistview'],
xtype: 'listdata',
config: {
refs: {
segBtnId : "#myPageControls",
myNavigationView: 'myPagesViewPanel',
},
control: {segBtnId : {toggle : "tapHandler"}}},
launch: function() {this.callParent();},
tapHandler: function(segBtn, button,toggle) {
if(toggle){
var canvas = segBtn.up().up();
canvas.setActiveItem({xtype:'centerlistdata'});
}
}
});