* updated DropdownButton props * refactoring in progress * working but layout is wrong * fixed bug * wip on ColumnHeadWithDropdown * fix bug * fix bug * remove unused styled component * fix z-index bug * add an optional argument to DropdownMenu to control the offset of the menu * add an optional argument to DropdownMenu to control the offset of the menu * modify files after PR comments * clean the way the offset is handled * fix lint
66 lines
1.8 KiB
TypeScript
66 lines
1.8 KiB
TypeScript
import { ReactNode } from 'react';
|
|
|
|
import { useDropdown } from '@/ui/dropdown/hooks/useDropdown';
|
|
import { TopBar } from '@/ui/top-bar/TopBar';
|
|
|
|
import { FiltersHotkeyScope } from '../types/FiltersHotkeyScope';
|
|
import { ViewsHotkeyScope } from '../types/ViewsHotkeyScope';
|
|
|
|
import { FilterDropdownButton } from './FilterDropdownButton';
|
|
import { SortDropdownButton } from './SortDropdownButton';
|
|
import { UpdateViewButtonGroup } from './UpdateViewButtonGroup';
|
|
import { ViewBarDetails } from './ViewBarDetails';
|
|
import { ViewsDropdownButton } from './ViewsDropdownButton';
|
|
|
|
export type ViewBarProps = {
|
|
className?: string;
|
|
optionsDropdownButton: ReactNode;
|
|
optionsDropdownKey: string;
|
|
};
|
|
|
|
export const ViewBar = ({
|
|
className,
|
|
optionsDropdownButton,
|
|
optionsDropdownKey,
|
|
}: ViewBarProps) => {
|
|
const { openDropdown: openOptionsDropdownButton } = useDropdown({
|
|
dropdownId: optionsDropdownKey,
|
|
});
|
|
|
|
return (
|
|
<TopBar
|
|
className={className}
|
|
leftComponent={
|
|
<ViewsDropdownButton
|
|
onViewEditModeChange={openOptionsDropdownButton}
|
|
hotkeyScope={{ scope: ViewsHotkeyScope.ListDropdown }}
|
|
/>
|
|
}
|
|
displayBottomBorder={false}
|
|
rightComponent={
|
|
<>
|
|
<FilterDropdownButton
|
|
hotkeyScope={{ scope: FiltersHotkeyScope.FilterDropdownButton }}
|
|
/>
|
|
<SortDropdownButton
|
|
hotkeyScope={{ scope: FiltersHotkeyScope.SortDropdownButton }}
|
|
isPrimaryButton
|
|
/>
|
|
{optionsDropdownButton}
|
|
</>
|
|
}
|
|
bottomComponent={
|
|
<ViewBarDetails
|
|
hasFilterButton
|
|
rightComponent={
|
|
<UpdateViewButtonGroup
|
|
onViewEditModeChange={openOptionsDropdownButton}
|
|
hotkeyScope={ViewsHotkeyScope.CreateDropdown}
|
|
/>
|
|
}
|
|
/>
|
|
}
|
|
/>
|
|
);
|
|
};
|