From 7a89701f9ecd4d7f0830bec954b6b0e710638907 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Kr=C3=A6n=20Hansen?= Date: Wed, 18 Dec 2024 06:43:33 +0100 Subject: [PATCH] chore(aggregations): Refactor aggregations stage toolbar (#6572) * Re-export GlyphName instead of IconGlyph * Use React composition instead of arrays of data --- .../stage-toolbar/option-menu-item.tsx | 45 ++++++++ .../components/stage-toolbar/option-menu.tsx | 106 ++++++------------ .../src/components/workspace-tabs/tab.tsx | 6 +- .../workspace-tabs/workspace-tabs.tsx | 4 +- packages/compass-components/src/index.ts | 3 +- packages/compass-editor/src/action-button.tsx | 4 +- .../src/namespace-card.tsx | 4 +- 7 files changed, 87 insertions(+), 85 deletions(-) create mode 100644 packages/compass-aggregations/src/components/stage-toolbar/option-menu-item.tsx diff --git a/packages/compass-aggregations/src/components/stage-toolbar/option-menu-item.tsx b/packages/compass-aggregations/src/components/stage-toolbar/option-menu-item.tsx new file mode 100644 index 00000000000..41f89301d90 --- /dev/null +++ b/packages/compass-aggregations/src/components/stage-toolbar/option-menu-item.tsx @@ -0,0 +1,45 @@ +import React from 'react'; + +import { + css, + Icon, + MenuItem, + palette, + spacing, + type GlyphName, +} from '@mongodb-js/compass-components'; + +const styles = css({ + display: 'flex', + alignItems: 'center', + gap: spacing[2], +}); + +type OptionMenuItemProps = { + label: string; + icon: GlyphName; + onClick: () => void; + setMenuOpen: (open: boolean) => void; +}; + +export function OptionMenuItem({ + label, + onClick, + setMenuOpen, + icon, +}: OptionMenuItemProps) { + return ( + { + setMenuOpen(false); + onClick(); + }} + > +
+ + {label} +
+
+ ); +} diff --git a/packages/compass-aggregations/src/components/stage-toolbar/option-menu.tsx b/packages/compass-aggregations/src/components/stage-toolbar/option-menu.tsx index f047592aecc..b5112be63e0 100644 --- a/packages/compass-aggregations/src/components/stage-toolbar/option-menu.tsx +++ b/packages/compass-aggregations/src/components/stage-toolbar/option-menu.tsx @@ -1,14 +1,6 @@ -import React, { useMemo, useState } from 'react'; +import React, { useState } from 'react'; import { connect } from 'react-redux'; -import { - Menu, - MenuItem, - css, - IconButton, - Icon, - palette, - spacing, -} from '@mongodb-js/compass-components'; +import { Menu, IconButton, Icon } from '@mongodb-js/compass-components'; import { addStage, removeStage, @@ -17,12 +9,7 @@ import { } from '../../modules/pipeline-builder/stage-editor'; import type { StoreStage } from '../../modules/pipeline-builder/stage-editor'; import type { RootState } from '../../modules'; - -const menuItemStyles = css({ - display: 'flex', - alignItems: 'center', - gap: spacing[2], -}); +import { OptionMenuItem } from './option-menu-item'; export const OptionMenu = ({ index, @@ -39,51 +26,6 @@ export const OptionMenu = ({ }) => { const [menuOpen, setMenuOpen] = useState(false); - const menuItems = useMemo(() => { - return [ - { - label: 'Add stage after', - onClick: () => { - onAddStageClick(index); - setMenuOpen(false); - }, - icon: 'PlusWithCircle', - }, - { - label: 'Add stage before', - onClick: () => { - onAddStageClick(index - 1); - setMenuOpen(false); - }, - icon: 'PlusWithCircle', - }, - { - label: 'Delete stage', - onClick: () => { - onDeleteStageClick(index); - setMenuOpen(false); - }, - icon: 'Trash', - }, - { - label: 'Expand documents', - onClick: () => { - onExpand(index); - setMenuOpen(false); - }, - icon: 'ChevronDown', - }, - { - label: 'Collapse documents', - onClick: () => { - onCollapse(index); - setMenuOpen(false); - }, - icon: 'ChevronUp', - }, - ]; - }, [index, onAddStageClick, onDeleteStageClick, onExpand, onCollapse]); - return ( - {menuItems.map((item) => ( - -
- - {item.label} -
-
- ))} + onAddStageClick(index)} + setMenuOpen={setMenuOpen} + /> + onAddStageClick(index - 1)} + setMenuOpen={setMenuOpen} + /> + onDeleteStageClick(index)} + setMenuOpen={setMenuOpen} + /> + onExpand(index)} + setMenuOpen={setMenuOpen} + /> + onCollapse(index)} + setMenuOpen={setMenuOpen} + />
); }; diff --git a/packages/compass-components/src/components/workspace-tabs/tab.tsx b/packages/compass-components/src/components/workspace-tabs/tab.tsx index c3316a5549f..93eb17de931 100644 --- a/packages/compass-components/src/components/workspace-tabs/tab.tsx +++ b/packages/compass-components/src/components/workspace-tabs/tab.tsx @@ -2,7 +2,7 @@ import React, { useMemo } from 'react'; import { css, cx } from '@leafygreen-ui/emotion'; import { palette } from '@leafygreen-ui/palette'; import { spacing } from '@leafygreen-ui/tokens'; -import type { glyphs } from '@leafygreen-ui/icon'; +import type { GlyphName } from '@leafygreen-ui/icon'; import { useSortable } from '@dnd-kit/sortable'; import { CSS as cssDndKit } from '@dnd-kit/utilities'; import { useDarkMode } from '../../hooks/use-theme'; @@ -180,8 +180,6 @@ const closeButtonStyles = css({ marginRight: spacing[100], }); -type IconGlyph = Extract; - type TabProps = { connectionName?: string; type: string; @@ -190,7 +188,7 @@ type TabProps = { isDragging: boolean; onSelect: () => void; onClose: () => void; - iconGlyph: IconGlyph | 'Logo' | 'Server'; + iconGlyph: GlyphName | 'Logo' | 'Server'; tabContentId: string; tooltip?: [string, string][]; tabTheme?: Partial; diff --git a/packages/compass-components/src/components/workspace-tabs/workspace-tabs.tsx b/packages/compass-components/src/components/workspace-tabs/workspace-tabs.tsx index a7262e44df1..206647d4513 100644 --- a/packages/compass-components/src/components/workspace-tabs/workspace-tabs.tsx +++ b/packages/compass-components/src/components/workspace-tabs/workspace-tabs.tsx @@ -8,7 +8,7 @@ import React, { import { css, cx } from '@leafygreen-ui/emotion'; import { palette } from '@leafygreen-ui/palette'; import { spacing } from '@leafygreen-ui/tokens'; -import type { glyphs } from '@leafygreen-ui/icon'; +import type { GlyphName } from '@leafygreen-ui/icon'; import { rgba } from 'polished'; import { @@ -174,7 +174,7 @@ export type TabProps = { title: string; tooltip?: [string, string][]; connectionId?: string; - iconGlyph: Extract | 'Logo' | 'Server'; + iconGlyph: GlyphName | 'Logo' | 'Server'; } & Omit, 'id' | 'title'>; export function useRovingTabIndex({ diff --git a/packages/compass-components/src/index.ts b/packages/compass-components/src/index.ts index e89642c64bf..e2b797c24a5 100644 --- a/packages/compass-components/src/index.ts +++ b/packages/compass-components/src/index.ts @@ -143,14 +143,13 @@ export { FadeInPlaceholder, } from './components/content-with-fallback'; export { InlineDefinition } from './components/inline-definition'; -import type { glyphs } from '@leafygreen-ui/icon'; +export type { GlyphName } from '@leafygreen-ui/icon'; export { createGlyphComponent, createIconComponent } from '@leafygreen-ui/icon'; export { SignalPopover, SignalHooksProvider, } from './components/signal-popover'; export type { Signal } from './components/signal-popover'; -export type IconGlyph = Extract; export { EmptyContent } from './components/empty-content'; export { ErrorBoundary } from './components/error-boundary'; diff --git a/packages/compass-editor/src/action-button.tsx b/packages/compass-editor/src/action-button.tsx index cc483c910ec..81db806cd72 100644 --- a/packages/compass-editor/src/action-button.tsx +++ b/packages/compass-editor/src/action-button.tsx @@ -1,11 +1,11 @@ import { cx } from '@mongodb-js/compass-components'; import { css } from '@mongodb-js/compass-components'; -import { Button, Icon, type IconGlyph } from '@mongodb-js/compass-components'; +import { Button, Icon, type GlyphName } from '@mongodb-js/compass-components'; import React, { useCallback, useEffect, useState } from 'react'; import type { EditorView } from '@codemirror/view'; export type Action = { - icon: IconGlyph; + icon: GlyphName; label: string; action: (editor: EditorView) => boolean | void; }; diff --git a/packages/databases-collections-list/src/namespace-card.tsx b/packages/databases-collections-list/src/namespace-card.tsx index f5d6b544e61..2ba48cbe46c 100644 --- a/packages/databases-collections-list/src/namespace-card.tsx +++ b/packages/databases-collections-list/src/namespace-card.tsx @@ -20,7 +20,7 @@ import { } from '@mongodb-js/compass-components'; import type { BadgeVariant, - IconGlyph, + GlyphName, ItemAction, SignalPopover, } from '@mongodb-js/compass-components'; @@ -107,7 +107,7 @@ export type BadgeProp = { id: string; name: string; variant?: BadgeVariant; - icon?: IconGlyph; + icon?: GlyphName; hint?: React.ReactNode; };