ui: tape/ChangerStatus: add 'is labeled' column for tapes
so that a user can see if a tape in a library is not yet labeled Signed-off-by: Dominik Csapak <d.csapak@proxmox.com>
This commit is contained in:
parent
11ecf058e4
commit
42eef1451c
|
@ -377,19 +377,31 @@ Ext.define('PBS.TapeManagement.ChangerStatus', {
|
||||||
try {
|
try {
|
||||||
Proxmox.Utils.setErrorMask(view, true);
|
Proxmox.Utils.setErrorMask(view, true);
|
||||||
Proxmox.Utils.setErrorMask(me.lookup('content'));
|
Proxmox.Utils.setErrorMask(me.lookup('content'));
|
||||||
let status = await PBS.Async.api2({
|
let status_fut = PBS.Async.api2({
|
||||||
url: `/api2/extjs/tape/changer/${encodeURIComponent(changer)}/status`,
|
url: `/api2/extjs/tape/changer/${encodeURIComponent(changer)}/status`,
|
||||||
});
|
});
|
||||||
let drives = await PBS.Async.api2({
|
let drives_fut = PBS.Async.api2({
|
||||||
url: `/api2/extjs/tape/drive?changer=${encodeURIComponent(changer)}`,
|
url: `/api2/extjs/tape/drive?changer=${encodeURIComponent(changer)}`,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let tapes_fut = PBS.Async.api2({
|
||||||
|
url: '/api2/extjs/tape/media/list',
|
||||||
|
});
|
||||||
|
|
||||||
|
let [status, drives, tapes_list] = await Promise.all([status_fut, drives_fut, tapes_fut]);
|
||||||
|
|
||||||
let data = {
|
let data = {
|
||||||
slot: [],
|
slot: [],
|
||||||
'import-export': [],
|
'import-export': [],
|
||||||
drive: [],
|
drive: [],
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let tapes = {};
|
||||||
|
|
||||||
|
for (const tape of tapes_list.result.data) {
|
||||||
|
tapes[tape['label-text']] = true;
|
||||||
|
}
|
||||||
|
|
||||||
let drive_entries = {};
|
let drive_entries = {};
|
||||||
|
|
||||||
for (const entry of drives.result.data) {
|
for (const entry of drives.result.data) {
|
||||||
|
@ -403,6 +415,8 @@ Ext.define('PBS.TapeManagement.ChangerStatus', {
|
||||||
entry = Ext.applyIf(entry, drive_entries[entry['entry-id']]);
|
entry = Ext.applyIf(entry, drive_entries[entry['entry-id']]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
entry['is-labeled'] = !!tapes[entry['label-text']];
|
||||||
|
|
||||||
data[type].push(entry);
|
data[type].push(entry);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -520,6 +534,22 @@ Ext.define('PBS.TapeManagement.ChangerStatus', {
|
||||||
flex: 1,
|
flex: 1,
|
||||||
renderer: (value) => value || '',
|
renderer: (value) => value || '',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
text: gettext('Labeled'),
|
||||||
|
dataIndex: 'is-labeled',
|
||||||
|
width: 80,
|
||||||
|
renderer: function(value, mD, record) {
|
||||||
|
if (!record.data['label-text']) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (record.data['label-text'].startsWith("CLN")) {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
return Proxmox.Utils.format_boolean(value);
|
||||||
|
},
|
||||||
|
},
|
||||||
{
|
{
|
||||||
text: gettext('Actions'),
|
text: gettext('Actions'),
|
||||||
xtype: 'actioncolumn',
|
xtype: 'actioncolumn',
|
||||||
|
|
Loading…
Reference in New Issue