最初のタブにグリッドがあるタブパネルがあります-メイングリッドと呼ばれます。メイングリッドの行をダブルクリックすると、フォームグリッドを含む新しいタブが読み込まれます。フォームグリッドで、列のレイアウトを設定しました。左側の列にグリッドがあり、右側の列にラジオグループがあるフォームがあります。
新しいタブが開くと、フォームグリッドからのグリッドが正常に読み込まれます。フォームグリッドグリッドでレコードを選択すると、フォームが正常に読み込まれ、ラジオグループも変換機能で読み込まれます。グリッドから使用している値は「はい」と「いいえ」なので、「変換」関数を使用してそれらをINTに変換し、それらを返します。
これが私のコードの抜粋です:
Ext.define('ValueRadioGroup',({
extend: 'Ext.form.RadioGroup',
alias: 'widget.valueradiogroup',
fieldLabel: 'Value',
columns: 2,
defaults: {
name: 'rating' //Radio has the same name so the browser will make sure only one is checked at once
},
items: [{
inputValue: '2',
boxLabel: 'Yey'
}, {
inputValue: '1',
boxLabel: 'Nay'
}]
}));
Ext.define('TargetViewModel', {
extend: 'Ext.data.Model',
fields : [
{name: 'ID'},
{name: 'FAMILYNAME'},
{name: 'TABLENAME'},
{name: 'TARGETNAME'},
{name: 'TARGETLABEL'},
{name: 'TARGETVALUE'},
{name: 'ITEMREL'},
{name: 'ITEMREF'},
{name: 'ITEMNAME'},
{name: 'ITEMMNEMONIC'},
{name: 'ALLOWED'},
{name: 'rating', type: 'int', convert: convertTARGETVALUE}
]
});
...そしてここにそれが呼ばれているところです:
this.items = [{
// GRID
columnWidth: .65, // GRID width
xtype: 'ggtargetviewgrid',
store: this.store,
listeners: {
selectionchange: function(model, records) {
if (records[0]) {
var value = this.up('form').getForm().loadRecord(records[0]);
}
}
}
}
,
{
// FORM
columnWidth: 0.3, // FORM width
margin: '0 0 0 10',
xtype: 'fieldset',
title:'Target Details',
defaults: {
width: 280,
labelWidth: 50
},
defaultType: 'textfield',
items: [
{
fieldLabel: 'Name',
name: 'ITEMNAME'
}, {
xtype: 'valueradiogroup'
}]
}]
これは私の変換関数です:
var convertTARGETVALUE = function(value, record) {
var tval = record.get('TARGETVALUE'), val = 0;
if (tval === 'Yes') return val+2;
if (tval === 'No') return val+1;
return val;
};
問題は、ラジオグループが最初のフォームグリッドに対しては正常に機能するが、2番目のフォームグリッドに対しては機能しないことです。