generated from pascalmartineau/wp-skeleton
refactor: sections-map
All checks were successful
Deploy WordPress and Nuxt / deploy (push) Successful in 1m6s
All checks were successful
Deploy WordPress and Nuxt / deploy (push) Successful in 1m6s
This commit is contained in:
@@ -1,14 +1,13 @@
|
||||
import { renderToString } from "vue/server-renderer";
|
||||
import { createSSRApp, h } from "vue";
|
||||
import type { TheSectionFragment } from "#graphql-operations";
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
const { fieldGroupName, ...attrs } = await readBody(event);
|
||||
const componentName = fieldGroupName.replace(/^GroupAbstractBuilder(.*)Layout$/, "Section$1");
|
||||
const { fieldGroupName, ...attrs } = await readBody<TheSectionFragment>(event);
|
||||
try {
|
||||
const componentModule = await import(`../../app/components/sections/${componentName}.vue`);
|
||||
const app = createSSRApp({
|
||||
render() {
|
||||
return h(componentModule.default, attrs);
|
||||
return h(sectionsMap[fieldGroupName as FieldGroupName], attrs);
|
||||
},
|
||||
});
|
||||
const html = await renderToString(app);
|
||||
@@ -16,6 +15,6 @@ export default defineEventHandler(async (event) => {
|
||||
}
|
||||
catch (error) {
|
||||
const message = error instanceof Error ? error.message : "Une erreur est survenue.";
|
||||
throw createError({ statusCode: 500, statusMessage: "Erreur interne", message });
|
||||
return `<div style="color: red">${message}</div>`;
|
||||
}
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user