Disposition de la vbox du conteneur de champ ExtJS 4.2
Question
J'ai un formulaire qui a un conteneur de champ avec layout: {type:'vbox'}
.
Je dois placer deux champs sur la même ligne mais le radiogroup
n’est pas correctement aligné.(J'ai joint l'image pour une meilleure compréhension).
Le code du formulaire est le suivant :
{
xtype: 'datefield',
fieldLabel: 'Date',
format: 'd/m/Y',
submitFormat: 'Y-m-d H:i:s',
allowBlank: false,
disabled: true,
value: new Date()
}, {
xtype: 'fieldcontainer',
fieldLabel: 'Type',
combineErrors: true,
defaults: {
hideLabel: true
},
layout: {
type: 'vbox'
},
items: [{
xtype: 'combobox',
width: 90,
store: Ext.create('HolidayType', {
autoLoad: true
}),
displayField: 'Description',
valueField: 'HolidayTypeId',
queryMode: 'local',
allowBlank: false,
}, {
xtype: 'radiogroup',
columns: 2,
items: [{
boxLabel: 'Official',
name: 'RequestInAdvance',
inputValue: 0,
checked: true
}, {
boxLabel: 'Personal',
name: 'RequestInAdvance',
inputValue: 1
}
]
}]
}, {
xtype: 'radiogroup',
fieldLabel: 'Request',
anchor: '70%',
columns: 2,
items: [{
boxLabel: 'Payable',
name: 'Request',
inputValue: 0,
checked: true
}, {
boxLabel: 'Non Payable',
name: 'Request',
inputValue: 1
}
]
},
Une idée sur la façon dont puis-je obtenir le comportement souhaité ?
MISE À JOUR
Voici le violon sencha : https://fiddle.sencha.com/#fiddle/8ch
La solution
Vous devez spécifier une largeur soit pour vos colonnes, soit pour l'ensemble du groupe radio :
xtype: 'radiogroup',
width: 200,
columns: 2,
items: [
{ boxLabel: 'Official', name: 'Request1', inputValue: 0, checked: true },
{ boxLabel: 'Personal', name: 'Request1', inputValue: 1 }
]
Découvrez le violon : https://fiddle.sencha.com/#fiddle/8cj
Autres conseils
Résolu :
La solution était d'attribuer à chaque élément radio une largeur ou flex fixe :
Voici le violon : https://fiddle.sencha.com/#fiddle/8ci
items: [{
boxLabel: 'Official',
width: 80,
padding: '0 0 0 22',
name: 'Request1',
inputValue: 0,
checked: true
}, {
boxLabel: 'Personal',
flex: 1,
name: 'Request1',
inputValue: 1
}
]