From: Christian Ebner <c.ebner@proxmox.com>
To: pbs-devel@lists.proxmox.com
Subject: [pbs-devel] [PATCH proxmox-backup v3 6/6] ui: replace bucket field by bucket selector
Date: Thu, 31 Jul 2025 12:48:14 +0200 [thread overview]
Message-ID: <20250731104814.99768-11-c.ebner@proxmox.com> (raw)
In-Reply-To: <20250731104814.99768-1-c.ebner@proxmox.com>
With the goal to improve usability for the datastore creation window,
replace the current bucket textfield with a bucket selector which
fetches available buckets on demand.
Signed-off-by: Christian Ebner <c.ebner@proxmox.com>
Reviewed-by: Lukas Wagner <l.wagner@proxmox.com>
---
changes since version 2:
- no changes
www/Makefile | 1 +
www/form/S3BucketSelector.js | 52 ++++++++++++++++++++++++++++++++++++
www/window/DataStoreEdit.js | 22 +++++++++++----
3 files changed, 70 insertions(+), 5 deletions(-)
create mode 100644 www/form/S3BucketSelector.js
diff --git a/www/Makefile b/www/Makefile
index 4a5cd1ff1..9ebf0445f 100644
--- a/www/Makefile
+++ b/www/Makefile
@@ -42,6 +42,7 @@ JSSRC= \
Schema.js \
form/TokenSelector.js \
form/AuthidSelector.js \
+ form/S3BucketSelector.js \
form/S3ClientSelector.js \
form/RemoteSelector.js \
form/RemoteTargetSelector.js \
diff --git a/www/form/S3BucketSelector.js b/www/form/S3BucketSelector.js
new file mode 100644
index 000000000..75b02479f
--- /dev/null
+++ b/www/form/S3BucketSelector.js
@@ -0,0 +1,52 @@
+Ext.define('PBS.form.S3BucketSelector', {
+ extend: 'Proxmox.form.ComboGrid',
+ alias: 'widget.pbsS3BucketSelector',
+
+ allowBlank: false,
+ valueField: 'name',
+ displayField: 'name',
+
+ listConfig: {
+ width: 350,
+ columns: [
+ {
+ header: gettext('Bucket Name'),
+ sortable: true,
+ dataIndex: 'name',
+ renderer: Ext.String.htmlEncode,
+ flex: 1,
+ },
+ ],
+ },
+
+ store: {
+ autoLoad: false,
+ sorters: 'name',
+ fields: ['name'],
+ proxy: {
+ type: 'proxmox',
+ url: `/api2/json/config/s3/${encodeURIComponent(this.endpoint)}/list-buckets`,
+ },
+ },
+
+ setS3Endpoint: function (endpoint) {
+ let me = this;
+
+ if (me.endpoint === endpoint) {
+ return;
+ }
+
+ me.endpoint = endpoint;
+ me.store.removeAll();
+
+ me.setDisabled(false);
+
+ if (!me.firstLoad) {
+ me.clearValue();
+ }
+
+ me.store.proxy.url = `/api2/json/config/s3/${encodeURIComponent(me.endpoint)}/list-buckets`;
+ me.store.load();
+ me.firstLoad = false;
+ },
+});
diff --git a/www/window/DataStoreEdit.js b/www/window/DataStoreEdit.js
index 8296e0b04..1b935ddd3 100644
--- a/www/window/DataStoreEdit.js
+++ b/www/window/DataStoreEdit.js
@@ -74,7 +74,7 @@ Ext.define('PBS.DataStoreEdit', {
let inputPanel = checkbox.up('inputpanel');
let pathField = inputPanel.down('[name=path]');
let uuidEditField = inputPanel.down('[name=backing-device]');
- let bucketField = inputPanel.down('[name=bucket]');
+ let s3BucketSelector = inputPanel.down('[name=bucket]');
let s3ClientSelector = inputPanel.down('[name=s3client]');
let overwriteInUseField =
inputPanel.down('[name=overwrite-in-use]');
@@ -86,9 +86,11 @@ Ext.define('PBS.DataStoreEdit', {
uuidEditField.allowBlank = !isRemovable;
uuidEditField.setValue('');
- bucketField.setDisabled(!isS3);
- bucketField.allowBlank = !isS3;
- bucketField.setValue('');
+ if (!isS3) {
+ s3BucketSelector.setDisabled(true);
+ s3BucketSelector.setValue('');
+ }
+ s3BucketSelector.allowBlank = !isS3;
s3ClientSelector.setDisabled(!isS3);
s3ClientSelector.allowBlank = !isS3;
@@ -130,6 +132,13 @@ Ext.define('PBS.DataStoreEdit', {
cbind: {
editable: '{isCreate}',
},
+ listeners: {
+ change: function (selector, endpointId) {
+ let inputPanel = selector.up('inputpanel');
+ let s3BucketSelector = inputPanel.down('[name=bucket]');
+ s3BucketSelector.setS3Endpoint(endpointId);
+ },
+ },
},
],
column2: [
@@ -166,11 +175,14 @@ Ext.define('PBS.DataStoreEdit', {
emptyText: gettext('Device path'),
},
{
- xtype: 'proxmoxtextfield',
+ xtype: 'pbsS3BucketSelector',
name: 'bucket',
fieldLabel: gettext('Bucket'),
allowBlank: false,
disabled: true,
+ cbind: {
+ editable: '{isCreate}',
+ },
},
],
columnB: [
--
2.47.2
_______________________________________________
pbs-devel mailing list
pbs-devel@lists.proxmox.com
https://lists.proxmox.com/cgi-bin/mailman/listinfo/pbs-devel
next prev parent reply other threads:[~2025-07-31 10:47 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2025-07-31 10:48 [pbs-devel] [PATCH proxmox{, -backup} v3 00/10] s3: implement list buckets and use bucket selector for datastore creation Christian Ebner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox v3 1/4] s3 client: restrict bucket template pattern to start of endpoint url Christian Ebner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox v3 2/4] s3 client: make bucket name optional in S3 client options Christian Ebner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox v3 3/4] s3 client: implement list buckets method Christian Ebner
2025-07-31 11:43 ` Lukas Wagner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox v3 4/4] s3 client: api types: add bucket list item type Christian Ebner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox-backup v3 1/6] ui: fix formatting issues using proxmox-biome Christian Ebner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox-backup v3 2/6] datastore: wrap bucket name, as in is now optional in the s3 client Christian Ebner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox-backup v3 3/6] api: admin s3: make store prefix for check command optional Christian Ebner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox-backup v3 4/6] api: config s3: add bucket list api endpoint Christian Ebner
2025-07-31 10:48 ` [pbs-devel] [PATCH proxmox-backup v3 5/6] bin: expose list buckets as proxmox-backup-manager s3 subcommand Christian Ebner
2025-07-31 10:48 ` Christian Ebner [this message]
2025-07-31 11:55 ` [pbs-devel] [PATCH proxmox{, -backup} v3 00/10] s3: implement list buckets and use bucket selector for datastore creation Lukas Wagner
2025-07-31 13:02 ` Christian Ebner
2025-07-31 13:17 ` Thomas Lamprecht
2025-07-31 13:28 ` Thomas Lamprecht
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20250731104814.99768-11-c.ebner@proxmox.com \
--to=c.ebner@proxmox.com \
--cc=pbs-devel@lists.proxmox.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox