From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from firstgate.proxmox.com (firstgate.proxmox.com [212.224.123.68]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by lists.proxmox.com (Postfix) with ESMTPS id 9EE766C2A4 for ; Fri, 29 Jan 2021 14:57:54 +0100 (CET) Received: from firstgate.proxmox.com (localhost [127.0.0.1]) by firstgate.proxmox.com (Proxmox) with ESMTP id 8E59DF6B5 for ; Fri, 29 Jan 2021 14:57:54 +0100 (CET) Received: from proxmox-new.maurer-it.com (proxmox-new.maurer-it.com [212.186.127.180]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits)) (No client certificate requested) by firstgate.proxmox.com (Proxmox) with ESMTPS id 2FD26F696 for ; Fri, 29 Jan 2021 14:57:53 +0100 (CET) Received: from proxmox-new.maurer-it.com (localhost.localdomain [127.0.0.1]) by proxmox-new.maurer-it.com (Proxmox) with ESMTP id EA70443AE8 for ; Fri, 29 Jan 2021 14:57:52 +0100 (CET) From: Dominik Csapak To: pbs-devel@lists.proxmox.com Date: Fri, 29 Jan 2021 14:57:49 +0100 Message-Id: <20210129135752.16123-2-d.csapak@proxmox.com> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20210129135752.16123-1-d.csapak@proxmox.com> References: <20210129135752.16123-1-d.csapak@proxmox.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SPAM-LEVEL: Spam detection results: 0 AWL 0.242 Adjusted score from AWL reputation of From: address KAM_DMARC_STATUS 0.01 Test Rule for DKIM or SPF Failure with Strict Alignment RCVD_IN_DNSWL_MED -2.3 Sender listed at https://www.dnswl.org/, medium trust SPF_HELO_NONE 0.001 SPF: HELO does not publish an SPF Record SPF_PASS -0.001 SPF: sender matches SPF record Subject: [pbs-devel] [PATCH proxmox-backup 2/5] ui: tape: add Changer config grid X-BeenThere: pbs-devel@lists.proxmox.com X-Mailman-Version: 2.1.29 Precedence: list List-Id: Proxmox Backup Server development discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 29 Jan 2021 13:57:54 -0000 analogous to the drive grid Signed-off-by: Dominik Csapak --- www/Makefile | 1 + www/tape/ChangerConfig.js | 128 +++++++++++++++++++++++++++++++++++++ www/tape/TapeManagement.js | 7 +- 3 files changed, 135 insertions(+), 1 deletion(-) create mode 100644 www/tape/ChangerConfig.js diff --git a/www/Makefile b/www/Makefile index 91899028..7a47ad8d 100644 --- a/www/Makefile +++ b/www/Makefile @@ -21,6 +21,7 @@ TAPE_UI_FILES= \ tape/window/PoolEdit.js \ tape/window/TapeBackup.js \ tape/BackupOverview.js \ + tape/ChangerConfig.js \ tape/ChangerStatus.js \ tape/DriveConfig.js \ tape/PoolConfig.js \ diff --git a/www/tape/ChangerConfig.js b/www/tape/ChangerConfig.js new file mode 100644 index 00000000..a4258dfd --- /dev/null +++ b/www/tape/ChangerConfig.js @@ -0,0 +1,128 @@ +Ext.define('pbs-model-changers', { + extend: 'Ext.data.Model', + fields: ['path', 'model', 'name', 'serial', 'vendor', 'export-slots'], + idProperty: 'name', +}); + +Ext.define('PBS.TapeManagement.ChangerPanel', { + extend: 'Ext.grid.Panel', + alias: 'widget.pbsTapeChangerPanel', + + controller: { + xclass: 'Ext.app.ViewController', + + onAdd: function() { + let me = this; + Ext.create('PBS.TapeManagement.ChangerEditWindow', { + listeners: { + destroy: function() { + me.reload(); + }, + }, + }).show(); + }, + + onEdit: function() { + let me = this; + let view = me.getView(); + let selection = view.getSelection(); + if (!selection || selection.length < 1) { + return; + } + Ext.create('PBS.TapeManagement.ChangerEditWindow', { + changerid: selection[0].data.name, + autoLoad: true, + listeners: { + destroy: () => me.reload(), + }, + }).show(); + }, + + reload: function() { + this.getView().getStore().rstore.load(); + }, + + stopStore: function() { + this.getView().getStore().rstore.stopUpdate(); + }, + + startStore: function() { + this.getView().getStore().rstore.startUpdate(); + }, + }, + + listeners: { + beforedestroy: 'stopStore', + deactivate: 'stopStore', + activate: 'startStore', + itemdblclick: 'onEdit', + }, + + store: { + type: 'diff', + rstore: { + type: 'update', + storeid: 'proxmox-tape-changers', + model: 'pbs-model-changers', + proxy: { + type: 'proxmox', + url: "/api2/json/tape/changer", + }, + }, + sorters: 'name', + }, + + tbar: [ + { + text: gettext('Add'), + xtype: 'proxmoxButton', + handler: 'onAdd', + selModel: false, + }, + '-', + { + text: gettext('Edit'), + xtype: 'proxmoxButton', + handler: 'onEdit', + disabled: true, + }, + { + xtype: 'proxmoxStdRemoveButton', + baseurl: '/api2/extjs/config/changer', + callback: 'reload', + }, + ], + columns: [ + { + text: gettext('Name'), + dataIndex: 'name', + flex: 1, + }, + { + text: gettext('Path'), + dataIndex: 'path', + flex: 2, + }, + { + text: gettext('Vendor'), + dataIndex: 'vendor', + flex: 1, + }, + { + text: gettext('Model'), + dataIndex: 'model', + flex: 1, + }, + { + text: gettext('Serial'), + dataIndex: 'serial', + flex: 1, + }, + { + text: gettext('Import/Export Slots'), + dataIndex: 'export-slots', + flex: 1, + }, + ], +}); + diff --git a/www/tape/TapeManagement.js b/www/tape/TapeManagement.js index f61c26d7..8461b0b3 100644 --- a/www/tape/TapeManagement.js +++ b/www/tape/TapeManagement.js @@ -16,10 +16,15 @@ Ext.define('PBS.TapeManagement', { itemId: 'backup', xtype: 'pbsBackupOverview', }, + { + title: gettext('Library'), + itemId: 'library', + xtype: 'pbsChangerStatus', + }, { title: gettext('Changers'), itemId: 'changers', - xtype: 'pbsChangerStatus', + xtype: 'pbsTapeChangerPanel', }, { title: gettext('Drives'), -- 2.20.1