hooks.tsx 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103
  1. import { useCallback, useState } from 'react';
  2. import { useTranslation } from 'next-i18next';
  3. import { useRouter } from 'next/router';
  4. import { createPage, exist } from '~/client/services/page-operation';
  5. import { toastError } from '~/client/util/toastr';
  6. import { LabelType } from '~/interfaces/template';
  7. import { useIsNotFound } from '~/stores/page';
  8. import { EditorMode, useEditorMode } from '~/stores/ui';
  9. import loggerFactory from '~/utils/logger';
  10. const logger = loggerFactory('growi:Navbar:GrowiContextualSubNavigation');
  11. export const useOnPageEditorModeButtonClicked = (
  12. setIsCreating:React.Dispatch<React.SetStateAction<boolean>>,
  13. path?: string,
  14. // grant?: number,
  15. // grantUserGroupId?: string,
  16. ): (editorMode: EditorMode) => Promise<void> => {
  17. const router = useRouter();
  18. const { t } = useTranslation('commons');
  19. const { data: isNotFound } = useIsNotFound();
  20. const { mutate: mutateEditorMode } = useEditorMode();
  21. return useCallback(async(editorMode: EditorMode) => {
  22. if (isNotFound == null || path == null) {
  23. return;
  24. }
  25. if (editorMode === EditorMode.Editor && isNotFound) {
  26. try {
  27. setIsCreating(true);
  28. const params = {
  29. isSlackEnabled: false,
  30. slackChannels: '',
  31. grant: 4,
  32. // grant,
  33. // grantUserGroupId,
  34. };
  35. const response = await createPage(path, '', params);
  36. // Should not mutateEditorMode as it might prevent transitioning during mutation
  37. router.push(`${response.page.id}#edit`);
  38. }
  39. catch (err) {
  40. logger.warn(err);
  41. toastError(t('toaster.create_failed', { target: path }));
  42. }
  43. finally {
  44. setIsCreating(false);
  45. }
  46. }
  47. mutateEditorMode(editorMode);
  48. }, [isNotFound, mutateEditorMode, path, router, setIsCreating, t]);
  49. };
  50. export const useOnTemplateButtonClicked = (
  51. currentPagePath: string,
  52. ): {
  53. onClickHandler: (label: LabelType) => Promise<void>,
  54. isPageCreating: boolean
  55. } => {
  56. const router = useRouter();
  57. const [isPageCreating, setIsPageCreating] = useState(false);
  58. const onClickHandler = useCallback(async(label: LabelType) => {
  59. try {
  60. setIsPageCreating(true);
  61. const path = currentPagePath == null || currentPagePath === '/'
  62. ? `/${label}`
  63. : `${currentPagePath}/${label}`;
  64. const params = {
  65. isSlackEnabled: false,
  66. slackChannels: '',
  67. grant: 4,
  68. // grant: currentPage?.grant || 1,
  69. // grantUserGroupId: currentPage?.grantedGroup?._id,
  70. };
  71. const res = await exist(JSON.stringify([path]));
  72. if (!res.pages[path]) {
  73. await createPage(path, '', params);
  74. }
  75. router.push(`${path}#edit`);
  76. }
  77. catch (err) {
  78. logger.warn(err);
  79. toastError(err);
  80. }
  81. finally {
  82. setIsPageCreating(false);
  83. }
  84. }, [currentPagePath, router]);
  85. return { onClickHandler, isPageCreating };
  86. };