BookmarkFolderItemControl.tsx 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. import React, { useState } from 'react';
  2. import { useTranslation } from 'next-i18next';
  3. import {
  4. Dropdown, DropdownItem, DropdownMenu, DropdownToggle,
  5. } from 'reactstrap';
  6. export const BookmarkFolderItemControl: React.FC<{
  7. children?: React.ReactNode
  8. onClickMoveToRoot?: () => Promise<void>
  9. onClickRename: () => void
  10. onClickDelete: () => void
  11. }> = ({
  12. children,
  13. onClickMoveToRoot,
  14. onClickRename,
  15. onClickDelete,
  16. }): JSX.Element => {
  17. const { t } = useTranslation();
  18. const [isOpen, setIsOpen] = useState(false);
  19. return (
  20. <Dropdown isOpen={isOpen} toggle={() => setIsOpen(!isOpen)}>
  21. { children ?? (
  22. <DropdownToggle color="transparent" className="border-0 rounded btn-page-item-control d-flex align-items-center justify-content-center">
  23. <span className="material-symbols-outlined">more_horiz</span>
  24. </DropdownToggle>
  25. ) }
  26. <DropdownMenu
  27. container="body"
  28. style={{ zIndex: 1055 }} /* make it larger than $zindex-modal of bootstrap */
  29. >
  30. {onClickMoveToRoot && (
  31. <DropdownItem
  32. onClick={onClickMoveToRoot}
  33. className="grw-page-control-dropdown-item"
  34. >
  35. <span className="material-symbols-outlined grw-page-control-dropdown-icon">bookmark</span>
  36. {t('bookmark_folder.move_to_root')}
  37. </DropdownItem>
  38. )}
  39. <DropdownItem
  40. onClick={onClickRename}
  41. className="grw-page-control-dropdown-item"
  42. >
  43. <span className="material-symbols-outlined me-1 grw-page-control-dropdown-icon">redo</span>
  44. {t('Rename')}
  45. </DropdownItem>
  46. <DropdownItem divider />
  47. <DropdownItem
  48. className="pt-2 grw-page-control-dropdown-item text-danger"
  49. onClick={onClickDelete}
  50. >
  51. <span className="material-symbols-outlined me-1 grw-page-control-dropdown-icon">delete</span>
  52. {t('Delete')}
  53. </DropdownItem>
  54. </DropdownMenu>
  55. </Dropdown>
  56. );
  57. };