[release-2.3] perf: add supports for force updating of post and single page settings (#913)

This is an automated cherry-pick of #907

/assign ruibaby

```release-note
支持强制保存文章和页面的设置,避免因为 Version 锁的机制导致保存失败。
```
pull/912/head^2
Halo Dev Bot 2023-03-15 14:24:26 +08:00 committed by GitHub
parent b33268997d
commit 6ec3ecc2e7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 85 additions and 17 deletions

View File

@ -17,6 +17,7 @@ import { toDatetimeLocal, toISOString } from "@/utils/date";
import { submitForm } from "@formkit/core";
import AnnotationsForm from "@/components/form/AnnotationsForm.vue";
import useSlugify from "@/composables/use-slugify";
import { useMutation } from "@tanstack/vue-query";
const initialFormState: SinglePage = {
spec: {
@ -110,6 +111,40 @@ const handlePublishClick = () => {
});
};
// Fix me:
// Force update post settings,
// because currently there may be errors caused by changes in version due to asynchronous processing.
const { mutateAsync: singlePageUpdateMutate } = useMutation({
mutationKey: ["singlePage-update"],
mutationFn: async (page: SinglePage) => {
const { data: latestSinglePage } =
await apiClient.extension.singlePage.getcontentHaloRunV1alpha1SinglePage({
name: page.metadata.name,
});
return apiClient.extension.singlePage.updatecontentHaloRunV1alpha1SinglePage(
{
name: page.metadata.name,
singlePage: {
...latestSinglePage,
spec: page.spec,
metadata: {
...latestSinglePage.metadata,
annotations: page.metadata.annotations,
},
},
},
{
mute: true,
}
);
},
retry: 3,
onError: (error) => {
console.error("Failed to update post", error);
Toast.error(`服务器内部错误`);
},
});
const handleSave = async () => {
annotationsFormRef.value?.handleSubmit();
await nextTick();
@ -133,15 +168,8 @@ const handleSave = async () => {
try {
saving.value = true;
saving.value = true;
const { data } = isUpdateMode.value
? await apiClient.extension.singlePage.updatecontentHaloRunV1alpha1SinglePage(
{
name: formState.value.metadata.name,
singlePage: formState.value,
}
)
? await singlePageUpdateMutate(formState.value)
: await apiClient.extension.singlePage.createcontentHaloRunV1alpha1SinglePage(
{
singlePage: formState.value,

View File

@ -17,6 +17,7 @@ import { toDatetimeLocal, toISOString } from "@/utils/date";
import AnnotationsForm from "@/components/form/AnnotationsForm.vue";
import { submitForm } from "@formkit/core";
import useSlugify from "@/composables/use-slugify";
import { useMutation } from "@tanstack/vue-query";
const initialFormState: Post = {
spec: {
@ -114,6 +115,40 @@ const handlePublishClick = () => {
});
};
// Fix me:
// Force update post settings,
// because currently there may be errors caused by changes in version due to asynchronous processing.
const { mutateAsync: postUpdateMutate } = useMutation({
mutationKey: ["post-update"],
mutationFn: async (post: Post) => {
const { data: latestPost } =
await apiClient.extension.post.getcontentHaloRunV1alpha1Post({
name: post.metadata.name,
});
return apiClient.extension.post.updatecontentHaloRunV1alpha1Post(
{
name: post.metadata.name,
post: {
...latestPost,
spec: post.spec,
metadata: {
...latestPost.metadata,
annotations: post.metadata.annotations,
},
},
},
{
mute: true,
}
);
},
retry: 3,
onError: (error) => {
console.error("Failed to update post", error);
Toast.error(`服务器内部错误`);
},
});
const handleSave = async () => {
annotationsFormRef.value?.handleSubmit();
await nextTick();
@ -139,10 +174,7 @@ const handleSave = async () => {
saving.value = true;
const { data } = isUpdateMode.value
? await apiClient.extension.post.updatecontentHaloRunV1alpha1Post({
name: formState.value.metadata.name,
post: formState.value,
})
? await postUpdateMutate(formState.value)
: await apiClient.extension.post.createcontentHaloRunV1alpha1Post({
post: formState.value,
});

View File

@ -2,6 +2,7 @@ import { beforeEach, describe, expect, it } from "vitest";
import { mount } from "@vue/test-utils";
import PostSettingModal from "../PostSettingModal.vue";
import { createPinia, setActivePinia } from "pinia";
import { VueQueryPlugin } from "@tanstack/vue-query";
describe("PostSettingModal", () => {
beforeEach(() => {
@ -9,12 +10,19 @@ describe("PostSettingModal", () => {
});
it("should render", () => {
const wrapper = mount({
components: {
PostSettingModal,
const wrapper = mount(
{
components: {
PostSettingModal,
},
template: `<PostSettingModal></PostSettingModal>`,
},
template: `<PostSettingModal></PostSettingModal>`,
});
{
global: {
plugins: [VueQueryPlugin],
},
}
);
expect(wrapper).toBeDefined();
});
});