hooks.tsx 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. import { useCallback } from 'react';
  2. import { useTranslation } from 'next-i18next';
  3. import { useRouter } from 'next/router';
  4. import { createPage } from '~/client/services/page-operation';
  5. import { toastError } from '~/client/util/toastr';
  6. import { useIsNotFound } from '~/stores/page';
  7. import { EditorMode, useEditorMode } from '~/stores/ui';
  8. import loggerFactory from '~/utils/logger';
  9. const logger = loggerFactory('growi:Navbar:GrowiContextualSubNavigation');
  10. export const useOnPageEditorModeButtonClicked = (
  11. setIsCreating:React.Dispatch<React.SetStateAction<boolean>>,
  12. path?: string,
  13. grant?: number,
  14. grantUserGroupId?: string,
  15. ): (editorMode: EditorMode) => Promise<void> => {
  16. const router = useRouter();
  17. const { t } = useTranslation('commons');
  18. const { data: isNotFound } = useIsNotFound();
  19. const { mutate: mutateEditorMode } = useEditorMode();
  20. return useCallback(async(editorMode: EditorMode) => {
  21. if (isNotFound == null || path == null || grant == null) {
  22. return;
  23. }
  24. if (editorMode === EditorMode.Editor && isNotFound) {
  25. try {
  26. setIsCreating(true);
  27. const params = {
  28. isSlackEnabled: false,
  29. slackChannels: '',
  30. grant,
  31. pageTags: [],
  32. grantUserGroupId,
  33. };
  34. const response = await createPage(path, '', params);
  35. // Should not mutateEditorMode as it might prevent transitioning during mutation
  36. router.push(`${response.page.id}#edit`);
  37. }
  38. catch (err) {
  39. logger.warn(err);
  40. toastError(t('toaster.create_failed', { target: path }));
  41. }
  42. finally {
  43. setIsCreating(false);
  44. }
  45. }
  46. mutateEditorMode(editorMode);
  47. }, [grant, grantUserGroupId, isNotFound, mutateEditorMode, path, router, setIsCreating, t]);
  48. };