403476f8ef
It needs to be a 'proxmoxButton' to get activated when selecting a HA
ressource. This was lost during the last code cleanup, commit a69e943
.
Signed-off-by: Aaron Lauterer <a.lauterer@proxmox.com>
169 lines
3.5 KiB
JavaScript
169 lines
3.5 KiB
JavaScript
Ext.define('PVE.ha.ResourcesView', {
|
|
extend: 'Ext.grid.GridPanel',
|
|
alias: ['widget.pveHAResourcesView'],
|
|
|
|
onlineHelp: 'ha_manager_resources',
|
|
|
|
stateful: true,
|
|
stateId: 'grid-ha-resources',
|
|
|
|
initComponent: function() {
|
|
let me = this;
|
|
|
|
if (!me.rstore) {
|
|
throw "no store given";
|
|
}
|
|
|
|
Proxmox.Utils.monStoreErrors(me, me.rstore);
|
|
let store = Ext.create('Proxmox.data.DiffStore', {
|
|
rstore: me.rstore,
|
|
filters: {
|
|
property: 'type',
|
|
value: 'service',
|
|
},
|
|
});
|
|
|
|
let sm = Ext.create('Ext.selection.RowModel', {});
|
|
|
|
let run_editor = function() {
|
|
let rec = sm.getSelection()[0];
|
|
let sid = rec.data.sid;
|
|
|
|
let res = sid.match(/^(\S+):(\S+)$/);
|
|
if (!res || (res[1] !== 'vm' && res[1] !== 'ct')) {
|
|
console.warn(`unknown HA service ID type ${sid}`);
|
|
return;
|
|
}
|
|
let [, guestType, vmid] = res;
|
|
Ext.create('PVE.ha.VMResourceEdit', {
|
|
guestType: guestType,
|
|
vmid: vmid,
|
|
listeners: {
|
|
destroy: () => me.rstore.load(),
|
|
},
|
|
autoShow: true,
|
|
});
|
|
};
|
|
|
|
let caps = Ext.state.Manager.get('GuiCap');
|
|
|
|
Ext.apply(me, {
|
|
store: store,
|
|
selModel: sm,
|
|
viewConfig: {
|
|
trackOver: false,
|
|
},
|
|
tbar: [
|
|
{
|
|
text: gettext('Add'),
|
|
disabled: !caps.nodes['Sys.Console'],
|
|
handler: function() {
|
|
Ext.create('PVE.ha.VMResourceEdit', {
|
|
listeners: {
|
|
destroy: () => me.rstore.load(),
|
|
},
|
|
autoShow: true,
|
|
});
|
|
},
|
|
},
|
|
{
|
|
xtype: 'proxmoxButton',
|
|
text: gettext('Edit'),
|
|
disabled: true,
|
|
selModel: sm,
|
|
handler: run_editor,
|
|
},
|
|
{
|
|
xtype: 'proxmoxStdRemoveButton',
|
|
selModel: sm,
|
|
getUrl: function(rec) {
|
|
return `/cluster/ha/resources/${rec.get('sid')}`;
|
|
},
|
|
callback: () => me.rstore.load(),
|
|
},
|
|
],
|
|
columns: [
|
|
{
|
|
header: 'ID',
|
|
width: 100,
|
|
sortable: true,
|
|
dataIndex: 'sid',
|
|
},
|
|
{
|
|
header: gettext('State'),
|
|
width: 100,
|
|
sortable: true,
|
|
dataIndex: 'state',
|
|
},
|
|
{
|
|
header: gettext('Node'),
|
|
width: 100,
|
|
sortable: true,
|
|
dataIndex: 'node',
|
|
},
|
|
{
|
|
header: gettext('Request State'),
|
|
width: 100,
|
|
hidden: true,
|
|
sortable: true,
|
|
renderer: v => v || 'started',
|
|
dataIndex: 'request_state',
|
|
},
|
|
{
|
|
header: gettext('CRM State'),
|
|
width: 100,
|
|
hidden: true,
|
|
sortable: true,
|
|
dataIndex: 'crm_state',
|
|
},
|
|
{
|
|
header: gettext('Name'),
|
|
width: 100,
|
|
sortable: true,
|
|
dataIndex: 'vname',
|
|
},
|
|
{
|
|
header: gettext('Max. Restart'),
|
|
width: 100,
|
|
sortable: true,
|
|
renderer: (v) => v === undefined ? '1' : v,
|
|
dataIndex: 'max_restart',
|
|
},
|
|
{
|
|
header: gettext('Max. Relocate'),
|
|
width: 100,
|
|
sortable: true,
|
|
renderer: (v) => v === undefined ? '1' : v,
|
|
dataIndex: 'max_relocate',
|
|
},
|
|
{
|
|
header: gettext('Group'),
|
|
width: 200,
|
|
sortable: true,
|
|
renderer: function(value, metaData, { data }) {
|
|
if (data.errors && data.errors.group) {
|
|
metaData.tdCls = 'proxmox-invalid-row';
|
|
let html = `<p>${Ext.htmlEncode(data.errors.group)}</p>`;
|
|
metaData.tdAttr = 'data-qwidth=600 data-qtitle="ERROR" data-qtip="' + html + '"';
|
|
}
|
|
return value;
|
|
},
|
|
dataIndex: 'group',
|
|
},
|
|
{
|
|
header: gettext('Description'),
|
|
flex: 1,
|
|
renderer: Ext.String.htmlEncode,
|
|
dataIndex: 'comment',
|
|
},
|
|
],
|
|
listeners: {
|
|
beforeselect: (grid, record, index, eOpts) => caps.nodes['Sys.Console'],
|
|
itemdblclick: run_editor,
|
|
},
|
|
});
|
|
|
|
me.callParent();
|
|
},
|
|
});
|