BookmarkFolderItemControl.tsx 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  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. { isOpen && (
  27. <DropdownMenu
  28. container="body"
  29. style={{ zIndex: 1055 }}
  30. >
  31. {onClickMoveToRoot && (
  32. <DropdownItem
  33. onClick={onClickMoveToRoot}
  34. className="grw-page-control-dropdown-item"
  35. >
  36. <span className="material-symbols-outlined grw-page-control-dropdown-icon">bookmark</span>
  37. {t('bookmark_folder.move_to_root')}
  38. </DropdownItem>
  39. )}
  40. <DropdownItem
  41. onClick={onClickRename}
  42. className="grw-page-control-dropdown-item"
  43. >
  44. <span className="material-symbols-outlined me-1 grw-page-control-dropdown-icon">redo</span>
  45. {t('Rename')}
  46. </DropdownItem>
  47. <DropdownItem divider />
  48. <DropdownItem
  49. className="pt-2 grw-page-control-dropdown-item text-danger"
  50. onClick={onClickDelete}
  51. >
  52. <span className="material-symbols-outlined me-1 grw-page-control-dropdown-icon">delete</span>
  53. {t('Delete')}
  54. </DropdownItem>
  55. </DropdownMenu>
  56. ) }
  57. </Dropdown>
  58. );
  59. };