diff --git a/ui/public/locales/en.json b/ui/public/locales/en.json
index e03aee00599b..661e28742f90 100644
--- a/ui/public/locales/en.json
+++ b/ui/public/locales/en.json
@@ -926,6 +926,7 @@
"label.endipv6": "IPv6 end IP",
"label.endpoint": "Endpoint",
"label.endport": "End port",
+"label.enter.account.name": "Enter the account name",
"label.enter.code": "Enter 2FA code to verify",
"label.enter.static.pin": "Enter static PIN to verify",
"label.enter.token": "Enter token",
@@ -2939,7 +2940,11 @@
"message.dedicating.host": "Dedicating host...",
"message.dedicating.pod": "Dedicating pod...",
"message.dedicating.zone": "Dedicating zone...",
-"message.delete.account": "Please confirm that you want to delete this Account.",
+"message.delete.account.confirm": "Please confirm that you want to delete this account by entering the name of the account below.",
+"message.delete.account.failed": "Delete account failed",
+"message.delete.account.processing": "Deleting account",
+"message.delete.account.success": "Successfully deleted account",
+"message.delete.account.warning": "Deleting this account will delete all of the instances, volumes and snapshots associated with the account.",
"message.delete.acl.processing": "Removing ACL rule...",
"message.delete.acl.rule": "Remove ACL rule",
"message.delete.acl.rule.failed": "Failed to remove ACL rule.",
@@ -3031,6 +3036,7 @@
"message.enabled.vpn.ip.sec": "Your IPSec pre-shared key is",
"message.enabling.security.group.provider": "Enabling security group provider",
"message.enter.valid.nic.ip": "Please enter a valid IP address for NIC",
+"message.error.account.delete.name.mismatch": "Name entered doesn't match the account name.",
"message.error.access.key": "Please enter access key.",
"message.error.add.guest.network": "Either IPv4 fields or IPv6 fields need to be filled when adding a guest Network.",
"message.error.add.interface.static.route": "Adding interface Static Route failed",
diff --git a/ui/src/config/section/account.js b/ui/src/config/section/account.js
index 21996167705d..61666e0bb5c2 100644
--- a/ui/src/config/section/account.js
+++ b/ui/src/config/section/account.js
@@ -221,14 +221,12 @@ export default {
api: 'deleteAccount',
icon: 'delete-outlined',
label: 'label.action.delete.account',
- message: 'message.delete.account',
dataView: true,
disabled: (record, store) => {
- return record.id !== 'undefined' && store.userInfo.accountid === record.id
+ return (record.id !== 'undefined' && store.userInfo.accountid === record.id) || record.state !== 'disabled'
},
- groupAction: true,
popup: true,
- groupMap: (selection) => { return selection.map(x => { return { id: x } }) }
+ component: shallowRef(defineAsyncComponent(() => import('@/views/iam/DeleteAccount.vue')))
}
]
}
diff --git a/ui/src/views/iam/DeleteAccount.vue b/ui/src/views/iam/DeleteAccount.vue
new file mode 100644
index 000000000000..0b86ed88be95
--- /dev/null
+++ b/ui/src/views/iam/DeleteAccount.vue
@@ -0,0 +1,142 @@
+// Licensed to the Apache Software Foundation (ASF) under one
+// or more contributor license agreements. See the NOTICE file
+// distributed with this work for additional information
+// regarding copyright ownership. The ASF licenses this file
+// to you under the Apache License, Version 2.0 (the
+// "License"); you may not use this file except in compliance
+// with the License. You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing,
+// software distributed under the License is distributed on an
+// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
+// KIND, either express or implied. See the License for the
+// specific language governing permissions and limitations
+// under the License.
+
+
+
+
+
+
+
+
+ {{ error }}
+
+
{{ $t('label.cancel') }}
+
{{ $t('label.ok') }}
+
+
+
+
+
+