diff --git a/changelogs/fragments/7795.yml b/changelogs/fragments/7795.yml
new file mode 100644
index 00000000000..daad28b1421
--- /dev/null
+++ b/changelogs/fragments/7795.yml
@@ -0,0 +1,2 @@
+feat:
+- Adjust the appearance of collaborator panel ([#7795](https://github.com/opensearch-project/OpenSearch-Dashboards/pull/7795))
\ No newline at end of file
diff --git a/src/plugins/workspace/public/components/workspace_form/workspace_form.tsx b/src/plugins/workspace/public/components/workspace_form/workspace_form.tsx
index 04e232736e2..8327bf39b95 100644
--- a/src/plugins/workspace/public/components/workspace_form/workspace_form.tsx
+++ b/src/plugins/workspace/public/components/workspace_form/workspace_form.tsx
@@ -103,7 +103,7 @@ export const WorkspaceForm = (props: WorkspaceFormProps) => {
'You will be added as an owner to the workspace. Select additional users and user groups as workspace collaborators with different access levels.',
})}
-
+
{
const { renderResult, onPermissionModesChangeMock } = setup({});
expect(onPermissionModesChangeMock).not.toHaveBeenCalled();
- const permissionToggleListButton = within(
- renderResult.getAllByTestId('workspace-permissionModeOptions')[0]
- ).getByTestId('comboBoxToggleListButton');
- fireEvent.click(permissionToggleListButton);
+ fireEvent.click(renderResult.getAllByTestId('workspace-permissionModeOptions')[0]);
fireEvent.click(renderResult.getByText('Owner'));
expect(onPermissionModesChangeMock).toHaveBeenCalledWith(['library_write', 'write'], 0);
});
@@ -148,7 +145,7 @@ describe('WorkspacePermissionSettingInput', () => {
expect(onTypeChangeMock).not.toHaveBeenCalled();
fireEvent.click(renderResult.getByTestId('workspace-typeOptions'));
- fireEvent.click(renderResult.getByText('Group'));
+ fireEvent.click(renderResult.getByText('User Group'));
expect(onTypeChangeMock).toHaveBeenCalledWith('group', 0);
});
});
diff --git a/src/plugins/workspace/public/components/workspace_form/workspace_permission_setting_input.tsx b/src/plugins/workspace/public/components/workspace_form/workspace_permission_setting_input.tsx
index 96c79b5b26d..87d5ccb3a41 100644
--- a/src/plugins/workspace/public/components/workspace_form/workspace_permission_setting_input.tsx
+++ b/src/plugins/workspace/public/components/workspace_form/workspace_permission_setting_input.tsx
@@ -3,17 +3,15 @@
* SPDX-License-Identifier: Apache-2.0
*/
-import React, { useCallback, useMemo, useState } from 'react';
+import React, { useCallback, useMemo } from 'react';
import {
EuiFlexGroup,
EuiFlexItem,
EuiComboBox,
- EuiPopover,
EuiButtonIcon,
- EuiButtonEmpty,
- EuiSelectable,
EuiComboBoxOptionOption,
- EuiSelectableOption,
+ EuiSuperSelect,
+ EuiSuperSelectOption,
} from '@elastic/eui';
import { i18n } from '@osd/i18n';
import { WorkspacePermissionMode } from '../../../common/constants';
@@ -24,16 +22,19 @@ import {
} from './constants';
import { getPermissionModeId } from './utils';
-const permissionModeOptions = [
+const permissionModeOptions: Array> = [
{
value: PermissionModeId.Read,
- label: i18n.translate('workspace.form.permissionSettingPanel.permissionModeOptions.read', {
- defaultMessage: 'Read',
- }),
+ inputDisplay: i18n.translate(
+ 'workspace.form.permissionSettingPanel.permissionModeOptions.read',
+ {
+ defaultMessage: 'Read',
+ }
+ ),
},
{
value: PermissionModeId.ReadAndWrite,
- label: i18n.translate(
+ inputDisplay: i18n.translate(
'workspace.form.permissionSettingPanel.permissionModeOptions.readAndWrite',
{
defaultMessage: 'Read & Write',
@@ -42,8 +43,26 @@ const permissionModeOptions = [
},
{
value: PermissionModeId.Owner,
- label: i18n.translate('workspace.form.permissionSettingPanel.permissionModeOptions.owner', {
- defaultMessage: 'Owner',
+ inputDisplay: i18n.translate(
+ 'workspace.form.permissionSettingPanel.permissionModeOptions.owner',
+ {
+ defaultMessage: 'Owner',
+ }
+ ),
+ },
+];
+
+const typeOptions: Array> = [
+ {
+ value: WorkspacePermissionItemType.User,
+ inputDisplay: i18n.translate('workspace.form.permissionSettingPanel.typeOptions.user', {
+ defaultMessage: 'User',
+ }),
+ },
+ {
+ value: WorkspacePermissionItemType.Group,
+ inputDisplay: i18n.translate('workspace.form.permissionSettingPanel.typeOptions.group', {
+ defaultMessage: 'User Group',
}),
},
];
@@ -90,36 +109,12 @@ export const WorkspacePermissionSettingInput = ({
[group, userId]
);
- const [isTypeListOpen, setIsTypeListOpen] = useState(false);
+ const permissionModesSelected = useMemo(
+ () => getPermissionModeId(modes ?? []),
- const typeOptions = useMemo>>(
- () => [
- {
- value: WorkspacePermissionItemType.User,
- label: i18n.translate('workspace.form.permissionSettingPanel.typeOptions.user', {
- defaultMessage: 'User',
- }),
- checked: type === WorkspacePermissionItemType.User ? 'on' : undefined,
- },
- {
- value: WorkspacePermissionItemType.Group,
- label: i18n.translate('workspace.form.permissionSettingPanel.typeOptions.group', {
- defaultMessage: 'Group',
- }),
- checked: type === WorkspacePermissionItemType.Group ? 'on' : undefined,
- },
- ],
- [type]
+ [modes]
);
- const permissionModesSelected = useMemo(() => {
- const idSelected = getPermissionModeId(modes ?? []);
- const permissionModeSelected = permissionModeOptions.find(
- (option) => option.value === idSelected
- );
- return permissionModeSelected ? [permissionModeSelected] : [];
- }, [modes]);
-
const handleGroupOrUserIdCreate = useCallback(
(groupOrUserId) => {
onGroupOrUserIdChange(
@@ -142,36 +137,33 @@ export const WorkspacePermissionSettingInput = ({
);
const handlePermissionModeOptionChange = useCallback(
- (option: Array>) => {
- if (option.length > 0) {
- const id = option[0].value;
- if (optionIdToWorkspacePermissionModesMap[id]) {
- onPermissionModesChange([...optionIdToWorkspacePermissionModesMap[id]], index);
- }
+ (id: string) => {
+ if (optionIdToWorkspacePermissionModesMap[id]) {
+ onPermissionModesChange([...optionIdToWorkspacePermissionModesMap[id]], index);
}
},
[index, onPermissionModesChange]
);
- const handleTypeChange = useCallback(
- (options: Array>) => {
- for (const option of options) {
- if (option.checked === 'on') {
- onTypeChange(option.value, index);
- setIsTypeListOpen(false);
- return;
- }
- }
- },
- [index, onTypeChange]
- );
-
const handleDelete = useCallback(() => {
onDelete(index);
}, [index, onDelete]);
return (
-
+
+
+ onTypeChange(value, index)}
+ disabled={userOrGroupDisabled || !isEditing}
+ data-test-subj="workspace-typeOptions"
+ />
+
setIsTypeListOpen((current) => !current)}
- data-test-subj="workspace-typeOptions"
- isDisabled={userOrGroupDisabled || !isEditing}
- >
- {type === WorkspacePermissionItemType.User
- ? typeOptions[0].label
- : typeOptions[1].label}
-
- }
- isOpen={isTypeListOpen}
- closePopover={() => setIsTypeListOpen(false)}
- panelPaddingSize="none"
- >
-
- {(list) => list}
-
-
- }
/>
-
-
+
{deletable && isEditing && (
{
const { renderResult, onChangeMock } = setup();
expect(onChangeMock).not.toHaveBeenCalled();
- const permissionToggleListButton = within(
- renderResult.getAllByTestId('workspace-permissionModeOptions')[0]
- ).getByTestId('comboBoxToggleListButton');
- fireEvent.click(permissionToggleListButton);
+ fireEvent.click(renderResult.getAllByTestId('workspace-permissionModeOptions')[0]);
fireEvent.click(renderResult.getAllByText('Read & Write')[1]);
expect(onChangeMock).toHaveBeenCalledWith([
{
@@ -111,10 +108,8 @@ describe('WorkspacePermissionSettingInput', () => {
const { renderResult, onChangeMock } = setup();
expect(onChangeMock).not.toHaveBeenCalled();
- const permissionToggleListButton = within(
- renderResult.getAllByTestId('workspace-permissionModeOptions')[1]
- ).getByTestId('comboBoxToggleListButton');
- fireEvent.click(permissionToggleListButton);
+
+ fireEvent.click(renderResult.getAllByTestId('workspace-permissionModeOptions')[1]);
fireEvent.click(renderResult.getByText('Owner'));
expect(onChangeMock).toHaveBeenCalledWith([
{
diff --git a/src/plugins/workspace/public/components/workspace_form/workspace_permission_setting_panel.tsx b/src/plugins/workspace/public/components/workspace_form/workspace_permission_setting_panel.tsx
index 951615279d9..8ea255b83b3 100644
--- a/src/plugins/workspace/public/components/workspace_form/workspace_permission_setting_panel.tsx
+++ b/src/plugins/workspace/public/components/workspace_form/workspace_permission_setting_panel.tsx
@@ -131,7 +131,16 @@ export const WorkspacePermissionSettingPanel = ({
return (
-
+
+
+
+ <>>
+
+