Skip to content

Split role details drawer update role functionality into CE and EE components

What does this MR do and why?

On the Manage -> Members page, clicking on a role in the Max role column will show a role details drawer:


Previously, the role_details_drawer.vue component was a single component that handled both FOSS and EE versions of the component. However, this makes it difficult to add EE features while still preserving the FOSS/EE divide. To make EE development easier without affecting FOSS, this MR breaks out the role updating part into two separate role_updater.vue components.

This MR also moves the "role change success/role change enqueued" toast messages into the drawer itself as alerts. The toast message shows up in the bottom left while the drawer is on the right side. Otherwise, because of how far apart they are, it's very easy to miss the toast notification.

Role change success

Before After
ksnip_20240626-170225 ksnip_20240626-170425

Role change enqueued

Before After
ksnip_20240626-170349 ksnip_20240626-170500

How to set up and validate locally

  1. Enable the show_role_details_in_drawer feature flag:
echo "Feature.enable(:show_role_details_in_drawer)" | rails c
  1. There are several features to validate. Follow the video walkthroughs below:


The easiest way to put the local GDK in FOSS mode is to delete the ee/ folder, then restart gdk:

rm -rf <gdk-folder>/gitlab/ee
gdk restart

FOSS also doesn't support feature flags, so we need to remove the feature flag check with this patch:

Index: app/assets/javascripts/members/components/table/members_table.vue
IDEA additional info:
Subsystem: com.intellij.openapi.diff.impl.patch.CharsetEP
diff --git a/app/assets/javascripts/members/components/table/members_table.vue b/app/assets/javascripts/members/components/table/members_table.vue
--- a/app/assets/javascripts/members/components/table/members_table.vue	(revision 3225e9fe3a9f9f04d196823aac34948f4e7a3777)
+++ b/app/assets/javascripts/members/components/table/members_table.vue	(date 1719951652525)
@@ -291,7 +291,7 @@
       <template #cell(maxRole)="{ item: member }">
         <members-table-cell #default="{ permissions }" :member="member" data-testid="max-role">
-          <div v-if="glFeatures.showRoleDetailsInDrawer">
+          <div v-if="!glFeatures.showRoleDetailsInDrawer">
@@ -339,7 +339,7 @@
     <ldap-override-confirmation-modal />
-      v-if="glFeatures.showRoleDetailsInDrawer"
+      v-if="!glFeatures.showRoleDetailsInDrawer"
       @busy="isRoleDrawerBusy = $event"
       @close="selectedMember = null"

Then follow this verification video with audio commentary:


For EE, saving and enqueueing:


For EE, guest overage check and license usage:

First, enable SAAS simulation:


Then apply this patch to force the guest overage confirmation to show:

Index: ee/app/assets/javascripts/members/components/table/drawer/guest_overage_confirmation.vue
IDEA additional info:
Subsystem: com.intellij.openapi.diff.impl.patch.CharsetEP
diff --git a/ee/app/assets/javascripts/members/components/table/drawer/guest_overage_confirmation.vue b/ee/app/assets/javascripts/members/components/table/drawer/guest_overage_confirmation.vue
--- a/ee/app/assets/javascripts/members/components/table/drawer/guest_overage_confirmation.vue	(revision 67caccd3dfba6a63aa54fe2f7fcc9f9b42b63e33)
+++ b/ee/app/assets/javascripts/members/components/table/drawer/guest_overage_confirmation.vue	(date 1720741546423)
@@ -77,7 +77,7 @@
       return new Promise((resolve, reject) => {
         this.resolve = resolve;
-        if (this.shouldSkipConfirmationCheck) {
+        if (!this.shouldSkipConfirmationCheck) {
@@ -99,7 +99,7 @@
             const { willIncreaseOverage, seatsInSubscription, newBillableUserCount } =
               response?.data?.group?.gitlabSubscriptionsPreviewBillableUserChange || {};
             // If the overage won't increase or if there's no subscription data, don't show the modal.
-            if (!willIncreaseOverage || isNil(seatsInSubscription) || isNil(newBillableUserCount)) {
+            if (willIncreaseOverage || isNil(seatsInSubscription) || isNil(newBillableUserCount)) {

Then follow this video with audio commentary:


Related to #464104

Edited by Daniel Tian

Merge request reports