У меня есть какой-то магазин, в котором формируются данные.На панели это выглядит как «fieldName» и текстовое поле (в зависимости от вызванной формы).Например, на одной форме отображается «имя документа» и поле, на другой - дата продажи и поле даты.Данные формируются динамически
Вот хранилище:
var someStore = new Ext.data.JsonStore({
storeId: 'myStore',
url: objectUrlAddress,
baseParams: {
'objectID' : objectID
},
root: 'Fields',
fields: [
{name: 'Hint'},
{name:'Type', type: 'int'},
{name: 'Value'},
{name: 'Index', type: 'int'},
{name: 'IsRequired', type:'bool'},
{name: 'Identifier'},
{name: 'EnumList'},
{name: 'Directory'},
{name: 'Data'}
]
});
Вот сетка:
var mainGrid = new Ext.grid.EditorGridPanel({
id: 'tableId',
height:300,
width: '100%',
frame: true,
store: someStore,
columns:
[{header: 'Объект', width:200, dataIndex: 'Hint'},
{header: 'Значение', dataIndex: 'Value', width:300, editor: {xtype: 'textfield'},
getEditor: function(record) {
var xtype = 'textfield',
args = {
fieldLabel: 'Hint',
allowBlank: 'IsRequired',
value: 'Data',
disabled: false
};
switch ('Type') {
case 0: // int
xtype = 'numberfield';
args.allowDecimals = false;
break;
case 1: // decimal
xtype = 'numberfield';
args.allowDecimals = true;
break;
case 2: // text
xtype = 'textfield';
break;
case 3: // date
xtype = 'textfield';
args.emptyText = 'дд.мм.гггг чч:мм';
args.format = 'd.m.y H:i';
break;
case 4: // enum
case 5: // sql
var dataValues = Ext.util.JSON.decode('Enumlist');
var dataArray = Object.keys(dataValues).map(function(k) { return [k, dataValues[k]] });
xtype = 'combo ';
args.store = new Ext.data.ArrayStore({
fields: [
{name: 'myId', type: 'string'},
{name: 'displayText'}
],
data: dataArray
});
break;
}
return new Ext.grid.CellEditor ({
field: Ext.create(xtype, args)
});
}
}]
});
Но у меня ошибка "TypeError: b [(промежуточное значение)]здесь не конструктор "
field: Ext.create(xtype, args)
Как я могу решить эту проблему?Пожалуйста, помогите!