fix title update (#1154)
This commit is contained in:
parent
3a75251e75
commit
00f4588c21
2 changed files with 33 additions and 21 deletions
|
|
@ -10,7 +10,7 @@ import {
|
||||||
pageEditorAtom,
|
pageEditorAtom,
|
||||||
titleEditorAtom,
|
titleEditorAtom,
|
||||||
} from "@/features/editor/atoms/editor-atoms";
|
} from "@/features/editor/atoms/editor-atoms";
|
||||||
import { useUpdatePageMutation } from "@/features/page/queries/page-query";
|
import { updatePageData, useUpdateTitlePageMutation } from "@/features/page/queries/page-query";
|
||||||
import { useDebouncedCallback } from "@mantine/hooks";
|
import { useDebouncedCallback } from "@mantine/hooks";
|
||||||
import { useAtom } from "jotai";
|
import { useAtom } from "jotai";
|
||||||
import { useQueryEmit } from "@/features/websocket/use-query-emit.ts";
|
import { useQueryEmit } from "@/features/websocket/use-query-emit.ts";
|
||||||
|
|
@ -38,7 +38,7 @@ export function TitleEditor({
|
||||||
editable,
|
editable,
|
||||||
}: TitleEditorProps) {
|
}: TitleEditorProps) {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
const { mutateAsync: updatePageMutationAsync } = useUpdatePageMutation();
|
const { mutateAsync: updateTitlePageMutationAsync } = useUpdateTitlePageMutation();
|
||||||
const pageEditor = useAtomValue(pageEditorAtom);
|
const pageEditor = useAtomValue(pageEditorAtom);
|
||||||
const [, setTitleEditor] = useAtom(titleEditorAtom);
|
const [, setTitleEditor] = useAtom(titleEditorAtom);
|
||||||
const emit = useQueryEmit();
|
const emit = useQueryEmit();
|
||||||
|
|
@ -94,7 +94,7 @@ export function TitleEditor({
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
updatePageMutationAsync({
|
updateTitlePageMutationAsync({
|
||||||
pageId: pageId,
|
pageId: pageId,
|
||||||
title: titleEditor.getText(),
|
title: titleEditor.getText(),
|
||||||
}).then((page) => {
|
}).then((page) => {
|
||||||
|
|
@ -106,6 +106,10 @@ export function TitleEditor({
|
||||||
payload: { title: page.title, slugId: page.slugId },
|
payload: { title: page.title, slugId: page.slugId },
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (page.title !== titleEditor.getText()) return;
|
||||||
|
|
||||||
|
updatePageData(page);
|
||||||
|
|
||||||
localEmitter.emit("message", event);
|
localEmitter.emit("message", event);
|
||||||
emit(event);
|
emit(event);
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -63,28 +63,36 @@ export function useCreatePageMutation() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export function useUpdatePageMutation() {
|
export function updatePageData(data: IPage) {
|
||||||
const queryClient = useQueryClient();
|
const pageBySlug = queryClient.getQueryData<IPage>([
|
||||||
|
"pages",
|
||||||
|
data.slugId,
|
||||||
|
]);
|
||||||
|
const pageById = queryClient.getQueryData<IPage>(["pages", data.id]);
|
||||||
|
|
||||||
|
if (pageBySlug) {
|
||||||
|
queryClient.setQueryData(["pages", data.slugId], {
|
||||||
|
...pageBySlug,
|
||||||
|
...data,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
if (pageById) {
|
||||||
|
queryClient.setQueryData(["pages", data.id], { ...pageById, ...data });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export function useUpdateTitlePageMutation() {
|
||||||
|
return useMutation<IPage, Error, Partial<IPageInput>>({
|
||||||
|
mutationFn: (data) => updatePage(data),
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
export function useUpdatePageMutation() {
|
||||||
return useMutation<IPage, Error, Partial<IPageInput>>({
|
return useMutation<IPage, Error, Partial<IPageInput>>({
|
||||||
mutationFn: (data) => updatePage(data),
|
mutationFn: (data) => updatePage(data),
|
||||||
onSuccess: (data) => {
|
onSuccess: (data) => {
|
||||||
const pageBySlug = queryClient.getQueryData<IPage>([
|
updatePage(data);
|
||||||
"pages",
|
|
||||||
data.slugId,
|
|
||||||
]);
|
|
||||||
const pageById = queryClient.getQueryData<IPage>(["pages", data.id]);
|
|
||||||
|
|
||||||
if (pageBySlug) {
|
|
||||||
queryClient.setQueryData(["pages", data.slugId], {
|
|
||||||
...pageBySlug,
|
|
||||||
...data,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (pageById) {
|
|
||||||
queryClient.setQueryData(["pages", data.id], { ...pageById, ...data });
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue