]>
git.proxmox.com Git - pve-manager.git/blob - www/manager6/lxc/Options.js
1 Ext
.define('PVE.lxc.Options', {
2 extend
: 'Proxmox.grid.PendingObjectGrid',
3 alias
: ['widget.pveLxcOptions'],
5 onlineHelp
: 'pct_options',
7 initComponent: function() {
11 var nodename
= me
.pveSelNode
.data
.node
;
13 throw "no node name specified";
16 var vmid
= me
.pveSelNode
.data
.vmid
;
18 throw "no VM ID specified";
21 var caps
= Ext
.state
.Manager
.get('GuiCap');
25 header
: gettext('Start at boot'),
27 renderer
: Proxmox
.Utils
.format_boolean
,
28 editor
: caps
.vms
['VM.Config.Options'] ? {
29 xtype
: 'proxmoxWindowEdit',
30 subject
: gettext('Start at boot'),
32 xtype
: 'proxmoxcheckbox',
36 fieldLabel
: gettext('Start at boot'),
41 header
: gettext('Start/Shutdown order'),
43 renderer
: PVE
.Utils
.render_kvm_startup
,
44 editor
: caps
.vms
['VM.Config.Options'] && caps
.nodes
['Sys.Modify']
46 xtype
: 'pveWindowStartupEdit',
47 onlineHelp
: 'pct_startup_and_shutdown',
51 header
: gettext('OS Type'),
52 defaultValue
: Proxmox
.Utils
.unknownText
,
55 header
: gettext('Architecture'),
56 defaultValue
: Proxmox
.Utils
.unknownText
,
59 header
: '/dev/console',
61 renderer
: Proxmox
.Utils
.format_enabled_toggle
,
62 editor
: caps
.vms
['VM.Config.Options'] ? {
63 xtype
: 'proxmoxWindowEdit',
64 subject
: '/dev/console',
66 xtype
: 'proxmoxcheckbox',
70 deleteDefaultValue
: true,
72 fieldLabel
: '/dev/console',
77 header
: gettext('TTY count'),
79 editor
: caps
.vms
['VM.Config.Options'] ? {
80 xtype
: 'proxmoxWindowEdit',
81 subject
: gettext('TTY count'),
83 xtype
: 'proxmoxintegerfield',
88 fieldLabel
: gettext('TTY count'),
89 emptyText
: gettext('Default'),
95 header
: gettext('Console mode'),
97 editor
: caps
.vms
['VM.Config.Options'] ? {
98 xtype
: 'proxmoxWindowEdit',
99 subject
: gettext('Console mode'),
101 xtype
: 'proxmoxKVComboBox',
104 value
: '__default__',
106 ['__default__', Proxmox
.Utils
.defaultText
+ " (tty)"],
107 ['tty', "/dev/tty[X]"],
108 ['console', "/dev/console"],
111 fieldLabel
: gettext('Console mode'),
116 header
: gettext('Protection'),
118 renderer
: Proxmox
.Utils
.format_boolean
,
119 editor
: caps
.vms
['VM.Config.Options'] ? {
120 xtype
: 'proxmoxWindowEdit',
121 subject
: gettext('Protection'),
123 xtype
: 'proxmoxcheckbox',
127 deleteDefaultValue
: true,
128 fieldLabel
: gettext('Enabled'),
133 header
: gettext('Unprivileged container'),
134 renderer
: Proxmox
.Utils
.format_boolean
,
138 header
: gettext('Features'),
139 defaultValue
: Proxmox
.Utils
.noneText
,
140 editor
: Proxmox
.UserName
=== 'root@pam'
141 ? 'PVE.lxc.FeaturesEdit' : undefined,
144 header
: gettext('Hookscript'),
148 var baseurl
= 'nodes/' + nodename
+ '/lxc/' + vmid
+ '/config';
150 var sm
= Ext
.create('Ext.selection.RowModel', {});
152 var edit_btn
= new Proxmox
.button
.Button({
153 text
: gettext('Edit'),
156 enableFn: function(rec
) {
157 var rowdef
= rows
[rec
.data
.key
];
158 return !!rowdef
.editor
;
160 handler: function() { me
.run_editor(); },
163 var revert_btn
= new PVE
.button
.PendingRevert();
165 var set_button_status = function() {
166 var sm
= me
.getSelectionModel();
167 var rec
= sm
.getSelection()[0];
174 var key
= rec
.data
.key
;
175 var pending
= rec
.data
.delete || me
.hasPendingChanges(key
);
176 var rowdef
= rows
[key
];
178 edit_btn
.setDisabled(!rowdef
.editor
);
179 revert_btn
.setDisabled(!pending
);
184 url
: "/api2/json/nodes/" + nodename
+ "/lxc/" + vmid
+ "/pending",
187 tbar
: [edit_btn
, revert_btn
],
190 url
: '/api2/extjs/' + baseurl
,
193 itemdblclick
: me
.run_editor
,
194 selectionchange
: set_button_status
,
200 me
.on('activate', me
.rstore
.startUpdate
);
201 me
.on('destroy', me
.rstore
.stopUpdate
);
202 me
.on('deactivate', me
.rstore
.stopUpdate
);
204 me
.mon(me
.getStore(), 'datachanged', function() {