diff --git a/packages/compass-indexes/src/components/regular-indexes-table/regular-indexes-table.tsx b/packages/compass-indexes/src/components/regular-indexes-table/regular-indexes-table.tsx
index 102f9c99198..056707f4d63 100644
--- a/packages/compass-indexes/src/components/regular-indexes-table/regular-indexes-table.tsx
+++ b/packages/compass-indexes/src/components/regular-indexes-table/regular-indexes-table.tsx
@@ -123,7 +123,12 @@ export const RegularIndexesTable: React.FunctionComponent<
onUnhideIndex={onUnhideIndex}
>
),
- details: ,
+ details: (
+
+ ),
};
});
diff --git a/packages/compass-indexes/src/components/search-indexes-table/search-indexes-table.spec.tsx b/packages/compass-indexes/src/components/search-indexes-table/search-indexes-table.spec.tsx
index 932ed587dac..fa28448a10c 100644
--- a/packages/compass-indexes/src/components/search-indexes-table/search-indexes-table.spec.tsx
+++ b/packages/compass-indexes/src/components/search-indexes-table/search-indexes-table.spec.tsx
@@ -9,6 +9,7 @@ import {
import { expect } from 'chai';
import sinon from 'sinon';
import userEvent from '@testing-library/user-event';
+import type { Document } from 'mongodb';
import { SearchIndexesTable } from './search-indexes-table';
import { SearchIndexesStatuses } from '../../modules/search-indexes';
@@ -69,6 +70,28 @@ describe('SearchIndexesTable Component', function () {
);
expect(badge).to.exist;
expect(badge).to.have.text(index.status);
+
+ // Renders details
+
+ const expandButton = within(indexRow).getByLabelText('Expand row');
+ expect(expandButton).to.exist;
+ fireEvent.click(expandButton);
+
+ const details = screen.getByTestId(
+ `search-indexes-details-${index.name}`
+ );
+ expect(details).to.exist;
+
+ if (index.latestDefinition.mappings?.dynamic) {
+ expect(within(details).getAllByText('Dynamic Mappings')).to.exist;
+ }
+ if (index.latestDefinition.mappings?.fields) {
+ for (const field of Object.keys(
+ index.latestDefinition.mappings.fields as Document
+ )) {
+ expect(within(details).getAllByText(field)).to.exist;
+ }
+ }
}
});
}
diff --git a/packages/compass-indexes/src/components/search-indexes-table/search-indexes-table.tsx b/packages/compass-indexes/src/components/search-indexes-table/search-indexes-table.tsx
index 3d53af013cb..7bd9a39e034 100644
--- a/packages/compass-indexes/src/components/search-indexes-table/search-indexes-table.tsx
+++ b/packages/compass-indexes/src/components/search-indexes-table/search-indexes-table.tsx
@@ -1,5 +1,6 @@
import React from 'react';
import { connect } from 'react-redux';
+import type { Document } from 'mongodb';
import type { SearchIndex, SearchIndexStatus } from 'mongodb-data-service';
import { withPreferences } from 'compass-preferences-model';
@@ -9,6 +10,8 @@ import {
Button,
Link,
Badge,
+ css,
+ spacing,
} from '@mongodb-js/compass-components';
import type { SearchSortColumn } from '../../modules/search-indexes';
@@ -96,6 +99,54 @@ function IndexStatus({
);
}
+const searchIndexDetailsStyles = css({
+ display: 'inline-flex',
+ gap: spacing[1],
+});
+
+const searchIndexFieldStyles = css({
+ // Override LeafyGreen's uppercase styles as we want to keep the case sensitivity of the key.
+ textTransform: 'none',
+ gap: spacing[1],
+});
+
+function SearchIndexDetails({
+ indexName,
+ definition,
+}: {
+ indexName: string;
+ definition: Document;
+}) {
+ const badges: { name: string; className?: string }[] = [];
+ if (definition.mappings?.dynamic) {
+ badges.push({
+ name: 'Dynamic Mappings',
+ className: undefined,
+ });
+ }
+
+ if (definition.mappings?.fields) {
+ badges.push(
+ ...Object.keys(definition.mappings.fields as Document).map((name) => ({
+ name,
+ className: searchIndexFieldStyles,
+ }))
+ );
+ }
+ return (
+
+ {badges.map((badge) => (
+
+ {badge.name}
+
+ ))}
+
+ );
+}
+
export const SearchIndexesTable: React.FunctionComponent<
SearchIndexesTableProps
> = ({
@@ -141,8 +192,13 @@ export const SearchIndexesTable: React.FunctionComponent<
),
},
],
+ details: (
+
+ ),
actions: ,
- // TODO(COMPASS-7206): details for the nested row
};
});