]>
git.proxmox.com Git - pve-manager.git/blob - www/manager/qemu/Options.js
1 /*jslint confusion: true */
2 Ext
.define('PVE.qemu.Options', {
3 extend
: 'PVE.grid.PendingObjectGrid',
4 alias
: ['widget.PVE.qemu.Options'],
6 initComponent : function() {
10 var nodename
= me
.pveSelNode
.data
.node
;
12 throw "no node name specified";
15 var vmid
= me
.pveSelNode
.data
.vmid
;
17 throw "no VM ID specified";
20 var caps
= Ext
.state
.Manager
.get('GuiCap');
25 defaultValue
: me
.pveSelNode
.data
.name
,
26 header
: gettext('Name'),
27 editor
: caps
.vms
['VM.Config.Options'] ? {
28 xtype
: 'pveWindowEdit',
29 subject
: gettext('Name'),
35 fieldLabel
: gettext('Name'),
41 header
: gettext('Start at boot'),
43 renderer
: PVE
.Utils
.format_boolean
,
44 editor
: caps
.vms
['VM.Config.Options'] ? {
45 xtype
: 'pveWindowEdit',
46 subject
: gettext('Start at boot'),
52 deleteDefaultValue
: true,
53 fieldLabel
: gettext('Start at boot')
58 header
: gettext('Start/Shutdown order'),
60 renderer
: PVE
.Utils
.render_kvm_startup
,
61 editor
: caps
.vms
['VM.Config.Options'] && caps
.nodes
['Sys.Modify'] ?
62 'PVE.qemu.StartupEdit' : undefined
65 header
: gettext('OS Type'),
66 editor
: caps
.vms
['VM.Config.Options'] ? 'PVE.qemu.OSTypeEdit' : undefined,
67 renderer
: PVE
.Utils
.render_kvm_ostype
,
74 header
: gettext('Boot order'),
76 editor
: caps
.vms
['VM.Config.Disk'] ? 'PVE.qemu.BootOrderEdit' : undefined,
77 renderer: function(order
, metaData
, record
, rowIndex
, colIndex
, store
, pending
) {
80 var bootdisk
= me
.getObjectValue('bootdisk', undefined, pending
);
81 order
= order
|| 'cdn';
82 for (i
= 0; i
< order
.length
; i
++) {
83 var sel
= order
.substring(i
, i
+ 1);
89 text
+= "Disk '" + bootdisk
+ "'";
93 } else if (sel
=== 'n') {
95 } else if (sel
=== 'a') {
97 } else if (sel
=== 'd') {
107 header
: gettext('Use tablet for pointer'),
109 renderer
: PVE
.Utils
.format_boolean
,
110 editor
: caps
.vms
['VM.Config.HWType'] ? {
111 xtype
: 'pveWindowEdit',
112 subject
: gettext('Use tablet for pointer'),
114 xtype
: 'pvecheckbox',
119 deleteDefaultValue
: true,
120 fieldLabel
: gettext('Enabled')
125 header
: gettext('Hotplug'),
126 defaultValue
: 'disk,network,usb',
127 renderer
: PVE
.Utils
.render_hotplug_features
,
128 editor
: caps
.vms
['VM.Config.HWType'] ? {
129 xtype
: 'pveWindowEdit',
130 subject
: gettext('Hotplug'),
132 xtype
: 'pveHotplugFeatureSelector',
136 fieldLabel
: gettext('Hotplug'),
142 header
: gettext('ACPI support'),
144 renderer
: PVE
.Utils
.format_boolean
,
145 editor
: caps
.vms
['VM.Config.HWType'] ? {
146 xtype
: 'pveWindowEdit',
147 subject
: gettext('ACPI support'),
149 xtype
: 'pvecheckbox',
154 deleteDefaultValue
: true,
155 fieldLabel
: gettext('Enabled')
160 header
: gettext('SCSI Controller Type'),
161 editor
: caps
.vms
['VM.Config.Options'] ? 'PVE.qemu.ScsiHwEdit' : undefined,
162 renderer
: PVE
.Utils
.render_scsihw
,
167 editor
: caps
.vms
['VM.Config.Options'] ? 'PVE.qemu.BiosEdit' : undefined,
168 renderer
: PVE
.Utils
.render_qemu_bios
,
172 header
: gettext('KVM hardware virtualization'),
174 renderer
: PVE
.Utils
.format_boolean
,
175 editor
: caps
.vms
['VM.Config.HWType'] ? {
176 xtype
: 'pveWindowEdit',
177 subject
: gettext('KVM hardware virtualization'),
179 xtype
: 'pvecheckbox',
184 deleteDefaultValue
: true,
185 fieldLabel
: gettext('Enabled')
190 header
: gettext('Freeze CPU at startup'),
192 renderer
: PVE
.Utils
.format_boolean
,
193 editor
: caps
.vms
['VM.PowerMgmt'] ? {
194 xtype
: 'pveWindowEdit',
195 subject
: gettext('Freeze CPU at startup'),
197 xtype
: 'pvecheckbox',
201 deleteDefaultValue
: true,
203 fieldLabel
: gettext('Freeze CPU at startup')
208 header
: gettext('Use local time for RTC'),
210 renderer
: PVE
.Utils
.format_boolean
,
211 editor
: caps
.vms
['VM.Config.Options'] ? {
212 xtype
: 'pveWindowEdit',
213 subject
: gettext('Use local time for RTC'),
215 xtype
: 'pvecheckbox',
219 deleteDefaultValue
: true,
221 fieldLabel
: gettext('Use local time for RTC')
226 header
: gettext('RTC start date'),
228 editor
: caps
.vms
['VM.Config.Options'] ? {
229 xtype
: 'pveWindowEdit',
230 subject
: gettext('RTC start date'),
232 xtype
: 'pvetextfield',
236 fieldLabel
: gettext('RTC start date'),
237 vtype
: 'QemuStartDate',
243 header
: gettext('SMBIOS settings (type1)'),
245 renderer
: Ext
.String
.htmlEncode
,
246 editor
: caps
.vms
['VM.Config.HWType'] ? 'PVE.qemu.Smbios1Edit' : undefined
249 header
: gettext('Qemu Agent'),
251 renderer
: PVE
.Utils
.format_boolean
,
252 editor
: caps
.vms
['VM.Config.Options'] ? {
253 xtype
: 'pveWindowEdit',
254 subject
: gettext('Qemu Agent'),
256 xtype
: 'pvecheckbox',
260 deleteDefaultValue
: true,
261 fieldLabel
: gettext('Enabled')
266 header
: gettext('VM protection'),
268 renderer
: PVE
.Utils
.format_boolean
,
269 editor
: caps
.vms
['VM.Config.Options'] ? {
270 xtype
: 'pveWindowEdit',
271 subject
: gettext('VM protection'),
273 xtype
: 'pvecheckbox',
277 deleteDefaultValue
: true,
278 fieldLabel
: gettext('Enabled')
284 var baseurl
= 'nodes/' + nodename
+ '/qemu/' + vmid
+ '/config';
286 var reload = function() {
290 var run_editor = function() {
291 var sm
= me
.getSelectionModel();
292 var rec
= sm
.getSelection()[0];
297 var rowdef
= rows
[rec
.data
.key
];
298 if (!rowdef
.editor
) {
303 if (Ext
.isString(rowdef
.editor
)) {
304 win
= Ext
.create(rowdef
.editor
, {
305 pveSelNode
: me
.pveSelNode
,
306 confid
: rec
.data
.key
,
307 url
: '/api2/extjs/' + baseurl
310 var config
= Ext
.apply({
311 pveSelNode
: me
.pveSelNode
,
312 confid
: rec
.data
.key
,
313 url
: '/api2/extjs/' + baseurl
315 win
= Ext
.createWidget(rowdef
.editor
.xtype
, config
);
320 win
.on('destroy', reload
);
323 var edit_btn
= new Ext
.Button({
324 text
: gettext('Edit'),
329 var revert_btn
= new PVE
.button
.Button({
330 text
: gettext('Revert'),
332 handler: function() {
333 var sm
= me
.getSelectionModel();
334 var rec
= sm
.getSelection()[0];
339 PVE
.Utils
.API2Request({
340 url
: '/api2/extjs/' + baseurl
,
344 'revert': rec
.data
.key
346 callback: function() {
349 failure: function (response
, opts
) {
350 Ext
.Msg
.alert('Error',response
.htmlStatus
);
356 var set_button_status = function() {
357 var sm
= me
.getSelectionModel();
358 var rec
= sm
.getSelection()[0];
365 var key
= rec
.data
.key
;
366 var pending
= rec
.data
['delete'] || me
.hasPendingChanges(key
);
367 var rowdef
= rows
[key
];
369 edit_btn
.setDisabled(!rowdef
.editor
);
370 revert_btn
.setDisabled(!pending
);
374 url
: "/api2/json/nodes/" + nodename
+ "/qemu/" + vmid
+ "/pending",
377 tbar
: [ edit_btn
, revert_btn
],
380 itemdblclick
: run_editor
,
381 selectionchange
: set_button_status
387 me
.on('show', me
.rstore
.startUpdate
);
388 me
.on('hide', me
.rstore
.stopUpdate
);
389 me
.on('destroy', me
.rstore
.stopUpdate
);
391 me
.rstore
.on('datachanged', function() {